@rxflow/base 0.0.2 → 0.0.4-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/Flow.d.ts +1 -1
- package/cjs/Flow.d.ts.map +1 -1
- package/cjs/Flow.js +28 -10
- package/cjs/components/Legend/index.d.ts.map +1 -1
- package/cjs/components/Legend/index.js +2 -1
- package/cjs/components/Popover/index.d.ts +1 -9
- package/cjs/components/Popover/index.d.ts.map +1 -1
- package/cjs/components/Popover/index.js +14 -75
- package/cjs/components/Tooltip/index.d.ts +1 -10
- package/cjs/components/Tooltip/index.d.ts.map +1 -1
- package/cjs/components/Tooltip/index.js +11 -83
- package/cjs/edges/manhattan.d.ts.map +1 -1
- package/cjs/edges/manhattan.js +100 -30
- package/cjs/hoc/createFlow.d.ts +30 -4
- package/cjs/hoc/createFlow.d.ts.map +1 -1
- package/cjs/hoc/createFlow.js +45 -18
- package/cjs/hooks/index.d.ts +5 -2
- package/cjs/hooks/index.d.ts.map +1 -1
- package/cjs/hooks/index.js +44 -22
- package/cjs/hooks/props/index.d.ts +12 -0
- package/cjs/hooks/props/index.d.ts.map +1 -0
- package/cjs/hooks/props/index.js +49 -0
- package/cjs/hooks/props/useFlowProps.d.ts +23 -0
- package/cjs/hooks/props/useFlowProps.d.ts.map +1 -0
- package/cjs/hooks/props/useFlowProps.js +34 -0
- package/cjs/hooks/props/useGetFlowProps.d.ts +19 -0
- package/cjs/hooks/props/useGetFlowProps.d.ts.map +1 -0
- package/cjs/hooks/props/useGetFlowProps.js +38 -0
- package/cjs/hooks/props/useGetInputProps.d.ts +18 -0
- package/cjs/hooks/props/useGetInputProps.d.ts.map +1 -0
- package/cjs/hooks/props/useGetInputProps.js +38 -0
- package/cjs/hooks/props/useInputProps.d.ts +14 -0
- package/cjs/hooks/props/useInputProps.d.ts.map +1 -0
- package/cjs/hooks/props/useInputProps.js +33 -0
- package/cjs/hooks/useListenRender.js +4 -4
- package/cjs/hooks/useTheme.d.ts.map +1 -1
- package/cjs/hooks/useTheme.js +3 -2
- package/cjs/index.d.ts +6 -3
- package/cjs/index.d.ts.map +1 -1
- package/cjs/index.js +46 -14
- package/cjs/providers/FlowProvider.d.ts +7 -1
- package/cjs/providers/FlowProvider.d.ts.map +1 -1
- package/cjs/providers/FlowProvider.js +33 -14
- package/cjs/store/PropsStore.d.ts +11 -6
- package/cjs/store/PropsStore.d.ts.map +1 -1
- package/cjs/store/PropsStore.js +55 -39
- package/cjs/types/props.d.ts +83 -0
- package/cjs/types/props.d.ts.map +1 -0
- package/cjs/types/props.js +5 -0
- package/cjs/types.d.ts +5 -1
- package/cjs/types.d.ts.map +1 -1
- package/cjs/utils/wrapNodeTypes.d.ts +30 -0
- package/cjs/utils/wrapNodeTypes.d.ts.map +1 -0
- package/cjs/utils/wrapNodeTypes.js +56 -0
- package/cjs/workers/manhattan.worker.js +12534 -31
- package/cjs/workers/manhattan.worker.js.map +7 -0
- package/esm/Flow.d.ts +1 -1
- package/esm/Flow.d.ts.map +1 -1
- package/esm/Flow.js +30 -16
- package/esm/components/Legend/index.d.ts.map +1 -1
- package/esm/components/Legend/index.js +3 -2
- package/esm/components/Popover/index.d.ts +1 -9
- package/esm/components/Popover/index.d.ts.map +1 -1
- package/esm/components/Popover/index.js +16 -87
- package/esm/components/Tooltip/index.d.ts +1 -10
- package/esm/components/Tooltip/index.d.ts.map +1 -1
- package/esm/components/Tooltip/index.js +14 -97
- package/esm/edges/manhattan.d.ts.map +1 -1
- package/esm/edges/manhattan.js +95 -23
- package/esm/hoc/createFlow.d.ts +30 -4
- package/esm/hoc/createFlow.d.ts.map +1 -1
- package/esm/hoc/createFlow.js +48 -20
- package/esm/hooks/index.d.ts +5 -2
- package/esm/hooks/index.d.ts.map +1 -1
- package/esm/hooks/index.js +8 -3
- package/esm/hooks/props/index.d.ts +12 -0
- package/esm/hooks/props/index.d.ts.map +1 -0
- package/esm/hooks/props/index.js +12 -0
- package/esm/hooks/props/useFlowProps.d.ts +23 -0
- package/esm/hooks/props/useFlowProps.d.ts.map +1 -0
- package/esm/hooks/props/useFlowProps.js +29 -0
- package/esm/hooks/props/useGetFlowProps.d.ts +19 -0
- package/esm/hooks/props/useGetFlowProps.d.ts.map +1 -0
- package/esm/hooks/props/useGetFlowProps.js +31 -0
- package/esm/hooks/props/useGetInputProps.d.ts +18 -0
- package/esm/hooks/props/useGetInputProps.d.ts.map +1 -0
- package/esm/hooks/props/useGetInputProps.js +31 -0
- package/esm/hooks/props/useInputProps.d.ts +14 -0
- package/esm/hooks/props/useInputProps.d.ts.map +1 -0
- package/esm/hooks/props/useInputProps.js +27 -0
- package/esm/hooks/useListenRender.js +4 -4
- package/esm/hooks/useTheme.d.ts.map +1 -1
- package/esm/hooks/useTheme.js +3 -2
- package/esm/index.d.ts +6 -3
- package/esm/index.d.ts.map +1 -1
- package/esm/index.js +22 -3
- package/esm/providers/FlowProvider.d.ts +7 -1
- package/esm/providers/FlowProvider.d.ts.map +1 -1
- package/esm/providers/FlowProvider.js +36 -15
- package/esm/store/PropsStore.d.ts +11 -6
- package/esm/store/PropsStore.d.ts.map +1 -1
- package/esm/store/PropsStore.js +75 -34
- package/esm/types/props.d.ts +83 -0
- package/esm/types/props.d.ts.map +1 -0
- package/esm/types/props.js +1 -0
- package/esm/types.d.ts +5 -1
- package/esm/types.d.ts.map +1 -1
- package/esm/utils/wrapNodeTypes.d.ts +30 -0
- package/esm/utils/wrapNodeTypes.d.ts.map +1 -0
- package/esm/utils/wrapNodeTypes.js +55 -0
- package/esm/workers/manhattan.worker.js +1 -1
- package/esm/workers/manhattan.worker.js.map +7 -0
- package/package.json +5 -3
- package/cjs/hooks/props/useGetProps.d.ts +0 -6
- package/cjs/hooks/props/useGetProps.d.ts.map +0 -1
- package/cjs/hooks/props/useGetProps.js +0 -29
- package/cjs/hooks/props/useProps.d.ts +0 -2
- package/cjs/hooks/props/useProps.d.ts.map +0 -1
- package/cjs/hooks/props/useProps.js +0 -20
- package/cjs/hooks/props/usePropsSelector.d.ts +0 -13
- package/cjs/hooks/props/usePropsSelector.d.ts.map +0 -1
- package/cjs/hooks/props/usePropsSelector.js +0 -37
- package/esm/hooks/props/useGetProps.d.ts +0 -6
- package/esm/hooks/props/useGetProps.d.ts.map +0 -1
- package/esm/hooks/props/useGetProps.js +0 -21
- package/esm/hooks/props/useProps.d.ts +0 -2
- package/esm/hooks/props/useProps.d.ts.map +0 -1
- package/esm/hooks/props/useProps.js +0 -14
- package/esm/hooks/props/usePropsSelector.d.ts +0 -13
- package/esm/hooks/props/usePropsSelector.d.ts.map +0 -1
- package/esm/hooks/props/usePropsSelector.js +0 -31
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../node_modules/react/cjs/react-jsx-runtime.production.js", "../../../../node_modules/react/jsx-runtime.js", "../../../../node_modules/react/cjs/react.production.js", "../../../../node_modules/react/index.js", "../../../../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js", "../../../../node_modules/use-sync-external-store/shim/index.js", "../../../../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.js", "../../../../node_modules/use-sync-external-store/shim/with-selector.js", "../../../../node_modules/react-dom/cjs/react-dom.production.js", "../../../../node_modules/react-dom/index.js", "../../../../node_modules/comlink/src/comlink.ts", "../../../../node_modules/@xyflow/react/dist/esm/index.js", "../../../../node_modules/classcat/index.js", "../../../../node_modules/d3-dispatch/src/dispatch.js", "../../../../node_modules/d3-selection/src/namespaces.js", "../../../../node_modules/d3-selection/src/namespace.js", "../../../../node_modules/d3-selection/src/creator.js", "../../../../node_modules/d3-selection/src/selector.js", "../../../../node_modules/d3-selection/src/selection/select.js", "../../../../node_modules/d3-selection/src/array.js", "../../../../node_modules/d3-selection/src/selectorAll.js", "../../../../node_modules/d3-selection/src/selection/selectAll.js", "../../../../node_modules/d3-selection/src/matcher.js", "../../../../node_modules/d3-selection/src/selection/selectChild.js", "../../../../node_modules/d3-selection/src/selection/selectChildren.js", "../../../../node_modules/d3-selection/src/selection/filter.js", "../../../../node_modules/d3-selection/src/selection/sparse.js", "../../../../node_modules/d3-selection/src/selection/enter.js", "../../../../node_modules/d3-selection/src/constant.js", "../../../../node_modules/d3-selection/src/selection/data.js", "../../../../node_modules/d3-selection/src/selection/exit.js", "../../../../node_modules/d3-selection/src/selection/join.js", "../../../../node_modules/d3-selection/src/selection/merge.js", "../../../../node_modules/d3-selection/src/selection/order.js", "../../../../node_modules/d3-selection/src/selection/sort.js", "../../../../node_modules/d3-selection/src/selection/call.js", "../../../../node_modules/d3-selection/src/selection/nodes.js", "../../../../node_modules/d3-selection/src/selection/node.js", "../../../../node_modules/d3-selection/src/selection/size.js", "../../../../node_modules/d3-selection/src/selection/empty.js", "../../../../node_modules/d3-selection/src/selection/each.js", "../../../../node_modules/d3-selection/src/selection/attr.js", "../../../../node_modules/d3-selection/src/window.js", "../../../../node_modules/d3-selection/src/selection/style.js", "../../../../node_modules/d3-selection/src/selection/property.js", "../../../../node_modules/d3-selection/src/selection/classed.js", "../../../../node_modules/d3-selection/src/selection/text.js", "../../../../node_modules/d3-selection/src/selection/html.js", "../../../../node_modules/d3-selection/src/selection/raise.js", "../../../../node_modules/d3-selection/src/selection/lower.js", "../../../../node_modules/d3-selection/src/selection/append.js", "../../../../node_modules/d3-selection/src/selection/insert.js", "../../../../node_modules/d3-selection/src/selection/remove.js", "../../../../node_modules/d3-selection/src/selection/clone.js", "../../../../node_modules/d3-selection/src/selection/datum.js", "../../../../node_modules/d3-selection/src/selection/on.js", "../../../../node_modules/d3-selection/src/selection/dispatch.js", "../../../../node_modules/d3-selection/src/selection/iterator.js", "../../../../node_modules/d3-selection/src/selection/index.js", "../../../../node_modules/d3-selection/src/select.js", "../../../../node_modules/d3-selection/src/sourceEvent.js", "../../../../node_modules/d3-selection/src/pointer.js", "../../../../node_modules/d3-drag/src/noevent.js", "../../../../node_modules/d3-drag/src/nodrag.js", "../../../../node_modules/d3-drag/src/constant.js", "../../../../node_modules/d3-drag/src/event.js", "../../../../node_modules/d3-drag/src/drag.js", "../../../../node_modules/d3-color/src/define.js", "../../../../node_modules/d3-color/src/color.js", "../../../../node_modules/d3-interpolate/src/basis.js", "../../../../node_modules/d3-interpolate/src/basisClosed.js", "../../../../node_modules/d3-interpolate/src/constant.js", "../../../../node_modules/d3-interpolate/src/color.js", "../../../../node_modules/d3-interpolate/src/rgb.js", "../../../../node_modules/d3-interpolate/src/numberArray.js", "../../../../node_modules/d3-interpolate/src/array.js", "../../../../node_modules/d3-interpolate/src/date.js", "../../../../node_modules/d3-interpolate/src/number.js", "../../../../node_modules/d3-interpolate/src/object.js", "../../../../node_modules/d3-interpolate/src/string.js", "../../../../node_modules/d3-interpolate/src/value.js", "../../../../node_modules/d3-interpolate/src/transform/decompose.js", "../../../../node_modules/d3-interpolate/src/transform/parse.js", "../../../../node_modules/d3-interpolate/src/transform/index.js", "../../../../node_modules/d3-interpolate/src/zoom.js", "../../../../node_modules/d3-timer/src/timer.js", "../../../../node_modules/d3-timer/src/timeout.js", "../../../../node_modules/d3-transition/src/transition/schedule.js", "../../../../node_modules/d3-transition/src/interrupt.js", "../../../../node_modules/d3-transition/src/selection/interrupt.js", "../../../../node_modules/d3-transition/src/transition/tween.js", "../../../../node_modules/d3-transition/src/transition/interpolate.js", "../../../../node_modules/d3-transition/src/transition/attr.js", "../../../../node_modules/d3-transition/src/transition/attrTween.js", "../../../../node_modules/d3-transition/src/transition/delay.js", "../../../../node_modules/d3-transition/src/transition/duration.js", "../../../../node_modules/d3-transition/src/transition/ease.js", "../../../../node_modules/d3-transition/src/transition/easeVarying.js", "../../../../node_modules/d3-transition/src/transition/filter.js", "../../../../node_modules/d3-transition/src/transition/merge.js", "../../../../node_modules/d3-transition/src/transition/on.js", "../../../../node_modules/d3-transition/src/transition/remove.js", "../../../../node_modules/d3-transition/src/transition/select.js", "../../../../node_modules/d3-transition/src/transition/selectAll.js", "../../../../node_modules/d3-transition/src/transition/selection.js", "../../../../node_modules/d3-transition/src/transition/style.js", "../../../../node_modules/d3-transition/src/transition/styleTween.js", "../../../../node_modules/d3-transition/src/transition/text.js", "../../../../node_modules/d3-transition/src/transition/textTween.js", "../../../../node_modules/d3-transition/src/transition/transition.js", "../../../../node_modules/d3-transition/src/transition/end.js", "../../../../node_modules/d3-transition/src/transition/index.js", "../../../../node_modules/d3-ease/src/cubic.js", "../../../../node_modules/d3-transition/src/selection/transition.js", "../../../../node_modules/d3-transition/src/selection/index.js", "../../../../node_modules/d3-zoom/src/constant.js", "../../../../node_modules/d3-zoom/src/event.js", "../../../../node_modules/d3-zoom/src/transform.js", "../../../../node_modules/d3-zoom/src/noevent.js", "../../../../node_modules/d3-zoom/src/zoom.js", "../../../../node_modules/@xyflow/react/node_modules/@xyflow/system/dist/esm/index.js", "../../../../node_modules/zustand/esm/traditional.mjs", "../../../../node_modules/zustand/esm/vanilla.mjs", "../../../../node_modules/zustand/esm/shallow.mjs", "../../../manhattan/src/geometry/Point.ts", "../../../manhattan/src/geometry/Rectangle.ts", "../../../manhattan/src/geometry/Line.ts", "../../../manhattan/src/utils/grid.ts", "../../../manhattan/src/options/defaults.ts", "../../../manhattan/src/utils/AdaptiveStepCalculator.ts", "../../../manhattan/src/options/resolver.ts", "../../../manhattan/src/utils/direction.ts", "../../../manhattan/src/utils/rect.ts", "../../../manhattan/src/utils/route.ts", "../../../manhattan/src/utils/node.ts", "../../../manhattan/src/utils/pathValidation.ts", "../../../manhattan/src/utils/ErrorRecovery.ts", "../../../manhattan/src/obstacle/QuadTree.ts", "../../../manhattan/src/obstacle/ObstacleMap.ts", "../../../manhattan/src/pathfinder/SortedSet.ts", "../../../manhattan/src/pathfinder/findRoute.ts", "../../../manhattan/src/svg/pathConverter.ts", "../../../manhattan/src/svg/pathParser.ts", "../../../manhattan/src/getManHattanPath.ts", "manhattan.worker.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * @license React\n * react-jsx-runtime.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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 */\n\n\"use strict\";\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\");\nfunction jsxProd(type, config, maybeKey) {\n var key = null;\n void 0 !== maybeKey && (key = \"\" + maybeKey);\n void 0 !== config.key && (key = \"\" + config.key);\n if (\"key\" in config) {\n maybeKey = {};\n for (var propName in config)\n \"key\" !== propName && (maybeKey[propName] = config[propName]);\n } else maybeKey = config;\n config = maybeKey.ref;\n return {\n $$typeof: REACT_ELEMENT_TYPE,\n type: type,\n key: key,\n ref: void 0 !== config ? config : null,\n props: maybeKey\n };\n}\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.jsx = jsxProd;\nexports.jsxs = jsxProd;\n", "'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\n", "/**\n * @license React\n * react.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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 */\n\n\"use strict\";\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\"),\n REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\"),\n REACT_ACTIVITY_TYPE = Symbol.for(\"react.activity\"),\n MAYBE_ITERATOR_SYMBOL = Symbol.iterator;\nfunction getIteratorFn(maybeIterable) {\n if (null === maybeIterable || \"object\" !== typeof maybeIterable) return null;\n maybeIterable =\n (MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL]) ||\n maybeIterable[\"@@iterator\"];\n return \"function\" === typeof maybeIterable ? maybeIterable : null;\n}\nvar ReactNoopUpdateQueue = {\n isMounted: function () {\n return !1;\n },\n enqueueForceUpdate: function () {},\n enqueueReplaceState: function () {},\n enqueueSetState: function () {}\n },\n assign = Object.assign,\n emptyObject = {};\nfunction Component(props, context, updater) {\n this.props = props;\n this.context = context;\n this.refs = emptyObject;\n this.updater = updater || ReactNoopUpdateQueue;\n}\nComponent.prototype.isReactComponent = {};\nComponent.prototype.setState = function (partialState, callback) {\n if (\n \"object\" !== typeof partialState &&\n \"function\" !== typeof partialState &&\n null != partialState\n )\n throw Error(\n \"takes an object of state variables to update or a function which returns an object of state variables.\"\n );\n this.updater.enqueueSetState(this, partialState, callback, \"setState\");\n};\nComponent.prototype.forceUpdate = function (callback) {\n this.updater.enqueueForceUpdate(this, callback, \"forceUpdate\");\n};\nfunction ComponentDummy() {}\nComponentDummy.prototype = Component.prototype;\nfunction PureComponent(props, context, updater) {\n this.props = props;\n this.context = context;\n this.refs = emptyObject;\n this.updater = updater || ReactNoopUpdateQueue;\n}\nvar pureComponentPrototype = (PureComponent.prototype = new ComponentDummy());\npureComponentPrototype.constructor = PureComponent;\nassign(pureComponentPrototype, Component.prototype);\npureComponentPrototype.isPureReactComponent = !0;\nvar isArrayImpl = Array.isArray;\nfunction noop() {}\nvar ReactSharedInternals = { H: null, A: null, T: null, S: null },\n hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction ReactElement(type, key, props) {\n var refProp = props.ref;\n return {\n $$typeof: REACT_ELEMENT_TYPE,\n type: type,\n key: key,\n ref: void 0 !== refProp ? refProp : null,\n props: props\n };\n}\nfunction cloneAndReplaceKey(oldElement, newKey) {\n return ReactElement(oldElement.type, newKey, oldElement.props);\n}\nfunction isValidElement(object) {\n return (\n \"object\" === typeof object &&\n null !== object &&\n object.$$typeof === REACT_ELEMENT_TYPE\n );\n}\nfunction escape(key) {\n var escaperLookup = { \"=\": \"=0\", \":\": \"=2\" };\n return (\n \"$\" +\n key.replace(/[=:]/g, function (match) {\n return escaperLookup[match];\n })\n );\n}\nvar userProvidedKeyEscapeRegex = /\\/+/g;\nfunction getElementKey(element, index) {\n return \"object\" === typeof element && null !== element && null != element.key\n ? escape(\"\" + element.key)\n : index.toString(36);\n}\nfunction resolveThenable(thenable) {\n switch (thenable.status) {\n case \"fulfilled\":\n return thenable.value;\n case \"rejected\":\n throw thenable.reason;\n default:\n switch (\n (\"string\" === typeof thenable.status\n ? thenable.then(noop, noop)\n : ((thenable.status = \"pending\"),\n thenable.then(\n function (fulfilledValue) {\n \"pending\" === thenable.status &&\n ((thenable.status = \"fulfilled\"),\n (thenable.value = fulfilledValue));\n },\n function (error) {\n \"pending\" === thenable.status &&\n ((thenable.status = \"rejected\"), (thenable.reason = error));\n }\n )),\n thenable.status)\n ) {\n case \"fulfilled\":\n return thenable.value;\n case \"rejected\":\n throw thenable.reason;\n }\n }\n throw thenable;\n}\nfunction mapIntoArray(children, array, escapedPrefix, nameSoFar, callback) {\n var type = typeof children;\n if (\"undefined\" === type || \"boolean\" === type) children = null;\n var invokeCallback = !1;\n if (null === children) invokeCallback = !0;\n else\n switch (type) {\n case \"bigint\":\n case \"string\":\n case \"number\":\n invokeCallback = !0;\n break;\n case \"object\":\n switch (children.$$typeof) {\n case REACT_ELEMENT_TYPE:\n case REACT_PORTAL_TYPE:\n invokeCallback = !0;\n break;\n case REACT_LAZY_TYPE:\n return (\n (invokeCallback = children._init),\n mapIntoArray(\n invokeCallback(children._payload),\n array,\n escapedPrefix,\n nameSoFar,\n callback\n )\n );\n }\n }\n if (invokeCallback)\n return (\n (callback = callback(children)),\n (invokeCallback =\n \"\" === nameSoFar ? \".\" + getElementKey(children, 0) : nameSoFar),\n isArrayImpl(callback)\n ? ((escapedPrefix = \"\"),\n null != invokeCallback &&\n (escapedPrefix =\n invokeCallback.replace(userProvidedKeyEscapeRegex, \"$&/\") + \"/\"),\n mapIntoArray(callback, array, escapedPrefix, \"\", function (c) {\n return c;\n }))\n : null != callback &&\n (isValidElement(callback) &&\n (callback = cloneAndReplaceKey(\n callback,\n escapedPrefix +\n (null == callback.key ||\n (children && children.key === callback.key)\n ? \"\"\n : (\"\" + callback.key).replace(\n userProvidedKeyEscapeRegex,\n \"$&/\"\n ) + \"/\") +\n invokeCallback\n )),\n array.push(callback)),\n 1\n );\n invokeCallback = 0;\n var nextNamePrefix = \"\" === nameSoFar ? \".\" : nameSoFar + \":\";\n if (isArrayImpl(children))\n for (var i = 0; i < children.length; i++)\n (nameSoFar = children[i]),\n (type = nextNamePrefix + getElementKey(nameSoFar, i)),\n (invokeCallback += mapIntoArray(\n nameSoFar,\n array,\n escapedPrefix,\n type,\n callback\n ));\n else if (((i = getIteratorFn(children)), \"function\" === typeof i))\n for (\n children = i.call(children), i = 0;\n !(nameSoFar = children.next()).done;\n\n )\n (nameSoFar = nameSoFar.value),\n (type = nextNamePrefix + getElementKey(nameSoFar, i++)),\n (invokeCallback += mapIntoArray(\n nameSoFar,\n array,\n escapedPrefix,\n type,\n callback\n ));\n else if (\"object\" === type) {\n if (\"function\" === typeof children.then)\n return mapIntoArray(\n resolveThenable(children),\n array,\n escapedPrefix,\n nameSoFar,\n callback\n );\n array = String(children);\n throw Error(\n \"Objects are not valid as a React child (found: \" +\n (\"[object Object]\" === array\n ? \"object with keys {\" + Object.keys(children).join(\", \") + \"}\"\n : array) +\n \"). If you meant to render a collection of children, use an array instead.\"\n );\n }\n return invokeCallback;\n}\nfunction mapChildren(children, func, context) {\n if (null == children) return children;\n var result = [],\n count = 0;\n mapIntoArray(children, result, \"\", \"\", function (child) {\n return func.call(context, child, count++);\n });\n return result;\n}\nfunction lazyInitializer(payload) {\n if (-1 === payload._status) {\n var ctor = payload._result;\n ctor = ctor();\n ctor.then(\n function (moduleObject) {\n if (0 === payload._status || -1 === payload._status)\n (payload._status = 1), (payload._result = moduleObject);\n },\n function (error) {\n if (0 === payload._status || -1 === payload._status)\n (payload._status = 2), (payload._result = error);\n }\n );\n -1 === payload._status && ((payload._status = 0), (payload._result = ctor));\n }\n if (1 === payload._status) return payload._result.default;\n throw payload._result;\n}\nvar reportGlobalError =\n \"function\" === typeof reportError\n ? reportError\n : function (error) {\n if (\n \"object\" === typeof window &&\n \"function\" === typeof window.ErrorEvent\n ) {\n var event = new window.ErrorEvent(\"error\", {\n bubbles: !0,\n cancelable: !0,\n message:\n \"object\" === typeof error &&\n null !== error &&\n \"string\" === typeof error.message\n ? String(error.message)\n : String(error),\n error: error\n });\n if (!window.dispatchEvent(event)) return;\n } else if (\n \"object\" === typeof process &&\n \"function\" === typeof process.emit\n ) {\n process.emit(\"uncaughtException\", error);\n return;\n }\n console.error(error);\n },\n Children = {\n map: mapChildren,\n forEach: function (children, forEachFunc, forEachContext) {\n mapChildren(\n children,\n function () {\n forEachFunc.apply(this, arguments);\n },\n forEachContext\n );\n },\n count: function (children) {\n var n = 0;\n mapChildren(children, function () {\n n++;\n });\n return n;\n },\n toArray: function (children) {\n return (\n mapChildren(children, function (child) {\n return child;\n }) || []\n );\n },\n only: function (children) {\n if (!isValidElement(children))\n throw Error(\n \"React.Children.only expected to receive a single React element child.\"\n );\n return children;\n }\n };\nexports.Activity = REACT_ACTIVITY_TYPE;\nexports.Children = Children;\nexports.Component = Component;\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.Profiler = REACT_PROFILER_TYPE;\nexports.PureComponent = PureComponent;\nexports.StrictMode = REACT_STRICT_MODE_TYPE;\nexports.Suspense = REACT_SUSPENSE_TYPE;\nexports.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE =\n ReactSharedInternals;\nexports.__COMPILER_RUNTIME = {\n __proto__: null,\n c: function (size) {\n return ReactSharedInternals.H.useMemoCache(size);\n }\n};\nexports.cache = function (fn) {\n return function () {\n return fn.apply(null, arguments);\n };\n};\nexports.cacheSignal = function () {\n return null;\n};\nexports.cloneElement = function (element, config, children) {\n if (null === element || void 0 === element)\n throw Error(\n \"The argument must be a React element, but you passed \" + element + \".\"\n );\n var props = assign({}, element.props),\n key = element.key;\n if (null != config)\n for (propName in (void 0 !== config.key && (key = \"\" + config.key), config))\n !hasOwnProperty.call(config, propName) ||\n \"key\" === propName ||\n \"__self\" === propName ||\n \"__source\" === propName ||\n (\"ref\" === propName && void 0 === config.ref) ||\n (props[propName] = config[propName]);\n var propName = arguments.length - 2;\n if (1 === propName) props.children = children;\n else if (1 < propName) {\n for (var childArray = Array(propName), i = 0; i < propName; i++)\n childArray[i] = arguments[i + 2];\n props.children = childArray;\n }\n return ReactElement(element.type, key, props);\n};\nexports.createContext = function (defaultValue) {\n defaultValue = {\n $$typeof: REACT_CONTEXT_TYPE,\n _currentValue: defaultValue,\n _currentValue2: defaultValue,\n _threadCount: 0,\n Provider: null,\n Consumer: null\n };\n defaultValue.Provider = defaultValue;\n defaultValue.Consumer = {\n $$typeof: REACT_CONSUMER_TYPE,\n _context: defaultValue\n };\n return defaultValue;\n};\nexports.createElement = function (type, config, children) {\n var propName,\n props = {},\n key = null;\n if (null != config)\n for (propName in (void 0 !== config.key && (key = \"\" + config.key), config))\n hasOwnProperty.call(config, propName) &&\n \"key\" !== propName &&\n \"__self\" !== propName &&\n \"__source\" !== propName &&\n (props[propName] = config[propName]);\n var childrenLength = arguments.length - 2;\n if (1 === childrenLength) props.children = children;\n else if (1 < childrenLength) {\n for (var childArray = Array(childrenLength), i = 0; i < childrenLength; i++)\n childArray[i] = arguments[i + 2];\n props.children = childArray;\n }\n if (type && type.defaultProps)\n for (propName in ((childrenLength = type.defaultProps), childrenLength))\n void 0 === props[propName] &&\n (props[propName] = childrenLength[propName]);\n return ReactElement(type, key, props);\n};\nexports.createRef = function () {\n return { current: null };\n};\nexports.forwardRef = function (render) {\n return { $$typeof: REACT_FORWARD_REF_TYPE, render: render };\n};\nexports.isValidElement = isValidElement;\nexports.lazy = function (ctor) {\n return {\n $$typeof: REACT_LAZY_TYPE,\n _payload: { _status: -1, _result: ctor },\n _init: lazyInitializer\n };\n};\nexports.memo = function (type, compare) {\n return {\n $$typeof: REACT_MEMO_TYPE,\n type: type,\n compare: void 0 === compare ? null : compare\n };\n};\nexports.startTransition = function (scope) {\n var prevTransition = ReactSharedInternals.T,\n currentTransition = {};\n ReactSharedInternals.T = currentTransition;\n try {\n var returnValue = scope(),\n onStartTransitionFinish = ReactSharedInternals.S;\n null !== onStartTransitionFinish &&\n onStartTransitionFinish(currentTransition, returnValue);\n \"object\" === typeof returnValue &&\n null !== returnValue &&\n \"function\" === typeof returnValue.then &&\n returnValue.then(noop, reportGlobalError);\n } catch (error) {\n reportGlobalError(error);\n } finally {\n null !== prevTransition &&\n null !== currentTransition.types &&\n (prevTransition.types = currentTransition.types),\n (ReactSharedInternals.T = prevTransition);\n }\n};\nexports.unstable_useCacheRefresh = function () {\n return ReactSharedInternals.H.useCacheRefresh();\n};\nexports.use = function (usable) {\n return ReactSharedInternals.H.use(usable);\n};\nexports.useActionState = function (action, initialState, permalink) {\n return ReactSharedInternals.H.useActionState(action, initialState, permalink);\n};\nexports.useCallback = function (callback, deps) {\n return ReactSharedInternals.H.useCallback(callback, deps);\n};\nexports.useContext = function (Context) {\n return ReactSharedInternals.H.useContext(Context);\n};\nexports.useDebugValue = function () {};\nexports.useDeferredValue = function (value, initialValue) {\n return ReactSharedInternals.H.useDeferredValue(value, initialValue);\n};\nexports.useEffect = function (create, deps) {\n return ReactSharedInternals.H.useEffect(create, deps);\n};\nexports.useEffectEvent = function (callback) {\n return ReactSharedInternals.H.useEffectEvent(callback);\n};\nexports.useId = function () {\n return ReactSharedInternals.H.useId();\n};\nexports.useImperativeHandle = function (ref, create, deps) {\n return ReactSharedInternals.H.useImperativeHandle(ref, create, deps);\n};\nexports.useInsertionEffect = function (create, deps) {\n return ReactSharedInternals.H.useInsertionEffect(create, deps);\n};\nexports.useLayoutEffect = function (create, deps) {\n return ReactSharedInternals.H.useLayoutEffect(create, deps);\n};\nexports.useMemo = function (create, deps) {\n return ReactSharedInternals.H.useMemo(create, deps);\n};\nexports.useOptimistic = function (passthrough, reducer) {\n return ReactSharedInternals.H.useOptimistic(passthrough, reducer);\n};\nexports.useReducer = function (reducer, initialArg, init) {\n return ReactSharedInternals.H.useReducer(reducer, initialArg, init);\n};\nexports.useRef = function (initialValue) {\n return ReactSharedInternals.H.useRef(initialValue);\n};\nexports.useState = function (initialState) {\n return ReactSharedInternals.H.useState(initialState);\n};\nexports.useSyncExternalStore = function (\n subscribe,\n getSnapshot,\n getServerSnapshot\n) {\n return ReactSharedInternals.H.useSyncExternalStore(\n subscribe,\n getSnapshot,\n getServerSnapshot\n );\n};\nexports.useTransition = function () {\n return ReactSharedInternals.H.useTransition();\n};\nexports.version = \"19.2.0\";\n", "'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n", "/**\n * @license React\n * use-sync-external-store-shim.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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 */\n\n\"use strict\";\nvar React = require(\"react\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue;\nfunction useSyncExternalStore$2(subscribe, getSnapshot) {\n var value = getSnapshot(),\n _useState = useState({ inst: { value: value, getSnapshot: getSnapshot } }),\n inst = _useState[0].inst,\n forceUpdate = _useState[1];\n useLayoutEffect(\n function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n },\n [subscribe, value, getSnapshot]\n );\n useEffect(\n function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n return subscribe(function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n });\n },\n [subscribe]\n );\n useDebugValue(value);\n return value;\n}\nfunction checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n}\nfunction useSyncExternalStore$1(subscribe, getSnapshot) {\n return getSnapshot();\n}\nvar shim =\n \"undefined\" === typeof window ||\n \"undefined\" === typeof window.document ||\n \"undefined\" === typeof window.document.createElement\n ? useSyncExternalStore$1\n : useSyncExternalStore$2;\nexports.useSyncExternalStore =\n void 0 !== React.useSyncExternalStore ? React.useSyncExternalStore : shim;\n", "'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n", "/**\n * @license React\n * use-sync-external-store-shim/with-selector.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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 */\n\n\"use strict\";\nvar React = require(\"react\"),\n shim = require(\"use-sync-external-store/shim\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useSyncExternalStore = shim.useSyncExternalStore,\n useRef = React.useRef,\n useEffect = React.useEffect,\n useMemo = React.useMemo,\n useDebugValue = React.useDebugValue;\nexports.useSyncExternalStoreWithSelector = function (\n subscribe,\n getSnapshot,\n getServerSnapshot,\n selector,\n isEqual\n) {\n var instRef = useRef(null);\n if (null === instRef.current) {\n var inst = { hasValue: !1, value: null };\n instRef.current = inst;\n } else inst = instRef.current;\n instRef = useMemo(\n function () {\n function memoizedSelector(nextSnapshot) {\n if (!hasMemo) {\n hasMemo = !0;\n memoizedSnapshot = nextSnapshot;\n nextSnapshot = selector(nextSnapshot);\n if (void 0 !== isEqual && inst.hasValue) {\n var currentSelection = inst.value;\n if (isEqual(currentSelection, nextSnapshot))\n return (memoizedSelection = currentSelection);\n }\n return (memoizedSelection = nextSnapshot);\n }\n currentSelection = memoizedSelection;\n if (objectIs(memoizedSnapshot, nextSnapshot)) return currentSelection;\n var nextSelection = selector(nextSnapshot);\n if (void 0 !== isEqual && isEqual(currentSelection, nextSelection))\n return (memoizedSnapshot = nextSnapshot), currentSelection;\n memoizedSnapshot = nextSnapshot;\n return (memoizedSelection = nextSelection);\n }\n var hasMemo = !1,\n memoizedSnapshot,\n memoizedSelection,\n maybeGetServerSnapshot =\n void 0 === getServerSnapshot ? null : getServerSnapshot;\n return [\n function () {\n return memoizedSelector(getSnapshot());\n },\n null === maybeGetServerSnapshot\n ? void 0\n : function () {\n return memoizedSelector(maybeGetServerSnapshot());\n }\n ];\n },\n [getSnapshot, getServerSnapshot, selector, isEqual]\n );\n var value = useSyncExternalStore(subscribe, instRef[0], instRef[1]);\n useEffect(\n function () {\n inst.hasValue = !0;\n inst.value = value;\n },\n [value]\n );\n useDebugValue(value);\n return value;\n};\n", "'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.production.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.development.js');\n}\n", "/**\n * @license React\n * react-dom.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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 */\n\n\"use strict\";\nvar React = require(\"react\");\nfunction formatProdErrorMessage(code) {\n var url = \"https://react.dev/errors/\" + code;\n if (1 < arguments.length) {\n url += \"?args[]=\" + encodeURIComponent(arguments[1]);\n for (var i = 2; i < arguments.length; i++)\n url += \"&args[]=\" + encodeURIComponent(arguments[i]);\n }\n return (\n \"Minified React error #\" +\n code +\n \"; visit \" +\n url +\n \" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"\n );\n}\nfunction noop() {}\nvar Internals = {\n d: {\n f: noop,\n r: function () {\n throw Error(formatProdErrorMessage(522));\n },\n D: noop,\n C: noop,\n L: noop,\n m: noop,\n X: noop,\n S: noop,\n M: noop\n },\n p: 0,\n findDOMNode: null\n },\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\");\nfunction createPortal$1(children, containerInfo, implementation) {\n var key =\n 3 < arguments.length && void 0 !== arguments[3] ? arguments[3] : null;\n return {\n $$typeof: REACT_PORTAL_TYPE,\n key: null == key ? null : \"\" + key,\n children: children,\n containerInfo: containerInfo,\n implementation: implementation\n };\n}\nvar ReactSharedInternals =\n React.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE;\nfunction getCrossOriginStringAs(as, input) {\n if (\"font\" === as) return \"\";\n if (\"string\" === typeof input)\n return \"use-credentials\" === input ? input : \"\";\n}\nexports.__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE =\n Internals;\nexports.createPortal = function (children, container) {\n var key =\n 2 < arguments.length && void 0 !== arguments[2] ? arguments[2] : null;\n if (\n !container ||\n (1 !== container.nodeType &&\n 9 !== container.nodeType &&\n 11 !== container.nodeType)\n )\n throw Error(formatProdErrorMessage(299));\n return createPortal$1(children, container, null, key);\n};\nexports.flushSync = function (fn) {\n var previousTransition = ReactSharedInternals.T,\n previousUpdatePriority = Internals.p;\n try {\n if (((ReactSharedInternals.T = null), (Internals.p = 2), fn)) return fn();\n } finally {\n (ReactSharedInternals.T = previousTransition),\n (Internals.p = previousUpdatePriority),\n Internals.d.f();\n }\n};\nexports.preconnect = function (href, options) {\n \"string\" === typeof href &&\n (options\n ? ((options = options.crossOrigin),\n (options =\n \"string\" === typeof options\n ? \"use-credentials\" === options\n ? options\n : \"\"\n : void 0))\n : (options = null),\n Internals.d.C(href, options));\n};\nexports.prefetchDNS = function (href) {\n \"string\" === typeof href && Internals.d.D(href);\n};\nexports.preinit = function (href, options) {\n if (\"string\" === typeof href && options && \"string\" === typeof options.as) {\n var as = options.as,\n crossOrigin = getCrossOriginStringAs(as, options.crossOrigin),\n integrity =\n \"string\" === typeof options.integrity ? options.integrity : void 0,\n fetchPriority =\n \"string\" === typeof options.fetchPriority\n ? options.fetchPriority\n : void 0;\n \"style\" === as\n ? Internals.d.S(\n href,\n \"string\" === typeof options.precedence ? options.precedence : void 0,\n {\n crossOrigin: crossOrigin,\n integrity: integrity,\n fetchPriority: fetchPriority\n }\n )\n : \"script\" === as &&\n Internals.d.X(href, {\n crossOrigin: crossOrigin,\n integrity: integrity,\n fetchPriority: fetchPriority,\n nonce: \"string\" === typeof options.nonce ? options.nonce : void 0\n });\n }\n};\nexports.preinitModule = function (href, options) {\n if (\"string\" === typeof href)\n if (\"object\" === typeof options && null !== options) {\n if (null == options.as || \"script\" === options.as) {\n var crossOrigin = getCrossOriginStringAs(\n options.as,\n options.crossOrigin\n );\n Internals.d.M(href, {\n crossOrigin: crossOrigin,\n integrity:\n \"string\" === typeof options.integrity ? options.integrity : void 0,\n nonce: \"string\" === typeof options.nonce ? options.nonce : void 0\n });\n }\n } else null == options && Internals.d.M(href);\n};\nexports.preload = function (href, options) {\n if (\n \"string\" === typeof href &&\n \"object\" === typeof options &&\n null !== options &&\n \"string\" === typeof options.as\n ) {\n var as = options.as,\n crossOrigin = getCrossOriginStringAs(as, options.crossOrigin);\n Internals.d.L(href, as, {\n crossOrigin: crossOrigin,\n integrity:\n \"string\" === typeof options.integrity ? options.integrity : void 0,\n nonce: \"string\" === typeof options.nonce ? options.nonce : void 0,\n type: \"string\" === typeof options.type ? options.type : void 0,\n fetchPriority:\n \"string\" === typeof options.fetchPriority\n ? options.fetchPriority\n : void 0,\n referrerPolicy:\n \"string\" === typeof options.referrerPolicy\n ? options.referrerPolicy\n : void 0,\n imageSrcSet:\n \"string\" === typeof options.imageSrcSet ? options.imageSrcSet : void 0,\n imageSizes:\n \"string\" === typeof options.imageSizes ? options.imageSizes : void 0,\n media: \"string\" === typeof options.media ? options.media : void 0\n });\n }\n};\nexports.preloadModule = function (href, options) {\n if (\"string\" === typeof href)\n if (options) {\n var crossOrigin = getCrossOriginStringAs(options.as, options.crossOrigin);\n Internals.d.m(href, {\n as:\n \"string\" === typeof options.as && \"script\" !== options.as\n ? options.as\n : void 0,\n crossOrigin: crossOrigin,\n integrity:\n \"string\" === typeof options.integrity ? options.integrity : void 0\n });\n } else Internals.d.m(href);\n};\nexports.requestFormReset = function (form) {\n Internals.d.r(form);\n};\nexports.unstable_batchedUpdates = function (fn, a) {\n return fn(a);\n};\nexports.useFormState = function (action, initialState, permalink) {\n return ReactSharedInternals.H.useFormState(action, initialState, permalink);\n};\nexports.useFormStatus = function () {\n return ReactSharedInternals.H.useHostTransitionStatus();\n};\nexports.version = \"19.2.0\";\n", "'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\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 }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n", "/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport {\n Endpoint,\n EventSource,\n Message,\n MessageType,\n PostMessageWithOrigin,\n WireValue,\n WireValueType,\n} from \"./protocol\";\nexport type { Endpoint };\n\nexport const proxyMarker = Symbol(\"Comlink.proxy\");\nexport const createEndpoint = Symbol(\"Comlink.endpoint\");\nexport const releaseProxy = Symbol(\"Comlink.releaseProxy\");\nexport const finalizer = Symbol(\"Comlink.finalizer\");\n\nconst throwMarker = Symbol(\"Comlink.thrown\");\n\n/**\n * Interface of values that were marked to be proxied with `comlink.proxy()`.\n * Can also be implemented by classes.\n */\nexport interface ProxyMarked {\n [proxyMarker]: true;\n}\n\n/**\n * Takes a type and wraps it in a Promise, if it not already is one.\n * This is to avoid `Promise<Promise<T>>`.\n *\n * This is the inverse of `Unpromisify<T>`.\n */\ntype Promisify<T> = T extends Promise<unknown> ? T : Promise<T>;\n/**\n * Takes a type that may be Promise and unwraps the Promise type.\n * If `P` is not a Promise, it returns `P`.\n *\n * This is the inverse of `Promisify<T>`.\n */\ntype Unpromisify<P> = P extends Promise<infer T> ? T : P;\n\n/**\n * Takes the raw type of a remote property and returns the type that is visible to the local thread on the proxy.\n *\n * Note: This needs to be its own type alias, otherwise it will not distribute over unions.\n * See https://www.typescriptlang.org/docs/handbook/advanced-types.html#distributive-conditional-types\n */\ntype RemoteProperty<T> =\n // If the value is a method, comlink will proxy it automatically.\n // Objects are only proxied if they are marked to be proxied.\n // Otherwise, the property is converted to a Promise that resolves the cloned value.\n T extends Function | ProxyMarked ? Remote<T> : Promisify<T>;\n\n/**\n * Takes the raw type of a property as a remote thread would see it through a proxy (e.g. when passed in as a function\n * argument) and returns the type that the local thread has to supply.\n *\n * This is the inverse of `RemoteProperty<T>`.\n *\n * Note: This needs to be its own type alias, otherwise it will not distribute over unions. See\n * https://www.typescriptlang.org/docs/handbook/advanced-types.html#distributive-conditional-types\n */\ntype LocalProperty<T> = T extends Function | ProxyMarked\n ? Local<T>\n : Unpromisify<T>;\n\n/**\n * Proxies `T` if it is a `ProxyMarked`, clones it otherwise (as handled by structured cloning and transfer handlers).\n */\nexport type ProxyOrClone<T> = T extends ProxyMarked ? Remote<T> : T;\n/**\n * Inverse of `ProxyOrClone<T>`.\n */\nexport type UnproxyOrClone<T> = T extends RemoteObject<ProxyMarked>\n ? Local<T>\n : T;\n\n/**\n * Takes the raw type of a remote object in the other thread and returns the type as it is visible to the local thread\n * when proxied with `Comlink.proxy()`.\n *\n * This does not handle call signatures, which is handled by the more general `Remote<T>` type.\n *\n * @template T The raw type of a remote object as seen in the other thread.\n */\nexport type RemoteObject<T> = { [P in keyof T]: RemoteProperty<T[P]> };\n/**\n * Takes the type of an object as a remote thread would see it through a proxy (e.g. when passed in as a function\n * argument) and returns the type that the local thread has to supply.\n *\n * This does not handle call signatures, which is handled by the more general `Local<T>` type.\n *\n * This is the inverse of `RemoteObject<T>`.\n *\n * @template T The type of a proxied object.\n */\nexport type LocalObject<T> = { [P in keyof T]: LocalProperty<T[P]> };\n\n/**\n * Additional special comlink methods available on each proxy returned by `Comlink.wrap()`.\n */\nexport interface ProxyMethods {\n [createEndpoint]: () => Promise<MessagePort>;\n [releaseProxy]: () => void;\n}\n\n/**\n * Takes the raw type of a remote object, function or class in the other thread and returns the type as it is visible to\n * the local thread from the proxy return value of `Comlink.wrap()` or `Comlink.proxy()`.\n */\nexport type Remote<T> =\n // Handle properties\n RemoteObject<T> &\n // Handle call signature (if present)\n (T extends (...args: infer TArguments) => infer TReturn\n ? (\n ...args: { [I in keyof TArguments]: UnproxyOrClone<TArguments[I]> }\n ) => Promisify<ProxyOrClone<Unpromisify<TReturn>>>\n : unknown) &\n // Handle construct signature (if present)\n // The return of construct signatures is always proxied (whether marked or not)\n (T extends { new (...args: infer TArguments): infer TInstance }\n ? {\n new (\n ...args: {\n [I in keyof TArguments]: UnproxyOrClone<TArguments[I]>;\n }\n ): Promisify<Remote<TInstance>>;\n }\n : unknown) &\n // Include additional special comlink methods available on the proxy.\n ProxyMethods;\n\n/**\n * Expresses that a type can be either a sync or async.\n */\ntype MaybePromise<T> = Promise<T> | T;\n\n/**\n * Takes the raw type of a remote object, function or class as a remote thread would see it through a proxy (e.g. when\n * passed in as a function argument) and returns the type the local thread has to supply.\n *\n * This is the inverse of `Remote<T>`. It takes a `Remote<T>` and returns its original input `T`.\n */\nexport type Local<T> =\n // Omit the special proxy methods (they don't need to be supplied, comlink adds them)\n Omit<LocalObject<T>, keyof ProxyMethods> &\n // Handle call signatures (if present)\n (T extends (...args: infer TArguments) => infer TReturn\n ? (\n ...args: { [I in keyof TArguments]: ProxyOrClone<TArguments[I]> }\n ) => // The raw function could either be sync or async, but is always proxied automatically\n MaybePromise<UnproxyOrClone<Unpromisify<TReturn>>>\n : unknown) &\n // Handle construct signature (if present)\n // The return of construct signatures is always proxied (whether marked or not)\n (T extends { new (...args: infer TArguments): infer TInstance }\n ? {\n new (\n ...args: {\n [I in keyof TArguments]: ProxyOrClone<TArguments[I]>;\n }\n ): // The raw constructor could either be sync or async, but is always proxied automatically\n MaybePromise<Local<Unpromisify<TInstance>>>;\n }\n : unknown);\n\nconst isObject = (val: unknown): val is object =>\n (typeof val === \"object\" && val !== null) || typeof val === \"function\";\n\n/**\n * Customizes the serialization of certain values as determined by `canHandle()`.\n *\n * @template T The input type being handled by this transfer handler.\n * @template S The serialized type sent over the wire.\n */\nexport interface TransferHandler<T, S> {\n /**\n * Gets called for every value to determine whether this transfer handler\n * should serialize the value, which includes checking that it is of the right\n * type (but can perform checks beyond that as well).\n */\n canHandle(value: unknown): value is T;\n\n /**\n * Gets called with the value if `canHandle()` returned `true` to produce a\n * value that can be sent in a message, consisting of structured-cloneable\n * values and/or transferrable objects.\n */\n serialize(value: T): [S, Transferable[]];\n\n /**\n * Gets called to deserialize an incoming value that was serialized in the\n * other thread with this transfer handler (known through the name it was\n * registered under).\n */\n deserialize(value: S): T;\n}\n\n/**\n * Internal transfer handle to handle objects marked to proxy.\n */\nconst proxyTransferHandler: TransferHandler<object, MessagePort> = {\n canHandle: (val): val is ProxyMarked =>\n isObject(val) && (val as ProxyMarked)[proxyMarker],\n serialize(obj) {\n const { port1, port2 } = new MessageChannel();\n expose(obj, port1);\n return [port2, [port2]];\n },\n deserialize(port) {\n port.start();\n return wrap(port);\n },\n};\n\ninterface ThrownValue {\n [throwMarker]: unknown; // just needs to be present\n value: unknown;\n}\ntype SerializedThrownValue =\n | { isError: true; value: Error }\n | { isError: false; value: unknown };\ntype PendingListenersMap = Map<\n string,\n (value: WireValue | PromiseLike<WireValue>) => void\n>;\n\n/**\n * Internal transfer handler to handle thrown exceptions.\n */\nconst throwTransferHandler: TransferHandler<\n ThrownValue,\n SerializedThrownValue\n> = {\n canHandle: (value): value is ThrownValue =>\n isObject(value) && throwMarker in value,\n serialize({ value }) {\n let serialized: SerializedThrownValue;\n if (value instanceof Error) {\n serialized = {\n isError: true,\n value: {\n message: value.message,\n name: value.name,\n stack: value.stack,\n },\n };\n } else {\n serialized = { isError: false, value };\n }\n return [serialized, []];\n },\n deserialize(serialized) {\n if (serialized.isError) {\n throw Object.assign(\n new Error(serialized.value.message),\n serialized.value\n );\n }\n throw serialized.value;\n },\n};\n\n/**\n * Allows customizing the serialization of certain values.\n */\nexport const transferHandlers = new Map<\n string,\n TransferHandler<unknown, unknown>\n>([\n [\"proxy\", proxyTransferHandler],\n [\"throw\", throwTransferHandler],\n]);\n\nfunction isAllowedOrigin(\n allowedOrigins: (string | RegExp)[],\n origin: string\n): boolean {\n for (const allowedOrigin of allowedOrigins) {\n if (origin === allowedOrigin || allowedOrigin === \"*\") {\n return true;\n }\n if (allowedOrigin instanceof RegExp && allowedOrigin.test(origin)) {\n return true;\n }\n }\n return false;\n}\n\nexport function expose(\n obj: any,\n ep: Endpoint = globalThis as any,\n allowedOrigins: (string | RegExp)[] = [\"*\"]\n) {\n ep.addEventListener(\"message\", function callback(ev: MessageEvent) {\n if (!ev || !ev.data) {\n return;\n }\n if (!isAllowedOrigin(allowedOrigins, ev.origin)) {\n console.warn(`Invalid origin '${ev.origin}' for comlink proxy`);\n return;\n }\n const { id, type, path } = {\n path: [] as string[],\n ...(ev.data as Message),\n };\n const argumentList = (ev.data.argumentList || []).map(fromWireValue);\n let returnValue;\n try {\n const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);\n const rawValue = path.reduce((obj, prop) => obj[prop], obj);\n switch (type) {\n case MessageType.GET:\n {\n returnValue = rawValue;\n }\n break;\n case MessageType.SET:\n {\n parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);\n returnValue = true;\n }\n break;\n case MessageType.APPLY:\n {\n returnValue = rawValue.apply(parent, argumentList);\n }\n break;\n case MessageType.CONSTRUCT:\n {\n const value = new rawValue(...argumentList);\n returnValue = proxy(value);\n }\n break;\n case MessageType.ENDPOINT:\n {\n const { port1, port2 } = new MessageChannel();\n expose(obj, port2);\n returnValue = transfer(port1, [port1]);\n }\n break;\n case MessageType.RELEASE:\n {\n returnValue = undefined;\n }\n break;\n default:\n return;\n }\n } catch (value) {\n returnValue = { value, [throwMarker]: 0 };\n }\n Promise.resolve(returnValue)\n .catch((value) => {\n return { value, [throwMarker]: 0 };\n })\n .then((returnValue) => {\n const [wireValue, transferables] = toWireValue(returnValue);\n ep.postMessage({ ...wireValue, id }, transferables);\n if (type === MessageType.RELEASE) {\n // detach and deactive after sending release response above.\n ep.removeEventListener(\"message\", callback as any);\n closeEndPoint(ep);\n if (finalizer in obj && typeof obj[finalizer] === \"function\") {\n obj[finalizer]();\n }\n }\n })\n .catch((error) => {\n // Send Serialization Error To Caller\n const [wireValue, transferables] = toWireValue({\n value: new TypeError(\"Unserializable return value\"),\n [throwMarker]: 0,\n });\n ep.postMessage({ ...wireValue, id }, transferables);\n });\n } as any);\n if (ep.start) {\n ep.start();\n }\n}\n\nfunction isMessagePort(endpoint: Endpoint): endpoint is MessagePort {\n return endpoint.constructor.name === \"MessagePort\";\n}\n\nfunction closeEndPoint(endpoint: Endpoint) {\n if (isMessagePort(endpoint)) endpoint.close();\n}\n\nexport function wrap<T>(ep: Endpoint, target?: any): Remote<T> {\n const pendingListeners : PendingListenersMap = new Map();\n\n ep.addEventListener(\"message\", function handleMessage(ev: Event) {\n const { data } = ev as MessageEvent;\n if (!data || !data.id) {\n return;\n }\n const resolver = pendingListeners.get(data.id);\n if (!resolver) {\n return;\n }\n\n try {\n resolver(data);\n } finally {\n pendingListeners.delete(data.id);\n }\n });\n\n return createProxy<T>(ep, pendingListeners, [], target) as any;\n}\n\nfunction throwIfProxyReleased(isReleased: boolean) {\n if (isReleased) {\n throw new Error(\"Proxy has been released and is not useable\");\n }\n}\n\nfunction releaseEndpoint(ep: Endpoint) {\n return requestResponseMessage(ep, new Map(), {\n type: MessageType.RELEASE,\n }).then(() => {\n closeEndPoint(ep);\n });\n}\n\ninterface FinalizationRegistry<T> {\n new (cb: (heldValue: T) => void): FinalizationRegistry<T>;\n register(\n weakItem: object,\n heldValue: T,\n unregisterToken?: object | undefined\n ): void;\n unregister(unregisterToken: object): void;\n}\ndeclare var FinalizationRegistry: FinalizationRegistry<Endpoint>;\n\nconst proxyCounter = new WeakMap<Endpoint, number>();\nconst proxyFinalizers =\n \"FinalizationRegistry\" in globalThis &&\n new FinalizationRegistry((ep: Endpoint) => {\n const newCount = (proxyCounter.get(ep) || 0) - 1;\n proxyCounter.set(ep, newCount);\n if (newCount === 0) {\n releaseEndpoint(ep);\n }\n });\n\nfunction registerProxy(proxy: object, ep: Endpoint) {\n const newCount = (proxyCounter.get(ep) || 0) + 1;\n proxyCounter.set(ep, newCount);\n if (proxyFinalizers) {\n proxyFinalizers.register(proxy, ep, proxy);\n }\n}\n\nfunction unregisterProxy(proxy: object) {\n if (proxyFinalizers) {\n proxyFinalizers.unregister(proxy);\n }\n}\n\nfunction createProxy<T>(\n ep: Endpoint,\n pendingListeners: PendingListenersMap,\n path: (string | number | symbol)[] = [],\n target: object = function () {}\n): Remote<T> {\n let isProxyReleased = false;\n const proxy = new Proxy(target, {\n get(_target, prop) {\n throwIfProxyReleased(isProxyReleased);\n if (prop === releaseProxy) {\n return () => {\n unregisterProxy(proxy);\n releaseEndpoint(ep);\n pendingListeners.clear();\n isProxyReleased = true;\n };\n }\n if (prop === \"then\") {\n if (path.length === 0) {\n return { then: () => proxy };\n }\n const r = requestResponseMessage(ep, pendingListeners, {\n type: MessageType.GET,\n path: path.map((p) => p.toString()),\n }).then(fromWireValue);\n return r.then.bind(r);\n }\n return createProxy(ep, pendingListeners, [...path, prop]);\n },\n set(_target, prop, rawValue) {\n throwIfProxyReleased(isProxyReleased);\n // FIXME: ES6 Proxy Handler `set` methods are supposed to return a\n // boolean. To show good will, we return true asynchronously \u00AF\\_(\u30C4)_/\u00AF\n const [value, transferables] = toWireValue(rawValue);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.SET,\n path: [...path, prop].map((p) => p.toString()),\n value,\n },\n transferables\n ).then(fromWireValue) as any;\n },\n apply(_target, _thisArg, rawArgumentList) {\n throwIfProxyReleased(isProxyReleased);\n const last = path[path.length - 1];\n if ((last as any) === createEndpoint) {\n return requestResponseMessage(ep, pendingListeners, {\n type: MessageType.ENDPOINT,\n }).then(fromWireValue);\n }\n // We just pretend that `bind()` didn\u2019t happen.\n if (last === \"bind\") {\n return createProxy(ep, pendingListeners, path.slice(0, -1));\n }\n const [argumentList, transferables] = processArguments(rawArgumentList);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.APPLY,\n path: path.map((p) => p.toString()),\n argumentList,\n },\n transferables\n ).then(fromWireValue);\n },\n construct(_target, rawArgumentList) {\n throwIfProxyReleased(isProxyReleased);\n const [argumentList, transferables] = processArguments(rawArgumentList);\n return requestResponseMessage(\n ep,\n pendingListeners,\n {\n type: MessageType.CONSTRUCT,\n path: path.map((p) => p.toString()),\n argumentList,\n },\n transferables\n ).then(fromWireValue);\n },\n });\n registerProxy(proxy, ep);\n return proxy as any;\n}\n\nfunction myFlat<T>(arr: (T | T[])[]): T[] {\n return Array.prototype.concat.apply([], arr);\n}\n\nfunction processArguments(argumentList: any[]): [WireValue[], Transferable[]] {\n const processed = argumentList.map(toWireValue);\n return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];\n}\n\nconst transferCache = new WeakMap<any, Transferable[]>();\nexport function transfer<T>(obj: T, transfers: Transferable[]): T {\n transferCache.set(obj, transfers);\n return obj;\n}\n\nexport function proxy<T extends {}>(obj: T): T & ProxyMarked {\n return Object.assign(obj, { [proxyMarker]: true }) as any;\n}\n\nexport function windowEndpoint(\n w: PostMessageWithOrigin,\n context: EventSource = globalThis,\n targetOrigin = \"*\"\n): Endpoint {\n return {\n postMessage: (msg: any, transferables: Transferable[]) =>\n w.postMessage(msg, targetOrigin, transferables),\n addEventListener: context.addEventListener.bind(context),\n removeEventListener: context.removeEventListener.bind(context),\n };\n}\n\nfunction toWireValue(value: any): [WireValue, Transferable[]] {\n for (const [name, handler] of transferHandlers) {\n if (handler.canHandle(value)) {\n const [serializedValue, transferables] = handler.serialize(value);\n return [\n {\n type: WireValueType.HANDLER,\n name,\n value: serializedValue,\n },\n transferables,\n ];\n }\n }\n return [\n {\n type: WireValueType.RAW,\n value,\n },\n transferCache.get(value) || [],\n ];\n}\n\nfunction fromWireValue(value: WireValue): any {\n switch (value.type) {\n case WireValueType.HANDLER:\n return transferHandlers.get(value.name)!.deserialize(value.value);\n case WireValueType.RAW:\n return value.value;\n }\n}\n\nfunction requestResponseMessage(\n ep: Endpoint,\n pendingListeners: PendingListenersMap,\n msg: Message,\n transfers?: Transferable[]\n): Promise<WireValue> {\n return new Promise((resolve) => {\n const id = generateUUID();\n pendingListeners.set(id, resolve);\n if (ep.start) {\n ep.start();\n }\n ep.postMessage({ id, ...msg }, transfers);\n});\n}\n\nfunction generateUUID(): string {\n return new Array(4)\n .fill(0)\n .map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))\n .join(\"-\");\n}\n", "\"use client\"\nimport { jsxs, Fragment, jsx } from 'react/jsx-runtime';\nimport { createContext, useContext, useMemo, forwardRef, useEffect, useRef, useState, useLayoutEffect, useCallback, memo } from 'react';\nimport cc from 'classcat';\nimport { errorMessages, mergeAriaLabelConfig, infiniteExtent, isInputDOMNode, getViewportForBounds, pointToRendererPoint, rendererPointToPoint, isNodeBase, isEdgeBase, getElementsToRemove, isRectObject, nodeToRect, getOverlappingArea, getNodesBounds, withResolvers, evaluateAbsolutePosition, getDimensions, XYPanZoom, PanOnScrollMode, SelectionMode, getEventPosition, getNodesInside, areSetsEqual, XYDrag, snapPosition, calculateNodePosition, Position, ConnectionMode, isMouseEvent, XYHandle, getHostForElement, addEdge, getInternalNodesBounds, isNumeric, nodeHasDimensions, getNodeDimensions, elementSelectionKeys, isEdgeVisible, MarkerType, createMarkerIds, getBezierEdgeCenter, getSmoothStepPath, getStraightPath, getBezierPath, getEdgePosition, getElevatedEdgeZIndex, getMarkerId, getConnectionStatus, ConnectionLineType, updateConnectionLookup, adoptUserNodes, initialConnection, devWarn, defaultAriaLabelConfig, updateNodeInternals, updateAbsolutePositions, handleExpandParent, panBy, fitViewport, isMacOs, areConnectionMapsEqual, handleConnectionChange, shallowNodeData, XYMinimap, getBoundsOfRects, ResizeControlVariant, XYResizer, XY_RESIZER_LINE_POSITIONS, XY_RESIZER_HANDLE_POSITIONS, getNodeToolbarTransform, getEdgeToolbarTransform } from '@xyflow/system';\nexport { ConnectionLineType, ConnectionMode, MarkerType, PanOnScrollMode, Position, ResizeControlVariant, SelectionMode, addEdge, getBezierEdgeCenter, getBezierPath, getConnectedEdges, getEdgeCenter, getIncomers, getNodesBounds, getOutgoers, getSmoothStepPath, getStraightPath, getViewportForBounds, reconnectEdge } from '@xyflow/system';\nimport { useStoreWithEqualityFn, createWithEqualityFn } from 'zustand/traditional';\nimport { shallow } from 'zustand/shallow';\nimport { createPortal } from 'react-dom';\n\nconst StoreContext = createContext(null);\nconst Provider$1 = StoreContext.Provider;\n\nconst zustandErrorMessage = errorMessages['error001']();\n/**\n * This hook can be used to subscribe to internal state changes of the React Flow\n * component. The `useStore` hook is re-exported from the [Zustand](https://github.com/pmndrs/zustand)\n * state management library, so you should check out their docs for more details.\n *\n * @public\n * @param selector - A selector function that returns a slice of the flow's internal state.\n * Extracting or transforming just the state you need is a good practice to avoid unnecessary\n * re-renders.\n * @param equalityFn - A function to compare the previous and next value. This is incredibly useful\n * for preventing unnecessary re-renders. Good sensible defaults are using `Object.is` or importing\n * `zustand/shallow`, but you can be as granular as you like.\n * @returns The selected state slice.\n *\n * @example\n * ```ts\n * const nodes = useStore((state) => state.nodes);\n * ```\n *\n * @remarks This hook should only be used if there is no other way to access the internal\n * state. For many of the common use cases, there are dedicated hooks available\n * such as {@link useReactFlow}, {@link useViewport}, etc.\n */\nfunction useStore(selector, equalityFn) {\n const store = useContext(StoreContext);\n if (store === null) {\n throw new Error(zustandErrorMessage);\n }\n return useStoreWithEqualityFn(store, selector, equalityFn);\n}\n/**\n * In some cases, you might need to access the store directly. This hook returns the store object which can be used on demand to access the state or dispatch actions.\n *\n * @returns The store object.\n * @example\n * ```ts\n * const store = useStoreApi();\n * ```\n *\n * @remarks This hook should only be used if there is no other way to access the internal\n * state. For many of the common use cases, there are dedicated hooks available\n * such as {@link useReactFlow}, {@link useViewport}, etc.\n */\nfunction useStoreApi() {\n const store = useContext(StoreContext);\n if (store === null) {\n throw new Error(zustandErrorMessage);\n }\n return useMemo(() => ({\n getState: store.getState,\n setState: store.setState,\n subscribe: store.subscribe,\n }), [store]);\n}\n\nconst style = { display: 'none' };\nconst ariaLiveStyle = {\n position: 'absolute',\n width: 1,\n height: 1,\n margin: -1,\n border: 0,\n padding: 0,\n overflow: 'hidden',\n clip: 'rect(0px, 0px, 0px, 0px)',\n clipPath: 'inset(100%)',\n};\nconst ARIA_NODE_DESC_KEY = 'react-flow__node-desc';\nconst ARIA_EDGE_DESC_KEY = 'react-flow__edge-desc';\nconst ARIA_LIVE_MESSAGE = 'react-flow__aria-live';\nconst ariaLiveSelector = (s) => s.ariaLiveMessage;\nconst ariaLabelConfigSelector = (s) => s.ariaLabelConfig;\nfunction AriaLiveMessage({ rfId }) {\n const ariaLiveMessage = useStore(ariaLiveSelector);\n return (jsx(\"div\", { id: `${ARIA_LIVE_MESSAGE}-${rfId}`, \"aria-live\": \"assertive\", \"aria-atomic\": \"true\", style: ariaLiveStyle, children: ariaLiveMessage }));\n}\nfunction A11yDescriptions({ rfId, disableKeyboardA11y }) {\n const ariaLabelConfig = useStore(ariaLabelConfigSelector);\n return (jsxs(Fragment, { children: [jsx(\"div\", { id: `${ARIA_NODE_DESC_KEY}-${rfId}`, style: style, children: disableKeyboardA11y\n ? ariaLabelConfig['node.a11yDescription.default']\n : ariaLabelConfig['node.a11yDescription.keyboardDisabled'] }), jsx(\"div\", { id: `${ARIA_EDGE_DESC_KEY}-${rfId}`, style: style, children: ariaLabelConfig['edge.a11yDescription.default'] }), !disableKeyboardA11y && jsx(AriaLiveMessage, { rfId: rfId })] }));\n}\n\n/**\n * The `<Panel />` component helps you position content above the viewport.\n * It is used internally by the [`<MiniMap />`](/api-reference/components/minimap)\n * and [`<Controls />`](/api-reference/components/controls) components.\n *\n * @public\n *\n * @example\n * ```jsx\n *import { ReactFlow, Background, Panel } from '@xyflow/react';\n *\n *export default function Flow() {\n * return (\n * <ReactFlow nodes={[]} fitView>\n * <Panel position=\"top-left\">top-left</Panel>\n * <Panel position=\"top-center\">top-center</Panel>\n * <Panel position=\"top-right\">top-right</Panel>\n * <Panel position=\"bottom-left\">bottom-left</Panel>\n * <Panel position=\"bottom-center\">bottom-center</Panel>\n * <Panel position=\"bottom-right\">bottom-right</Panel>\n * </ReactFlow>\n * );\n *}\n *```\n */\nconst Panel = forwardRef(({ position = 'top-left', children, className, style, ...rest }, ref) => {\n const positionClasses = `${position}`.split('-');\n return (jsx(\"div\", { className: cc(['react-flow__panel', className, ...positionClasses]), style: style, ref: ref, ...rest, children: children }));\n});\nPanel.displayName = 'Panel';\n\nfunction Attribution({ proOptions, position = 'bottom-right' }) {\n if (proOptions?.hideAttribution) {\n return null;\n }\n return (jsx(Panel, { position: position, className: \"react-flow__attribution\", \"data-message\": \"Please only hide this attribution when you are subscribed to React Flow Pro: https://pro.reactflow.dev\", children: jsx(\"a\", { href: \"https://reactflow.dev\", target: \"_blank\", rel: \"noopener noreferrer\", \"aria-label\": \"React Flow attribution\", children: \"React Flow\" }) }));\n}\n\nconst selector$m = (s) => {\n const selectedNodes = [];\n const selectedEdges = [];\n for (const [, node] of s.nodeLookup) {\n if (node.selected) {\n selectedNodes.push(node.internals.userNode);\n }\n }\n for (const [, edge] of s.edgeLookup) {\n if (edge.selected) {\n selectedEdges.push(edge);\n }\n }\n return { selectedNodes, selectedEdges };\n};\nconst selectId = (obj) => obj.id;\nfunction areEqual(a, b) {\n return (shallow(a.selectedNodes.map(selectId), b.selectedNodes.map(selectId)) &&\n shallow(a.selectedEdges.map(selectId), b.selectedEdges.map(selectId)));\n}\nfunction SelectionListenerInner({ onSelectionChange, }) {\n const store = useStoreApi();\n const { selectedNodes, selectedEdges } = useStore(selector$m, areEqual);\n useEffect(() => {\n const params = { nodes: selectedNodes, edges: selectedEdges };\n onSelectionChange?.(params);\n store.getState().onSelectionChangeHandlers.forEach((fn) => fn(params));\n }, [selectedNodes, selectedEdges, onSelectionChange]);\n return null;\n}\nconst changeSelector = (s) => !!s.onSelectionChangeHandlers;\nfunction SelectionListener({ onSelectionChange, }) {\n const storeHasSelectionChangeHandlers = useStore(changeSelector);\n if (onSelectionChange || storeHasSelectionChangeHandlers) {\n return jsx(SelectionListenerInner, { onSelectionChange: onSelectionChange });\n }\n return null;\n}\n\nconst defaultNodeOrigin = [0, 0];\nconst defaultViewport = { x: 0, y: 0, zoom: 1 };\n\n/*\n * This component helps us to update the store with the values coming from the user.\n * We distinguish between values we can update directly with `useDirectStoreUpdater` (like `snapGrid`)\n * and values that have a dedicated setter function in the store (like `setNodes`).\n */\n// These fields exist in the global store, and we need to keep them up to date\nconst reactFlowFieldsToTrack = [\n 'nodes',\n 'edges',\n 'defaultNodes',\n 'defaultEdges',\n 'onConnect',\n 'onConnectStart',\n 'onConnectEnd',\n 'onClickConnectStart',\n 'onClickConnectEnd',\n 'nodesDraggable',\n 'autoPanOnNodeFocus',\n 'nodesConnectable',\n 'nodesFocusable',\n 'edgesFocusable',\n 'edgesReconnectable',\n 'elevateNodesOnSelect',\n 'elevateEdgesOnSelect',\n 'minZoom',\n 'maxZoom',\n 'nodeExtent',\n 'onNodesChange',\n 'onEdgesChange',\n 'elementsSelectable',\n 'connectionMode',\n 'snapGrid',\n 'snapToGrid',\n 'translateExtent',\n 'connectOnClick',\n 'defaultEdgeOptions',\n 'fitView',\n 'fitViewOptions',\n 'onNodesDelete',\n 'onEdgesDelete',\n 'onDelete',\n 'onNodeDrag',\n 'onNodeDragStart',\n 'onNodeDragStop',\n 'onSelectionDrag',\n 'onSelectionDragStart',\n 'onSelectionDragStop',\n 'onMoveStart',\n 'onMove',\n 'onMoveEnd',\n 'noPanClassName',\n 'nodeOrigin',\n 'autoPanOnConnect',\n 'autoPanOnNodeDrag',\n 'onError',\n 'connectionRadius',\n 'isValidConnection',\n 'selectNodesOnDrag',\n 'nodeDragThreshold',\n 'connectionDragThreshold',\n 'onBeforeDelete',\n 'debug',\n 'autoPanSpeed',\n 'paneClickDistance',\n 'ariaLabelConfig',\n];\n// rfId doesn't exist in ReactFlowProps, but it's one of the fields we want to update\nconst fieldsToTrack = [...reactFlowFieldsToTrack, 'rfId'];\nconst selector$l = (s) => ({\n setNodes: s.setNodes,\n setEdges: s.setEdges,\n setMinZoom: s.setMinZoom,\n setMaxZoom: s.setMaxZoom,\n setTranslateExtent: s.setTranslateExtent,\n setNodeExtent: s.setNodeExtent,\n reset: s.reset,\n setDefaultNodesAndEdges: s.setDefaultNodesAndEdges,\n setPaneClickDistance: s.setPaneClickDistance,\n});\nconst initPrevValues = {\n /*\n * these are values that are also passed directly to other components\n * than the StoreUpdater. We can reduce the number of setStore calls\n * by setting the same values here as prev fields.\n */\n translateExtent: infiniteExtent,\n nodeOrigin: defaultNodeOrigin,\n minZoom: 0.5,\n maxZoom: 2,\n elementsSelectable: true,\n noPanClassName: 'nopan',\n rfId: '1',\n paneClickDistance: 0,\n};\nfunction StoreUpdater(props) {\n const { setNodes, setEdges, setMinZoom, setMaxZoom, setTranslateExtent, setNodeExtent, reset, setDefaultNodesAndEdges, setPaneClickDistance, } = useStore(selector$l, shallow);\n const store = useStoreApi();\n useEffect(() => {\n setDefaultNodesAndEdges(props.defaultNodes, props.defaultEdges);\n return () => {\n // when we reset the store we also need to reset the previous fields\n previousFields.current = initPrevValues;\n reset();\n };\n }, []);\n const previousFields = useRef(initPrevValues);\n useEffect(() => {\n for (const fieldName of fieldsToTrack) {\n const fieldValue = props[fieldName];\n const previousFieldValue = previousFields.current[fieldName];\n if (fieldValue === previousFieldValue)\n continue;\n if (typeof props[fieldName] === 'undefined')\n continue;\n // Custom handling with dedicated setters for some fields\n if (fieldName === 'nodes')\n setNodes(fieldValue);\n else if (fieldName === 'edges')\n setEdges(fieldValue);\n else if (fieldName === 'minZoom')\n setMinZoom(fieldValue);\n else if (fieldName === 'maxZoom')\n setMaxZoom(fieldValue);\n else if (fieldName === 'translateExtent')\n setTranslateExtent(fieldValue);\n else if (fieldName === 'nodeExtent')\n setNodeExtent(fieldValue);\n else if (fieldName === 'paneClickDistance')\n setPaneClickDistance(fieldValue);\n else if (fieldName === 'ariaLabelConfig')\n store.setState({ ariaLabelConfig: mergeAriaLabelConfig(fieldValue) });\n // Renamed fields\n else if (fieldName === 'fitView')\n store.setState({ fitViewQueued: fieldValue });\n else if (fieldName === 'fitViewOptions')\n store.setState({ fitViewOptions: fieldValue });\n // General case\n else\n store.setState({ [fieldName]: fieldValue });\n }\n previousFields.current = props;\n }, \n // Only re-run the effect if one of the fields we track changes\n fieldsToTrack.map((fieldName) => props[fieldName]));\n return null;\n}\n\nfunction getMediaQuery() {\n if (typeof window === 'undefined' || !window.matchMedia) {\n return null;\n }\n return window.matchMedia('(prefers-color-scheme: dark)');\n}\n/**\n * Hook for receiving the current color mode class 'dark' or 'light'.\n *\n * @internal\n * @param colorMode - The color mode to use ('dark', 'light' or 'system')\n */\nfunction useColorModeClass(colorMode) {\n const [colorModeClass, setColorModeClass] = useState(colorMode === 'system' ? null : colorMode);\n useEffect(() => {\n if (colorMode !== 'system') {\n setColorModeClass(colorMode);\n return;\n }\n const mediaQuery = getMediaQuery();\n const updateColorModeClass = () => setColorModeClass(mediaQuery?.matches ? 'dark' : 'light');\n updateColorModeClass();\n mediaQuery?.addEventListener('change', updateColorModeClass);\n return () => {\n mediaQuery?.removeEventListener('change', updateColorModeClass);\n };\n }, [colorMode]);\n return colorModeClass !== null ? colorModeClass : getMediaQuery()?.matches ? 'dark' : 'light';\n}\n\nconst defaultDoc = typeof document !== 'undefined' ? document : null;\n/**\n * This hook lets you listen for specific key codes and tells you whether they are\n * currently pressed or not.\n *\n * @public\n * @param options - Options\n *\n * @example\n * ```tsx\n *import { useKeyPress } from '@xyflow/react';\n *\n *export default function () {\n * const spacePressed = useKeyPress('Space');\n * const cmdAndSPressed = useKeyPress(['Meta+s', 'Strg+s']);\n *\n * return (\n * <div>\n * {spacePressed && <p>Space pressed!</p>}\n * {cmdAndSPressed && <p>Cmd + S pressed!</p>}\n * </div>\n * );\n *}\n *```\n */\nfunction useKeyPress(\n/**\n * The key code (string or array of strings) specifies which key(s) should trigger\n * an action.\n *\n * A **string** can represent:\n * - A **single key**, e.g. `'a'`\n * - A **key combination**, using `'+'` to separate keys, e.g. `'a+d'`\n *\n * An **array of strings** represents **multiple possible key inputs**. For example, `['a', 'd+s']`\n * means the user can press either the single key `'a'` or the combination of `'d'` and `'s'`.\n * @default null\n */\nkeyCode = null, options = { target: defaultDoc, actInsideInputWithModifier: true }) {\n const [keyPressed, setKeyPressed] = useState(false);\n // we need to remember if a modifier key is pressed in order to track it\n const modifierPressed = useRef(false);\n // we need to remember the pressed keys in order to support combinations\n const pressedKeys = useRef(new Set([]));\n /*\n * keyCodes = array with single keys [['a']] or key combinations [['a', 's']]\n * keysToWatch = array with all keys flattened ['a', 'd', 'ShiftLeft']\n * used to check if we store event.code or event.key. When the code is in the list of keysToWatch\n * we use the code otherwise the key. Explainer: When you press the left \"command\" key, the code is \"MetaLeft\"\n * and the key is \"Meta\". We want users to be able to pass keys and codes so we assume that the key is meant when\n * we can't find it in the list of keysToWatch.\n */\n const [keyCodes, keysToWatch] = useMemo(() => {\n if (keyCode !== null) {\n const keyCodeArr = Array.isArray(keyCode) ? keyCode : [keyCode];\n const keys = keyCodeArr\n .filter((kc) => typeof kc === 'string')\n /*\n * we first replace all '+' with '\\n' which we will use to split the keys on\n * then we replace '\\n\\n' with '\\n+', this way we can also support the combination 'key++'\n * in the end we simply split on '\\n' to get the key array\n */\n .map((kc) => kc.replace('+', '\\n').replace('\\n\\n', '\\n+').split('\\n'));\n const keysFlat = keys.reduce((res, item) => res.concat(...item), []);\n return [keys, keysFlat];\n }\n return [[], []];\n }, [keyCode]);\n useEffect(() => {\n const target = options?.target ?? defaultDoc;\n const actInsideInputWithModifier = options?.actInsideInputWithModifier ?? true;\n if (keyCode !== null) {\n const downHandler = (event) => {\n modifierPressed.current = event.ctrlKey || event.metaKey || event.shiftKey || event.altKey;\n const preventAction = (!modifierPressed.current || (modifierPressed.current && !actInsideInputWithModifier)) &&\n isInputDOMNode(event);\n if (preventAction) {\n return false;\n }\n const keyOrCode = useKeyOrCode(event.code, keysToWatch);\n pressedKeys.current.add(event[keyOrCode]);\n if (isMatchingKey(keyCodes, pressedKeys.current, false)) {\n const target = (event.composedPath?.()?.[0] || event.target);\n const isInteractiveElement = target?.nodeName === 'BUTTON' || target?.nodeName === 'A';\n if (options.preventDefault !== false && (modifierPressed.current || !isInteractiveElement)) {\n event.preventDefault();\n }\n setKeyPressed(true);\n }\n };\n const upHandler = (event) => {\n const keyOrCode = useKeyOrCode(event.code, keysToWatch);\n if (isMatchingKey(keyCodes, pressedKeys.current, true)) {\n setKeyPressed(false);\n pressedKeys.current.clear();\n }\n else {\n pressedKeys.current.delete(event[keyOrCode]);\n }\n // fix for Mac: when cmd key is pressed, keyup is not triggered for any other key, see: https://stackoverflow.com/questions/27380018/when-cmd-key-is-kept-pressed-keyup-is-not-triggered-for-any-other-key\n if (event.key === 'Meta') {\n pressedKeys.current.clear();\n }\n modifierPressed.current = false;\n };\n const resetHandler = () => {\n pressedKeys.current.clear();\n setKeyPressed(false);\n };\n target?.addEventListener('keydown', downHandler);\n target?.addEventListener('keyup', upHandler);\n window.addEventListener('blur', resetHandler);\n window.addEventListener('contextmenu', resetHandler);\n return () => {\n target?.removeEventListener('keydown', downHandler);\n target?.removeEventListener('keyup', upHandler);\n window.removeEventListener('blur', resetHandler);\n window.removeEventListener('contextmenu', resetHandler);\n };\n }\n }, [keyCode, setKeyPressed]);\n return keyPressed;\n}\n// utils\nfunction isMatchingKey(keyCodes, pressedKeys, isUp) {\n return (keyCodes\n /*\n * we only want to compare same sizes of keyCode definitions\n * and pressed keys. When the user specified 'Meta' as a key somewhere\n * this would also be truthy without this filter when user presses 'Meta' + 'r'\n */\n .filter((keys) => isUp || keys.length === pressedKeys.size)\n /*\n * since we want to support multiple possibilities only one of the\n * combinations need to be part of the pressed keys\n */\n .some((keys) => keys.every((k) => pressedKeys.has(k))));\n}\nfunction useKeyOrCode(eventCode, keysToWatch) {\n return keysToWatch.includes(eventCode) ? 'code' : 'key';\n}\n\n/**\n * Hook for getting viewport helper functions.\n *\n * @internal\n * @returns viewport helper functions\n */\nconst useViewportHelper = () => {\n const store = useStoreApi();\n return useMemo(() => {\n return {\n zoomIn: (options) => {\n const { panZoom } = store.getState();\n return panZoom ? panZoom.scaleBy(1.2, { duration: options?.duration }) : Promise.resolve(false);\n },\n zoomOut: (options) => {\n const { panZoom } = store.getState();\n return panZoom ? panZoom.scaleBy(1 / 1.2, { duration: options?.duration }) : Promise.resolve(false);\n },\n zoomTo: (zoomLevel, options) => {\n const { panZoom } = store.getState();\n return panZoom ? panZoom.scaleTo(zoomLevel, { duration: options?.duration }) : Promise.resolve(false);\n },\n getZoom: () => store.getState().transform[2],\n setViewport: async (viewport, options) => {\n const { transform: [tX, tY, tZoom], panZoom, } = store.getState();\n if (!panZoom) {\n return Promise.resolve(false);\n }\n await panZoom.setViewport({\n x: viewport.x ?? tX,\n y: viewport.y ?? tY,\n zoom: viewport.zoom ?? tZoom,\n }, options);\n return Promise.resolve(true);\n },\n getViewport: () => {\n const [x, y, zoom] = store.getState().transform;\n return { x, y, zoom };\n },\n setCenter: async (x, y, options) => {\n return store.getState().setCenter(x, y, options);\n },\n fitBounds: async (bounds, options) => {\n const { width, height, minZoom, maxZoom, panZoom } = store.getState();\n const viewport = getViewportForBounds(bounds, width, height, minZoom, maxZoom, options?.padding ?? 0.1);\n if (!panZoom) {\n return Promise.resolve(false);\n }\n await panZoom.setViewport(viewport, {\n duration: options?.duration,\n ease: options?.ease,\n interpolate: options?.interpolate,\n });\n return Promise.resolve(true);\n },\n screenToFlowPosition: (clientPosition, options = {}) => {\n const { transform, snapGrid, snapToGrid, domNode } = store.getState();\n if (!domNode) {\n return clientPosition;\n }\n const { x: domX, y: domY } = domNode.getBoundingClientRect();\n const correctedPosition = {\n x: clientPosition.x - domX,\n y: clientPosition.y - domY,\n };\n const _snapGrid = options.snapGrid ?? snapGrid;\n const _snapToGrid = options.snapToGrid ?? snapToGrid;\n return pointToRendererPoint(correctedPosition, transform, _snapToGrid, _snapGrid);\n },\n flowToScreenPosition: (flowPosition) => {\n const { transform, domNode } = store.getState();\n if (!domNode) {\n return flowPosition;\n }\n const { x: domX, y: domY } = domNode.getBoundingClientRect();\n const rendererPosition = rendererPointToPoint(flowPosition, transform);\n return {\n x: rendererPosition.x + domX,\n y: rendererPosition.y + domY,\n };\n },\n };\n }, []);\n};\n\n/*\n * This function applies changes to nodes or edges that are triggered by React Flow internally.\n * When you drag a node for example, React Flow will send a position change update.\n * This function then applies the changes and returns the updated elements.\n */\nfunction applyChanges(changes, elements) {\n const updatedElements = [];\n /*\n * By storing a map of changes for each element, we can a quick lookup as we\n * iterate over the elements array!\n */\n const changesMap = new Map();\n const addItemChanges = [];\n for (const change of changes) {\n if (change.type === 'add') {\n addItemChanges.push(change);\n continue;\n }\n else if (change.type === 'remove' || change.type === 'replace') {\n /*\n * For a 'remove' change we can safely ignore any other changes queued for\n * the same element, it's going to be removed anyway!\n */\n changesMap.set(change.id, [change]);\n }\n else {\n const elementChanges = changesMap.get(change.id);\n if (elementChanges) {\n /*\n * If we have some changes queued already, we can do a mutable update of\n * that array and save ourselves some copying.\n */\n elementChanges.push(change);\n }\n else {\n changesMap.set(change.id, [change]);\n }\n }\n }\n for (const element of elements) {\n const changes = changesMap.get(element.id);\n /*\n * When there are no changes for an element we can just push it unmodified,\n * no need to copy it.\n */\n if (!changes) {\n updatedElements.push(element);\n continue;\n }\n // If we have a 'remove' change queued, it'll be the only change in the array\n if (changes[0].type === 'remove') {\n continue;\n }\n if (changes[0].type === 'replace') {\n updatedElements.push({ ...changes[0].item });\n continue;\n }\n /**\n * For other types of changes, we want to start with a shallow copy of the\n * object so React knows this element has changed. Sequential changes will\n * each _mutate_ this object, so there's only ever one copy.\n */\n const updatedElement = { ...element };\n for (const change of changes) {\n applyChange(change, updatedElement);\n }\n updatedElements.push(updatedElement);\n }\n /*\n * we need to wait for all changes to be applied before adding new items\n * to be able to add them at the correct index\n */\n if (addItemChanges.length) {\n addItemChanges.forEach((change) => {\n if (change.index !== undefined) {\n updatedElements.splice(change.index, 0, { ...change.item });\n }\n else {\n updatedElements.push({ ...change.item });\n }\n });\n }\n return updatedElements;\n}\n// Applies a single change to an element. This is a *mutable* update.\nfunction applyChange(change, element) {\n switch (change.type) {\n case 'select': {\n element.selected = change.selected;\n break;\n }\n case 'position': {\n if (typeof change.position !== 'undefined') {\n element.position = change.position;\n }\n if (typeof change.dragging !== 'undefined') {\n element.dragging = change.dragging;\n }\n break;\n }\n case 'dimensions': {\n if (typeof change.dimensions !== 'undefined') {\n element.measured ??= {};\n element.measured.width = change.dimensions.width;\n element.measured.height = change.dimensions.height;\n if (change.setAttributes) {\n if (change.setAttributes === true || change.setAttributes === 'width') {\n element.width = change.dimensions.width;\n }\n if (change.setAttributes === true || change.setAttributes === 'height') {\n element.height = change.dimensions.height;\n }\n }\n }\n if (typeof change.resizing === 'boolean') {\n element.resizing = change.resizing;\n }\n break;\n }\n }\n}\n/**\n * Drop in function that applies node changes to an array of nodes.\n * @public\n * @param changes - Array of changes to apply.\n * @param nodes - Array of nodes to apply the changes to.\n * @returns Array of updated nodes.\n * @example\n *```tsx\n *import { useState, useCallback } from 'react';\n *import { ReactFlow, applyNodeChanges, type Node, type Edge, type OnNodesChange } from '@xyflow/react';\n *\n *export default function Flow() {\n * const [nodes, setNodes] = useState<Node[]>([]);\n * const [edges, setEdges] = useState<Edge[]>([]);\n * const onNodesChange: OnNodesChange = useCallback(\n * (changes) => {\n * setNodes((oldNodes) => applyNodeChanges(changes, oldNodes));\n * },\n * [setNodes],\n * );\n *\n * return (\n * <ReactFlow nodes={nodes} edges={edges} onNodesChange={onNodesChange} />\n * );\n *}\n *```\n * @remarks Various events on the <ReactFlow /> component can produce an {@link NodeChange}\n * that describes how to update the edges of your flow in some way.\n * If you don't need any custom behaviour, this util can be used to take an array\n * of these changes and apply them to your edges.\n */\nfunction applyNodeChanges(changes, nodes) {\n return applyChanges(changes, nodes);\n}\n/**\n * Drop in function that applies edge changes to an array of edges.\n * @public\n * @param changes - Array of changes to apply.\n * @param edges - Array of edge to apply the changes to.\n * @returns Array of updated edges.\n * @example\n * ```tsx\n *import { useState, useCallback } from 'react';\n *import { ReactFlow, applyEdgeChanges } from '@xyflow/react';\n *\n *export default function Flow() {\n * const [nodes, setNodes] = useState([]);\n * const [edges, setEdges] = useState([]);\n * const onEdgesChange = useCallback(\n * (changes) => {\n * setEdges((oldEdges) => applyEdgeChanges(changes, oldEdges));\n * },\n * [setEdges],\n * );\n *\n * return (\n * <ReactFlow nodes={nodes} edges={edges} onEdgesChange={onEdgesChange} />\n * );\n *}\n *```\n * @remarks Various events on the <ReactFlow /> component can produce an {@link EdgeChange}\n * that describes how to update the edges of your flow in some way.\n * If you don't need any custom behaviour, this util can be used to take an array\n * of these changes and apply them to your edges.\n */\nfunction applyEdgeChanges(changes, edges) {\n return applyChanges(changes, edges);\n}\nfunction createSelectionChange(id, selected) {\n return {\n id,\n type: 'select',\n selected,\n };\n}\nfunction getSelectionChanges(items, selectedIds = new Set(), mutateItem = false) {\n const changes = [];\n for (const [id, item] of items) {\n const willBeSelected = selectedIds.has(id);\n // we don't want to set all items to selected=false on the first selection\n if (!(item.selected === undefined && !willBeSelected) && item.selected !== willBeSelected) {\n if (mutateItem) {\n /*\n * this hack is needed for nodes. When the user dragged a node, it's selected.\n * When another node gets dragged, we need to deselect the previous one,\n * in order to have only one selected node at a time - the onNodesChange callback comes too late here :/\n */\n item.selected = willBeSelected;\n }\n changes.push(createSelectionChange(item.id, willBeSelected));\n }\n }\n return changes;\n}\nfunction getElementsDiffChanges({ items = [], lookup, }) {\n const changes = [];\n const itemsLookup = new Map(items.map((item) => [item.id, item]));\n for (const [index, item] of items.entries()) {\n const lookupItem = lookup.get(item.id);\n const storeItem = lookupItem?.internals?.userNode ?? lookupItem;\n if (storeItem !== undefined && storeItem !== item) {\n changes.push({ id: item.id, item: item, type: 'replace' });\n }\n if (storeItem === undefined) {\n changes.push({ item: item, type: 'add', index });\n }\n }\n for (const [id] of lookup) {\n const nextNode = itemsLookup.get(id);\n if (nextNode === undefined) {\n changes.push({ id, type: 'remove' });\n }\n }\n return changes;\n}\nfunction elementToRemoveChange(item) {\n return {\n id: item.id,\n type: 'remove',\n };\n}\n\n/**\n * Test whether an object is usable as an [`Node`](/api-reference/types/node).\n * In TypeScript this is a type guard that will narrow the type of whatever you pass in to\n * [`Node`](/api-reference/types/node) if it returns `true`.\n *\n * @public\n * @remarks In TypeScript this is a type guard that will narrow the type of whatever you pass in to Node if it returns true\n * @param element - The element to test.\n * @returns Tests whether the provided value can be used as a `Node`. If you're using TypeScript,\n * this function acts as a type guard and will narrow the type of the value to `Node` if it returns\n * `true`.\n *\n * @example\n * ```js\n *import { isNode } from '@xyflow/react';\n *\n *if (isNode(node)) {\n * // ...\n *}\n *```\n */\nconst isNode = (element) => isNodeBase(element);\n/**\n * Test whether an object is usable as an [`Edge`](/api-reference/types/edge).\n * In TypeScript this is a type guard that will narrow the type of whatever you pass in to\n * [`Edge`](/api-reference/types/edge) if it returns `true`.\n *\n * @public\n * @remarks In TypeScript this is a type guard that will narrow the type of whatever you pass in to Edge if it returns true\n * @param element - The element to test\n * @returns Tests whether the provided value can be used as an `Edge`. If you're using TypeScript,\n * this function acts as a type guard and will narrow the type of the value to `Edge` if it returns\n * `true`.\n *\n * @example\n * ```js\n *import { isEdge } from '@xyflow/react';\n *\n *if (isEdge(edge)) {\n * // ...\n *}\n *```\n */\nconst isEdge = (element) => isEdgeBase(element);\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nfunction fixedForwardRef(render) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return forwardRef(render);\n}\n\n// we need this hook to prevent a warning when using react-flow in SSR\nconst useIsomorphicLayoutEffect = typeof window !== 'undefined' ? useLayoutEffect : useEffect;\n\n/**\n * This hook returns a queue that can be used to batch updates.\n *\n * @param runQueue - a function that gets called when the queue is flushed\n * @internal\n *\n * @returns a Queue object\n */\nfunction useQueue(runQueue) {\n /*\n * Because we're using a ref above, we need some way to let React know when to\n * actually process the queue. We increment this number any time we mutate the\n * queue, creating a new state to trigger the layout effect below.\n * Using a boolean dirty flag here instead would lead to issues related to\n * automatic batching. (https://github.com/xyflow/xyflow/issues/4779)\n */\n const [serial, setSerial] = useState(BigInt(0));\n /*\n * A reference of all the batched updates to process before the next render. We\n * want a reference here so multiple synchronous calls to `setNodes` etc can be\n * batched together.\n */\n const [queue] = useState(() => createQueue(() => setSerial(n => n + BigInt(1))));\n /*\n * Layout effects are guaranteed to run before the next render which means we\n * shouldn't run into any issues with stale state or weird issues that come from\n * rendering things one frame later than expected (we used to use `setTimeout`).\n */\n useIsomorphicLayoutEffect(() => {\n const queueItems = queue.get();\n if (queueItems.length) {\n runQueue(queueItems);\n queue.reset();\n }\n }, [serial]);\n return queue;\n}\nfunction createQueue(cb) {\n let queue = [];\n return {\n get: () => queue,\n reset: () => {\n queue = [];\n },\n push: (item) => {\n queue.push(item);\n cb();\n },\n };\n}\n\nconst BatchContext = createContext(null);\n/**\n * This is a context provider that holds and processes the node and edge update queues\n * that are needed to handle setNodes, addNodes, setEdges and addEdges.\n *\n * @internal\n */\nfunction BatchProvider({ children, }) {\n const store = useStoreApi();\n const nodeQueueHandler = useCallback((queueItems) => {\n const { nodes = [], setNodes, hasDefaultNodes, onNodesChange, nodeLookup, fitViewQueued } = store.getState();\n /*\n * This is essentially an `Array.reduce` in imperative clothing. Processing\n * this queue is a relatively hot path so we'd like to avoid the overhead of\n * array methods where we can.\n */\n let next = nodes;\n for (const payload of queueItems) {\n next = typeof payload === 'function' ? payload(next) : payload;\n }\n const changes = getElementsDiffChanges({\n items: next,\n lookup: nodeLookup,\n });\n if (hasDefaultNodes) {\n setNodes(next);\n }\n // We only want to fire onNodesChange if there are changes to the nodes\n if (changes.length > 0) {\n onNodesChange?.(changes);\n }\n else if (fitViewQueued) {\n // If there are no changes to the nodes, we still need to call setNodes\n // to trigger a re-render and fitView.\n window.requestAnimationFrame(() => {\n const { fitViewQueued, nodes, setNodes } = store.getState();\n if (fitViewQueued) {\n setNodes(nodes);\n }\n });\n }\n }, []);\n const nodeQueue = useQueue(nodeQueueHandler);\n const edgeQueueHandler = useCallback((queueItems) => {\n const { edges = [], setEdges, hasDefaultEdges, onEdgesChange, edgeLookup } = store.getState();\n let next = edges;\n for (const payload of queueItems) {\n next = typeof payload === 'function' ? payload(next) : payload;\n }\n if (hasDefaultEdges) {\n setEdges(next);\n }\n else if (onEdgesChange) {\n onEdgesChange(getElementsDiffChanges({\n items: next,\n lookup: edgeLookup,\n }));\n }\n }, []);\n const edgeQueue = useQueue(edgeQueueHandler);\n const value = useMemo(() => ({ nodeQueue, edgeQueue }), []);\n return jsx(BatchContext.Provider, { value: value, children: children });\n}\nfunction useBatchContext() {\n const batchContext = useContext(BatchContext);\n if (!batchContext) {\n throw new Error('useBatchContext must be used within a BatchProvider');\n }\n return batchContext;\n}\n\nconst selector$k = (s) => !!s.panZoom;\n/**\n * This hook returns a ReactFlowInstance that can be used to update nodes and edges, manipulate the viewport, or query the current state of the flow.\n *\n * @public\n * @example\n * ```jsx\n *import { useCallback, useState } from 'react';\n *import { useReactFlow } from '@xyflow/react';\n *\n *export function NodeCounter() {\n * const reactFlow = useReactFlow();\n * const [count, setCount] = useState(0);\n * const countNodes = useCallback(() => {\n * setCount(reactFlow.getNodes().length);\n * // you need to pass it as a dependency if you are using it with useEffect or useCallback\n * // because at the first render, it's not initialized yet and some functions might not work.\n * }, [reactFlow]);\n *\n * return (\n * <div>\n * <button onClick={countNodes}>Update count</button>\n * <p>There are {count} nodes in the flow.</p>\n * </div>\n * );\n *}\n *```\n */\nfunction useReactFlow() {\n const viewportHelper = useViewportHelper();\n const store = useStoreApi();\n const batchContext = useBatchContext();\n const viewportInitialized = useStore(selector$k);\n const generalHelper = useMemo(() => {\n const getInternalNode = (id) => store.getState().nodeLookup.get(id);\n const setNodes = (payload) => {\n batchContext.nodeQueue.push(payload);\n };\n const setEdges = (payload) => {\n batchContext.edgeQueue.push(payload);\n };\n const getNodeRect = (node) => {\n const { nodeLookup, nodeOrigin } = store.getState();\n const nodeToUse = isNode(node) ? node : nodeLookup.get(node.id);\n const position = nodeToUse.parentId\n ? evaluateAbsolutePosition(nodeToUse.position, nodeToUse.measured, nodeToUse.parentId, nodeLookup, nodeOrigin)\n : nodeToUse.position;\n const nodeWithPosition = {\n ...nodeToUse,\n position,\n width: nodeToUse.measured?.width ?? nodeToUse.width,\n height: nodeToUse.measured?.height ?? nodeToUse.height,\n };\n return nodeToRect(nodeWithPosition);\n };\n const updateNode = (id, nodeUpdate, options = { replace: false }) => {\n setNodes((prevNodes) => prevNodes.map((node) => {\n if (node.id === id) {\n const nextNode = typeof nodeUpdate === 'function' ? nodeUpdate(node) : nodeUpdate;\n return options.replace && isNode(nextNode) ? nextNode : { ...node, ...nextNode };\n }\n return node;\n }));\n };\n const updateEdge = (id, edgeUpdate, options = { replace: false }) => {\n setEdges((prevEdges) => prevEdges.map((edge) => {\n if (edge.id === id) {\n const nextEdge = typeof edgeUpdate === 'function' ? edgeUpdate(edge) : edgeUpdate;\n return options.replace && isEdge(nextEdge) ? nextEdge : { ...edge, ...nextEdge };\n }\n return edge;\n }));\n };\n return {\n getNodes: () => store.getState().nodes.map((n) => ({ ...n })),\n getNode: (id) => getInternalNode(id)?.internals.userNode,\n getInternalNode,\n getEdges: () => {\n const { edges = [] } = store.getState();\n return edges.map((e) => ({ ...e }));\n },\n getEdge: (id) => store.getState().edgeLookup.get(id),\n setNodes,\n setEdges,\n addNodes: (payload) => {\n const newNodes = Array.isArray(payload) ? payload : [payload];\n batchContext.nodeQueue.push((nodes) => [...nodes, ...newNodes]);\n },\n addEdges: (payload) => {\n const newEdges = Array.isArray(payload) ? payload : [payload];\n batchContext.edgeQueue.push((edges) => [...edges, ...newEdges]);\n },\n toObject: () => {\n const { nodes = [], edges = [], transform } = store.getState();\n const [x, y, zoom] = transform;\n return {\n nodes: nodes.map((n) => ({ ...n })),\n edges: edges.map((e) => ({ ...e })),\n viewport: {\n x,\n y,\n zoom,\n },\n };\n },\n deleteElements: async ({ nodes: nodesToRemove = [], edges: edgesToRemove = [] }) => {\n const { nodes, edges, onNodesDelete, onEdgesDelete, triggerNodeChanges, triggerEdgeChanges, onDelete, onBeforeDelete, } = store.getState();\n const { nodes: matchingNodes, edges: matchingEdges } = await getElementsToRemove({\n nodesToRemove,\n edgesToRemove,\n nodes,\n edges,\n onBeforeDelete,\n });\n const hasMatchingEdges = matchingEdges.length > 0;\n const hasMatchingNodes = matchingNodes.length > 0;\n if (hasMatchingEdges) {\n const edgeChanges = matchingEdges.map(elementToRemoveChange);\n onEdgesDelete?.(matchingEdges);\n triggerEdgeChanges(edgeChanges);\n }\n if (hasMatchingNodes) {\n const nodeChanges = matchingNodes.map(elementToRemoveChange);\n onNodesDelete?.(matchingNodes);\n triggerNodeChanges(nodeChanges);\n }\n if (hasMatchingNodes || hasMatchingEdges) {\n onDelete?.({ nodes: matchingNodes, edges: matchingEdges });\n }\n return { deletedNodes: matchingNodes, deletedEdges: matchingEdges };\n },\n /**\n * Partial is defined as \"the 2 nodes/areas are intersecting partially\".\n * If a is contained in b or b is contained in a, they are both\n * considered fully intersecting.\n */\n getIntersectingNodes: (nodeOrRect, partially = true, nodes) => {\n const isRect = isRectObject(nodeOrRect);\n const nodeRect = isRect ? nodeOrRect : getNodeRect(nodeOrRect);\n const hasNodesOption = nodes !== undefined;\n if (!nodeRect) {\n return [];\n }\n return (nodes || store.getState().nodes).filter((n) => {\n const internalNode = store.getState().nodeLookup.get(n.id);\n if (internalNode && !isRect && (n.id === nodeOrRect.id || !internalNode.internals.positionAbsolute)) {\n return false;\n }\n const currNodeRect = nodeToRect(hasNodesOption ? n : internalNode);\n const overlappingArea = getOverlappingArea(currNodeRect, nodeRect);\n const partiallyVisible = partially && overlappingArea > 0;\n return (partiallyVisible ||\n overlappingArea >= currNodeRect.width * currNodeRect.height ||\n overlappingArea >= nodeRect.width * nodeRect.height);\n });\n },\n isNodeIntersecting: (nodeOrRect, area, partially = true) => {\n const isRect = isRectObject(nodeOrRect);\n const nodeRect = isRect ? nodeOrRect : getNodeRect(nodeOrRect);\n if (!nodeRect) {\n return false;\n }\n const overlappingArea = getOverlappingArea(nodeRect, area);\n const partiallyVisible = partially && overlappingArea > 0;\n return (partiallyVisible ||\n overlappingArea >= area.width * area.height ||\n overlappingArea >= nodeRect.width * nodeRect.height);\n },\n updateNode,\n updateNodeData: (id, dataUpdate, options = { replace: false }) => {\n updateNode(id, (node) => {\n const nextData = typeof dataUpdate === 'function' ? dataUpdate(node) : dataUpdate;\n return options.replace ? { ...node, data: nextData } : { ...node, data: { ...node.data, ...nextData } };\n }, options);\n },\n updateEdge,\n updateEdgeData: (id, dataUpdate, options = { replace: false }) => {\n updateEdge(id, (edge) => {\n const nextData = typeof dataUpdate === 'function' ? dataUpdate(edge) : dataUpdate;\n return options.replace ? { ...edge, data: nextData } : { ...edge, data: { ...edge.data, ...nextData } };\n }, options);\n },\n getNodesBounds: (nodes) => {\n const { nodeLookup, nodeOrigin } = store.getState();\n return getNodesBounds(nodes, { nodeLookup, nodeOrigin });\n },\n getHandleConnections: ({ type, id, nodeId }) => Array.from(store\n .getState()\n .connectionLookup.get(`${nodeId}-${type}${id ? `-${id}` : ''}`)\n ?.values() ?? []),\n getNodeConnections: ({ type, handleId, nodeId }) => Array.from(store\n .getState()\n .connectionLookup.get(`${nodeId}${type ? (handleId ? `-${type}-${handleId}` : `-${type}`) : ''}`)\n ?.values() ?? []),\n fitView: async (options) => {\n // We either create a new Promise or reuse the existing one\n // Even if fitView is called multiple times in a row, we only end up with a single Promise\n const fitViewResolver = store.getState().fitViewResolver ?? withResolvers();\n // We schedule a fitView by setting fitViewQueued and triggering a setNodes\n store.setState({ fitViewQueued: true, fitViewOptions: options, fitViewResolver });\n batchContext.nodeQueue.push((nodes) => [...nodes]);\n return fitViewResolver.promise;\n },\n };\n }, []);\n return useMemo(() => {\n return {\n ...generalHelper,\n ...viewportHelper,\n viewportInitialized,\n };\n }, [viewportInitialized]);\n}\n\nconst selected = (item) => item.selected;\nconst win$1 = typeof window !== 'undefined' ? window : undefined;\n/**\n * Hook for handling global key events.\n *\n * @internal\n */\nfunction useGlobalKeyHandler({ deleteKeyCode, multiSelectionKeyCode, }) {\n const store = useStoreApi();\n const { deleteElements } = useReactFlow();\n const deleteKeyPressed = useKeyPress(deleteKeyCode, { actInsideInputWithModifier: false });\n const multiSelectionKeyPressed = useKeyPress(multiSelectionKeyCode, { target: win$1 });\n useEffect(() => {\n if (deleteKeyPressed) {\n const { edges, nodes } = store.getState();\n deleteElements({ nodes: nodes.filter(selected), edges: edges.filter(selected) });\n store.setState({ nodesSelectionActive: false });\n }\n }, [deleteKeyPressed]);\n useEffect(() => {\n store.setState({ multiSelectionActive: multiSelectionKeyPressed });\n }, [multiSelectionKeyPressed]);\n}\n\n/**\n * Hook for handling resize events.\n *\n * @internal\n */\nfunction useResizeHandler(domNode) {\n const store = useStoreApi();\n useEffect(() => {\n const updateDimensions = () => {\n if (!domNode.current || !(domNode.current.checkVisibility?.() ?? true)) {\n return false;\n }\n const size = getDimensions(domNode.current);\n if (size.height === 0 || size.width === 0) {\n store.getState().onError?.('004', errorMessages['error004']());\n }\n store.setState({ width: size.width || 500, height: size.height || 500 });\n };\n if (domNode.current) {\n updateDimensions();\n window.addEventListener('resize', updateDimensions);\n const resizeObserver = new ResizeObserver(() => updateDimensions());\n resizeObserver.observe(domNode.current);\n return () => {\n window.removeEventListener('resize', updateDimensions);\n if (resizeObserver && domNode.current) {\n resizeObserver.unobserve(domNode.current);\n }\n };\n }\n }, []);\n}\n\nconst containerStyle = {\n position: 'absolute',\n width: '100%',\n height: '100%',\n top: 0,\n left: 0,\n};\n\nconst selector$j = (s) => ({\n userSelectionActive: s.userSelectionActive,\n lib: s.lib,\n connectionInProgress: s.connection.inProgress,\n});\nfunction ZoomPane({ onPaneContextMenu, zoomOnScroll = true, zoomOnPinch = true, panOnScroll = false, panOnScrollSpeed = 0.5, panOnScrollMode = PanOnScrollMode.Free, zoomOnDoubleClick = true, panOnDrag = true, defaultViewport, translateExtent, minZoom, maxZoom, zoomActivationKeyCode, preventScrolling = true, children, noWheelClassName, noPanClassName, onViewportChange, isControlledViewport, paneClickDistance, }) {\n const store = useStoreApi();\n const zoomPane = useRef(null);\n const { userSelectionActive, lib, connectionInProgress } = useStore(selector$j, shallow);\n const zoomActivationKeyPressed = useKeyPress(zoomActivationKeyCode);\n const panZoom = useRef();\n useResizeHandler(zoomPane);\n const onTransformChange = useCallback((transform) => {\n onViewportChange?.({ x: transform[0], y: transform[1], zoom: transform[2] });\n if (!isControlledViewport) {\n store.setState({ transform });\n }\n }, [onViewportChange, isControlledViewport]);\n useEffect(() => {\n if (zoomPane.current) {\n panZoom.current = XYPanZoom({\n domNode: zoomPane.current,\n minZoom,\n maxZoom,\n translateExtent,\n viewport: defaultViewport,\n paneClickDistance,\n onDraggingChange: (paneDragging) => store.setState({ paneDragging }),\n onPanZoomStart: (event, vp) => {\n const { onViewportChangeStart, onMoveStart } = store.getState();\n onMoveStart?.(event, vp);\n onViewportChangeStart?.(vp);\n },\n onPanZoom: (event, vp) => {\n const { onViewportChange, onMove } = store.getState();\n onMove?.(event, vp);\n onViewportChange?.(vp);\n },\n onPanZoomEnd: (event, vp) => {\n const { onViewportChangeEnd, onMoveEnd } = store.getState();\n onMoveEnd?.(event, vp);\n onViewportChangeEnd?.(vp);\n },\n });\n const { x, y, zoom } = panZoom.current.getViewport();\n store.setState({\n panZoom: panZoom.current,\n transform: [x, y, zoom],\n domNode: zoomPane.current.closest('.react-flow'),\n });\n return () => {\n panZoom.current?.destroy();\n };\n }\n }, []);\n useEffect(() => {\n panZoom.current?.update({\n onPaneContextMenu,\n zoomOnScroll,\n zoomOnPinch,\n panOnScroll,\n panOnScrollSpeed,\n panOnScrollMode,\n zoomOnDoubleClick,\n panOnDrag,\n zoomActivationKeyPressed,\n preventScrolling,\n noPanClassName,\n userSelectionActive,\n noWheelClassName,\n lib,\n onTransformChange,\n connectionInProgress,\n });\n }, [\n onPaneContextMenu,\n zoomOnScroll,\n zoomOnPinch,\n panOnScroll,\n panOnScrollSpeed,\n panOnScrollMode,\n zoomOnDoubleClick,\n panOnDrag,\n zoomActivationKeyPressed,\n preventScrolling,\n noPanClassName,\n userSelectionActive,\n noWheelClassName,\n lib,\n onTransformChange,\n connectionInProgress,\n ]);\n return (jsx(\"div\", { className: \"react-flow__renderer\", ref: zoomPane, style: containerStyle, children: children }));\n}\n\nconst selector$i = (s) => ({\n userSelectionActive: s.userSelectionActive,\n userSelectionRect: s.userSelectionRect,\n});\nfunction UserSelection() {\n const { userSelectionActive, userSelectionRect } = useStore(selector$i, shallow);\n const isActive = userSelectionActive && userSelectionRect;\n if (!isActive) {\n return null;\n }\n return (jsx(\"div\", { className: \"react-flow__selection react-flow__container\", style: {\n width: userSelectionRect.width,\n height: userSelectionRect.height,\n transform: `translate(${userSelectionRect.x}px, ${userSelectionRect.y}px)`,\n } }));\n}\n\nconst wrapHandler = (handler, containerRef) => {\n return (event) => {\n if (event.target !== containerRef.current) {\n return;\n }\n handler?.(event);\n };\n};\nconst selector$h = (s) => ({\n userSelectionActive: s.userSelectionActive,\n elementsSelectable: s.elementsSelectable,\n connectionInProgress: s.connection.inProgress,\n dragging: s.paneDragging,\n});\nfunction Pane({ isSelecting, selectionKeyPressed, selectionMode = SelectionMode.Full, panOnDrag, selectionOnDrag, onSelectionStart, onSelectionEnd, onPaneClick, onPaneContextMenu, onPaneScroll, onPaneMouseEnter, onPaneMouseMove, onPaneMouseLeave, children, }) {\n const store = useStoreApi();\n const { userSelectionActive, elementsSelectable, dragging, connectionInProgress } = useStore(selector$h, shallow);\n const hasActiveSelection = elementsSelectable && (isSelecting || userSelectionActive);\n const container = useRef(null);\n const containerBounds = useRef();\n const selectedNodeIds = useRef(new Set());\n const selectedEdgeIds = useRef(new Set());\n // Used to prevent click events when the user lets go of the selectionKey during a selection\n const selectionInProgress = useRef(false);\n const selectionStarted = useRef(false);\n const onClick = (event) => {\n // We prevent click events when the user let go of the selectionKey during a selection\n // We also prevent click events when a connection is in progress\n if (selectionInProgress.current || connectionInProgress) {\n selectionInProgress.current = false;\n return;\n }\n onPaneClick?.(event);\n store.getState().resetSelectedElements();\n store.setState({ nodesSelectionActive: false });\n };\n const onContextMenu = (event) => {\n if (Array.isArray(panOnDrag) && panOnDrag?.includes(2)) {\n event.preventDefault();\n return;\n }\n onPaneContextMenu?.(event);\n };\n const onWheel = onPaneScroll ? (event) => onPaneScroll(event) : undefined;\n const onClickCapture = (event) => {\n const isSelectionOnDragActive = (selectionOnDrag && container.current === event.target) || !selectionOnDrag || selectionKeyPressed;\n if (!isSelectionOnDragActive) {\n return;\n }\n event.stopPropagation();\n };\n // We are using capture here in order to prevent other pointer events\n // to be able to create a selection above a node or an edge\n const onPointerDownCapture = (event) => {\n const { resetSelectedElements, domNode } = store.getState();\n containerBounds.current = domNode?.getBoundingClientRect();\n const isNoKeyEvent = event.target !== container.current && !!event.target.closest('.nokey');\n const isSelectionActive = (selectionOnDrag && container.current === event.target) || !selectionOnDrag || selectionKeyPressed;\n if (!elementsSelectable ||\n !isSelecting ||\n event.button !== 0 ||\n !containerBounds.current ||\n isNoKeyEvent ||\n !isSelectionActive ||\n !event.isPrimary) {\n return;\n }\n event.stopPropagation();\n event.preventDefault();\n event.target?.setPointerCapture?.(event.pointerId);\n selectionStarted.current = true;\n selectionInProgress.current = false;\n const { x, y } = getEventPosition(event.nativeEvent, containerBounds.current);\n resetSelectedElements();\n store.setState({\n userSelectionRect: {\n width: 0,\n height: 0,\n startX: x,\n startY: y,\n x,\n y,\n },\n });\n onSelectionStart?.(event);\n };\n const onPointerMove = (event) => {\n const { userSelectionRect, transform, nodeLookup, edgeLookup, connectionLookup, triggerNodeChanges, triggerEdgeChanges, defaultEdgeOptions, } = store.getState();\n if (!containerBounds.current || !userSelectionRect) {\n return;\n }\n selectionInProgress.current = true;\n const { x: mouseX, y: mouseY } = getEventPosition(event.nativeEvent, containerBounds.current);\n const { startX, startY } = userSelectionRect;\n const nextUserSelectRect = {\n startX,\n startY,\n x: mouseX < startX ? mouseX : startX,\n y: mouseY < startY ? mouseY : startY,\n width: Math.abs(mouseX - startX),\n height: Math.abs(mouseY - startY),\n };\n const prevSelectedNodeIds = selectedNodeIds.current;\n const prevSelectedEdgeIds = selectedEdgeIds.current;\n selectedNodeIds.current = new Set(getNodesInside(nodeLookup, nextUserSelectRect, transform, selectionMode === SelectionMode.Partial, true).map((node) => node.id));\n selectedEdgeIds.current = new Set();\n const edgesSelectable = defaultEdgeOptions?.selectable ?? true;\n // We look for all edges connected to the selected nodes\n for (const nodeId of selectedNodeIds.current) {\n const connections = connectionLookup.get(nodeId);\n if (!connections)\n continue;\n for (const { edgeId } of connections.values()) {\n const edge = edgeLookup.get(edgeId);\n if (edge && (edge.selectable ?? edgesSelectable)) {\n selectedEdgeIds.current.add(edgeId);\n }\n }\n }\n if (!areSetsEqual(prevSelectedNodeIds, selectedNodeIds.current)) {\n const changes = getSelectionChanges(nodeLookup, selectedNodeIds.current, true);\n triggerNodeChanges(changes);\n }\n if (!areSetsEqual(prevSelectedEdgeIds, selectedEdgeIds.current)) {\n const changes = getSelectionChanges(edgeLookup, selectedEdgeIds.current);\n triggerEdgeChanges(changes);\n }\n store.setState({\n userSelectionRect: nextUserSelectRect,\n userSelectionActive: true,\n nodesSelectionActive: false,\n });\n };\n const onPointerUp = (event) => {\n if (event.button !== 0 || !selectionStarted.current) {\n return;\n }\n event.target?.releasePointerCapture?.(event.pointerId);\n const { userSelectionRect } = store.getState();\n /*\n * We only want to trigger click functions when in selection mode if\n * the user did not move the mouse.\n */\n if (!userSelectionActive && userSelectionRect && event.target === container.current) {\n onClick?.(event);\n }\n store.setState({\n userSelectionActive: false,\n userSelectionRect: null,\n nodesSelectionActive: selectedNodeIds.current.size > 0,\n });\n onSelectionEnd?.(event);\n /*\n * If the user kept holding the selectionKey during the selection,\n * we need to reset the selectionInProgress, so the next click event is not prevented\n */\n if (selectionKeyPressed || selectionOnDrag) {\n selectionInProgress.current = false;\n }\n selectionStarted.current = false;\n };\n const draggable = panOnDrag === true || (Array.isArray(panOnDrag) && panOnDrag.includes(0));\n return (jsxs(\"div\", { className: cc(['react-flow__pane', { draggable, dragging, selection: isSelecting }]), onClick: hasActiveSelection ? undefined : wrapHandler(onClick, container), onContextMenu: wrapHandler(onContextMenu, container), onWheel: wrapHandler(onWheel, container), onPointerEnter: hasActiveSelection ? undefined : onPaneMouseEnter, onPointerMove: hasActiveSelection ? onPointerMove : onPaneMouseMove, onPointerUp: hasActiveSelection ? onPointerUp : undefined, onPointerDownCapture: hasActiveSelection ? onPointerDownCapture : undefined, onClickCapture: hasActiveSelection ? onClickCapture : undefined, onPointerLeave: onPaneMouseLeave, ref: container, style: containerStyle, children: [children, jsx(UserSelection, {})] }));\n}\n\n/*\n * this handler is called by\n * 1. the click handler when node is not draggable or selectNodesOnDrag = false\n * or\n * 2. the on drag start handler when node is draggable and selectNodesOnDrag = true\n */\nfunction handleNodeClick({ id, store, unselect = false, nodeRef, }) {\n const { addSelectedNodes, unselectNodesAndEdges, multiSelectionActive, nodeLookup, onError } = store.getState();\n const node = nodeLookup.get(id);\n if (!node) {\n onError?.('012', errorMessages['error012'](id));\n return;\n }\n store.setState({ nodesSelectionActive: false });\n if (!node.selected) {\n addSelectedNodes([id]);\n }\n else if (unselect || (node.selected && multiSelectionActive)) {\n unselectNodesAndEdges({ nodes: [node], edges: [] });\n requestAnimationFrame(() => nodeRef?.current?.blur());\n }\n}\n\n/**\n * Hook for calling XYDrag helper from @xyflow/system.\n *\n * @internal\n */\nfunction useDrag({ nodeRef, disabled = false, noDragClassName, handleSelector, nodeId, isSelectable, nodeClickDistance, }) {\n const store = useStoreApi();\n const [dragging, setDragging] = useState(false);\n const xyDrag = useRef();\n useEffect(() => {\n xyDrag.current = XYDrag({\n getStoreItems: () => store.getState(),\n onNodeMouseDown: (id) => {\n handleNodeClick({\n id,\n store,\n nodeRef,\n });\n },\n onDragStart: () => {\n setDragging(true);\n },\n onDragStop: () => {\n setDragging(false);\n },\n });\n }, []);\n useEffect(() => {\n if (disabled) {\n xyDrag.current?.destroy();\n }\n else if (nodeRef.current) {\n xyDrag.current?.update({\n noDragClassName,\n handleSelector,\n domNode: nodeRef.current,\n isSelectable,\n nodeId,\n nodeClickDistance,\n });\n return () => {\n xyDrag.current?.destroy();\n };\n }\n }, [noDragClassName, handleSelector, disabled, isSelectable, nodeRef, nodeId]);\n return dragging;\n}\n\nconst selectedAndDraggable = (nodesDraggable) => (n) => n.selected && (n.draggable || (nodesDraggable && typeof n.draggable === 'undefined'));\n/**\n * Hook for updating node positions by passing a direction and factor\n *\n * @internal\n * @returns function for updating node positions\n */\nfunction useMoveSelectedNodes() {\n const store = useStoreApi();\n const moveSelectedNodes = useCallback((params) => {\n const { nodeExtent, snapToGrid, snapGrid, nodesDraggable, onError, updateNodePositions, nodeLookup, nodeOrigin } = store.getState();\n const nodeUpdates = new Map();\n const isSelected = selectedAndDraggable(nodesDraggable);\n /*\n * by default a node moves 5px on each key press\n * if snap grid is enabled, we use that for the velocity\n */\n const xVelo = snapToGrid ? snapGrid[0] : 5;\n const yVelo = snapToGrid ? snapGrid[1] : 5;\n const xDiff = params.direction.x * xVelo * params.factor;\n const yDiff = params.direction.y * yVelo * params.factor;\n for (const [, node] of nodeLookup) {\n if (!isSelected(node)) {\n continue;\n }\n let nextPosition = {\n x: node.internals.positionAbsolute.x + xDiff,\n y: node.internals.positionAbsolute.y + yDiff,\n };\n if (snapToGrid) {\n nextPosition = snapPosition(nextPosition, snapGrid);\n }\n const { position, positionAbsolute } = calculateNodePosition({\n nodeId: node.id,\n nextPosition,\n nodeLookup,\n nodeExtent,\n nodeOrigin,\n onError,\n });\n node.position = position;\n node.internals.positionAbsolute = positionAbsolute;\n nodeUpdates.set(node.id, node);\n }\n updateNodePositions(nodeUpdates);\n }, []);\n return moveSelectedNodes;\n}\n\nconst NodeIdContext = createContext(null);\nconst Provider = NodeIdContext.Provider;\nNodeIdContext.Consumer;\n/**\n * You can use this hook to get the id of the node it is used inside. It is useful\n * if you need the node's id deeper in the render tree but don't want to manually\n * drill down the id as a prop.\n *\n * @public\n * @returns The id for a node in the flow.\n *\n * @example\n *```jsx\n *import { useNodeId } from '@xyflow/react';\n *\n *export default function CustomNode() {\n * return (\n * <div>\n * <span>This node has an id of </span>\n * <NodeIdDisplay />\n * </div>\n * );\n *}\n *\n *function NodeIdDisplay() {\n * const nodeId = useNodeId();\n *\n * return <span>{nodeId}</span>;\n *}\n *```\n */\nconst useNodeId = () => {\n const nodeId = useContext(NodeIdContext);\n return nodeId;\n};\n\nconst selector$g = (s) => ({\n connectOnClick: s.connectOnClick,\n noPanClassName: s.noPanClassName,\n rfId: s.rfId,\n});\nconst connectingSelector = (nodeId, handleId, type) => (state) => {\n const { connectionClickStartHandle: clickHandle, connectionMode, connection } = state;\n const { fromHandle, toHandle, isValid } = connection;\n const connectingTo = toHandle?.nodeId === nodeId && toHandle?.id === handleId && toHandle?.type === type;\n return {\n connectingFrom: fromHandle?.nodeId === nodeId && fromHandle?.id === handleId && fromHandle?.type === type,\n connectingTo,\n clickConnecting: clickHandle?.nodeId === nodeId && clickHandle?.id === handleId && clickHandle?.type === type,\n isPossibleEndHandle: connectionMode === ConnectionMode.Strict\n ? fromHandle?.type !== type\n : nodeId !== fromHandle?.nodeId || handleId !== fromHandle?.id,\n connectionInProcess: !!fromHandle,\n clickConnectionInProcess: !!clickHandle,\n valid: connectingTo && isValid,\n };\n};\nfunction HandleComponent({ type = 'source', position = Position.Top, isValidConnection, isConnectable = true, isConnectableStart = true, isConnectableEnd = true, id, onConnect, children, className, onMouseDown, onTouchStart, ...rest }, ref) {\n const handleId = id || null;\n const isTarget = type === 'target';\n const store = useStoreApi();\n const nodeId = useNodeId();\n const { connectOnClick, noPanClassName, rfId } = useStore(selector$g, shallow);\n const { connectingFrom, connectingTo, clickConnecting, isPossibleEndHandle, connectionInProcess, clickConnectionInProcess, valid, } = useStore(connectingSelector(nodeId, handleId, type), shallow);\n if (!nodeId) {\n store.getState().onError?.('010', errorMessages['error010']());\n }\n const onConnectExtended = (params) => {\n const { defaultEdgeOptions, onConnect: onConnectAction, hasDefaultEdges } = store.getState();\n const edgeParams = {\n ...defaultEdgeOptions,\n ...params,\n };\n if (hasDefaultEdges) {\n const { edges, setEdges } = store.getState();\n setEdges(addEdge(edgeParams, edges));\n }\n onConnectAction?.(edgeParams);\n onConnect?.(edgeParams);\n };\n const onPointerDown = (event) => {\n if (!nodeId) {\n return;\n }\n const isMouseTriggered = isMouseEvent(event.nativeEvent);\n if (isConnectableStart &&\n ((isMouseTriggered && event.button === 0) || !isMouseTriggered)) {\n const currentStore = store.getState();\n XYHandle.onPointerDown(event.nativeEvent, {\n handleDomNode: event.currentTarget,\n autoPanOnConnect: currentStore.autoPanOnConnect,\n connectionMode: currentStore.connectionMode,\n connectionRadius: currentStore.connectionRadius,\n domNode: currentStore.domNode,\n nodeLookup: currentStore.nodeLookup,\n lib: currentStore.lib,\n isTarget,\n handleId,\n nodeId,\n flowId: currentStore.rfId,\n panBy: currentStore.panBy,\n cancelConnection: currentStore.cancelConnection,\n onConnectStart: currentStore.onConnectStart,\n onConnectEnd: currentStore.onConnectEnd,\n updateConnection: currentStore.updateConnection,\n onConnect: onConnectExtended,\n isValidConnection: isValidConnection || currentStore.isValidConnection,\n getTransform: () => store.getState().transform,\n getFromHandle: () => store.getState().connection.fromHandle,\n autoPanSpeed: currentStore.autoPanSpeed,\n dragThreshold: currentStore.connectionDragThreshold,\n });\n }\n if (isMouseTriggered) {\n onMouseDown?.(event);\n }\n else {\n onTouchStart?.(event);\n }\n };\n const onClick = (event) => {\n const { onClickConnectStart, onClickConnectEnd, connectionClickStartHandle, connectionMode, isValidConnection: isValidConnectionStore, lib, rfId: flowId, nodeLookup, connection: connectionState, } = store.getState();\n if (!nodeId || (!connectionClickStartHandle && !isConnectableStart)) {\n return;\n }\n if (!connectionClickStartHandle) {\n onClickConnectStart?.(event.nativeEvent, { nodeId, handleId, handleType: type });\n store.setState({ connectionClickStartHandle: { nodeId, type, id: handleId } });\n return;\n }\n const doc = getHostForElement(event.target);\n const isValidConnectionHandler = isValidConnection || isValidConnectionStore;\n const { connection, isValid } = XYHandle.isValid(event.nativeEvent, {\n handle: {\n nodeId,\n id: handleId,\n type,\n },\n connectionMode,\n fromNodeId: connectionClickStartHandle.nodeId,\n fromHandleId: connectionClickStartHandle.id || null,\n fromType: connectionClickStartHandle.type,\n isValidConnection: isValidConnectionHandler,\n flowId,\n doc,\n lib,\n nodeLookup,\n });\n if (isValid && connection) {\n onConnectExtended(connection);\n }\n const connectionClone = structuredClone(connectionState);\n delete connectionClone.inProgress;\n connectionClone.toPosition = connectionClone.toHandle ? connectionClone.toHandle.position : null;\n onClickConnectEnd?.(event, connectionClone);\n store.setState({ connectionClickStartHandle: null });\n };\n return (jsx(\"div\", { \"data-handleid\": handleId, \"data-nodeid\": nodeId, \"data-handlepos\": position, \"data-id\": `${rfId}-${nodeId}-${handleId}-${type}`, className: cc([\n 'react-flow__handle',\n `react-flow__handle-${position}`,\n 'nodrag',\n noPanClassName,\n className,\n {\n source: !isTarget,\n target: isTarget,\n connectable: isConnectable,\n connectablestart: isConnectableStart,\n connectableend: isConnectableEnd,\n clickconnecting: clickConnecting,\n connectingfrom: connectingFrom,\n connectingto: connectingTo,\n valid,\n /*\n * shows where you can start a connection from\n * and where you can end it while connecting\n */\n connectionindicator: isConnectable &&\n (!connectionInProcess || isPossibleEndHandle) &&\n (connectionInProcess || clickConnectionInProcess ? isConnectableEnd : isConnectableStart),\n },\n ]), onMouseDown: onPointerDown, onTouchStart: onPointerDown, onClick: connectOnClick ? onClick : undefined, ref: ref, ...rest, children: children }));\n}\n/**\n * The `<Handle />` component is used in your [custom nodes](/learn/customization/custom-nodes)\n * to define connection points.\n *\n *@public\n *\n *@example\n *\n *```jsx\n *import { Handle, Position } from '@xyflow/react';\n *\n *export function CustomNode({ data }) {\n * return (\n * <>\n * <div style={{ padding: '10px 20px' }}>\n * {data.label}\n * </div>\n *\n * <Handle type=\"target\" position={Position.Left} />\n * <Handle type=\"source\" position={Position.Right} />\n * </>\n * );\n *};\n *```\n */\nconst Handle = memo(fixedForwardRef(HandleComponent));\n\nfunction InputNode({ data, isConnectable, sourcePosition = Position.Bottom }) {\n return (jsxs(Fragment, { children: [data?.label, jsx(Handle, { type: \"source\", position: sourcePosition, isConnectable: isConnectable })] }));\n}\n\nfunction DefaultNode({ data, isConnectable, targetPosition = Position.Top, sourcePosition = Position.Bottom, }) {\n return (jsxs(Fragment, { children: [jsx(Handle, { type: \"target\", position: targetPosition, isConnectable: isConnectable }), data?.label, jsx(Handle, { type: \"source\", position: sourcePosition, isConnectable: isConnectable })] }));\n}\n\nfunction GroupNode() {\n return null;\n}\n\nfunction OutputNode({ data, isConnectable, targetPosition = Position.Top }) {\n return (jsxs(Fragment, { children: [jsx(Handle, { type: \"target\", position: targetPosition, isConnectable: isConnectable }), data?.label] }));\n}\n\nconst arrowKeyDiffs = {\n ArrowUp: { x: 0, y: -1 },\n ArrowDown: { x: 0, y: 1 },\n ArrowLeft: { x: -1, y: 0 },\n ArrowRight: { x: 1, y: 0 },\n};\nconst builtinNodeTypes = {\n input: InputNode,\n default: DefaultNode,\n output: OutputNode,\n group: GroupNode,\n};\nfunction getNodeInlineStyleDimensions(node) {\n if (node.internals.handleBounds === undefined) {\n return {\n width: node.width ?? node.initialWidth ?? node.style?.width,\n height: node.height ?? node.initialHeight ?? node.style?.height,\n };\n }\n return {\n width: node.width ?? node.style?.width,\n height: node.height ?? node.style?.height,\n };\n}\n\nconst selector$f = (s) => {\n const { width, height, x, y } = getInternalNodesBounds(s.nodeLookup, {\n filter: (node) => !!node.selected,\n });\n return {\n width: isNumeric(width) ? width : null,\n height: isNumeric(height) ? height : null,\n userSelectionActive: s.userSelectionActive,\n transformString: `translate(${s.transform[0]}px,${s.transform[1]}px) scale(${s.transform[2]}) translate(${x}px,${y}px)`,\n };\n};\nfunction NodesSelection({ onSelectionContextMenu, noPanClassName, disableKeyboardA11y, }) {\n const store = useStoreApi();\n const { width, height, transformString, userSelectionActive } = useStore(selector$f, shallow);\n const moveSelectedNodes = useMoveSelectedNodes();\n const nodeRef = useRef(null);\n useEffect(() => {\n if (!disableKeyboardA11y) {\n nodeRef.current?.focus({\n preventScroll: true,\n });\n }\n }, [disableKeyboardA11y]);\n useDrag({\n nodeRef,\n });\n if (userSelectionActive || !width || !height) {\n return null;\n }\n const onContextMenu = onSelectionContextMenu\n ? (event) => {\n const selectedNodes = store.getState().nodes.filter((n) => n.selected);\n onSelectionContextMenu(event, selectedNodes);\n }\n : undefined;\n const onKeyDown = (event) => {\n if (Object.prototype.hasOwnProperty.call(arrowKeyDiffs, event.key)) {\n event.preventDefault();\n moveSelectedNodes({\n direction: arrowKeyDiffs[event.key],\n factor: event.shiftKey ? 4 : 1,\n });\n }\n };\n return (jsx(\"div\", { className: cc(['react-flow__nodesselection', 'react-flow__container', noPanClassName]), style: {\n transform: transformString,\n }, children: jsx(\"div\", { ref: nodeRef, className: \"react-flow__nodesselection-rect\", onContextMenu: onContextMenu, tabIndex: disableKeyboardA11y ? undefined : -1, onKeyDown: disableKeyboardA11y ? undefined : onKeyDown, style: {\n width,\n height,\n } }) }));\n}\n\nconst win = typeof window !== 'undefined' ? window : undefined;\nconst selector$e = (s) => {\n return { nodesSelectionActive: s.nodesSelectionActive, userSelectionActive: s.userSelectionActive };\n};\nfunction FlowRendererComponent({ children, onPaneClick, onPaneMouseEnter, onPaneMouseMove, onPaneMouseLeave, onPaneContextMenu, onPaneScroll, paneClickDistance, deleteKeyCode, selectionKeyCode, selectionOnDrag, selectionMode, onSelectionStart, onSelectionEnd, multiSelectionKeyCode, panActivationKeyCode, zoomActivationKeyCode, elementsSelectable, zoomOnScroll, zoomOnPinch, panOnScroll: _panOnScroll, panOnScrollSpeed, panOnScrollMode, zoomOnDoubleClick, panOnDrag: _panOnDrag, defaultViewport, translateExtent, minZoom, maxZoom, preventScrolling, onSelectionContextMenu, noWheelClassName, noPanClassName, disableKeyboardA11y, onViewportChange, isControlledViewport, }) {\n const { nodesSelectionActive, userSelectionActive } = useStore(selector$e);\n const selectionKeyPressed = useKeyPress(selectionKeyCode, { target: win });\n const panActivationKeyPressed = useKeyPress(panActivationKeyCode, { target: win });\n const panOnDrag = panActivationKeyPressed || _panOnDrag;\n const panOnScroll = panActivationKeyPressed || _panOnScroll;\n const _selectionOnDrag = selectionOnDrag && panOnDrag !== true;\n const isSelecting = selectionKeyPressed || userSelectionActive || _selectionOnDrag;\n useGlobalKeyHandler({ deleteKeyCode, multiSelectionKeyCode });\n return (jsx(ZoomPane, { onPaneContextMenu: onPaneContextMenu, elementsSelectable: elementsSelectable, zoomOnScroll: zoomOnScroll, zoomOnPinch: zoomOnPinch, panOnScroll: panOnScroll, panOnScrollSpeed: panOnScrollSpeed, panOnScrollMode: panOnScrollMode, zoomOnDoubleClick: zoomOnDoubleClick, panOnDrag: !selectionKeyPressed && panOnDrag, defaultViewport: defaultViewport, translateExtent: translateExtent, minZoom: minZoom, maxZoom: maxZoom, zoomActivationKeyCode: zoomActivationKeyCode, preventScrolling: preventScrolling, noWheelClassName: noWheelClassName, noPanClassName: noPanClassName, onViewportChange: onViewportChange, isControlledViewport: isControlledViewport, paneClickDistance: paneClickDistance, children: jsxs(Pane, { onSelectionStart: onSelectionStart, onSelectionEnd: onSelectionEnd, onPaneClick: onPaneClick, onPaneMouseEnter: onPaneMouseEnter, onPaneMouseMove: onPaneMouseMove, onPaneMouseLeave: onPaneMouseLeave, onPaneContextMenu: onPaneContextMenu, onPaneScroll: onPaneScroll, panOnDrag: panOnDrag, isSelecting: !!isSelecting, selectionMode: selectionMode, selectionKeyPressed: selectionKeyPressed, selectionOnDrag: _selectionOnDrag, children: [children, nodesSelectionActive && (jsx(NodesSelection, { onSelectionContextMenu: onSelectionContextMenu, noPanClassName: noPanClassName, disableKeyboardA11y: disableKeyboardA11y }))] }) }));\n}\nFlowRendererComponent.displayName = 'FlowRenderer';\nconst FlowRenderer = memo(FlowRendererComponent);\n\nconst selector$d = (onlyRenderVisible) => (s) => {\n return onlyRenderVisible\n ? getNodesInside(s.nodeLookup, { x: 0, y: 0, width: s.width, height: s.height }, s.transform, true).map((node) => node.id)\n : Array.from(s.nodeLookup.keys());\n};\n/**\n * Hook for getting the visible node ids from the store.\n *\n * @internal\n * @param onlyRenderVisible\n * @returns array with visible node ids\n */\nfunction useVisibleNodeIds(onlyRenderVisible) {\n const nodeIds = useStore(useCallback(selector$d(onlyRenderVisible), [onlyRenderVisible]), shallow);\n return nodeIds;\n}\n\nconst selector$c = (s) => s.updateNodeInternals;\nfunction useResizeObserver() {\n const updateNodeInternals = useStore(selector$c);\n const [resizeObserver] = useState(() => {\n if (typeof ResizeObserver === 'undefined') {\n return null;\n }\n return new ResizeObserver((entries) => {\n const updates = new Map();\n entries.forEach((entry) => {\n const id = entry.target.getAttribute('data-id');\n updates.set(id, {\n id,\n nodeElement: entry.target,\n force: true,\n });\n });\n updateNodeInternals(updates);\n });\n });\n useEffect(() => {\n return () => {\n resizeObserver?.disconnect();\n };\n }, [resizeObserver]);\n return resizeObserver;\n}\n\n/**\n * Hook to handle the resize observation + internal updates for the passed node.\n *\n * @internal\n * @returns nodeRef - reference to the node element\n */\nfunction useNodeObserver({ node, nodeType, hasDimensions, resizeObserver, }) {\n const store = useStoreApi();\n const nodeRef = useRef(null);\n const observedNode = useRef(null);\n const prevSourcePosition = useRef(node.sourcePosition);\n const prevTargetPosition = useRef(node.targetPosition);\n const prevType = useRef(nodeType);\n const isInitialized = hasDimensions && !!node.internals.handleBounds;\n useEffect(() => {\n if (nodeRef.current && !node.hidden && (!isInitialized || observedNode.current !== nodeRef.current)) {\n if (observedNode.current) {\n resizeObserver?.unobserve(observedNode.current);\n }\n resizeObserver?.observe(nodeRef.current);\n observedNode.current = nodeRef.current;\n }\n }, [isInitialized, node.hidden]);\n useEffect(() => {\n return () => {\n if (observedNode.current) {\n resizeObserver?.unobserve(observedNode.current);\n observedNode.current = null;\n }\n };\n }, []);\n useEffect(() => {\n if (nodeRef.current) {\n /*\n * when the user programmatically changes the source or handle position, we need to update the internals\n * to make sure the edges are updated correctly\n */\n const typeChanged = prevType.current !== nodeType;\n const sourcePosChanged = prevSourcePosition.current !== node.sourcePosition;\n const targetPosChanged = prevTargetPosition.current !== node.targetPosition;\n if (typeChanged || sourcePosChanged || targetPosChanged) {\n prevType.current = nodeType;\n prevSourcePosition.current = node.sourcePosition;\n prevTargetPosition.current = node.targetPosition;\n store\n .getState()\n .updateNodeInternals(new Map([[node.id, { id: node.id, nodeElement: nodeRef.current, force: true }]]));\n }\n }\n }, [node.id, nodeType, node.sourcePosition, node.targetPosition]);\n return nodeRef;\n}\n\nfunction NodeWrapper({ id, onClick, onMouseEnter, onMouseMove, onMouseLeave, onContextMenu, onDoubleClick, nodesDraggable, elementsSelectable, nodesConnectable, nodesFocusable, resizeObserver, noDragClassName, noPanClassName, disableKeyboardA11y, rfId, nodeTypes, nodeClickDistance, onError, }) {\n const { node, internals, isParent } = useStore((s) => {\n const node = s.nodeLookup.get(id);\n const isParent = s.parentLookup.has(id);\n return {\n node,\n internals: node.internals,\n isParent,\n };\n }, shallow);\n let nodeType = node.type || 'default';\n let NodeComponent = nodeTypes?.[nodeType] || builtinNodeTypes[nodeType];\n if (NodeComponent === undefined) {\n onError?.('003', errorMessages['error003'](nodeType));\n nodeType = 'default';\n NodeComponent = nodeTypes?.['default'] || builtinNodeTypes.default;\n }\n const isDraggable = !!(node.draggable || (nodesDraggable && typeof node.draggable === 'undefined'));\n const isSelectable = !!(node.selectable || (elementsSelectable && typeof node.selectable === 'undefined'));\n const isConnectable = !!(node.connectable || (nodesConnectable && typeof node.connectable === 'undefined'));\n const isFocusable = !!(node.focusable || (nodesFocusable && typeof node.focusable === 'undefined'));\n const store = useStoreApi();\n const hasDimensions = nodeHasDimensions(node);\n const nodeRef = useNodeObserver({ node, nodeType, hasDimensions, resizeObserver });\n const dragging = useDrag({\n nodeRef,\n disabled: node.hidden || !isDraggable,\n noDragClassName,\n handleSelector: node.dragHandle,\n nodeId: id,\n isSelectable,\n nodeClickDistance,\n });\n const moveSelectedNodes = useMoveSelectedNodes();\n if (node.hidden) {\n return null;\n }\n const nodeDimensions = getNodeDimensions(node);\n const inlineDimensions = getNodeInlineStyleDimensions(node);\n const hasPointerEvents = isSelectable || isDraggable || onClick || onMouseEnter || onMouseMove || onMouseLeave;\n const onMouseEnterHandler = onMouseEnter\n ? (event) => onMouseEnter(event, { ...internals.userNode })\n : undefined;\n const onMouseMoveHandler = onMouseMove\n ? (event) => onMouseMove(event, { ...internals.userNode })\n : undefined;\n const onMouseLeaveHandler = onMouseLeave\n ? (event) => onMouseLeave(event, { ...internals.userNode })\n : undefined;\n const onContextMenuHandler = onContextMenu\n ? (event) => onContextMenu(event, { ...internals.userNode })\n : undefined;\n const onDoubleClickHandler = onDoubleClick\n ? (event) => onDoubleClick(event, { ...internals.userNode })\n : undefined;\n const onSelectNodeHandler = (event) => {\n const { selectNodesOnDrag, nodeDragThreshold } = store.getState();\n if (isSelectable && (!selectNodesOnDrag || !isDraggable || nodeDragThreshold > 0)) {\n /*\n * this handler gets called by XYDrag on drag start when selectNodesOnDrag=true\n * here we only need to call it when selectNodesOnDrag=false\n */\n handleNodeClick({\n id,\n store,\n nodeRef,\n });\n }\n if (onClick) {\n onClick(event, { ...internals.userNode });\n }\n };\n const onKeyDown = (event) => {\n if (isInputDOMNode(event.nativeEvent) || disableKeyboardA11y) {\n return;\n }\n if (elementSelectionKeys.includes(event.key) && isSelectable) {\n const unselect = event.key === 'Escape';\n handleNodeClick({\n id,\n store,\n unselect,\n nodeRef,\n });\n }\n else if (isDraggable && node.selected && Object.prototype.hasOwnProperty.call(arrowKeyDiffs, event.key)) {\n // prevent default scrolling behavior on arrow key press when node is moved\n event.preventDefault();\n const { ariaLabelConfig } = store.getState();\n store.setState({\n ariaLiveMessage: ariaLabelConfig['node.a11yDescription.ariaLiveMessage']({\n direction: event.key.replace('Arrow', '').toLowerCase(),\n x: ~~internals.positionAbsolute.x,\n y: ~~internals.positionAbsolute.y,\n }),\n });\n moveSelectedNodes({\n direction: arrowKeyDiffs[event.key],\n factor: event.shiftKey ? 4 : 1,\n });\n }\n };\n const onFocus = () => {\n if (disableKeyboardA11y || !nodeRef.current?.matches(':focus-visible')) {\n return;\n }\n const { transform, width, height, autoPanOnNodeFocus, setCenter } = store.getState();\n if (!autoPanOnNodeFocus) {\n return;\n }\n const withinViewport = getNodesInside(new Map([[id, node]]), { x: 0, y: 0, width, height }, transform, true).length > 0;\n if (!withinViewport) {\n setCenter(node.position.x + nodeDimensions.width / 2, node.position.y + nodeDimensions.height / 2, {\n zoom: transform[2],\n });\n }\n };\n return (jsx(\"div\", { className: cc([\n 'react-flow__node',\n `react-flow__node-${nodeType}`,\n {\n // this is overwritable by passing `nopan` as a class name\n [noPanClassName]: isDraggable,\n },\n node.className,\n {\n selected: node.selected,\n selectable: isSelectable,\n parent: isParent,\n draggable: isDraggable,\n dragging,\n },\n ]), ref: nodeRef, style: {\n zIndex: internals.z,\n transform: `translate(${internals.positionAbsolute.x}px,${internals.positionAbsolute.y}px)`,\n pointerEvents: hasPointerEvents ? 'all' : 'none',\n visibility: hasDimensions ? 'visible' : 'hidden',\n ...node.style,\n ...inlineDimensions,\n }, \"data-id\": id, \"data-testid\": `rf__node-${id}`, onMouseEnter: onMouseEnterHandler, onMouseMove: onMouseMoveHandler, onMouseLeave: onMouseLeaveHandler, onContextMenu: onContextMenuHandler, onClick: onSelectNodeHandler, onDoubleClick: onDoubleClickHandler, onKeyDown: isFocusable ? onKeyDown : undefined, tabIndex: isFocusable ? 0 : undefined, onFocus: isFocusable ? onFocus : undefined, role: node.ariaRole ?? (isFocusable ? 'group' : undefined), \"aria-roledescription\": \"node\", \"aria-describedby\": disableKeyboardA11y ? undefined : `${ARIA_NODE_DESC_KEY}-${rfId}`, \"aria-label\": node.ariaLabel, ...node.domAttributes, children: jsx(Provider, { value: id, children: jsx(NodeComponent, { id: id, data: node.data, type: nodeType, positionAbsoluteX: internals.positionAbsolute.x, positionAbsoluteY: internals.positionAbsolute.y, selected: node.selected ?? false, selectable: isSelectable, draggable: isDraggable, deletable: node.deletable ?? true, isConnectable: isConnectable, sourcePosition: node.sourcePosition, targetPosition: node.targetPosition, dragging: dragging, dragHandle: node.dragHandle, zIndex: internals.z, parentId: node.parentId, ...nodeDimensions }) }) }));\n}\nvar NodeWrapper$1 = memo(NodeWrapper);\n\nconst selector$b = (s) => ({\n nodesDraggable: s.nodesDraggable,\n nodesConnectable: s.nodesConnectable,\n nodesFocusable: s.nodesFocusable,\n elementsSelectable: s.elementsSelectable,\n onError: s.onError,\n});\nfunction NodeRendererComponent(props) {\n const { nodesDraggable, nodesConnectable, nodesFocusable, elementsSelectable, onError } = useStore(selector$b, shallow);\n const nodeIds = useVisibleNodeIds(props.onlyRenderVisibleElements);\n const resizeObserver = useResizeObserver();\n return (jsx(\"div\", { className: \"react-flow__nodes\", style: containerStyle, children: nodeIds.map((nodeId) => {\n return (\n /*\n * The split of responsibilities between NodeRenderer and\n * NodeComponentWrapper may appear weird. However, it\u2019s designed to\n * minimize the cost of updates when individual nodes change.\n *\n * For example, when you\u2019re dragging a single node, that node gets\n * updated multiple times per second. If `NodeRenderer` were to update\n * every time, it would have to re-run the `nodes.map()` loop every\n * time. This gets pricey with hundreds of nodes, especially if every\n * loop cycle does more than just rendering a JSX element!\n *\n * As a result of this choice, we took the following implementation\n * decisions:\n * - NodeRenderer subscribes *only* to node IDs \u2013 and therefore\n * rerender *only* when visible nodes are added or removed.\n * - NodeRenderer performs all operations the result of which can be\n * shared between nodes (such as creating the `ResizeObserver`\n * instance, or subscribing to `selector`). This means extra prop\n * drilling into `NodeComponentWrapper`, but it means we need to run\n * these operations only once \u2013 instead of once per node.\n * - Any operations that you\u2019d normally write inside `nodes.map` are\n * moved into `NodeComponentWrapper`. This ensures they are\n * memorized \u2013 so if `NodeRenderer` *has* to rerender, it only\n * needs to regenerate the list of nodes, nothing else.\n */\n jsx(NodeWrapper$1, { id: nodeId, nodeTypes: props.nodeTypes, nodeExtent: props.nodeExtent, onClick: props.onNodeClick, onMouseEnter: props.onNodeMouseEnter, onMouseMove: props.onNodeMouseMove, onMouseLeave: props.onNodeMouseLeave, onContextMenu: props.onNodeContextMenu, onDoubleClick: props.onNodeDoubleClick, noDragClassName: props.noDragClassName, noPanClassName: props.noPanClassName, rfId: props.rfId, disableKeyboardA11y: props.disableKeyboardA11y, resizeObserver: resizeObserver, nodesDraggable: nodesDraggable, nodesConnectable: nodesConnectable, nodesFocusable: nodesFocusable, elementsSelectable: elementsSelectable, nodeClickDistance: props.nodeClickDistance, onError: onError }, nodeId));\n }) }));\n}\nNodeRendererComponent.displayName = 'NodeRenderer';\nconst NodeRenderer = memo(NodeRendererComponent);\n\n/**\n * Hook for getting the visible edge ids from the store.\n *\n * @internal\n * @param onlyRenderVisible\n * @returns array with visible edge ids\n */\nfunction useVisibleEdgeIds(onlyRenderVisible) {\n const edgeIds = useStore(useCallback((s) => {\n if (!onlyRenderVisible) {\n return s.edges.map((edge) => edge.id);\n }\n const visibleEdgeIds = [];\n if (s.width && s.height) {\n for (const edge of s.edges) {\n const sourceNode = s.nodeLookup.get(edge.source);\n const targetNode = s.nodeLookup.get(edge.target);\n if (sourceNode &&\n targetNode &&\n isEdgeVisible({\n sourceNode,\n targetNode,\n width: s.width,\n height: s.height,\n transform: s.transform,\n })) {\n visibleEdgeIds.push(edge.id);\n }\n }\n }\n return visibleEdgeIds;\n }, [onlyRenderVisible]), shallow);\n return edgeIds;\n}\n\nconst ArrowSymbol = ({ color = 'none', strokeWidth = 1 }) => {\n const style = {\n strokeWidth,\n ...(color && { stroke: color }),\n };\n return (jsx(\"polyline\", { className: \"arrow\", style: style, strokeLinecap: \"round\", fill: \"none\", strokeLinejoin: \"round\", points: \"-5,-4 0,0 -5,4\" }));\n};\nconst ArrowClosedSymbol = ({ color = 'none', strokeWidth = 1 }) => {\n const style = {\n strokeWidth,\n ...(color && { stroke: color, fill: color }),\n };\n return (jsx(\"polyline\", { className: \"arrowclosed\", style: style, strokeLinecap: \"round\", strokeLinejoin: \"round\", points: \"-5,-4 0,0 -5,4 -5,-4\" }));\n};\nconst MarkerSymbols = {\n [MarkerType.Arrow]: ArrowSymbol,\n [MarkerType.ArrowClosed]: ArrowClosedSymbol,\n};\nfunction useMarkerSymbol(type) {\n const store = useStoreApi();\n const symbol = useMemo(() => {\n const symbolExists = Object.prototype.hasOwnProperty.call(MarkerSymbols, type);\n if (!symbolExists) {\n store.getState().onError?.('009', errorMessages['error009'](type));\n return null;\n }\n return MarkerSymbols[type];\n }, [type]);\n return symbol;\n}\n\nconst Marker = ({ id, type, color, width = 12.5, height = 12.5, markerUnits = 'strokeWidth', strokeWidth, orient = 'auto-start-reverse', }) => {\n const Symbol = useMarkerSymbol(type);\n if (!Symbol) {\n return null;\n }\n return (jsx(\"marker\", { className: \"react-flow__arrowhead\", id: id, markerWidth: `${width}`, markerHeight: `${height}`, viewBox: \"-10 -10 20 20\", markerUnits: markerUnits, orient: orient, refX: \"0\", refY: \"0\", children: jsx(Symbol, { color: color, strokeWidth: strokeWidth }) }));\n};\n/*\n * when you have multiple flows on a page and you hide the first one, the other ones have no markers anymore\n * when they do have markers with the same ids. To prevent this the user can pass a unique id to the react flow wrapper\n * that we can then use for creating our unique marker ids\n */\nconst MarkerDefinitions = ({ defaultColor, rfId }) => {\n const edges = useStore((s) => s.edges);\n const defaultEdgeOptions = useStore((s) => s.defaultEdgeOptions);\n const markers = useMemo(() => {\n const markers = createMarkerIds(edges, {\n id: rfId,\n defaultColor,\n defaultMarkerStart: defaultEdgeOptions?.markerStart,\n defaultMarkerEnd: defaultEdgeOptions?.markerEnd,\n });\n return markers;\n }, [edges, defaultEdgeOptions, rfId, defaultColor]);\n if (!markers.length) {\n return null;\n }\n return (jsx(\"svg\", { className: \"react-flow__marker\", \"aria-hidden\": \"true\", children: jsx(\"defs\", { children: markers.map((marker) => (jsx(Marker, { id: marker.id, type: marker.type, color: marker.color, width: marker.width, height: marker.height, markerUnits: marker.markerUnits, strokeWidth: marker.strokeWidth, orient: marker.orient }, marker.id))) }) }));\n};\nMarkerDefinitions.displayName = 'MarkerDefinitions';\nvar MarkerDefinitions$1 = memo(MarkerDefinitions);\n\nfunction EdgeTextComponent({ x, y, label, labelStyle, labelShowBg = true, labelBgStyle, labelBgPadding = [2, 4], labelBgBorderRadius = 2, children, className, ...rest }) {\n const [edgeTextBbox, setEdgeTextBbox] = useState({ x: 1, y: 0, width: 0, height: 0 });\n const edgeTextClasses = cc(['react-flow__edge-textwrapper', className]);\n const edgeTextRef = useRef(null);\n useEffect(() => {\n if (edgeTextRef.current) {\n const textBbox = edgeTextRef.current.getBBox();\n setEdgeTextBbox({\n x: textBbox.x,\n y: textBbox.y,\n width: textBbox.width,\n height: textBbox.height,\n });\n }\n }, [label]);\n if (!label) {\n return null;\n }\n return (jsxs(\"g\", { transform: `translate(${x - edgeTextBbox.width / 2} ${y - edgeTextBbox.height / 2})`, className: edgeTextClasses, visibility: edgeTextBbox.width ? 'visible' : 'hidden', ...rest, children: [labelShowBg && (jsx(\"rect\", { width: edgeTextBbox.width + 2 * labelBgPadding[0], x: -labelBgPadding[0], y: -labelBgPadding[1], height: edgeTextBbox.height + 2 * labelBgPadding[1], className: \"react-flow__edge-textbg\", style: labelBgStyle, rx: labelBgBorderRadius, ry: labelBgBorderRadius })), jsx(\"text\", { className: \"react-flow__edge-text\", y: edgeTextBbox.height / 2, dy: \"0.3em\", ref: edgeTextRef, style: labelStyle, children: label }), children] }));\n}\nEdgeTextComponent.displayName = 'EdgeText';\n/**\n * You can use the `<EdgeText />` component as a helper component to display text\n * within your custom edges.\n *\n * @public\n *\n * @example\n * ```jsx\n * import { EdgeText } from '@xyflow/react';\n *\n * export function CustomEdgeLabel({ label }) {\n * return (\n * <EdgeText\n * x={100}\n * y={100}\n * label={label}\n * labelStyle={{ fill: 'white' }}\n * labelShowBg\n * labelBgStyle={{ fill: 'red' }}\n * labelBgPadding={[2, 4]}\n * labelBgBorderRadius={2}\n * />\n * );\n * }\n *```\n */\nconst EdgeText = memo(EdgeTextComponent);\n\n/**\n * The `<BaseEdge />` component gets used internally for all the edges. It can be\n * used inside a custom edge and handles the invisible helper edge and the edge label\n * for you.\n *\n * @public\n * @example\n * ```jsx\n *import { BaseEdge } from '@xyflow/react';\n *\n *export function CustomEdge({ sourceX, sourceY, targetX, targetY, ...props }) {\n * const [edgePath] = getStraightPath({\n * sourceX,\n * sourceY,\n * targetX,\n * targetY,\n * });\n *\n * return <BaseEdge path={edgePath} {...props} />;\n *}\n *```\n *\n * @remarks If you want to use an edge marker with the [`<BaseEdge />`](/api-reference/components/base-edge) component,\n * you can pass the `markerStart` or `markerEnd` props passed to your custom edge\n * through to the [`<BaseEdge />`](/api-reference/components/base-edge) component.\n * You can see all the props passed to a custom edge by looking at the [`EdgeProps`](/api-reference/types/edge-props) type.\n */\nfunction BaseEdge({ path, labelX, labelY, label, labelStyle, labelShowBg, labelBgStyle, labelBgPadding, labelBgBorderRadius, interactionWidth = 20, ...props }) {\n return (jsxs(Fragment, { children: [jsx(\"path\", { ...props, d: path, fill: \"none\", className: cc(['react-flow__edge-path', props.className]) }), interactionWidth ? (jsx(\"path\", { d: path, fill: \"none\", strokeOpacity: 0, strokeWidth: interactionWidth, className: \"react-flow__edge-interaction\" })) : null, label && isNumeric(labelX) && isNumeric(labelY) ? (jsx(EdgeText, { x: labelX, y: labelY, label: label, labelStyle: labelStyle, labelShowBg: labelShowBg, labelBgStyle: labelBgStyle, labelBgPadding: labelBgPadding, labelBgBorderRadius: labelBgBorderRadius })) : null] }));\n}\n\nfunction getControl({ pos, x1, y1, x2, y2 }) {\n if (pos === Position.Left || pos === Position.Right) {\n return [0.5 * (x1 + x2), y1];\n }\n return [x1, 0.5 * (y1 + y2)];\n}\n/**\n * The `getSimpleBezierPath` util returns everything you need to render a simple\n * bezier edge between two nodes.\n * @public\n * @returns\n * - `path`: the path to use in an SVG `<path>` element.\n * - `labelX`: the `x` position you can use to render a label for this edge.\n * - `labelY`: the `y` position you can use to render a label for this edge.\n * - `offsetX`: the absolute difference between the source `x` position and the `x` position of the\n * middle of this path.\n * - `offsetY`: the absolute difference between the source `y` position and the `y` position of the\n * middle of this path.\n */\nfunction getSimpleBezierPath({ sourceX, sourceY, sourcePosition = Position.Bottom, targetX, targetY, targetPosition = Position.Top, }) {\n const [sourceControlX, sourceControlY] = getControl({\n pos: sourcePosition,\n x1: sourceX,\n y1: sourceY,\n x2: targetX,\n y2: targetY,\n });\n const [targetControlX, targetControlY] = getControl({\n pos: targetPosition,\n x1: targetX,\n y1: targetY,\n x2: sourceX,\n y2: sourceY,\n });\n const [labelX, labelY, offsetX, offsetY] = getBezierEdgeCenter({\n sourceX,\n sourceY,\n targetX,\n targetY,\n sourceControlX,\n sourceControlY,\n targetControlX,\n targetControlY,\n });\n return [\n `M${sourceX},${sourceY} C${sourceControlX},${sourceControlY} ${targetControlX},${targetControlY} ${targetX},${targetY}`,\n labelX,\n labelY,\n offsetX,\n offsetY,\n ];\n}\nfunction createSimpleBezierEdge(params) {\n // eslint-disable-next-line react/display-name\n return memo(({ id, sourceX, sourceY, targetX, targetY, sourcePosition, targetPosition, label, labelStyle, labelShowBg, labelBgStyle, labelBgPadding, labelBgBorderRadius, style, markerEnd, markerStart, interactionWidth, }) => {\n const [path, labelX, labelY] = getSimpleBezierPath({\n sourceX,\n sourceY,\n sourcePosition,\n targetX,\n targetY,\n targetPosition,\n });\n const _id = params.isInternal ? undefined : id;\n return (jsx(BaseEdge, { id: _id, path: path, labelX: labelX, labelY: labelY, label: label, labelStyle: labelStyle, labelShowBg: labelShowBg, labelBgStyle: labelBgStyle, labelBgPadding: labelBgPadding, labelBgBorderRadius: labelBgBorderRadius, style: style, markerEnd: markerEnd, markerStart: markerStart, interactionWidth: interactionWidth }));\n });\n}\nconst SimpleBezierEdge = createSimpleBezierEdge({ isInternal: false });\nconst SimpleBezierEdgeInternal = createSimpleBezierEdge({ isInternal: true });\nSimpleBezierEdge.displayName = 'SimpleBezierEdge';\nSimpleBezierEdgeInternal.displayName = 'SimpleBezierEdgeInternal';\n\nfunction createSmoothStepEdge(params) {\n // eslint-disable-next-line react/display-name\n return memo(({ id, sourceX, sourceY, targetX, targetY, label, labelStyle, labelShowBg, labelBgStyle, labelBgPadding, labelBgBorderRadius, style, sourcePosition = Position.Bottom, targetPosition = Position.Top, markerEnd, markerStart, pathOptions, interactionWidth, }) => {\n const [path, labelX, labelY] = getSmoothStepPath({\n sourceX,\n sourceY,\n sourcePosition,\n targetX,\n targetY,\n targetPosition,\n borderRadius: pathOptions?.borderRadius,\n offset: pathOptions?.offset,\n stepPosition: pathOptions?.stepPosition,\n });\n const _id = params.isInternal ? undefined : id;\n return (jsx(BaseEdge, { id: _id, path: path, labelX: labelX, labelY: labelY, label: label, labelStyle: labelStyle, labelShowBg: labelShowBg, labelBgStyle: labelBgStyle, labelBgPadding: labelBgPadding, labelBgBorderRadius: labelBgBorderRadius, style: style, markerEnd: markerEnd, markerStart: markerStart, interactionWidth: interactionWidth }));\n });\n}\n/**\n * Component that can be used inside a custom edge to render a smooth step edge.\n *\n * @public\n * @example\n *\n * ```tsx\n * import { SmoothStepEdge } from '@xyflow/react';\n *\n * function CustomEdge({ sourceX, sourceY, targetX, targetY, sourcePosition, targetPosition }) {\n * return (\n * <SmoothStepEdge\n * sourceX={sourceX}\n * sourceY={sourceY}\n * targetX={targetX}\n * targetY={targetY}\n * sourcePosition={sourcePosition}\n * targetPosition={targetPosition}\n * />\n * );\n * }\n * ```\n */\nconst SmoothStepEdge = createSmoothStepEdge({ isInternal: false });\n/**\n * @internal\n */\nconst SmoothStepEdgeInternal = createSmoothStepEdge({ isInternal: true });\nSmoothStepEdge.displayName = 'SmoothStepEdge';\nSmoothStepEdgeInternal.displayName = 'SmoothStepEdgeInternal';\n\nfunction createStepEdge(params) {\n // eslint-disable-next-line react/display-name\n return memo(({ id, ...props }) => {\n const _id = params.isInternal ? undefined : id;\n return (jsx(SmoothStepEdge, { ...props, id: _id, pathOptions: useMemo(() => ({ borderRadius: 0, offset: props.pathOptions?.offset }), [props.pathOptions?.offset]) }));\n });\n}\n/**\n * Component that can be used inside a custom edge to render a step edge.\n *\n * @public\n * @example\n *\n * ```tsx\n * import { StepEdge } from '@xyflow/react';\n *\n * function CustomEdge({ sourceX, sourceY, targetX, targetY, sourcePosition, targetPosition }) {\n * return (\n * <StepEdge\n * sourceX={sourceX}\n * sourceY={sourceY}\n * targetX={targetX}\n * targetY={targetY}\n * sourcePosition={sourcePosition}\n * targetPosition={targetPosition}\n * />\n * );\n * }\n * ```\n */\nconst StepEdge = createStepEdge({ isInternal: false });\n/**\n * @internal\n */\nconst StepEdgeInternal = createStepEdge({ isInternal: true });\nStepEdge.displayName = 'StepEdge';\nStepEdgeInternal.displayName = 'StepEdgeInternal';\n\nfunction createStraightEdge(params) {\n // eslint-disable-next-line react/display-name\n return memo(({ id, sourceX, sourceY, targetX, targetY, label, labelStyle, labelShowBg, labelBgStyle, labelBgPadding, labelBgBorderRadius, style, markerEnd, markerStart, interactionWidth, }) => {\n const [path, labelX, labelY] = getStraightPath({ sourceX, sourceY, targetX, targetY });\n const _id = params.isInternal ? undefined : id;\n return (jsx(BaseEdge, { id: _id, path: path, labelX: labelX, labelY: labelY, label: label, labelStyle: labelStyle, labelShowBg: labelShowBg, labelBgStyle: labelBgStyle, labelBgPadding: labelBgPadding, labelBgBorderRadius: labelBgBorderRadius, style: style, markerEnd: markerEnd, markerStart: markerStart, interactionWidth: interactionWidth }));\n });\n}\n/**\n * Component that can be used inside a custom edge to render a straight line.\n *\n * @public\n * @example\n *\n * ```tsx\n * import { StraightEdge } from '@xyflow/react';\n *\n * function CustomEdge({ sourceX, sourceY, targetX, targetY }) {\n * return (\n * <StraightEdge\n * sourceX={sourceX}\n * sourceY={sourceY}\n * targetX={targetX}\n * targetY={targetY}\n * />\n * );\n * }\n * ```\n */\nconst StraightEdge = createStraightEdge({ isInternal: false });\n/**\n * @internal\n */\nconst StraightEdgeInternal = createStraightEdge({ isInternal: true });\nStraightEdge.displayName = 'StraightEdge';\nStraightEdgeInternal.displayName = 'StraightEdgeInternal';\n\nfunction createBezierEdge(params) {\n // eslint-disable-next-line react/display-name\n return memo(({ id, sourceX, sourceY, targetX, targetY, sourcePosition = Position.Bottom, targetPosition = Position.Top, label, labelStyle, labelShowBg, labelBgStyle, labelBgPadding, labelBgBorderRadius, style, markerEnd, markerStart, pathOptions, interactionWidth, }) => {\n const [path, labelX, labelY] = getBezierPath({\n sourceX,\n sourceY,\n sourcePosition,\n targetX,\n targetY,\n targetPosition,\n curvature: pathOptions?.curvature,\n });\n const _id = params.isInternal ? undefined : id;\n return (jsx(BaseEdge, { id: _id, path: path, labelX: labelX, labelY: labelY, label: label, labelStyle: labelStyle, labelShowBg: labelShowBg, labelBgStyle: labelBgStyle, labelBgPadding: labelBgPadding, labelBgBorderRadius: labelBgBorderRadius, style: style, markerEnd: markerEnd, markerStart: markerStart, interactionWidth: interactionWidth }));\n });\n}\n/**\n * Component that can be used inside a custom edge to render a bezier curve.\n *\n * @public\n * @example\n *\n * ```tsx\n * import { BezierEdge } from '@xyflow/react';\n *\n * function CustomEdge({ sourceX, sourceY, targetX, targetY, sourcePosition, targetPosition }) {\n * return (\n * <BezierEdge\n * sourceX={sourceX}\n * sourceY={sourceY}\n * targetX={targetX}\n * targetY={targetY}\n * sourcePosition={sourcePosition}\n * targetPosition={targetPosition}\n * />\n * );\n * }\n * ```\n */\nconst BezierEdge = createBezierEdge({ isInternal: false });\n/**\n * @internal\n */\nconst BezierEdgeInternal = createBezierEdge({ isInternal: true });\nBezierEdge.displayName = 'BezierEdge';\nBezierEdgeInternal.displayName = 'BezierEdgeInternal';\n\nconst builtinEdgeTypes = {\n default: BezierEdgeInternal,\n straight: StraightEdgeInternal,\n step: StepEdgeInternal,\n smoothstep: SmoothStepEdgeInternal,\n simplebezier: SimpleBezierEdgeInternal,\n};\nconst nullPosition = {\n sourceX: null,\n sourceY: null,\n targetX: null,\n targetY: null,\n sourcePosition: null,\n targetPosition: null,\n};\n\nconst shiftX = (x, shift, position) => {\n if (position === Position.Left)\n return x - shift;\n if (position === Position.Right)\n return x + shift;\n return x;\n};\nconst shiftY = (y, shift, position) => {\n if (position === Position.Top)\n return y - shift;\n if (position === Position.Bottom)\n return y + shift;\n return y;\n};\nconst EdgeUpdaterClassName = 'react-flow__edgeupdater';\n/**\n * @internal\n */\nfunction EdgeAnchor({ position, centerX, centerY, radius = 10, onMouseDown, onMouseEnter, onMouseOut, type, }) {\n return (jsx(\"circle\", { onMouseDown: onMouseDown, onMouseEnter: onMouseEnter, onMouseOut: onMouseOut, className: cc([EdgeUpdaterClassName, `${EdgeUpdaterClassName}-${type}`]), cx: shiftX(centerX, radius, position), cy: shiftY(centerY, radius, position), r: radius, stroke: \"transparent\", fill: \"transparent\" }));\n}\n\nfunction EdgeUpdateAnchors({ isReconnectable, reconnectRadius, edge, sourceX, sourceY, targetX, targetY, sourcePosition, targetPosition, onReconnect, onReconnectStart, onReconnectEnd, setReconnecting, setUpdateHover, }) {\n const store = useStoreApi();\n const handleEdgeUpdater = (event, oppositeHandle) => {\n // avoid triggering edge updater if mouse btn is not left\n if (event.button !== 0) {\n return;\n }\n const { autoPanOnConnect, domNode, isValidConnection, connectionMode, connectionRadius, lib, onConnectStart, onConnectEnd, cancelConnection, nodeLookup, rfId: flowId, panBy, updateConnection, } = store.getState();\n const isTarget = oppositeHandle.type === 'target';\n const _onReconnectEnd = (evt, connectionState) => {\n setReconnecting(false);\n onReconnectEnd?.(evt, edge, oppositeHandle.type, connectionState);\n };\n const onConnectEdge = (connection) => onReconnect?.(edge, connection);\n const _onConnectStart = (_event, params) => {\n setReconnecting(true);\n onReconnectStart?.(event, edge, oppositeHandle.type);\n onConnectStart?.(_event, params);\n };\n XYHandle.onPointerDown(event.nativeEvent, {\n autoPanOnConnect,\n connectionMode,\n connectionRadius,\n domNode,\n handleId: oppositeHandle.id,\n nodeId: oppositeHandle.nodeId,\n nodeLookup,\n isTarget,\n edgeUpdaterType: oppositeHandle.type,\n lib,\n flowId,\n cancelConnection,\n panBy,\n isValidConnection,\n onConnect: onConnectEdge,\n onConnectStart: _onConnectStart,\n onConnectEnd,\n onReconnectEnd: _onReconnectEnd,\n updateConnection,\n getTransform: () => store.getState().transform,\n getFromHandle: () => store.getState().connection.fromHandle,\n dragThreshold: store.getState().connectionDragThreshold,\n handleDomNode: event.currentTarget,\n });\n };\n const onReconnectSourceMouseDown = (event) => handleEdgeUpdater(event, { nodeId: edge.target, id: edge.targetHandle ?? null, type: 'target' });\n const onReconnectTargetMouseDown = (event) => handleEdgeUpdater(event, { nodeId: edge.source, id: edge.sourceHandle ?? null, type: 'source' });\n const onReconnectMouseEnter = () => setUpdateHover(true);\n const onReconnectMouseOut = () => setUpdateHover(false);\n return (jsxs(Fragment, { children: [(isReconnectable === true || isReconnectable === 'source') && (jsx(EdgeAnchor, { position: sourcePosition, centerX: sourceX, centerY: sourceY, radius: reconnectRadius, onMouseDown: onReconnectSourceMouseDown, onMouseEnter: onReconnectMouseEnter, onMouseOut: onReconnectMouseOut, type: \"source\" })), (isReconnectable === true || isReconnectable === 'target') && (jsx(EdgeAnchor, { position: targetPosition, centerX: targetX, centerY: targetY, radius: reconnectRadius, onMouseDown: onReconnectTargetMouseDown, onMouseEnter: onReconnectMouseEnter, onMouseOut: onReconnectMouseOut, type: \"target\" }))] }));\n}\n\nfunction EdgeWrapper({ id, edgesFocusable, edgesReconnectable, elementsSelectable, onClick, onDoubleClick, onContextMenu, onMouseEnter, onMouseMove, onMouseLeave, reconnectRadius, onReconnect, onReconnectStart, onReconnectEnd, rfId, edgeTypes, noPanClassName, onError, disableKeyboardA11y, }) {\n let edge = useStore((s) => s.edgeLookup.get(id));\n const defaultEdgeOptions = useStore((s) => s.defaultEdgeOptions);\n edge = defaultEdgeOptions ? { ...defaultEdgeOptions, ...edge } : edge;\n let edgeType = edge.type || 'default';\n let EdgeComponent = edgeTypes?.[edgeType] || builtinEdgeTypes[edgeType];\n if (EdgeComponent === undefined) {\n onError?.('011', errorMessages['error011'](edgeType));\n edgeType = 'default';\n EdgeComponent = edgeTypes?.['default'] || builtinEdgeTypes.default;\n }\n const isFocusable = !!(edge.focusable || (edgesFocusable && typeof edge.focusable === 'undefined'));\n const isReconnectable = typeof onReconnect !== 'undefined' &&\n (edge.reconnectable || (edgesReconnectable && typeof edge.reconnectable === 'undefined'));\n const isSelectable = !!(edge.selectable || (elementsSelectable && typeof edge.selectable === 'undefined'));\n const edgeRef = useRef(null);\n const [updateHover, setUpdateHover] = useState(false);\n const [reconnecting, setReconnecting] = useState(false);\n const store = useStoreApi();\n const { zIndex, sourceX, sourceY, targetX, targetY, sourcePosition, targetPosition } = useStore(useCallback((store) => {\n const sourceNode = store.nodeLookup.get(edge.source);\n const targetNode = store.nodeLookup.get(edge.target);\n if (!sourceNode || !targetNode) {\n return {\n zIndex: edge.zIndex,\n ...nullPosition,\n };\n }\n const edgePosition = getEdgePosition({\n id,\n sourceNode,\n targetNode,\n sourceHandle: edge.sourceHandle || null,\n targetHandle: edge.targetHandle || null,\n connectionMode: store.connectionMode,\n onError,\n });\n const zIndex = getElevatedEdgeZIndex({\n selected: edge.selected,\n zIndex: edge.zIndex,\n sourceNode,\n targetNode,\n elevateOnSelect: store.elevateEdgesOnSelect,\n });\n return {\n zIndex,\n ...(edgePosition || nullPosition),\n };\n }, [edge.source, edge.target, edge.sourceHandle, edge.targetHandle, edge.selected, edge.zIndex]), shallow);\n const markerStartUrl = useMemo(() => (edge.markerStart ? `url('#${getMarkerId(edge.markerStart, rfId)}')` : undefined), [edge.markerStart, rfId]);\n const markerEndUrl = useMemo(() => (edge.markerEnd ? `url('#${getMarkerId(edge.markerEnd, rfId)}')` : undefined), [edge.markerEnd, rfId]);\n if (edge.hidden || sourceX === null || sourceY === null || targetX === null || targetY === null) {\n return null;\n }\n const onEdgeClick = (event) => {\n const { addSelectedEdges, unselectNodesAndEdges, multiSelectionActive } = store.getState();\n if (isSelectable) {\n store.setState({ nodesSelectionActive: false });\n if (edge.selected && multiSelectionActive) {\n unselectNodesAndEdges({ nodes: [], edges: [edge] });\n edgeRef.current?.blur();\n }\n else {\n addSelectedEdges([id]);\n }\n }\n if (onClick) {\n onClick(event, edge);\n }\n };\n const onEdgeDoubleClick = onDoubleClick\n ? (event) => {\n onDoubleClick(event, { ...edge });\n }\n : undefined;\n const onEdgeContextMenu = onContextMenu\n ? (event) => {\n onContextMenu(event, { ...edge });\n }\n : undefined;\n const onEdgeMouseEnter = onMouseEnter\n ? (event) => {\n onMouseEnter(event, { ...edge });\n }\n : undefined;\n const onEdgeMouseMove = onMouseMove\n ? (event) => {\n onMouseMove(event, { ...edge });\n }\n : undefined;\n const onEdgeMouseLeave = onMouseLeave\n ? (event) => {\n onMouseLeave(event, { ...edge });\n }\n : undefined;\n const onKeyDown = (event) => {\n if (!disableKeyboardA11y && elementSelectionKeys.includes(event.key) && isSelectable) {\n const { unselectNodesAndEdges, addSelectedEdges } = store.getState();\n const unselect = event.key === 'Escape';\n if (unselect) {\n edgeRef.current?.blur();\n unselectNodesAndEdges({ edges: [edge] });\n }\n else {\n addSelectedEdges([id]);\n }\n }\n };\n return (jsx(\"svg\", { style: { zIndex }, children: jsxs(\"g\", { className: cc([\n 'react-flow__edge',\n `react-flow__edge-${edgeType}`,\n edge.className,\n noPanClassName,\n {\n selected: edge.selected,\n animated: edge.animated,\n inactive: !isSelectable && !onClick,\n updating: updateHover,\n selectable: isSelectable,\n },\n ]), onClick: onEdgeClick, onDoubleClick: onEdgeDoubleClick, onContextMenu: onEdgeContextMenu, onMouseEnter: onEdgeMouseEnter, onMouseMove: onEdgeMouseMove, onMouseLeave: onEdgeMouseLeave, onKeyDown: isFocusable ? onKeyDown : undefined, tabIndex: isFocusable ? 0 : undefined, role: edge.ariaRole ?? (isFocusable ? 'group' : 'img'), \"aria-roledescription\": \"edge\", \"data-id\": id, \"data-testid\": `rf__edge-${id}`, \"aria-label\": edge.ariaLabel === null ? undefined : edge.ariaLabel || `Edge from ${edge.source} to ${edge.target}`, \"aria-describedby\": isFocusable ? `${ARIA_EDGE_DESC_KEY}-${rfId}` : undefined, ref: edgeRef, ...edge.domAttributes, children: [!reconnecting && (jsx(EdgeComponent, { id: id, source: edge.source, target: edge.target, type: edge.type, selected: edge.selected, animated: edge.animated, selectable: isSelectable, deletable: edge.deletable ?? true, label: edge.label, labelStyle: edge.labelStyle, labelShowBg: edge.labelShowBg, labelBgStyle: edge.labelBgStyle, labelBgPadding: edge.labelBgPadding, labelBgBorderRadius: edge.labelBgBorderRadius, sourceX: sourceX, sourceY: sourceY, targetX: targetX, targetY: targetY, sourcePosition: sourcePosition, targetPosition: targetPosition, data: edge.data, style: edge.style, sourceHandleId: edge.sourceHandle, targetHandleId: edge.targetHandle, markerStart: markerStartUrl, markerEnd: markerEndUrl, pathOptions: 'pathOptions' in edge ? edge.pathOptions : undefined, interactionWidth: edge.interactionWidth })), isReconnectable && (jsx(EdgeUpdateAnchors, { edge: edge, isReconnectable: isReconnectable, reconnectRadius: reconnectRadius, onReconnect: onReconnect, onReconnectStart: onReconnectStart, onReconnectEnd: onReconnectEnd, sourceX: sourceX, sourceY: sourceY, targetX: targetX, targetY: targetY, sourcePosition: sourcePosition, targetPosition: targetPosition, setUpdateHover: setUpdateHover, setReconnecting: setReconnecting }))] }) }));\n}\nvar EdgeWrapper$1 = memo(EdgeWrapper);\n\nconst selector$a = (s) => ({\n edgesFocusable: s.edgesFocusable,\n edgesReconnectable: s.edgesReconnectable,\n elementsSelectable: s.elementsSelectable,\n connectionMode: s.connectionMode,\n onError: s.onError,\n});\nfunction EdgeRendererComponent({ defaultMarkerColor, onlyRenderVisibleElements, rfId, edgeTypes, noPanClassName, onReconnect, onEdgeContextMenu, onEdgeMouseEnter, onEdgeMouseMove, onEdgeMouseLeave, onEdgeClick, reconnectRadius, onEdgeDoubleClick, onReconnectStart, onReconnectEnd, disableKeyboardA11y, }) {\n const { edgesFocusable, edgesReconnectable, elementsSelectable, onError } = useStore(selector$a, shallow);\n const edgeIds = useVisibleEdgeIds(onlyRenderVisibleElements);\n return (jsxs(\"div\", { className: \"react-flow__edges\", children: [jsx(MarkerDefinitions$1, { defaultColor: defaultMarkerColor, rfId: rfId }), edgeIds.map((id) => {\n return (jsx(EdgeWrapper$1, { id: id, edgesFocusable: edgesFocusable, edgesReconnectable: edgesReconnectable, elementsSelectable: elementsSelectable, noPanClassName: noPanClassName, onReconnect: onReconnect, onContextMenu: onEdgeContextMenu, onMouseEnter: onEdgeMouseEnter, onMouseMove: onEdgeMouseMove, onMouseLeave: onEdgeMouseLeave, onClick: onEdgeClick, reconnectRadius: reconnectRadius, onDoubleClick: onEdgeDoubleClick, onReconnectStart: onReconnectStart, onReconnectEnd: onReconnectEnd, rfId: rfId, onError: onError, edgeTypes: edgeTypes, disableKeyboardA11y: disableKeyboardA11y }, id));\n })] }));\n}\nEdgeRendererComponent.displayName = 'EdgeRenderer';\nconst EdgeRenderer = memo(EdgeRendererComponent);\n\nconst selector$9 = (s) => `translate(${s.transform[0]}px,${s.transform[1]}px) scale(${s.transform[2]})`;\nfunction Viewport({ children }) {\n const transform = useStore(selector$9);\n return (jsx(\"div\", { className: \"react-flow__viewport xyflow__viewport react-flow__container\", style: { transform }, children: children }));\n}\n\n/**\n * Hook for calling onInit handler.\n *\n * @internal\n */\nfunction useOnInitHandler(onInit) {\n const rfInstance = useReactFlow();\n const isInitialized = useRef(false);\n useEffect(() => {\n if (!isInitialized.current && rfInstance.viewportInitialized && onInit) {\n setTimeout(() => onInit(rfInstance), 1);\n isInitialized.current = true;\n }\n }, [onInit, rfInstance.viewportInitialized]);\n}\n\nconst selector$8 = (state) => state.panZoom?.syncViewport;\n/**\n * Hook for syncing the viewport with the panzoom instance.\n *\n * @internal\n * @param viewport\n */\nfunction useViewportSync(viewport) {\n const syncViewport = useStore(selector$8);\n const store = useStoreApi();\n useEffect(() => {\n if (viewport) {\n syncViewport?.(viewport);\n store.setState({ transform: [viewport.x, viewport.y, viewport.zoom] });\n }\n }, [viewport, syncViewport]);\n return null;\n}\n\nfunction storeSelector$1(s) {\n return s.connection.inProgress\n ? { ...s.connection, to: pointToRendererPoint(s.connection.to, s.transform) }\n : { ...s.connection };\n}\nfunction getSelector(connectionSelector) {\n if (connectionSelector) {\n const combinedSelector = (s) => {\n const connection = storeSelector$1(s);\n return connectionSelector(connection);\n };\n return combinedSelector;\n }\n return storeSelector$1;\n}\n/**\n * The `useConnection` hook returns the current connection when there is an active\n * connection interaction. If no connection interaction is active, it returns null\n * for every property. A typical use case for this hook is to colorize handles\n * based on a certain condition (e.g. if the connection is valid or not).\n *\n * @public\n * @param connectionSelector - An optional selector function used to extract a slice of the\n * `ConnectionState` data. Using a selector can prevent component re-renders where data you don't\n * otherwise care about might change. If a selector is not provided, the entire `ConnectionState`\n * object is returned unchanged.\n * @example\n *\n * ```tsx\n *import { useConnection } from '@xyflow/react';\n *\n *function App() {\n * const connection = useConnection();\n *\n * return (\n * <div> {connection ? `Someone is trying to make a connection from ${connection.fromNode} to this one.` : 'There are currently no incoming connections!'}\n *\n * </div>\n * );\n * }\n * ```\n *\n * @returns ConnectionState\n */\nfunction useConnection(connectionSelector) {\n const combinedSelector = getSelector(connectionSelector);\n return useStore(combinedSelector, shallow);\n}\n\nconst selector$7 = (s) => ({\n nodesConnectable: s.nodesConnectable,\n isValid: s.connection.isValid,\n inProgress: s.connection.inProgress,\n width: s.width,\n height: s.height,\n});\nfunction ConnectionLineWrapper({ containerStyle, style, type, component, }) {\n const { nodesConnectable, width, height, isValid, inProgress } = useStore(selector$7, shallow);\n const renderConnection = !!(width && nodesConnectable && inProgress);\n if (!renderConnection) {\n return null;\n }\n return (jsx(\"svg\", { style: containerStyle, width: width, height: height, className: \"react-flow__connectionline react-flow__container\", children: jsx(\"g\", { className: cc(['react-flow__connection', getConnectionStatus(isValid)]), children: jsx(ConnectionLine, { style: style, type: type, CustomComponent: component, isValid: isValid }) }) }));\n}\nconst ConnectionLine = ({ style, type = ConnectionLineType.Bezier, CustomComponent, isValid, }) => {\n const { inProgress, from, fromNode, fromHandle, fromPosition, to, toNode, toHandle, toPosition } = useConnection();\n if (!inProgress) {\n return;\n }\n if (CustomComponent) {\n return (jsx(CustomComponent, { connectionLineType: type, connectionLineStyle: style, fromNode: fromNode, fromHandle: fromHandle, fromX: from.x, fromY: from.y, toX: to.x, toY: to.y, fromPosition: fromPosition, toPosition: toPosition, connectionStatus: getConnectionStatus(isValid), toNode: toNode, toHandle: toHandle }));\n }\n let path = '';\n const pathParams = {\n sourceX: from.x,\n sourceY: from.y,\n sourcePosition: fromPosition,\n targetX: to.x,\n targetY: to.y,\n targetPosition: toPosition,\n };\n switch (type) {\n case ConnectionLineType.Bezier:\n [path] = getBezierPath(pathParams);\n break;\n case ConnectionLineType.SimpleBezier:\n [path] = getSimpleBezierPath(pathParams);\n break;\n case ConnectionLineType.Step:\n [path] = getSmoothStepPath({\n ...pathParams,\n borderRadius: 0,\n });\n break;\n case ConnectionLineType.SmoothStep:\n [path] = getSmoothStepPath(pathParams);\n break;\n default:\n [path] = getStraightPath(pathParams);\n }\n return jsx(\"path\", { d: path, fill: \"none\", className: \"react-flow__connection-path\", style: style });\n};\nConnectionLine.displayName = 'ConnectionLine';\n\nconst emptyTypes = {};\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction useNodeOrEdgeTypesWarning(nodeOrEdgeTypes = emptyTypes) {\n const typesRef = useRef(nodeOrEdgeTypes);\n const store = useStoreApi();\n useEffect(() => {\n if (process.env.NODE_ENV === 'development') {\n const usedKeys = new Set([...Object.keys(typesRef.current), ...Object.keys(nodeOrEdgeTypes)]);\n for (const key of usedKeys) {\n if (typesRef.current[key] !== nodeOrEdgeTypes[key]) {\n store.getState().onError?.('002', errorMessages['error002']());\n break;\n }\n }\n typesRef.current = nodeOrEdgeTypes;\n }\n }, [nodeOrEdgeTypes]);\n}\n\nfunction useStylesLoadedWarning() {\n const store = useStoreApi();\n const checked = useRef(false);\n useEffect(() => {\n if (process.env.NODE_ENV === 'development') {\n if (!checked.current) {\n const pane = document.querySelector('.react-flow__pane');\n if (pane && !(window.getComputedStyle(pane).zIndex === '1')) {\n store.getState().onError?.('013', errorMessages['error013']('react'));\n }\n checked.current = true;\n }\n }\n }, []);\n}\n\nfunction GraphViewComponent({ nodeTypes, edgeTypes, onInit, onNodeClick, onEdgeClick, onNodeDoubleClick, onEdgeDoubleClick, onNodeMouseEnter, onNodeMouseMove, onNodeMouseLeave, onNodeContextMenu, onSelectionContextMenu, onSelectionStart, onSelectionEnd, connectionLineType, connectionLineStyle, connectionLineComponent, connectionLineContainerStyle, selectionKeyCode, selectionOnDrag, selectionMode, multiSelectionKeyCode, panActivationKeyCode, zoomActivationKeyCode, deleteKeyCode, onlyRenderVisibleElements, elementsSelectable, defaultViewport, translateExtent, minZoom, maxZoom, preventScrolling, defaultMarkerColor, zoomOnScroll, zoomOnPinch, panOnScroll, panOnScrollSpeed, panOnScrollMode, zoomOnDoubleClick, panOnDrag, onPaneClick, onPaneMouseEnter, onPaneMouseMove, onPaneMouseLeave, onPaneScroll, onPaneContextMenu, paneClickDistance, nodeClickDistance, onEdgeContextMenu, onEdgeMouseEnter, onEdgeMouseMove, onEdgeMouseLeave, reconnectRadius, onReconnect, onReconnectStart, onReconnectEnd, noDragClassName, noWheelClassName, noPanClassName, disableKeyboardA11y, nodeExtent, rfId, viewport, onViewportChange, }) {\n useNodeOrEdgeTypesWarning(nodeTypes);\n useNodeOrEdgeTypesWarning(edgeTypes);\n useStylesLoadedWarning();\n useOnInitHandler(onInit);\n useViewportSync(viewport);\n return (jsx(FlowRenderer, { onPaneClick: onPaneClick, onPaneMouseEnter: onPaneMouseEnter, onPaneMouseMove: onPaneMouseMove, onPaneMouseLeave: onPaneMouseLeave, onPaneContextMenu: onPaneContextMenu, onPaneScroll: onPaneScroll, paneClickDistance: paneClickDistance, deleteKeyCode: deleteKeyCode, selectionKeyCode: selectionKeyCode, selectionOnDrag: selectionOnDrag, selectionMode: selectionMode, onSelectionStart: onSelectionStart, onSelectionEnd: onSelectionEnd, multiSelectionKeyCode: multiSelectionKeyCode, panActivationKeyCode: panActivationKeyCode, zoomActivationKeyCode: zoomActivationKeyCode, elementsSelectable: elementsSelectable, zoomOnScroll: zoomOnScroll, zoomOnPinch: zoomOnPinch, zoomOnDoubleClick: zoomOnDoubleClick, panOnScroll: panOnScroll, panOnScrollSpeed: panOnScrollSpeed, panOnScrollMode: panOnScrollMode, panOnDrag: panOnDrag, defaultViewport: defaultViewport, translateExtent: translateExtent, minZoom: minZoom, maxZoom: maxZoom, onSelectionContextMenu: onSelectionContextMenu, preventScrolling: preventScrolling, noDragClassName: noDragClassName, noWheelClassName: noWheelClassName, noPanClassName: noPanClassName, disableKeyboardA11y: disableKeyboardA11y, onViewportChange: onViewportChange, isControlledViewport: !!viewport, children: jsxs(Viewport, { children: [jsx(EdgeRenderer, { edgeTypes: edgeTypes, onEdgeClick: onEdgeClick, onEdgeDoubleClick: onEdgeDoubleClick, onReconnect: onReconnect, onReconnectStart: onReconnectStart, onReconnectEnd: onReconnectEnd, onlyRenderVisibleElements: onlyRenderVisibleElements, onEdgeContextMenu: onEdgeContextMenu, onEdgeMouseEnter: onEdgeMouseEnter, onEdgeMouseMove: onEdgeMouseMove, onEdgeMouseLeave: onEdgeMouseLeave, reconnectRadius: reconnectRadius, defaultMarkerColor: defaultMarkerColor, noPanClassName: noPanClassName, disableKeyboardA11y: disableKeyboardA11y, rfId: rfId }), jsx(ConnectionLineWrapper, { style: connectionLineStyle, type: connectionLineType, component: connectionLineComponent, containerStyle: connectionLineContainerStyle }), jsx(\"div\", { className: \"react-flow__edgelabel-renderer\" }), jsx(NodeRenderer, { nodeTypes: nodeTypes, onNodeClick: onNodeClick, onNodeDoubleClick: onNodeDoubleClick, onNodeMouseEnter: onNodeMouseEnter, onNodeMouseMove: onNodeMouseMove, onNodeMouseLeave: onNodeMouseLeave, onNodeContextMenu: onNodeContextMenu, nodeClickDistance: nodeClickDistance, onlyRenderVisibleElements: onlyRenderVisibleElements, noPanClassName: noPanClassName, noDragClassName: noDragClassName, disableKeyboardA11y: disableKeyboardA11y, nodeExtent: nodeExtent, rfId: rfId }), jsx(\"div\", { className: \"react-flow__viewport-portal\" })] }) }));\n}\nGraphViewComponent.displayName = 'GraphView';\nconst GraphView = memo(GraphViewComponent);\n\nconst getInitialState = ({ nodes, edges, defaultNodes, defaultEdges, width, height, fitView, fitViewOptions, minZoom = 0.5, maxZoom = 2, nodeOrigin, nodeExtent, } = {}) => {\n const nodeLookup = new Map();\n const parentLookup = new Map();\n const connectionLookup = new Map();\n const edgeLookup = new Map();\n const storeEdges = defaultEdges ?? edges ?? [];\n const storeNodes = defaultNodes ?? nodes ?? [];\n const storeNodeOrigin = nodeOrigin ?? [0, 0];\n const storeNodeExtent = nodeExtent ?? infiniteExtent;\n updateConnectionLookup(connectionLookup, edgeLookup, storeEdges);\n const nodesInitialized = adoptUserNodes(storeNodes, nodeLookup, parentLookup, {\n nodeOrigin: storeNodeOrigin,\n nodeExtent: storeNodeExtent,\n elevateNodesOnSelect: false,\n });\n let transform = [0, 0, 1];\n if (fitView && width && height) {\n const bounds = getInternalNodesBounds(nodeLookup, {\n filter: (node) => !!((node.width || node.initialWidth) && (node.height || node.initialHeight)),\n });\n const { x, y, zoom } = getViewportForBounds(bounds, width, height, minZoom, maxZoom, fitViewOptions?.padding ?? 0.1);\n transform = [x, y, zoom];\n }\n return {\n rfId: '1',\n width: width ?? 0,\n height: height ?? 0,\n transform,\n nodes: storeNodes,\n nodesInitialized,\n nodeLookup,\n parentLookup,\n edges: storeEdges,\n edgeLookup,\n connectionLookup,\n onNodesChange: null,\n onEdgesChange: null,\n hasDefaultNodes: defaultNodes !== undefined,\n hasDefaultEdges: defaultEdges !== undefined,\n panZoom: null,\n minZoom,\n maxZoom,\n translateExtent: infiniteExtent,\n nodeExtent: storeNodeExtent,\n nodesSelectionActive: false,\n userSelectionActive: false,\n userSelectionRect: null,\n connectionMode: ConnectionMode.Strict,\n domNode: null,\n paneDragging: false,\n noPanClassName: 'nopan',\n nodeOrigin: storeNodeOrigin,\n nodeDragThreshold: 1,\n connectionDragThreshold: 1,\n snapGrid: [15, 15],\n snapToGrid: false,\n nodesDraggable: true,\n nodesConnectable: true,\n nodesFocusable: true,\n edgesFocusable: true,\n edgesReconnectable: true,\n elementsSelectable: true,\n elevateNodesOnSelect: true,\n elevateEdgesOnSelect: false,\n selectNodesOnDrag: true,\n multiSelectionActive: false,\n fitViewQueued: fitView ?? false,\n fitViewOptions,\n fitViewResolver: null,\n connection: { ...initialConnection },\n connectionClickStartHandle: null,\n connectOnClick: true,\n ariaLiveMessage: '',\n autoPanOnConnect: true,\n autoPanOnNodeDrag: true,\n autoPanOnNodeFocus: true,\n autoPanSpeed: 15,\n connectionRadius: 20,\n onError: devWarn,\n isValidConnection: undefined,\n onSelectionChangeHandlers: [],\n lib: 'react',\n debug: false,\n ariaLabelConfig: defaultAriaLabelConfig,\n };\n};\n\nconst createStore = ({ nodes, edges, defaultNodes, defaultEdges, width, height, fitView, fitViewOptions, minZoom, maxZoom, nodeOrigin, nodeExtent, }) => createWithEqualityFn((set, get) => {\n async function resolveFitView() {\n const { nodeLookup, panZoom, fitViewOptions, fitViewResolver, width, height, minZoom, maxZoom } = get();\n if (!panZoom) {\n return;\n }\n await fitViewport({\n nodes: nodeLookup,\n width,\n height,\n panZoom,\n minZoom,\n maxZoom,\n }, fitViewOptions);\n fitViewResolver?.resolve(true);\n /**\n * wait for the fitViewport to resolve before deleting the resolver,\n * we want to reuse the old resolver if the user calls fitView again in the mean time\n */\n set({ fitViewResolver: null });\n }\n return {\n ...getInitialState({\n nodes,\n edges,\n width,\n height,\n fitView,\n fitViewOptions,\n minZoom,\n maxZoom,\n nodeOrigin,\n nodeExtent,\n defaultNodes,\n defaultEdges,\n }),\n setNodes: (nodes) => {\n const { nodeLookup, parentLookup, nodeOrigin, elevateNodesOnSelect, fitViewQueued } = get();\n /*\n * setNodes() is called exclusively in response to user actions:\n * - either when the `<ReactFlow nodes>` prop is updated in the controlled ReactFlow setup,\n * - or when the user calls something like `reactFlowInstance.setNodes()` in an uncontrolled ReactFlow setup.\n *\n * When this happens, we take the note objects passed by the user and extend them with fields\n * relevant for internal React Flow operations.\n */\n const nodesInitialized = adoptUserNodes(nodes, nodeLookup, parentLookup, {\n nodeOrigin,\n nodeExtent,\n elevateNodesOnSelect,\n checkEquality: true,\n });\n if (fitViewQueued && nodesInitialized) {\n resolveFitView();\n set({ nodes, nodesInitialized, fitViewQueued: false, fitViewOptions: undefined });\n }\n else {\n set({ nodes, nodesInitialized });\n }\n },\n setEdges: (edges) => {\n const { connectionLookup, edgeLookup } = get();\n updateConnectionLookup(connectionLookup, edgeLookup, edges);\n set({ edges });\n },\n setDefaultNodesAndEdges: (nodes, edges) => {\n if (nodes) {\n const { setNodes } = get();\n setNodes(nodes);\n set({ hasDefaultNodes: true });\n }\n if (edges) {\n const { setEdges } = get();\n setEdges(edges);\n set({ hasDefaultEdges: true });\n }\n },\n /*\n * Every node gets registerd at a ResizeObserver. Whenever a node\n * changes its dimensions, this function is called to measure the\n * new dimensions and update the nodes.\n */\n updateNodeInternals: (updates) => {\n const { triggerNodeChanges, nodeLookup, parentLookup, domNode, nodeOrigin, nodeExtent, debug, fitViewQueued } = get();\n const { changes, updatedInternals } = updateNodeInternals(updates, nodeLookup, parentLookup, domNode, nodeOrigin, nodeExtent);\n if (!updatedInternals) {\n return;\n }\n updateAbsolutePositions(nodeLookup, parentLookup, { nodeOrigin, nodeExtent });\n if (fitViewQueued) {\n resolveFitView();\n set({ fitViewQueued: false, fitViewOptions: undefined });\n }\n else {\n // we always want to trigger useStore calls whenever updateNodeInternals is called\n set({});\n }\n if (changes?.length > 0) {\n if (debug) {\n console.log('React Flow: trigger node changes', changes);\n }\n triggerNodeChanges?.(changes);\n }\n },\n updateNodePositions: (nodeDragItems, dragging = false) => {\n const parentExpandChildren = [];\n const changes = [];\n const { nodeLookup, triggerNodeChanges } = get();\n for (const [id, dragItem] of nodeDragItems) {\n // we are using the nodelookup to be sure to use the current expandParent and parentId value\n const node = nodeLookup.get(id);\n const expandParent = !!(node?.expandParent && node?.parentId && dragItem?.position);\n const change = {\n id,\n type: 'position',\n position: expandParent\n ? {\n x: Math.max(0, dragItem.position.x),\n y: Math.max(0, dragItem.position.y),\n }\n : dragItem.position,\n dragging,\n };\n if (expandParent && node.parentId) {\n parentExpandChildren.push({\n id,\n parentId: node.parentId,\n rect: {\n ...dragItem.internals.positionAbsolute,\n width: dragItem.measured.width ?? 0,\n height: dragItem.measured.height ?? 0,\n },\n });\n }\n changes.push(change);\n }\n if (parentExpandChildren.length > 0) {\n const { parentLookup, nodeOrigin } = get();\n const parentExpandChanges = handleExpandParent(parentExpandChildren, nodeLookup, parentLookup, nodeOrigin);\n changes.push(...parentExpandChanges);\n }\n triggerNodeChanges(changes);\n },\n triggerNodeChanges: (changes) => {\n const { onNodesChange, setNodes, nodes, hasDefaultNodes, debug } = get();\n if (changes?.length) {\n if (hasDefaultNodes) {\n const updatedNodes = applyNodeChanges(changes, nodes);\n setNodes(updatedNodes);\n }\n if (debug) {\n console.log('React Flow: trigger node changes', changes);\n }\n onNodesChange?.(changes);\n }\n },\n triggerEdgeChanges: (changes) => {\n const { onEdgesChange, setEdges, edges, hasDefaultEdges, debug } = get();\n if (changes?.length) {\n if (hasDefaultEdges) {\n const updatedEdges = applyEdgeChanges(changes, edges);\n setEdges(updatedEdges);\n }\n if (debug) {\n console.log('React Flow: trigger edge changes', changes);\n }\n onEdgesChange?.(changes);\n }\n },\n addSelectedNodes: (selectedNodeIds) => {\n const { multiSelectionActive, edgeLookup, nodeLookup, triggerNodeChanges, triggerEdgeChanges } = get();\n if (multiSelectionActive) {\n const nodeChanges = selectedNodeIds.map((nodeId) => createSelectionChange(nodeId, true));\n triggerNodeChanges(nodeChanges);\n return;\n }\n triggerNodeChanges(getSelectionChanges(nodeLookup, new Set([...selectedNodeIds]), true));\n triggerEdgeChanges(getSelectionChanges(edgeLookup));\n },\n addSelectedEdges: (selectedEdgeIds) => {\n const { multiSelectionActive, edgeLookup, nodeLookup, triggerNodeChanges, triggerEdgeChanges } = get();\n if (multiSelectionActive) {\n const changedEdges = selectedEdgeIds.map((edgeId) => createSelectionChange(edgeId, true));\n triggerEdgeChanges(changedEdges);\n return;\n }\n triggerEdgeChanges(getSelectionChanges(edgeLookup, new Set([...selectedEdgeIds])));\n triggerNodeChanges(getSelectionChanges(nodeLookup, new Set(), true));\n },\n unselectNodesAndEdges: ({ nodes, edges } = {}) => {\n const { edges: storeEdges, nodes: storeNodes, nodeLookup, triggerNodeChanges, triggerEdgeChanges } = get();\n const nodesToUnselect = nodes ? nodes : storeNodes;\n const edgesToUnselect = edges ? edges : storeEdges;\n const nodeChanges = nodesToUnselect.map((n) => {\n const internalNode = nodeLookup.get(n.id);\n if (internalNode) {\n /*\n * we need to unselect the internal node that was selected previously before we\n * send the change to the user to prevent it to be selected while dragging the new node\n */\n internalNode.selected = false;\n }\n return createSelectionChange(n.id, false);\n });\n const edgeChanges = edgesToUnselect.map((edge) => createSelectionChange(edge.id, false));\n triggerNodeChanges(nodeChanges);\n triggerEdgeChanges(edgeChanges);\n },\n setMinZoom: (minZoom) => {\n const { panZoom, maxZoom } = get();\n panZoom?.setScaleExtent([minZoom, maxZoom]);\n set({ minZoom });\n },\n setMaxZoom: (maxZoom) => {\n const { panZoom, minZoom } = get();\n panZoom?.setScaleExtent([minZoom, maxZoom]);\n set({ maxZoom });\n },\n setTranslateExtent: (translateExtent) => {\n get().panZoom?.setTranslateExtent(translateExtent);\n set({ translateExtent });\n },\n setPaneClickDistance: (clickDistance) => {\n get().panZoom?.setClickDistance(clickDistance);\n },\n resetSelectedElements: () => {\n const { edges, nodes, triggerNodeChanges, triggerEdgeChanges, elementsSelectable } = get();\n if (!elementsSelectable) {\n return;\n }\n const nodeChanges = nodes.reduce((res, node) => (node.selected ? [...res, createSelectionChange(node.id, false)] : res), []);\n const edgeChanges = edges.reduce((res, edge) => (edge.selected ? [...res, createSelectionChange(edge.id, false)] : res), []);\n triggerNodeChanges(nodeChanges);\n triggerEdgeChanges(edgeChanges);\n },\n setNodeExtent: (nextNodeExtent) => {\n const { nodes, nodeLookup, parentLookup, nodeOrigin, elevateNodesOnSelect, nodeExtent } = get();\n if (nextNodeExtent[0][0] === nodeExtent[0][0] &&\n nextNodeExtent[0][1] === nodeExtent[0][1] &&\n nextNodeExtent[1][0] === nodeExtent[1][0] &&\n nextNodeExtent[1][1] === nodeExtent[1][1]) {\n return;\n }\n adoptUserNodes(nodes, nodeLookup, parentLookup, {\n nodeOrigin,\n nodeExtent: nextNodeExtent,\n elevateNodesOnSelect,\n checkEquality: false,\n });\n set({ nodeExtent: nextNodeExtent });\n },\n panBy: (delta) => {\n const { transform, width, height, panZoom, translateExtent } = get();\n return panBy({ delta, panZoom, transform, translateExtent, width, height });\n },\n setCenter: async (x, y, options) => {\n const { width, height, maxZoom, panZoom } = get();\n if (!panZoom) {\n return Promise.resolve(false);\n }\n const nextZoom = typeof options?.zoom !== 'undefined' ? options.zoom : maxZoom;\n await panZoom.setViewport({\n x: width / 2 - x * nextZoom,\n y: height / 2 - y * nextZoom,\n zoom: nextZoom,\n }, { duration: options?.duration, ease: options?.ease, interpolate: options?.interpolate });\n return Promise.resolve(true);\n },\n cancelConnection: () => {\n set({\n connection: { ...initialConnection },\n });\n },\n updateConnection: (connection) => {\n set({ connection });\n },\n reset: () => set({ ...getInitialState() }),\n };\n}, Object.is);\n\n/**\n * The `<ReactFlowProvider />` component is a [context provider](https://react.dev/learn/passing-data-deeply-with-context#)\n * that makes it possible to access a flow's internal state outside of the\n * [`<ReactFlow />`](/api-reference/react-flow) component. Many of the hooks we\n * provide rely on this component to work.\n * @public\n *\n * @example\n * ```tsx\n *import { ReactFlow, ReactFlowProvider, useNodes } from '@xyflow/react'\n *\n *export default function Flow() {\n * return (\n * <ReactFlowProvider>\n * <ReactFlow nodes={...} edges={...} />\n * <Sidebar />\n * </ReactFlowProvider>\n * );\n *}\n *\n *function Sidebar() {\n * // This hook will only work if the component it's used in is a child of a\n * // <ReactFlowProvider />.\n * const nodes = useNodes()\n *\n * return <aside>do something with nodes</aside>;\n *}\n *```\n *\n * @remarks If you're using a router and want your flow's state to persist across routes,\n * it's vital that you place the `<ReactFlowProvider />` component _outside_ of\n * your router. If you have multiple flows on the same page you will need to use a separate\n * `<ReactFlowProvider />` for each flow.\n */\nfunction ReactFlowProvider({ initialNodes: nodes, initialEdges: edges, defaultNodes, defaultEdges, initialWidth: width, initialHeight: height, initialMinZoom: minZoom, initialMaxZoom: maxZoom, initialFitViewOptions: fitViewOptions, fitView, nodeOrigin, nodeExtent, children, }) {\n const [store] = useState(() => createStore({\n nodes,\n edges,\n defaultNodes,\n defaultEdges,\n width,\n height,\n fitView,\n minZoom,\n maxZoom,\n fitViewOptions,\n nodeOrigin,\n nodeExtent,\n }));\n return (jsx(Provider$1, { value: store, children: jsx(BatchProvider, { children: children }) }));\n}\n\nfunction Wrapper({ children, nodes, edges, defaultNodes, defaultEdges, width, height, fitView, fitViewOptions, minZoom, maxZoom, nodeOrigin, nodeExtent, }) {\n const isWrapped = useContext(StoreContext);\n if (isWrapped) {\n /*\n * we need to wrap it with a fragment because it's not allowed for children to be a ReactNode\n * https://github.com/DefinitelyTyped/DefinitelyTyped/issues/18051\n */\n return jsx(Fragment, { children: children });\n }\n return (jsx(ReactFlowProvider, { initialNodes: nodes, initialEdges: edges, defaultNodes: defaultNodes, defaultEdges: defaultEdges, initialWidth: width, initialHeight: height, fitView: fitView, initialFitViewOptions: fitViewOptions, initialMinZoom: minZoom, initialMaxZoom: maxZoom, nodeOrigin: nodeOrigin, nodeExtent: nodeExtent, children: children }));\n}\n\nconst wrapperStyle = {\n width: '100%',\n height: '100%',\n overflow: 'hidden',\n position: 'relative',\n zIndex: 0,\n};\nfunction ReactFlow({ nodes, edges, defaultNodes, defaultEdges, className, nodeTypes, edgeTypes, onNodeClick, onEdgeClick, onInit, onMove, onMoveStart, onMoveEnd, onConnect, onConnectStart, onConnectEnd, onClickConnectStart, onClickConnectEnd, onNodeMouseEnter, onNodeMouseMove, onNodeMouseLeave, onNodeContextMenu, onNodeDoubleClick, onNodeDragStart, onNodeDrag, onNodeDragStop, onNodesDelete, onEdgesDelete, onDelete, onSelectionChange, onSelectionDragStart, onSelectionDrag, onSelectionDragStop, onSelectionContextMenu, onSelectionStart, onSelectionEnd, onBeforeDelete, connectionMode, connectionLineType = ConnectionLineType.Bezier, connectionLineStyle, connectionLineComponent, connectionLineContainerStyle, deleteKeyCode = 'Backspace', selectionKeyCode = 'Shift', selectionOnDrag = false, selectionMode = SelectionMode.Full, panActivationKeyCode = 'Space', multiSelectionKeyCode = isMacOs() ? 'Meta' : 'Control', zoomActivationKeyCode = isMacOs() ? 'Meta' : 'Control', snapToGrid, snapGrid, onlyRenderVisibleElements = false, selectNodesOnDrag, nodesDraggable, autoPanOnNodeFocus, nodesConnectable, nodesFocusable, nodeOrigin = defaultNodeOrigin, edgesFocusable, edgesReconnectable, elementsSelectable = true, defaultViewport: defaultViewport$1 = defaultViewport, minZoom = 0.5, maxZoom = 2, translateExtent = infiniteExtent, preventScrolling = true, nodeExtent, defaultMarkerColor = '#b1b1b7', zoomOnScroll = true, zoomOnPinch = true, panOnScroll = false, panOnScrollSpeed = 0.5, panOnScrollMode = PanOnScrollMode.Free, zoomOnDoubleClick = true, panOnDrag = true, onPaneClick, onPaneMouseEnter, onPaneMouseMove, onPaneMouseLeave, onPaneScroll, onPaneContextMenu, paneClickDistance = 0, nodeClickDistance = 0, children, onReconnect, onReconnectStart, onReconnectEnd, onEdgeContextMenu, onEdgeDoubleClick, onEdgeMouseEnter, onEdgeMouseMove, onEdgeMouseLeave, reconnectRadius = 10, onNodesChange, onEdgesChange, noDragClassName = 'nodrag', noWheelClassName = 'nowheel', noPanClassName = 'nopan', fitView, fitViewOptions, connectOnClick, attributionPosition, proOptions, defaultEdgeOptions, elevateNodesOnSelect, elevateEdgesOnSelect, disableKeyboardA11y = false, autoPanOnConnect, autoPanOnNodeDrag, autoPanSpeed, connectionRadius, isValidConnection, onError, style, id, nodeDragThreshold, connectionDragThreshold, viewport, onViewportChange, width, height, colorMode = 'light', debug, onScroll, ariaLabelConfig, ...rest }, ref) {\n const rfId = id || '1';\n const colorModeClassName = useColorModeClass(colorMode);\n // Undo scroll events, preventing viewport from shifting when nodes outside of it are focused\n const wrapperOnScroll = useCallback((e) => {\n e.currentTarget.scrollTo({ top: 0, left: 0, behavior: 'instant' });\n onScroll?.(e);\n }, [onScroll]);\n return (jsx(\"div\", { \"data-testid\": \"rf__wrapper\", ...rest, onScroll: wrapperOnScroll, style: { ...style, ...wrapperStyle }, ref: ref, className: cc(['react-flow', className, colorModeClassName]), id: id, role: \"application\", children: jsxs(Wrapper, { nodes: nodes, edges: edges, width: width, height: height, fitView: fitView, fitViewOptions: fitViewOptions, minZoom: minZoom, maxZoom: maxZoom, nodeOrigin: nodeOrigin, nodeExtent: nodeExtent, children: [jsx(GraphView, { onInit: onInit, onNodeClick: onNodeClick, onEdgeClick: onEdgeClick, onNodeMouseEnter: onNodeMouseEnter, onNodeMouseMove: onNodeMouseMove, onNodeMouseLeave: onNodeMouseLeave, onNodeContextMenu: onNodeContextMenu, onNodeDoubleClick: onNodeDoubleClick, nodeTypes: nodeTypes, edgeTypes: edgeTypes, connectionLineType: connectionLineType, connectionLineStyle: connectionLineStyle, connectionLineComponent: connectionLineComponent, connectionLineContainerStyle: connectionLineContainerStyle, selectionKeyCode: selectionKeyCode, selectionOnDrag: selectionOnDrag, selectionMode: selectionMode, deleteKeyCode: deleteKeyCode, multiSelectionKeyCode: multiSelectionKeyCode, panActivationKeyCode: panActivationKeyCode, zoomActivationKeyCode: zoomActivationKeyCode, onlyRenderVisibleElements: onlyRenderVisibleElements, defaultViewport: defaultViewport$1, translateExtent: translateExtent, minZoom: minZoom, maxZoom: maxZoom, preventScrolling: preventScrolling, zoomOnScroll: zoomOnScroll, zoomOnPinch: zoomOnPinch, zoomOnDoubleClick: zoomOnDoubleClick, panOnScroll: panOnScroll, panOnScrollSpeed: panOnScrollSpeed, panOnScrollMode: panOnScrollMode, panOnDrag: panOnDrag, onPaneClick: onPaneClick, onPaneMouseEnter: onPaneMouseEnter, onPaneMouseMove: onPaneMouseMove, onPaneMouseLeave: onPaneMouseLeave, onPaneScroll: onPaneScroll, onPaneContextMenu: onPaneContextMenu, paneClickDistance: paneClickDistance, nodeClickDistance: nodeClickDistance, onSelectionContextMenu: onSelectionContextMenu, onSelectionStart: onSelectionStart, onSelectionEnd: onSelectionEnd, onReconnect: onReconnect, onReconnectStart: onReconnectStart, onReconnectEnd: onReconnectEnd, onEdgeContextMenu: onEdgeContextMenu, onEdgeDoubleClick: onEdgeDoubleClick, onEdgeMouseEnter: onEdgeMouseEnter, onEdgeMouseMove: onEdgeMouseMove, onEdgeMouseLeave: onEdgeMouseLeave, reconnectRadius: reconnectRadius, defaultMarkerColor: defaultMarkerColor, noDragClassName: noDragClassName, noWheelClassName: noWheelClassName, noPanClassName: noPanClassName, rfId: rfId, disableKeyboardA11y: disableKeyboardA11y, nodeExtent: nodeExtent, viewport: viewport, onViewportChange: onViewportChange }), jsx(StoreUpdater, { nodes: nodes, edges: edges, defaultNodes: defaultNodes, defaultEdges: defaultEdges, onConnect: onConnect, onConnectStart: onConnectStart, onConnectEnd: onConnectEnd, onClickConnectStart: onClickConnectStart, onClickConnectEnd: onClickConnectEnd, nodesDraggable: nodesDraggable, autoPanOnNodeFocus: autoPanOnNodeFocus, nodesConnectable: nodesConnectable, nodesFocusable: nodesFocusable, edgesFocusable: edgesFocusable, edgesReconnectable: edgesReconnectable, elementsSelectable: elementsSelectable, elevateNodesOnSelect: elevateNodesOnSelect, elevateEdgesOnSelect: elevateEdgesOnSelect, minZoom: minZoom, maxZoom: maxZoom, nodeExtent: nodeExtent, onNodesChange: onNodesChange, onEdgesChange: onEdgesChange, snapToGrid: snapToGrid, snapGrid: snapGrid, connectionMode: connectionMode, translateExtent: translateExtent, connectOnClick: connectOnClick, defaultEdgeOptions: defaultEdgeOptions, fitView: fitView, fitViewOptions: fitViewOptions, onNodesDelete: onNodesDelete, onEdgesDelete: onEdgesDelete, onDelete: onDelete, onNodeDragStart: onNodeDragStart, onNodeDrag: onNodeDrag, onNodeDragStop: onNodeDragStop, onSelectionDrag: onSelectionDrag, onSelectionDragStart: onSelectionDragStart, onSelectionDragStop: onSelectionDragStop, onMove: onMove, onMoveStart: onMoveStart, onMoveEnd: onMoveEnd, noPanClassName: noPanClassName, nodeOrigin: nodeOrigin, rfId: rfId, autoPanOnConnect: autoPanOnConnect, autoPanOnNodeDrag: autoPanOnNodeDrag, autoPanSpeed: autoPanSpeed, onError: onError, connectionRadius: connectionRadius, isValidConnection: isValidConnection, selectNodesOnDrag: selectNodesOnDrag, nodeDragThreshold: nodeDragThreshold, connectionDragThreshold: connectionDragThreshold, onBeforeDelete: onBeforeDelete, paneClickDistance: paneClickDistance, debug: debug, ariaLabelConfig: ariaLabelConfig }), jsx(SelectionListener, { onSelectionChange: onSelectionChange }), children, jsx(Attribution, { proOptions: proOptions, position: attributionPosition }), jsx(A11yDescriptions, { rfId: rfId, disableKeyboardA11y: disableKeyboardA11y })] }) }));\n}\n/**\n * The `<ReactFlow />` component is the heart of your React Flow application.\n * It renders your nodes and edges and handles user interaction\n *\n * @public\n *\n * @example\n * ```tsx\n *import { ReactFlow } from '@xyflow/react'\n *\n *export default function Flow() {\n * return (<ReactFlow\n * nodes={...}\n * edges={...}\n * onNodesChange={...}\n * ...\n * />);\n *}\n *```\n */\nvar index = fixedForwardRef(ReactFlow);\n\nconst selector$6 = (s) => s.domNode?.querySelector('.react-flow__edgelabel-renderer');\n/**\n * Edges are SVG-based. If you want to render more complex labels you can use the\n * `<EdgeLabelRenderer />` component to access a div based renderer. This component\n * is a portal that renders the label in a `<div />` that is positioned on top of\n * the edges. You can see an example usage of the component in the\n * [edge label renderer example](/examples/edges/edge-label-renderer).\n * @public\n *\n * @example\n * ```jsx\n * import React from 'react';\n * import { getBezierPath, EdgeLabelRenderer, BaseEdge } from '@xyflow/react';\n *\n * export function CustomEdge({ id, data, ...props }) {\n * const [edgePath, labelX, labelY] = getBezierPath(props);\n *\n * return (\n * <>\n * <BaseEdge id={id} path={edgePath} />\n * <EdgeLabelRenderer>\n * <div\n * style={{\n * position: 'absolute',\n * transform: `translate(-50%, -50%) translate(${labelX}px,${labelY}px)`,\n * background: '#ffcc00',\n * padding: 10,\n * }}\n * className=\"nodrag nopan\"\n * >\n * {data.label}\n * </div>\n * </EdgeLabelRenderer>\n * </>\n * );\n * };\n * ```\n *\n * @remarks The `<EdgeLabelRenderer />` has no pointer events by default. If you want to\n * add mouse interactions you need to set the style `pointerEvents: all` and add\n * the `nopan` class on the label or the element you want to interact with.\n */\nfunction EdgeLabelRenderer({ children }) {\n const edgeLabelRenderer = useStore(selector$6);\n if (!edgeLabelRenderer) {\n return null;\n }\n return createPortal(children, edgeLabelRenderer);\n}\n\nconst selector$5 = (s) => s.domNode?.querySelector('.react-flow__viewport-portal');\n/**\n * The `<ViewportPortal />` component can be used to add components to the same viewport\n * of the flow where nodes and edges are rendered. This is useful when you want to render\n * your own components that are adhere to the same coordinate system as the nodes & edges\n * and are also affected by zooming and panning\n * @public\n * @example\n *\n * ```jsx\n *import React from 'react';\n *import { ViewportPortal } from '@xyflow/react';\n *\n *export default function () {\n * return (\n * <ViewportPortal>\n * <div\n * style={{ transform: 'translate(100px, 100px)', position: 'absolute' }}\n * >\n * This div is positioned at [100, 100] on the flow.\n * </div>\n * </ViewportPortal>\n * );\n *}\n *```\n */\nfunction ViewportPortal({ children }) {\n const viewPortalDiv = useStore(selector$5);\n if (!viewPortalDiv) {\n return null;\n }\n return createPortal(children, viewPortalDiv);\n}\n\n/**\n * When you programmatically add or remove handles to a node or update a node's\n * handle position, you need to let React Flow know about it using this hook. This\n * will update the internal dimensions of the node and properly reposition handles\n * on the canvas if necessary.\n *\n * @public\n * @returns Use this function to tell React Flow to update the internal state of one or more nodes\n * that you have changed programmatically.\n *\n * @example\n * ```jsx\n *import { useCallback, useState } from 'react';\n *import { Handle, useUpdateNodeInternals } from '@xyflow/react';\n *\n *export default function RandomHandleNode({ id }) {\n * const updateNodeInternals = useUpdateNodeInternals();\n * const [handleCount, setHandleCount] = useState(0);\n * const randomizeHandleCount = useCallback(() => {\n * setHandleCount(Math.floor(Math.random() * 10));\n * updateNodeInternals(id);\n * }, [id, updateNodeInternals]);\n *\n * return (\n * <>\n * {Array.from({ length: handleCount }).map((_, index) => (\n * <Handle\n * key={index}\n * type=\"target\"\n * position=\"left\"\n * id={`handle-${index}`}\n * />\n * ))}\n *\n * <div>\n * <button onClick={randomizeHandleCount}>Randomize handle count</button>\n * <p>There are {handleCount} handles on this node.</p>\n * </div>\n * </>\n * );\n *}\n *```\n * @remarks This hook can only be used in a component that is a child of a\n *{@link ReactFlowProvider} or a {@link ReactFlow} component.\n */\nfunction useUpdateNodeInternals() {\n const store = useStoreApi();\n return useCallback((id) => {\n const { domNode, updateNodeInternals } = store.getState();\n const updateIds = Array.isArray(id) ? id : [id];\n const updates = new Map();\n updateIds.forEach((updateId) => {\n const nodeElement = domNode?.querySelector(`.react-flow__node[data-id=\"${updateId}\"]`);\n if (nodeElement) {\n updates.set(updateId, { id: updateId, nodeElement, force: true });\n }\n });\n requestAnimationFrame(() => updateNodeInternals(updates, { triggerFitView: false }));\n }, []);\n}\n\nconst nodesSelector = (state) => state.nodes;\n/**\n * This hook returns an array of the current nodes. Components that use this hook\n * will re-render **whenever any node changes**, including when a node is selected\n * or moved.\n *\n * @public\n * @returns An array of all nodes currently in the flow.\n *\n * @example\n * ```jsx\n *import { useNodes } from '@xyflow/react';\n *\n *export default function() {\n * const nodes = useNodes();\n *\n * return <div>There are currently {nodes.length} nodes!</div>;\n *}\n *```\n */\nfunction useNodes() {\n const nodes = useStore(nodesSelector, shallow);\n return nodes;\n}\n\nconst edgesSelector = (state) => state.edges;\n/**\n * This hook returns an array of the current edges. Components that use this hook\n * will re-render **whenever any edge changes**.\n *\n * @public\n * @returns An array of all edges currently in the flow.\n *\n * @example\n * ```tsx\n *import { useEdges } from '@xyflow/react';\n *\n *export default function () {\n * const edges = useEdges();\n *\n * return <div>There are currently {edges.length} edges!</div>;\n *}\n *```\n */\nfunction useEdges() {\n const edges = useStore(edgesSelector, shallow);\n return edges;\n}\n\nconst viewportSelector = (state) => ({\n x: state.transform[0],\n y: state.transform[1],\n zoom: state.transform[2],\n});\n/**\n * The `useViewport` hook is a convenient way to read the current state of the\n * {@link Viewport} in a component. Components that use this hook\n * will re-render **whenever the viewport changes**.\n *\n * @public\n * @returns The current viewport.\n *\n * @example\n *\n *```jsx\n *import { useViewport } from '@xyflow/react';\n *\n *export default function ViewportDisplay() {\n * const { x, y, zoom } = useViewport();\n *\n * return (\n * <div>\n * <p>\n * The viewport is currently at ({x}, {y}) and zoomed to {zoom}.\n * </p>\n * </div>\n * );\n *}\n *```\n *\n * @remarks This hook can only be used in a component that is a child of a\n *{@link ReactFlowProvider} or a {@link ReactFlow} component.\n */\nfunction useViewport() {\n const viewport = useStore(viewportSelector, shallow);\n return viewport;\n}\n\n/**\n * This hook makes it easy to prototype a controlled flow where you manage the\n * state of nodes and edges outside the `ReactFlowInstance`. You can think of it\n * like React's `useState` hook with an additional helper callback.\n *\n * @public\n * @returns\n * - `nodes`: The current array of nodes. You might pass this directly to the `nodes` prop of your\n * `<ReactFlow />` component, or you may want to manipulate it first to perform some layouting,\n * for example.\n * - `setNodes`: A function that you can use to update the nodes. You can pass it a new array of\n * nodes or a callback that receives the current array of nodes and returns a new array of nodes.\n * This is the same as the second element of the tuple returned by React's `useState` hook.\n * - `onNodesChange`: A handy callback that can take an array of `NodeChanges` and update the nodes\n * state accordingly. You'll typically pass this directly to the `onNodesChange` prop of your\n * `<ReactFlow />` component.\n * @example\n *\n *```tsx\n *import { ReactFlow, useNodesState, useEdgesState } from '@xyflow/react';\n *\n *const initialNodes = [];\n *const initialEdges = [];\n *\n *export default function () {\n * const [nodes, setNodes, onNodesChange] = useNodesState(initialNodes);\n * const [edges, setEdges, onEdgesChange] = useEdgesState(initialEdges);\n *\n * return (\n * <ReactFlow\n * nodes={nodes}\n * edges={edges}\n * onNodesChange={onNodesChange}\n * onEdgesChange={onEdgesChange}\n * />\n * );\n *}\n *```\n *\n * @remarks This hook was created to make prototyping easier and our documentation\n * examples clearer. Although it is OK to use this hook in production, in\n * practice you may want to use a more sophisticated state management solution\n * like Zustand {@link https://reactflow.dev/docs/guides/state-management/} instead.\n *\n */\nfunction useNodesState(initialNodes) {\n const [nodes, setNodes] = useState(initialNodes);\n const onNodesChange = useCallback((changes) => setNodes((nds) => applyNodeChanges(changes, nds)), []);\n return [nodes, setNodes, onNodesChange];\n}\n/**\n * This hook makes it easy to prototype a controlled flow where you manage the\n * state of nodes and edges outside the `ReactFlowInstance`. You can think of it\n * like React's `useState` hook with an additional helper callback.\n *\n * @public\n * @returns\n * - `edges`: The current array of edges. You might pass this directly to the `edges` prop of your\n * `<ReactFlow />` component, or you may want to manipulate it first to perform some layouting,\n * for example.\n *\n * - `setEdges`: A function that you can use to update the edges. You can pass it a new array of\n * edges or a callback that receives the current array of edges and returns a new array of edges.\n * This is the same as the second element of the tuple returned by React's `useState` hook.\n *\n * - `onEdgesChange`: A handy callback that can take an array of `EdgeChanges` and update the edges\n * state accordingly. You'll typically pass this directly to the `onEdgesChange` prop of your\n * `<ReactFlow />` component.\n * @example\n *\n *```tsx\n *import { ReactFlow, useNodesState, useEdgesState } from '@xyflow/react';\n *\n *const initialNodes = [];\n *const initialEdges = [];\n *\n *export default function () {\n * const [nodes, setNodes, onNodesChange] = useNodesState(initialNodes);\n * const [edges, setEdges, onEdgesChange] = useEdgesState(initialEdges);\n *\n * return (\n * <ReactFlow\n * nodes={nodes}\n * edges={edges}\n * onNodesChange={onNodesChange}\n * onEdgesChange={onEdgesChange}\n * />\n * );\n *}\n *```\n *\n * @remarks This hook was created to make prototyping easier and our documentation\n * examples clearer. Although it is OK to use this hook in production, in\n * practice you may want to use a more sophisticated state management solution\n * like Zustand {@link https://reactflow.dev/docs/guides/state-management/} instead.\n *\n */\nfunction useEdgesState(initialEdges) {\n const [edges, setEdges] = useState(initialEdges);\n const onEdgesChange = useCallback((changes) => setEdges((eds) => applyEdgeChanges(changes, eds)), []);\n return [edges, setEdges, onEdgesChange];\n}\n\n/**\n * The `useOnViewportChange` hook lets you listen for changes to the viewport such\n * as panning and zooming. You can provide a callback for each phase of a viewport\n * change: `onStart`, `onChange`, and `onEnd`.\n *\n * @public\n * @example\n * ```jsx\n *import { useCallback } from 'react';\n *import { useOnViewportChange } from '@xyflow/react';\n *\n *function ViewportChangeLogger() {\n * useOnViewportChange({\n * onStart: (viewport: Viewport) => console.log('start', viewport),\n * onChange: (viewport: Viewport) => console.log('change', viewport),\n * onEnd: (viewport: Viewport) => console.log('end', viewport),\n * });\n *\n * return null;\n *}\n *```\n */\nfunction useOnViewportChange({ onStart, onChange, onEnd }) {\n const store = useStoreApi();\n useEffect(() => {\n store.setState({ onViewportChangeStart: onStart });\n }, [onStart]);\n useEffect(() => {\n store.setState({ onViewportChange: onChange });\n }, [onChange]);\n useEffect(() => {\n store.setState({ onViewportChangeEnd: onEnd });\n }, [onEnd]);\n}\n\n/**\n * This hook lets you listen for changes to both node and edge selection. As the\n *name implies, the callback you provide will be called whenever the selection of\n *_either_ nodes or edges changes.\n *\n * @public\n * @example\n * ```jsx\n *import { useState } from 'react';\n *import { ReactFlow, useOnSelectionChange } from '@xyflow/react';\n *\n *function SelectionDisplay() {\n * const [selectedNodes, setSelectedNodes] = useState([]);\n * const [selectedEdges, setSelectedEdges] = useState([]);\n *\n * // the passed handler has to be memoized, otherwise the hook will not work correctly\n * const onChange = useCallback(({ nodes, edges }) => {\n * setSelectedNodes(nodes.map((node) => node.id));\n * setSelectedEdges(edges.map((edge) => edge.id));\n * }, []);\n *\n * useOnSelectionChange({\n * onChange,\n * });\n *\n * return (\n * <div>\n * <p>Selected nodes: {selectedNodes.join(', ')}</p>\n * <p>Selected edges: {selectedEdges.join(', ')}</p>\n * </div>\n * );\n *}\n *```\n *\n * @remarks You need to memoize the passed `onChange` handler, otherwise the hook will not work correctly.\n */\nfunction useOnSelectionChange({ onChange, }) {\n const store = useStoreApi();\n useEffect(() => {\n const nextOnSelectionChangeHandlers = [...store.getState().onSelectionChangeHandlers, onChange];\n store.setState({ onSelectionChangeHandlers: nextOnSelectionChangeHandlers });\n return () => {\n const nextHandlers = store.getState().onSelectionChangeHandlers.filter((fn) => fn !== onChange);\n store.setState({ onSelectionChangeHandlers: nextHandlers });\n };\n }, [onChange]);\n}\n\nconst selector$4 = (options) => (s) => {\n if (!options.includeHiddenNodes) {\n return s.nodesInitialized;\n }\n if (s.nodeLookup.size === 0) {\n return false;\n }\n for (const [, { internals }] of s.nodeLookup) {\n if (internals.handleBounds === undefined || !nodeHasDimensions(internals.userNode)) {\n return false;\n }\n }\n return true;\n};\n/**\n * This hook tells you whether all the nodes in a flow have been measured and given\n *a width and height. When you add a node to the flow, this hook will return\n *`false` and then `true` again once the node has been measured.\n *\n * @public\n * @returns Whether or not the nodes have been initialized by the `<ReactFlow />` component and\n * given a width and height.\n *\n * @example\n * ```jsx\n *import { useReactFlow, useNodesInitialized } from '@xyflow/react';\n *import { useEffect, useState } from 'react';\n *\n *const options = {\n * includeHiddenNodes: false,\n *};\n *\n *export default function useLayout() {\n * const { getNodes } = useReactFlow();\n * const nodesInitialized = useNodesInitialized(options);\n * const [layoutedNodes, setLayoutedNodes] = useState(getNodes());\n *\n * useEffect(() => {\n * if (nodesInitialized) {\n * setLayoutedNodes(yourLayoutingFunction(getNodes()));\n * }\n * }, [nodesInitialized]);\n *\n * return layoutedNodes;\n *}\n *```\n */\nfunction useNodesInitialized(options = {\n includeHiddenNodes: false,\n}) {\n const initialized = useStore(selector$4(options));\n return initialized;\n}\n\n/**\n * Hook to check if a <Handle /> is connected to another <Handle /> and get the connections.\n *\n * @public\n * @deprecated Use `useNodeConnections` instead.\n * @returns An array with handle connections.\n */\nfunction useHandleConnections({ type, id, nodeId, onConnect, onDisconnect, }) {\n console.warn('[DEPRECATED] `useHandleConnections` is deprecated. Instead use `useNodeConnections` https://reactflow.dev/api-reference/hooks/useNodeConnections');\n const _nodeId = useNodeId();\n const currentNodeId = nodeId ?? _nodeId;\n const prevConnections = useRef(null);\n const connections = useStore((state) => state.connectionLookup.get(`${currentNodeId}-${type}${id ? `-${id}` : ''}`), areConnectionMapsEqual);\n useEffect(() => {\n // @todo dicuss if onConnect/onDisconnect should be called when the component mounts/unmounts\n if (prevConnections.current && prevConnections.current !== connections) {\n const _connections = connections ?? new Map();\n handleConnectionChange(prevConnections.current, _connections, onDisconnect);\n handleConnectionChange(_connections, prevConnections.current, onConnect);\n }\n prevConnections.current = connections ?? new Map();\n }, [connections, onConnect, onDisconnect]);\n return useMemo(() => Array.from(connections?.values() ?? []), [connections]);\n}\n\nconst error014 = errorMessages['error014']();\n/**\n * This hook returns an array of connections on a specific node, handle type ('source', 'target') or handle ID.\n *\n * @public\n * @returns An array with connections.\n *\n * @example\n * ```jsx\n *import { useNodeConnections } from '@xyflow/react';\n *\n *export default function () {\n * const connections = useNodeConnections({\n * handleType: 'target',\n * handleId: 'my-handle',\n * });\n *\n * return (\n * <div>There are currently {connections.length} incoming connections!</div>\n * );\n *}\n *```\n */\nfunction useNodeConnections({ id, handleType, handleId, onConnect, onDisconnect, } = {}) {\n const nodeId = useNodeId();\n const currentNodeId = id ?? nodeId;\n if (!currentNodeId) {\n throw new Error(error014);\n }\n const prevConnections = useRef(null);\n const connections = useStore((state) => state.connectionLookup.get(`${currentNodeId}${handleType ? (handleId ? `-${handleType}-${handleId}` : `-${handleType}`) : ''}`), areConnectionMapsEqual);\n useEffect(() => {\n // @todo discuss if onConnect/onDisconnect should be called when the component mounts/unmounts\n if (prevConnections.current && prevConnections.current !== connections) {\n const _connections = connections ?? new Map();\n handleConnectionChange(prevConnections.current, _connections, onDisconnect);\n handleConnectionChange(_connections, prevConnections.current, onConnect);\n }\n prevConnections.current = connections ?? new Map();\n }, [connections, onConnect, onDisconnect]);\n return useMemo(() => Array.from(connections?.values() ?? []), [connections]);\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction useNodesData(nodeIds) {\n const nodesData = useStore(useCallback((s) => {\n const data = [];\n const isArrayOfIds = Array.isArray(nodeIds);\n const _nodeIds = isArrayOfIds ? nodeIds : [nodeIds];\n for (const nodeId of _nodeIds) {\n const node = s.nodeLookup.get(nodeId);\n if (node) {\n data.push({\n id: node.id,\n type: node.type,\n data: node.data,\n });\n }\n }\n return isArrayOfIds ? data : data[0] ?? null;\n }, [nodeIds]), shallowNodeData);\n return nodesData;\n}\n\n/**\n * This hook returns the internal representation of a specific node.\n * Components that use this hook will re-render **whenever the node changes**,\n * including when a node is selected or moved.\n *\n * @public\n * @param id - The ID of a node you want to observe.\n * @returns The `InternalNode` object for the node with the given ID.\n *\n * @example\n * ```tsx\n *import { useInternalNode } from '@xyflow/react';\n *\n *export default function () {\n * const internalNode = useInternalNode('node-1');\n * const absolutePosition = internalNode.internals.positionAbsolute;\n *\n * return (\n * <div>\n * The absolute position of the node is at:\n * <p>x: {absolutePosition.x}</p>\n * <p>y: {absolutePosition.y}</p>\n * </div>\n * );\n *}\n *```\n */\nfunction useInternalNode(id) {\n const node = useStore(useCallback((s) => s.nodeLookup.get(id), [id]), shallow);\n return node;\n}\n\nfunction LinePattern({ dimensions, lineWidth, variant, className }) {\n return (jsx(\"path\", { strokeWidth: lineWidth, d: `M${dimensions[0] / 2} 0 V${dimensions[1]} M0 ${dimensions[1] / 2} H${dimensions[0]}`, className: cc(['react-flow__background-pattern', variant, className]) }));\n}\nfunction DotPattern({ radius, className }) {\n return (jsx(\"circle\", { cx: radius, cy: radius, r: radius, className: cc(['react-flow__background-pattern', 'dots', className]) }));\n}\n\n/**\n * The three variants are exported as an enum for convenience. You can either import\n * the enum and use it like `BackgroundVariant.Lines` or you can use the raw string\n * value directly.\n * @public\n */\nvar BackgroundVariant;\n(function (BackgroundVariant) {\n BackgroundVariant[\"Lines\"] = \"lines\";\n BackgroundVariant[\"Dots\"] = \"dots\";\n BackgroundVariant[\"Cross\"] = \"cross\";\n})(BackgroundVariant || (BackgroundVariant = {}));\n\nconst defaultSize = {\n [BackgroundVariant.Dots]: 1,\n [BackgroundVariant.Lines]: 1,\n [BackgroundVariant.Cross]: 6,\n};\nconst selector$3 = (s) => ({ transform: s.transform, patternId: `pattern-${s.rfId}` });\nfunction BackgroundComponent({ id, variant = BackgroundVariant.Dots, \n// only used for dots and cross\ngap = 20, \n// only used for lines and cross\nsize, lineWidth = 1, offset = 0, color, bgColor, style, className, patternClassName, }) {\n const ref = useRef(null);\n const { transform, patternId } = useStore(selector$3, shallow);\n const patternSize = size || defaultSize[variant];\n const isDots = variant === BackgroundVariant.Dots;\n const isCross = variant === BackgroundVariant.Cross;\n const gapXY = Array.isArray(gap) ? gap : [gap, gap];\n const scaledGap = [gapXY[0] * transform[2] || 1, gapXY[1] * transform[2] || 1];\n const scaledSize = patternSize * transform[2];\n const offsetXY = Array.isArray(offset) ? offset : [offset, offset];\n const patternDimensions = isCross ? [scaledSize, scaledSize] : scaledGap;\n const scaledOffset = [\n offsetXY[0] * transform[2] || 1 + patternDimensions[0] / 2,\n offsetXY[1] * transform[2] || 1 + patternDimensions[1] / 2,\n ];\n const _patternId = `${patternId}${id ? id : ''}`;\n return (jsxs(\"svg\", { className: cc(['react-flow__background', className]), style: {\n ...style,\n ...containerStyle,\n '--xy-background-color-props': bgColor,\n '--xy-background-pattern-color-props': color,\n }, ref: ref, \"data-testid\": \"rf__background\", children: [jsx(\"pattern\", { id: _patternId, x: transform[0] % scaledGap[0], y: transform[1] % scaledGap[1], width: scaledGap[0], height: scaledGap[1], patternUnits: \"userSpaceOnUse\", patternTransform: `translate(-${scaledOffset[0]},-${scaledOffset[1]})`, children: isDots ? (jsx(DotPattern, { radius: scaledSize / 2, className: patternClassName })) : (jsx(LinePattern, { dimensions: patternDimensions, lineWidth: lineWidth, variant: variant, className: patternClassName })) }), jsx(\"rect\", { x: \"0\", y: \"0\", width: \"100%\", height: \"100%\", fill: `url(#${_patternId})` })] }));\n}\nBackgroundComponent.displayName = 'Background';\n/**\n * The `<Background />` component makes it convenient to render different types of backgrounds common in node-based UIs. It comes with three variants: lines, dots and cross.\n *\n * @example\n *\n * A simple example of how to use the Background component.\n *\n * ```tsx\n * import { useState } from 'react';\n * import { ReactFlow, Background, BackgroundVariant } from '@xyflow/react';\n *\n * export default function Flow() {\n * return (\n * <ReactFlow defaultNodes={[...]} defaultEdges={[...]}>\n * <Background color=\"#ccc\" variant={BackgroundVariant.Dots} />\n * </ReactFlow>\n * );\n * }\n * ```\n *\n * @example\n *\n * In this example you can see how to combine multiple backgrounds\n *\n * ```tsx\n * import { ReactFlow, Background, BackgroundVariant } from '@xyflow/react';\n * import '@xyflow/react/dist/style.css';\n *\n * export default function Flow() {\n * return (\n * <ReactFlow defaultNodes={[...]} defaultEdges={[...]}>\n * <Background\n * id=\"1\"\n * gap={10}\n * color=\"#f1f1f1\"\n * variant={BackgroundVariant.Lines}\n * />\n * <Background\n * id=\"2\"\n * gap={100}\n * color=\"#ccc\"\n * variant={BackgroundVariant.Lines}\n * />\n * </ReactFlow>\n * );\n * }\n * ```\n *\n * @remarks\n *\n * When combining multiple <Background /> components it\u2019s important to give each of them a unique id prop!\n *\n */\nconst Background = memo(BackgroundComponent);\n\nfunction PlusIcon() {\n return (jsx(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 32 32\", children: jsx(\"path\", { d: \"M32 18.133H18.133V32h-4.266V18.133H0v-4.266h13.867V0h4.266v13.867H32z\" }) }));\n}\n\nfunction MinusIcon() {\n return (jsx(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 32 5\", children: jsx(\"path\", { d: \"M0 0h32v4.2H0z\" }) }));\n}\n\nfunction FitViewIcon() {\n return (jsx(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 32 30\", children: jsx(\"path\", { d: \"M3.692 4.63c0-.53.4-.938.939-.938h5.215V0H4.708C2.13 0 0 2.054 0 4.63v5.216h3.692V4.631zM27.354 0h-5.2v3.692h5.17c.53 0 .984.4.984.939v5.215H32V4.631A4.624 4.624 0 0027.354 0zm.954 24.83c0 .532-.4.94-.939.94h-5.215v3.768h5.215c2.577 0 4.631-2.13 4.631-4.707v-5.139h-3.692v5.139zm-23.677.94c-.531 0-.939-.4-.939-.94v-5.138H0v5.139c0 2.577 2.13 4.707 4.708 4.707h5.138V25.77H4.631z\" }) }));\n}\n\nfunction LockIcon() {\n return (jsx(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 25 32\", children: jsx(\"path\", { d: \"M21.333 10.667H19.81V7.619C19.81 3.429 16.38 0 12.19 0 8 0 4.571 3.429 4.571 7.619v3.048H3.048A3.056 3.056 0 000 13.714v15.238A3.056 3.056 0 003.048 32h18.285a3.056 3.056 0 003.048-3.048V13.714a3.056 3.056 0 00-3.048-3.047zM12.19 24.533a3.056 3.056 0 01-3.047-3.047 3.056 3.056 0 013.047-3.048 3.056 3.056 0 013.048 3.048 3.056 3.056 0 01-3.048 3.047zm4.724-13.866H7.467V7.619c0-2.59 2.133-4.724 4.723-4.724 2.591 0 4.724 2.133 4.724 4.724v3.048z\" }) }));\n}\n\nfunction UnlockIcon() {\n return (jsx(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 25 32\", children: jsx(\"path\", { d: \"M21.333 10.667H19.81V7.619C19.81 3.429 16.38 0 12.19 0c-4.114 1.828-1.37 2.133.305 2.438 1.676.305 4.42 2.59 4.42 5.181v3.048H3.047A3.056 3.056 0 000 13.714v15.238A3.056 3.056 0 003.048 32h18.285a3.056 3.056 0 003.048-3.048V13.714a3.056 3.056 0 00-3.048-3.047zM12.19 24.533a3.056 3.056 0 01-3.047-3.047 3.056 3.056 0 013.047-3.048 3.056 3.056 0 013.048 3.048 3.056 3.056 0 01-3.048 3.047z\" }) }));\n}\n\n/**\n * You can add buttons to the control panel by using the `<ControlButton />` component\n * and pass it as a child to the [`<Controls />`](/api-reference/components/controls) component.\n *\n * @public\n * @example\n *```jsx\n *import { MagicWand } from '@radix-ui/react-icons'\n *import { ReactFlow, Controls, ControlButton } from '@xyflow/react'\n *\n *export default function Flow() {\n * return (\n * <ReactFlow nodes={[...]} edges={[...]}>\n * <Controls>\n * <ControlButton onClick={() => alert('Something magical just happened. \u2728')}>\n * <MagicWand />\n * </ControlButton>\n * </Controls>\n * </ReactFlow>\n * )\n *}\n *```\n */\nfunction ControlButton({ children, className, ...rest }) {\n return (jsx(\"button\", { type: \"button\", className: cc(['react-flow__controls-button', className]), ...rest, children: children }));\n}\n\nconst selector$2 = (s) => ({\n isInteractive: s.nodesDraggable || s.nodesConnectable || s.elementsSelectable,\n minZoomReached: s.transform[2] <= s.minZoom,\n maxZoomReached: s.transform[2] >= s.maxZoom,\n ariaLabelConfig: s.ariaLabelConfig,\n});\nfunction ControlsComponent({ style, showZoom = true, showFitView = true, showInteractive = true, fitViewOptions, onZoomIn, onZoomOut, onFitView, onInteractiveChange, className, children, position = 'bottom-left', orientation = 'vertical', 'aria-label': ariaLabel, }) {\n const store = useStoreApi();\n const { isInteractive, minZoomReached, maxZoomReached, ariaLabelConfig } = useStore(selector$2, shallow);\n const { zoomIn, zoomOut, fitView } = useReactFlow();\n const onZoomInHandler = () => {\n zoomIn();\n onZoomIn?.();\n };\n const onZoomOutHandler = () => {\n zoomOut();\n onZoomOut?.();\n };\n const onFitViewHandler = () => {\n fitView(fitViewOptions);\n onFitView?.();\n };\n const onToggleInteractivity = () => {\n store.setState({\n nodesDraggable: !isInteractive,\n nodesConnectable: !isInteractive,\n elementsSelectable: !isInteractive,\n });\n onInteractiveChange?.(!isInteractive);\n };\n const orientationClass = orientation === 'horizontal' ? 'horizontal' : 'vertical';\n return (jsxs(Panel, { className: cc(['react-flow__controls', orientationClass, className]), position: position, style: style, \"data-testid\": \"rf__controls\", \"aria-label\": ariaLabel ?? ariaLabelConfig['controls.ariaLabel'], children: [showZoom && (jsxs(Fragment, { children: [jsx(ControlButton, { onClick: onZoomInHandler, className: \"react-flow__controls-zoomin\", title: ariaLabelConfig['controls.zoomIn.ariaLabel'], \"aria-label\": ariaLabelConfig['controls.zoomIn.ariaLabel'], disabled: maxZoomReached, children: jsx(PlusIcon, {}) }), jsx(ControlButton, { onClick: onZoomOutHandler, className: \"react-flow__controls-zoomout\", title: ariaLabelConfig['controls.zoomOut.ariaLabel'], \"aria-label\": ariaLabelConfig['controls.zoomOut.ariaLabel'], disabled: minZoomReached, children: jsx(MinusIcon, {}) })] })), showFitView && (jsx(ControlButton, { className: \"react-flow__controls-fitview\", onClick: onFitViewHandler, title: ariaLabelConfig['controls.fitView.ariaLabel'], \"aria-label\": ariaLabelConfig['controls.fitView.ariaLabel'], children: jsx(FitViewIcon, {}) })), showInteractive && (jsx(ControlButton, { className: \"react-flow__controls-interactive\", onClick: onToggleInteractivity, title: ariaLabelConfig['controls.interactive.ariaLabel'], \"aria-label\": ariaLabelConfig['controls.interactive.ariaLabel'], children: isInteractive ? jsx(UnlockIcon, {}) : jsx(LockIcon, {}) })), children] }));\n}\nControlsComponent.displayName = 'Controls';\n/**\n * The `<Controls />` component renders a small panel that contains convenient\n * buttons to zoom in, zoom out, fit the view, and lock the viewport.\n *\n * @public\n * @example\n *```tsx\n *import { ReactFlow, Controls } from '@xyflow/react'\n *\n *export default function Flow() {\n * return (\n * <ReactFlow nodes={[...]} edges={[...]}>\n * <Controls />\n * </ReactFlow>\n * )\n *}\n *```\n *\n * @remarks To extend or customise the controls, you can use the [`<ControlButton />`](/api-reference/components/control-button) component\n *\n */\nconst Controls = memo(ControlsComponent);\n\nfunction MiniMapNodeComponent({ id, x, y, width, height, style, color, strokeColor, strokeWidth, className, borderRadius, shapeRendering, selected, onClick, }) {\n const { background, backgroundColor } = style || {};\n const fill = (color || background || backgroundColor);\n return (jsx(\"rect\", { className: cc(['react-flow__minimap-node', { selected }, className]), x: x, y: y, rx: borderRadius, ry: borderRadius, width: width, height: height, style: {\n fill,\n stroke: strokeColor,\n strokeWidth,\n }, shapeRendering: shapeRendering, onClick: onClick ? (event) => onClick(event, id) : undefined }));\n}\nconst MiniMapNode = memo(MiniMapNodeComponent);\n\nconst selectorNodeIds = (s) => s.nodes.map((node) => node.id);\nconst getAttrFunction = (func) => func instanceof Function ? func : () => func;\nfunction MiniMapNodes({ nodeStrokeColor, nodeColor, nodeClassName = '', nodeBorderRadius = 5, nodeStrokeWidth, \n/*\n * We need to rename the prop to be `CapitalCase` so that JSX will render it as\n * a component properly.\n */\nnodeComponent: NodeComponent = MiniMapNode, onClick, }) {\n const nodeIds = useStore(selectorNodeIds, shallow);\n const nodeColorFunc = getAttrFunction(nodeColor);\n const nodeStrokeColorFunc = getAttrFunction(nodeStrokeColor);\n const nodeClassNameFunc = getAttrFunction(nodeClassName);\n const shapeRendering = typeof window === 'undefined' || !!window.chrome ? 'crispEdges' : 'geometricPrecision';\n return (jsx(Fragment, { children: nodeIds.map((nodeId) => (\n /*\n * The split of responsibilities between MiniMapNodes and\n * NodeComponentWrapper may appear weird. However, it\u2019s designed to\n * minimize the cost of updates when individual nodes change.\n *\n * For more details, see a similar commit in `NodeRenderer/index.tsx`.\n */\n jsx(NodeComponentWrapper, { id: nodeId, nodeColorFunc: nodeColorFunc, nodeStrokeColorFunc: nodeStrokeColorFunc, nodeClassNameFunc: nodeClassNameFunc, nodeBorderRadius: nodeBorderRadius, nodeStrokeWidth: nodeStrokeWidth, NodeComponent: NodeComponent, onClick: onClick, shapeRendering: shapeRendering }, nodeId))) }));\n}\nfunction NodeComponentWrapperInner({ id, nodeColorFunc, nodeStrokeColorFunc, nodeClassNameFunc, nodeBorderRadius, nodeStrokeWidth, shapeRendering, NodeComponent, onClick, }) {\n const { node, x, y, width, height } = useStore((s) => {\n const { internals } = s.nodeLookup.get(id);\n const node = internals.userNode;\n const { x, y } = internals.positionAbsolute;\n const { width, height } = getNodeDimensions(node);\n return {\n node,\n x,\n y,\n width,\n height,\n };\n }, shallow);\n if (!node || node.hidden || !nodeHasDimensions(node)) {\n return null;\n }\n return (jsx(NodeComponent, { x: x, y: y, width: width, height: height, style: node.style, selected: !!node.selected, className: nodeClassNameFunc(node), color: nodeColorFunc(node), borderRadius: nodeBorderRadius, strokeColor: nodeStrokeColorFunc(node), strokeWidth: nodeStrokeWidth, shapeRendering: shapeRendering, onClick: onClick, id: node.id }));\n}\nconst NodeComponentWrapper = memo(NodeComponentWrapperInner);\nvar MiniMapNodes$1 = memo(MiniMapNodes);\n\nconst defaultWidth = 200;\nconst defaultHeight = 150;\nconst filterHidden = (node) => !node.hidden;\nconst selector$1 = (s) => {\n const viewBB = {\n x: -s.transform[0] / s.transform[2],\n y: -s.transform[1] / s.transform[2],\n width: s.width / s.transform[2],\n height: s.height / s.transform[2],\n };\n return {\n viewBB,\n boundingRect: s.nodeLookup.size > 0\n ? getBoundsOfRects(getInternalNodesBounds(s.nodeLookup, { filter: filterHidden }), viewBB)\n : viewBB,\n rfId: s.rfId,\n panZoom: s.panZoom,\n translateExtent: s.translateExtent,\n flowWidth: s.width,\n flowHeight: s.height,\n ariaLabelConfig: s.ariaLabelConfig,\n };\n};\nconst ARIA_LABEL_KEY = 'react-flow__minimap-desc';\nfunction MiniMapComponent({ style, className, nodeStrokeColor, nodeColor, nodeClassName = '', nodeBorderRadius = 5, nodeStrokeWidth, \n/*\n * We need to rename the prop to be `CapitalCase` so that JSX will render it as\n * a component properly.\n */\nnodeComponent, bgColor, maskColor, maskStrokeColor, maskStrokeWidth, position = 'bottom-right', onClick, onNodeClick, pannable = false, zoomable = false, ariaLabel, inversePan, zoomStep = 1, offsetScale = 5, }) {\n const store = useStoreApi();\n const svg = useRef(null);\n const { boundingRect, viewBB, rfId, panZoom, translateExtent, flowWidth, flowHeight, ariaLabelConfig } = useStore(selector$1, shallow);\n const elementWidth = style?.width ?? defaultWidth;\n const elementHeight = style?.height ?? defaultHeight;\n const scaledWidth = boundingRect.width / elementWidth;\n const scaledHeight = boundingRect.height / elementHeight;\n const viewScale = Math.max(scaledWidth, scaledHeight);\n const viewWidth = viewScale * elementWidth;\n const viewHeight = viewScale * elementHeight;\n const offset = offsetScale * viewScale;\n const x = boundingRect.x - (viewWidth - boundingRect.width) / 2 - offset;\n const y = boundingRect.y - (viewHeight - boundingRect.height) / 2 - offset;\n const width = viewWidth + offset * 2;\n const height = viewHeight + offset * 2;\n const labelledBy = `${ARIA_LABEL_KEY}-${rfId}`;\n const viewScaleRef = useRef(0);\n const minimapInstance = useRef();\n viewScaleRef.current = viewScale;\n useEffect(() => {\n if (svg.current && panZoom) {\n minimapInstance.current = XYMinimap({\n domNode: svg.current,\n panZoom,\n getTransform: () => store.getState().transform,\n getViewScale: () => viewScaleRef.current,\n });\n return () => {\n minimapInstance.current?.destroy();\n };\n }\n }, [panZoom]);\n useEffect(() => {\n minimapInstance.current?.update({\n translateExtent,\n width: flowWidth,\n height: flowHeight,\n inversePan,\n pannable,\n zoomStep,\n zoomable,\n });\n }, [pannable, zoomable, inversePan, zoomStep, translateExtent, flowWidth, flowHeight]);\n const onSvgClick = onClick\n ? (event) => {\n const [x, y] = minimapInstance.current?.pointer(event) || [0, 0];\n onClick(event, { x, y });\n }\n : undefined;\n const onSvgNodeClick = onNodeClick\n ? useCallback((event, nodeId) => {\n const node = store.getState().nodeLookup.get(nodeId).internals.userNode;\n onNodeClick(event, node);\n }, [])\n : undefined;\n const _ariaLabel = ariaLabel ?? ariaLabelConfig['minimap.ariaLabel'];\n return (jsx(Panel, { position: position, style: {\n ...style,\n '--xy-minimap-background-color-props': typeof bgColor === 'string' ? bgColor : undefined,\n '--xy-minimap-mask-background-color-props': typeof maskColor === 'string' ? maskColor : undefined,\n '--xy-minimap-mask-stroke-color-props': typeof maskStrokeColor === 'string' ? maskStrokeColor : undefined,\n '--xy-minimap-mask-stroke-width-props': typeof maskStrokeWidth === 'number' ? maskStrokeWidth * viewScale : undefined,\n '--xy-minimap-node-background-color-props': typeof nodeColor === 'string' ? nodeColor : undefined,\n '--xy-minimap-node-stroke-color-props': typeof nodeStrokeColor === 'string' ? nodeStrokeColor : undefined,\n '--xy-minimap-node-stroke-width-props': typeof nodeStrokeWidth === 'number' ? nodeStrokeWidth : undefined,\n }, className: cc(['react-flow__minimap', className]), \"data-testid\": \"rf__minimap\", children: jsxs(\"svg\", { width: elementWidth, height: elementHeight, viewBox: `${x} ${y} ${width} ${height}`, className: \"react-flow__minimap-svg\", role: \"img\", \"aria-labelledby\": labelledBy, ref: svg, onClick: onSvgClick, children: [_ariaLabel && jsx(\"title\", { id: labelledBy, children: _ariaLabel }), jsx(MiniMapNodes$1, { onClick: onSvgNodeClick, nodeColor: nodeColor, nodeStrokeColor: nodeStrokeColor, nodeBorderRadius: nodeBorderRadius, nodeClassName: nodeClassName, nodeStrokeWidth: nodeStrokeWidth, nodeComponent: nodeComponent }), jsx(\"path\", { className: \"react-flow__minimap-mask\", d: `M${x - offset},${y - offset}h${width + offset * 2}v${height + offset * 2}h${-width - offset * 2}z\n M${viewBB.x},${viewBB.y}h${viewBB.width}v${viewBB.height}h${-viewBB.width}z`, fillRule: \"evenodd\", pointerEvents: \"none\" })] }) }));\n}\nMiniMapComponent.displayName = 'MiniMap';\n/**\n * The `<MiniMap />` component can be used to render an overview of your flow. It\n * renders each node as an SVG element and visualizes where the current viewport is\n * in relation to the rest of the flow.\n *\n * @public\n * @example\n *\n * ```jsx\n *import { ReactFlow, MiniMap } from '@xyflow/react';\n *\n *export default function Flow() {\n * return (\n * <ReactFlow nodes={[...]]} edges={[...]]}>\n * <MiniMap nodeStrokeWidth={3} />\n * </ReactFlow>\n * );\n *}\n *```\n */\nconst MiniMap = memo(MiniMapComponent);\n\nconst scaleSelector = (calculateScale) => (store) => calculateScale ? `${Math.max(1 / store.transform[2], 1)}` : undefined;\nconst defaultPositions = {\n [ResizeControlVariant.Line]: 'right',\n [ResizeControlVariant.Handle]: 'bottom-right',\n};\nfunction ResizeControl({ nodeId, position, variant = ResizeControlVariant.Handle, className, style = undefined, children, color, minWidth = 10, minHeight = 10, maxWidth = Number.MAX_VALUE, maxHeight = Number.MAX_VALUE, keepAspectRatio = false, resizeDirection, autoScale = true, shouldResize, onResizeStart, onResize, onResizeEnd, }) {\n const contextNodeId = useNodeId();\n const id = typeof nodeId === 'string' ? nodeId : contextNodeId;\n const store = useStoreApi();\n const resizeControlRef = useRef(null);\n const isHandleControl = variant === ResizeControlVariant.Handle;\n const scale = useStore(useCallback(scaleSelector(isHandleControl && autoScale), [isHandleControl, autoScale]), shallow);\n const resizer = useRef(null);\n const controlPosition = position ?? defaultPositions[variant];\n useEffect(() => {\n if (!resizeControlRef.current || !id) {\n return;\n }\n if (!resizer.current) {\n resizer.current = XYResizer({\n domNode: resizeControlRef.current,\n nodeId: id,\n getStoreItems: () => {\n const { nodeLookup, transform, snapGrid, snapToGrid, nodeOrigin, domNode } = store.getState();\n return {\n nodeLookup,\n transform,\n snapGrid,\n snapToGrid,\n nodeOrigin,\n paneDomNode: domNode,\n };\n },\n onChange: (change, childChanges) => {\n const { triggerNodeChanges, nodeLookup, parentLookup, nodeOrigin } = store.getState();\n const changes = [];\n const nextPosition = { x: change.x, y: change.y };\n const node = nodeLookup.get(id);\n if (node && node.expandParent && node.parentId) {\n const origin = node.origin ?? nodeOrigin;\n const width = change.width ?? node.measured.width ?? 0;\n const height = change.height ?? node.measured.height ?? 0;\n const child = {\n id: node.id,\n parentId: node.parentId,\n rect: {\n width,\n height,\n ...evaluateAbsolutePosition({\n x: change.x ?? node.position.x,\n y: change.y ?? node.position.y,\n }, { width, height }, node.parentId, nodeLookup, origin),\n },\n };\n const parentExpandChanges = handleExpandParent([child], nodeLookup, parentLookup, nodeOrigin);\n changes.push(...parentExpandChanges);\n /*\n * when the parent was expanded by the child node, its position will be clamped at\n * 0,0 when node origin is 0,0 and to width, height if it's 1,1\n */\n nextPosition.x = change.x ? Math.max(origin[0] * width, change.x) : undefined;\n nextPosition.y = change.y ? Math.max(origin[1] * height, change.y) : undefined;\n }\n if (nextPosition.x !== undefined && nextPosition.y !== undefined) {\n const positionChange = {\n id,\n type: 'position',\n position: { ...nextPosition },\n };\n changes.push(positionChange);\n }\n if (change.width !== undefined && change.height !== undefined) {\n const setAttributes = !resizeDirection ? true : resizeDirection === 'horizontal' ? 'width' : 'height';\n const dimensionChange = {\n id,\n type: 'dimensions',\n resizing: true,\n setAttributes,\n dimensions: {\n width: change.width,\n height: change.height,\n },\n };\n changes.push(dimensionChange);\n }\n for (const childChange of childChanges) {\n const positionChange = {\n ...childChange,\n type: 'position',\n };\n changes.push(positionChange);\n }\n triggerNodeChanges(changes);\n },\n onEnd: ({ width, height }) => {\n const dimensionChange = {\n id: id,\n type: 'dimensions',\n resizing: false,\n dimensions: {\n width,\n height,\n },\n };\n store.getState().triggerNodeChanges([dimensionChange]);\n },\n });\n }\n resizer.current.update({\n controlPosition,\n boundaries: {\n minWidth,\n minHeight,\n maxWidth,\n maxHeight,\n },\n keepAspectRatio,\n resizeDirection,\n onResizeStart,\n onResize,\n onResizeEnd,\n shouldResize,\n });\n return () => {\n resizer.current?.destroy();\n };\n }, [\n controlPosition,\n minWidth,\n minHeight,\n maxWidth,\n maxHeight,\n keepAspectRatio,\n onResizeStart,\n onResize,\n onResizeEnd,\n shouldResize,\n ]);\n const positionClassNames = controlPosition.split('-');\n return (jsx(\"div\", { className: cc(['react-flow__resize-control', 'nodrag', ...positionClassNames, variant, className]), ref: resizeControlRef, style: {\n ...style,\n scale,\n ...(color && { [isHandleControl ? 'backgroundColor' : 'borderColor']: color }),\n }, children: children }));\n}\n/**\n * To create your own resizing UI, you can use the `NodeResizeControl` component where you can pass children (such as icons).\n * @public\n *\n */\nconst NodeResizeControl = memo(ResizeControl);\n\n/**\n * The `<NodeResizer />` component can be used to add a resize functionality to your\n * nodes. It renders draggable controls around the node to resize in all directions.\n * @public\n *\n * @example\n *```jsx\n *import { memo } from 'react';\n *import { Handle, Position, NodeResizer } from '@xyflow/react';\n *\n *function ResizableNode({ data }) {\n * return (\n * <>\n * <NodeResizer minWidth={100} minHeight={30} />\n * <Handle type=\"target\" position={Position.Left} />\n * <div style={{ padding: 10 }}>{data.label}</div>\n * <Handle type=\"source\" position={Position.Right} />\n * </>\n * );\n *};\n *\n *export default memo(ResizableNode);\n *```\n */\nfunction NodeResizer({ nodeId, isVisible = true, handleClassName, handleStyle, lineClassName, lineStyle, color, minWidth = 10, minHeight = 10, maxWidth = Number.MAX_VALUE, maxHeight = Number.MAX_VALUE, keepAspectRatio = false, autoScale = true, shouldResize, onResizeStart, onResize, onResizeEnd, }) {\n if (!isVisible) {\n return null;\n }\n return (jsxs(Fragment, { children: [XY_RESIZER_LINE_POSITIONS.map((position) => (jsx(NodeResizeControl, { className: lineClassName, style: lineStyle, nodeId: nodeId, position: position, variant: ResizeControlVariant.Line, color: color, minWidth: minWidth, minHeight: minHeight, maxWidth: maxWidth, maxHeight: maxHeight, onResizeStart: onResizeStart, keepAspectRatio: keepAspectRatio, autoScale: autoScale, shouldResize: shouldResize, onResize: onResize, onResizeEnd: onResizeEnd }, position))), XY_RESIZER_HANDLE_POSITIONS.map((position) => (jsx(NodeResizeControl, { className: handleClassName, style: handleStyle, nodeId: nodeId, position: position, color: color, minWidth: minWidth, minHeight: minHeight, maxWidth: maxWidth, maxHeight: maxHeight, onResizeStart: onResizeStart, keepAspectRatio: keepAspectRatio, autoScale: autoScale, shouldResize: shouldResize, onResize: onResize, onResizeEnd: onResizeEnd }, position)))] }));\n}\n\nconst selector = (state) => state.domNode?.querySelector('.react-flow__renderer');\nfunction NodeToolbarPortal({ children }) {\n const wrapperRef = useStore(selector);\n if (!wrapperRef) {\n return null;\n }\n return createPortal(children, wrapperRef);\n}\n\nconst nodeEqualityFn = (a, b) => a?.internals.positionAbsolute.x !== b?.internals.positionAbsolute.x ||\n a?.internals.positionAbsolute.y !== b?.internals.positionAbsolute.y ||\n a?.measured.width !== b?.measured.width ||\n a?.measured.height !== b?.measured.height ||\n a?.selected !== b?.selected ||\n a?.internals.z !== b?.internals.z;\nconst nodesEqualityFn = (a, b) => {\n if (a.size !== b.size) {\n return false;\n }\n for (const [key, node] of a) {\n if (nodeEqualityFn(node, b.get(key))) {\n return false;\n }\n }\n return true;\n};\nconst storeSelector = (state) => ({\n x: state.transform[0],\n y: state.transform[1],\n zoom: state.transform[2],\n selectedNodesCount: state.nodes.filter((node) => node.selected).length,\n});\n/**\n * This component can render a toolbar or tooltip to one side of a custom node. This\n * toolbar doesn't scale with the viewport so that the content is always visible.\n *\n * @public\n * @example\n * ```jsx\n *import { memo } from 'react';\n *import { Handle, Position, NodeToolbar } from '@xyflow/react';\n *\n *function CustomNode({ data }) {\n * return (\n * <>\n * <NodeToolbar isVisible={data.toolbarVisible} position={data.toolbarPosition}>\n * <button>delete</button>\n * <button>copy</button>\n * <button>expand</button>\n * </NodeToolbar>\n *\n * <div style={{ padding: '10px 20px' }}>\n * {data.label}\n * </div>\n *\n * <Handle type=\"target\" position={Position.Left} />\n * <Handle type=\"source\" position={Position.Right} />\n * </>\n * );\n *};\n *\n *export default memo(CustomNode);\n *```\n * @remarks By default, the toolbar is only visible when a node is selected. If multiple\n * nodes are selected it will not be visible to prevent overlapping toolbars or\n * clutter. You can override this behavior by setting the `isVisible` prop to `true`.\n */\nfunction NodeToolbar({ nodeId, children, className, style, isVisible, position = Position.Top, offset = 10, align = 'center', ...rest }) {\n const contextNodeId = useNodeId();\n const nodesSelector = useCallback((state) => {\n const nodeIds = Array.isArray(nodeId) ? nodeId : [nodeId || contextNodeId || ''];\n const internalNodes = nodeIds.reduce((res, id) => {\n const node = state.nodeLookup.get(id);\n if (node) {\n res.set(node.id, node);\n }\n return res;\n }, new Map());\n return internalNodes;\n }, [nodeId, contextNodeId]);\n const nodes = useStore(nodesSelector, nodesEqualityFn);\n const { x, y, zoom, selectedNodesCount } = useStore(storeSelector, shallow);\n // if isVisible is not set, we show the toolbar only if its node is selected and no other node is selected\n const isActive = typeof isVisible === 'boolean'\n ? isVisible\n : nodes.size === 1 && nodes.values().next().value?.selected && selectedNodesCount === 1;\n if (!isActive || !nodes.size) {\n return null;\n }\n const nodeRect = getInternalNodesBounds(nodes);\n const nodesArray = Array.from(nodes.values());\n const zIndex = Math.max(...nodesArray.map((node) => node.internals.z + 1));\n const wrapperStyle = {\n position: 'absolute',\n transform: getNodeToolbarTransform(nodeRect, { x, y, zoom }, position, offset, align),\n zIndex,\n ...style,\n };\n return (jsx(NodeToolbarPortal, { children: jsx(\"div\", { style: wrapperStyle, className: cc(['react-flow__node-toolbar', className]), ...rest, \"data-id\": nodesArray.reduce((acc, node) => `${acc}${node.id} `, '').trim(), children: children }) }));\n}\n\nconst zoomSelector = (state) => state.transform[2];\n/**\n * This component can render a toolbar or tooltip to one side of a custom edge. This\n * toolbar doesn't scale with the viewport so that the content stays the same size.\n *\n * @public\n * @example\n * ```jsx\n * import { EdgeToolbar, BaseEdge, getBezierPath, type EdgeProps } from \"@xyflow/react\";\n *\n * export function CustomEdge({ id, data, ...props }: EdgeProps) {\n * const [edgePath, centerX, centerY] = getBezierPath(props);\n *\n * return (\n * <>\n * <BaseEdge id={id} path={edgePath} />\n * <EdgeToolbar edgeId={id} x={centerX} y={centerY} isVisible>\n * <button onClick={() => console.log('edge', id, 'click')}}>Click me</button>\n * </EdgeToolbar>\n * </>\n * );\n * }\n * ```\n */\nfunction EdgeToolbar({ edgeId, x, y, children, className, style, isVisible, alignX = 'center', alignY = 'center', ...rest }) {\n const edgeSelector = useCallback((state) => state.edgeLookup.get(edgeId), [edgeId]);\n const edge = useStore(edgeSelector, shallow);\n const isActive = typeof isVisible === 'boolean' ? isVisible : edge?.selected;\n const zoom = useStore(zoomSelector);\n if (!isActive) {\n return null;\n }\n const zIndex = (edge?.zIndex ?? 0) + 1;\n const transform = getEdgeToolbarTransform(x, y, zoom, alignX, alignY);\n return (jsx(EdgeLabelRenderer, { children: jsx(\"div\", { style: {\n position: 'absolute',\n transform,\n zIndex,\n pointerEvents: 'all',\n transformOrigin: '0 0',\n ...style,\n }, className: cc(['react-flow__edge-toolbar', className]), \"data-id\": edge?.id ?? '', ...rest, children: children }) }));\n}\n\nexport { Background, BackgroundVariant, BaseEdge, BezierEdge, ControlButton, Controls, EdgeLabelRenderer, EdgeText, EdgeToolbar, Handle, MiniMap, MiniMapNode, NodeResizeControl, NodeResizer, NodeToolbar, Panel, index as ReactFlow, ReactFlowProvider, SimpleBezierEdge, SmoothStepEdge, StepEdge, StraightEdge, ViewportPortal, applyEdgeChanges, applyNodeChanges, getSimpleBezierPath, isEdge, isNode, useConnection, useEdges, useEdgesState, useHandleConnections, useInternalNode, useKeyPress, useNodeConnections, useNodeId, useNodes, useNodesData, useNodesInitialized, useNodesState, useOnSelectionChange, useOnViewportChange, useReactFlow, useStore, useStoreApi, useUpdateNodeInternals, useViewport };\n", "export default function cc(names) {\n if (typeof names === \"string\" || typeof names === \"number\") return \"\" + names\n\n let out = \"\"\n\n if (Array.isArray(names)) {\n for (let i = 0, tmp; i < names.length; i++) {\n if ((tmp = cc(names[i])) !== \"\") {\n out += (out && \" \") + tmp\n }\n }\n } else {\n for (let k in names) {\n if (names[k]) out += (out && \" \") + k\n }\n }\n\n return out\n}\n", "var noop = {value: () => {}};\n\nfunction dispatch() {\n for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n if (!(t = arguments[i] + \"\") || (t in _) || /[\\s.]/.test(t)) throw new Error(\"illegal type: \" + t);\n _[t] = [];\n }\n return new Dispatch(_);\n}\n\nfunction Dispatch(_) {\n this._ = _;\n}\n\nfunction parseTypenames(typenames, types) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n return {type: t, name: name};\n });\n}\n\nDispatch.prototype = dispatch.prototype = {\n constructor: Dispatch,\n on: function(typename, callback) {\n var _ = this._,\n T = parseTypenames(typename + \"\", _),\n t,\n i = -1,\n n = T.length;\n\n // If no callback was specified, return the callback of the given type and name.\n if (arguments.length < 2) {\n while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n return;\n }\n\n // If a type was specified, set the callback for the given type and name.\n // Otherwise, if a null callback was specified, remove callbacks of the given name.\n if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n while (++i < n) {\n if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);\n else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);\n }\n\n return this;\n },\n copy: function() {\n var copy = {}, _ = this._;\n for (var t in _) copy[t] = _[t].slice();\n return new Dispatch(copy);\n },\n call: function(type, that) {\n if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n },\n apply: function(type, that, args) {\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n }\n};\n\nfunction get(type, name) {\n for (var i = 0, n = type.length, c; i < n; ++i) {\n if ((c = type[i]).name === name) {\n return c.value;\n }\n }\n}\n\nfunction set(type, name, callback) {\n for (var i = 0, n = type.length; i < n; ++i) {\n if (type[i].name === name) {\n type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));\n break;\n }\n }\n if (callback != null) type.push({name: name, value: callback});\n return type;\n}\n\nexport default dispatch;\n", "export var xhtml = \"http://www.w3.org/1999/xhtml\";\n\nexport default {\n svg: \"http://www.w3.org/2000/svg\",\n xhtml: xhtml,\n xlink: \"http://www.w3.org/1999/xlink\",\n xml: \"http://www.w3.org/XML/1998/namespace\",\n xmlns: \"http://www.w3.org/2000/xmlns/\"\n};\n", "import namespaces from \"./namespaces.js\";\n\nexport default function(name) {\n var prefix = name += \"\", i = prefix.indexOf(\":\");\n if (i >= 0 && (prefix = name.slice(0, i)) !== \"xmlns\") name = name.slice(i + 1);\n return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name; // eslint-disable-line no-prototype-builtins\n}\n", "import namespace from \"./namespace.js\";\nimport {xhtml} from \"./namespaces.js\";\n\nfunction creatorInherit(name) {\n return function() {\n var document = this.ownerDocument,\n uri = this.namespaceURI;\n return uri === xhtml && document.documentElement.namespaceURI === xhtml\n ? document.createElement(name)\n : document.createElementNS(uri, name);\n };\n}\n\nfunction creatorFixed(fullname) {\n return function() {\n return this.ownerDocument.createElementNS(fullname.space, fullname.local);\n };\n}\n\nexport default function(name) {\n var fullname = namespace(name);\n return (fullname.local\n ? creatorFixed\n : creatorInherit)(fullname);\n}\n", "function none() {}\n\nexport default function(selector) {\n return selector == null ? none : function() {\n return this.querySelector(selector);\n };\n}\n", "import {Selection} from \"./index.js\";\nimport selector from \"../selector.js\";\n\nexport default function(select) {\n if (typeof select !== \"function\") select = selector(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n subgroup[i] = subnode;\n }\n }\n }\n\n return new Selection(subgroups, this._parents);\n}\n", "// Given something array like (or null), returns something that is strictly an\n// array. This is used to ensure that array-like objects passed to d3.selectAll\n// or selection.selectAll are converted into proper arrays when creating a\n// selection; we don\u2019t ever want to create a selection backed by a live\n// HTMLCollection or NodeList. However, note that selection.selectAll will use a\n// static NodeList as a group, since it safely derived from querySelectorAll.\nexport default function array(x) {\n return x == null ? [] : Array.isArray(x) ? x : Array.from(x);\n}\n", "function empty() {\n return [];\n}\n\nexport default function(selector) {\n return selector == null ? empty : function() {\n return this.querySelectorAll(selector);\n };\n}\n", "import {Selection} from \"./index.js\";\nimport array from \"../array.js\";\nimport selectorAll from \"../selectorAll.js\";\n\nfunction arrayAll(select) {\n return function() {\n return array(select.apply(this, arguments));\n };\n}\n\nexport default function(select) {\n if (typeof select === \"function\") select = arrayAll(select);\n else select = selectorAll(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n subgroups.push(select.call(node, node.__data__, i, group));\n parents.push(node);\n }\n }\n }\n\n return new Selection(subgroups, parents);\n}\n", "export default function(selector) {\n return function() {\n return this.matches(selector);\n };\n}\n\nexport function childMatcher(selector) {\n return function(node) {\n return node.matches(selector);\n };\n}\n\n", "import {childMatcher} from \"../matcher.js\";\n\nvar find = Array.prototype.find;\n\nfunction childFind(match) {\n return function() {\n return find.call(this.children, match);\n };\n}\n\nfunction childFirst() {\n return this.firstElementChild;\n}\n\nexport default function(match) {\n return this.select(match == null ? childFirst\n : childFind(typeof match === \"function\" ? match : childMatcher(match)));\n}\n", "import {childMatcher} from \"../matcher.js\";\n\nvar filter = Array.prototype.filter;\n\nfunction children() {\n return Array.from(this.children);\n}\n\nfunction childrenFilter(match) {\n return function() {\n return filter.call(this.children, match);\n };\n}\n\nexport default function(match) {\n return this.selectAll(match == null ? children\n : childrenFilter(typeof match === \"function\" ? match : childMatcher(match)));\n}\n", "import {Selection} from \"./index.js\";\nimport matcher from \"../matcher.js\";\n\nexport default function(match) {\n if (typeof match !== \"function\") match = matcher(match);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n subgroup.push(node);\n }\n }\n }\n\n return new Selection(subgroups, this._parents);\n}\n", "export default function(update) {\n return new Array(update.length);\n}\n", "import sparse from \"./sparse.js\";\nimport {Selection} from \"./index.js\";\n\nexport default function() {\n return new Selection(this._enter || this._groups.map(sparse), this._parents);\n}\n\nexport function EnterNode(parent, datum) {\n this.ownerDocument = parent.ownerDocument;\n this.namespaceURI = parent.namespaceURI;\n this._next = null;\n this._parent = parent;\n this.__data__ = datum;\n}\n\nEnterNode.prototype = {\n constructor: EnterNode,\n appendChild: function(child) { return this._parent.insertBefore(child, this._next); },\n insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },\n querySelector: function(selector) { return this._parent.querySelector(selector); },\n querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }\n};\n", "export default function(x) {\n return function() {\n return x;\n };\n}\n", "import {Selection} from \"./index.js\";\nimport {EnterNode} from \"./enter.js\";\nimport constant from \"../constant.js\";\n\nfunction bindIndex(parent, group, enter, update, exit, data) {\n var i = 0,\n node,\n groupLength = group.length,\n dataLength = data.length;\n\n // Put any non-null nodes that fit into update.\n // Put any null nodes into enter.\n // Put any remaining data into enter.\n for (; i < dataLength; ++i) {\n if (node = group[i]) {\n node.__data__ = data[i];\n update[i] = node;\n } else {\n enter[i] = new EnterNode(parent, data[i]);\n }\n }\n\n // Put any non-null nodes that don\u2019t fit into exit.\n for (; i < groupLength; ++i) {\n if (node = group[i]) {\n exit[i] = node;\n }\n }\n}\n\nfunction bindKey(parent, group, enter, update, exit, data, key) {\n var i,\n node,\n nodeByKeyValue = new Map,\n groupLength = group.length,\n dataLength = data.length,\n keyValues = new Array(groupLength),\n keyValue;\n\n // Compute the key for each node.\n // If multiple nodes have the same key, the duplicates are added to exit.\n for (i = 0; i < groupLength; ++i) {\n if (node = group[i]) {\n keyValues[i] = keyValue = key.call(node, node.__data__, i, group) + \"\";\n if (nodeByKeyValue.has(keyValue)) {\n exit[i] = node;\n } else {\n nodeByKeyValue.set(keyValue, node);\n }\n }\n }\n\n // Compute the key for each datum.\n // If there a node associated with this key, join and add it to update.\n // If there is not (or the key is a duplicate), add it to enter.\n for (i = 0; i < dataLength; ++i) {\n keyValue = key.call(parent, data[i], i, data) + \"\";\n if (node = nodeByKeyValue.get(keyValue)) {\n update[i] = node;\n node.__data__ = data[i];\n nodeByKeyValue.delete(keyValue);\n } else {\n enter[i] = new EnterNode(parent, data[i]);\n }\n }\n\n // Add any remaining nodes that were not bound to data to exit.\n for (i = 0; i < groupLength; ++i) {\n if ((node = group[i]) && (nodeByKeyValue.get(keyValues[i]) === node)) {\n exit[i] = node;\n }\n }\n}\n\nfunction datum(node) {\n return node.__data__;\n}\n\nexport default function(value, key) {\n if (!arguments.length) return Array.from(this, datum);\n\n var bind = key ? bindKey : bindIndex,\n parents = this._parents,\n groups = this._groups;\n\n if (typeof value !== \"function\") value = constant(value);\n\n for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {\n var parent = parents[j],\n group = groups[j],\n groupLength = group.length,\n data = arraylike(value.call(parent, parent && parent.__data__, j, parents)),\n dataLength = data.length,\n enterGroup = enter[j] = new Array(dataLength),\n updateGroup = update[j] = new Array(dataLength),\n exitGroup = exit[j] = new Array(groupLength);\n\n bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);\n\n // Now connect the enter nodes to their following update node, such that\n // appendChild can insert the materialized enter node before this node,\n // rather than at the end of the parent node.\n for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {\n if (previous = enterGroup[i0]) {\n if (i0 >= i1) i1 = i0 + 1;\n while (!(next = updateGroup[i1]) && ++i1 < dataLength);\n previous._next = next || null;\n }\n }\n }\n\n update = new Selection(update, parents);\n update._enter = enter;\n update._exit = exit;\n return update;\n}\n\n// Given some data, this returns an array-like view of it: an object that\n// exposes a length property and allows numeric indexing. Note that unlike\n// selectAll, this isn\u2019t worried about \u201Clive\u201D collections because the resulting\n// array will only be used briefly while data is being bound. (It is possible to\n// cause the data to change while iterating by using a key function, but please\n// don\u2019t; we\u2019d rather avoid a gratuitous copy.)\nfunction arraylike(data) {\n return typeof data === \"object\" && \"length\" in data\n ? data // Array, TypedArray, NodeList, array-like\n : Array.from(data); // Map, Set, iterable, string, or anything else\n}\n", "import sparse from \"./sparse.js\";\nimport {Selection} from \"./index.js\";\n\nexport default function() {\n return new Selection(this._exit || this._groups.map(sparse), this._parents);\n}\n", "export default function(onenter, onupdate, onexit) {\n var enter = this.enter(), update = this, exit = this.exit();\n if (typeof onenter === \"function\") {\n enter = onenter(enter);\n if (enter) enter = enter.selection();\n } else {\n enter = enter.append(onenter + \"\");\n }\n if (onupdate != null) {\n update = onupdate(update);\n if (update) update = update.selection();\n }\n if (onexit == null) exit.remove(); else onexit(exit);\n return enter && update ? enter.merge(update).order() : update;\n}\n", "import {Selection} from \"./index.js\";\n\nexport default function(context) {\n var selection = context.selection ? context.selection() : context;\n\n for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group0[i] || group1[i]) {\n merge[i] = node;\n }\n }\n }\n\n for (; j < m0; ++j) {\n merges[j] = groups0[j];\n }\n\n return new Selection(merges, this._parents);\n}\n", "export default function() {\n\n for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {\n for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {\n if (node = group[i]) {\n if (next && node.compareDocumentPosition(next) ^ 4) next.parentNode.insertBefore(node, next);\n next = node;\n }\n }\n }\n\n return this;\n}\n", "import {Selection} from \"./index.js\";\n\nexport default function(compare) {\n if (!compare) compare = ascending;\n\n function compareNode(a, b) {\n return a && b ? compare(a.__data__, b.__data__) : !a - !b;\n }\n\n for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n sortgroup[i] = node;\n }\n }\n sortgroup.sort(compareNode);\n }\n\n return new Selection(sortgroups, this._parents).order();\n}\n\nfunction ascending(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n", "export default function() {\n var callback = arguments[0];\n arguments[0] = this;\n callback.apply(null, arguments);\n return this;\n}\n", "export default function() {\n return Array.from(this);\n}\n", "export default function() {\n\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {\n var node = group[i];\n if (node) return node;\n }\n }\n\n return null;\n}\n", "export default function() {\n let size = 0;\n for (const node of this) ++size; // eslint-disable-line no-unused-vars\n return size;\n}\n", "export default function() {\n return !this.node();\n}\n", "export default function(callback) {\n\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n if (node = group[i]) callback.call(node, node.__data__, i, group);\n }\n }\n\n return this;\n}\n", "import namespace from \"../namespace.js\";\n\nfunction attrRemove(name) {\n return function() {\n this.removeAttribute(name);\n };\n}\n\nfunction attrRemoveNS(fullname) {\n return function() {\n this.removeAttributeNS(fullname.space, fullname.local);\n };\n}\n\nfunction attrConstant(name, value) {\n return function() {\n this.setAttribute(name, value);\n };\n}\n\nfunction attrConstantNS(fullname, value) {\n return function() {\n this.setAttributeNS(fullname.space, fullname.local, value);\n };\n}\n\nfunction attrFunction(name, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.removeAttribute(name);\n else this.setAttribute(name, v);\n };\n}\n\nfunction attrFunctionNS(fullname, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.removeAttributeNS(fullname.space, fullname.local);\n else this.setAttributeNS(fullname.space, fullname.local, v);\n };\n}\n\nexport default function(name, value) {\n var fullname = namespace(name);\n\n if (arguments.length < 2) {\n var node = this.node();\n return fullname.local\n ? node.getAttributeNS(fullname.space, fullname.local)\n : node.getAttribute(fullname);\n }\n\n return this.each((value == null\n ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === \"function\"\n ? (fullname.local ? attrFunctionNS : attrFunction)\n : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));\n}\n", "export default function(node) {\n return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node\n || (node.document && node) // node is a Window\n || node.defaultView; // node is a Document\n}\n", "import defaultView from \"../window.js\";\n\nfunction styleRemove(name) {\n return function() {\n this.style.removeProperty(name);\n };\n}\n\nfunction styleConstant(name, value, priority) {\n return function() {\n this.style.setProperty(name, value, priority);\n };\n}\n\nfunction styleFunction(name, value, priority) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.style.removeProperty(name);\n else this.style.setProperty(name, v, priority);\n };\n}\n\nexport default function(name, value, priority) {\n return arguments.length > 1\n ? this.each((value == null\n ? styleRemove : typeof value === \"function\"\n ? styleFunction\n : styleConstant)(name, value, priority == null ? \"\" : priority))\n : styleValue(this.node(), name);\n}\n\nexport function styleValue(node, name) {\n return node.style.getPropertyValue(name)\n || defaultView(node).getComputedStyle(node, null).getPropertyValue(name);\n}\n", "function propertyRemove(name) {\n return function() {\n delete this[name];\n };\n}\n\nfunction propertyConstant(name, value) {\n return function() {\n this[name] = value;\n };\n}\n\nfunction propertyFunction(name, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) delete this[name];\n else this[name] = v;\n };\n}\n\nexport default function(name, value) {\n return arguments.length > 1\n ? this.each((value == null\n ? propertyRemove : typeof value === \"function\"\n ? propertyFunction\n : propertyConstant)(name, value))\n : this.node()[name];\n}\n", "function classArray(string) {\n return string.trim().split(/^|\\s+/);\n}\n\nfunction classList(node) {\n return node.classList || new ClassList(node);\n}\n\nfunction ClassList(node) {\n this._node = node;\n this._names = classArray(node.getAttribute(\"class\") || \"\");\n}\n\nClassList.prototype = {\n add: function(name) {\n var i = this._names.indexOf(name);\n if (i < 0) {\n this._names.push(name);\n this._node.setAttribute(\"class\", this._names.join(\" \"));\n }\n },\n remove: function(name) {\n var i = this._names.indexOf(name);\n if (i >= 0) {\n this._names.splice(i, 1);\n this._node.setAttribute(\"class\", this._names.join(\" \"));\n }\n },\n contains: function(name) {\n return this._names.indexOf(name) >= 0;\n }\n};\n\nfunction classedAdd(node, names) {\n var list = classList(node), i = -1, n = names.length;\n while (++i < n) list.add(names[i]);\n}\n\nfunction classedRemove(node, names) {\n var list = classList(node), i = -1, n = names.length;\n while (++i < n) list.remove(names[i]);\n}\n\nfunction classedTrue(names) {\n return function() {\n classedAdd(this, names);\n };\n}\n\nfunction classedFalse(names) {\n return function() {\n classedRemove(this, names);\n };\n}\n\nfunction classedFunction(names, value) {\n return function() {\n (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);\n };\n}\n\nexport default function(name, value) {\n var names = classArray(name + \"\");\n\n if (arguments.length < 2) {\n var list = classList(this.node()), i = -1, n = names.length;\n while (++i < n) if (!list.contains(names[i])) return false;\n return true;\n }\n\n return this.each((typeof value === \"function\"\n ? classedFunction : value\n ? classedTrue\n : classedFalse)(names, value));\n}\n", "function textRemove() {\n this.textContent = \"\";\n}\n\nfunction textConstant(value) {\n return function() {\n this.textContent = value;\n };\n}\n\nfunction textFunction(value) {\n return function() {\n var v = value.apply(this, arguments);\n this.textContent = v == null ? \"\" : v;\n };\n}\n\nexport default function(value) {\n return arguments.length\n ? this.each(value == null\n ? textRemove : (typeof value === \"function\"\n ? textFunction\n : textConstant)(value))\n : this.node().textContent;\n}\n", "function htmlRemove() {\n this.innerHTML = \"\";\n}\n\nfunction htmlConstant(value) {\n return function() {\n this.innerHTML = value;\n };\n}\n\nfunction htmlFunction(value) {\n return function() {\n var v = value.apply(this, arguments);\n this.innerHTML = v == null ? \"\" : v;\n };\n}\n\nexport default function(value) {\n return arguments.length\n ? this.each(value == null\n ? htmlRemove : (typeof value === \"function\"\n ? htmlFunction\n : htmlConstant)(value))\n : this.node().innerHTML;\n}\n", "function raise() {\n if (this.nextSibling) this.parentNode.appendChild(this);\n}\n\nexport default function() {\n return this.each(raise);\n}\n", "function lower() {\n if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);\n}\n\nexport default function() {\n return this.each(lower);\n}\n", "import creator from \"../creator.js\";\n\nexport default function(name) {\n var create = typeof name === \"function\" ? name : creator(name);\n return this.select(function() {\n return this.appendChild(create.apply(this, arguments));\n });\n}\n", "import creator from \"../creator.js\";\nimport selector from \"../selector.js\";\n\nfunction constantNull() {\n return null;\n}\n\nexport default function(name, before) {\n var create = typeof name === \"function\" ? name : creator(name),\n select = before == null ? constantNull : typeof before === \"function\" ? before : selector(before);\n return this.select(function() {\n return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);\n });\n}\n", "function remove() {\n var parent = this.parentNode;\n if (parent) parent.removeChild(this);\n}\n\nexport default function() {\n return this.each(remove);\n}\n", "function selection_cloneShallow() {\n var clone = this.cloneNode(false), parent = this.parentNode;\n return parent ? parent.insertBefore(clone, this.nextSibling) : clone;\n}\n\nfunction selection_cloneDeep() {\n var clone = this.cloneNode(true), parent = this.parentNode;\n return parent ? parent.insertBefore(clone, this.nextSibling) : clone;\n}\n\nexport default function(deep) {\n return this.select(deep ? selection_cloneDeep : selection_cloneShallow);\n}\n", "export default function(value) {\n return arguments.length\n ? this.property(\"__data__\", value)\n : this.node().__data__;\n}\n", "function contextListener(listener) {\n return function(event) {\n listener.call(this, event, this.__data__);\n };\n}\n\nfunction parseTypenames(typenames) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n return {type: t, name: name};\n });\n}\n\nfunction onRemove(typename) {\n return function() {\n var on = this.__on;\n if (!on) return;\n for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {\n if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {\n this.removeEventListener(o.type, o.listener, o.options);\n } else {\n on[++i] = o;\n }\n }\n if (++i) on.length = i;\n else delete this.__on;\n };\n}\n\nfunction onAdd(typename, value, options) {\n return function() {\n var on = this.__on, o, listener = contextListener(value);\n if (on) for (var j = 0, m = on.length; j < m; ++j) {\n if ((o = on[j]).type === typename.type && o.name === typename.name) {\n this.removeEventListener(o.type, o.listener, o.options);\n this.addEventListener(o.type, o.listener = listener, o.options = options);\n o.value = value;\n return;\n }\n }\n this.addEventListener(typename.type, listener, options);\n o = {type: typename.type, name: typename.name, value: value, listener: listener, options: options};\n if (!on) this.__on = [o];\n else on.push(o);\n };\n}\n\nexport default function(typename, value, options) {\n var typenames = parseTypenames(typename + \"\"), i, n = typenames.length, t;\n\n if (arguments.length < 2) {\n var on = this.node().__on;\n if (on) for (var j = 0, m = on.length, o; j < m; ++j) {\n for (i = 0, o = on[j]; i < n; ++i) {\n if ((t = typenames[i]).type === o.type && t.name === o.name) {\n return o.value;\n }\n }\n }\n return;\n }\n\n on = value ? onAdd : onRemove;\n for (i = 0; i < n; ++i) this.each(on(typenames[i], value, options));\n return this;\n}\n", "import defaultView from \"../window.js\";\n\nfunction dispatchEvent(node, type, params) {\n var window = defaultView(node),\n event = window.CustomEvent;\n\n if (typeof event === \"function\") {\n event = new event(type, params);\n } else {\n event = window.document.createEvent(\"Event\");\n if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;\n else event.initEvent(type, false, false);\n }\n\n node.dispatchEvent(event);\n}\n\nfunction dispatchConstant(type, params) {\n return function() {\n return dispatchEvent(this, type, params);\n };\n}\n\nfunction dispatchFunction(type, params) {\n return function() {\n return dispatchEvent(this, type, params.apply(this, arguments));\n };\n}\n\nexport default function(type, params) {\n return this.each((typeof params === \"function\"\n ? dispatchFunction\n : dispatchConstant)(type, params));\n}\n", "export default function*() {\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n if (node = group[i]) yield node;\n }\n }\n}\n", "import selection_select from \"./select.js\";\nimport selection_selectAll from \"./selectAll.js\";\nimport selection_selectChild from \"./selectChild.js\";\nimport selection_selectChildren from \"./selectChildren.js\";\nimport selection_filter from \"./filter.js\";\nimport selection_data from \"./data.js\";\nimport selection_enter from \"./enter.js\";\nimport selection_exit from \"./exit.js\";\nimport selection_join from \"./join.js\";\nimport selection_merge from \"./merge.js\";\nimport selection_order from \"./order.js\";\nimport selection_sort from \"./sort.js\";\nimport selection_call from \"./call.js\";\nimport selection_nodes from \"./nodes.js\";\nimport selection_node from \"./node.js\";\nimport selection_size from \"./size.js\";\nimport selection_empty from \"./empty.js\";\nimport selection_each from \"./each.js\";\nimport selection_attr from \"./attr.js\";\nimport selection_style from \"./style.js\";\nimport selection_property from \"./property.js\";\nimport selection_classed from \"./classed.js\";\nimport selection_text from \"./text.js\";\nimport selection_html from \"./html.js\";\nimport selection_raise from \"./raise.js\";\nimport selection_lower from \"./lower.js\";\nimport selection_append from \"./append.js\";\nimport selection_insert from \"./insert.js\";\nimport selection_remove from \"./remove.js\";\nimport selection_clone from \"./clone.js\";\nimport selection_datum from \"./datum.js\";\nimport selection_on from \"./on.js\";\nimport selection_dispatch from \"./dispatch.js\";\nimport selection_iterator from \"./iterator.js\";\n\nexport var root = [null];\n\nexport function Selection(groups, parents) {\n this._groups = groups;\n this._parents = parents;\n}\n\nfunction selection() {\n return new Selection([[document.documentElement]], root);\n}\n\nfunction selection_selection() {\n return this;\n}\n\nSelection.prototype = selection.prototype = {\n constructor: Selection,\n select: selection_select,\n selectAll: selection_selectAll,\n selectChild: selection_selectChild,\n selectChildren: selection_selectChildren,\n filter: selection_filter,\n data: selection_data,\n enter: selection_enter,\n exit: selection_exit,\n join: selection_join,\n merge: selection_merge,\n selection: selection_selection,\n order: selection_order,\n sort: selection_sort,\n call: selection_call,\n nodes: selection_nodes,\n node: selection_node,\n size: selection_size,\n empty: selection_empty,\n each: selection_each,\n attr: selection_attr,\n style: selection_style,\n property: selection_property,\n classed: selection_classed,\n text: selection_text,\n html: selection_html,\n raise: selection_raise,\n lower: selection_lower,\n append: selection_append,\n insert: selection_insert,\n remove: selection_remove,\n clone: selection_clone,\n datum: selection_datum,\n on: selection_on,\n dispatch: selection_dispatch,\n [Symbol.iterator]: selection_iterator\n};\n\nexport default selection;\n", "import {Selection, root} from \"./selection/index.js\";\n\nexport default function(selector) {\n return typeof selector === \"string\"\n ? new Selection([[document.querySelector(selector)]], [document.documentElement])\n : new Selection([[selector]], root);\n}\n", "export default function(event) {\n let sourceEvent;\n while (sourceEvent = event.sourceEvent) event = sourceEvent;\n return event;\n}\n", "import sourceEvent from \"./sourceEvent.js\";\n\nexport default function(event, node) {\n event = sourceEvent(event);\n if (node === undefined) node = event.currentTarget;\n if (node) {\n var svg = node.ownerSVGElement || node;\n if (svg.createSVGPoint) {\n var point = svg.createSVGPoint();\n point.x = event.clientX, point.y = event.clientY;\n point = point.matrixTransform(node.getScreenCTM().inverse());\n return [point.x, point.y];\n }\n if (node.getBoundingClientRect) {\n var rect = node.getBoundingClientRect();\n return [event.clientX - rect.left - node.clientLeft, event.clientY - rect.top - node.clientTop];\n }\n }\n return [event.pageX, event.pageY];\n}\n", "// These are typically used in conjunction with noevent to ensure that we can\n// preventDefault on the event.\nexport const nonpassive = {passive: false};\nexport const nonpassivecapture = {capture: true, passive: false};\n\nexport function nopropagation(event) {\n event.stopImmediatePropagation();\n}\n\nexport default function(event) {\n event.preventDefault();\n event.stopImmediatePropagation();\n}\n", "import {select} from \"d3-selection\";\nimport noevent, {nonpassivecapture} from \"./noevent.js\";\n\nexport default function(view) {\n var root = view.document.documentElement,\n selection = select(view).on(\"dragstart.drag\", noevent, nonpassivecapture);\n if (\"onselectstart\" in root) {\n selection.on(\"selectstart.drag\", noevent, nonpassivecapture);\n } else {\n root.__noselect = root.style.MozUserSelect;\n root.style.MozUserSelect = \"none\";\n }\n}\n\nexport function yesdrag(view, noclick) {\n var root = view.document.documentElement,\n selection = select(view).on(\"dragstart.drag\", null);\n if (noclick) {\n selection.on(\"click.drag\", noevent, nonpassivecapture);\n setTimeout(function() { selection.on(\"click.drag\", null); }, 0);\n }\n if (\"onselectstart\" in root) {\n selection.on(\"selectstart.drag\", null);\n } else {\n root.style.MozUserSelect = root.__noselect;\n delete root.__noselect;\n }\n}\n", "export default x => () => x;\n", "export default function DragEvent(type, {\n sourceEvent,\n subject,\n target,\n identifier,\n active,\n x, y, dx, dy,\n dispatch\n}) {\n Object.defineProperties(this, {\n type: {value: type, enumerable: true, configurable: true},\n sourceEvent: {value: sourceEvent, enumerable: true, configurable: true},\n subject: {value: subject, enumerable: true, configurable: true},\n target: {value: target, enumerable: true, configurable: true},\n identifier: {value: identifier, enumerable: true, configurable: true},\n active: {value: active, enumerable: true, configurable: true},\n x: {value: x, enumerable: true, configurable: true},\n y: {value: y, enumerable: true, configurable: true},\n dx: {value: dx, enumerable: true, configurable: true},\n dy: {value: dy, enumerable: true, configurable: true},\n _: {value: dispatch}\n });\n}\n\nDragEvent.prototype.on = function() {\n var value = this._.on.apply(this._, arguments);\n return value === this._ ? this : value;\n};\n", "import {dispatch} from \"d3-dispatch\";\nimport {select, pointer} from \"d3-selection\";\nimport nodrag, {yesdrag} from \"./nodrag.js\";\nimport noevent, {nonpassive, nonpassivecapture, nopropagation} from \"./noevent.js\";\nimport constant from \"./constant.js\";\nimport DragEvent from \"./event.js\";\n\n// Ignore right-click, since that should open the context menu.\nfunction defaultFilter(event) {\n return !event.ctrlKey && !event.button;\n}\n\nfunction defaultContainer() {\n return this.parentNode;\n}\n\nfunction defaultSubject(event, d) {\n return d == null ? {x: event.x, y: event.y} : d;\n}\n\nfunction defaultTouchable() {\n return navigator.maxTouchPoints || (\"ontouchstart\" in this);\n}\n\nexport default function() {\n var filter = defaultFilter,\n container = defaultContainer,\n subject = defaultSubject,\n touchable = defaultTouchable,\n gestures = {},\n listeners = dispatch(\"start\", \"drag\", \"end\"),\n active = 0,\n mousedownx,\n mousedowny,\n mousemoving,\n touchending,\n clickDistance2 = 0;\n\n function drag(selection) {\n selection\n .on(\"mousedown.drag\", mousedowned)\n .filter(touchable)\n .on(\"touchstart.drag\", touchstarted)\n .on(\"touchmove.drag\", touchmoved, nonpassive)\n .on(\"touchend.drag touchcancel.drag\", touchended)\n .style(\"touch-action\", \"none\")\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\");\n }\n\n function mousedowned(event, d) {\n if (touchending || !filter.call(this, event, d)) return;\n var gesture = beforestart(this, container.call(this, event, d), event, d, \"mouse\");\n if (!gesture) return;\n select(event.view)\n .on(\"mousemove.drag\", mousemoved, nonpassivecapture)\n .on(\"mouseup.drag\", mouseupped, nonpassivecapture);\n nodrag(event.view);\n nopropagation(event);\n mousemoving = false;\n mousedownx = event.clientX;\n mousedowny = event.clientY;\n gesture(\"start\", event);\n }\n\n function mousemoved(event) {\n noevent(event);\n if (!mousemoving) {\n var dx = event.clientX - mousedownx, dy = event.clientY - mousedowny;\n mousemoving = dx * dx + dy * dy > clickDistance2;\n }\n gestures.mouse(\"drag\", event);\n }\n\n function mouseupped(event) {\n select(event.view).on(\"mousemove.drag mouseup.drag\", null);\n yesdrag(event.view, mousemoving);\n noevent(event);\n gestures.mouse(\"end\", event);\n }\n\n function touchstarted(event, d) {\n if (!filter.call(this, event, d)) return;\n var touches = event.changedTouches,\n c = container.call(this, event, d),\n n = touches.length, i, gesture;\n\n for (i = 0; i < n; ++i) {\n if (gesture = beforestart(this, c, event, d, touches[i].identifier, touches[i])) {\n nopropagation(event);\n gesture(\"start\", event, touches[i]);\n }\n }\n }\n\n function touchmoved(event) {\n var touches = event.changedTouches,\n n = touches.length, i, gesture;\n\n for (i = 0; i < n; ++i) {\n if (gesture = gestures[touches[i].identifier]) {\n noevent(event);\n gesture(\"drag\", event, touches[i]);\n }\n }\n }\n\n function touchended(event) {\n var touches = event.changedTouches,\n n = touches.length, i, gesture;\n\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n for (i = 0; i < n; ++i) {\n if (gesture = gestures[touches[i].identifier]) {\n nopropagation(event);\n gesture(\"end\", event, touches[i]);\n }\n }\n }\n\n function beforestart(that, container, event, d, identifier, touch) {\n var dispatch = listeners.copy(),\n p = pointer(touch || event, container), dx, dy,\n s;\n\n if ((s = subject.call(that, new DragEvent(\"beforestart\", {\n sourceEvent: event,\n target: drag,\n identifier,\n active,\n x: p[0],\n y: p[1],\n dx: 0,\n dy: 0,\n dispatch\n }), d)) == null) return;\n\n dx = s.x - p[0] || 0;\n dy = s.y - p[1] || 0;\n\n return function gesture(type, event, touch) {\n var p0 = p, n;\n switch (type) {\n case \"start\": gestures[identifier] = gesture, n = active++; break;\n case \"end\": delete gestures[identifier], --active; // falls through\n case \"drag\": p = pointer(touch || event, container), n = active; break;\n }\n dispatch.call(\n type,\n that,\n new DragEvent(type, {\n sourceEvent: event,\n subject: s,\n target: drag,\n identifier,\n active: n,\n x: p[0] + dx,\n y: p[1] + dy,\n dx: p[0] - p0[0],\n dy: p[1] - p0[1],\n dispatch\n }),\n d\n );\n };\n }\n\n drag.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant(!!_), drag) : filter;\n };\n\n drag.container = function(_) {\n return arguments.length ? (container = typeof _ === \"function\" ? _ : constant(_), drag) : container;\n };\n\n drag.subject = function(_) {\n return arguments.length ? (subject = typeof _ === \"function\" ? _ : constant(_), drag) : subject;\n };\n\n drag.touchable = function(_) {\n return arguments.length ? (touchable = typeof _ === \"function\" ? _ : constant(!!_), drag) : touchable;\n };\n\n drag.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? drag : value;\n };\n\n drag.clickDistance = function(_) {\n return arguments.length ? (clickDistance2 = (_ = +_) * _, drag) : Math.sqrt(clickDistance2);\n };\n\n return drag;\n}\n", "export default function(constructor, factory, prototype) {\n constructor.prototype = factory.prototype = prototype;\n prototype.constructor = constructor;\n}\n\nexport function extend(parent, definition) {\n var prototype = Object.create(parent.prototype);\n for (var key in definition) prototype[key] = definition[key];\n return prototype;\n}\n", "import define, {extend} from \"./define.js\";\n\nexport function Color() {}\n\nexport var darker = 0.7;\nexport var brighter = 1 / darker;\n\nvar reI = \"\\\\s*([+-]?\\\\d+)\\\\s*\",\n reN = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)\\\\s*\",\n reP = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)%\\\\s*\",\n reHex = /^#([0-9a-f]{3,8})$/,\n reRgbInteger = new RegExp(`^rgb\\\\(${reI},${reI},${reI}\\\\)$`),\n reRgbPercent = new RegExp(`^rgb\\\\(${reP},${reP},${reP}\\\\)$`),\n reRgbaInteger = new RegExp(`^rgba\\\\(${reI},${reI},${reI},${reN}\\\\)$`),\n reRgbaPercent = new RegExp(`^rgba\\\\(${reP},${reP},${reP},${reN}\\\\)$`),\n reHslPercent = new RegExp(`^hsl\\\\(${reN},${reP},${reP}\\\\)$`),\n reHslaPercent = new RegExp(`^hsla\\\\(${reN},${reP},${reP},${reN}\\\\)$`);\n\nvar named = {\n aliceblue: 0xf0f8ff,\n antiquewhite: 0xfaebd7,\n aqua: 0x00ffff,\n aquamarine: 0x7fffd4,\n azure: 0xf0ffff,\n beige: 0xf5f5dc,\n bisque: 0xffe4c4,\n black: 0x000000,\n blanchedalmond: 0xffebcd,\n blue: 0x0000ff,\n blueviolet: 0x8a2be2,\n brown: 0xa52a2a,\n burlywood: 0xdeb887,\n cadetblue: 0x5f9ea0,\n chartreuse: 0x7fff00,\n chocolate: 0xd2691e,\n coral: 0xff7f50,\n cornflowerblue: 0x6495ed,\n cornsilk: 0xfff8dc,\n crimson: 0xdc143c,\n cyan: 0x00ffff,\n darkblue: 0x00008b,\n darkcyan: 0x008b8b,\n darkgoldenrod: 0xb8860b,\n darkgray: 0xa9a9a9,\n darkgreen: 0x006400,\n darkgrey: 0xa9a9a9,\n darkkhaki: 0xbdb76b,\n darkmagenta: 0x8b008b,\n darkolivegreen: 0x556b2f,\n darkorange: 0xff8c00,\n darkorchid: 0x9932cc,\n darkred: 0x8b0000,\n darksalmon: 0xe9967a,\n darkseagreen: 0x8fbc8f,\n darkslateblue: 0x483d8b,\n darkslategray: 0x2f4f4f,\n darkslategrey: 0x2f4f4f,\n darkturquoise: 0x00ced1,\n darkviolet: 0x9400d3,\n deeppink: 0xff1493,\n deepskyblue: 0x00bfff,\n dimgray: 0x696969,\n dimgrey: 0x696969,\n dodgerblue: 0x1e90ff,\n firebrick: 0xb22222,\n floralwhite: 0xfffaf0,\n forestgreen: 0x228b22,\n fuchsia: 0xff00ff,\n gainsboro: 0xdcdcdc,\n ghostwhite: 0xf8f8ff,\n gold: 0xffd700,\n goldenrod: 0xdaa520,\n gray: 0x808080,\n green: 0x008000,\n greenyellow: 0xadff2f,\n grey: 0x808080,\n honeydew: 0xf0fff0,\n hotpink: 0xff69b4,\n indianred: 0xcd5c5c,\n indigo: 0x4b0082,\n ivory: 0xfffff0,\n khaki: 0xf0e68c,\n lavender: 0xe6e6fa,\n lavenderblush: 0xfff0f5,\n lawngreen: 0x7cfc00,\n lemonchiffon: 0xfffacd,\n lightblue: 0xadd8e6,\n lightcoral: 0xf08080,\n lightcyan: 0xe0ffff,\n lightgoldenrodyellow: 0xfafad2,\n lightgray: 0xd3d3d3,\n lightgreen: 0x90ee90,\n lightgrey: 0xd3d3d3,\n lightpink: 0xffb6c1,\n lightsalmon: 0xffa07a,\n lightseagreen: 0x20b2aa,\n lightskyblue: 0x87cefa,\n lightslategray: 0x778899,\n lightslategrey: 0x778899,\n lightsteelblue: 0xb0c4de,\n lightyellow: 0xffffe0,\n lime: 0x00ff00,\n limegreen: 0x32cd32,\n linen: 0xfaf0e6,\n magenta: 0xff00ff,\n maroon: 0x800000,\n mediumaquamarine: 0x66cdaa,\n mediumblue: 0x0000cd,\n mediumorchid: 0xba55d3,\n mediumpurple: 0x9370db,\n mediumseagreen: 0x3cb371,\n mediumslateblue: 0x7b68ee,\n mediumspringgreen: 0x00fa9a,\n mediumturquoise: 0x48d1cc,\n mediumvioletred: 0xc71585,\n midnightblue: 0x191970,\n mintcream: 0xf5fffa,\n mistyrose: 0xffe4e1,\n moccasin: 0xffe4b5,\n navajowhite: 0xffdead,\n navy: 0x000080,\n oldlace: 0xfdf5e6,\n olive: 0x808000,\n olivedrab: 0x6b8e23,\n orange: 0xffa500,\n orangered: 0xff4500,\n orchid: 0xda70d6,\n palegoldenrod: 0xeee8aa,\n palegreen: 0x98fb98,\n paleturquoise: 0xafeeee,\n palevioletred: 0xdb7093,\n papayawhip: 0xffefd5,\n peachpuff: 0xffdab9,\n peru: 0xcd853f,\n pink: 0xffc0cb,\n plum: 0xdda0dd,\n powderblue: 0xb0e0e6,\n purple: 0x800080,\n rebeccapurple: 0x663399,\n red: 0xff0000,\n rosybrown: 0xbc8f8f,\n royalblue: 0x4169e1,\n saddlebrown: 0x8b4513,\n salmon: 0xfa8072,\n sandybrown: 0xf4a460,\n seagreen: 0x2e8b57,\n seashell: 0xfff5ee,\n sienna: 0xa0522d,\n silver: 0xc0c0c0,\n skyblue: 0x87ceeb,\n slateblue: 0x6a5acd,\n slategray: 0x708090,\n slategrey: 0x708090,\n snow: 0xfffafa,\n springgreen: 0x00ff7f,\n steelblue: 0x4682b4,\n tan: 0xd2b48c,\n teal: 0x008080,\n thistle: 0xd8bfd8,\n tomato: 0xff6347,\n turquoise: 0x40e0d0,\n violet: 0xee82ee,\n wheat: 0xf5deb3,\n white: 0xffffff,\n whitesmoke: 0xf5f5f5,\n yellow: 0xffff00,\n yellowgreen: 0x9acd32\n};\n\ndefine(Color, color, {\n copy(channels) {\n return Object.assign(new this.constructor, this, channels);\n },\n displayable() {\n return this.rgb().displayable();\n },\n hex: color_formatHex, // Deprecated! Use color.formatHex.\n formatHex: color_formatHex,\n formatHex8: color_formatHex8,\n formatHsl: color_formatHsl,\n formatRgb: color_formatRgb,\n toString: color_formatRgb\n});\n\nfunction color_formatHex() {\n return this.rgb().formatHex();\n}\n\nfunction color_formatHex8() {\n return this.rgb().formatHex8();\n}\n\nfunction color_formatHsl() {\n return hslConvert(this).formatHsl();\n}\n\nfunction color_formatRgb() {\n return this.rgb().formatRgb();\n}\n\nexport default function color(format) {\n var m, l;\n format = (format + \"\").trim().toLowerCase();\n return (m = reHex.exec(format)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) // #ff0000\n : l === 3 ? new Rgb((m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1) // #f00\n : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000\n : l === 4 ? rgba((m >> 12 & 0xf) | (m >> 8 & 0xf0), (m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), (((m & 0xf) << 4) | (m & 0xf)) / 0xff) // #f000\n : null) // invalid hex\n : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins\n : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n : null;\n}\n\nfunction rgbn(n) {\n return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n}\n\nfunction rgba(r, g, b, a) {\n if (a <= 0) r = g = b = NaN;\n return new Rgb(r, g, b, a);\n}\n\nexport function rgbConvert(o) {\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Rgb;\n o = o.rgb();\n return new Rgb(o.r, o.g, o.b, o.opacity);\n}\n\nexport function rgb(r, g, b, opacity) {\n return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n}\n\nexport function Rgb(r, g, b, opacity) {\n this.r = +r;\n this.g = +g;\n this.b = +b;\n this.opacity = +opacity;\n}\n\ndefine(Rgb, rgb, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n rgb() {\n return this;\n },\n clamp() {\n return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity));\n },\n displayable() {\n return (-0.5 <= this.r && this.r < 255.5)\n && (-0.5 <= this.g && this.g < 255.5)\n && (-0.5 <= this.b && this.b < 255.5)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n hex: rgb_formatHex, // Deprecated! Use color.formatHex.\n formatHex: rgb_formatHex,\n formatHex8: rgb_formatHex8,\n formatRgb: rgb_formatRgb,\n toString: rgb_formatRgb\n}));\n\nfunction rgb_formatHex() {\n return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`;\n}\n\nfunction rgb_formatHex8() {\n return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`;\n}\n\nfunction rgb_formatRgb() {\n const a = clampa(this.opacity);\n return `${a === 1 ? \"rgb(\" : \"rgba(\"}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? \")\" : `, ${a})`}`;\n}\n\nfunction clampa(opacity) {\n return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity));\n}\n\nfunction clampi(value) {\n return Math.max(0, Math.min(255, Math.round(value) || 0));\n}\n\nfunction hex(value) {\n value = clampi(value);\n return (value < 16 ? \"0\" : \"\") + value.toString(16);\n}\n\nfunction hsla(h, s, l, a) {\n if (a <= 0) h = s = l = NaN;\n else if (l <= 0 || l >= 1) h = s = NaN;\n else if (s <= 0) h = NaN;\n return new Hsl(h, s, l, a);\n}\n\nexport function hslConvert(o) {\n if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Hsl;\n if (o instanceof Hsl) return o;\n o = o.rgb();\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n min = Math.min(r, g, b),\n max = Math.max(r, g, b),\n h = NaN,\n s = max - min,\n l = (max + min) / 2;\n if (s) {\n if (r === max) h = (g - b) / s + (g < b) * 6;\n else if (g === max) h = (b - r) / s + 2;\n else h = (r - g) / s + 4;\n s /= l < 0.5 ? max + min : 2 - max - min;\n h *= 60;\n } else {\n s = l > 0 && l < 1 ? 0 : h;\n }\n return new Hsl(h, s, l, o.opacity);\n}\n\nexport function hsl(h, s, l, opacity) {\n return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hsl(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n}\n\ndefine(Hsl, hsl, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n rgb() {\n var h = this.h % 360 + (this.h < 0) * 360,\n s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n l = this.l,\n m2 = l + (l < 0.5 ? l : 1 - l) * s,\n m1 = 2 * l - m2;\n return new Rgb(\n hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n hsl2rgb(h, m1, m2),\n hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n this.opacity\n );\n },\n clamp() {\n return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity));\n },\n displayable() {\n return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n && (0 <= this.l && this.l <= 1)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n formatHsl() {\n const a = clampa(this.opacity);\n return `${a === 1 ? \"hsl(\" : \"hsla(\"}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? \")\" : `, ${a})`}`;\n }\n}));\n\nfunction clamph(value) {\n value = (value || 0) % 360;\n return value < 0 ? value + 360 : value;\n}\n\nfunction clampt(value) {\n return Math.max(0, Math.min(1, value || 0));\n}\n\n/* From FvD 13.37, CSS Color Module Level 3 */\nfunction hsl2rgb(h, m1, m2) {\n return (h < 60 ? m1 + (m2 - m1) * h / 60\n : h < 180 ? m2\n : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n : m1) * 255;\n}\n", "export function basis(t1, v0, v1, v2, v3) {\n var t2 = t1 * t1, t3 = t2 * t1;\n return ((1 - 3 * t1 + 3 * t2 - t3) * v0\n + (4 - 6 * t2 + 3 * t3) * v1\n + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2\n + t3 * v3) / 6;\n}\n\nexport default function(values) {\n var n = values.length - 1;\n return function(t) {\n var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),\n v1 = values[i],\n v2 = values[i + 1],\n v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,\n v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n", "import {basis} from \"./basis.js\";\n\nexport default function(values) {\n var n = values.length;\n return function(t) {\n var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),\n v0 = values[(i + n - 1) % n],\n v1 = values[i % n],\n v2 = values[(i + 1) % n],\n v3 = values[(i + 2) % n];\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n", "export default x => () => x;\n", "import constant from \"./constant.js\";\n\nfunction linear(a, d) {\n return function(t) {\n return a + t * d;\n };\n}\n\nfunction exponential(a, b, y) {\n return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n return Math.pow(a + t * b, y);\n };\n}\n\nexport function hue(a, b) {\n var d = b - a;\n return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant(isNaN(a) ? b : a);\n}\n\nexport function gamma(y) {\n return (y = +y) === 1 ? nogamma : function(a, b) {\n return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);\n };\n}\n\nexport default function nogamma(a, b) {\n var d = b - a;\n return d ? linear(a, d) : constant(isNaN(a) ? b : a);\n}\n", "import {rgb as colorRgb} from \"d3-color\";\nimport basis from \"./basis.js\";\nimport basisClosed from \"./basisClosed.js\";\nimport nogamma, {gamma} from \"./color.js\";\n\nexport default (function rgbGamma(y) {\n var color = gamma(y);\n\n function rgb(start, end) {\n var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n g = color(start.g, end.g),\n b = color(start.b, end.b),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.r = r(t);\n start.g = g(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n rgb.gamma = rgbGamma;\n\n return rgb;\n})(1);\n\nfunction rgbSpline(spline) {\n return function(colors) {\n var n = colors.length,\n r = new Array(n),\n g = new Array(n),\n b = new Array(n),\n i, color;\n for (i = 0; i < n; ++i) {\n color = colorRgb(colors[i]);\n r[i] = color.r || 0;\n g[i] = color.g || 0;\n b[i] = color.b || 0;\n }\n r = spline(r);\n g = spline(g);\n b = spline(b);\n color.opacity = 1;\n return function(t) {\n color.r = r(t);\n color.g = g(t);\n color.b = b(t);\n return color + \"\";\n };\n };\n}\n\nexport var rgbBasis = rgbSpline(basis);\nexport var rgbBasisClosed = rgbSpline(basisClosed);\n", "export default function(a, b) {\n if (!b) b = [];\n var n = a ? Math.min(b.length, a.length) : 0,\n c = b.slice(),\n i;\n return function(t) {\n for (i = 0; i < n; ++i) c[i] = a[i] * (1 - t) + b[i] * t;\n return c;\n };\n}\n\nexport function isNumberArray(x) {\n return ArrayBuffer.isView(x) && !(x instanceof DataView);\n}\n", "import value from \"./value.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n return (isNumberArray(b) ? numberArray : genericArray)(a, b);\n}\n\nexport function genericArray(a, b) {\n var nb = b ? b.length : 0,\n na = a ? Math.min(nb, a.length) : 0,\n x = new Array(na),\n c = new Array(nb),\n i;\n\n for (i = 0; i < na; ++i) x[i] = value(a[i], b[i]);\n for (; i < nb; ++i) c[i] = b[i];\n\n return function(t) {\n for (i = 0; i < na; ++i) c[i] = x[i](t);\n return c;\n };\n}\n", "export default function(a, b) {\n var d = new Date;\n return a = +a, b = +b, function(t) {\n return d.setTime(a * (1 - t) + b * t), d;\n };\n}\n", "export default function(a, b) {\n return a = +a, b = +b, function(t) {\n return a * (1 - t) + b * t;\n };\n}\n", "import value from \"./value.js\";\n\nexport default function(a, b) {\n var i = {},\n c = {},\n k;\n\n if (a === null || typeof a !== \"object\") a = {};\n if (b === null || typeof b !== \"object\") b = {};\n\n for (k in b) {\n if (k in a) {\n i[k] = value(a[k], b[k]);\n } else {\n c[k] = b[k];\n }\n }\n\n return function(t) {\n for (k in i) c[k] = i[k](t);\n return c;\n };\n}\n", "import number from \"./number.js\";\n\nvar reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,\n reB = new RegExp(reA.source, \"g\");\n\nfunction zero(b) {\n return function() {\n return b;\n };\n}\n\nfunction one(b) {\n return function(t) {\n return b(t) + \"\";\n };\n}\n\nexport default function(a, b) {\n var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n am, // current match in a\n bm, // current match in b\n bs, // string preceding current number in b, if any\n i = -1, // index in s\n s = [], // string constants and placeholders\n q = []; // number interpolators\n\n // Coerce inputs to strings.\n a = a + \"\", b = b + \"\";\n\n // Interpolate pairs of numbers in a & b.\n while ((am = reA.exec(a))\n && (bm = reB.exec(b))) {\n if ((bs = bm.index) > bi) { // a string precedes the next number in b\n bs = b.slice(bi, bs);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n if (s[i]) s[i] += bm; // coalesce with previous string\n else s[++i] = bm;\n } else { // interpolate non-matching numbers\n s[++i] = null;\n q.push({i: i, x: number(am, bm)});\n }\n bi = reB.lastIndex;\n }\n\n // Add remains of b.\n if (bi < b.length) {\n bs = b.slice(bi);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n\n // Special optimization for only a single match.\n // Otherwise, interpolate each of the numbers and rejoin the string.\n return s.length < 2 ? (q[0]\n ? one(q[0].x)\n : zero(b))\n : (b = q.length, function(t) {\n for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n });\n}\n", "import {color} from \"d3-color\";\nimport rgb from \"./rgb.js\";\nimport {genericArray} from \"./array.js\";\nimport date from \"./date.js\";\nimport number from \"./number.js\";\nimport object from \"./object.js\";\nimport string from \"./string.js\";\nimport constant from \"./constant.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n var t = typeof b, c;\n return b == null || t === \"boolean\" ? constant(b)\n : (t === \"number\" ? number\n : t === \"string\" ? ((c = color(b)) ? (b = c, rgb) : string)\n : b instanceof color ? rgb\n : b instanceof Date ? date\n : isNumberArray(b) ? numberArray\n : Array.isArray(b) ? genericArray\n : typeof b.valueOf !== \"function\" && typeof b.toString !== \"function\" || isNaN(b) ? object\n : number)(a, b);\n}\n", "var degrees = 180 / Math.PI;\n\nexport var identity = {\n translateX: 0,\n translateY: 0,\n rotate: 0,\n skewX: 0,\n scaleX: 1,\n scaleY: 1\n};\n\nexport default function(a, b, c, d, e, f) {\n var scaleX, scaleY, skewX;\n if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;\n if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;\n if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;\n if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;\n return {\n translateX: e,\n translateY: f,\n rotate: Math.atan2(b, a) * degrees,\n skewX: Math.atan(skewX) * degrees,\n scaleX: scaleX,\n scaleY: scaleY\n };\n}\n", "import decompose, {identity} from \"./decompose.js\";\n\nvar svgNode;\n\n/* eslint-disable no-undef */\nexport function parseCss(value) {\n const m = new (typeof DOMMatrix === \"function\" ? DOMMatrix : WebKitCSSMatrix)(value + \"\");\n return m.isIdentity ? identity : decompose(m.a, m.b, m.c, m.d, m.e, m.f);\n}\n\nexport function parseSvg(value) {\n if (value == null) return identity;\n if (!svgNode) svgNode = document.createElementNS(\"http://www.w3.org/2000/svg\", \"g\");\n svgNode.setAttribute(\"transform\", value);\n if (!(value = svgNode.transform.baseVal.consolidate())) return identity;\n value = value.matrix;\n return decompose(value.a, value.b, value.c, value.d, value.e, value.f);\n}\n", "import number from \"../number.js\";\nimport {parseCss, parseSvg} from \"./parse.js\";\n\nfunction interpolateTransform(parse, pxComma, pxParen, degParen) {\n\n function pop(s) {\n return s.length ? s.pop() + \" \" : \"\";\n }\n\n function translate(xa, ya, xb, yb, s, q) {\n if (xa !== xb || ya !== yb) {\n var i = s.push(\"translate(\", null, pxComma, null, pxParen);\n q.push({i: i - 4, x: number(xa, xb)}, {i: i - 2, x: number(ya, yb)});\n } else if (xb || yb) {\n s.push(\"translate(\" + xb + pxComma + yb + pxParen);\n }\n }\n\n function rotate(a, b, s, q) {\n if (a !== b) {\n if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path\n q.push({i: s.push(pop(s) + \"rotate(\", null, degParen) - 2, x: number(a, b)});\n } else if (b) {\n s.push(pop(s) + \"rotate(\" + b + degParen);\n }\n }\n\n function skewX(a, b, s, q) {\n if (a !== b) {\n q.push({i: s.push(pop(s) + \"skewX(\", null, degParen) - 2, x: number(a, b)});\n } else if (b) {\n s.push(pop(s) + \"skewX(\" + b + degParen);\n }\n }\n\n function scale(xa, ya, xb, yb, s, q) {\n if (xa !== xb || ya !== yb) {\n var i = s.push(pop(s) + \"scale(\", null, \",\", null, \")\");\n q.push({i: i - 4, x: number(xa, xb)}, {i: i - 2, x: number(ya, yb)});\n } else if (xb !== 1 || yb !== 1) {\n s.push(pop(s) + \"scale(\" + xb + \",\" + yb + \")\");\n }\n }\n\n return function(a, b) {\n var s = [], // string constants and placeholders\n q = []; // number interpolators\n a = parse(a), b = parse(b);\n translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);\n rotate(a.rotate, b.rotate, s, q);\n skewX(a.skewX, b.skewX, s, q);\n scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);\n a = b = null; // gc\n return function(t) {\n var i = -1, n = q.length, o;\n while (++i < n) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n };\n };\n}\n\nexport var interpolateTransformCss = interpolateTransform(parseCss, \"px, \", \"px)\", \"deg)\");\nexport var interpolateTransformSvg = interpolateTransform(parseSvg, \", \", \")\", \")\");\n", "var epsilon2 = 1e-12;\n\nfunction cosh(x) {\n return ((x = Math.exp(x)) + 1 / x) / 2;\n}\n\nfunction sinh(x) {\n return ((x = Math.exp(x)) - 1 / x) / 2;\n}\n\nfunction tanh(x) {\n return ((x = Math.exp(2 * x)) - 1) / (x + 1);\n}\n\nexport default (function zoomRho(rho, rho2, rho4) {\n\n // p0 = [ux0, uy0, w0]\n // p1 = [ux1, uy1, w1]\n function zoom(p0, p1) {\n var ux0 = p0[0], uy0 = p0[1], w0 = p0[2],\n ux1 = p1[0], uy1 = p1[1], w1 = p1[2],\n dx = ux1 - ux0,\n dy = uy1 - uy0,\n d2 = dx * dx + dy * dy,\n i,\n S;\n\n // Special case for u0 \u2245 u1.\n if (d2 < epsilon2) {\n S = Math.log(w1 / w0) / rho;\n i = function(t) {\n return [\n ux0 + t * dx,\n uy0 + t * dy,\n w0 * Math.exp(rho * t * S)\n ];\n }\n }\n\n // General case.\n else {\n var d1 = Math.sqrt(d2),\n b0 = (w1 * w1 - w0 * w0 + rho4 * d2) / (2 * w0 * rho2 * d1),\n b1 = (w1 * w1 - w0 * w0 - rho4 * d2) / (2 * w1 * rho2 * d1),\n r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0),\n r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);\n S = (r1 - r0) / rho;\n i = function(t) {\n var s = t * S,\n coshr0 = cosh(r0),\n u = w0 / (rho2 * d1) * (coshr0 * tanh(rho * s + r0) - sinh(r0));\n return [\n ux0 + u * dx,\n uy0 + u * dy,\n w0 * coshr0 / cosh(rho * s + r0)\n ];\n }\n }\n\n i.duration = S * 1000 * rho / Math.SQRT2;\n\n return i;\n }\n\n zoom.rho = function(_) {\n var _1 = Math.max(1e-3, +_), _2 = _1 * _1, _4 = _2 * _2;\n return zoomRho(_1, _2, _4);\n };\n\n return zoom;\n})(Math.SQRT2, 2, 4);\n", "var frame = 0, // is an animation frame pending?\n timeout = 0, // is a timeout pending?\n interval = 0, // are any timers active?\n pokeDelay = 1000, // how frequently we check for clock skew\n taskHead,\n taskTail,\n clockLast = 0,\n clockNow = 0,\n clockSkew = 0,\n clock = typeof performance === \"object\" && performance.now ? performance : Date,\n setFrame = typeof window === \"object\" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };\n\nexport function now() {\n return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n clockNow = 0;\n}\n\nexport function Timer() {\n this._call =\n this._time =\n this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n constructor: Timer,\n restart: function(callback, delay, time) {\n if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n if (!this._next && taskTail !== this) {\n if (taskTail) taskTail._next = this;\n else taskHead = this;\n taskTail = this;\n }\n this._call = callback;\n this._time = time;\n sleep();\n },\n stop: function() {\n if (this._call) {\n this._call = null;\n this._time = Infinity;\n sleep();\n }\n }\n};\n\nexport function timer(callback, delay, time) {\n var t = new Timer;\n t.restart(callback, delay, time);\n return t;\n}\n\nexport function timerFlush() {\n now(); // Get the current time, if not already set.\n ++frame; // Pretend we\u2019ve set an alarm, if we haven\u2019t already.\n var t = taskHead, e;\n while (t) {\n if ((e = clockNow - t._time) >= 0) t._call.call(undefined, e);\n t = t._next;\n }\n --frame;\n}\n\nfunction wake() {\n clockNow = (clockLast = clock.now()) + clockSkew;\n frame = timeout = 0;\n try {\n timerFlush();\n } finally {\n frame = 0;\n nap();\n clockNow = 0;\n }\n}\n\nfunction poke() {\n var now = clock.now(), delay = now - clockLast;\n if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n var t0, t1 = taskHead, t2, time = Infinity;\n while (t1) {\n if (t1._call) {\n if (time > t1._time) time = t1._time;\n t0 = t1, t1 = t1._next;\n } else {\n t2 = t1._next, t1._next = null;\n t1 = t0 ? t0._next = t2 : taskHead = t2;\n }\n }\n taskTail = t0;\n sleep(time);\n}\n\nfunction sleep(time) {\n if (frame) return; // Soonest alarm already set, or will be.\n if (timeout) timeout = clearTimeout(timeout);\n var delay = time - clockNow; // Strictly less than if we recomputed clockNow.\n if (delay > 24) {\n if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);\n if (interval) interval = clearInterval(interval);\n } else {\n if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);\n frame = 1, setFrame(wake);\n }\n}\n", "import {Timer} from \"./timer.js\";\n\nexport default function(callback, delay, time) {\n var t = new Timer;\n delay = delay == null ? 0 : +delay;\n t.restart(elapsed => {\n t.stop();\n callback(elapsed + delay);\n }, delay, time);\n return t;\n}\n", "import {dispatch} from \"d3-dispatch\";\nimport {timer, timeout} from \"d3-timer\";\n\nvar emptyOn = dispatch(\"start\", \"end\", \"cancel\", \"interrupt\");\nvar emptyTween = [];\n\nexport var CREATED = 0;\nexport var SCHEDULED = 1;\nexport var STARTING = 2;\nexport var STARTED = 3;\nexport var RUNNING = 4;\nexport var ENDING = 5;\nexport var ENDED = 6;\n\nexport default function(node, name, id, index, group, timing) {\n var schedules = node.__transition;\n if (!schedules) node.__transition = {};\n else if (id in schedules) return;\n create(node, id, {\n name: name,\n index: index, // For context during callback.\n group: group, // For context during callback.\n on: emptyOn,\n tween: emptyTween,\n time: timing.time,\n delay: timing.delay,\n duration: timing.duration,\n ease: timing.ease,\n timer: null,\n state: CREATED\n });\n}\n\nexport function init(node, id) {\n var schedule = get(node, id);\n if (schedule.state > CREATED) throw new Error(\"too late; already scheduled\");\n return schedule;\n}\n\nexport function set(node, id) {\n var schedule = get(node, id);\n if (schedule.state > STARTED) throw new Error(\"too late; already running\");\n return schedule;\n}\n\nexport function get(node, id) {\n var schedule = node.__transition;\n if (!schedule || !(schedule = schedule[id])) throw new Error(\"transition not found\");\n return schedule;\n}\n\nfunction create(node, id, self) {\n var schedules = node.__transition,\n tween;\n\n // Initialize the self timer when the transition is created.\n // Note the actual delay is not known until the first callback!\n schedules[id] = self;\n self.timer = timer(schedule, 0, self.time);\n\n function schedule(elapsed) {\n self.state = SCHEDULED;\n self.timer.restart(start, self.delay, self.time);\n\n // If the elapsed delay is less than our first sleep, start immediately.\n if (self.delay <= elapsed) start(elapsed - self.delay);\n }\n\n function start(elapsed) {\n var i, j, n, o;\n\n // If the state is not SCHEDULED, then we previously errored on start.\n if (self.state !== SCHEDULED) return stop();\n\n for (i in schedules) {\n o = schedules[i];\n if (o.name !== self.name) continue;\n\n // While this element already has a starting transition during this frame,\n // defer starting an interrupting transition until that transition has a\n // chance to tick (and possibly end); see d3/d3-transition#54!\n if (o.state === STARTED) return timeout(start);\n\n // Interrupt the active transition, if any.\n if (o.state === RUNNING) {\n o.state = ENDED;\n o.timer.stop();\n o.on.call(\"interrupt\", node, node.__data__, o.index, o.group);\n delete schedules[i];\n }\n\n // Cancel any pre-empted transitions.\n else if (+i < id) {\n o.state = ENDED;\n o.timer.stop();\n o.on.call(\"cancel\", node, node.__data__, o.index, o.group);\n delete schedules[i];\n }\n }\n\n // Defer the first tick to end of the current frame; see d3/d3#1576.\n // Note the transition may be canceled after start and before the first tick!\n // Note this must be scheduled before the start event; see d3/d3-transition#16!\n // Assuming this is successful, subsequent callbacks go straight to tick.\n timeout(function() {\n if (self.state === STARTED) {\n self.state = RUNNING;\n self.timer.restart(tick, self.delay, self.time);\n tick(elapsed);\n }\n });\n\n // Dispatch the start event.\n // Note this must be done before the tween are initialized.\n self.state = STARTING;\n self.on.call(\"start\", node, node.__data__, self.index, self.group);\n if (self.state !== STARTING) return; // interrupted\n self.state = STARTED;\n\n // Initialize the tween, deleting null tween.\n tween = new Array(n = self.tween.length);\n for (i = 0, j = -1; i < n; ++i) {\n if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {\n tween[++j] = o;\n }\n }\n tween.length = j + 1;\n }\n\n function tick(elapsed) {\n var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),\n i = -1,\n n = tween.length;\n\n while (++i < n) {\n tween[i].call(node, t);\n }\n\n // Dispatch the end event.\n if (self.state === ENDING) {\n self.on.call(\"end\", node, node.__data__, self.index, self.group);\n stop();\n }\n }\n\n function stop() {\n self.state = ENDED;\n self.timer.stop();\n delete schedules[id];\n for (var i in schedules) return; // eslint-disable-line no-unused-vars\n delete node.__transition;\n }\n}\n", "import {STARTING, ENDING, ENDED} from \"./transition/schedule.js\";\n\nexport default function(node, name) {\n var schedules = node.__transition,\n schedule,\n active,\n empty = true,\n i;\n\n if (!schedules) return;\n\n name = name == null ? null : name + \"\";\n\n for (i in schedules) {\n if ((schedule = schedules[i]).name !== name) { empty = false; continue; }\n active = schedule.state > STARTING && schedule.state < ENDING;\n schedule.state = ENDED;\n schedule.timer.stop();\n schedule.on.call(active ? \"interrupt\" : \"cancel\", node, node.__data__, schedule.index, schedule.group);\n delete schedules[i];\n }\n\n if (empty) delete node.__transition;\n}\n", "import interrupt from \"../interrupt.js\";\n\nexport default function(name) {\n return this.each(function() {\n interrupt(this, name);\n });\n}\n", "import {get, set} from \"./schedule.js\";\n\nfunction tweenRemove(id, name) {\n var tween0, tween1;\n return function() {\n var schedule = set(this, id),\n tween = schedule.tween;\n\n // If this node shared tween with the previous node,\n // just assign the updated shared tween and we\u2019re done!\n // Otherwise, copy-on-write.\n if (tween !== tween0) {\n tween1 = tween0 = tween;\n for (var i = 0, n = tween1.length; i < n; ++i) {\n if (tween1[i].name === name) {\n tween1 = tween1.slice();\n tween1.splice(i, 1);\n break;\n }\n }\n }\n\n schedule.tween = tween1;\n };\n}\n\nfunction tweenFunction(id, name, value) {\n var tween0, tween1;\n if (typeof value !== \"function\") throw new Error;\n return function() {\n var schedule = set(this, id),\n tween = schedule.tween;\n\n // If this node shared tween with the previous node,\n // just assign the updated shared tween and we\u2019re done!\n // Otherwise, copy-on-write.\n if (tween !== tween0) {\n tween1 = (tween0 = tween).slice();\n for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {\n if (tween1[i].name === name) {\n tween1[i] = t;\n break;\n }\n }\n if (i === n) tween1.push(t);\n }\n\n schedule.tween = tween1;\n };\n}\n\nexport default function(name, value) {\n var id = this._id;\n\n name += \"\";\n\n if (arguments.length < 2) {\n var tween = get(this.node(), id).tween;\n for (var i = 0, n = tween.length, t; i < n; ++i) {\n if ((t = tween[i]).name === name) {\n return t.value;\n }\n }\n return null;\n }\n\n return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));\n}\n\nexport function tweenValue(transition, name, value) {\n var id = transition._id;\n\n transition.each(function() {\n var schedule = set(this, id);\n (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);\n });\n\n return function(node) {\n return get(node, id).value[name];\n };\n}\n", "import {color} from \"d3-color\";\nimport {interpolateNumber, interpolateRgb, interpolateString} from \"d3-interpolate\";\n\nexport default function(a, b) {\n var c;\n return (typeof b === \"number\" ? interpolateNumber\n : b instanceof color ? interpolateRgb\n : (c = color(b)) ? (b = c, interpolateRgb)\n : interpolateString)(a, b);\n}\n", "import {interpolateTransformSvg as interpolateTransform} from \"d3-interpolate\";\nimport {namespace} from \"d3-selection\";\nimport {tweenValue} from \"./tween.js\";\nimport interpolate from \"./interpolate.js\";\n\nfunction attrRemove(name) {\n return function() {\n this.removeAttribute(name);\n };\n}\n\nfunction attrRemoveNS(fullname) {\n return function() {\n this.removeAttributeNS(fullname.space, fullname.local);\n };\n}\n\nfunction attrConstant(name, interpolate, value1) {\n var string00,\n string1 = value1 + \"\",\n interpolate0;\n return function() {\n var string0 = this.getAttribute(name);\n return string0 === string1 ? null\n : string0 === string00 ? interpolate0\n : interpolate0 = interpolate(string00 = string0, value1);\n };\n}\n\nfunction attrConstantNS(fullname, interpolate, value1) {\n var string00,\n string1 = value1 + \"\",\n interpolate0;\n return function() {\n var string0 = this.getAttributeNS(fullname.space, fullname.local);\n return string0 === string1 ? null\n : string0 === string00 ? interpolate0\n : interpolate0 = interpolate(string00 = string0, value1);\n };\n}\n\nfunction attrFunction(name, interpolate, value) {\n var string00,\n string10,\n interpolate0;\n return function() {\n var string0, value1 = value(this), string1;\n if (value1 == null) return void this.removeAttribute(name);\n string0 = this.getAttribute(name);\n string1 = value1 + \"\";\n return string0 === string1 ? null\n : string0 === string00 && string1 === string10 ? interpolate0\n : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n };\n}\n\nfunction attrFunctionNS(fullname, interpolate, value) {\n var string00,\n string10,\n interpolate0;\n return function() {\n var string0, value1 = value(this), string1;\n if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);\n string0 = this.getAttributeNS(fullname.space, fullname.local);\n string1 = value1 + \"\";\n return string0 === string1 ? null\n : string0 === string00 && string1 === string10 ? interpolate0\n : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n };\n}\n\nexport default function(name, value) {\n var fullname = namespace(name), i = fullname === \"transform\" ? interpolateTransform : interpolate;\n return this.attrTween(name, typeof value === \"function\"\n ? (fullname.local ? attrFunctionNS : attrFunction)(fullname, i, tweenValue(this, \"attr.\" + name, value))\n : value == null ? (fullname.local ? attrRemoveNS : attrRemove)(fullname)\n : (fullname.local ? attrConstantNS : attrConstant)(fullname, i, value));\n}\n", "import {namespace} from \"d3-selection\";\n\nfunction attrInterpolate(name, i) {\n return function(t) {\n this.setAttribute(name, i.call(this, t));\n };\n}\n\nfunction attrInterpolateNS(fullname, i) {\n return function(t) {\n this.setAttributeNS(fullname.space, fullname.local, i.call(this, t));\n };\n}\n\nfunction attrTweenNS(fullname, value) {\n var t0, i0;\n function tween() {\n var i = value.apply(this, arguments);\n if (i !== i0) t0 = (i0 = i) && attrInterpolateNS(fullname, i);\n return t0;\n }\n tween._value = value;\n return tween;\n}\n\nfunction attrTween(name, value) {\n var t0, i0;\n function tween() {\n var i = value.apply(this, arguments);\n if (i !== i0) t0 = (i0 = i) && attrInterpolate(name, i);\n return t0;\n }\n tween._value = value;\n return tween;\n}\n\nexport default function(name, value) {\n var key = \"attr.\" + name;\n if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n var fullname = namespace(name);\n return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));\n}\n", "import {get, init} from \"./schedule.js\";\n\nfunction delayFunction(id, value) {\n return function() {\n init(this, id).delay = +value.apply(this, arguments);\n };\n}\n\nfunction delayConstant(id, value) {\n return value = +value, function() {\n init(this, id).delay = value;\n };\n}\n\nexport default function(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each((typeof value === \"function\"\n ? delayFunction\n : delayConstant)(id, value))\n : get(this.node(), id).delay;\n}\n", "import {get, set} from \"./schedule.js\";\n\nfunction durationFunction(id, value) {\n return function() {\n set(this, id).duration = +value.apply(this, arguments);\n };\n}\n\nfunction durationConstant(id, value) {\n return value = +value, function() {\n set(this, id).duration = value;\n };\n}\n\nexport default function(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each((typeof value === \"function\"\n ? durationFunction\n : durationConstant)(id, value))\n : get(this.node(), id).duration;\n}\n", "import {get, set} from \"./schedule.js\";\n\nfunction easeConstant(id, value) {\n if (typeof value !== \"function\") throw new Error;\n return function() {\n set(this, id).ease = value;\n };\n}\n\nexport default function(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each(easeConstant(id, value))\n : get(this.node(), id).ease;\n}\n", "import {set} from \"./schedule.js\";\n\nfunction easeVarying(id, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (typeof v !== \"function\") throw new Error;\n set(this, id).ease = v;\n };\n}\n\nexport default function(value) {\n if (typeof value !== \"function\") throw new Error;\n return this.each(easeVarying(this._id, value));\n}\n", "import {matcher} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\n\nexport default function(match) {\n if (typeof match !== \"function\") match = matcher(match);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n subgroup.push(node);\n }\n }\n }\n\n return new Transition(subgroups, this._parents, this._name, this._id);\n}\n", "import {Transition} from \"./index.js\";\n\nexport default function(transition) {\n if (transition._id !== this._id) throw new Error;\n\n for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group0[i] || group1[i]) {\n merge[i] = node;\n }\n }\n }\n\n for (; j < m0; ++j) {\n merges[j] = groups0[j];\n }\n\n return new Transition(merges, this._parents, this._name, this._id);\n}\n", "import {get, set, init} from \"./schedule.js\";\n\nfunction start(name) {\n return (name + \"\").trim().split(/^|\\s+/).every(function(t) {\n var i = t.indexOf(\".\");\n if (i >= 0) t = t.slice(0, i);\n return !t || t === \"start\";\n });\n}\n\nfunction onFunction(id, name, listener) {\n var on0, on1, sit = start(name) ? init : set;\n return function() {\n var schedule = sit(this, id),\n on = schedule.on;\n\n // If this node shared a dispatch with the previous node,\n // just assign the updated shared dispatch and we\u2019re done!\n // Otherwise, copy-on-write.\n if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);\n\n schedule.on = on1;\n };\n}\n\nexport default function(name, listener) {\n var id = this._id;\n\n return arguments.length < 2\n ? get(this.node(), id).on.on(name)\n : this.each(onFunction(id, name, listener));\n}\n", "function removeFunction(id) {\n return function() {\n var parent = this.parentNode;\n for (var i in this.__transition) if (+i !== id) return;\n if (parent) parent.removeChild(this);\n };\n}\n\nexport default function() {\n return this.on(\"end.remove\", removeFunction(this._id));\n}\n", "import {selector} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function(select) {\n var name = this._name,\n id = this._id;\n\n if (typeof select !== \"function\") select = selector(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n subgroup[i] = subnode;\n schedule(subgroup[i], name, id, i, subgroup, get(node, id));\n }\n }\n }\n\n return new Transition(subgroups, this._parents, name, id);\n}\n", "import {selectorAll} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function(select) {\n var name = this._name,\n id = this._id;\n\n if (typeof select !== \"function\") select = selectorAll(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n for (var children = select.call(node, node.__data__, i, group), child, inherit = get(node, id), k = 0, l = children.length; k < l; ++k) {\n if (child = children[k]) {\n schedule(child, name, id, k, children, inherit);\n }\n }\n subgroups.push(children);\n parents.push(node);\n }\n }\n }\n\n return new Transition(subgroups, parents, name, id);\n}\n", "import {selection} from \"d3-selection\";\n\nvar Selection = selection.prototype.constructor;\n\nexport default function() {\n return new Selection(this._groups, this._parents);\n}\n", "import {interpolateTransformCss as interpolateTransform} from \"d3-interpolate\";\nimport {style} from \"d3-selection\";\nimport {set} from \"./schedule.js\";\nimport {tweenValue} from \"./tween.js\";\nimport interpolate from \"./interpolate.js\";\n\nfunction styleNull(name, interpolate) {\n var string00,\n string10,\n interpolate0;\n return function() {\n var string0 = style(this, name),\n string1 = (this.style.removeProperty(name), style(this, name));\n return string0 === string1 ? null\n : string0 === string00 && string1 === string10 ? interpolate0\n : interpolate0 = interpolate(string00 = string0, string10 = string1);\n };\n}\n\nfunction styleRemove(name) {\n return function() {\n this.style.removeProperty(name);\n };\n}\n\nfunction styleConstant(name, interpolate, value1) {\n var string00,\n string1 = value1 + \"\",\n interpolate0;\n return function() {\n var string0 = style(this, name);\n return string0 === string1 ? null\n : string0 === string00 ? interpolate0\n : interpolate0 = interpolate(string00 = string0, value1);\n };\n}\n\nfunction styleFunction(name, interpolate, value) {\n var string00,\n string10,\n interpolate0;\n return function() {\n var string0 = style(this, name),\n value1 = value(this),\n string1 = value1 + \"\";\n if (value1 == null) string1 = value1 = (this.style.removeProperty(name), style(this, name));\n return string0 === string1 ? null\n : string0 === string00 && string1 === string10 ? interpolate0\n : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n };\n}\n\nfunction styleMaybeRemove(id, name) {\n var on0, on1, listener0, key = \"style.\" + name, event = \"end.\" + key, remove;\n return function() {\n var schedule = set(this, id),\n on = schedule.on,\n listener = schedule.value[key] == null ? remove || (remove = styleRemove(name)) : undefined;\n\n // If this node shared a dispatch with the previous node,\n // just assign the updated shared dispatch and we\u2019re done!\n // Otherwise, copy-on-write.\n if (on !== on0 || listener0 !== listener) (on1 = (on0 = on).copy()).on(event, listener0 = listener);\n\n schedule.on = on1;\n };\n}\n\nexport default function(name, value, priority) {\n var i = (name += \"\") === \"transform\" ? interpolateTransform : interpolate;\n return value == null ? this\n .styleTween(name, styleNull(name, i))\n .on(\"end.style.\" + name, styleRemove(name))\n : typeof value === \"function\" ? this\n .styleTween(name, styleFunction(name, i, tweenValue(this, \"style.\" + name, value)))\n .each(styleMaybeRemove(this._id, name))\n : this\n .styleTween(name, styleConstant(name, i, value), priority)\n .on(\"end.style.\" + name, null);\n}\n", "function styleInterpolate(name, i, priority) {\n return function(t) {\n this.style.setProperty(name, i.call(this, t), priority);\n };\n}\n\nfunction styleTween(name, value, priority) {\n var t, i0;\n function tween() {\n var i = value.apply(this, arguments);\n if (i !== i0) t = (i0 = i) && styleInterpolate(name, i, priority);\n return t;\n }\n tween._value = value;\n return tween;\n}\n\nexport default function(name, value, priority) {\n var key = \"style.\" + (name += \"\");\n if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n return this.tween(key, styleTween(name, value, priority == null ? \"\" : priority));\n}\n", "import {tweenValue} from \"./tween.js\";\n\nfunction textConstant(value) {\n return function() {\n this.textContent = value;\n };\n}\n\nfunction textFunction(value) {\n return function() {\n var value1 = value(this);\n this.textContent = value1 == null ? \"\" : value1;\n };\n}\n\nexport default function(value) {\n return this.tween(\"text\", typeof value === \"function\"\n ? textFunction(tweenValue(this, \"text\", value))\n : textConstant(value == null ? \"\" : value + \"\"));\n}\n", "function textInterpolate(i) {\n return function(t) {\n this.textContent = i.call(this, t);\n };\n}\n\nfunction textTween(value) {\n var t0, i0;\n function tween() {\n var i = value.apply(this, arguments);\n if (i !== i0) t0 = (i0 = i) && textInterpolate(i);\n return t0;\n }\n tween._value = value;\n return tween;\n}\n\nexport default function(value) {\n var key = \"text\";\n if (arguments.length < 1) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n return this.tween(key, textTween(value));\n}\n", "import {Transition, newId} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function() {\n var name = this._name,\n id0 = this._id,\n id1 = newId();\n\n for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n var inherit = get(node, id0);\n schedule(node, name, id1, i, group, {\n time: inherit.time + inherit.delay + inherit.duration,\n delay: 0,\n duration: inherit.duration,\n ease: inherit.ease\n });\n }\n }\n }\n\n return new Transition(groups, this._parents, name, id1);\n}\n", "import {set} from \"./schedule.js\";\n\nexport default function() {\n var on0, on1, that = this, id = that._id, size = that.size();\n return new Promise(function(resolve, reject) {\n var cancel = {value: reject},\n end = {value: function() { if (--size === 0) resolve(); }};\n\n that.each(function() {\n var schedule = set(this, id),\n on = schedule.on;\n\n // If this node shared a dispatch with the previous node,\n // just assign the updated shared dispatch and we\u2019re done!\n // Otherwise, copy-on-write.\n if (on !== on0) {\n on1 = (on0 = on).copy();\n on1._.cancel.push(cancel);\n on1._.interrupt.push(cancel);\n on1._.end.push(end);\n }\n\n schedule.on = on1;\n });\n\n // The selection was empty, resolve end immediately\n if (size === 0) resolve();\n });\n}\n", "import {selection} from \"d3-selection\";\nimport transition_attr from \"./attr.js\";\nimport transition_attrTween from \"./attrTween.js\";\nimport transition_delay from \"./delay.js\";\nimport transition_duration from \"./duration.js\";\nimport transition_ease from \"./ease.js\";\nimport transition_easeVarying from \"./easeVarying.js\";\nimport transition_filter from \"./filter.js\";\nimport transition_merge from \"./merge.js\";\nimport transition_on from \"./on.js\";\nimport transition_remove from \"./remove.js\";\nimport transition_select from \"./select.js\";\nimport transition_selectAll from \"./selectAll.js\";\nimport transition_selection from \"./selection.js\";\nimport transition_style from \"./style.js\";\nimport transition_styleTween from \"./styleTween.js\";\nimport transition_text from \"./text.js\";\nimport transition_textTween from \"./textTween.js\";\nimport transition_transition from \"./transition.js\";\nimport transition_tween from \"./tween.js\";\nimport transition_end from \"./end.js\";\n\nvar id = 0;\n\nexport function Transition(groups, parents, name, id) {\n this._groups = groups;\n this._parents = parents;\n this._name = name;\n this._id = id;\n}\n\nexport default function transition(name) {\n return selection().transition(name);\n}\n\nexport function newId() {\n return ++id;\n}\n\nvar selection_prototype = selection.prototype;\n\nTransition.prototype = transition.prototype = {\n constructor: Transition,\n select: transition_select,\n selectAll: transition_selectAll,\n selectChild: selection_prototype.selectChild,\n selectChildren: selection_prototype.selectChildren,\n filter: transition_filter,\n merge: transition_merge,\n selection: transition_selection,\n transition: transition_transition,\n call: selection_prototype.call,\n nodes: selection_prototype.nodes,\n node: selection_prototype.node,\n size: selection_prototype.size,\n empty: selection_prototype.empty,\n each: selection_prototype.each,\n on: transition_on,\n attr: transition_attr,\n attrTween: transition_attrTween,\n style: transition_style,\n styleTween: transition_styleTween,\n text: transition_text,\n textTween: transition_textTween,\n remove: transition_remove,\n tween: transition_tween,\n delay: transition_delay,\n duration: transition_duration,\n ease: transition_ease,\n easeVarying: transition_easeVarying,\n end: transition_end,\n [Symbol.iterator]: selection_prototype[Symbol.iterator]\n};\n", "export function cubicIn(t) {\n return t * t * t;\n}\n\nexport function cubicOut(t) {\n return --t * t * t + 1;\n}\n\nexport function cubicInOut(t) {\n return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\n}\n", "import {Transition, newId} from \"../transition/index.js\";\nimport schedule from \"../transition/schedule.js\";\nimport {easeCubicInOut} from \"d3-ease\";\nimport {now} from \"d3-timer\";\n\nvar defaultTiming = {\n time: null, // Set on use.\n delay: 0,\n duration: 250,\n ease: easeCubicInOut\n};\n\nfunction inherit(node, id) {\n var timing;\n while (!(timing = node.__transition) || !(timing = timing[id])) {\n if (!(node = node.parentNode)) {\n throw new Error(`transition ${id} not found`);\n }\n }\n return timing;\n}\n\nexport default function(name) {\n var id,\n timing;\n\n if (name instanceof Transition) {\n id = name._id, name = name._name;\n } else {\n id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + \"\";\n }\n\n for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n schedule(node, name, id, i, group, timing || inherit(node, id));\n }\n }\n }\n\n return new Transition(groups, this._parents, name, id);\n}\n", "import {selection} from \"d3-selection\";\nimport selection_interrupt from \"./interrupt.js\";\nimport selection_transition from \"./transition.js\";\n\nselection.prototype.interrupt = selection_interrupt;\nselection.prototype.transition = selection_transition;\n", "export default x => () => x;\n", "export default function ZoomEvent(type, {\n sourceEvent,\n target,\n transform,\n dispatch\n}) {\n Object.defineProperties(this, {\n type: {value: type, enumerable: true, configurable: true},\n sourceEvent: {value: sourceEvent, enumerable: true, configurable: true},\n target: {value: target, enumerable: true, configurable: true},\n transform: {value: transform, enumerable: true, configurable: true},\n _: {value: dispatch}\n });\n}\n", "export function Transform(k, x, y) {\n this.k = k;\n this.x = x;\n this.y = y;\n}\n\nTransform.prototype = {\n constructor: Transform,\n scale: function(k) {\n return k === 1 ? this : new Transform(this.k * k, this.x, this.y);\n },\n translate: function(x, y) {\n return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);\n },\n apply: function(point) {\n return [point[0] * this.k + this.x, point[1] * this.k + this.y];\n },\n applyX: function(x) {\n return x * this.k + this.x;\n },\n applyY: function(y) {\n return y * this.k + this.y;\n },\n invert: function(location) {\n return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];\n },\n invertX: function(x) {\n return (x - this.x) / this.k;\n },\n invertY: function(y) {\n return (y - this.y) / this.k;\n },\n rescaleX: function(x) {\n return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));\n },\n rescaleY: function(y) {\n return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));\n },\n toString: function() {\n return \"translate(\" + this.x + \",\" + this.y + \") scale(\" + this.k + \")\";\n }\n};\n\nexport var identity = new Transform(1, 0, 0);\n\ntransform.prototype = Transform.prototype;\n\nexport default function transform(node) {\n while (!node.__zoom) if (!(node = node.parentNode)) return identity;\n return node.__zoom;\n}\n", "export function nopropagation(event) {\n event.stopImmediatePropagation();\n}\n\nexport default function(event) {\n event.preventDefault();\n event.stopImmediatePropagation();\n}\n", "import {dispatch} from \"d3-dispatch\";\nimport {dragDisable, dragEnable} from \"d3-drag\";\nimport {interpolateZoom} from \"d3-interpolate\";\nimport {select, pointer} from \"d3-selection\";\nimport {interrupt} from \"d3-transition\";\nimport constant from \"./constant.js\";\nimport ZoomEvent from \"./event.js\";\nimport {Transform, identity} from \"./transform.js\";\nimport noevent, {nopropagation} from \"./noevent.js\";\n\n// Ignore right-click, since that should open the context menu.\n// except for pinch-to-zoom, which is sent as a wheel+ctrlKey event\nfunction defaultFilter(event) {\n return (!event.ctrlKey || event.type === 'wheel') && !event.button;\n}\n\nfunction defaultExtent() {\n var e = this;\n if (e instanceof SVGElement) {\n e = e.ownerSVGElement || e;\n if (e.hasAttribute(\"viewBox\")) {\n e = e.viewBox.baseVal;\n return [[e.x, e.y], [e.x + e.width, e.y + e.height]];\n }\n return [[0, 0], [e.width.baseVal.value, e.height.baseVal.value]];\n }\n return [[0, 0], [e.clientWidth, e.clientHeight]];\n}\n\nfunction defaultTransform() {\n return this.__zoom || identity;\n}\n\nfunction defaultWheelDelta(event) {\n return -event.deltaY * (event.deltaMode === 1 ? 0.05 : event.deltaMode ? 1 : 0.002) * (event.ctrlKey ? 10 : 1);\n}\n\nfunction defaultTouchable() {\n return navigator.maxTouchPoints || (\"ontouchstart\" in this);\n}\n\nfunction defaultConstrain(transform, extent, translateExtent) {\n var dx0 = transform.invertX(extent[0][0]) - translateExtent[0][0],\n dx1 = transform.invertX(extent[1][0]) - translateExtent[1][0],\n dy0 = transform.invertY(extent[0][1]) - translateExtent[0][1],\n dy1 = transform.invertY(extent[1][1]) - translateExtent[1][1];\n return transform.translate(\n dx1 > dx0 ? (dx0 + dx1) / 2 : Math.min(0, dx0) || Math.max(0, dx1),\n dy1 > dy0 ? (dy0 + dy1) / 2 : Math.min(0, dy0) || Math.max(0, dy1)\n );\n}\n\nexport default function() {\n var filter = defaultFilter,\n extent = defaultExtent,\n constrain = defaultConstrain,\n wheelDelta = defaultWheelDelta,\n touchable = defaultTouchable,\n scaleExtent = [0, Infinity],\n translateExtent = [[-Infinity, -Infinity], [Infinity, Infinity]],\n duration = 250,\n interpolate = interpolateZoom,\n listeners = dispatch(\"start\", \"zoom\", \"end\"),\n touchstarting,\n touchfirst,\n touchending,\n touchDelay = 500,\n wheelDelay = 150,\n clickDistance2 = 0,\n tapDistance = 10;\n\n function zoom(selection) {\n selection\n .property(\"__zoom\", defaultTransform)\n .on(\"wheel.zoom\", wheeled, {passive: false})\n .on(\"mousedown.zoom\", mousedowned)\n .on(\"dblclick.zoom\", dblclicked)\n .filter(touchable)\n .on(\"touchstart.zoom\", touchstarted)\n .on(\"touchmove.zoom\", touchmoved)\n .on(\"touchend.zoom touchcancel.zoom\", touchended)\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\");\n }\n\n zoom.transform = function(collection, transform, point, event) {\n var selection = collection.selection ? collection.selection() : collection;\n selection.property(\"__zoom\", defaultTransform);\n if (collection !== selection) {\n schedule(collection, transform, point, event);\n } else {\n selection.interrupt().each(function() {\n gesture(this, arguments)\n .event(event)\n .start()\n .zoom(null, typeof transform === \"function\" ? transform.apply(this, arguments) : transform)\n .end();\n });\n }\n };\n\n zoom.scaleBy = function(selection, k, p, event) {\n zoom.scaleTo(selection, function() {\n var k0 = this.__zoom.k,\n k1 = typeof k === \"function\" ? k.apply(this, arguments) : k;\n return k0 * k1;\n }, p, event);\n };\n\n zoom.scaleTo = function(selection, k, p, event) {\n zoom.transform(selection, function() {\n var e = extent.apply(this, arguments),\n t0 = this.__zoom,\n p0 = p == null ? centroid(e) : typeof p === \"function\" ? p.apply(this, arguments) : p,\n p1 = t0.invert(p0),\n k1 = typeof k === \"function\" ? k.apply(this, arguments) : k;\n return constrain(translate(scale(t0, k1), p0, p1), e, translateExtent);\n }, p, event);\n };\n\n zoom.translateBy = function(selection, x, y, event) {\n zoom.transform(selection, function() {\n return constrain(this.__zoom.translate(\n typeof x === \"function\" ? x.apply(this, arguments) : x,\n typeof y === \"function\" ? y.apply(this, arguments) : y\n ), extent.apply(this, arguments), translateExtent);\n }, null, event);\n };\n\n zoom.translateTo = function(selection, x, y, p, event) {\n zoom.transform(selection, function() {\n var e = extent.apply(this, arguments),\n t = this.__zoom,\n p0 = p == null ? centroid(e) : typeof p === \"function\" ? p.apply(this, arguments) : p;\n return constrain(identity.translate(p0[0], p0[1]).scale(t.k).translate(\n typeof x === \"function\" ? -x.apply(this, arguments) : -x,\n typeof y === \"function\" ? -y.apply(this, arguments) : -y\n ), e, translateExtent);\n }, p, event);\n };\n\n function scale(transform, k) {\n k = Math.max(scaleExtent[0], Math.min(scaleExtent[1], k));\n return k === transform.k ? transform : new Transform(k, transform.x, transform.y);\n }\n\n function translate(transform, p0, p1) {\n var x = p0[0] - p1[0] * transform.k, y = p0[1] - p1[1] * transform.k;\n return x === transform.x && y === transform.y ? transform : new Transform(transform.k, x, y);\n }\n\n function centroid(extent) {\n return [(+extent[0][0] + +extent[1][0]) / 2, (+extent[0][1] + +extent[1][1]) / 2];\n }\n\n function schedule(transition, transform, point, event) {\n transition\n .on(\"start.zoom\", function() { gesture(this, arguments).event(event).start(); })\n .on(\"interrupt.zoom end.zoom\", function() { gesture(this, arguments).event(event).end(); })\n .tween(\"zoom\", function() {\n var that = this,\n args = arguments,\n g = gesture(that, args).event(event),\n e = extent.apply(that, args),\n p = point == null ? centroid(e) : typeof point === \"function\" ? point.apply(that, args) : point,\n w = Math.max(e[1][0] - e[0][0], e[1][1] - e[0][1]),\n a = that.__zoom,\n b = typeof transform === \"function\" ? transform.apply(that, args) : transform,\n i = interpolate(a.invert(p).concat(w / a.k), b.invert(p).concat(w / b.k));\n return function(t) {\n if (t === 1) t = b; // Avoid rounding error on end.\n else { var l = i(t), k = w / l[2]; t = new Transform(k, p[0] - l[0] * k, p[1] - l[1] * k); }\n g.zoom(null, t);\n };\n });\n }\n\n function gesture(that, args, clean) {\n return (!clean && that.__zooming) || new Gesture(that, args);\n }\n\n function Gesture(that, args) {\n this.that = that;\n this.args = args;\n this.active = 0;\n this.sourceEvent = null;\n this.extent = extent.apply(that, args);\n this.taps = 0;\n }\n\n Gesture.prototype = {\n event: function(event) {\n if (event) this.sourceEvent = event;\n return this;\n },\n start: function() {\n if (++this.active === 1) {\n this.that.__zooming = this;\n this.emit(\"start\");\n }\n return this;\n },\n zoom: function(key, transform) {\n if (this.mouse && key !== \"mouse\") this.mouse[1] = transform.invert(this.mouse[0]);\n if (this.touch0 && key !== \"touch\") this.touch0[1] = transform.invert(this.touch0[0]);\n if (this.touch1 && key !== \"touch\") this.touch1[1] = transform.invert(this.touch1[0]);\n this.that.__zoom = transform;\n this.emit(\"zoom\");\n return this;\n },\n end: function() {\n if (--this.active === 0) {\n delete this.that.__zooming;\n this.emit(\"end\");\n }\n return this;\n },\n emit: function(type) {\n var d = select(this.that).datum();\n listeners.call(\n type,\n this.that,\n new ZoomEvent(type, {\n sourceEvent: this.sourceEvent,\n target: zoom,\n type,\n transform: this.that.__zoom,\n dispatch: listeners\n }),\n d\n );\n }\n };\n\n function wheeled(event, ...args) {\n if (!filter.apply(this, arguments)) return;\n var g = gesture(this, args).event(event),\n t = this.__zoom,\n k = Math.max(scaleExtent[0], Math.min(scaleExtent[1], t.k * Math.pow(2, wheelDelta.apply(this, arguments)))),\n p = pointer(event);\n\n // If the mouse is in the same location as before, reuse it.\n // If there were recent wheel events, reset the wheel idle timeout.\n if (g.wheel) {\n if (g.mouse[0][0] !== p[0] || g.mouse[0][1] !== p[1]) {\n g.mouse[1] = t.invert(g.mouse[0] = p);\n }\n clearTimeout(g.wheel);\n }\n\n // If this wheel event won\u2019t trigger a transform change, ignore it.\n else if (t.k === k) return;\n\n // Otherwise, capture the mouse point and location at the start.\n else {\n g.mouse = [p, t.invert(p)];\n interrupt(this);\n g.start();\n }\n\n noevent(event);\n g.wheel = setTimeout(wheelidled, wheelDelay);\n g.zoom(\"mouse\", constrain(translate(scale(t, k), g.mouse[0], g.mouse[1]), g.extent, translateExtent));\n\n function wheelidled() {\n g.wheel = null;\n g.end();\n }\n }\n\n function mousedowned(event, ...args) {\n if (touchending || !filter.apply(this, arguments)) return;\n var currentTarget = event.currentTarget,\n g = gesture(this, args, true).event(event),\n v = select(event.view).on(\"mousemove.zoom\", mousemoved, true).on(\"mouseup.zoom\", mouseupped, true),\n p = pointer(event, currentTarget),\n x0 = event.clientX,\n y0 = event.clientY;\n\n dragDisable(event.view);\n nopropagation(event);\n g.mouse = [p, this.__zoom.invert(p)];\n interrupt(this);\n g.start();\n\n function mousemoved(event) {\n noevent(event);\n if (!g.moved) {\n var dx = event.clientX - x0, dy = event.clientY - y0;\n g.moved = dx * dx + dy * dy > clickDistance2;\n }\n g.event(event)\n .zoom(\"mouse\", constrain(translate(g.that.__zoom, g.mouse[0] = pointer(event, currentTarget), g.mouse[1]), g.extent, translateExtent));\n }\n\n function mouseupped(event) {\n v.on(\"mousemove.zoom mouseup.zoom\", null);\n dragEnable(event.view, g.moved);\n noevent(event);\n g.event(event).end();\n }\n }\n\n function dblclicked(event, ...args) {\n if (!filter.apply(this, arguments)) return;\n var t0 = this.__zoom,\n p0 = pointer(event.changedTouches ? event.changedTouches[0] : event, this),\n p1 = t0.invert(p0),\n k1 = t0.k * (event.shiftKey ? 0.5 : 2),\n t1 = constrain(translate(scale(t0, k1), p0, p1), extent.apply(this, args), translateExtent);\n\n noevent(event);\n if (duration > 0) select(this).transition().duration(duration).call(schedule, t1, p0, event);\n else select(this).call(zoom.transform, t1, p0, event);\n }\n\n function touchstarted(event, ...args) {\n if (!filter.apply(this, arguments)) return;\n var touches = event.touches,\n n = touches.length,\n g = gesture(this, args, event.changedTouches.length === n).event(event),\n started, i, t, p;\n\n nopropagation(event);\n for (i = 0; i < n; ++i) {\n t = touches[i], p = pointer(t, this);\n p = [p, this.__zoom.invert(p), t.identifier];\n if (!g.touch0) g.touch0 = p, started = true, g.taps = 1 + !!touchstarting;\n else if (!g.touch1 && g.touch0[2] !== p[2]) g.touch1 = p, g.taps = 0;\n }\n\n if (touchstarting) touchstarting = clearTimeout(touchstarting);\n\n if (started) {\n if (g.taps < 2) touchfirst = p[0], touchstarting = setTimeout(function() { touchstarting = null; }, touchDelay);\n interrupt(this);\n g.start();\n }\n }\n\n function touchmoved(event, ...args) {\n if (!this.__zooming) return;\n var g = gesture(this, args).event(event),\n touches = event.changedTouches,\n n = touches.length, i, t, p, l;\n\n noevent(event);\n for (i = 0; i < n; ++i) {\n t = touches[i], p = pointer(t, this);\n if (g.touch0 && g.touch0[2] === t.identifier) g.touch0[0] = p;\n else if (g.touch1 && g.touch1[2] === t.identifier) g.touch1[0] = p;\n }\n t = g.that.__zoom;\n if (g.touch1) {\n var p0 = g.touch0[0], l0 = g.touch0[1],\n p1 = g.touch1[0], l1 = g.touch1[1],\n dp = (dp = p1[0] - p0[0]) * dp + (dp = p1[1] - p0[1]) * dp,\n dl = (dl = l1[0] - l0[0]) * dl + (dl = l1[1] - l0[1]) * dl;\n t = scale(t, Math.sqrt(dp / dl));\n p = [(p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2];\n l = [(l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2];\n }\n else if (g.touch0) p = g.touch0[0], l = g.touch0[1];\n else return;\n\n g.zoom(\"touch\", constrain(translate(t, p, l), g.extent, translateExtent));\n }\n\n function touchended(event, ...args) {\n if (!this.__zooming) return;\n var g = gesture(this, args).event(event),\n touches = event.changedTouches,\n n = touches.length, i, t;\n\n nopropagation(event);\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, touchDelay);\n for (i = 0; i < n; ++i) {\n t = touches[i];\n if (g.touch0 && g.touch0[2] === t.identifier) delete g.touch0;\n else if (g.touch1 && g.touch1[2] === t.identifier) delete g.touch1;\n }\n if (g.touch1 && !g.touch0) g.touch0 = g.touch1, delete g.touch1;\n if (g.touch0) g.touch0[1] = this.__zoom.invert(g.touch0[0]);\n else {\n g.end();\n // If this was a dbltap, reroute to the (optional) dblclick.zoom handler.\n if (g.taps === 2) {\n t = pointer(t, this);\n if (Math.hypot(touchfirst[0] - t[0], touchfirst[1] - t[1]) < tapDistance) {\n var p = select(this).on(\"dblclick.zoom\");\n if (p) p.apply(this, arguments);\n }\n }\n }\n }\n\n zoom.wheelDelta = function(_) {\n return arguments.length ? (wheelDelta = typeof _ === \"function\" ? _ : constant(+_), zoom) : wheelDelta;\n };\n\n zoom.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant(!!_), zoom) : filter;\n };\n\n zoom.touchable = function(_) {\n return arguments.length ? (touchable = typeof _ === \"function\" ? _ : constant(!!_), zoom) : touchable;\n };\n\n zoom.extent = function(_) {\n return arguments.length ? (extent = typeof _ === \"function\" ? _ : constant([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), zoom) : extent;\n };\n\n zoom.scaleExtent = function(_) {\n return arguments.length ? (scaleExtent[0] = +_[0], scaleExtent[1] = +_[1], zoom) : [scaleExtent[0], scaleExtent[1]];\n };\n\n zoom.translateExtent = function(_) {\n return arguments.length ? (translateExtent[0][0] = +_[0][0], translateExtent[1][0] = +_[1][0], translateExtent[0][1] = +_[0][1], translateExtent[1][1] = +_[1][1], zoom) : [[translateExtent[0][0], translateExtent[0][1]], [translateExtent[1][0], translateExtent[1][1]]];\n };\n\n zoom.constrain = function(_) {\n return arguments.length ? (constrain = _, zoom) : constrain;\n };\n\n zoom.duration = function(_) {\n return arguments.length ? (duration = +_, zoom) : duration;\n };\n\n zoom.interpolate = function(_) {\n return arguments.length ? (interpolate = _, zoom) : interpolate;\n };\n\n zoom.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? zoom : value;\n };\n\n zoom.clickDistance = function(_) {\n return arguments.length ? (clickDistance2 = (_ = +_) * _, zoom) : Math.sqrt(clickDistance2);\n };\n\n zoom.tapDistance = function(_) {\n return arguments.length ? (tapDistance = +_, zoom) : tapDistance;\n };\n\n return zoom;\n}\n", "import { drag } from 'd3-drag';\nimport { select, pointer } from 'd3-selection';\nimport { zoom, zoomIdentity, zoomTransform } from 'd3-zoom';\nimport { interpolateZoom, interpolate } from 'd3-interpolate';\n\nconst errorMessages = {\n error001: () => '[React Flow]: Seems like you have not used zustand provider as an ancestor. Help: https://reactflow.dev/error#001',\n error002: () => \"It looks like you've created a new nodeTypes or edgeTypes object. If this wasn't on purpose please define the nodeTypes/edgeTypes outside of the component or memoize them.\",\n error003: (nodeType) => `Node type \"${nodeType}\" not found. Using fallback type \"default\".`,\n error004: () => 'The React Flow parent container needs a width and a height to render the graph.',\n error005: () => 'Only child nodes can use a parent extent.',\n error006: () => \"Can't create edge. An edge needs a source and a target.\",\n error007: (id) => `The old edge with id=${id} does not exist.`,\n error009: (type) => `Marker type \"${type}\" doesn't exist.`,\n error008: (handleType, { id, sourceHandle, targetHandle }) => `Couldn't create edge for ${handleType} handle id: \"${handleType === 'source' ? sourceHandle : targetHandle}\", edge id: ${id}.`,\n error010: () => 'Handle: No node id found. Make sure to only use a Handle inside a custom Node.',\n error011: (edgeType) => `Edge type \"${edgeType}\" not found. Using fallback type \"default\".`,\n error012: (id) => `Node with id \"${id}\" does not exist, it may have been removed. This can happen when a node is deleted before the \"onNodeClick\" handler is called.`,\n error013: (lib = 'react') => `It seems that you haven't loaded the styles. Please import '@xyflow/${lib}/dist/style.css' or base.css to make sure everything is working properly.`,\n error014: () => 'useNodeConnections: No node ID found. Call useNodeConnections inside a custom Node or provide a node ID.',\n error015: () => 'It seems that you are trying to drag a node that is not initialized. Please use onNodesChange as explained in the docs.',\n};\nconst infiniteExtent = [\n [Number.NEGATIVE_INFINITY, Number.NEGATIVE_INFINITY],\n [Number.POSITIVE_INFINITY, Number.POSITIVE_INFINITY],\n];\nconst elementSelectionKeys = ['Enter', ' ', 'Escape'];\nconst defaultAriaLabelConfig = {\n 'node.a11yDescription.default': 'Press enter or space to select a node. Press delete to remove it and escape to cancel.',\n 'node.a11yDescription.keyboardDisabled': 'Press enter or space to select a node. You can then use the arrow keys to move the node around. Press delete to remove it and escape to cancel.',\n 'node.a11yDescription.ariaLiveMessage': ({ direction, x, y }) => `Moved selected node ${direction}. New position, x: ${x}, y: ${y}`,\n 'edge.a11yDescription.default': 'Press enter or space to select an edge. You can then press delete to remove it or escape to cancel.',\n // Control elements\n 'controls.ariaLabel': 'Control Panel',\n 'controls.zoomIn.ariaLabel': 'Zoom In',\n 'controls.zoomOut.ariaLabel': 'Zoom Out',\n 'controls.fitView.ariaLabel': 'Fit View',\n 'controls.interactive.ariaLabel': 'Toggle Interactivity',\n // Mini map\n 'minimap.ariaLabel': 'Mini Map',\n // Handle\n 'handle.ariaLabel': 'Handle',\n};\n\n/**\n * The `ConnectionMode` is used to set the mode of connection between nodes.\n * The `Strict` mode is the default one and only allows source to target edges.\n * `Loose` mode allows source to source and target to target edges as well.\n *\n * @public\n */\nvar ConnectionMode;\n(function (ConnectionMode) {\n ConnectionMode[\"Strict\"] = \"strict\";\n ConnectionMode[\"Loose\"] = \"loose\";\n})(ConnectionMode || (ConnectionMode = {}));\n/**\n * This enum is used to set the different modes of panning the viewport when the\n * user scrolls. The `Free` mode allows the user to pan in any direction by scrolling\n * with a device like a trackpad. The `Vertical` and `Horizontal` modes restrict\n * scroll panning to only the vertical or horizontal axis, respectively.\n *\n * @public\n */\nvar PanOnScrollMode;\n(function (PanOnScrollMode) {\n PanOnScrollMode[\"Free\"] = \"free\";\n PanOnScrollMode[\"Vertical\"] = \"vertical\";\n PanOnScrollMode[\"Horizontal\"] = \"horizontal\";\n})(PanOnScrollMode || (PanOnScrollMode = {}));\nvar SelectionMode;\n(function (SelectionMode) {\n SelectionMode[\"Partial\"] = \"partial\";\n SelectionMode[\"Full\"] = \"full\";\n})(SelectionMode || (SelectionMode = {}));\nconst initialConnection = {\n inProgress: false,\n isValid: null,\n from: null,\n fromHandle: null,\n fromPosition: null,\n fromNode: null,\n to: null,\n toHandle: null,\n toPosition: null,\n toNode: null,\n};\n\n/**\n * If you set the `connectionLineType` prop on your [`<ReactFlow />`](/api-reference/react-flow#connection-connectionLineType)\n *component, it will dictate the style of connection line rendered when creating\n *new edges.\n *\n * @public\n *\n * @remarks If you choose to render a custom connection line component, this value will be\n *passed to your component as part of its [`ConnectionLineComponentProps`](/api-reference/types/connection-line-component-props).\n */\nvar ConnectionLineType;\n(function (ConnectionLineType) {\n ConnectionLineType[\"Bezier\"] = \"default\";\n ConnectionLineType[\"Straight\"] = \"straight\";\n ConnectionLineType[\"Step\"] = \"step\";\n ConnectionLineType[\"SmoothStep\"] = \"smoothstep\";\n ConnectionLineType[\"SimpleBezier\"] = \"simplebezier\";\n})(ConnectionLineType || (ConnectionLineType = {}));\n/**\n * Edges may optionally have a marker on either end. The MarkerType type enumerates\n * the options available to you when configuring a given marker.\n *\n * @public\n */\nvar MarkerType;\n(function (MarkerType) {\n MarkerType[\"Arrow\"] = \"arrow\";\n MarkerType[\"ArrowClosed\"] = \"arrowclosed\";\n})(MarkerType || (MarkerType = {}));\n\n/**\n * While [`PanelPosition`](/api-reference/types/panel-position) can be used to place a\n * component in the corners of a container, the `Position` enum is less precise and used\n * primarily in relation to edges and handles.\n *\n * @public\n */\nvar Position;\n(function (Position) {\n Position[\"Left\"] = \"left\";\n Position[\"Top\"] = \"top\";\n Position[\"Right\"] = \"right\";\n Position[\"Bottom\"] = \"bottom\";\n})(Position || (Position = {}));\nconst oppositePosition = {\n [Position.Left]: Position.Right,\n [Position.Right]: Position.Left,\n [Position.Top]: Position.Bottom,\n [Position.Bottom]: Position.Top,\n};\n\n/**\n * @internal\n */\nfunction areConnectionMapsEqual(a, b) {\n if (!a && !b) {\n return true;\n }\n if (!a || !b || a.size !== b.size) {\n return false;\n }\n if (!a.size && !b.size) {\n return true;\n }\n for (const key of a.keys()) {\n if (!b.has(key)) {\n return false;\n }\n }\n return true;\n}\n/**\n * We call the callback for all connections in a that are not in b\n *\n * @internal\n */\nfunction handleConnectionChange(a, b, cb) {\n if (!cb) {\n return;\n }\n const diff = [];\n a.forEach((connection, key) => {\n if (!b?.has(key)) {\n diff.push(connection);\n }\n });\n if (diff.length) {\n cb(diff);\n }\n}\nfunction getConnectionStatus(isValid) {\n return isValid === null ? null : isValid ? 'valid' : 'invalid';\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Test whether an object is usable as an Edge\n * @public\n * @remarks In TypeScript this is a type guard that will narrow the type of whatever you pass in to Edge if it returns true\n * @param element - The element to test\n * @returns A boolean indicating whether the element is an Edge\n */\nconst isEdgeBase = (element) => 'id' in element && 'source' in element && 'target' in element;\n/**\n * Test whether an object is usable as a Node\n * @public\n * @remarks In TypeScript this is a type guard that will narrow the type of whatever you pass in to Node if it returns true\n * @param element - The element to test\n * @returns A boolean indicating whether the element is an Node\n */\nconst isNodeBase = (element) => 'id' in element && 'position' in element && !('source' in element) && !('target' in element);\nconst isInternalNodeBase = (element) => 'id' in element && 'internals' in element && !('source' in element) && !('target' in element);\n/**\n * This util is used to tell you what nodes, if any, are connected to the given node\n * as the _target_ of an edge.\n * @public\n * @param node - The node to get the connected nodes from.\n * @param nodes - The array of all nodes.\n * @param edges - The array of all edges.\n * @returns An array of nodes that are connected over edges where the source is the given node.\n *\n * @example\n * ```ts\n *import { getOutgoers } from '@xyflow/react';\n *\n *const nodes = [];\n *const edges = [];\n *\n *const outgoers = getOutgoers(\n * { id: '1', position: { x: 0, y: 0 }, data: { label: 'node' } },\n * nodes,\n * edges,\n *);\n *```\n */\nconst getOutgoers = (node, nodes, edges) => {\n if (!node.id) {\n return [];\n }\n const outgoerIds = new Set();\n edges.forEach((edge) => {\n if (edge.source === node.id) {\n outgoerIds.add(edge.target);\n }\n });\n return nodes.filter((n) => outgoerIds.has(n.id));\n};\n/**\n * This util is used to tell you what nodes, if any, are connected to the given node\n * as the _source_ of an edge.\n * @public\n * @param node - The node to get the connected nodes from.\n * @param nodes - The array of all nodes.\n * @param edges - The array of all edges.\n * @returns An array of nodes that are connected over edges where the target is the given node.\n *\n * @example\n * ```ts\n *import { getIncomers } from '@xyflow/react';\n *\n *const nodes = [];\n *const edges = [];\n *\n *const incomers = getIncomers(\n * { id: '1', position: { x: 0, y: 0 }, data: { label: 'node' } },\n * nodes,\n * edges,\n *);\n *```\n */\nconst getIncomers = (node, nodes, edges) => {\n if (!node.id) {\n return [];\n }\n const incomersIds = new Set();\n edges.forEach((edge) => {\n if (edge.target === node.id) {\n incomersIds.add(edge.source);\n }\n });\n return nodes.filter((n) => incomersIds.has(n.id));\n};\nconst getNodePositionWithOrigin = (node, nodeOrigin = [0, 0]) => {\n const { width, height } = getNodeDimensions(node);\n const origin = node.origin ?? nodeOrigin;\n const offsetX = width * origin[0];\n const offsetY = height * origin[1];\n return {\n x: node.position.x - offsetX,\n y: node.position.y - offsetY,\n };\n};\n/**\n * Returns the bounding box that contains all the given nodes in an array. This can\n * be useful when combined with [`getViewportForBounds`](/api-reference/utils/get-viewport-for-bounds)\n * to calculate the correct transform to fit the given nodes in a viewport.\n * @public\n * @remarks Useful when combined with {@link getViewportForBounds} to calculate the correct transform to fit the given nodes in a viewport.\n * @param nodes - Nodes to calculate the bounds for.\n * @returns Bounding box enclosing all nodes.\n *\n * @remarks This function was previously called `getRectOfNodes`\n *\n * @example\n * ```js\n *import { getNodesBounds } from '@xyflow/react';\n *\n *const nodes = [\n * {\n * id: 'a',\n * position: { x: 0, y: 0 },\n * data: { label: 'a' },\n * width: 50,\n * height: 25,\n * },\n * {\n * id: 'b',\n * position: { x: 100, y: 100 },\n * data: { label: 'b' },\n * width: 50,\n * height: 25,\n * },\n *];\n *\n *const bounds = getNodesBounds(nodes);\n *```\n */\nconst getNodesBounds = (nodes, params = { nodeOrigin: [0, 0] }) => {\n if (process.env.NODE_ENV === 'development' && !params.nodeLookup) {\n console.warn('Please use `getNodesBounds` from `useReactFlow`/`useSvelteFlow` hook to ensure correct values for sub flows. If not possible, you have to provide a nodeLookup to support sub flows.');\n }\n if (nodes.length === 0) {\n return { x: 0, y: 0, width: 0, height: 0 };\n }\n const box = nodes.reduce((currBox, nodeOrId) => {\n const isId = typeof nodeOrId === 'string';\n let currentNode = !params.nodeLookup && !isId ? nodeOrId : undefined;\n if (params.nodeLookup) {\n currentNode = isId\n ? params.nodeLookup.get(nodeOrId)\n : !isInternalNodeBase(nodeOrId)\n ? params.nodeLookup.get(nodeOrId.id)\n : nodeOrId;\n }\n const nodeBox = currentNode ? nodeToBox(currentNode, params.nodeOrigin) : { x: 0, y: 0, x2: 0, y2: 0 };\n return getBoundsOfBoxes(currBox, nodeBox);\n }, { x: Infinity, y: Infinity, x2: -Infinity, y2: -Infinity });\n return boxToRect(box);\n};\n/**\n * Determines a bounding box that contains all given nodes in an array\n * @internal\n */\nconst getInternalNodesBounds = (nodeLookup, params = {}) => {\n let box = { x: Infinity, y: Infinity, x2: -Infinity, y2: -Infinity };\n let hasVisibleNodes = false;\n nodeLookup.forEach((node) => {\n if (params.filter === undefined || params.filter(node)) {\n box = getBoundsOfBoxes(box, nodeToBox(node));\n hasVisibleNodes = true;\n }\n });\n return hasVisibleNodes ? boxToRect(box) : { x: 0, y: 0, width: 0, height: 0 };\n};\nconst getNodesInside = (nodes, rect, [tx, ty, tScale] = [0, 0, 1], partially = false, \n// set excludeNonSelectableNodes if you want to pay attention to the nodes \"selectable\" attribute\nexcludeNonSelectableNodes = false) => {\n const paneRect = {\n ...pointToRendererPoint(rect, [tx, ty, tScale]),\n width: rect.width / tScale,\n height: rect.height / tScale,\n };\n const visibleNodes = [];\n for (const node of nodes.values()) {\n const { measured, selectable = true, hidden = false } = node;\n if ((excludeNonSelectableNodes && !selectable) || hidden) {\n continue;\n }\n const width = measured.width ?? node.width ?? node.initialWidth ?? null;\n const height = measured.height ?? node.height ?? node.initialHeight ?? null;\n const overlappingArea = getOverlappingArea(paneRect, nodeToRect(node));\n const area = (width ?? 0) * (height ?? 0);\n const partiallyVisible = partially && overlappingArea > 0;\n const forceInitialRender = !node.internals.handleBounds;\n const isVisible = forceInitialRender || partiallyVisible || overlappingArea >= area;\n if (isVisible || node.dragging) {\n visibleNodes.push(node);\n }\n }\n return visibleNodes;\n};\n/**\n * This utility filters an array of edges, keeping only those where either the source or target\n * node is present in the given array of nodes.\n * @public\n * @param nodes - Nodes you want to get the connected edges for.\n * @param edges - All edges.\n * @returns Array of edges that connect any of the given nodes with each other.\n *\n * @example\n * ```js\n *import { getConnectedEdges } from '@xyflow/react';\n *\n *const nodes = [\n * { id: 'a', position: { x: 0, y: 0 } },\n * { id: 'b', position: { x: 100, y: 0 } },\n *];\n *\n *const edges = [\n * { id: 'a->c', source: 'a', target: 'c' },\n * { id: 'c->d', source: 'c', target: 'd' },\n *];\n *\n *const connectedEdges = getConnectedEdges(nodes, edges);\n * // => [{ id: 'a->c', source: 'a', target: 'c' }]\n *```\n */\nconst getConnectedEdges = (nodes, edges) => {\n const nodeIds = new Set();\n nodes.forEach((node) => {\n nodeIds.add(node.id);\n });\n return edges.filter((edge) => nodeIds.has(edge.source) || nodeIds.has(edge.target));\n};\nfunction getFitViewNodes(nodeLookup, options) {\n const fitViewNodes = new Map();\n const optionNodeIds = options?.nodes ? new Set(options.nodes.map((node) => node.id)) : null;\n nodeLookup.forEach((n) => {\n const isVisible = n.measured.width && n.measured.height && (options?.includeHiddenNodes || !n.hidden);\n if (isVisible && (!optionNodeIds || optionNodeIds.has(n.id))) {\n fitViewNodes.set(n.id, n);\n }\n });\n return fitViewNodes;\n}\nasync function fitViewport({ nodes, width, height, panZoom, minZoom, maxZoom }, options) {\n if (nodes.size === 0) {\n return Promise.resolve(true);\n }\n const nodesToFit = getFitViewNodes(nodes, options);\n const bounds = getInternalNodesBounds(nodesToFit);\n const viewport = getViewportForBounds(bounds, width, height, options?.minZoom ?? minZoom, options?.maxZoom ?? maxZoom, options?.padding ?? 0.1);\n await panZoom.setViewport(viewport, {\n duration: options?.duration,\n ease: options?.ease,\n interpolate: options?.interpolate,\n });\n return Promise.resolve(true);\n}\n/**\n * This function calculates the next position of a node, taking into account the node's extent, parent node, and origin.\n *\n * @internal\n * @returns position, positionAbsolute\n */\nfunction calculateNodePosition({ nodeId, nextPosition, nodeLookup, nodeOrigin = [0, 0], nodeExtent, onError, }) {\n const node = nodeLookup.get(nodeId);\n const parentNode = node.parentId ? nodeLookup.get(node.parentId) : undefined;\n const { x: parentX, y: parentY } = parentNode ? parentNode.internals.positionAbsolute : { x: 0, y: 0 };\n const origin = node.origin ?? nodeOrigin;\n let extent = node.extent || nodeExtent;\n if (node.extent === 'parent' && !node.expandParent) {\n if (!parentNode) {\n onError?.('005', errorMessages['error005']());\n }\n else {\n const parentWidth = parentNode.measured.width;\n const parentHeight = parentNode.measured.height;\n if (parentWidth && parentHeight) {\n extent = [\n [parentX, parentY],\n [parentX + parentWidth, parentY + parentHeight],\n ];\n }\n }\n }\n else if (parentNode && isCoordinateExtent(node.extent)) {\n extent = [\n [node.extent[0][0] + parentX, node.extent[0][1] + parentY],\n [node.extent[1][0] + parentX, node.extent[1][1] + parentY],\n ];\n }\n const positionAbsolute = isCoordinateExtent(extent)\n ? clampPosition(nextPosition, extent, node.measured)\n : nextPosition;\n if (node.measured.width === undefined || node.measured.height === undefined) {\n onError?.('015', errorMessages['error015']());\n }\n return {\n position: {\n x: positionAbsolute.x - parentX + (node.measured.width ?? 0) * origin[0],\n y: positionAbsolute.y - parentY + (node.measured.height ?? 0) * origin[1],\n },\n positionAbsolute,\n };\n}\n/**\n * Pass in nodes & edges to delete, get arrays of nodes and edges that actually can be deleted\n * @internal\n * @param param.nodesToRemove - The nodes to remove\n * @param param.edgesToRemove - The edges to remove\n * @param param.nodes - All nodes\n * @param param.edges - All edges\n * @param param.onBeforeDelete - Callback to check which nodes and edges can be deleted\n * @returns nodes: nodes that can be deleted, edges: edges that can be deleted\n */\nasync function getElementsToRemove({ nodesToRemove = [], edgesToRemove = [], nodes, edges, onBeforeDelete, }) {\n const nodeIds = new Set(nodesToRemove.map((node) => node.id));\n const matchingNodes = [];\n for (const node of nodes) {\n if (node.deletable === false) {\n continue;\n }\n const isIncluded = nodeIds.has(node.id);\n const parentHit = !isIncluded && node.parentId && matchingNodes.find((n) => n.id === node.parentId);\n if (isIncluded || parentHit) {\n matchingNodes.push(node);\n }\n }\n const edgeIds = new Set(edgesToRemove.map((edge) => edge.id));\n const deletableEdges = edges.filter((edge) => edge.deletable !== false);\n const connectedEdges = getConnectedEdges(matchingNodes, deletableEdges);\n const matchingEdges = connectedEdges;\n for (const edge of deletableEdges) {\n const isIncluded = edgeIds.has(edge.id);\n if (isIncluded && !matchingEdges.find((e) => e.id === edge.id)) {\n matchingEdges.push(edge);\n }\n }\n if (!onBeforeDelete) {\n return {\n edges: matchingEdges,\n nodes: matchingNodes,\n };\n }\n const onBeforeDeleteResult = await onBeforeDelete({\n nodes: matchingNodes,\n edges: matchingEdges,\n });\n if (typeof onBeforeDeleteResult === 'boolean') {\n return onBeforeDeleteResult ? { edges: matchingEdges, nodes: matchingNodes } : { edges: [], nodes: [] };\n }\n return onBeforeDeleteResult;\n}\n\nconst clamp = (val, min = 0, max = 1) => Math.min(Math.max(val, min), max);\nconst clampPosition = (position = { x: 0, y: 0 }, extent, dimensions) => ({\n x: clamp(position.x, extent[0][0], extent[1][0] - (dimensions?.width ?? 0)),\n y: clamp(position.y, extent[0][1], extent[1][1] - (dimensions?.height ?? 0)),\n});\nfunction clampPositionToParent(childPosition, childDimensions, parent) {\n const { width: parentWidth, height: parentHeight } = getNodeDimensions(parent);\n const { x: parentX, y: parentY } = parent.internals.positionAbsolute;\n return clampPosition(childPosition, [\n [parentX, parentY],\n [parentX + parentWidth, parentY + parentHeight],\n ], childDimensions);\n}\n/**\n * Calculates the velocity of panning when the mouse is close to the edge of the canvas\n * @internal\n * @param value - One dimensional poition of the mouse (x or y)\n * @param min - Minimal position on canvas before panning starts\n * @param max - Maximal position on canvas before panning starts\n * @returns - A number between 0 and 1 that represents the velocity of panning\n */\nconst calcAutoPanVelocity = (value, min, max) => {\n if (value < min) {\n return clamp(Math.abs(value - min), 1, min) / min;\n }\n else if (value > max) {\n return -clamp(Math.abs(value - max), 1, min) / min;\n }\n return 0;\n};\nconst calcAutoPan = (pos, bounds, speed = 15, distance = 40) => {\n const xMovement = calcAutoPanVelocity(pos.x, distance, bounds.width - distance) * speed;\n const yMovement = calcAutoPanVelocity(pos.y, distance, bounds.height - distance) * speed;\n return [xMovement, yMovement];\n};\nconst getBoundsOfBoxes = (box1, box2) => ({\n x: Math.min(box1.x, box2.x),\n y: Math.min(box1.y, box2.y),\n x2: Math.max(box1.x2, box2.x2),\n y2: Math.max(box1.y2, box2.y2),\n});\nconst rectToBox = ({ x, y, width, height }) => ({\n x,\n y,\n x2: x + width,\n y2: y + height,\n});\nconst boxToRect = ({ x, y, x2, y2 }) => ({\n x,\n y,\n width: x2 - x,\n height: y2 - y,\n});\nconst nodeToRect = (node, nodeOrigin = [0, 0]) => {\n const { x, y } = isInternalNodeBase(node)\n ? node.internals.positionAbsolute\n : getNodePositionWithOrigin(node, nodeOrigin);\n return {\n x,\n y,\n width: node.measured?.width ?? node.width ?? node.initialWidth ?? 0,\n height: node.measured?.height ?? node.height ?? node.initialHeight ?? 0,\n };\n};\nconst nodeToBox = (node, nodeOrigin = [0, 0]) => {\n const { x, y } = isInternalNodeBase(node)\n ? node.internals.positionAbsolute\n : getNodePositionWithOrigin(node, nodeOrigin);\n return {\n x,\n y,\n x2: x + (node.measured?.width ?? node.width ?? node.initialWidth ?? 0),\n y2: y + (node.measured?.height ?? node.height ?? node.initialHeight ?? 0),\n };\n};\nconst getBoundsOfRects = (rect1, rect2) => boxToRect(getBoundsOfBoxes(rectToBox(rect1), rectToBox(rect2)));\nconst getOverlappingArea = (rectA, rectB) => {\n const xOverlap = Math.max(0, Math.min(rectA.x + rectA.width, rectB.x + rectB.width) - Math.max(rectA.x, rectB.x));\n const yOverlap = Math.max(0, Math.min(rectA.y + rectA.height, rectB.y + rectB.height) - Math.max(rectA.y, rectB.y));\n return Math.ceil(xOverlap * yOverlap);\n};\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst isRectObject = (obj) => isNumeric(obj.width) && isNumeric(obj.height) && isNumeric(obj.x) && isNumeric(obj.y);\n/* eslint-disable-next-line @typescript-eslint/no-explicit-any */\nconst isNumeric = (n) => !isNaN(n) && isFinite(n);\n// used for a11y key board controls for nodes and edges\nconst devWarn = (id, message) => {\n if (process.env.NODE_ENV === 'development') {\n console.warn(`[React Flow]: ${message} Help: https://reactflow.dev/error#${id}`);\n }\n};\nconst snapPosition = (position, snapGrid = [1, 1]) => {\n return {\n x: snapGrid[0] * Math.round(position.x / snapGrid[0]),\n y: snapGrid[1] * Math.round(position.y / snapGrid[1]),\n };\n};\nconst pointToRendererPoint = ({ x, y }, [tx, ty, tScale], snapToGrid = false, snapGrid = [1, 1]) => {\n const position = {\n x: (x - tx) / tScale,\n y: (y - ty) / tScale,\n };\n return snapToGrid ? snapPosition(position, snapGrid) : position;\n};\nconst rendererPointToPoint = ({ x, y }, [tx, ty, tScale]) => {\n return {\n x: x * tScale + tx,\n y: y * tScale + ty,\n };\n};\n/**\n * Parses a single padding value to a number\n * @internal\n * @param padding - Padding to parse\n * @param viewport - Width or height of the viewport\n * @returns The padding in pixels\n */\nfunction parsePadding(padding, viewport) {\n if (typeof padding === 'number') {\n return Math.floor((viewport - viewport / (1 + padding)) * 0.5);\n }\n if (typeof padding === 'string' && padding.endsWith('px')) {\n const paddingValue = parseFloat(padding);\n if (!Number.isNaN(paddingValue)) {\n return Math.floor(paddingValue);\n }\n }\n if (typeof padding === 'string' && padding.endsWith('%')) {\n const paddingValue = parseFloat(padding);\n if (!Number.isNaN(paddingValue)) {\n return Math.floor(viewport * paddingValue * 0.01);\n }\n }\n console.error(`[React Flow] The padding value \"${padding}\" is invalid. Please provide a number or a string with a valid unit (px or %).`);\n return 0;\n}\n/**\n * Parses the paddings to an object with top, right, bottom, left, x and y paddings\n * @internal\n * @param padding - Padding to parse\n * @param width - Width of the viewport\n * @param height - Height of the viewport\n * @returns An object with the paddings in pixels\n */\nfunction parsePaddings(padding, width, height) {\n if (typeof padding === 'string' || typeof padding === 'number') {\n const paddingY = parsePadding(padding, height);\n const paddingX = parsePadding(padding, width);\n return {\n top: paddingY,\n right: paddingX,\n bottom: paddingY,\n left: paddingX,\n x: paddingX * 2,\n y: paddingY * 2,\n };\n }\n if (typeof padding === 'object') {\n const top = parsePadding(padding.top ?? padding.y ?? 0, height);\n const bottom = parsePadding(padding.bottom ?? padding.y ?? 0, height);\n const left = parsePadding(padding.left ?? padding.x ?? 0, width);\n const right = parsePadding(padding.right ?? padding.x ?? 0, width);\n return { top, right, bottom, left, x: left + right, y: top + bottom };\n }\n return { top: 0, right: 0, bottom: 0, left: 0, x: 0, y: 0 };\n}\n/**\n * Calculates the resulting paddings if the new viewport is applied\n * @internal\n * @param bounds - Bounds to fit inside viewport\n * @param x - X position of the viewport\n * @param y - Y position of the viewport\n * @param zoom - Zoom level of the viewport\n * @param width - Width of the viewport\n * @param height - Height of the viewport\n * @returns An object with the minimum padding required to fit the bounds inside the viewport\n */\nfunction calculateAppliedPaddings(bounds, x, y, zoom, width, height) {\n const { x: left, y: top } = rendererPointToPoint(bounds, [x, y, zoom]);\n const { x: boundRight, y: boundBottom } = rendererPointToPoint({ x: bounds.x + bounds.width, y: bounds.y + bounds.height }, [x, y, zoom]);\n const right = width - boundRight;\n const bottom = height - boundBottom;\n return {\n left: Math.floor(left),\n top: Math.floor(top),\n right: Math.floor(right),\n bottom: Math.floor(bottom),\n };\n}\n/**\n * Returns a viewport that encloses the given bounds with padding.\n * @public\n * @remarks You can determine bounds of nodes with {@link getNodesBounds} and {@link getBoundsOfRects}\n * @param bounds - Bounds to fit inside viewport.\n * @param width - Width of the viewport.\n * @param height - Height of the viewport.\n * @param minZoom - Minimum zoom level of the resulting viewport.\n * @param maxZoom - Maximum zoom level of the resulting viewport.\n * @param padding - Padding around the bounds.\n * @returns A transformed {@link Viewport} that encloses the given bounds which you can pass to e.g. {@link setViewport}.\n * @example\n * const { x, y, zoom } = getViewportForBounds(\n * { x: 0, y: 0, width: 100, height: 100},\n * 1200, 800, 0.5, 2);\n */\nconst getViewportForBounds = (bounds, width, height, minZoom, maxZoom, padding) => {\n // First we resolve all the paddings to actual pixel values\n const p = parsePaddings(padding, width, height);\n const xZoom = (width - p.x) / bounds.width;\n const yZoom = (height - p.y) / bounds.height;\n // We calculate the new x, y, zoom for a centered view\n const zoom = Math.min(xZoom, yZoom);\n const clampedZoom = clamp(zoom, minZoom, maxZoom);\n const boundsCenterX = bounds.x + bounds.width / 2;\n const boundsCenterY = bounds.y + bounds.height / 2;\n const x = width / 2 - boundsCenterX * clampedZoom;\n const y = height / 2 - boundsCenterY * clampedZoom;\n // Then we calculate the minimum padding, to respect asymmetric paddings\n const newPadding = calculateAppliedPaddings(bounds, x, y, clampedZoom, width, height);\n // We only want to have an offset if the newPadding is smaller than the required padding\n const offset = {\n left: Math.min(newPadding.left - p.left, 0),\n top: Math.min(newPadding.top - p.top, 0),\n right: Math.min(newPadding.right - p.right, 0),\n bottom: Math.min(newPadding.bottom - p.bottom, 0),\n };\n return {\n x: x - offset.left + offset.right,\n y: y - offset.top + offset.bottom,\n zoom: clampedZoom,\n };\n};\nconst isMacOs = () => typeof navigator !== 'undefined' && navigator?.userAgent?.indexOf('Mac') >= 0;\nfunction isCoordinateExtent(extent) {\n return extent !== undefined && extent !== null && extent !== 'parent';\n}\nfunction getNodeDimensions(node) {\n return {\n width: node.measured?.width ?? node.width ?? node.initialWidth ?? 0,\n height: node.measured?.height ?? node.height ?? node.initialHeight ?? 0,\n };\n}\nfunction nodeHasDimensions(node) {\n return ((node.measured?.width ?? node.width ?? node.initialWidth) !== undefined &&\n (node.measured?.height ?? node.height ?? node.initialHeight) !== undefined);\n}\n/**\n * Convert child position to aboslute position\n *\n * @internal\n * @param position\n * @param parentId\n * @param nodeLookup\n * @param nodeOrigin\n * @returns an internal node with an absolute position\n */\nfunction evaluateAbsolutePosition(position, dimensions = { width: 0, height: 0 }, parentId, nodeLookup, nodeOrigin) {\n const positionAbsolute = { ...position };\n const parent = nodeLookup.get(parentId);\n if (parent) {\n const origin = parent.origin || nodeOrigin;\n positionAbsolute.x += parent.internals.positionAbsolute.x - (dimensions.width ?? 0) * origin[0];\n positionAbsolute.y += parent.internals.positionAbsolute.y - (dimensions.height ?? 0) * origin[1];\n }\n return positionAbsolute;\n}\nfunction areSetsEqual(a, b) {\n if (a.size !== b.size) {\n return false;\n }\n for (const item of a) {\n if (!b.has(item)) {\n return false;\n }\n }\n return true;\n}\n/**\n * Polyfill for Promise.withResolvers until we can use it in all browsers\n * @internal\n */\nfunction withResolvers() {\n let resolve;\n let reject;\n const promise = new Promise((res, rej) => {\n resolve = res;\n reject = rej;\n });\n return { promise, resolve, reject };\n}\nfunction mergeAriaLabelConfig(partial) {\n return { ...defaultAriaLabelConfig, ...(partial || {}) };\n}\n\nfunction getPointerPosition(event, { snapGrid = [0, 0], snapToGrid = false, transform, containerBounds }) {\n const { x, y } = getEventPosition(event);\n const pointerPos = pointToRendererPoint({ x: x - (containerBounds?.left ?? 0), y: y - (containerBounds?.top ?? 0) }, transform);\n const { x: xSnapped, y: ySnapped } = snapToGrid ? snapPosition(pointerPos, snapGrid) : pointerPos;\n // we need the snapped position in order to be able to skip unnecessary drag events\n return {\n xSnapped,\n ySnapped,\n ...pointerPos,\n };\n}\nconst getDimensions = (node) => ({\n width: node.offsetWidth,\n height: node.offsetHeight,\n});\nconst getHostForElement = (element) => element?.getRootNode?.() || window?.document;\nconst inputTags = ['INPUT', 'SELECT', 'TEXTAREA'];\nfunction isInputDOMNode(event) {\n // using composed path for handling shadow dom\n const target = (event.composedPath?.()?.[0] || event.target);\n if (target?.nodeType !== 1 /* Node.ELEMENT_NODE */)\n return false;\n const isInput = inputTags.includes(target.nodeName) || target.hasAttribute('contenteditable');\n // when an input field is focused we don't want to trigger deletion or movement of nodes\n return isInput || !!target.closest('.nokey');\n}\nconst isMouseEvent = (event) => 'clientX' in event;\nconst getEventPosition = (event, bounds) => {\n const isMouse = isMouseEvent(event);\n const evtX = isMouse ? event.clientX : event.touches?.[0].clientX;\n const evtY = isMouse ? event.clientY : event.touches?.[0].clientY;\n return {\n x: evtX - (bounds?.left ?? 0),\n y: evtY - (bounds?.top ?? 0),\n };\n};\n/*\n * The handle bounds are calculated relative to the node element.\n * We store them in the internals object of the node in order to avoid\n * unnecessary recalculations.\n */\nconst getHandleBounds = (type, nodeElement, nodeBounds, zoom, nodeId) => {\n const handles = nodeElement.querySelectorAll(`.${type}`);\n if (!handles || !handles.length) {\n return null;\n }\n return Array.from(handles).map((handle) => {\n const handleBounds = handle.getBoundingClientRect();\n return {\n id: handle.getAttribute('data-handleid'),\n type,\n nodeId,\n position: handle.getAttribute('data-handlepos'),\n x: (handleBounds.left - nodeBounds.left) / zoom,\n y: (handleBounds.top - nodeBounds.top) / zoom,\n ...getDimensions(handle),\n };\n });\n};\n\nfunction getBezierEdgeCenter({ sourceX, sourceY, targetX, targetY, sourceControlX, sourceControlY, targetControlX, targetControlY, }) {\n /*\n * cubic bezier t=0.5 mid point, not the actual mid point, but easy to calculate\n * https://stackoverflow.com/questions/67516101/how-to-find-distance-mid-point-of-bezier-curve\n */\n const centerX = sourceX * 0.125 + sourceControlX * 0.375 + targetControlX * 0.375 + targetX * 0.125;\n const centerY = sourceY * 0.125 + sourceControlY * 0.375 + targetControlY * 0.375 + targetY * 0.125;\n const offsetX = Math.abs(centerX - sourceX);\n const offsetY = Math.abs(centerY - sourceY);\n return [centerX, centerY, offsetX, offsetY];\n}\nfunction calculateControlOffset(distance, curvature) {\n if (distance >= 0) {\n return 0.5 * distance;\n }\n return curvature * 25 * Math.sqrt(-distance);\n}\nfunction getControlWithCurvature({ pos, x1, y1, x2, y2, c }) {\n switch (pos) {\n case Position.Left:\n return [x1 - calculateControlOffset(x1 - x2, c), y1];\n case Position.Right:\n return [x1 + calculateControlOffset(x2 - x1, c), y1];\n case Position.Top:\n return [x1, y1 - calculateControlOffset(y1 - y2, c)];\n case Position.Bottom:\n return [x1, y1 + calculateControlOffset(y2 - y1, c)];\n }\n}\n/**\n * The `getBezierPath` util returns everything you need to render a bezier edge\n *between two nodes.\n * @public\n * @returns A path string you can use in an SVG, the `labelX` and `labelY` position (center of path)\n * and `offsetX`, `offsetY` between source handle and label.\n * - `path`: the path to use in an SVG `<path>` element.\n * - `labelX`: the `x` position you can use to render a label for this edge.\n * - `labelY`: the `y` position you can use to render a label for this edge.\n * - `offsetX`: the absolute difference between the source `x` position and the `x` position of the\n * middle of this path.\n * - `offsetY`: the absolute difference between the source `y` position and the `y` position of the\n * middle of this path.\n * @example\n * ```js\n * const source = { x: 0, y: 20 };\n * const target = { x: 150, y: 100 };\n *\n * const [path, labelX, labelY, offsetX, offsetY] = getBezierPath({\n * sourceX: source.x,\n * sourceY: source.y,\n * sourcePosition: Position.Right,\n * targetX: target.x,\n * targetY: target.y,\n * targetPosition: Position.Left,\n *});\n *```\n *\n * @remarks This function returns a tuple (aka a fixed-size array) to make it easier to\n *work with multiple edge paths at once.\n */\nfunction getBezierPath({ sourceX, sourceY, sourcePosition = Position.Bottom, targetX, targetY, targetPosition = Position.Top, curvature = 0.25, }) {\n const [sourceControlX, sourceControlY] = getControlWithCurvature({\n pos: sourcePosition,\n x1: sourceX,\n y1: sourceY,\n x2: targetX,\n y2: targetY,\n c: curvature,\n });\n const [targetControlX, targetControlY] = getControlWithCurvature({\n pos: targetPosition,\n x1: targetX,\n y1: targetY,\n x2: sourceX,\n y2: sourceY,\n c: curvature,\n });\n const [labelX, labelY, offsetX, offsetY] = getBezierEdgeCenter({\n sourceX,\n sourceY,\n targetX,\n targetY,\n sourceControlX,\n sourceControlY,\n targetControlX,\n targetControlY,\n });\n return [\n `M${sourceX},${sourceY} C${sourceControlX},${sourceControlY} ${targetControlX},${targetControlY} ${targetX},${targetY}`,\n labelX,\n labelY,\n offsetX,\n offsetY,\n ];\n}\n\n// this is used for straight edges and simple smoothstep edges (LTR, RTL, BTT, TTB)\nfunction getEdgeCenter({ sourceX, sourceY, targetX, targetY, }) {\n const xOffset = Math.abs(targetX - sourceX) / 2;\n const centerX = targetX < sourceX ? targetX + xOffset : targetX - xOffset;\n const yOffset = Math.abs(targetY - sourceY) / 2;\n const centerY = targetY < sourceY ? targetY + yOffset : targetY - yOffset;\n return [centerX, centerY, xOffset, yOffset];\n}\n/**\n * Returns the z-index for an edge based on the node it connects and whether it is selected.\n * By default, edges are rendered below nodes. This behaviour is different for edges that are\n * connected to nodes with a parent, as they are rendered above the parent node.\n */\nfunction getElevatedEdgeZIndex({ sourceNode, targetNode, selected = false, zIndex, elevateOnSelect = false, }) {\n if (zIndex !== undefined) {\n return zIndex;\n }\n const edgeZ = elevateOnSelect && selected ? 1000 : 0;\n const nodeZ = Math.max(sourceNode.parentId || (elevateOnSelect && sourceNode.selected) ? sourceNode.internals.z : 0, targetNode.parentId || (elevateOnSelect && targetNode.selected) ? targetNode.internals.z : 0);\n return edgeZ + nodeZ;\n}\nfunction isEdgeVisible({ sourceNode, targetNode, width, height, transform }) {\n const edgeBox = getBoundsOfBoxes(nodeToBox(sourceNode), nodeToBox(targetNode));\n if (edgeBox.x === edgeBox.x2) {\n edgeBox.x2 += 1;\n }\n if (edgeBox.y === edgeBox.y2) {\n edgeBox.y2 += 1;\n }\n const viewRect = {\n x: -transform[0] / transform[2],\n y: -transform[1] / transform[2],\n width: width / transform[2],\n height: height / transform[2],\n };\n return getOverlappingArea(viewRect, boxToRect(edgeBox)) > 0;\n}\nconst getEdgeId = ({ source, sourceHandle, target, targetHandle }) => `xy-edge__${source}${sourceHandle || ''}-${target}${targetHandle || ''}`;\nconst connectionExists = (edge, edges) => {\n return edges.some((el) => el.source === edge.source &&\n el.target === edge.target &&\n (el.sourceHandle === edge.sourceHandle || (!el.sourceHandle && !edge.sourceHandle)) &&\n (el.targetHandle === edge.targetHandle || (!el.targetHandle && !edge.targetHandle)));\n};\n/**\n * This util is a convenience function to add a new Edge to an array of edges. It also performs some validation to make sure you don't add an invalid edge or duplicate an existing one.\n * @public\n * @param edgeParams - Either an `Edge` or a `Connection` you want to add.\n * @param edges - The array of all current edges.\n * @returns A new array of edges with the new edge added.\n *\n * @remarks If an edge with the same `target` and `source` already exists (and the same\n *`targetHandle` and `sourceHandle` if those are set), then this util won't add\n *a new edge even if the `id` property is different.\n *\n */\nconst addEdge = (edgeParams, edges) => {\n if (!edgeParams.source || !edgeParams.target) {\n devWarn('006', errorMessages['error006']());\n return edges;\n }\n let edge;\n if (isEdgeBase(edgeParams)) {\n edge = { ...edgeParams };\n }\n else {\n edge = {\n ...edgeParams,\n id: getEdgeId(edgeParams),\n };\n }\n if (connectionExists(edge, edges)) {\n return edges;\n }\n if (edge.sourceHandle === null) {\n delete edge.sourceHandle;\n }\n if (edge.targetHandle === null) {\n delete edge.targetHandle;\n }\n return edges.concat(edge);\n};\n/**\n * A handy utility to update an existing [`Edge`](/api-reference/types/edge) with new properties.\n *This searches your edge array for an edge with a matching `id` and updates its\n *properties with the connection you provide.\n * @public\n * @param oldEdge - The edge you want to update.\n * @param newConnection - The new connection you want to update the edge with.\n * @param edges - The array of all current edges.\n * @returns The updated edges array.\n *\n * @example\n * ```js\n *const onReconnect = useCallback(\n * (oldEdge: Edge, newConnection: Connection) => setEdges((els) => reconnectEdge(oldEdge, newConnection, els)),[]);\n *```\n */\nconst reconnectEdge = (oldEdge, newConnection, edges, options = { shouldReplaceId: true }) => {\n const { id: oldEdgeId, ...rest } = oldEdge;\n if (!newConnection.source || !newConnection.target) {\n devWarn('006', errorMessages['error006']());\n return edges;\n }\n const foundEdge = edges.find((e) => e.id === oldEdge.id);\n if (!foundEdge) {\n devWarn('007', errorMessages['error007'](oldEdgeId));\n return edges;\n }\n // Remove old edge and create the new edge with parameters of old edge.\n const edge = {\n ...rest,\n id: options.shouldReplaceId ? getEdgeId(newConnection) : oldEdgeId,\n source: newConnection.source,\n target: newConnection.target,\n sourceHandle: newConnection.sourceHandle,\n targetHandle: newConnection.targetHandle,\n };\n return edges.filter((e) => e.id !== oldEdgeId).concat(edge);\n};\n\n/**\n * Calculates the straight line path between two points.\n * @public\n * @returns A path string you can use in an SVG, the `labelX` and `labelY` position (center of path)\n * and `offsetX`, `offsetY` between source handle and label.\n *\n * - `path`: the path to use in an SVG `<path>` element.\n * - `labelX`: the `x` position you can use to render a label for this edge.\n * - `labelY`: the `y` position you can use to render a label for this edge.\n * - `offsetX`: the absolute difference between the source `x` position and the `x` position of the\n * middle of this path.\n * - `offsetY`: the absolute difference between the source `y` position and the `y` position of the\n * middle of this path.\n * @example\n * ```js\n * const source = { x: 0, y: 20 };\n * const target = { x: 150, y: 100 };\n *\n * const [path, labelX, labelY, offsetX, offsetY] = getStraightPath({\n * sourceX: source.x,\n * sourceY: source.y,\n * sourcePosition: Position.Right,\n * targetX: target.x,\n * targetY: target.y,\n * targetPosition: Position.Left,\n * });\n * ```\n * @remarks This function returns a tuple (aka a fixed-size array) to make it easier to work with multiple edge paths at once.\n */\nfunction getStraightPath({ sourceX, sourceY, targetX, targetY, }) {\n const [labelX, labelY, offsetX, offsetY] = getEdgeCenter({\n sourceX,\n sourceY,\n targetX,\n targetY,\n });\n return [`M ${sourceX},${sourceY}L ${targetX},${targetY}`, labelX, labelY, offsetX, offsetY];\n}\n\nconst handleDirections = {\n [Position.Left]: { x: -1, y: 0 },\n [Position.Right]: { x: 1, y: 0 },\n [Position.Top]: { x: 0, y: -1 },\n [Position.Bottom]: { x: 0, y: 1 },\n};\nconst getDirection = ({ source, sourcePosition = Position.Bottom, target, }) => {\n if (sourcePosition === Position.Left || sourcePosition === Position.Right) {\n return source.x < target.x ? { x: 1, y: 0 } : { x: -1, y: 0 };\n }\n return source.y < target.y ? { x: 0, y: 1 } : { x: 0, y: -1 };\n};\nconst distance = (a, b) => Math.sqrt(Math.pow(b.x - a.x, 2) + Math.pow(b.y - a.y, 2));\n/*\n * With this function we try to mimic an orthogonal edge routing behaviour\n * It's not as good as a real orthogonal edge routing, but it's faster and good enough as a default for step and smooth step edges\n */\nfunction getPoints({ source, sourcePosition = Position.Bottom, target, targetPosition = Position.Top, center, offset, stepPosition, }) {\n const sourceDir = handleDirections[sourcePosition];\n const targetDir = handleDirections[targetPosition];\n const sourceGapped = { x: source.x + sourceDir.x * offset, y: source.y + sourceDir.y * offset };\n const targetGapped = { x: target.x + targetDir.x * offset, y: target.y + targetDir.y * offset };\n const dir = getDirection({\n source: sourceGapped,\n sourcePosition,\n target: targetGapped,\n });\n const dirAccessor = dir.x !== 0 ? 'x' : 'y';\n const currDir = dir[dirAccessor];\n let points = [];\n let centerX, centerY;\n const sourceGapOffset = { x: 0, y: 0 };\n const targetGapOffset = { x: 0, y: 0 };\n const [, , defaultOffsetX, defaultOffsetY] = getEdgeCenter({\n sourceX: source.x,\n sourceY: source.y,\n targetX: target.x,\n targetY: target.y,\n });\n // opposite handle positions, default case\n if (sourceDir[dirAccessor] * targetDir[dirAccessor] === -1) {\n if (dirAccessor === 'x') {\n // Primary direction is horizontal, so stepPosition affects X coordinate\n centerX = center.x ?? (sourceGapped.x + (targetGapped.x - sourceGapped.x) * stepPosition);\n centerY = center.y ?? (sourceGapped.y + targetGapped.y) / 2;\n }\n else {\n // Primary direction is vertical, so stepPosition affects Y coordinate \n centerX = center.x ?? (sourceGapped.x + targetGapped.x) / 2;\n centerY = center.y ?? (sourceGapped.y + (targetGapped.y - sourceGapped.y) * stepPosition);\n }\n /*\n * --->\n * |\n * >---\n */\n const verticalSplit = [\n { x: centerX, y: sourceGapped.y },\n { x: centerX, y: targetGapped.y },\n ];\n /*\n * |\n * ---\n * |\n */\n const horizontalSplit = [\n { x: sourceGapped.x, y: centerY },\n { x: targetGapped.x, y: centerY },\n ];\n if (sourceDir[dirAccessor] === currDir) {\n points = dirAccessor === 'x' ? verticalSplit : horizontalSplit;\n }\n else {\n points = dirAccessor === 'x' ? horizontalSplit : verticalSplit;\n }\n }\n else {\n // sourceTarget means we take x from source and y from target, targetSource is the opposite\n const sourceTarget = [{ x: sourceGapped.x, y: targetGapped.y }];\n const targetSource = [{ x: targetGapped.x, y: sourceGapped.y }];\n // this handles edges with same handle positions\n if (dirAccessor === 'x') {\n points = sourceDir.x === currDir ? targetSource : sourceTarget;\n }\n else {\n points = sourceDir.y === currDir ? sourceTarget : targetSource;\n }\n if (sourcePosition === targetPosition) {\n const diff = Math.abs(source[dirAccessor] - target[dirAccessor]);\n // if an edge goes from right to right for example (sourcePosition === targetPosition) and the distance between source.x and target.x is less than the offset, the added point and the gapped source/target will overlap. This leads to a weird edge path. To avoid this we add a gapOffset to the source/target\n if (diff <= offset) {\n const gapOffset = Math.min(offset - 1, offset - diff);\n if (sourceDir[dirAccessor] === currDir) {\n sourceGapOffset[dirAccessor] = (sourceGapped[dirAccessor] > source[dirAccessor] ? -1 : 1) * gapOffset;\n }\n else {\n targetGapOffset[dirAccessor] = (targetGapped[dirAccessor] > target[dirAccessor] ? -1 : 1) * gapOffset;\n }\n }\n }\n // these are conditions for handling mixed handle positions like Right -> Bottom for example\n if (sourcePosition !== targetPosition) {\n const dirAccessorOpposite = dirAccessor === 'x' ? 'y' : 'x';\n const isSameDir = sourceDir[dirAccessor] === targetDir[dirAccessorOpposite];\n const sourceGtTargetOppo = sourceGapped[dirAccessorOpposite] > targetGapped[dirAccessorOpposite];\n const sourceLtTargetOppo = sourceGapped[dirAccessorOpposite] < targetGapped[dirAccessorOpposite];\n const flipSourceTarget = (sourceDir[dirAccessor] === 1 && ((!isSameDir && sourceGtTargetOppo) || (isSameDir && sourceLtTargetOppo))) ||\n (sourceDir[dirAccessor] !== 1 && ((!isSameDir && sourceLtTargetOppo) || (isSameDir && sourceGtTargetOppo)));\n if (flipSourceTarget) {\n points = dirAccessor === 'x' ? sourceTarget : targetSource;\n }\n }\n const sourceGapPoint = { x: sourceGapped.x + sourceGapOffset.x, y: sourceGapped.y + sourceGapOffset.y };\n const targetGapPoint = { x: targetGapped.x + targetGapOffset.x, y: targetGapped.y + targetGapOffset.y };\n const maxXDistance = Math.max(Math.abs(sourceGapPoint.x - points[0].x), Math.abs(targetGapPoint.x - points[0].x));\n const maxYDistance = Math.max(Math.abs(sourceGapPoint.y - points[0].y), Math.abs(targetGapPoint.y - points[0].y));\n // we want to place the label on the longest segment of the edge\n if (maxXDistance >= maxYDistance) {\n centerX = (sourceGapPoint.x + targetGapPoint.x) / 2;\n centerY = points[0].y;\n }\n else {\n centerX = points[0].x;\n centerY = (sourceGapPoint.y + targetGapPoint.y) / 2;\n }\n }\n const pathPoints = [\n source,\n { x: sourceGapped.x + sourceGapOffset.x, y: sourceGapped.y + sourceGapOffset.y },\n ...points,\n { x: targetGapped.x + targetGapOffset.x, y: targetGapped.y + targetGapOffset.y },\n target,\n ];\n return [pathPoints, centerX, centerY, defaultOffsetX, defaultOffsetY];\n}\nfunction getBend(a, b, c, size) {\n const bendSize = Math.min(distance(a, b) / 2, distance(b, c) / 2, size);\n const { x, y } = b;\n // no bend\n if ((a.x === x && x === c.x) || (a.y === y && y === c.y)) {\n return `L${x} ${y}`;\n }\n // first segment is horizontal\n if (a.y === y) {\n const xDir = a.x < c.x ? -1 : 1;\n const yDir = a.y < c.y ? 1 : -1;\n return `L ${x + bendSize * xDir},${y}Q ${x},${y} ${x},${y + bendSize * yDir}`;\n }\n const xDir = a.x < c.x ? 1 : -1;\n const yDir = a.y < c.y ? -1 : 1;\n return `L ${x},${y + bendSize * yDir}Q ${x},${y} ${x + bendSize * xDir},${y}`;\n}\n/**\n * The `getSmoothStepPath` util returns everything you need to render a stepped path\n * between two nodes. The `borderRadius` property can be used to choose how rounded\n * the corners of those steps are.\n * @public\n * @returns A path string you can use in an SVG, the `labelX` and `labelY` position (center of path)\n * and `offsetX`, `offsetY` between source handle and label.\n *\n * - `path`: the path to use in an SVG `<path>` element.\n * - `labelX`: the `x` position you can use to render a label for this edge.\n * - `labelY`: the `y` position you can use to render a label for this edge.\n * - `offsetX`: the absolute difference between the source `x` position and the `x` position of the\n * middle of this path.\n * - `offsetY`: the absolute difference between the source `y` position and the `y` position of the\n * middle of this path.\n * @example\n * ```js\n * const source = { x: 0, y: 20 };\n * const target = { x: 150, y: 100 };\n *\n * const [path, labelX, labelY, offsetX, offsetY] = getSmoothStepPath({\n * sourceX: source.x,\n * sourceY: source.y,\n * sourcePosition: Position.Right,\n * targetX: target.x,\n * targetY: target.y,\n * targetPosition: Position.Left,\n * });\n * ```\n * @remarks This function returns a tuple (aka a fixed-size array) to make it easier to work with multiple edge paths at once.\n */\nfunction getSmoothStepPath({ sourceX, sourceY, sourcePosition = Position.Bottom, targetX, targetY, targetPosition = Position.Top, borderRadius = 5, centerX, centerY, offset = 20, stepPosition = 0.5, }) {\n const [points, labelX, labelY, offsetX, offsetY] = getPoints({\n source: { x: sourceX, y: sourceY },\n sourcePosition,\n target: { x: targetX, y: targetY },\n targetPosition,\n center: { x: centerX, y: centerY },\n offset,\n stepPosition,\n });\n const path = points.reduce((res, p, i) => {\n let segment = '';\n if (i > 0 && i < points.length - 1) {\n segment = getBend(points[i - 1], p, points[i + 1], borderRadius);\n }\n else {\n segment = `${i === 0 ? 'M' : 'L'}${p.x} ${p.y}`;\n }\n res += segment;\n return res;\n }, '');\n return [path, labelX, labelY, offsetX, offsetY];\n}\n\nfunction isNodeInitialized(node) {\n return (node &&\n !!(node.internals.handleBounds || node.handles?.length) &&\n !!(node.measured.width || node.width || node.initialWidth));\n}\nfunction getEdgePosition(params) {\n const { sourceNode, targetNode } = params;\n if (!isNodeInitialized(sourceNode) || !isNodeInitialized(targetNode)) {\n return null;\n }\n const sourceHandleBounds = sourceNode.internals.handleBounds || toHandleBounds(sourceNode.handles);\n const targetHandleBounds = targetNode.internals.handleBounds || toHandleBounds(targetNode.handles);\n const sourceHandle = getHandle$1(sourceHandleBounds?.source ?? [], params.sourceHandle);\n const targetHandle = getHandle$1(\n // when connection type is loose we can define all handles as sources and connect source -> source\n params.connectionMode === ConnectionMode.Strict\n ? targetHandleBounds?.target ?? []\n : (targetHandleBounds?.target ?? []).concat(targetHandleBounds?.source ?? []), params.targetHandle);\n if (!sourceHandle || !targetHandle) {\n params.onError?.('008', errorMessages['error008'](!sourceHandle ? 'source' : 'target', {\n id: params.id,\n sourceHandle: params.sourceHandle,\n targetHandle: params.targetHandle,\n }));\n return null;\n }\n const sourcePosition = sourceHandle?.position || Position.Bottom;\n const targetPosition = targetHandle?.position || Position.Top;\n const source = getHandlePosition(sourceNode, sourceHandle, sourcePosition);\n const target = getHandlePosition(targetNode, targetHandle, targetPosition);\n return {\n sourceX: source.x,\n sourceY: source.y,\n targetX: target.x,\n targetY: target.y,\n sourcePosition,\n targetPosition,\n };\n}\nfunction toHandleBounds(handles) {\n if (!handles) {\n return null;\n }\n const source = [];\n const target = [];\n for (const handle of handles) {\n handle.width = handle.width ?? 1;\n handle.height = handle.height ?? 1;\n if (handle.type === 'source') {\n source.push(handle);\n }\n else if (handle.type === 'target') {\n target.push(handle);\n }\n }\n return {\n source,\n target,\n };\n}\nfunction getHandlePosition(node, handle, fallbackPosition = Position.Left, center = false) {\n const x = (handle?.x ?? 0) + node.internals.positionAbsolute.x;\n const y = (handle?.y ?? 0) + node.internals.positionAbsolute.y;\n const { width, height } = handle ?? getNodeDimensions(node);\n if (center) {\n return { x: x + width / 2, y: y + height / 2 };\n }\n const position = handle?.position ?? fallbackPosition;\n switch (position) {\n case Position.Top:\n return { x: x + width / 2, y };\n case Position.Right:\n return { x: x + width, y: y + height / 2 };\n case Position.Bottom:\n return { x: x + width / 2, y: y + height };\n case Position.Left:\n return { x, y: y + height / 2 };\n }\n}\nfunction getHandle$1(bounds, handleId) {\n if (!bounds) {\n return null;\n }\n // if no handleId is given, we use the first handle, otherwise we check for the id\n return (!handleId ? bounds[0] : bounds.find((d) => d.id === handleId)) || null;\n}\n\nfunction getMarkerId(marker, id) {\n if (!marker) {\n return '';\n }\n if (typeof marker === 'string') {\n return marker;\n }\n const idPrefix = id ? `${id}__` : '';\n return `${idPrefix}${Object.keys(marker)\n .sort()\n .map((key) => `${key}=${marker[key]}`)\n .join('&')}`;\n}\nfunction createMarkerIds(edges, { id, defaultColor, defaultMarkerStart, defaultMarkerEnd, }) {\n const ids = new Set();\n return edges\n .reduce((markers, edge) => {\n [edge.markerStart || defaultMarkerStart, edge.markerEnd || defaultMarkerEnd].forEach((marker) => {\n if (marker && typeof marker === 'object') {\n const markerId = getMarkerId(marker, id);\n if (!ids.has(markerId)) {\n markers.push({ id: markerId, color: marker.color || defaultColor, ...marker });\n ids.add(markerId);\n }\n }\n });\n return markers;\n }, [])\n .sort((a, b) => a.id.localeCompare(b.id));\n}\n\nfunction getNodeToolbarTransform(nodeRect, viewport, position, offset, align) {\n let alignmentOffset = 0.5;\n if (align === 'start') {\n alignmentOffset = 0;\n }\n else if (align === 'end') {\n alignmentOffset = 1;\n }\n /*\n * position === Position.Top\n * we set the x any y position of the toolbar based on the nodes position\n */\n let pos = [\n (nodeRect.x + nodeRect.width * alignmentOffset) * viewport.zoom + viewport.x,\n nodeRect.y * viewport.zoom + viewport.y - offset,\n ];\n // and than shift it based on the alignment. The shift values are in %.\n let shift = [-100 * alignmentOffset, -100];\n switch (position) {\n case Position.Right:\n pos = [\n (nodeRect.x + nodeRect.width) * viewport.zoom + viewport.x + offset,\n (nodeRect.y + nodeRect.height * alignmentOffset) * viewport.zoom + viewport.y,\n ];\n shift = [0, -100 * alignmentOffset];\n break;\n case Position.Bottom:\n pos[1] = (nodeRect.y + nodeRect.height) * viewport.zoom + viewport.y + offset;\n shift[1] = 0;\n break;\n case Position.Left:\n pos = [\n nodeRect.x * viewport.zoom + viewport.x - offset,\n (nodeRect.y + nodeRect.height * alignmentOffset) * viewport.zoom + viewport.y,\n ];\n shift = [-100, -100 * alignmentOffset];\n break;\n }\n return `translate(${pos[0]}px, ${pos[1]}px) translate(${shift[0]}%, ${shift[1]}%)`;\n}\n\nconst alignXToPercent = {\n left: 0,\n center: 50,\n right: 100,\n};\nconst alignYToPercent = {\n top: 0,\n center: 50,\n bottom: 100,\n};\nfunction getEdgeToolbarTransform(x, y, zoom, alignX = 'center', alignY = 'center') {\n return `translate(${x}px, ${y}px) scale(${1 / zoom}) translate(${-(alignXToPercent[alignX] ?? 50)}%, ${-(alignYToPercent[alignY] ?? 50)}%)`;\n}\n\nconst SELECTED_NODE_Z = 1000;\nconst ROOT_PARENT_Z_INCREMENT = 10;\nconst defaultOptions = {\n nodeOrigin: [0, 0],\n nodeExtent: infiniteExtent,\n elevateNodesOnSelect: true,\n defaults: {},\n};\nconst adoptUserNodesDefaultOptions = {\n ...defaultOptions,\n checkEquality: true,\n};\nfunction mergeObjects(base, incoming) {\n const result = { ...base };\n for (const key in incoming) {\n if (incoming[key] !== undefined) {\n // typecast is safe here, because we check for undefined\n result[key] = incoming[key];\n }\n }\n return result;\n}\nfunction updateAbsolutePositions(nodeLookup, parentLookup, options) {\n const _options = mergeObjects(defaultOptions, options);\n for (const node of nodeLookup.values()) {\n if (node.parentId) {\n updateChildNode(node, nodeLookup, parentLookup, _options);\n }\n else {\n const positionWithOrigin = getNodePositionWithOrigin(node, _options.nodeOrigin);\n const extent = isCoordinateExtent(node.extent) ? node.extent : _options.nodeExtent;\n const clampedPosition = clampPosition(positionWithOrigin, extent, getNodeDimensions(node));\n node.internals.positionAbsolute = clampedPosition;\n }\n }\n}\nfunction parseHandles(userNode, internalNode) {\n if (!userNode.handles) {\n return !userNode.measured ? undefined : internalNode?.internals.handleBounds;\n }\n const source = [];\n const target = [];\n for (const handle of userNode.handles) {\n const handleBounds = {\n id: handle.id,\n width: handle.width ?? 1,\n height: handle.height ?? 1,\n nodeId: userNode.id,\n x: handle.x,\n y: handle.y,\n position: handle.position,\n type: handle.type,\n };\n if (handle.type === 'source') {\n source.push(handleBounds);\n }\n else if (handle.type === 'target') {\n target.push(handleBounds);\n }\n }\n return {\n source,\n target,\n };\n}\nfunction adoptUserNodes(nodes, nodeLookup, parentLookup, options) {\n const _options = mergeObjects(adoptUserNodesDefaultOptions, options);\n let rootParentIndex = { i: -1 };\n let nodesInitialized = nodes.length > 0;\n const tmpLookup = new Map(nodeLookup);\n const selectedNodeZ = _options?.elevateNodesOnSelect ? SELECTED_NODE_Z : 0;\n nodeLookup.clear();\n parentLookup.clear();\n for (const userNode of nodes) {\n let internalNode = tmpLookup.get(userNode.id);\n if (_options.checkEquality && userNode === internalNode?.internals.userNode) {\n nodeLookup.set(userNode.id, internalNode);\n }\n else {\n const positionWithOrigin = getNodePositionWithOrigin(userNode, _options.nodeOrigin);\n const extent = isCoordinateExtent(userNode.extent) ? userNode.extent : _options.nodeExtent;\n const clampedPosition = clampPosition(positionWithOrigin, extent, getNodeDimensions(userNode));\n internalNode = {\n ..._options.defaults,\n ...userNode,\n measured: {\n width: userNode.measured?.width,\n height: userNode.measured?.height,\n },\n internals: {\n positionAbsolute: clampedPosition,\n // if user re-initializes the node or removes `measured` for whatever reason, we reset the handleBounds so that the node gets re-measured\n handleBounds: parseHandles(userNode, internalNode),\n z: calculateZ(userNode, selectedNodeZ),\n userNode,\n },\n };\n nodeLookup.set(userNode.id, internalNode);\n }\n if ((internalNode.measured === undefined ||\n internalNode.measured.width === undefined ||\n internalNode.measured.height === undefined) &&\n !internalNode.hidden) {\n nodesInitialized = false;\n }\n if (userNode.parentId) {\n updateChildNode(internalNode, nodeLookup, parentLookup, options, rootParentIndex);\n }\n }\n return nodesInitialized;\n}\nfunction updateParentLookup(node, parentLookup) {\n if (!node.parentId) {\n return;\n }\n const childNodes = parentLookup.get(node.parentId);\n if (childNodes) {\n childNodes.set(node.id, node);\n }\n else {\n parentLookup.set(node.parentId, new Map([[node.id, node]]));\n }\n}\n/**\n * Updates positionAbsolute and zIndex of a child node and the parentLookup.\n */\nfunction updateChildNode(node, nodeLookup, parentLookup, options, rootParentIndex) {\n const { elevateNodesOnSelect, nodeOrigin, nodeExtent } = mergeObjects(defaultOptions, options);\n const parentId = node.parentId;\n const parentNode = nodeLookup.get(parentId);\n if (!parentNode) {\n console.warn(`Parent node ${parentId} not found. Please make sure that parent nodes are in front of their child nodes in the nodes array.`);\n return;\n }\n updateParentLookup(node, parentLookup);\n // We just want to set the rootParentIndex for the first child\n if (rootParentIndex && !parentNode.parentId && parentNode.internals.rootParentIndex === undefined) {\n parentNode.internals.rootParentIndex = ++rootParentIndex.i;\n parentNode.internals.z = parentNode.internals.z + rootParentIndex.i * ROOT_PARENT_Z_INCREMENT;\n }\n // But we need to update rootParentIndex.i also when parent has not been updated\n if (rootParentIndex && parentNode.internals.rootParentIndex !== undefined) {\n rootParentIndex.i = parentNode.internals.rootParentIndex;\n }\n const selectedNodeZ = elevateNodesOnSelect ? SELECTED_NODE_Z : 0;\n const { x, y, z } = calculateChildXYZ(node, parentNode, nodeOrigin, nodeExtent, selectedNodeZ);\n const { positionAbsolute } = node.internals;\n const positionChanged = x !== positionAbsolute.x || y !== positionAbsolute.y;\n if (positionChanged || z !== node.internals.z) {\n // we create a new object to mark the node as updated\n nodeLookup.set(node.id, {\n ...node,\n internals: {\n ...node.internals,\n positionAbsolute: positionChanged ? { x, y } : positionAbsolute,\n z,\n },\n });\n }\n}\nfunction calculateZ(node, selectedNodeZ) {\n return (isNumeric(node.zIndex) ? node.zIndex : 0) + (node.selected ? selectedNodeZ : 0);\n}\nfunction calculateChildXYZ(childNode, parentNode, nodeOrigin, nodeExtent, selectedNodeZ) {\n const { x: parentX, y: parentY } = parentNode.internals.positionAbsolute;\n const childDimensions = getNodeDimensions(childNode);\n const positionWithOrigin = getNodePositionWithOrigin(childNode, nodeOrigin);\n const clampedPosition = isCoordinateExtent(childNode.extent)\n ? clampPosition(positionWithOrigin, childNode.extent, childDimensions)\n : positionWithOrigin;\n let absolutePosition = clampPosition({ x: parentX + clampedPosition.x, y: parentY + clampedPosition.y }, nodeExtent, childDimensions);\n if (childNode.extent === 'parent') {\n absolutePosition = clampPositionToParent(absolutePosition, childDimensions, parentNode);\n }\n const childZ = calculateZ(childNode, selectedNodeZ);\n const parentZ = parentNode.internals.z ?? 0;\n return {\n x: absolutePosition.x,\n y: absolutePosition.y,\n z: parentZ >= childZ ? parentZ + 1 : childZ,\n };\n}\nfunction handleExpandParent(children, nodeLookup, parentLookup, nodeOrigin = [0, 0]) {\n const changes = [];\n const parentExpansions = new Map();\n // determine the expanded rectangle the child nodes would take for each parent\n for (const child of children) {\n const parent = nodeLookup.get(child.parentId);\n if (!parent) {\n continue;\n }\n const parentRect = parentExpansions.get(child.parentId)?.expandedRect ?? nodeToRect(parent);\n const expandedRect = getBoundsOfRects(parentRect, child.rect);\n parentExpansions.set(child.parentId, { expandedRect, parent });\n }\n if (parentExpansions.size > 0) {\n parentExpansions.forEach(({ expandedRect, parent }, parentId) => {\n // determine the position & dimensions of the parent\n const positionAbsolute = parent.internals.positionAbsolute;\n const dimensions = getNodeDimensions(parent);\n const origin = parent.origin ?? nodeOrigin;\n // determine how much the parent expands in width and position\n const xChange = expandedRect.x < positionAbsolute.x ? Math.round(Math.abs(positionAbsolute.x - expandedRect.x)) : 0;\n const yChange = expandedRect.y < positionAbsolute.y ? Math.round(Math.abs(positionAbsolute.y - expandedRect.y)) : 0;\n const newWidth = Math.max(dimensions.width, Math.round(expandedRect.width));\n const newHeight = Math.max(dimensions.height, Math.round(expandedRect.height));\n const widthChange = (newWidth - dimensions.width) * origin[0];\n const heightChange = (newHeight - dimensions.height) * origin[1];\n // We need to correct the position of the parent node if the origin is not [0,0]\n if (xChange > 0 || yChange > 0 || widthChange || heightChange) {\n changes.push({\n id: parentId,\n type: 'position',\n position: {\n x: parent.position.x - xChange + widthChange,\n y: parent.position.y - yChange + heightChange,\n },\n });\n /*\n * We move all child nodes in the oppsite direction\n * so the x,y changes of the parent do not move the children\n */\n parentLookup.get(parentId)?.forEach((childNode) => {\n if (!children.some((child) => child.id === childNode.id)) {\n changes.push({\n id: childNode.id,\n type: 'position',\n position: {\n x: childNode.position.x + xChange,\n y: childNode.position.y + yChange,\n },\n });\n }\n });\n }\n // We need to correct the dimensions of the parent node if the origin is not [0,0]\n if (dimensions.width < expandedRect.width || dimensions.height < expandedRect.height || xChange || yChange) {\n changes.push({\n id: parentId,\n type: 'dimensions',\n setAttributes: true,\n dimensions: {\n width: newWidth + (xChange ? origin[0] * xChange - widthChange : 0),\n height: newHeight + (yChange ? origin[1] * yChange - heightChange : 0),\n },\n });\n }\n });\n }\n return changes;\n}\nfunction updateNodeInternals(updates, nodeLookup, parentLookup, domNode, nodeOrigin, nodeExtent) {\n const viewportNode = domNode?.querySelector('.xyflow__viewport');\n let updatedInternals = false;\n if (!viewportNode) {\n return { changes: [], updatedInternals };\n }\n const changes = [];\n const style = window.getComputedStyle(viewportNode);\n const { m22: zoom } = new window.DOMMatrixReadOnly(style.transform);\n // in this array we collect nodes, that might trigger changes (like expanding parent)\n const parentExpandChildren = [];\n for (const update of updates.values()) {\n const node = nodeLookup.get(update.id);\n if (!node) {\n continue;\n }\n if (node.hidden) {\n nodeLookup.set(node.id, {\n ...node,\n internals: {\n ...node.internals,\n handleBounds: undefined,\n },\n });\n updatedInternals = true;\n continue;\n }\n const dimensions = getDimensions(update.nodeElement);\n const dimensionChanged = node.measured.width !== dimensions.width || node.measured.height !== dimensions.height;\n const doUpdate = !!(dimensions.width &&\n dimensions.height &&\n (dimensionChanged || !node.internals.handleBounds || update.force));\n if (doUpdate) {\n const nodeBounds = update.nodeElement.getBoundingClientRect();\n const extent = isCoordinateExtent(node.extent) ? node.extent : nodeExtent;\n let { positionAbsolute } = node.internals;\n if (node.parentId && node.extent === 'parent') {\n positionAbsolute = clampPositionToParent(positionAbsolute, dimensions, nodeLookup.get(node.parentId));\n }\n else if (extent) {\n positionAbsolute = clampPosition(positionAbsolute, extent, dimensions);\n }\n const newNode = {\n ...node,\n measured: dimensions,\n internals: {\n ...node.internals,\n positionAbsolute,\n handleBounds: {\n source: getHandleBounds('source', update.nodeElement, nodeBounds, zoom, node.id),\n target: getHandleBounds('target', update.nodeElement, nodeBounds, zoom, node.id),\n },\n },\n };\n nodeLookup.set(node.id, newNode);\n if (node.parentId) {\n updateChildNode(newNode, nodeLookup, parentLookup, { nodeOrigin });\n }\n updatedInternals = true;\n if (dimensionChanged) {\n changes.push({\n id: node.id,\n type: 'dimensions',\n dimensions,\n });\n if (node.expandParent && node.parentId) {\n parentExpandChildren.push({\n id: node.id,\n parentId: node.parentId,\n rect: nodeToRect(newNode, nodeOrigin),\n });\n }\n }\n }\n }\n if (parentExpandChildren.length > 0) {\n const parentExpandChanges = handleExpandParent(parentExpandChildren, nodeLookup, parentLookup, nodeOrigin);\n changes.push(...parentExpandChanges);\n }\n return { changes, updatedInternals };\n}\nasync function panBy({ delta, panZoom, transform, translateExtent, width, height, }) {\n if (!panZoom || (!delta.x && !delta.y)) {\n return Promise.resolve(false);\n }\n const nextViewport = await panZoom.setViewportConstrained({\n x: transform[0] + delta.x,\n y: transform[1] + delta.y,\n zoom: transform[2],\n }, [\n [0, 0],\n [width, height],\n ], translateExtent);\n const transformChanged = !!nextViewport &&\n (nextViewport.x !== transform[0] || nextViewport.y !== transform[1] || nextViewport.k !== transform[2]);\n return Promise.resolve(transformChanged);\n}\n/**\n * this function adds the connection to the connectionLookup\n * at the following keys: nodeId-type-handleId, nodeId-type and nodeId\n * @param type type of the connection\n * @param connection connection that should be added to the lookup\n * @param connectionKey at which key the connection should be added\n * @param connectionLookup reference to the connection lookup\n * @param nodeId nodeId of the connection\n * @param handleId handleId of the conneciton\n */\nfunction addConnectionToLookup(type, connection, connectionKey, connectionLookup, nodeId, handleId) {\n /*\n * We add the connection to the connectionLookup at the following keys\n * 1. nodeId, 2. nodeId-type, 3. nodeId-type-handleId\n * If the key already exists, we add the connection to the existing map\n */\n let key = nodeId;\n const nodeMap = connectionLookup.get(key) || new Map();\n connectionLookup.set(key, nodeMap.set(connectionKey, connection));\n key = `${nodeId}-${type}`;\n const typeMap = connectionLookup.get(key) || new Map();\n connectionLookup.set(key, typeMap.set(connectionKey, connection));\n if (handleId) {\n key = `${nodeId}-${type}-${handleId}`;\n const handleMap = connectionLookup.get(key) || new Map();\n connectionLookup.set(key, handleMap.set(connectionKey, connection));\n }\n}\nfunction updateConnectionLookup(connectionLookup, edgeLookup, edges) {\n connectionLookup.clear();\n edgeLookup.clear();\n for (const edge of edges) {\n const { source: sourceNode, target: targetNode, sourceHandle = null, targetHandle = null } = edge;\n const connection = { edgeId: edge.id, source: sourceNode, target: targetNode, sourceHandle, targetHandle };\n const sourceKey = `${sourceNode}-${sourceHandle}--${targetNode}-${targetHandle}`;\n const targetKey = `${targetNode}-${targetHandle}--${sourceNode}-${sourceHandle}`;\n addConnectionToLookup('source', connection, targetKey, connectionLookup, sourceNode, sourceHandle);\n addConnectionToLookup('target', connection, sourceKey, connectionLookup, targetNode, targetHandle);\n edgeLookup.set(edge.id, edge);\n }\n}\n\nfunction shallowNodeData(a, b) {\n if (a === null || b === null) {\n return false;\n }\n const _a = Array.isArray(a) ? a : [a];\n const _b = Array.isArray(b) ? b : [b];\n if (_a.length !== _b.length) {\n return false;\n }\n for (let i = 0; i < _a.length; i++) {\n if (_a[i].id !== _b[i].id || _a[i].type !== _b[i].type || !Object.is(_a[i].data, _b[i].data)) {\n return false;\n }\n }\n return true;\n}\n\nfunction isParentSelected(node, nodeLookup) {\n if (!node.parentId) {\n return false;\n }\n const parentNode = nodeLookup.get(node.parentId);\n if (!parentNode) {\n return false;\n }\n if (parentNode.selected) {\n return true;\n }\n return isParentSelected(parentNode, nodeLookup);\n}\nfunction hasSelector(target, selector, domNode) {\n let current = target;\n do {\n if (current?.matches?.(selector))\n return true;\n if (current === domNode)\n return false;\n current = current?.parentElement;\n } while (current);\n return false;\n}\n// looks for all selected nodes and created a NodeDragItem for each of them\nfunction getDragItems(nodeLookup, nodesDraggable, mousePos, nodeId) {\n const dragItems = new Map();\n for (const [id, node] of nodeLookup) {\n if ((node.selected || node.id === nodeId) &&\n (!node.parentId || !isParentSelected(node, nodeLookup)) &&\n (node.draggable || (nodesDraggable && typeof node.draggable === 'undefined'))) {\n const internalNode = nodeLookup.get(id);\n if (internalNode) {\n dragItems.set(id, {\n id,\n position: internalNode.position || { x: 0, y: 0 },\n distance: {\n x: mousePos.x - internalNode.internals.positionAbsolute.x,\n y: mousePos.y - internalNode.internals.positionAbsolute.y,\n },\n extent: internalNode.extent,\n parentId: internalNode.parentId,\n origin: internalNode.origin,\n expandParent: internalNode.expandParent,\n internals: {\n positionAbsolute: internalNode.internals.positionAbsolute || { x: 0, y: 0 },\n },\n measured: {\n width: internalNode.measured.width ?? 0,\n height: internalNode.measured.height ?? 0,\n },\n });\n }\n }\n }\n return dragItems;\n}\n/*\n * returns two params:\n * 1. the dragged node (or the first of the list, if we are dragging a node selection)\n * 2. array of selected nodes (for multi selections)\n */\nfunction getEventHandlerParams({ nodeId, dragItems, nodeLookup, dragging = true, }) {\n const nodesFromDragItems = [];\n for (const [id, dragItem] of dragItems) {\n const node = nodeLookup.get(id)?.internals.userNode;\n if (node) {\n nodesFromDragItems.push({\n ...node,\n position: dragItem.position,\n dragging,\n });\n }\n }\n if (!nodeId) {\n return [nodesFromDragItems[0], nodesFromDragItems];\n }\n const node = nodeLookup.get(nodeId)?.internals.userNode;\n return [\n !node\n ? nodesFromDragItems[0]\n : {\n ...node,\n position: dragItems.get(nodeId)?.position || node.position,\n dragging,\n },\n nodesFromDragItems,\n ];\n}\n/**\n * If a selection is being dragged we want to apply the same snap offset to all nodes in the selection.\n * This function calculates the snap offset based on the first node in the selection.\n */\nfunction calculateSnapOffset({ dragItems, snapGrid, x, y, }) {\n const refDragItem = dragItems.values().next().value;\n if (!refDragItem) {\n return null;\n }\n const refPos = {\n x: x - refDragItem.distance.x,\n y: y - refDragItem.distance.y,\n };\n const refPosSnapped = snapPosition(refPos, snapGrid);\n return {\n x: refPosSnapped.x - refPos.x,\n y: refPosSnapped.y - refPos.y,\n };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction XYDrag({ onNodeMouseDown, getStoreItems, onDragStart, onDrag, onDragStop, }) {\n let lastPos = { x: null, y: null };\n let autoPanId = 0;\n let dragItems = new Map();\n let autoPanStarted = false;\n let mousePosition = { x: 0, y: 0 };\n let containerBounds = null;\n let dragStarted = false;\n let d3Selection = null;\n let abortDrag = false; // prevents unintentional dragging on multitouch\n let nodePositionsChanged = false;\n // we store the last drag event to be able to use it in the update function\n let dragEvent = null;\n // public functions\n function update({ noDragClassName, handleSelector, domNode, isSelectable, nodeId, nodeClickDistance = 0, }) {\n d3Selection = select(domNode);\n function updateNodes({ x, y }) {\n const { nodeLookup, nodeExtent, snapGrid, snapToGrid, nodeOrigin, onNodeDrag, onSelectionDrag, onError, updateNodePositions, } = getStoreItems();\n lastPos = { x, y };\n let hasChange = false;\n const isMultiDrag = dragItems.size > 1;\n const nodesBox = isMultiDrag && nodeExtent ? rectToBox(getInternalNodesBounds(dragItems)) : null;\n const multiDragSnapOffset = isMultiDrag && snapToGrid\n ? calculateSnapOffset({\n dragItems,\n snapGrid,\n x,\n y,\n })\n : null;\n for (const [id, dragItem] of dragItems) {\n /*\n * if the node is not in the nodeLookup anymore, it was probably deleted while dragging\n */\n if (!nodeLookup.has(id)) {\n continue;\n }\n let nextPosition = { x: x - dragItem.distance.x, y: y - dragItem.distance.y };\n if (snapToGrid) {\n nextPosition = multiDragSnapOffset\n ? {\n x: Math.round(nextPosition.x + multiDragSnapOffset.x),\n y: Math.round(nextPosition.y + multiDragSnapOffset.y),\n }\n : snapPosition(nextPosition, snapGrid);\n }\n let adjustedNodeExtent = null;\n if (isMultiDrag && nodeExtent && !dragItem.extent && nodesBox) {\n const { positionAbsolute } = dragItem.internals;\n const x1 = positionAbsolute.x - nodesBox.x + nodeExtent[0][0];\n const x2 = positionAbsolute.x + dragItem.measured.width - nodesBox.x2 + nodeExtent[1][0];\n const y1 = positionAbsolute.y - nodesBox.y + nodeExtent[0][1];\n const y2 = positionAbsolute.y + dragItem.measured.height - nodesBox.y2 + nodeExtent[1][1];\n adjustedNodeExtent = [\n [x1, y1],\n [x2, y2],\n ];\n }\n const { position, positionAbsolute } = calculateNodePosition({\n nodeId: id,\n nextPosition,\n nodeLookup,\n nodeExtent: adjustedNodeExtent ? adjustedNodeExtent : nodeExtent,\n nodeOrigin,\n onError,\n });\n // we want to make sure that we only fire a change event when there is a change\n hasChange = hasChange || dragItem.position.x !== position.x || dragItem.position.y !== position.y;\n dragItem.position = position;\n dragItem.internals.positionAbsolute = positionAbsolute;\n }\n nodePositionsChanged = nodePositionsChanged || hasChange;\n if (!hasChange) {\n return;\n }\n updateNodePositions(dragItems, true);\n if (dragEvent && (onDrag || onNodeDrag || (!nodeId && onSelectionDrag))) {\n const [currentNode, currentNodes] = getEventHandlerParams({\n nodeId,\n dragItems,\n nodeLookup,\n });\n onDrag?.(dragEvent, dragItems, currentNode, currentNodes);\n onNodeDrag?.(dragEvent, currentNode, currentNodes);\n if (!nodeId) {\n onSelectionDrag?.(dragEvent, currentNodes);\n }\n }\n }\n async function autoPan() {\n if (!containerBounds) {\n return;\n }\n const { transform, panBy, autoPanSpeed, autoPanOnNodeDrag } = getStoreItems();\n if (!autoPanOnNodeDrag) {\n autoPanStarted = false;\n cancelAnimationFrame(autoPanId);\n return;\n }\n const [xMovement, yMovement] = calcAutoPan(mousePosition, containerBounds, autoPanSpeed);\n if (xMovement !== 0 || yMovement !== 0) {\n lastPos.x = (lastPos.x ?? 0) - xMovement / transform[2];\n lastPos.y = (lastPos.y ?? 0) - yMovement / transform[2];\n if (await panBy({ x: xMovement, y: yMovement })) {\n updateNodes(lastPos);\n }\n }\n autoPanId = requestAnimationFrame(autoPan);\n }\n function startDrag(event) {\n const { nodeLookup, multiSelectionActive, nodesDraggable, transform, snapGrid, snapToGrid, selectNodesOnDrag, onNodeDragStart, onSelectionDragStart, unselectNodesAndEdges, } = getStoreItems();\n dragStarted = true;\n if ((!selectNodesOnDrag || !isSelectable) && !multiSelectionActive && nodeId) {\n if (!nodeLookup.get(nodeId)?.selected) {\n // we need to reset selected nodes when selectNodesOnDrag=false\n unselectNodesAndEdges();\n }\n }\n if (isSelectable && selectNodesOnDrag && nodeId) {\n onNodeMouseDown?.(nodeId);\n }\n const pointerPos = getPointerPosition(event.sourceEvent, { transform, snapGrid, snapToGrid, containerBounds });\n lastPos = pointerPos;\n dragItems = getDragItems(nodeLookup, nodesDraggable, pointerPos, nodeId);\n if (dragItems.size > 0 && (onDragStart || onNodeDragStart || (!nodeId && onSelectionDragStart))) {\n const [currentNode, currentNodes] = getEventHandlerParams({\n nodeId,\n dragItems,\n nodeLookup,\n });\n onDragStart?.(event.sourceEvent, dragItems, currentNode, currentNodes);\n onNodeDragStart?.(event.sourceEvent, currentNode, currentNodes);\n if (!nodeId) {\n onSelectionDragStart?.(event.sourceEvent, currentNodes);\n }\n }\n }\n const d3DragInstance = drag()\n .clickDistance(nodeClickDistance)\n .on('start', (event) => {\n const { domNode, nodeDragThreshold, transform, snapGrid, snapToGrid } = getStoreItems();\n containerBounds = domNode?.getBoundingClientRect() || null;\n abortDrag = false;\n nodePositionsChanged = false;\n dragEvent = event.sourceEvent;\n if (nodeDragThreshold === 0) {\n startDrag(event);\n }\n const pointerPos = getPointerPosition(event.sourceEvent, { transform, snapGrid, snapToGrid, containerBounds });\n lastPos = pointerPos;\n mousePosition = getEventPosition(event.sourceEvent, containerBounds);\n })\n .on('drag', (event) => {\n const { autoPanOnNodeDrag, transform, snapGrid, snapToGrid, nodeDragThreshold, nodeLookup } = getStoreItems();\n const pointerPos = getPointerPosition(event.sourceEvent, { transform, snapGrid, snapToGrid, containerBounds });\n dragEvent = event.sourceEvent;\n if ((event.sourceEvent.type === 'touchmove' && event.sourceEvent.touches.length > 1) ||\n // if user deletes a node while dragging, we need to abort the drag to prevent errors\n (nodeId && !nodeLookup.has(nodeId))) {\n abortDrag = true;\n }\n if (abortDrag) {\n return;\n }\n if (!autoPanStarted && autoPanOnNodeDrag && dragStarted) {\n autoPanStarted = true;\n autoPan();\n }\n if (!dragStarted) {\n // Calculate distance in client coordinates for consistent drag threshold behavior across zoom levels\n const currentMousePosition = getEventPosition(event.sourceEvent, containerBounds);\n const x = currentMousePosition.x - mousePosition.x;\n const y = currentMousePosition.y - mousePosition.y;\n const distance = Math.sqrt(x * x + y * y);\n if (distance > nodeDragThreshold) {\n startDrag(event);\n }\n }\n // skip events without movement\n if ((lastPos.x !== pointerPos.xSnapped || lastPos.y !== pointerPos.ySnapped) && dragItems && dragStarted) {\n mousePosition = getEventPosition(event.sourceEvent, containerBounds);\n updateNodes(pointerPos);\n }\n })\n .on('end', (event) => {\n if (!dragStarted || abortDrag) {\n return;\n }\n autoPanStarted = false;\n dragStarted = false;\n cancelAnimationFrame(autoPanId);\n if (dragItems.size > 0) {\n const { nodeLookup, updateNodePositions, onNodeDragStop, onSelectionDragStop } = getStoreItems();\n if (nodePositionsChanged) {\n updateNodePositions(dragItems, false);\n nodePositionsChanged = false;\n }\n if (onDragStop || onNodeDragStop || (!nodeId && onSelectionDragStop)) {\n const [currentNode, currentNodes] = getEventHandlerParams({\n nodeId,\n dragItems,\n nodeLookup,\n dragging: false,\n });\n onDragStop?.(event.sourceEvent, dragItems, currentNode, currentNodes);\n onNodeDragStop?.(event.sourceEvent, currentNode, currentNodes);\n if (!nodeId) {\n onSelectionDragStop?.(event.sourceEvent, currentNodes);\n }\n }\n }\n })\n .filter((event) => {\n const target = event.target;\n const isDraggable = !event.button &&\n (!noDragClassName || !hasSelector(target, `.${noDragClassName}`, domNode)) &&\n (!handleSelector || hasSelector(target, handleSelector, domNode));\n return isDraggable;\n });\n d3Selection.call(d3DragInstance);\n }\n function destroy() {\n d3Selection?.on('.drag', null);\n }\n return {\n update,\n destroy,\n };\n}\n\nfunction getNodesWithinDistance(position, nodeLookup, distance) {\n const nodes = [];\n const rect = {\n x: position.x - distance,\n y: position.y - distance,\n width: distance * 2,\n height: distance * 2,\n };\n for (const node of nodeLookup.values()) {\n if (getOverlappingArea(rect, nodeToRect(node)) > 0) {\n nodes.push(node);\n }\n }\n return nodes;\n}\n/*\n * this distance is used for the area around the user pointer\n * while doing a connection for finding the closest nodes\n */\nconst ADDITIONAL_DISTANCE = 250;\nfunction getClosestHandle(position, connectionRadius, nodeLookup, fromHandle) {\n let closestHandles = [];\n let minDistance = Infinity;\n const closeNodes = getNodesWithinDistance(position, nodeLookup, connectionRadius + ADDITIONAL_DISTANCE);\n for (const node of closeNodes) {\n const allHandles = [...(node.internals.handleBounds?.source ?? []), ...(node.internals.handleBounds?.target ?? [])];\n for (const handle of allHandles) {\n // if the handle is the same as the fromHandle we skip it\n if (fromHandle.nodeId === handle.nodeId && fromHandle.type === handle.type && fromHandle.id === handle.id) {\n continue;\n }\n // determine absolute position of the handle\n const { x, y } = getHandlePosition(node, handle, handle.position, true);\n const distance = Math.sqrt(Math.pow(x - position.x, 2) + Math.pow(y - position.y, 2));\n if (distance > connectionRadius) {\n continue;\n }\n if (distance < minDistance) {\n closestHandles = [{ ...handle, x, y }];\n minDistance = distance;\n }\n else if (distance === minDistance) {\n // when multiple handles are on the same distance we collect all of them\n closestHandles.push({ ...handle, x, y });\n }\n }\n }\n if (!closestHandles.length) {\n return null;\n }\n // when multiple handles overlay each other we prefer the opposite handle\n if (closestHandles.length > 1) {\n const oppositeHandleType = fromHandle.type === 'source' ? 'target' : 'source';\n return closestHandles.find((handle) => handle.type === oppositeHandleType) ?? closestHandles[0];\n }\n return closestHandles[0];\n}\nfunction getHandle(nodeId, handleType, handleId, nodeLookup, connectionMode, withAbsolutePosition = false) {\n const node = nodeLookup.get(nodeId);\n if (!node) {\n return null;\n }\n const handles = connectionMode === 'strict'\n ? node.internals.handleBounds?.[handleType]\n : [...(node.internals.handleBounds?.source ?? []), ...(node.internals.handleBounds?.target ?? [])];\n const handle = (handleId ? handles?.find((h) => h.id === handleId) : handles?.[0]) ?? null;\n return handle && withAbsolutePosition\n ? { ...handle, ...getHandlePosition(node, handle, handle.position, true) }\n : handle;\n}\nfunction getHandleType(edgeUpdaterType, handleDomNode) {\n if (edgeUpdaterType) {\n return edgeUpdaterType;\n }\n else if (handleDomNode?.classList.contains('target')) {\n return 'target';\n }\n else if (handleDomNode?.classList.contains('source')) {\n return 'source';\n }\n return null;\n}\nfunction isConnectionValid(isInsideConnectionRadius, isHandleValid) {\n let isValid = null;\n if (isHandleValid) {\n isValid = true;\n }\n else if (isInsideConnectionRadius && !isHandleValid) {\n isValid = false;\n }\n return isValid;\n}\n\nconst alwaysValid = () => true;\nfunction onPointerDown(event, { connectionMode, connectionRadius, handleId, nodeId, edgeUpdaterType, isTarget, domNode, nodeLookup, lib, autoPanOnConnect, flowId, panBy, cancelConnection, onConnectStart, onConnect, onConnectEnd, isValidConnection = alwaysValid, onReconnectEnd, updateConnection, getTransform, getFromHandle, autoPanSpeed, dragThreshold = 1, handleDomNode, }) {\n // when xyflow is used inside a shadow root we can't use document\n const doc = getHostForElement(event.target);\n let autoPanId = 0;\n let closestHandle;\n const { x, y } = getEventPosition(event);\n const handleType = getHandleType(edgeUpdaterType, handleDomNode);\n const containerBounds = domNode?.getBoundingClientRect();\n let connectionStarted = false;\n if (!containerBounds || !handleType) {\n return;\n }\n const fromHandleInternal = getHandle(nodeId, handleType, handleId, nodeLookup, connectionMode);\n if (!fromHandleInternal) {\n return;\n }\n let position = getEventPosition(event, containerBounds);\n let autoPanStarted = false;\n let connection = null;\n let isValid = false;\n let resultHandleDomNode = null;\n // when the user is moving the mouse close to the edge of the canvas while connecting we move the canvas\n function autoPan() {\n if (!autoPanOnConnect || !containerBounds) {\n return;\n }\n const [x, y] = calcAutoPan(position, containerBounds, autoPanSpeed);\n panBy({ x, y });\n autoPanId = requestAnimationFrame(autoPan);\n }\n // Stays the same for all consecutive pointermove events\n const fromHandle = {\n ...fromHandleInternal,\n nodeId,\n type: handleType,\n position: fromHandleInternal.position,\n };\n const fromNodeInternal = nodeLookup.get(nodeId);\n const from = getHandlePosition(fromNodeInternal, fromHandle, Position.Left, true);\n let previousConnection = {\n inProgress: true,\n isValid: null,\n from,\n fromHandle,\n fromPosition: fromHandle.position,\n fromNode: fromNodeInternal,\n to: position,\n toHandle: null,\n toPosition: oppositePosition[fromHandle.position],\n toNode: null,\n };\n function startConnection() {\n connectionStarted = true;\n updateConnection(previousConnection);\n onConnectStart?.(event, { nodeId, handleId, handleType });\n }\n if (dragThreshold === 0) {\n startConnection();\n }\n function onPointerMove(event) {\n if (!connectionStarted) {\n const { x: evtX, y: evtY } = getEventPosition(event);\n const dx = evtX - x;\n const dy = evtY - y;\n const nextConnectionStarted = dx * dx + dy * dy > dragThreshold * dragThreshold;\n if (!nextConnectionStarted) {\n return;\n }\n startConnection();\n }\n if (!getFromHandle() || !fromHandle) {\n onPointerUp(event);\n return;\n }\n const transform = getTransform();\n position = getEventPosition(event, containerBounds);\n closestHandle = getClosestHandle(pointToRendererPoint(position, transform, false, [1, 1]), connectionRadius, nodeLookup, fromHandle);\n if (!autoPanStarted) {\n autoPan();\n autoPanStarted = true;\n }\n const result = isValidHandle(event, {\n handle: closestHandle,\n connectionMode,\n fromNodeId: nodeId,\n fromHandleId: handleId,\n fromType: isTarget ? 'target' : 'source',\n isValidConnection,\n doc,\n lib,\n flowId,\n nodeLookup,\n });\n resultHandleDomNode = result.handleDomNode;\n connection = result.connection;\n isValid = isConnectionValid(!!closestHandle, result.isValid);\n const newConnection = {\n // from stays the same\n ...previousConnection,\n isValid,\n to: result.toHandle && isValid\n ? rendererPointToPoint({ x: result.toHandle.x, y: result.toHandle.y }, transform)\n : position,\n toHandle: result.toHandle,\n toPosition: isValid && result.toHandle ? result.toHandle.position : oppositePosition[fromHandle.position],\n toNode: result.toHandle ? nodeLookup.get(result.toHandle.nodeId) : null,\n };\n /*\n * we don't want to trigger an update when the connection\n * is snapped to the same handle as before\n */\n if (isValid &&\n closestHandle &&\n previousConnection.toHandle &&\n newConnection.toHandle &&\n previousConnection.toHandle.type === newConnection.toHandle.type &&\n previousConnection.toHandle.nodeId === newConnection.toHandle.nodeId &&\n previousConnection.toHandle.id === newConnection.toHandle.id &&\n previousConnection.to.x === newConnection.to.x &&\n previousConnection.to.y === newConnection.to.y) {\n return;\n }\n updateConnection(newConnection);\n previousConnection = newConnection;\n }\n function onPointerUp(event) {\n // Prevent multi-touch aborting connection\n if ('touches' in event && event.touches.length > 0) {\n return;\n }\n if (connectionStarted) {\n if ((closestHandle || resultHandleDomNode) && connection && isValid) {\n onConnect?.(connection);\n }\n /*\n * it's important to get a fresh reference from the store here\n * in order to get the latest state of onConnectEnd\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { inProgress, ...connectionState } = previousConnection;\n const finalConnectionState = {\n ...connectionState,\n toPosition: previousConnection.toHandle ? previousConnection.toPosition : null,\n };\n onConnectEnd?.(event, finalConnectionState);\n if (edgeUpdaterType) {\n onReconnectEnd?.(event, finalConnectionState);\n }\n }\n cancelConnection();\n cancelAnimationFrame(autoPanId);\n autoPanStarted = false;\n isValid = false;\n connection = null;\n resultHandleDomNode = null;\n doc.removeEventListener('mousemove', onPointerMove);\n doc.removeEventListener('mouseup', onPointerUp);\n doc.removeEventListener('touchmove', onPointerMove);\n doc.removeEventListener('touchend', onPointerUp);\n }\n doc.addEventListener('mousemove', onPointerMove);\n doc.addEventListener('mouseup', onPointerUp);\n doc.addEventListener('touchmove', onPointerMove);\n doc.addEventListener('touchend', onPointerUp);\n}\n// checks if and returns connection in fom of an object { source: 123, target: 312 }\nfunction isValidHandle(event, { handle, connectionMode, fromNodeId, fromHandleId, fromType, doc, lib, flowId, isValidConnection = alwaysValid, nodeLookup, }) {\n const isTarget = fromType === 'target';\n const handleDomNode = handle\n ? doc.querySelector(`.${lib}-flow__handle[data-id=\"${flowId}-${handle?.nodeId}-${handle?.id}-${handle?.type}\"]`)\n : null;\n const { x, y } = getEventPosition(event);\n const handleBelow = doc.elementFromPoint(x, y);\n /*\n * we always want to prioritize the handle below the mouse cursor over the closest distance handle,\n * because it could be that the center of another handle is closer to the mouse pointer than the handle below the cursor\n */\n const handleToCheck = handleBelow?.classList.contains(`${lib}-flow__handle`) ? handleBelow : handleDomNode;\n const result = {\n handleDomNode: handleToCheck,\n isValid: false,\n connection: null,\n toHandle: null,\n };\n if (handleToCheck) {\n const handleType = getHandleType(undefined, handleToCheck);\n const handleNodeId = handleToCheck.getAttribute('data-nodeid');\n const handleId = handleToCheck.getAttribute('data-handleid');\n const connectable = handleToCheck.classList.contains('connectable');\n const connectableEnd = handleToCheck.classList.contains('connectableend');\n if (!handleNodeId || !handleType) {\n return result;\n }\n const connection = {\n source: isTarget ? handleNodeId : fromNodeId,\n sourceHandle: isTarget ? handleId : fromHandleId,\n target: isTarget ? fromNodeId : handleNodeId,\n targetHandle: isTarget ? fromHandleId : handleId,\n };\n result.connection = connection;\n const isConnectable = connectable && connectableEnd;\n // in strict mode we don't allow target to target or source to source connections\n const isValid = isConnectable &&\n (connectionMode === ConnectionMode.Strict\n ? (isTarget && handleType === 'source') || (!isTarget && handleType === 'target')\n : handleNodeId !== fromNodeId || handleId !== fromHandleId);\n result.isValid = isValid && isValidConnection(connection);\n result.toHandle = getHandle(handleNodeId, handleType, handleId, nodeLookup, connectionMode, true);\n }\n return result;\n}\nconst XYHandle = {\n onPointerDown,\n isValid: isValidHandle,\n};\n\nfunction XYMinimap({ domNode, panZoom, getTransform, getViewScale }) {\n const selection = select(domNode);\n function update({ translateExtent, width, height, zoomStep = 1, pannable = true, zoomable = true, inversePan = false, }) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const zoomHandler = (event) => {\n if (event.sourceEvent.type !== 'wheel' || !panZoom) {\n return;\n }\n const transform = getTransform();\n const factor = event.sourceEvent.ctrlKey && isMacOs() ? 10 : 1;\n const pinchDelta = -event.sourceEvent.deltaY *\n (event.sourceEvent.deltaMode === 1 ? 0.05 : event.sourceEvent.deltaMode ? 1 : 0.002) *\n zoomStep;\n const nextZoom = transform[2] * Math.pow(2, pinchDelta * factor);\n panZoom.scaleTo(nextZoom);\n };\n let panStart = [0, 0];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const panStartHandler = (event) => {\n if (event.sourceEvent.type === 'mousedown' || event.sourceEvent.type === 'touchstart') {\n panStart = [\n event.sourceEvent.clientX ?? event.sourceEvent.touches[0].clientX,\n event.sourceEvent.clientY ?? event.sourceEvent.touches[0].clientY,\n ];\n }\n };\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const panHandler = (event) => {\n const transform = getTransform();\n if ((event.sourceEvent.type !== 'mousemove' && event.sourceEvent.type !== 'touchmove') || !panZoom) {\n return;\n }\n const panCurrent = [\n event.sourceEvent.clientX ?? event.sourceEvent.touches[0].clientX,\n event.sourceEvent.clientY ?? event.sourceEvent.touches[0].clientY,\n ];\n const panDelta = [panCurrent[0] - panStart[0], panCurrent[1] - panStart[1]];\n panStart = panCurrent;\n const moveScale = getViewScale() * Math.max(transform[2], Math.log(transform[2])) * (inversePan ? -1 : 1);\n const position = {\n x: transform[0] - panDelta[0] * moveScale,\n y: transform[1] - panDelta[1] * moveScale,\n };\n const extent = [\n [0, 0],\n [width, height],\n ];\n panZoom.setViewportConstrained({\n x: position.x,\n y: position.y,\n zoom: transform[2],\n }, extent, translateExtent);\n };\n const zoomAndPanHandler = zoom()\n .on('start', panStartHandler)\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n .on('zoom', pannable ? panHandler : null)\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n .on('zoom.wheel', zoomable ? zoomHandler : null);\n selection.call(zoomAndPanHandler, {});\n }\n function destroy() {\n selection.on('zoom', null);\n }\n return {\n update,\n destroy,\n pointer,\n };\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nconst transformToViewport = (transform) => ({\n x: transform.x,\n y: transform.y,\n zoom: transform.k,\n});\nconst viewportToTransform = ({ x, y, zoom }) => zoomIdentity.translate(x, y).scale(zoom);\nconst isWrappedWithClass = (event, className) => event.target.closest(`.${className}`);\nconst isRightClickPan = (panOnDrag, usedButton) => usedButton === 2 && Array.isArray(panOnDrag) && panOnDrag.includes(2);\n// taken from d3-ease: https://github.com/d3/d3-ease/blob/main/src/cubic.js\nconst defaultEase = (t) => ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\nconst getD3Transition = (selection, duration = 0, ease = defaultEase, onEnd = () => { }) => {\n const hasDuration = typeof duration === 'number' && duration > 0;\n if (!hasDuration) {\n onEnd();\n }\n return hasDuration ? selection.transition().duration(duration).ease(ease).on('end', onEnd) : selection;\n};\nconst wheelDelta = (event) => {\n const factor = event.ctrlKey && isMacOs() ? 10 : 1;\n return -event.deltaY * (event.deltaMode === 1 ? 0.05 : event.deltaMode ? 1 : 0.002) * factor;\n};\n\nfunction createPanOnScrollHandler({ zoomPanValues, noWheelClassName, d3Selection, d3Zoom, panOnScrollMode, panOnScrollSpeed, zoomOnPinch, onPanZoomStart, onPanZoom, onPanZoomEnd, }) {\n return (event) => {\n if (isWrappedWithClass(event, noWheelClassName)) {\n if (event.ctrlKey) {\n event.preventDefault(); // stop native page zoom for pinch zooming\n }\n return false;\n }\n event.preventDefault();\n event.stopImmediatePropagation();\n const currentZoom = d3Selection.property('__zoom').k || 1;\n // macos sets ctrlKey=true for pinch gesture on a trackpad\n if (event.ctrlKey && zoomOnPinch) {\n const point = pointer(event);\n const pinchDelta = wheelDelta(event);\n const zoom = currentZoom * Math.pow(2, pinchDelta);\n // @ts-ignore\n d3Zoom.scaleTo(d3Selection, zoom, point, event);\n return;\n }\n /*\n * increase scroll speed in firefox\n * firefox: deltaMode === 1; chrome: deltaMode === 0\n */\n const deltaNormalize = event.deltaMode === 1 ? 20 : 1;\n let deltaX = panOnScrollMode === PanOnScrollMode.Vertical ? 0 : event.deltaX * deltaNormalize;\n let deltaY = panOnScrollMode === PanOnScrollMode.Horizontal ? 0 : event.deltaY * deltaNormalize;\n // this enables vertical scrolling with shift + scroll on windows\n if (!isMacOs() && event.shiftKey && panOnScrollMode !== PanOnScrollMode.Vertical) {\n deltaX = event.deltaY * deltaNormalize;\n deltaY = 0;\n }\n d3Zoom.translateBy(d3Selection, -(deltaX / currentZoom) * panOnScrollSpeed, -(deltaY / currentZoom) * panOnScrollSpeed, \n // @ts-ignore\n { internal: true });\n const nextViewport = transformToViewport(d3Selection.property('__zoom'));\n clearTimeout(zoomPanValues.panScrollTimeout);\n /*\n * for pan on scroll we need to handle the event calls on our own\n * we can't use the start, zoom and end events from d3-zoom\n * because start and move gets called on every scroll event and not once at the beginning\n */\n if (!zoomPanValues.isPanScrolling) {\n zoomPanValues.isPanScrolling = true;\n onPanZoomStart?.(event, nextViewport);\n }\n else {\n onPanZoom?.(event, nextViewport);\n zoomPanValues.panScrollTimeout = setTimeout(() => {\n onPanZoomEnd?.(event, nextViewport);\n zoomPanValues.isPanScrolling = false;\n }, 150);\n }\n };\n}\nfunction createZoomOnScrollHandler({ noWheelClassName, preventScrolling, d3ZoomHandler }) {\n return function (event, d) {\n const isWheel = event.type === 'wheel';\n // we still want to enable pinch zooming even if preventScrolling is set to false\n const preventZoom = !preventScrolling && isWheel && !event.ctrlKey;\n const hasNoWheelClass = isWrappedWithClass(event, noWheelClassName);\n // if user is pinch zooming above a nowheel element, we don't want the browser to zoom\n if (event.ctrlKey && isWheel && hasNoWheelClass) {\n event.preventDefault();\n }\n if (preventZoom || hasNoWheelClass) {\n return null;\n }\n event.preventDefault();\n d3ZoomHandler.call(this, event, d);\n };\n}\nfunction createPanZoomStartHandler({ zoomPanValues, onDraggingChange, onPanZoomStart }) {\n return (event) => {\n if (event.sourceEvent?.internal) {\n return;\n }\n const viewport = transformToViewport(event.transform);\n // we need to remember it here, because it's always 0 in the \"zoom\" event\n zoomPanValues.mouseButton = event.sourceEvent?.button || 0;\n zoomPanValues.isZoomingOrPanning = true;\n zoomPanValues.prevViewport = viewport;\n if (event.sourceEvent?.type === 'mousedown') {\n onDraggingChange(true);\n }\n if (onPanZoomStart) {\n onPanZoomStart?.(event.sourceEvent, viewport);\n }\n };\n}\nfunction createPanZoomHandler({ zoomPanValues, panOnDrag, onPaneContextMenu, onTransformChange, onPanZoom, }) {\n return (event) => {\n zoomPanValues.usedRightMouseButton = !!(onPaneContextMenu && isRightClickPan(panOnDrag, zoomPanValues.mouseButton ?? 0));\n if (!event.sourceEvent?.sync) {\n onTransformChange([event.transform.x, event.transform.y, event.transform.k]);\n }\n if (onPanZoom && !event.sourceEvent?.internal) {\n onPanZoom?.(event.sourceEvent, transformToViewport(event.transform));\n }\n };\n}\nfunction createPanZoomEndHandler({ zoomPanValues, panOnDrag, panOnScroll, onDraggingChange, onPanZoomEnd, onPaneContextMenu, }) {\n return (event) => {\n if (event.sourceEvent?.internal) {\n return;\n }\n zoomPanValues.isZoomingOrPanning = false;\n if (onPaneContextMenu &&\n isRightClickPan(panOnDrag, zoomPanValues.mouseButton ?? 0) &&\n !zoomPanValues.usedRightMouseButton &&\n event.sourceEvent) {\n onPaneContextMenu(event.sourceEvent);\n }\n zoomPanValues.usedRightMouseButton = false;\n onDraggingChange(false);\n if (onPanZoomEnd) {\n const viewport = transformToViewport(event.transform);\n zoomPanValues.prevViewport = viewport;\n clearTimeout(zoomPanValues.timerId);\n zoomPanValues.timerId = setTimeout(() => {\n onPanZoomEnd?.(event.sourceEvent, viewport);\n }, \n // we need a setTimeout for panOnScroll to supress multiple end events fired during scroll\n panOnScroll ? 150 : 0);\n }\n };\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nfunction createFilter({ zoomActivationKeyPressed, zoomOnScroll, zoomOnPinch, panOnDrag, panOnScroll, zoomOnDoubleClick, userSelectionActive, noWheelClassName, noPanClassName, lib, connectionInProgress, }) {\n return (event) => {\n const zoomScroll = zoomActivationKeyPressed || zoomOnScroll;\n const pinchZoom = zoomOnPinch && event.ctrlKey;\n const isWheelEvent = event.type === 'wheel';\n if (event.button === 1 &&\n event.type === 'mousedown' &&\n (isWrappedWithClass(event, `${lib}-flow__node`) || isWrappedWithClass(event, `${lib}-flow__edge`))) {\n return true;\n }\n // if all interactions are disabled, we prevent all zoom events\n if (!panOnDrag && !zoomScroll && !panOnScroll && !zoomOnDoubleClick && !zoomOnPinch) {\n return false;\n }\n // during a selection we prevent all other interactions\n if (userSelectionActive) {\n return false;\n }\n // we want to disable pinch-zooming while making a connection\n if (connectionInProgress && !isWheelEvent) {\n return false;\n }\n // if the target element is inside an element with the nowheel class, we prevent zooming\n if (isWrappedWithClass(event, noWheelClassName) && isWheelEvent) {\n return false;\n }\n // if the target element is inside an element with the nopan class, we prevent panning\n if (isWrappedWithClass(event, noPanClassName) &&\n (!isWheelEvent || (panOnScroll && isWheelEvent && !zoomActivationKeyPressed))) {\n return false;\n }\n if (!zoomOnPinch && event.ctrlKey && isWheelEvent) {\n return false;\n }\n if (!zoomOnPinch && event.type === 'touchstart' && event.touches?.length > 1) {\n event.preventDefault(); // if you manage to start with 2 touches, we prevent native zoom\n return false;\n }\n // when there is no scroll handling enabled, we prevent all wheel events\n if (!zoomScroll && !panOnScroll && !pinchZoom && isWheelEvent) {\n return false;\n }\n // if the pane is not movable, we prevent dragging it with mousestart or touchstart\n if (!panOnDrag && (event.type === 'mousedown' || event.type === 'touchstart')) {\n return false;\n }\n // if the pane is only movable using allowed clicks\n if (Array.isArray(panOnDrag) && !panOnDrag.includes(event.button) && event.type === 'mousedown') {\n return false;\n }\n // We only allow right clicks if pan on drag is set to right click\n const buttonAllowed = (Array.isArray(panOnDrag) && panOnDrag.includes(event.button)) || !event.button || event.button <= 1;\n // default filter for d3-zoom\n return (!event.ctrlKey || isWheelEvent) && buttonAllowed;\n };\n}\n\nfunction XYPanZoom({ domNode, minZoom, maxZoom, paneClickDistance, translateExtent, viewport, onPanZoom, onPanZoomStart, onPanZoomEnd, onDraggingChange, }) {\n const zoomPanValues = {\n isZoomingOrPanning: false,\n usedRightMouseButton: false,\n prevViewport: { x: 0, y: 0, zoom: 0 },\n mouseButton: 0,\n timerId: undefined,\n panScrollTimeout: undefined,\n isPanScrolling: false,\n };\n const bbox = domNode.getBoundingClientRect();\n const d3ZoomInstance = zoom()\n .clickDistance(!isNumeric(paneClickDistance) || paneClickDistance < 0 ? 0 : paneClickDistance)\n .scaleExtent([minZoom, maxZoom])\n .translateExtent(translateExtent);\n const d3Selection = select(domNode).call(d3ZoomInstance);\n setViewportConstrained({\n x: viewport.x,\n y: viewport.y,\n zoom: clamp(viewport.zoom, minZoom, maxZoom),\n }, [\n [0, 0],\n [bbox.width, bbox.height],\n ], translateExtent);\n const d3ZoomHandler = d3Selection.on('wheel.zoom');\n const d3DblClickZoomHandler = d3Selection.on('dblclick.zoom');\n d3ZoomInstance.wheelDelta(wheelDelta);\n function setTransform(transform, options) {\n if (d3Selection) {\n return new Promise((resolve) => {\n d3ZoomInstance?.interpolate(options?.interpolate === 'linear' ? interpolate : interpolateZoom).transform(getD3Transition(d3Selection, options?.duration, options?.ease, () => resolve(true)), transform);\n });\n }\n return Promise.resolve(false);\n }\n // public functions\n function update({ noWheelClassName, noPanClassName, onPaneContextMenu, userSelectionActive, panOnScroll, panOnDrag, panOnScrollMode, panOnScrollSpeed, preventScrolling, zoomOnPinch, zoomOnScroll, zoomOnDoubleClick, zoomActivationKeyPressed, lib, onTransformChange, connectionInProgress, }) {\n if (userSelectionActive && !zoomPanValues.isZoomingOrPanning) {\n destroy();\n }\n const isPanOnScroll = panOnScroll && !zoomActivationKeyPressed && !userSelectionActive;\n const wheelHandler = isPanOnScroll\n ? createPanOnScrollHandler({\n zoomPanValues,\n noWheelClassName,\n d3Selection,\n d3Zoom: d3ZoomInstance,\n panOnScrollMode,\n panOnScrollSpeed,\n zoomOnPinch,\n onPanZoomStart,\n onPanZoom,\n onPanZoomEnd,\n })\n : createZoomOnScrollHandler({\n noWheelClassName,\n preventScrolling,\n d3ZoomHandler,\n });\n d3Selection.on('wheel.zoom', wheelHandler, { passive: false });\n if (!userSelectionActive) {\n // pan zoom start\n const startHandler = createPanZoomStartHandler({\n zoomPanValues,\n onDraggingChange,\n onPanZoomStart,\n });\n d3ZoomInstance.on('start', startHandler);\n // pan zoom\n const panZoomHandler = createPanZoomHandler({\n zoomPanValues,\n panOnDrag,\n onPaneContextMenu: !!onPaneContextMenu,\n onPanZoom,\n onTransformChange,\n });\n d3ZoomInstance.on('zoom', panZoomHandler);\n // pan zoom end\n const panZoomEndHandler = createPanZoomEndHandler({\n zoomPanValues,\n panOnDrag,\n panOnScroll,\n onPaneContextMenu,\n onPanZoomEnd,\n onDraggingChange,\n });\n d3ZoomInstance.on('end', panZoomEndHandler);\n }\n const filter = createFilter({\n zoomActivationKeyPressed,\n panOnDrag,\n zoomOnScroll,\n panOnScroll,\n zoomOnDoubleClick,\n zoomOnPinch,\n userSelectionActive,\n noPanClassName,\n noWheelClassName,\n lib,\n connectionInProgress,\n });\n d3ZoomInstance.filter(filter);\n /*\n * We cannot add zoomOnDoubleClick to the filter above because\n * double tapping on touch screens circumvents the filter and\n * dblclick.zoom is fired on the selection directly\n */\n if (zoomOnDoubleClick) {\n d3Selection.on('dblclick.zoom', d3DblClickZoomHandler);\n }\n else {\n d3Selection.on('dblclick.zoom', null);\n }\n }\n function destroy() {\n d3ZoomInstance.on('zoom', null);\n }\n async function setViewportConstrained(viewport, extent, translateExtent) {\n const nextTransform = viewportToTransform(viewport);\n const contrainedTransform = d3ZoomInstance?.constrain()(nextTransform, extent, translateExtent);\n if (contrainedTransform) {\n await setTransform(contrainedTransform);\n }\n return new Promise((resolve) => resolve(contrainedTransform));\n }\n async function setViewport(viewport, options) {\n const nextTransform = viewportToTransform(viewport);\n await setTransform(nextTransform, options);\n return new Promise((resolve) => resolve(nextTransform));\n }\n function syncViewport(viewport) {\n if (d3Selection) {\n const nextTransform = viewportToTransform(viewport);\n const currentTransform = d3Selection.property('__zoom');\n if (currentTransform.k !== viewport.zoom ||\n currentTransform.x !== viewport.x ||\n currentTransform.y !== viewport.y) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n d3ZoomInstance?.transform(d3Selection, nextTransform, null, { sync: true });\n }\n }\n }\n function getViewport() {\n const transform = d3Selection ? zoomTransform(d3Selection.node()) : { x: 0, y: 0, k: 1 };\n return { x: transform.x, y: transform.y, zoom: transform.k };\n }\n function scaleTo(zoom, options) {\n if (d3Selection) {\n return new Promise((resolve) => {\n d3ZoomInstance?.interpolate(options?.interpolate === 'linear' ? interpolate : interpolateZoom).scaleTo(getD3Transition(d3Selection, options?.duration, options?.ease, () => resolve(true)), zoom);\n });\n }\n return Promise.resolve(false);\n }\n function scaleBy(factor, options) {\n if (d3Selection) {\n return new Promise((resolve) => {\n d3ZoomInstance?.interpolate(options?.interpolate === 'linear' ? interpolate : interpolateZoom).scaleBy(getD3Transition(d3Selection, options?.duration, options?.ease, () => resolve(true)), factor);\n });\n }\n return Promise.resolve(false);\n }\n function setScaleExtent(scaleExtent) {\n d3ZoomInstance?.scaleExtent(scaleExtent);\n }\n function setTranslateExtent(translateExtent) {\n d3ZoomInstance?.translateExtent(translateExtent);\n }\n function setClickDistance(distance) {\n const validDistance = !isNumeric(distance) || distance < 0 ? 0 : distance;\n d3ZoomInstance?.clickDistance(validDistance);\n }\n return {\n update,\n destroy,\n setViewport,\n setViewportConstrained,\n getViewport,\n scaleTo,\n scaleBy,\n setScaleExtent,\n setTranslateExtent,\n syncViewport,\n setClickDistance,\n };\n}\n\n/**\n * Used to determine the variant of the resize control\n *\n * @public\n */\nvar ResizeControlVariant;\n(function (ResizeControlVariant) {\n ResizeControlVariant[\"Line\"] = \"line\";\n ResizeControlVariant[\"Handle\"] = \"handle\";\n})(ResizeControlVariant || (ResizeControlVariant = {}));\nconst XY_RESIZER_HANDLE_POSITIONS = ['top-left', 'top-right', 'bottom-left', 'bottom-right'];\nconst XY_RESIZER_LINE_POSITIONS = ['top', 'right', 'bottom', 'left'];\n\n/**\n * Get all connecting edges for a given set of nodes\n * @param width - new width of the node\n * @param prevWidth - previous width of the node\n * @param height - new height of the node\n * @param prevHeight - previous height of the node\n * @param affectsX - whether to invert the resize direction for the x axis\n * @param affectsY - whether to invert the resize direction for the y axis\n * @returns array of two numbers representing the direction of the resize for each axis, 0 = no change, 1 = increase, -1 = decrease\n */\nfunction getResizeDirection({ width, prevWidth, height, prevHeight, affectsX, affectsY, }) {\n const deltaWidth = width - prevWidth;\n const deltaHeight = height - prevHeight;\n const direction = [deltaWidth > 0 ? 1 : deltaWidth < 0 ? -1 : 0, deltaHeight > 0 ? 1 : deltaHeight < 0 ? -1 : 0];\n if (deltaWidth && affectsX) {\n direction[0] = direction[0] * -1;\n }\n if (deltaHeight && affectsY) {\n direction[1] = direction[1] * -1;\n }\n return direction;\n}\n/**\n * Parses the control position that is being dragged to dimensions that are being resized\n * @param controlPosition - position of the control that is being dragged\n * @returns isHorizontal, isVertical, affectsX, affectsY,\n */\nfunction getControlDirection(controlPosition) {\n const isHorizontal = controlPosition.includes('right') || controlPosition.includes('left');\n const isVertical = controlPosition.includes('bottom') || controlPosition.includes('top');\n const affectsX = controlPosition.includes('left');\n const affectsY = controlPosition.includes('top');\n return {\n isHorizontal,\n isVertical,\n affectsX,\n affectsY,\n };\n}\nfunction getLowerExtentClamp(lowerExtent, lowerBound) {\n return Math.max(0, lowerBound - lowerExtent);\n}\nfunction getUpperExtentClamp(upperExtent, upperBound) {\n return Math.max(0, upperExtent - upperBound);\n}\nfunction getSizeClamp(size, minSize, maxSize) {\n return Math.max(0, minSize - size, size - maxSize);\n}\nfunction xor(a, b) {\n return a ? !b : b;\n}\n/**\n * Calculates new width & height and x & y of node after resize based on pointer position\n * @description - Buckle up, this is a chunky one... If you want to determine the new dimensions of a node after a resize,\n * you have to account for all possible restrictions: min/max width/height of the node, the maximum extent the node is allowed\n * to move in (in this case: resize into) determined by the parent node, the minimal extent determined by child nodes\n * with expandParent or extent: 'parent' set and oh yeah, these things also have to work with keepAspectRatio!\n * The way this is done is by determining how much each of these restricting actually restricts the resize and then applying the\n * strongest restriction. Because the resize affects x, y and width, height and width, height of a opposing side with keepAspectRatio,\n * the resize amount is always kept in distX & distY amount (the distance in mouse movement)\n * Instead of clamping each value, we first calculate the biggest 'clamp' (for the lack of a better name) and then apply it to all values.\n * To complicate things nodeOrigin has to be taken into account as well. This is done by offsetting the nodes as if their origin is [0, 0],\n * then calculating the restrictions as usual\n * @param startValues - starting values of resize\n * @param controlDirection - dimensions affected by the resize\n * @param pointerPosition - the current pointer position corrected for snapping\n * @param boundaries - minimum and maximum dimensions of the node\n * @param keepAspectRatio - prevent changes of asprect ratio\n * @returns x, y, width and height of the node after resize\n */\nfunction getDimensionsAfterResize(startValues, controlDirection, pointerPosition, boundaries, keepAspectRatio, nodeOrigin, extent, childExtent) {\n let { affectsX, affectsY } = controlDirection;\n const { isHorizontal, isVertical } = controlDirection;\n const isDiagonal = isHorizontal && isVertical;\n const { xSnapped, ySnapped } = pointerPosition;\n const { minWidth, maxWidth, minHeight, maxHeight } = boundaries;\n const { x: startX, y: startY, width: startWidth, height: startHeight, aspectRatio } = startValues;\n let distX = Math.floor(isHorizontal ? xSnapped - startValues.pointerX : 0);\n let distY = Math.floor(isVertical ? ySnapped - startValues.pointerY : 0);\n const newWidth = startWidth + (affectsX ? -distX : distX);\n const newHeight = startHeight + (affectsY ? -distY : distY);\n const originOffsetX = -nodeOrigin[0] * startWidth;\n const originOffsetY = -nodeOrigin[1] * startHeight;\n // Check if maxWidth, minWWidth, maxHeight, minHeight are restricting the resize\n let clampX = getSizeClamp(newWidth, minWidth, maxWidth);\n let clampY = getSizeClamp(newHeight, minHeight, maxHeight);\n // Check if extent is restricting the resize\n if (extent) {\n let xExtentClamp = 0;\n let yExtentClamp = 0;\n if (affectsX && distX < 0) {\n xExtentClamp = getLowerExtentClamp(startX + distX + originOffsetX, extent[0][0]);\n }\n else if (!affectsX && distX > 0) {\n xExtentClamp = getUpperExtentClamp(startX + newWidth + originOffsetX, extent[1][0]);\n }\n if (affectsY && distY < 0) {\n yExtentClamp = getLowerExtentClamp(startY + distY + originOffsetY, extent[0][1]);\n }\n else if (!affectsY && distY > 0) {\n yExtentClamp = getUpperExtentClamp(startY + newHeight + originOffsetY, extent[1][1]);\n }\n clampX = Math.max(clampX, xExtentClamp);\n clampY = Math.max(clampY, yExtentClamp);\n }\n // Check if the child extent is restricting the resize\n if (childExtent) {\n let xExtentClamp = 0;\n let yExtentClamp = 0;\n if (affectsX && distX > 0) {\n xExtentClamp = getUpperExtentClamp(startX + distX, childExtent[0][0]);\n }\n else if (!affectsX && distX < 0) {\n xExtentClamp = getLowerExtentClamp(startX + newWidth, childExtent[1][0]);\n }\n if (affectsY && distY > 0) {\n yExtentClamp = getUpperExtentClamp(startY + distY, childExtent[0][1]);\n }\n else if (!affectsY && distY < 0) {\n yExtentClamp = getLowerExtentClamp(startY + newHeight, childExtent[1][1]);\n }\n clampX = Math.max(clampX, xExtentClamp);\n clampY = Math.max(clampY, yExtentClamp);\n }\n // Check if the aspect ratio resizing of the other side is restricting the resize\n if (keepAspectRatio) {\n if (isHorizontal) {\n // Check if the max dimensions might be restricting the resize\n const aspectHeightClamp = getSizeClamp(newWidth / aspectRatio, minHeight, maxHeight) * aspectRatio;\n clampX = Math.max(clampX, aspectHeightClamp);\n // Check if the extent is restricting the resize\n if (extent) {\n let aspectExtentClamp = 0;\n if ((!affectsX && !affectsY) || (affectsX && !affectsY && isDiagonal)) {\n aspectExtentClamp =\n getUpperExtentClamp(startY + originOffsetY + newWidth / aspectRatio, extent[1][1]) * aspectRatio;\n }\n else {\n aspectExtentClamp =\n getLowerExtentClamp(startY + originOffsetY + (affectsX ? distX : -distX) / aspectRatio, extent[0][1]) *\n aspectRatio;\n }\n clampX = Math.max(clampX, aspectExtentClamp);\n }\n // Check if the child extent is restricting the resize\n if (childExtent) {\n let aspectExtentClamp = 0;\n if ((!affectsX && !affectsY) || (affectsX && !affectsY && isDiagonal)) {\n aspectExtentClamp = getLowerExtentClamp(startY + newWidth / aspectRatio, childExtent[1][1]) * aspectRatio;\n }\n else {\n aspectExtentClamp =\n getUpperExtentClamp(startY + (affectsX ? distX : -distX) / aspectRatio, childExtent[0][1]) * aspectRatio;\n }\n clampX = Math.max(clampX, aspectExtentClamp);\n }\n }\n // Do the same thing for vertical resizing\n if (isVertical) {\n const aspectWidthClamp = getSizeClamp(newHeight * aspectRatio, minWidth, maxWidth) / aspectRatio;\n clampY = Math.max(clampY, aspectWidthClamp);\n if (extent) {\n let aspectExtentClamp = 0;\n if ((!affectsX && !affectsY) || (affectsY && !affectsX && isDiagonal)) {\n aspectExtentClamp =\n getUpperExtentClamp(startX + newHeight * aspectRatio + originOffsetX, extent[1][0]) / aspectRatio;\n }\n else {\n aspectExtentClamp =\n getLowerExtentClamp(startX + (affectsY ? distY : -distY) * aspectRatio + originOffsetX, extent[0][0]) /\n aspectRatio;\n }\n clampY = Math.max(clampY, aspectExtentClamp);\n }\n if (childExtent) {\n let aspectExtentClamp = 0;\n if ((!affectsX && !affectsY) || (affectsY && !affectsX && isDiagonal)) {\n aspectExtentClamp = getLowerExtentClamp(startX + newHeight * aspectRatio, childExtent[1][0]) / aspectRatio;\n }\n else {\n aspectExtentClamp =\n getUpperExtentClamp(startX + (affectsY ? distY : -distY) * aspectRatio, childExtent[0][0]) / aspectRatio;\n }\n clampY = Math.max(clampY, aspectExtentClamp);\n }\n }\n }\n distY = distY + (distY < 0 ? clampY : -clampY);\n distX = distX + (distX < 0 ? clampX : -clampX);\n if (keepAspectRatio) {\n if (isDiagonal) {\n if (newWidth > newHeight * aspectRatio) {\n distY = (xor(affectsX, affectsY) ? -distX : distX) / aspectRatio;\n }\n else {\n distX = (xor(affectsX, affectsY) ? -distY : distY) * aspectRatio;\n }\n }\n else {\n if (isHorizontal) {\n distY = distX / aspectRatio;\n affectsY = affectsX;\n }\n else {\n distX = distY * aspectRatio;\n affectsX = affectsY;\n }\n }\n }\n const x = affectsX ? startX + distX : startX;\n const y = affectsY ? startY + distY : startY;\n return {\n width: startWidth + (affectsX ? -distX : distX),\n height: startHeight + (affectsY ? -distY : distY),\n x: nodeOrigin[0] * distX * (!affectsX ? 1 : -1) + x,\n y: nodeOrigin[1] * distY * (!affectsY ? 1 : -1) + y,\n };\n}\n\nconst initPrevValues = { width: 0, height: 0, x: 0, y: 0 };\nconst initStartValues = {\n ...initPrevValues,\n pointerX: 0,\n pointerY: 0,\n aspectRatio: 1,\n};\nfunction nodeToParentExtent(node) {\n return [\n [0, 0],\n [node.measured.width, node.measured.height],\n ];\n}\nfunction nodeToChildExtent(child, parent, nodeOrigin) {\n const x = parent.position.x + child.position.x;\n const y = parent.position.y + child.position.y;\n const width = child.measured.width ?? 0;\n const height = child.measured.height ?? 0;\n const originOffsetX = nodeOrigin[0] * width;\n const originOffsetY = nodeOrigin[1] * height;\n return [\n [x - originOffsetX, y - originOffsetY],\n [x + width - originOffsetX, y + height - originOffsetY],\n ];\n}\nfunction XYResizer({ domNode, nodeId, getStoreItems, onChange, onEnd }) {\n const selection = select(domNode);\n let params = {\n controlDirection: getControlDirection('bottom-right'),\n boundaries: {\n minWidth: 0,\n minHeight: 0,\n maxWidth: Number.MAX_VALUE,\n maxHeight: Number.MAX_VALUE,\n },\n resizeDirection: undefined,\n keepAspectRatio: false,\n };\n function update({ controlPosition, boundaries, keepAspectRatio, resizeDirection, onResizeStart, onResize, onResizeEnd, shouldResize, }) {\n let prevValues = { ...initPrevValues };\n let startValues = { ...initStartValues };\n params = {\n boundaries,\n resizeDirection,\n keepAspectRatio,\n controlDirection: getControlDirection(controlPosition),\n };\n let node = undefined;\n let containerBounds = null;\n let childNodes = [];\n let parentNode = undefined; // Needed to fix expandParent\n let parentExtent = undefined;\n let childExtent = undefined;\n // we only want to trigger onResizeEnd if onResize was actually called\n let resizeDetected = false;\n const dragHandler = drag()\n .on('start', (event) => {\n const { nodeLookup, transform, snapGrid, snapToGrid, nodeOrigin, paneDomNode } = getStoreItems();\n node = nodeLookup.get(nodeId);\n if (!node) {\n return;\n }\n containerBounds = paneDomNode?.getBoundingClientRect() ?? null;\n const { xSnapped, ySnapped } = getPointerPosition(event.sourceEvent, {\n transform,\n snapGrid,\n snapToGrid,\n containerBounds,\n });\n prevValues = {\n width: node.measured.width ?? 0,\n height: node.measured.height ?? 0,\n x: node.position.x ?? 0,\n y: node.position.y ?? 0,\n };\n startValues = {\n ...prevValues,\n pointerX: xSnapped,\n pointerY: ySnapped,\n aspectRatio: prevValues.width / prevValues.height,\n };\n parentNode = undefined;\n if (node.parentId && (node.extent === 'parent' || node.expandParent)) {\n parentNode = nodeLookup.get(node.parentId);\n parentExtent = parentNode && node.extent === 'parent' ? nodeToParentExtent(parentNode) : undefined;\n }\n /*\n * Collect all child nodes to correct their relative positions when top/left changes\n * Determine largest minimal extent the parent node is allowed to resize to\n */\n childNodes = [];\n childExtent = undefined;\n for (const [childId, child] of nodeLookup) {\n if (child.parentId === nodeId) {\n childNodes.push({\n id: childId,\n position: { ...child.position },\n extent: child.extent,\n });\n if (child.extent === 'parent' || child.expandParent) {\n const extent = nodeToChildExtent(child, node, child.origin ?? nodeOrigin);\n if (childExtent) {\n childExtent = [\n [Math.min(extent[0][0], childExtent[0][0]), Math.min(extent[0][1], childExtent[0][1])],\n [Math.max(extent[1][0], childExtent[1][0]), Math.max(extent[1][1], childExtent[1][1])],\n ];\n }\n else {\n childExtent = extent;\n }\n }\n }\n }\n onResizeStart?.(event, { ...prevValues });\n })\n .on('drag', (event) => {\n const { transform, snapGrid, snapToGrid, nodeOrigin: storeNodeOrigin } = getStoreItems();\n const pointerPosition = getPointerPosition(event.sourceEvent, {\n transform,\n snapGrid,\n snapToGrid,\n containerBounds,\n });\n const childChanges = [];\n if (!node) {\n return;\n }\n const { x: prevX, y: prevY, width: prevWidth, height: prevHeight } = prevValues;\n const change = {};\n const nodeOrigin = node.origin ?? storeNodeOrigin;\n const { width, height, x, y } = getDimensionsAfterResize(startValues, params.controlDirection, pointerPosition, params.boundaries, params.keepAspectRatio, nodeOrigin, parentExtent, childExtent);\n const isWidthChange = width !== prevWidth;\n const isHeightChange = height !== prevHeight;\n const isXPosChange = x !== prevX && isWidthChange;\n const isYPosChange = y !== prevY && isHeightChange;\n if (!isXPosChange && !isYPosChange && !isWidthChange && !isHeightChange) {\n return;\n }\n if (isXPosChange || isYPosChange || nodeOrigin[0] === 1 || nodeOrigin[1] === 1) {\n change.x = isXPosChange ? x : prevValues.x;\n change.y = isYPosChange ? y : prevValues.y;\n prevValues.x = change.x;\n prevValues.y = change.y;\n /*\n * when top/left changes, correct the relative positions of child nodes\n * so that they stay in the same position\n */\n if (childNodes.length > 0) {\n const xChange = x - prevX;\n const yChange = y - prevY;\n for (const childNode of childNodes) {\n childNode.position = {\n x: childNode.position.x - xChange + nodeOrigin[0] * (width - prevWidth),\n y: childNode.position.y - yChange + nodeOrigin[1] * (height - prevHeight),\n };\n childChanges.push(childNode);\n }\n }\n }\n if (isWidthChange || isHeightChange) {\n change.width =\n isWidthChange && (!params.resizeDirection || params.resizeDirection === 'horizontal')\n ? width\n : prevValues.width;\n change.height =\n isHeightChange && (!params.resizeDirection || params.resizeDirection === 'vertical')\n ? height\n : prevValues.height;\n prevValues.width = change.width;\n prevValues.height = change.height;\n }\n // Fix expandParent when resizing from top/left\n if (parentNode && node.expandParent) {\n const xLimit = nodeOrigin[0] * (change.width ?? 0);\n if (change.x && change.x < xLimit) {\n prevValues.x = xLimit;\n startValues.x = startValues.x - (change.x - xLimit);\n }\n const yLimit = nodeOrigin[1] * (change.height ?? 0);\n if (change.y && change.y < yLimit) {\n prevValues.y = yLimit;\n startValues.y = startValues.y - (change.y - yLimit);\n }\n }\n const direction = getResizeDirection({\n width: prevValues.width,\n prevWidth,\n height: prevValues.height,\n prevHeight,\n affectsX: params.controlDirection.affectsX,\n affectsY: params.controlDirection.affectsY,\n });\n const nextValues = { ...prevValues, direction };\n const callResize = shouldResize?.(event, nextValues);\n if (callResize === false) {\n return;\n }\n resizeDetected = true;\n onResize?.(event, nextValues);\n onChange(change, childChanges);\n })\n .on('end', (event) => {\n if (!resizeDetected) {\n return;\n }\n onResizeEnd?.(event, { ...prevValues });\n onEnd?.({ ...prevValues });\n resizeDetected = false;\n });\n selection.call(dragHandler);\n }\n function destroy() {\n selection.on('.drag', null);\n }\n return {\n update,\n destroy,\n };\n}\n\nexport { ConnectionLineType, ConnectionMode, MarkerType, PanOnScrollMode, Position, ResizeControlVariant, SelectionMode, XYDrag, XYHandle, XYMinimap, XYPanZoom, XYResizer, XY_RESIZER_HANDLE_POSITIONS, XY_RESIZER_LINE_POSITIONS, addEdge, adoptUserNodes, areConnectionMapsEqual, areSetsEqual, boxToRect, calcAutoPan, calculateNodePosition, clamp, clampPosition, clampPositionToParent, createMarkerIds, defaultAriaLabelConfig, devWarn, elementSelectionKeys, errorMessages, evaluateAbsolutePosition, fitViewport, getBezierEdgeCenter, getBezierPath, getBoundsOfBoxes, getBoundsOfRects, getConnectedEdges, getConnectionStatus, getDimensions, getEdgeCenter, getEdgePosition, getEdgeToolbarTransform, getElementsToRemove, getElevatedEdgeZIndex, getEventPosition, getHandleBounds, getHandlePosition, getHostForElement, getIncomers, getInternalNodesBounds, getMarkerId, getNodeDimensions, getNodePositionWithOrigin, getNodeToolbarTransform, getNodesBounds, getNodesInside, getOutgoers, getOverlappingArea, getPointerPosition, getSmoothStepPath, getStraightPath, getViewportForBounds, handleConnectionChange, handleExpandParent, infiniteExtent, initialConnection, isCoordinateExtent, isEdgeBase, isEdgeVisible, isInputDOMNode, isInternalNodeBase, isMacOs, isMouseEvent, isNodeBase, isNumeric, isRectObject, mergeAriaLabelConfig, nodeHasDimensions, nodeToBox, nodeToRect, oppositePosition, panBy, pointToRendererPoint, reconnectEdge, rectToBox, rendererPointToPoint, shallowNodeData, snapPosition, updateAbsolutePositions, updateConnectionLookup, updateNodeInternals, withResolvers };\n", "import ReactExports from 'react';\nimport useSyncExternalStoreExports from 'use-sync-external-store/shim/with-selector.js';\nimport { createStore } from 'zustand/vanilla';\n\nconst { useDebugValue } = ReactExports;\nconst { useSyncExternalStoreWithSelector } = useSyncExternalStoreExports;\nconst identity = (arg) => arg;\nfunction useStoreWithEqualityFn(api, selector = identity, equalityFn) {\n const slice = useSyncExternalStoreWithSelector(\n api.subscribe,\n api.getState,\n api.getServerState || api.getInitialState,\n selector,\n equalityFn\n );\n useDebugValue(slice);\n return slice;\n}\nconst createWithEqualityFnImpl = (createState, defaultEqualityFn) => {\n const api = createStore(createState);\n const useBoundStoreWithEqualityFn = (selector, equalityFn = defaultEqualityFn) => useStoreWithEqualityFn(api, selector, equalityFn);\n Object.assign(useBoundStoreWithEqualityFn, api);\n return useBoundStoreWithEqualityFn;\n};\nconst createWithEqualityFn = (createState, defaultEqualityFn) => createState ? createWithEqualityFnImpl(createState, defaultEqualityFn) : createWithEqualityFnImpl;\n\nexport { createWithEqualityFn, useStoreWithEqualityFn };\n", "const createStoreImpl = (createState) => {\n let state;\n const listeners = /* @__PURE__ */ new Set();\n const setState = (partial, replace) => {\n const nextState = typeof partial === \"function\" ? partial(state) : partial;\n if (!Object.is(nextState, state)) {\n const previousState = state;\n state = (replace != null ? replace : typeof nextState !== \"object\" || nextState === null) ? nextState : Object.assign({}, state, nextState);\n listeners.forEach((listener) => listener(state, previousState));\n }\n };\n const getState = () => state;\n const getInitialState = () => initialState;\n const subscribe = (listener) => {\n listeners.add(listener);\n return () => listeners.delete(listener);\n };\n const destroy = () => {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") {\n console.warn(\n \"[DEPRECATED] The `destroy` method will be unsupported in a future version. Instead use unsubscribe function returned by subscribe. Everything will be garbage-collected if store is garbage-collected.\"\n );\n }\n listeners.clear();\n };\n const api = { setState, getState, getInitialState, subscribe, destroy };\n const initialState = state = createState(setState, getState, api);\n return api;\n};\nconst createStore = (createState) => createState ? createStoreImpl(createState) : createStoreImpl;\nvar vanilla = (createState) => {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") {\n console.warn(\n \"[DEPRECATED] Default export is deprecated. Instead use import { createStore } from 'zustand/vanilla'.\"\n );\n }\n return createStore(createState);\n};\n\nexport { createStore, vanilla as default };\n", "function shallow$1(objA, objB) {\n if (Object.is(objA, objB)) {\n return true;\n }\n if (typeof objA !== \"object\" || objA === null || typeof objB !== \"object\" || objB === null) {\n return false;\n }\n if (objA instanceof Map && objB instanceof Map) {\n if (objA.size !== objB.size) return false;\n for (const [key, value] of objA) {\n if (!Object.is(value, objB.get(key))) {\n return false;\n }\n }\n return true;\n }\n if (objA instanceof Set && objB instanceof Set) {\n if (objA.size !== objB.size) return false;\n for (const value of objA) {\n if (!objB.has(value)) {\n return false;\n }\n }\n return true;\n }\n const keysA = Object.keys(objA);\n if (keysA.length !== Object.keys(objB).length) {\n return false;\n }\n for (const keyA of keysA) {\n if (!Object.prototype.hasOwnProperty.call(objB, keyA) || !Object.is(objA[keyA], objB[keyA])) {\n return false;\n }\n }\n return true;\n}\n\nvar shallow = (objA, objB) => {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") {\n console.warn(\n \"[DEPRECATED] Default export is deprecated. Instead use `import { shallow } from 'zustand/shallow'`.\"\n );\n }\n return shallow$1(objA, objB);\n};\n\nexport { shallow as default, shallow$1 as shallow };\n", "/**\n * Point class representing a 2D coordinate\n */\nexport class Point {\n x: number\n y: number\n\n constructor(x: number, y: number) {\n this.x = x\n this.y = y\n }\n\n /**\n * Create a copy of this point\n */\n clone(): Point {\n return new Point(this.x, this.y)\n }\n\n /**\n * Check if this point equals another point\n */\n equals(other: Point): boolean {\n return this.x === other.x && this.y === other.y\n }\n\n /**\n * Translate this point by dx and dy\n */\n translate(dx: number, dy: number): Point {\n return new Point(this.x + dx, this.y + dy)\n }\n\n /**\n * Round coordinates to specified precision\n */\n round(precision: number): Point {\n const factor = Math.pow(10, precision)\n return new Point(\n Math.round(this.x * factor) / factor,\n Math.round(this.y * factor) / factor\n )\n }\n\n /**\n * Calculate Manhattan distance to another point\n */\n manhattanDistance(other: Point): number {\n return Math.abs(this.x - other.x) + Math.abs(this.y - other.y)\n }\n\n /**\n * Calculate angle (in degrees) from this point to another point\n */\n theta(other: Point): number {\n const dx = other.x - this.x\n const dy = other.y - this.y\n const radians = Math.atan2(dy, dx)\n return (radians * 180) / Math.PI\n }\n\n /**\n * Calculate the difference vector from this point to another\n */\n diff(other: Point): Point {\n return new Point(other.x - this.x, other.y - this.y)\n }\n\n /**\n * Convert point to string representation\n */\n toString(): string {\n return `${this.x}@${this.y}`\n }\n\n /**\n * Snap point to grid\n */\n snapToGrid(gridSize: number): Point {\n return new Point(\n Math.round(this.x / gridSize) * gridSize,\n Math.round(this.y / gridSize) * gridSize\n )\n }\n\n /**\n * Calculate squared distance to another point (for performance)\n */\n squaredDistance(other: Point): number {\n const dx = other.x - this.x\n const dy = other.y - this.y\n return dx * dx + dy * dy\n }\n}\n", "import { Point } from './Point'\n\n/**\n * Rectangle class representing a bounding box\n */\nexport class Rectangle {\n x: number\n y: number\n width: number\n height: number\n\n constructor(x: number, y: number, width: number, height: number) {\n this.x = x\n this.y = y\n this.width = width\n this.height = height\n }\n\n /**\n * Create a copy of this rectangle\n */\n clone(): Rectangle {\n return new Rectangle(this.x, this.y, this.width, this.height)\n }\n\n /**\n * Get the center point of the rectangle\n */\n getCenter(): Point {\n return new Point(\n this.x + this.width / 2,\n this.y + this.height / 2\n )\n }\n\n /**\n * Get the origin (top-left) point of the rectangle\n */\n getOrigin(): Point {\n return new Point(this.x, this.y)\n }\n\n /**\n * Get the corner (bottom-right) point of the rectangle\n */\n getCorner(): Point {\n return new Point(this.x + this.width, this.y + this.height)\n }\n\n /**\n * Check if a point is contained within this rectangle (interior only, excluding edges)\n */\n containsPoint(point: Point): boolean {\n return (\n point.x > this.x &&\n point.x < this.x + this.width &&\n point.y > this.y &&\n point.y < this.y + this.height\n )\n }\n\n /**\n * Move and expand the rectangle by a box offset\n */\n moveAndExpand(box: { x: number; y: number; width: number; height: number }): Rectangle {\n return new Rectangle(\n this.x + box.x,\n this.y + box.y,\n this.width + box.width,\n this.height + box.height\n )\n }\n}\n", "import { Point } from './Point'\nimport { Rectangle } from './Rectangle'\n\n/**\n * Line class representing a line segment\n */\nexport class Line {\n start: Point\n end: Point\n\n constructor(start: Point, end: Point) {\n this.start = start\n this.end = end\n }\n\n /**\n * Calculate intersection points with a rectangle\n * Returns an array of intersection points\n */\n intersect(rect: Rectangle): Point[] {\n const intersections: Point[] = []\n\n // Define rectangle edges\n const edges = [\n // Top edge\n { p1: new Point(rect.x, rect.y), p2: new Point(rect.x + rect.width, rect.y) },\n // Right edge\n { p1: new Point(rect.x + rect.width, rect.y), p2: new Point(rect.x + rect.width, rect.y + rect.height) },\n // Bottom edge\n { p1: new Point(rect.x, rect.y + rect.height), p2: new Point(rect.x + rect.width, rect.y + rect.height) },\n // Left edge\n { p1: new Point(rect.x, rect.y), p2: new Point(rect.x, rect.y + rect.height) }\n ]\n\n // Check intersection with each edge\n for (const edge of edges) {\n const intersection = this.lineIntersection(\n this.start,\n this.end,\n edge.p1,\n edge.p2\n )\n if (intersection) {\n intersections.push(intersection)\n }\n }\n\n return intersections\n }\n\n /**\n * Calculate intersection point between two line segments\n * Returns null if lines don't intersect\n */\n private lineIntersection(\n p1: Point,\n p2: Point,\n p3: Point,\n p4: Point\n ): Point | null {\n const x1 = p1.x, y1 = p1.y\n const x2 = p2.x, y2 = p2.y\n const x3 = p3.x, y3 = p3.y\n const x4 = p4.x, y4 = p4.y\n\n const denom = (x1 - x2) * (y3 - y4) - (y1 - y2) * (x3 - x4)\n\n // Lines are parallel\n if (Math.abs(denom) < 1e-10) {\n return null\n }\n\n const t = ((x1 - x3) * (y3 - y4) - (y1 - y3) * (x3 - x4)) / denom\n const u = -((x1 - x2) * (y1 - y3) - (y1 - y2) * (x1 - x3)) / denom\n\n // Check if intersection is within both line segments\n if (t >= 0 && t <= 1 && u >= 0 && u <= 1) {\n return new Point(\n x1 + t * (x2 - x1),\n y1 + t * (y2 - y1)\n )\n }\n\n return null\n }\n}\n", "import { Point } from '../geometry'\nimport { GlobalGrid } from './GlobalGrid'\n\n/**\n * Grid interface for dynamic grid system\n */\nexport interface Grid {\n source: Point\n x: number\n y: number\n}\n\n/**\n * Get grid size in x and y dimensions, adapted to source and target positions\n * Uses global grid system with origin at (0, 0) for path alignment\n *\n * @param step - The grid step size\n * @param source - Source point (used for reference, not as origin)\n * @param target - Target point (used for reference, not as origin)\n * @returns Grid configuration with global origin\n */\nexport function getGrid(step: number, source: Point, target: Point): Grid {\n return {\n source: new Point(0, 0), // Use global origin for consistent grid alignment\n x: step,\n y: step,\n }\n}\n\n/**\n * Create a GlobalGrid instance from step size\n * This is the preferred way to create grids for new code\n */\nexport function createGlobalGrid(step: number): GlobalGrid {\n return GlobalGrid.uniform(step)\n}\n\n/**\n * Snap a value to grid\n */\nexport function snapToGrid(value: number, gridSize: number): number {\n return Math.round(value / gridSize) * gridSize\n}\n\n/**\n * Snap a point to grid using global origin\n */\nexport function snapPointToGrid(point: Point, grid: Grid): Point {\n const source = grid.source\n const x = snapToGrid(point.x - source.x, grid.x) + source.x\n const y = snapToGrid(point.y - source.y, grid.y) + source.y\n return new Point(x, y)\n}\n\n/**\n * Align point to grid and apply precision\n */\nexport function align(point: Point, grid: Grid, precision: number): Point {\n return snapPointToGrid(point.clone(), grid).round(precision)\n}\n\n/**\n * Round point coordinates\n */\nexport function round(point: Point, precision: number): Point {\n return point.round(precision)\n}\n", "import { Point } from '../geometry'\nimport type { ManhattanRouterOptions, Direction } from './types'\n\n/**\n * Default configuration for Manhattan router\n */\nexport const defaults: Required<Omit<ManhattanRouterOptions, 'fallbackRoute' | 'sourcePosition' | 'targetPosition' | 'performance' | 'adaptiveStep' | 'debug'>> = {\n step: 10,\n maxLoopCount: 2000,\n precision: 1,\n maxDirectionChange: 90,\n startDirections: ['top', 'right', 'bottom', 'left'] as Direction[],\n endDirections: ['top', 'right', 'bottom', 'left'] as Direction[],\n excludeNodes: [],\n excludeShapes: [],\n excludeTerminals: [],\n padding: 15,\n borderRadius: 5,\n extensionDistance: 20,\n penalties: {\n 0: 0,\n 45: 5,\n 90: 5,\n },\n}\n\n/**\n * Direction map - maps direction names to unit vectors\n */\nexport const directionMap = {\n top: new Point(0, -1),\n right: new Point(1, 0),\n bottom: new Point(0, 1),\n left: new Point(-1, 0),\n}\n", "/**\n * AdaptiveStepCalculator - \u81EA\u9002\u5E94\u6B65\u957F\u8BA1\u7B97\u5668\n *\n * \u6839\u636E\u573A\u666F\u81EA\u52A8\u8C03\u6574\u7F51\u683C\u6B65\u957F\uFF0C\u5E73\u8861\u6027\u80FD\u548C\u8DEF\u5F84\u8D28\u91CF\n * - \u9AD8\u5BC6\u5EA6\u533A\u57DF\u4F7F\u7528\u5C0F\u6B65\u957F\uFF0C\u63D0\u9AD8\u8DEF\u5F84\u7CBE\u5EA6\n * - \u957F\u8DDD\u79BB\u8DEF\u5F84\u4F7F\u7528\u5927\u6B65\u957F\uFF0C\u63D0\u9AD8\u8BA1\u7B97\u6027\u80FD\n *\n * Feature: manhattan-optimization\n * Requirements: 2.3, 2.4\n */\n\nimport type { InternalNode, NodeLookup } from '../options/types'\nimport { Point } from '../geometry'\n\n/**\n * \u81EA\u9002\u5E94\u6B65\u957F\u914D\u7F6E\n */\nexport interface AdaptiveStepConfig {\n /** \u662F\u5426\u542F\u7528\u81EA\u9002\u5E94\u6B65\u957F */\n enabled: boolean\n /** \u6700\u5C0F\u6B65\u957F */\n minStep: number\n /** \u6700\u5927\u6B65\u957F */\n maxStep: number\n /** \u57FA\u4E8E\u5BC6\u5EA6\u7684\u8C03\u6574\u914D\u7F6E */\n densityBased: {\n enabled: boolean\n /** \u8282\u70B9\u5BC6\u5EA6\u9608\u503C\uFF08\u8282\u70B9\u6570/10000\u5E73\u65B9\u50CF\u7D20\uFF09 */\n threshold: number\n }\n /** \u57FA\u4E8E\u8DDD\u79BB\u7684\u8C03\u6574\u914D\u7F6E */\n distanceBased: {\n enabled: boolean\n /** \u77ED\u8DEF\u5F84\u9608\u503C\uFF08\u50CF\u7D20\uFF09 */\n shortPathThreshold: number\n /** \u957F\u8DEF\u5F84\u9608\u503C\uFF08\u50CF\u7D20\uFF09 */\n longPathThreshold: number\n }\n}\n\n/**\n * \u9ED8\u8BA4\u81EA\u9002\u5E94\u6B65\u957F\u914D\u7F6E\n */\nexport const DEFAULT_ADAPTIVE_STEP_CONFIG: AdaptiveStepConfig = {\n enabled: false,\n minStep: 5,\n maxStep: 20,\n densityBased: {\n enabled: true,\n threshold: 0.5, // \u6BCF10000\u5E73\u65B9\u50CF\u7D200.5\u4E2A\u8282\u70B9\n },\n distanceBased: {\n enabled: true,\n shortPathThreshold: 200,\n longPathThreshold: 800,\n },\n}\n\n/**\n * \u81EA\u9002\u5E94\u6B65\u957F\u8BA1\u7B97\u5668\n */\nexport class AdaptiveStepCalculator {\n private config: AdaptiveStepConfig\n\n constructor(config: Partial<AdaptiveStepConfig> = {}) {\n this.config = this.mergeConfig(config)\n }\n\n /**\n * \u5408\u5E76\u914D\u7F6E\u4E0E\u9ED8\u8BA4\u503C\n */\n private mergeConfig(config: Partial<AdaptiveStepConfig>): AdaptiveStepConfig {\n return {\n enabled: config.enabled ?? DEFAULT_ADAPTIVE_STEP_CONFIG.enabled,\n minStep: config.minStep ?? DEFAULT_ADAPTIVE_STEP_CONFIG.minStep,\n maxStep: config.maxStep ?? DEFAULT_ADAPTIVE_STEP_CONFIG.maxStep,\n densityBased: {\n enabled: config.densityBased?.enabled ?? DEFAULT_ADAPTIVE_STEP_CONFIG.densityBased.enabled,\n threshold: config.densityBased?.threshold ?? DEFAULT_ADAPTIVE_STEP_CONFIG.densityBased.threshold,\n },\n distanceBased: {\n enabled: config.distanceBased?.enabled ?? DEFAULT_ADAPTIVE_STEP_CONFIG.distanceBased.enabled,\n shortPathThreshold: config.distanceBased?.shortPathThreshold ?? DEFAULT_ADAPTIVE_STEP_CONFIG.distanceBased.shortPathThreshold,\n longPathThreshold: config.distanceBased?.longPathThreshold ?? DEFAULT_ADAPTIVE_STEP_CONFIG.distanceBased.longPathThreshold,\n },\n }\n }\n\n /**\n * \u8BA1\u7B97\u8282\u70B9\u5BC6\u5EA6\n * @param nodeLookup \u8282\u70B9\u67E5\u627E\u8868\n * @returns \u5BC6\u5EA6\u503C\uFF08\u8282\u70B9\u6570/10000\u5E73\u65B9\u50CF\u7D20\uFF09\n */\n calculateNodeDensity(nodeLookup: NodeLookup): number {\n if (nodeLookup.size === 0) return 0\n\n let minX = Infinity, minY = Infinity\n let maxX = -Infinity, maxY = -Infinity\n\n for (const node of nodeLookup.values()) {\n const pos = node.internals?.positionAbsolute ?? node.position\n const width = node.measured?.width ?? node.width ?? 100\n const height = node.measured?.height ?? node.height ?? 50\n\n minX = Math.min(minX, pos.x)\n minY = Math.min(minY, pos.y)\n maxX = Math.max(maxX, pos.x + width)\n maxY = Math.max(maxY, pos.y + height)\n }\n\n // \u8BA1\u7B97\u8FB9\u754C\u6846\u9762\u79EF\uFF08\u4EE510000\u5E73\u65B9\u50CF\u7D20\u4E3A\u5355\u4F4D\uFF09\n const width = maxX - minX\n const height = maxY - minY\n const area = (width * height) / 10000\n\n if (area <= 0) return 0\n\n return nodeLookup.size / area\n }\n\n /**\n * \u8BA1\u7B97\u4E24\u70B9\u4E4B\u95F4\u7684\u66FC\u54C8\u987F\u8DDD\u79BB\n */\n calculateDistance(source: Point | { x: number; y: number }, target: Point | { x: number; y: number }): number {\n return Math.abs(target.x - source.x) + Math.abs(target.y - source.y)\n }\n\n /**\n * \u57FA\u4E8E\u8DDD\u79BB\u8BA1\u7B97\u6B65\u957F\n */\n calculateDistanceBasedStep(distance: number): number {\n const { minStep, maxStep, distanceBased } = this.config\n\n if (!distanceBased.enabled) {\n return minStep\n }\n\n const { shortPathThreshold, longPathThreshold } = distanceBased\n\n if (distance <= shortPathThreshold) {\n return minStep\n }\n\n if (distance >= longPathThreshold) {\n return maxStep\n }\n\n // \u7EBF\u6027\u63D2\u503C\n const ratio = (distance - shortPathThreshold) / (longPathThreshold - shortPathThreshold)\n return Math.round(minStep + ratio * (maxStep - minStep))\n }\n\n /**\n * \u57FA\u4E8E\u5BC6\u5EA6\u8BA1\u7B97\u6B65\u957F\n */\n calculateDensityBasedStep(density: number): number {\n const { minStep, maxStep, densityBased } = this.config\n\n if (!densityBased.enabled) {\n return maxStep\n }\n\n // \u9AD8\u5BC6\u5EA6\u4F7F\u7528\u5C0F\u6B65\u957F\n if (density >= densityBased.threshold) {\n return minStep\n }\n\n // \u4F4E\u5BC6\u5EA6\u4F7F\u7528\u5927\u6B65\u957F\n if (density <= densityBased.threshold / 2) {\n return maxStep\n }\n\n // \u7EBF\u6027\u63D2\u503C\n const ratio = (densityBased.threshold - density) / (densityBased.threshold / 2)\n return Math.round(minStep + ratio * (maxStep - minStep))\n }\n\n /**\n * \u8BA1\u7B97\u81EA\u9002\u5E94\u6B65\u957F\n * \u7EFC\u5408\u8003\u8651\u8DDD\u79BB\u548C\u5BC6\u5EA6\u56E0\u7D20\n */\n calculateStep(\n sourceNode: InternalNode,\n targetNode: InternalNode,\n nodeLookup: NodeLookup\n ): number {\n if (!this.config.enabled) {\n return this.config.minStep\n }\n\n // \u83B7\u53D6\u6E90\u548C\u76EE\u6807\u4F4D\u7F6E\n const sourcePos = sourceNode.internals?.positionAbsolute ?? sourceNode.position\n const targetPos = targetNode.internals?.positionAbsolute ?? targetNode.position\n\n // \u8BA1\u7B97\u8282\u70B9\u4E2D\u5FC3\u70B9\n const sourceWidth = sourceNode.measured?.width ?? sourceNode.width ?? 100\n const sourceHeight = sourceNode.measured?.height ?? sourceNode.height ?? 50\n const targetWidth = targetNode.measured?.width ?? targetNode.width ?? 100\n const targetHeight = targetNode.measured?.height ?? targetNode.height ?? 50\n\n const sourceCenter = {\n x: sourcePos.x + sourceWidth / 2,\n y: sourcePos.y + sourceHeight / 2,\n }\n const targetCenter = {\n x: targetPos.x + targetWidth / 2,\n y: targetPos.y + targetHeight / 2,\n }\n\n // \u8BA1\u7B97\u8DDD\u79BB\n const distance = this.calculateDistance(sourceCenter, targetCenter)\n\n // \u8BA1\u7B97\u5BC6\u5EA6\n const density = this.calculateNodeDensity(nodeLookup)\n\n // \u83B7\u53D6\u57FA\u4E8E\u8DDD\u79BB\u548C\u5BC6\u5EA6\u7684\u6B65\u957F\n const distanceStep = this.calculateDistanceBasedStep(distance)\n const densityStep = this.calculateDensityBasedStep(density)\n\n // \u53D6\u4E24\u8005\u4E2D\u8F83\u5C0F\u7684\u503C\uFF08\u66F4\u4FDD\u5B88\u7684\u9009\u62E9\uFF09\n const step = Math.min(distanceStep, densityStep)\n\n // \u786E\u4FDD\u6B65\u957F\u5728\u6709\u6548\u8303\u56F4\u5185\n return Math.max(this.config.minStep, Math.min(this.config.maxStep, step))\n }\n\n /**\n * \u83B7\u53D6\u5F53\u524D\u914D\u7F6E\n */\n getConfig(): AdaptiveStepConfig {\n return { ...this.config }\n }\n\n /**\n * \u66F4\u65B0\u914D\u7F6E\n */\n updateConfig(config: Partial<AdaptiveStepConfig>): void {\n this.config = this.mergeConfig({ ...this.config, ...config })\n }\n}\n", "import { Point } from '../geometry'\nimport type { ManhattanRouterOptions, ResolvedOptions, PerformanceConfig, DebugConfig } from './types'\nimport { defaults, directionMap } from './defaults'\nimport { DEFAULT_ADAPTIVE_STEP_CONFIG, type AdaptiveStepConfig } from '../utils/AdaptiveStepCalculator'\n\n/**\n * Default performance configuration\n */\nconst DEFAULT_PERFORMANCE_CONFIG: Required<PerformanceConfig> = {\n enableCache: true,\n cacheSize: 100,\n enableQuadTree: true,\n earlyTermination: false,\n}\n\n/**\n * Default debug configuration\n */\nconst DEFAULT_DEBUG_CONFIG: Required<DebugConfig> = {\n enableLogging: false,\n enableMetrics: false,\n logLevel: 'info',\n}\n\n/**\n * Normalize padding value to box format\n */\nfunction normalizePadding(\n padding: number | { top: number; right: number; bottom: number; left: number }\n): { top: number; right: number; bottom: number; left: number } {\n if (typeof padding === 'number') {\n return { top: padding, right: padding, bottom: padding, left: padding }\n }\n return padding\n}\n\n/**\n * Normalize angle to 0-360 range\n */\nexport function normalizeAngle(angle: number): number {\n while (angle < 0) {\n angle += 360\n }\n while (angle >= 360) {\n angle -= 360\n }\n return angle\n}\n\n/**\n * Validate and fix configuration options\n */\nfunction validateAndFixOptions(options: ManhattanRouterOptions): ManhattanRouterOptions {\n const fixed = { ...options }\n\n // Validate step\n if (fixed.step !== undefined && fixed.step <= 0) {\n console.warn('[ManhattanRouter] Invalid step value, using default')\n fixed.step = defaults.step\n }\n\n // Validate maxLoopCount\n if (fixed.maxLoopCount !== undefined && fixed.maxLoopCount <= 0) {\n console.warn('[ManhattanRouter] Invalid maxLoopCount, using default')\n fixed.maxLoopCount = defaults.maxLoopCount\n }\n\n // Validate borderRadius\n if (fixed.borderRadius !== undefined && fixed.borderRadius < 0) {\n console.warn('[ManhattanRouter] Invalid borderRadius, using default')\n fixed.borderRadius = defaults.borderRadius\n }\n\n // Validate extensionDistance\n if (fixed.extensionDistance !== undefined && fixed.extensionDistance < 0) {\n console.warn('[ManhattanRouter] Invalid extensionDistance, using default')\n fixed.extensionDistance = defaults.extensionDistance\n }\n\n // Validate precision\n if (fixed.precision !== undefined && (fixed.precision < 0 || fixed.precision > 10)) {\n console.warn('[ManhattanRouter] Invalid precision, using default')\n fixed.precision = defaults.precision\n }\n\n return fixed\n}\n\n/**\n * Resolve adaptive step configuration\n */\nfunction resolveAdaptiveStepConfig(config?: Partial<AdaptiveStepConfig>): AdaptiveStepConfig {\n if (!config) {\n return { ...DEFAULT_ADAPTIVE_STEP_CONFIG }\n }\n\n return {\n enabled: config.enabled ?? DEFAULT_ADAPTIVE_STEP_CONFIG.enabled,\n minStep: config.minStep ?? DEFAULT_ADAPTIVE_STEP_CONFIG.minStep,\n maxStep: config.maxStep ?? DEFAULT_ADAPTIVE_STEP_CONFIG.maxStep,\n densityBased: {\n enabled: config.densityBased?.enabled ?? DEFAULT_ADAPTIVE_STEP_CONFIG.densityBased.enabled,\n threshold: config.densityBased?.threshold ?? DEFAULT_ADAPTIVE_STEP_CONFIG.densityBased.threshold,\n },\n distanceBased: {\n enabled: config.distanceBased?.enabled ?? DEFAULT_ADAPTIVE_STEP_CONFIG.distanceBased.enabled,\n shortPathThreshold: config.distanceBased?.shortPathThreshold ?? DEFAULT_ADAPTIVE_STEP_CONFIG.distanceBased.shortPathThreshold,\n longPathThreshold: config.distanceBased?.longPathThreshold ?? DEFAULT_ADAPTIVE_STEP_CONFIG.distanceBased.longPathThreshold,\n },\n }\n}\n\n/**\n * Resolve performance configuration\n */\nfunction resolvePerformanceConfig(config?: PerformanceConfig): Required<PerformanceConfig> {\n if (!config) {\n return { ...DEFAULT_PERFORMANCE_CONFIG }\n }\n\n return {\n enableCache: config.enableCache ?? DEFAULT_PERFORMANCE_CONFIG.enableCache,\n cacheSize: config.cacheSize ?? DEFAULT_PERFORMANCE_CONFIG.cacheSize,\n enableQuadTree: config.enableQuadTree ?? DEFAULT_PERFORMANCE_CONFIG.enableQuadTree,\n earlyTermination: config.earlyTermination ?? DEFAULT_PERFORMANCE_CONFIG.earlyTermination,\n }\n}\n\n/**\n * Resolve debug configuration\n */\nfunction resolveDebugConfig(config?: DebugConfig): Required<DebugConfig> {\n if (!config) {\n return { ...DEFAULT_DEBUG_CONFIG }\n }\n\n return {\n enableLogging: config.enableLogging ?? DEFAULT_DEBUG_CONFIG.enableLogging,\n enableMetrics: config.enableMetrics ?? DEFAULT_DEBUG_CONFIG.enableMetrics,\n logLevel: config.logLevel ?? DEFAULT_DEBUG_CONFIG.logLevel,\n }\n}\n\n/**\n * Resolve options by merging user options with defaults\n */\nexport function resolveOptions(options: ManhattanRouterOptions = {}): ResolvedOptions {\n // Validate and fix options first\n const validatedOptions = validateAndFixOptions(options)\n\n const step = validatedOptions.step ?? defaults.step\n const maxLoopCount = validatedOptions.maxLoopCount ?? defaults.maxLoopCount\n const precision = validatedOptions.precision ?? defaults.precision\n const maxDirectionChange = validatedOptions.maxDirectionChange ?? defaults.maxDirectionChange\n const startDirections = validatedOptions.startDirections ?? defaults.startDirections\n const endDirections = validatedOptions.endDirections ?? defaults.endDirections\n const excludeNodes = validatedOptions.excludeNodes ?? defaults.excludeNodes\n const excludeShapes = validatedOptions.excludeShapes ?? defaults.excludeShapes\n const excludeTerminals = validatedOptions.excludeTerminals ?? defaults.excludeTerminals\n const borderRadius = validatedOptions.borderRadius ?? defaults.borderRadius\n const extensionDistance = validatedOptions.extensionDistance ?? defaults.extensionDistance\n const penalties = validatedOptions.penalties ?? defaults.penalties\n const fallbackRoute = validatedOptions.fallbackRoute\n\n // Convert padding to paddingBox\n const padding = validatedOptions.padding ?? defaults.padding\n const sides = normalizePadding(padding)\n const paddingBox = {\n x: -sides.left,\n y: -sides.top,\n width: sides.left + sides.right,\n height: sides.top + sides.bottom,\n }\n\n // Calculate cost (same as step)\n const cost = step\n\n // Calculate directions array with offsets and costs\n const directions = [\n { cost, offsetX: step, offsetY: 0, angle: 0 },\n { cost, offsetX: -step, offsetY: 0, angle: 0 },\n { cost, offsetX: 0, offsetY: step, angle: 0 },\n { cost, offsetX: 0, offsetY: -step, angle: 0 },\n ]\n\n // Calculate angle for each direction\n directions.forEach((direction) => {\n const point1 = new Point(0, 0)\n const point2 = new Point(direction.offsetX, direction.offsetY)\n direction.angle = normalizeAngle(point1.theta(point2))\n })\n\n // Resolve new configuration sections\n const adaptiveStep = resolveAdaptiveStepConfig(validatedOptions.adaptiveStep)\n const performance = resolvePerformanceConfig(validatedOptions.performance)\n const debug = resolveDebugConfig(validatedOptions.debug)\n\n return {\n step,\n maxLoopCount,\n precision,\n maxDirectionChange,\n startDirections,\n endDirections,\n excludeNodes,\n excludeShapes,\n excludeTerminals,\n paddingBox,\n borderRadius,\n extensionDistance,\n sourcePosition: (validatedOptions as any).sourcePosition,\n targetPosition: (validatedOptions as any).targetPosition,\n directionMap,\n directions,\n penalties,\n cost,\n fallbackRoute,\n previousDirectionAngle: undefined,\n adaptiveStep,\n performance,\n debug,\n }\n}\n", "import { Point } from '../geometry'\nimport type { ResolvedOptions } from '../options'\nimport { normalizeAngle } from '../options/resolver'\nimport type { Grid } from './grid'\n\n/**\n * Fix angle end point to account for grid deformation\n */\nfunction fixAngleEnd(\n start: Point,\n end: Point,\n grid: Grid,\n options: ResolvedOptions\n): Point {\n const step = options.step\n\n const diffX = end.x - start.x\n const diffY = end.y - start.y\n\n const gridStepsX = diffX / grid.x\n const gridStepsY = diffY / grid.y\n\n const distanceX = gridStepsX * step\n const distanceY = gridStepsY * step\n\n return new Point(start.x + distanceX, start.y + distanceY)\n}\n\n/**\n * Get direction angle from start point to end point\n * Corrects for grid deformation between start and end\n */\nexport function getDirectionAngle(\n start: Point,\n end: Point,\n directionCount: number,\n grid: Grid,\n options: ResolvedOptions\n): number {\n const quadrant = 360 / directionCount\n const angleTheta = start.theta(fixAngleEnd(start, end, grid, options))\n const normalizedAngle = normalizeAngle(angleTheta + quadrant / 2)\n return quadrant * Math.floor(normalizedAngle / quadrant)\n}\n\n/**\n * Get the change in direction between two direction angles\n */\nexport function getDirectionChange(angle1: number, angle2: number): number {\n const change = Math.abs(angle1 - angle2)\n return change > 180 ? 360 - change : change\n}\n\n/**\n * Fix direction offsets according to current grid\n */\nexport function getGridOffsets(grid: Grid, options: ResolvedOptions) {\n const step = options.step\n\n options.directions.forEach((direction) => {\n direction.gridOffsetX = (direction.offsetX / step) * grid.x\n direction.gridOffsetY = (direction.offsetY / step) * grid.y\n })\n\n return options.directions\n}\n", "import { Point, Rectangle, Line } from '../geometry'\nimport type { ResolvedOptions, Direction } from '../options'\nimport type { Grid } from './grid'\nimport { align } from './grid'\n\n/**\n * Check if a point is on the edge of a rectangle\n */\nfunction isPointOnRectangleEdge(point: Point, bbox: Rectangle, tolerance = 0.01): boolean {\n const onLeft = Math.abs(point.x - bbox.x) < tolerance\n const onRight = Math.abs(point.x - (bbox.x + bbox.width)) < tolerance\n const onTop = Math.abs(point.y - bbox.y) < tolerance\n const onBottom = Math.abs(point.y - (bbox.y + bbox.height)) < tolerance\n\n const withinVerticalBounds = point.y >= bbox.y - tolerance && point.y <= bbox.y + bbox.height + tolerance\n const withinHorizontalBounds = point.x >= bbox.x - tolerance && point.x <= bbox.x + bbox.width + tolerance\n\n return (onLeft || onRight) && withinVerticalBounds || (onTop || onBottom) && withinHorizontalBounds\n}\n\n/**\n * Check if a direction points outward from the rectangle edge where the anchor is located\n */\nfunction isDirectionOutward(\n anchor: Point,\n bbox: Rectangle,\n direction: { x: number; y: number },\n tolerance = 0.01\n): boolean {\n const onLeft = Math.abs(anchor.x - bbox.x) < tolerance\n const onRight = Math.abs(anchor.x - (bbox.x + bbox.width)) < tolerance\n const onTop = Math.abs(anchor.y - bbox.y) < tolerance\n const onBottom = Math.abs(anchor.y - (bbox.y + bbox.height)) < tolerance\n\n // Only allow outward directions from the edge\n if (onLeft && direction.x < 0) return true\n if (onRight && direction.x > 0) return true\n if (onTop && direction.y < 0) return true\n if (onBottom && direction.y > 0) return true\n\n // For corners, allow both perpendicular directions\n if ((onLeft || onRight) && direction.x === 0) return true\n if ((onTop || onBottom) && direction.y === 0) return true\n\n return false\n}\n\n/**\n * Get points around a rectangle taking given directions into account\n * Lines are drawn from anchor in given directions, intersections recorded\n */\nexport function getRectPoints(\n anchor: Point,\n bbox: Rectangle,\n directionList: Direction[],\n grid: Grid,\n options: ResolvedOptions\n): Point[] {\n const precision = options.precision\n const directionMap = options.directionMap\n const centerVector = anchor.diff(bbox.getCenter())\n\n const rectPoints: Point[] = []\n\n // Check if anchor is on the edge of the bbox\n const isOnEdge = isPointOnRectangleEdge(anchor, bbox)\n\n // Check each allowed direction\n for (const key of directionList) {\n const direction = directionMap[key]\n\n // If anchor is on edge, only consider outward directions\n if (isOnEdge) {\n const isOutward = isDirectionOutward(anchor, bbox, direction)\n if (!isOutward) {\n continue // Skip inward directions\n }\n\n // When anchor is on edge and direction is outward, create extension point directly\n // instead of trying to find intersection (which won't exist for outward directions)\n const extensionPoint = new Point(\n anchor.x + direction.x * grid.x,\n anchor.y + direction.y * grid.y\n )\n const target = align(extensionPoint, grid, precision)\n rectPoints.push(target)\n continue\n }\n\n // Create a line that is guaranteed to intersect the bbox if bbox\n // is in the direction even if anchor lies outside of bbox\n const ending = new Point(\n anchor.x + direction.x * (Math.abs(centerVector.x) + bbox.width),\n anchor.y + direction.y * (Math.abs(centerVector.y) + bbox.height)\n )\n const intersectionLine = new Line(anchor, ending)\n\n // Get the farther intersection, in case there are two\n const intersections = intersectionLine.intersect(bbox)\n let farthestIntersectionDistance: number | undefined\n let farthestIntersection: Point | null = null\n\n for (const intersection of intersections) {\n const distance = anchor.squaredDistance(intersection)\n if (\n farthestIntersectionDistance === undefined ||\n distance > farthestIntersectionDistance\n ) {\n farthestIntersectionDistance = distance\n farthestIntersection = intersection\n }\n }\n\n // If an intersection was found in this direction, it is our rectPoint\n if (farthestIntersection) {\n let target = align(farthestIntersection, grid, precision)\n\n // If the rectPoint lies inside the bbox, offset it by one more step\n if (bbox.containsPoint(target)) {\n target = align(\n target.translate(direction.x * grid.x, direction.y * grid.y),\n grid,\n precision\n )\n }\n\n rectPoints.push(target)\n }\n }\n\n // If anchor lies outside of bbox, add it to the array of points\n // If anchor is on edge, don't add it - force path to start from extended points\n if (!bbox.containsPoint(anchor) && !isOnEdge) {\n rectPoints.push(align(anchor, grid, precision))\n }\n\n return rectPoints\n}\n", "import { Point } from '../geometry'\n\n/**\n * Normalize a point to a unit direction vector\n */\nexport function normalizePoint(point: Point): Point {\n return new Point(\n point.x === 0 ? 0 : Math.abs(point.x) / point.x,\n point.y === 0 ? 0 : Math.abs(point.y) / point.y\n )\n}\n\n/**\n * Get string key for a point\n */\nexport function getKey(point: Point): string {\n return point.toString()\n}\n\n/**\n * Calculate minimum Manhattan distance from a point to multiple anchors\n */\nexport function getCost(from: Point, anchors: Point[]): number {\n let min = Infinity\n\n for (const anchor of anchors) {\n const dist = from.manhattanDistance(anchor)\n if (dist < min) {\n min = dist\n }\n }\n\n return min\n}\n\n/**\n * Reconstruct route by concatenating points with their parents\n * Removes redundant points in the same direction\n */\nexport function reconstructRoute(\n parents: Map<string, Point>,\n points: Map<string, Point>,\n tailPoint: Point,\n startPoint: Point,\n endPoint: Point\n): Point[] {\n\n const route: Point[] = []\n\n let prevDiff = normalizePoint(endPoint.diff(tailPoint))\n\n // tailPoint is assumed to be aligned already\n let currentKey = getKey(tailPoint)\n let parent = parents.get(currentKey)\n\n\n let point: Point | undefined\n let iterationCount = 0\n const maxIterations = 10000 // Safety limit\n\n while (parent && iterationCount < maxIterations) {\n iterationCount++\n\n if (iterationCount % 100 === 0) {\n }\n\n // point is assumed to be aligned already\n point = points.get(currentKey)\n\n if (point) {\n const diff = normalizePoint(point.diff(parent))\n if (!diff.equals(prevDiff)) {\n route.unshift(point)\n prevDiff = diff\n }\n }\n\n // parent is assumed to be aligned already\n const nextKey = getKey(parent)\n\n // CRITICAL: Check for circular reference\n if (nextKey === currentKey) {\n console.error('[reconstructRoute] CIRCULAR REFERENCE DETECTED! currentKey === nextKey:', currentKey)\n break\n }\n\n currentKey = nextKey\n parent = parents.get(currentKey)\n }\n\n if (iterationCount >= maxIterations) {\n console.error('[reconstructRoute] MAX ITERATIONS REACHED! Possible infinite loop.')\n }\n\n\n // leadPoint is assumed to be aligned already\n const leadPoint = points.get(currentKey)\n\n if (leadPoint) {\n const fromDiff = normalizePoint(leadPoint.diff(startPoint))\n if (!fromDiff.equals(prevDiff)) {\n route.unshift(leadPoint)\n }\n }\n\n return route\n}\n", "import type { InternalNode } from '../options'\n\n/**\n * Node dimensions interface\n */\nexport interface NodeDimensions {\n width: number\n height: number\n}\n\n/**\n * Get node dimensions following ReactFlow's internal logic\n * Priority: measured > direct property > initialWidth/Height > 0\n * \n * @param node - ReactFlow internal node\n * @returns Node dimensions with width and height\n */\nexport function getNodeDimensions(node: InternalNode): NodeDimensions {\n const width = node.measured?.width ?? node.width ?? node.initialWidth ?? 0\n const height = node.measured?.height ?? node.height ?? node.initialHeight ?? 0\n\n return { width, height }\n}\n\n/**\n * Get node absolute position from internals\n * \n * @param node - ReactFlow internal node\n * @returns Absolute position { x, y }\n */\nexport function getNodePosition(node: InternalNode): { x: number; y: number } {\n return node.internals.positionAbsolute\n}\n", "import { Point, Rectangle } from '../geometry'\nimport type { NodeLookup } from '../options'\nimport { getNodeDimensions, getNodePosition } from './node'\n\n/**\n * Get node bounding box\n */\nfunction getNodeBBox(nodeId: string, nodeLookup: NodeLookup): Rectangle | null {\n const node = nodeLookup.get(nodeId)\n if (!node) return null\n\n const dimensions = getNodeDimensions(node)\n const position = getNodePosition(node)\n return new Rectangle(position.x, position.y, dimensions.width, dimensions.height)\n}\n\n\n\n/**\n * Find unique intersection points between a line segment and a rectangle\n * Returns array of intersection points (deduplicated)\n */\nfunction findSegmentRectIntersections(p1: Point, p2: Point, rect: Rectangle): Point[] {\n const intersections: Point[] = []\n const tolerance = 0.01\n\n // Define rectangle edges\n const edges = [\n { start: new Point(rect.x, rect.y), end: new Point(rect.x + rect.width, rect.y) }, // Top\n { start: new Point(rect.x + rect.width, rect.y), end: new Point(rect.x + rect.width, rect.y + rect.height) }, // Right\n { start: new Point(rect.x + rect.width, rect.y + rect.height), end: new Point(rect.x, rect.y + rect.height) }, // Bottom\n { start: new Point(rect.x, rect.y + rect.height), end: new Point(rect.x, rect.y) }, // Left\n ]\n\n // Find intersection point with each edge\n for (const edge of edges) {\n const intersection = getLineSegmentIntersection(p1, p2, edge.start, edge.end)\n if (intersection) {\n // Check if this point is already in the list (avoid duplicates at corners)\n const isDuplicate = intersections.some(\n (existing) => Math.abs(existing.x - intersection.x) < tolerance && Math.abs(existing.y - intersection.y) < tolerance\n )\n if (!isDuplicate) {\n intersections.push(intersection)\n }\n }\n }\n\n return intersections\n}\n\n/**\n * Get intersection point between two line segments (if exists)\n */\nfunction getLineSegmentIntersection(p1: Point, p2: Point, p3: Point, p4: Point): Point | null {\n const d1 = direction(p3, p4, p1)\n const d2 = direction(p3, p4, p2)\n const d3 = direction(p1, p2, p3)\n const d4 = direction(p1, p2, p4)\n\n if (((d1 > 0 && d2 < 0) || (d1 < 0 && d2 > 0)) && ((d3 > 0 && d4 < 0) || (d3 < 0 && d4 > 0))) {\n // Lines intersect, calculate intersection point\n const t = ((p3.x - p1.x) * (p3.y - p4.y) - (p3.y - p1.y) * (p3.x - p4.x)) / ((p1.x - p2.x) * (p3.y - p4.y) - (p1.y - p2.y) * (p3.x - p4.x))\n return new Point(p1.x + t * (p2.x - p1.x), p1.y + t * (p2.y - p1.y))\n }\n\n // Check collinear cases\n if (d1 === 0 && onSegment(p3, p1, p4)) return p1.clone()\n if (d2 === 0 && onSegment(p3, p2, p4)) return p2.clone()\n if (d3 === 0 && onSegment(p1, p3, p2)) return p3.clone()\n if (d4 === 0 && onSegment(p1, p4, p2)) return p4.clone()\n\n return null\n}\n\n\n\nfunction direction(p1: Point, p2: Point, p3: Point): number {\n return (p3.x - p1.x) * (p2.y - p1.y) - (p2.x - p1.x) * (p3.y - p1.y)\n}\n\nfunction onSegment(p1: Point, p2: Point, p3: Point): boolean {\n return (\n p2.x >= Math.min(p1.x, p3.x) &&\n p2.x <= Math.max(p1.x, p3.x) &&\n p2.y >= Math.min(p1.y, p3.y) &&\n p2.y <= Math.max(p1.y, p3.y)\n )\n}\n\n/**\n * Check if a path intersects with any obstacles (nodes)\n * A path is considered to intersect if it has >= 2 unique intersection points with a node\n *\n * Note: pathPoints should be pre-processed by parseSVGPath which samples bezier curves\n * into line segments, so this function works correctly with curved paths\n */\nexport function pathIntersectsObstacles(pathPoints: Point[], nodeLookup: NodeLookup): boolean {\n const tolerance = 0.01\n\n // Iterate through all nodes (including source and target)\n for (const [nodeId] of nodeLookup) {\n const nodeBBox = getNodeBBox(nodeId, nodeLookup)\n if (!nodeBBox) continue\n\n const allIntersections: Point[] = []\n\n // Collect all unique intersection points for this node\n for (let i = 0; i < pathPoints.length - 1; i++) {\n const p1 = pathPoints[i]\n const p2 = pathPoints[i + 1]\n\n const segmentIntersections = findSegmentRectIntersections(p1, p2, nodeBBox)\n\n // Add to global list, avoiding duplicates\n for (const intersection of segmentIntersections) {\n const isDuplicate = allIntersections.some(\n (existing) => Math.abs(existing.x - intersection.x) < tolerance && Math.abs(existing.y - intersection.y) < tolerance\n )\n if (!isDuplicate) {\n allIntersections.push(intersection)\n }\n }\n }\n\n // If path has 2 or more unique intersections with this node, it crosses through it\n if (allIntersections.length >= 2) {\n return true\n }\n }\n\n return false\n}\n", "/**\n * ErrorRecovery - \u9519\u8BEF\u6062\u590D\u548C\u964D\u7EA7\u7B56\u7565\n *\n * \u63D0\u4F9B\u8DEF\u5F84\u8BA1\u7B97\u5931\u8D25\u65F6\u7684\u6062\u590D\u673A\u5236\uFF0C\u5305\u62EC\uFF1A\n * - \u8D85\u65F6\u68C0\u6D4B\u548C\u5904\u7406\n * - \u964D\u7EA7\u8DEF\u5F84\u751F\u6210\n * - \u9519\u8BEF\u5206\u7C7B\u548C\u62A5\u544A\n *\n * Implements: Requirements 4.2, 3.6\n */\n\nimport { Point, Rectangle } from '../geometry'\n\n/**\n * \u9519\u8BEF\u7C7B\u578B\u679A\u4E3E\n */\nexport enum PathfindingErrorType {\n /** \u8D85\u65F6\u9519\u8BEF - \u8BA1\u7B97\u65F6\u95F4\u8D85\u8FC7\u9650\u5236 */\n TIMEOUT = 'TIMEOUT',\n /** \u65E0\u8DEF\u5F84\u9519\u8BEF - \u65E0\u6CD5\u627E\u5230\u6709\u6548\u8DEF\u5F84 */\n NO_PATH = 'NO_PATH',\n /** \u65E0\u6548\u8F93\u5165\u9519\u8BEF - \u8F93\u5165\u53C2\u6570\u65E0\u6548 */\n INVALID_INPUT = 'INVALID_INPUT',\n /** \u969C\u788D\u7269\u963B\u585E\u9519\u8BEF - \u8D77\u70B9\u6216\u7EC8\u70B9\u88AB\u969C\u788D\u7269\u963B\u585E */\n BLOCKED = 'BLOCKED',\n /** \u5185\u90E8\u9519\u8BEF - \u7B97\u6CD5\u5185\u90E8\u9519\u8BEF */\n INTERNAL = 'INTERNAL',\n}\n\n/**\n * \u8DEF\u5F84\u8BA1\u7B97\u9519\u8BEF\n */\nexport class PathfindingError extends Error {\n constructor(\n public readonly type: PathfindingErrorType,\n message: string,\n public readonly details?: Record<string, unknown>\n ) {\n super(message)\n this.name = 'PathfindingError'\n }\n}\n\n/**\n * \u6062\u590D\u7B56\u7565\u7C7B\u578B\n */\nexport enum RecoveryStrategy {\n /** \u76F4\u7EBF\u8FDE\u63A5 */\n DIRECT_LINE = 'DIRECT_LINE',\n /** L\u5F62\u8DEF\u5F84 */\n L_SHAPE = 'L_SHAPE',\n /** Z\u5F62\u8DEF\u5F84 */\n Z_SHAPE = 'Z_SHAPE',\n /** \u7B80\u5316\u66FC\u54C8\u987F\u8DEF\u5F84 */\n SIMPLE_MANHATTAN = 'SIMPLE_MANHATTAN',\n /** \u65E0\u6062\u590D */\n NONE = 'NONE',\n}\n\n/**\n * \u6062\u590D\u7ED3\u679C\n */\nexport interface RecoveryResult {\n /** \u662F\u5426\u6210\u529F\u6062\u590D */\n success: boolean\n /** \u6062\u590D\u540E\u7684\u8DEF\u5F84 */\n path: Point[]\n /** \u4F7F\u7528\u7684\u6062\u590D\u7B56\u7565 */\n strategy: RecoveryStrategy\n /** \u539F\u59CB\u9519\u8BEF */\n originalError?: PathfindingError\n /** \u6062\u590D\u8017\u65F6\uFF08\u6BEB\u79D2\uFF09 */\n recoveryTime: number\n}\n\n/**\n * \u9519\u8BEF\u6062\u590D\u914D\u7F6E\n */\nexport interface ErrorRecoveryConfig {\n /** \u662F\u5426\u542F\u7528\u81EA\u52A8\u6062\u590D */\n enabled: boolean\n /** \u6700\u5927\u6062\u590D\u5C1D\u8BD5\u6B21\u6570 */\n maxAttempts: number\n /** \u6062\u590D\u7B56\u7565\u4F18\u5148\u7EA7 */\n strategyPriority: RecoveryStrategy[]\n /** \u662F\u5426\u8BB0\u5F55\u6062\u590D\u65E5\u5FD7 */\n logRecovery: boolean\n}\n\n/**\n * \u9ED8\u8BA4\u6062\u590D\u914D\u7F6E\n */\nexport const DEFAULT_RECOVERY_CONFIG: ErrorRecoveryConfig = {\n enabled: true,\n maxAttempts: 3,\n strategyPriority: [\n RecoveryStrategy.SIMPLE_MANHATTAN,\n RecoveryStrategy.L_SHAPE,\n RecoveryStrategy.Z_SHAPE,\n RecoveryStrategy.DIRECT_LINE,\n ],\n logRecovery: false,\n}\n\n/**\n * \u9519\u8BEF\u6062\u590D\u7C7B\n */\nexport class ErrorRecovery {\n private config: ErrorRecoveryConfig\n private recoveryAttempts: number = 0\n\n constructor(config: Partial<ErrorRecoveryConfig> = {}) {\n this.config = { ...DEFAULT_RECOVERY_CONFIG, ...config }\n }\n\n /**\n * \u5C1D\u8BD5\u6062\u590D\u8DEF\u5F84\u8BA1\u7B97\n */\n recover(\n from: Point,\n to: Point,\n error: PathfindingError,\n obstacles?: Rectangle[]\n ): RecoveryResult {\n const startTime = performance.now()\n\n if (!this.config.enabled) {\n return {\n success: false,\n path: [],\n strategy: RecoveryStrategy.NONE,\n originalError: error,\n recoveryTime: performance.now() - startTime,\n }\n }\n\n this.recoveryAttempts = 0\n\n for (const strategy of this.config.strategyPriority) {\n if (this.recoveryAttempts >= this.config.maxAttempts) {\n break\n }\n\n this.recoveryAttempts++\n\n const path = this.applyStrategy(strategy, from, to, obstacles)\n\n if (path.length > 0) {\n if (this.config.logRecovery) {\n console.info(\n `[ErrorRecovery] Recovered using ${strategy} after ${this.recoveryAttempts} attempts`\n )\n }\n\n return {\n success: true,\n path,\n strategy,\n originalError: error,\n recoveryTime: performance.now() - startTime,\n }\n }\n }\n\n // \u6240\u6709\u7B56\u7565\u90FD\u5931\u8D25\uFF0C\u8FD4\u56DE\u76F4\u7EBF\u4F5C\u4E3A\u6700\u540E\u624B\u6BB5\n return {\n success: true,\n path: [from, to],\n strategy: RecoveryStrategy.DIRECT_LINE,\n originalError: error,\n recoveryTime: performance.now() - startTime,\n }\n }\n\n /**\n * \u5E94\u7528\u6062\u590D\u7B56\u7565\n */\n private applyStrategy(\n strategy: RecoveryStrategy,\n from: Point,\n to: Point,\n obstacles?: Rectangle[]\n ): Point[] {\n switch (strategy) {\n case RecoveryStrategy.DIRECT_LINE:\n return this.directLine(from, to)\n\n case RecoveryStrategy.L_SHAPE:\n return this.lShape(from, to, obstacles)\n\n case RecoveryStrategy.Z_SHAPE:\n return this.zShape(from, to, obstacles)\n\n case RecoveryStrategy.SIMPLE_MANHATTAN:\n return this.simpleManhattan(from, to, obstacles)\n\n default:\n return []\n }\n }\n\n /**\n * \u76F4\u7EBF\u8FDE\u63A5\u7B56\u7565\n */\n private directLine(from: Point, to: Point): Point[] {\n return [from, to]\n }\n\n /**\n * L\u5F62\u8DEF\u5F84\u7B56\u7565\n */\n private lShape(from: Point, to: Point, obstacles?: Rectangle[]): Point[] {\n // \u5C1D\u8BD5\u5148\u6C34\u5E73\u540E\u5782\u76F4\n const corner1 = new Point(to.x, from.y)\n const path1 = [from, corner1, to]\n\n if (!obstacles || !this.pathIntersectsObstacles(path1, obstacles)) {\n return path1\n }\n\n // \u5C1D\u8BD5\u5148\u5782\u76F4\u540E\u6C34\u5E73\n const corner2 = new Point(from.x, to.y)\n const path2 = [from, corner2, to]\n\n if (!obstacles || !this.pathIntersectsObstacles(path2, obstacles)) {\n return path2\n }\n\n return []\n }\n\n /**\n * Z\u5F62\u8DEF\u5F84\u7B56\u7565\n */\n private zShape(from: Point, to: Point, obstacles?: Rectangle[]): Point[] {\n const midX = (from.x + to.x) / 2\n const midY = (from.y + to.y) / 2\n\n // \u5C1D\u8BD5\u6C34\u5E73-\u5782\u76F4-\u6C34\u5E73 Z\u5F62\n const path1 = [from, new Point(midX, from.y), new Point(midX, to.y), to]\n\n if (!obstacles || !this.pathIntersectsObstacles(path1, obstacles)) {\n return path1\n }\n\n // \u5C1D\u8BD5\u5782\u76F4-\u6C34\u5E73-\u5782\u76F4 Z\u5F62\n const path2 = [from, new Point(from.x, midY), new Point(to.x, midY), to]\n\n if (!obstacles || !this.pathIntersectsObstacles(path2, obstacles)) {\n return path2\n }\n\n return []\n }\n\n /**\n * \u7B80\u5316\u66FC\u54C8\u987F\u8DEF\u5F84\u7B56\u7565\n */\n private simpleManhattan(\n from: Point,\n to: Point,\n obstacles?: Rectangle[]\n ): Point[] {\n const offsets = [0.25, 0.5, 0.75, 0.1, 0.9]\n\n for (const offset of offsets) {\n // \u6C34\u5E73\u65B9\u5411\u504F\u79FB\n const midX = from.x + (to.x - from.x) * offset\n const path1 = [from, new Point(midX, from.y), new Point(midX, to.y), to]\n\n if (!obstacles || !this.pathIntersectsObstacles(path1, obstacles)) {\n return path1\n }\n\n // \u5782\u76F4\u65B9\u5411\u504F\u79FB\n const midY = from.y + (to.y - from.y) * offset\n const path2 = [from, new Point(from.x, midY), new Point(to.x, midY), to]\n\n if (!obstacles || !this.pathIntersectsObstacles(path2, obstacles)) {\n return path2\n }\n }\n\n return []\n }\n\n /**\n * \u68C0\u67E5\u8DEF\u5F84\u662F\u5426\u4E0E\u969C\u788D\u7269\u76F8\u4EA4\n */\n private pathIntersectsObstacles(\n path: Point[],\n obstacles: Rectangle[]\n ): boolean {\n for (let i = 0; i < path.length - 1; i++) {\n const p1 = path[i]\n const p2 = path[i + 1]\n\n for (const obstacle of obstacles) {\n if (this.lineIntersectsRect(p1, p2, obstacle)) {\n return true\n }\n }\n }\n\n return false\n }\n\n /**\n * \u68C0\u67E5\u7EBF\u6BB5\u662F\u5426\u4E0E\u77E9\u5F62\u76F8\u4EA4\n */\n private lineIntersectsRect(p1: Point, p2: Point, rect: Rectangle): boolean {\n const minX = rect.x\n const maxX = rect.x + rect.width\n const minY = rect.y\n const maxY = rect.y + rect.height\n\n // \u68C0\u67E5\u7EBF\u6BB5\u662F\u5426\u5B8C\u5168\u5728\u77E9\u5F62\u5916\u90E8\n if (\n (p1.x < minX && p2.x < minX) ||\n (p1.x > maxX && p2.x > maxX) ||\n (p1.y < minY && p2.y < minY) ||\n (p1.y > maxY && p2.y > maxY)\n ) {\n return false\n }\n\n // \u68C0\u67E5\u7EBF\u6BB5\u7AEF\u70B9\u662F\u5426\u5728\u77E9\u5F62\u5185\u90E8\n if (this.pointInRect(p1, rect) || this.pointInRect(p2, rect)) {\n return true\n }\n\n // \u68C0\u67E5\u7EBF\u6BB5\u662F\u5426\u4E0E\u77E9\u5F62\u7684\u56DB\u6761\u8FB9\u76F8\u4EA4\n return (\n this.lineIntersectsLine(\n p1,\n p2,\n new Point(minX, minY),\n new Point(maxX, minY)\n ) ||\n this.lineIntersectsLine(\n p1,\n p2,\n new Point(maxX, minY),\n new Point(maxX, maxY)\n ) ||\n this.lineIntersectsLine(\n p1,\n p2,\n new Point(maxX, maxY),\n new Point(minX, maxY)\n ) ||\n this.lineIntersectsLine(\n p1,\n p2,\n new Point(minX, maxY),\n new Point(minX, minY)\n )\n )\n }\n\n /**\n * \u68C0\u67E5\u70B9\u662F\u5426\u5728\u77E9\u5F62\u5185\u90E8\n */\n private pointInRect(p: Point, rect: Rectangle): boolean {\n return (\n p.x > rect.x &&\n p.x < rect.x + rect.width &&\n p.y > rect.y &&\n p.y < rect.y + rect.height\n )\n }\n\n /**\n * \u68C0\u67E5\u4E24\u6761\u7EBF\u6BB5\u662F\u5426\u76F8\u4EA4\n */\n private lineIntersectsLine(\n p1: Point,\n p2: Point,\n p3: Point,\n p4: Point\n ): boolean {\n const d1 = this.direction(p3, p4, p1)\n const d2 = this.direction(p3, p4, p2)\n const d3 = this.direction(p1, p2, p3)\n const d4 = this.direction(p1, p2, p4)\n\n if (\n ((d1 > 0 && d2 < 0) || (d1 < 0 && d2 > 0)) &&\n ((d3 > 0 && d4 < 0) || (d3 < 0 && d4 > 0))\n ) {\n return true\n }\n\n if (d1 === 0 && this.onSegment(p3, p4, p1)) return true\n if (d2 === 0 && this.onSegment(p3, p4, p2)) return true\n if (d3 === 0 && this.onSegment(p1, p2, p3)) return true\n if (d4 === 0 && this.onSegment(p1, p2, p4)) return true\n\n return false\n }\n\n /**\n * \u8BA1\u7B97\u53C9\u79EF\u65B9\u5411\n */\n private direction(p1: Point, p2: Point, p3: Point): number {\n return (p3.x - p1.x) * (p2.y - p1.y) - (p2.x - p1.x) * (p3.y - p1.y)\n }\n\n /**\n * \u68C0\u67E5\u70B9\u662F\u5426\u5728\u7EBF\u6BB5\u4E0A\n */\n private onSegment(p1: Point, p2: Point, p: Point): boolean {\n return (\n p.x >= Math.min(p1.x, p2.x) &&\n p.x <= Math.max(p1.x, p2.x) &&\n p.y >= Math.min(p1.y, p2.y) &&\n p.y <= Math.max(p1.y, p2.y)\n )\n }\n\n /**\n * \u521B\u5EFA\u8D85\u65F6\u9519\u8BEF\n */\n static createTimeoutError(\n iterations: number,\n maxIterations: number\n ): PathfindingError {\n return new PathfindingError(\n PathfindingErrorType.TIMEOUT,\n `Pathfinding timeout: exceeded ${maxIterations} iterations`,\n { iterations, maxIterations }\n )\n }\n\n /**\n * \u521B\u5EFA\u65E0\u8DEF\u5F84\u9519\u8BEF\n */\n static createNoPathError(from: Point, to: Point): PathfindingError {\n return new PathfindingError(\n PathfindingErrorType.NO_PATH,\n `No path found from (${from.x}, ${from.y}) to (${to.x}, ${to.y})`,\n { from: { x: from.x, y: from.y }, to: { x: to.x, y: to.y } }\n )\n }\n\n /**\n * \u521B\u5EFA\u65E0\u6548\u8F93\u5165\u9519\u8BEF\n */\n static createInvalidInputError(message: string): PathfindingError {\n return new PathfindingError(PathfindingErrorType.INVALID_INPUT, message)\n }\n\n /**\n * \u521B\u5EFA\u963B\u585E\u9519\u8BEF\n */\n static createBlockedError(\n point: Point,\n type: 'source' | 'target'\n ): PathfindingError {\n return new PathfindingError(\n PathfindingErrorType.BLOCKED,\n `${type === 'source' ? 'Source' : 'Target'} point (${point.x}, ${point.y}) is blocked`,\n { point: { x: point.x, y: point.y }, type }\n )\n }\n\n /**\n * \u521B\u5EFA\u5185\u90E8\u9519\u8BEF\n */\n static createInternalError(\n message: string,\n cause?: Error\n ): PathfindingError {\n return new PathfindingError(PathfindingErrorType.INTERNAL, message, {\n cause: cause?.message,\n })\n }\n\n /**\n * \u751F\u6210\u56DE\u9000\u8DEF\u5F84\uFF08\u9759\u6001\u65B9\u6CD5\uFF09\n */\n static generateFallbackPath(source: Point, target: Point): Point[] {\n const midX = (source.x + target.x) / 2\n return [source, new Point(midX, source.y), new Point(midX, target.y), target]\n }\n\n /**\n * \u9A8C\u8BC1\u5E76\u4FEE\u590D\u914D\u7F6E\u9009\u9879\n */\n static validateAndFixOptions<T extends Record<string, unknown>>(\n options: T,\n defaults: T\n ): T {\n const fixed = { ...options }\n\n for (const key of Object.keys(defaults)) {\n const value = fixed[key]\n const defaultValue = defaults[key]\n\n if (value === undefined || value === null) {\n ;(fixed as Record<string, unknown>)[key] = defaultValue\n } else if (typeof defaultValue === 'number' && typeof value === 'number') {\n if (value <= 0 && defaultValue > 0) {\n console.warn(`Invalid ${key} value (${value}), using default (${defaultValue})`)\n ;(fixed as Record<string, unknown>)[key] = defaultValue\n }\n }\n }\n\n return fixed\n }\n\n /**\n * \u83B7\u53D6\u6062\u590D\u5C1D\u8BD5\u6B21\u6570\n */\n getRecoveryAttempts(): number {\n return this.recoveryAttempts\n }\n\n /**\n * \u91CD\u7F6E\u6062\u590D\u72B6\u6001\n */\n reset(): void {\n this.recoveryAttempts = 0\n }\n\n /**\n * \u66F4\u65B0\u914D\u7F6E\n */\n updateConfig(config: Partial<ErrorRecoveryConfig>): void {\n this.config = { ...this.config, ...config }\n }\n\n /**\n * \u83B7\u53D6\u5F53\u524D\u914D\u7F6E\n */\n getConfig(): ErrorRecoveryConfig {\n return { ...this.config }\n }\n}\n", "/**\n * QuadTree implementation for efficient spatial queries\n * Feature: manhattan-optimization\n *\n * A QuadTree is a tree data structure that recursively subdivides 2D space\n * into four quadrants. This enables O(log n) spatial queries instead of O(n).\n */\nimport { Point, Rectangle } from '../geometry'\n\n/**\n * Item stored in the QuadTree\n */\nexport interface QuadTreeItem<T> {\n bounds: Rectangle\n data: T\n}\n\n/**\n * QuadTree configuration\n */\nexport interface QuadTreeConfig {\n /** Maximum items per node before splitting */\n maxItems: number\n /** Maximum depth of the tree */\n maxDepth: number\n /** Minimum node size (prevents infinite subdivision) */\n minSize: number\n}\n\n/**\n * Default QuadTree configuration\n */\nconst DEFAULT_CONFIG: QuadTreeConfig = {\n maxItems: 8,\n maxDepth: 8,\n minSize: 10,\n}\n\n/**\n * QuadTree node for spatial partitioning\n */\nexport class QuadTree<T> {\n private bounds: Rectangle\n private items: QuadTreeItem<T>[]\n private children: QuadTree<T>[] | null\n private depth: number\n private config: QuadTreeConfig\n\n constructor(\n bounds: Rectangle,\n config: Partial<QuadTreeConfig> = {},\n depth: number = 0\n ) {\n this.bounds = bounds\n this.items = []\n this.children = null\n this.depth = depth\n this.config = { ...DEFAULT_CONFIG, ...config }\n }\n\n /**\n * Insert an item into the QuadTree\n */\n insert(item: QuadTreeItem<T>): boolean {\n // Check if item intersects this node's bounds\n if (!this.intersects(item.bounds)) {\n return false\n }\n\n // If we have children, try to insert into them\n if (this.children !== null) {\n return this.insertIntoChildren(item)\n }\n\n // Add to this node\n this.items.push(item)\n\n // Check if we need to split\n if (this.shouldSplit()) {\n this.split()\n }\n\n return true\n }\n\n /**\n * Insert an item with just bounds and data\n */\n insertRect(bounds: Rectangle, data: T): boolean {\n return this.insert({ bounds, data })\n }\n\n /**\n * Query all items that intersect with the given bounds\n */\n query(bounds: Rectangle): QuadTreeItem<T>[] {\n const results: QuadTreeItem<T>[] = []\n this.queryInternal(bounds, results)\n return results\n }\n\n /**\n * Query all items that contain the given point\n */\n queryPoint(point: Point): QuadTreeItem<T>[] {\n const results: QuadTreeItem<T>[] = []\n this.queryPointInternal(point, results)\n return results\n }\n\n /**\n * Get all items in the tree\n */\n getAllItems(): QuadTreeItem<T>[] {\n const results: QuadTreeItem<T>[] = [...this.items]\n\n if (this.children !== null) {\n for (const child of this.children) {\n results.push(...child.getAllItems())\n }\n }\n\n return results\n }\n\n /**\n * Clear all items from the tree\n */\n clear(): void {\n this.items = []\n this.children = null\n }\n\n /**\n * Get the total number of items in the tree\n */\n get size(): number {\n let count = this.items.length\n\n if (this.children !== null) {\n for (const child of this.children) {\n count += child.size\n }\n }\n\n return count\n }\n\n /**\n * Get the depth of the tree\n */\n getMaxDepth(): number {\n if (this.children === null) {\n return this.depth\n }\n\n let maxChildDepth = this.depth\n for (const child of this.children) {\n maxChildDepth = Math.max(maxChildDepth, child.getMaxDepth())\n }\n\n return maxChildDepth\n }\n\n /**\n * Internal query implementation\n */\n private queryInternal(bounds: Rectangle, results: QuadTreeItem<T>[]): void {\n // Check if query bounds intersects this node\n if (!this.intersects(bounds)) {\n return\n }\n\n // Check items in this node\n for (const item of this.items) {\n if (this.rectanglesIntersect(item.bounds, bounds)) {\n results.push(item)\n }\n }\n\n // Query children\n if (this.children !== null) {\n for (const child of this.children) {\n child.queryInternal(bounds, results)\n }\n }\n }\n\n /**\n * Internal point query implementation\n */\n private queryPointInternal(point: Point, results: QuadTreeItem<T>[]): void {\n // Check if point is within this node's bounds\n if (!this.containsPoint(point)) {\n return\n }\n\n // Check items in this node\n for (const item of this.items) {\n if (item.bounds.containsPoint(point)) {\n results.push(item)\n }\n }\n\n // Query children\n if (this.children !== null) {\n for (const child of this.children) {\n child.queryPointInternal(point, results)\n }\n }\n }\n\n /**\n * Check if this node should split\n */\n private shouldSplit(): boolean {\n return (\n this.items.length > this.config.maxItems &&\n this.depth < this.config.maxDepth &&\n this.bounds.width > this.config.minSize * 2 &&\n this.bounds.height > this.config.minSize * 2\n )\n }\n\n /**\n * Split this node into four children\n */\n private split(): void {\n const halfWidth = this.bounds.width / 2\n const halfHeight = this.bounds.height / 2\n const x = this.bounds.x\n const y = this.bounds.y\n const nextDepth = this.depth + 1\n\n this.children = [\n // Top-left\n new QuadTree<T>(\n new Rectangle(x, y, halfWidth, halfHeight),\n this.config,\n nextDepth\n ),\n // Top-right\n new QuadTree<T>(\n new Rectangle(x + halfWidth, y, halfWidth, halfHeight),\n this.config,\n nextDepth\n ),\n // Bottom-left\n new QuadTree<T>(\n new Rectangle(x, y + halfHeight, halfWidth, halfHeight),\n this.config,\n nextDepth\n ),\n // Bottom-right\n new QuadTree<T>(\n new Rectangle(x + halfWidth, y + halfHeight, halfWidth, halfHeight),\n this.config,\n nextDepth\n ),\n ]\n\n // Redistribute items to children\n const itemsToRedistribute = this.items\n this.items = []\n\n for (const item of itemsToRedistribute) {\n this.insertIntoChildren(item)\n }\n }\n\n /**\n * Insert item into appropriate children\n */\n private insertIntoChildren(item: QuadTreeItem<T>): boolean {\n if (this.children === null) {\n return false\n }\n\n let inserted = false\n for (const child of this.children) {\n if (child.insert(item)) {\n inserted = true\n }\n }\n\n // If item doesn't fit in any child (spans multiple), keep in this node\n if (!inserted) {\n this.items.push(item)\n inserted = true\n }\n\n return inserted\n }\n\n /**\n * Check if a rectangle intersects this node's bounds\n */\n private intersects(rect: Rectangle): boolean {\n return this.rectanglesIntersect(this.bounds, rect)\n }\n\n /**\n * Check if two rectangles intersect\n */\n private rectanglesIntersect(a: Rectangle, b: Rectangle): boolean {\n return !(\n a.x + a.width <= b.x ||\n b.x + b.width <= a.x ||\n a.y + a.height <= b.y ||\n b.y + b.height <= a.y\n )\n }\n\n /**\n * Check if this node's bounds contain a point\n */\n private containsPoint(point: Point): boolean {\n return (\n point.x >= this.bounds.x &&\n point.x <= this.bounds.x + this.bounds.width &&\n point.y >= this.bounds.y &&\n point.y <= this.bounds.y + this.bounds.height\n )\n }\n\n /**\n * Get statistics about the tree\n */\n getStats(): {\n totalItems: number\n maxDepth: number\n nodeCount: number\n itemsPerNode: number\n } {\n const stats = {\n totalItems: 0,\n maxDepth: 0,\n nodeCount: 0,\n itemsPerNode: 0,\n }\n\n this.collectStats(stats)\n stats.itemsPerNode = stats.nodeCount > 0 ? stats.totalItems / stats.nodeCount : 0\n\n return stats\n }\n\n private collectStats(stats: {\n totalItems: number\n maxDepth: number\n nodeCount: number\n }): void {\n stats.totalItems += this.items.length\n stats.maxDepth = Math.max(stats.maxDepth, this.depth)\n stats.nodeCount++\n\n if (this.children !== null) {\n for (const child of this.children) {\n child.collectStats(stats)\n }\n }\n }\n}\n\n/**\n * Create a QuadTree with bounds that cover all given rectangles\n */\nexport function createQuadTreeFromRects<T>(\n items: Array<{ bounds: Rectangle; data: T }>,\n config?: Partial<QuadTreeConfig>\n): QuadTree<T> {\n if (items.length === 0) {\n return new QuadTree<T>(new Rectangle(0, 0, 1000, 1000), config)\n }\n\n // Calculate bounding box of all items\n let minX = Infinity\n let minY = Infinity\n let maxX = -Infinity\n let maxY = -Infinity\n\n for (const item of items) {\n minX = Math.min(minX, item.bounds.x)\n minY = Math.min(minY, item.bounds.y)\n maxX = Math.max(maxX, item.bounds.x + item.bounds.width)\n maxY = Math.max(maxY, item.bounds.y + item.bounds.height)\n }\n\n // Add some padding\n const padding = 100\n const bounds = new Rectangle(\n minX - padding,\n minY - padding,\n maxX - minX + padding * 2,\n maxY - minY + padding * 2\n )\n\n const tree = new QuadTree<T>(bounds, config)\n\n for (const item of items) {\n tree.insert(item)\n }\n\n return tree\n}\n", "import { Point, Rectangle } from '../geometry'\nimport type { ResolvedOptions, NodeLookup } from '../options'\nimport { getNodePosition, getNodeDimensions } from '../utils'\nimport { QuadTree, createQuadTreeFromRects } from './QuadTree'\n\n/**\n * ObstacleMap class for managing obstacles in pathfinding\n * Feature: manhattan-optimization\n *\n * Uses QuadTree for efficient spatial queries (O(log n) instead of O(n))\n * Includes query caching for repeated accessibility checks\n */\nexport class ObstacleMap {\n private options: ResolvedOptions\n private quadTree: QuadTree<string> | null = null\n private obstacles: Array<{ bounds: Rectangle; nodeId: string }> = []\n private sourceAnchor?: Point\n private targetAnchor?: Point\n\n // Query cache for repeated accessibility checks\n private accessibilityCache: Map<string, boolean> = new Map()\n private cacheHits: number = 0\n private cacheMisses: number = 0\n\n constructor(options: ResolvedOptions) {\n this.options = options\n }\n\n /**\n * Get cache statistics for performance monitoring\n */\n getCacheStats(): { hits: number; misses: number; hitRate: number } {\n const total = this.cacheHits + this.cacheMisses\n return {\n hits: this.cacheHits,\n misses: this.cacheMisses,\n hitRate: total > 0 ? this.cacheHits / total : 0,\n }\n }\n\n /**\n * Clear the accessibility cache\n */\n clearCache(): void {\n this.accessibilityCache.clear()\n this.cacheHits = 0\n this.cacheMisses = 0\n }\n\n /**\n * Build obstacle map from node lookup using QuadTree\n */\n build(\n nodeLookup: NodeLookup,\n sourceNodeId: string,\n targetNodeId: string,\n sourceAnchor?: Point,\n targetAnchor?: Point\n ): ObstacleMap {\n const { excludeNodes, excludeShapes, excludeTerminals, paddingBox } = this.options\n\n // Store anchors for later use in isAccessible\n this.sourceAnchor = sourceAnchor\n this.targetAnchor = targetAnchor\n\n // Clear previous data\n this.obstacles = []\n this.clearCache()\n\n // Collect all obstacles\n nodeLookup.forEach((node) => {\n // Check if node should be excluded\n const isExcludedNode = excludeNodes.includes(node.id)\n const isExcludedShape = node.type ? excludeShapes.includes(node.type) : false\n const isSourceTerminal = excludeTerminals.includes('source') && node.id === sourceNodeId\n const isTargetTerminal = excludeTerminals.includes('target') && node.id === targetNodeId\n\n // Skip if node should be excluded\n if (isExcludedNode || isExcludedShape || isSourceTerminal || isTargetTerminal) {\n return\n }\n\n // Calculate node bounding box with padding\n const position = getNodePosition(node)\n const dimensions = getNodeDimensions(node)\n\n const bbox = new Rectangle(\n position.x,\n position.y,\n dimensions.width,\n dimensions.height\n ).moveAndExpand(paddingBox)\n\n this.obstacles.push({ bounds: bbox, nodeId: node.id })\n })\n\n // Build QuadTree from obstacles\n this.quadTree = createQuadTreeFromRects(\n this.obstacles.map((o) => ({ bounds: o.bounds, data: o.nodeId }))\n )\n\n return this\n }\n\n /**\n * Check if a point is accessible (not inside any obstacle)\n * Uses QuadTree for efficient spatial queries with caching\n */\n isAccessible(point: Point, checkRadius: number = 0): boolean {\n // Generate cache key\n const cacheKey = `${point.x},${point.y},${checkRadius}`\n\n // Check cache first\n if (this.accessibilityCache.has(cacheKey)) {\n this.cacheHits++\n return this.accessibilityCache.get(cacheKey)!\n }\n\n this.cacheMisses++\n\n // Check if point is near an anchor - if so, allow it\n const margin = (this.options.step || 10) * 3\n\n if (this.sourceAnchor) {\n const distToSource = Math.abs(point.x - this.sourceAnchor.x) + Math.abs(point.y - this.sourceAnchor.y)\n if (distToSource < margin) {\n this.accessibilityCache.set(cacheKey, true)\n return true\n }\n }\n\n if (this.targetAnchor) {\n const distToTarget = Math.abs(point.x - this.targetAnchor.x) + Math.abs(point.y - this.targetAnchor.y)\n if (distToTarget < margin) {\n this.accessibilityCache.set(cacheKey, true)\n return true\n }\n }\n\n // If no QuadTree, point is accessible\n if (!this.quadTree) {\n this.accessibilityCache.set(cacheKey, true)\n return true\n }\n\n // Query QuadTree for obstacles at this point\n const obstacles = this.quadTree.queryPoint(point)\n\n // If checkRadius is specified, use binary search to find accessible points\n if (checkRadius > 0 && obstacles.length > 0) {\n const result = this.isAccessibleWithBinarySearch(point, checkRadius, obstacles.map((o) => o.bounds))\n this.accessibilityCache.set(cacheKey, result)\n return result\n }\n\n const accessible = obstacles.length === 0\n this.accessibilityCache.set(cacheKey, accessible)\n return accessible\n }\n\n /**\n * Check if an anchor point has sufficient clearance around it\n * This ensures the path can start/end at the anchor without being blocked\n */\n hasAnchorClearance(anchor: Point, direction: 'top' | 'right' | 'bottom' | 'left'): boolean {\n const step = this.options.step || 10\n const clearanceDistance = step * 2\n\n // Direction vectors\n const directionVectors: Record<string, { dx: number; dy: number }> = {\n top: { dx: 0, dy: -1 },\n right: { dx: 1, dy: 0 },\n bottom: { dx: 0, dy: 1 },\n left: { dx: -1, dy: 0 },\n }\n\n const dir = directionVectors[direction]\n if (!dir) return true\n\n // Check points along the direction\n for (let dist = step; dist <= clearanceDistance; dist += step) {\n const testPoint = new Point(\n anchor.x + dir.dx * dist,\n anchor.y + dir.dy * dist\n )\n\n // Temporarily remove anchor from consideration\n const originalSourceAnchor = this.sourceAnchor\n const originalTargetAnchor = this.targetAnchor\n this.sourceAnchor = undefined\n this.targetAnchor = undefined\n\n const accessible = this.isAccessibleWithoutCache(testPoint)\n\n // Restore anchors\n this.sourceAnchor = originalSourceAnchor\n this.targetAnchor = originalTargetAnchor\n\n if (!accessible) {\n return false\n }\n }\n\n return true\n }\n\n /**\n * Check accessibility without using cache (for internal use)\n */\n private isAccessibleWithoutCache(point: Point): boolean {\n if (!this.quadTree) {\n return true\n }\n\n const obstacles = this.quadTree.queryPoint(point)\n return obstacles.length === 0\n }\n\n /**\n * Find the nearest accessible point from an anchor in a given direction\n * Uses binary search for efficiency\n */\n findNearestAccessiblePoint(\n anchor: Point,\n direction: 'top' | 'right' | 'bottom' | 'left',\n maxDistance: number\n ): Point | null {\n const directionVectors: Record<string, { dx: number; dy: number }> = {\n top: { dx: 0, dy: -1 },\n right: { dx: 1, dy: 0 },\n bottom: { dx: 0, dy: 1 },\n left: { dx: -1, dy: 0 },\n }\n\n const dir = directionVectors[direction]\n if (!dir) return null\n\n const step = this.options.step || 10\n\n // First, find an accessible point using linear search\n let foundDistance = -1\n for (let dist = step; dist <= maxDistance; dist += step) {\n const testPoint = new Point(\n anchor.x + dir.dx * dist,\n anchor.y + dir.dy * dist\n )\n\n if (this.isAccessible(testPoint)) {\n foundDistance = dist\n break\n }\n }\n\n if (foundDistance < 0) {\n return null\n }\n\n // Binary search to find the closest accessible point\n let left = Math.max(0, foundDistance - step)\n let right = foundDistance\n let bestDistance = foundDistance\n\n while (right - left > 1) {\n const mid = Math.floor((left + right) / 2)\n const testPoint = new Point(\n anchor.x + dir.dx * mid,\n anchor.y + dir.dy * mid\n )\n\n if (this.isAccessible(testPoint)) {\n bestDistance = mid\n right = mid\n } else {\n left = mid\n }\n }\n\n return new Point(\n anchor.x + dir.dx * bestDistance,\n anchor.y + dir.dy * bestDistance\n )\n }\n\n /**\n * Batch check accessibility for multiple points (optimized)\n * Returns array of booleans in same order as input points\n */\n areAccessible(points: Point[]): boolean[] {\n return points.map((point) => this.isAccessible(point))\n }\n\n /**\n * Check accessibility using binary search optimization\n * Tries step -> step/2 -> step/4 -> ... -> 1px\n */\n private isAccessibleWithBinarySearch(\n point: Point,\n maxRadius: number,\n rects: Rectangle[]\n ): boolean {\n // First check the point itself\n if (rects.every((rect) => !rect.containsPoint(point))) {\n return true\n }\n\n // Binary search: start with step, then halve until we reach 1px\n let radius = maxRadius\n const offsets = [\n { dx: 1, dy: 0 }, // right\n { dx: -1, dy: 0 }, // left\n { dx: 0, dy: 1 }, // down\n { dx: 0, dy: -1 }, // up\n ]\n\n while (radius >= 1) {\n for (const offset of offsets) {\n const testPoint = new Point(\n point.x + offset.dx * radius,\n point.y + offset.dy * radius\n )\n\n if (rects.every((rect) => !rect.containsPoint(testPoint))) {\n return true\n }\n }\n\n // Halve the radius for next iteration\n radius = Math.floor(radius / 2)\n }\n\n return false\n }\n}\n", "const OPEN = 1\nconst CLOSE = 2\n\n/**\n * SortedSet class for managing open and closed sets in A* algorithm\n * Maintains items sorted by their values\n */\nexport class SortedSet {\n private items: string[]\n private hash: Map<string, number>\n private values: Map<string, number>\n\n constructor() {\n this.items = []\n this.hash = new Map()\n this.values = new Map()\n }\n\n /**\n * Add an item with its value, maintaining sorted order\n */\n add(item: string, value: number): void {\n if (this.hash.get(item)) {\n // Item removal - remove from items array\n const index = this.items.indexOf(item)\n if (index !== -1) {\n this.items.splice(index, 1)\n }\n } else {\n this.hash.set(item, OPEN)\n }\n\n this.values.set(item, value)\n\n // Find insertion index using binary search\n const index = this.sortedIndexBy(item)\n this.items.splice(index, 0, item)\n }\n\n /**\n * Pop the item with minimum value and mark it as closed\n */\n pop(): string | undefined {\n const item = this.items.shift()\n if (item) {\n this.hash.set(item, CLOSE)\n }\n return item\n }\n\n /**\n * Check if item is in open set\n */\n isOpen(item: string): boolean {\n return this.hash.get(item) === OPEN\n }\n\n /**\n * Check if item is in closed set\n */\n isClose(item: string): boolean {\n return this.hash.get(item) === CLOSE\n }\n\n /**\n * Check if open set is empty\n */\n isEmpty(): boolean {\n return this.items.length === 0\n }\n\n /**\n * Find sorted insertion index for an item\n */\n private sortedIndexBy(item: string): number {\n const value = this.values.get(item)!\n let low = 0\n let high = this.items.length\n\n while (low < high) {\n const mid = (low + high) >>> 1\n const midValue = this.values.get(this.items[mid])!\n if (midValue < value) {\n low = mid + 1\n } else {\n high = mid\n }\n }\n\n return low\n }\n}\n", "import { Point, Rectangle } from '../geometry'\nimport type { ResolvedOptions } from '../options'\nimport type { ObstacleMap } from '../obstacle'\nimport { SortedSet } from './SortedSet'\nimport type { Grid } from '../utils'\nimport {\n getGrid,\n round,\n getDirectionAngle,\n getDirectionChange,\n getGridOffsets,\n getRectPoints,\n getCost,\n getKey,\n reconstructRoute,\n ErrorRecovery,\n} from '../utils'\n\n/**\n * Generate smart points based on position using extensionDistance and binary search\n *\n * Algorithm:\n * 1. First try extensionDistance in the specified direction\n * 2. If blocked, use binary search starting from step, halving until finding accessible point\n * 3. For target points, approach from opposite direction\n */\nfunction generateSmartPoints(\n anchor: Point,\n bbox: Rectangle,\n position: string,\n grid: Grid,\n map: ObstacleMap,\n options: ResolvedOptions,\n isTarget: boolean = false\n): Point[] {\n const directionMap: Record<string, { x: number; y: number }> = {\n 'right': { x: 1, y: 0 },\n 'left': { x: -1, y: 0 },\n 'top': { x: 0, y: -1 },\n 'bottom': { x: 0, y: 1 }\n }\n\n const direction = directionMap[position]\n if (!direction) {\n console.warn(`[generateSmartPoints] Unknown position: ${position}, falling back to anchor`)\n return [anchor]\n }\n\n // Both source and target extend in the specified direction\n // - Source: extends away from node in sourcePosition direction\n // - Target: extends away from node in targetPosition direction (path approaches from this direction)\n const actualDirection = direction\n\n const points: Point[] = []\n\n // 1. First try extensionDistance\n const extensionPoint = new Point(\n anchor.x + actualDirection.x * options.extensionDistance,\n anchor.y + actualDirection.y * options.extensionDistance\n ).round(options.precision)\n\n if (map.isAccessible(extensionPoint)) {\n points.push(extensionPoint)\n return points\n }\n\n // 2. Step-based search with binary refinement\n // First, extend outward by step increments until we find an accessible point\n let stepMultiplier = 1\n let maxSteps = 20 // Prevent infinite loop\n let foundAccessibleDistance = -1\n\n while (stepMultiplier <= maxSteps) {\n const distance = stepMultiplier * options.step\n const testPoint = new Point(\n anchor.x + actualDirection.x * distance,\n anchor.y + actualDirection.y * distance\n ).round(options.precision)\n\n if (map.isAccessible(testPoint)) {\n foundAccessibleDistance = distance\n break\n }\n\n stepMultiplier++\n }\n\n // 3. If we found an accessible point, refine by binary search within the last step interval\n if (foundAccessibleDistance > 0) {\n const outerDistance = foundAccessibleDistance\n const innerDistance = foundAccessibleDistance - options.step\n\n // Binary search within the last step interval to find the closest accessible point\n let left = innerDistance\n let right = outerDistance\n let bestDistance = outerDistance\n let binarySearchIterations = 0\n const maxBinarySearchIterations = 50 // Prevent infinite loop\n\n // Binary search with precision of 1px\n while (right - left > 1 && binarySearchIterations < maxBinarySearchIterations) {\n binarySearchIterations++\n const mid = (left + right) / 2\n const testPoint = new Point(\n anchor.x + actualDirection.x * mid,\n anchor.y + actualDirection.y * mid\n ).round(options.precision)\n\n if (map.isAccessible(testPoint)) {\n bestDistance = mid\n right = mid\n } else {\n left = mid\n }\n }\n\n // Use the best distance found\n const finalPoint = new Point(\n anchor.x + actualDirection.x * bestDistance,\n anchor.y + actualDirection.y * bestDistance\n ).round(options.precision)\n\n points.push(finalPoint)\n } else {\n // 4. If no accessible point found after maxSteps, use anchor as fallback\n points.push(anchor)\n }\n\n return points\n}\n\n/**\n * Find route between two points using A* algorithm\n */\nexport function findRoute(\n sourceBBox: Rectangle,\n targetBBox: Rectangle,\n sourceAnchor: Point,\n targetAnchor: Point,\n map: ObstacleMap,\n options: ResolvedOptions\n): Point[] | null {\n const precision = options.precision\n\n // Round anchor points\n const sourceEndpoint = round(sourceAnchor.clone(), precision)\n const targetEndpoint = round(targetAnchor.clone(), precision)\n\n // Get grid for this route\n const grid = getGrid(options.step, sourceEndpoint, targetEndpoint)\n\n // DEBUG: Check for invalid grid values\n if (grid.x === 0 || grid.y === 0 || !isFinite(grid.x) || !isFinite(grid.y)) {\n console.error('[findRoute] INVALID GRID:', grid, 'step:', options.step)\n return ErrorRecovery.generateFallbackPath(sourceEndpoint, targetEndpoint)\n }\n\n // Get pathfinding points\n const startPoint = sourceEndpoint\n const endPoint = targetEndpoint\n\n // Get start and end points around rectangles\n // Use smart point generation based on position if available\n let startPoints: Point[]\n let endPoints: Point[]\n\n // Generate smart start points based on sourcePosition\n if (options.sourcePosition) {\n startPoints = generateSmartPoints(\n startPoint,\n sourceBBox,\n options.sourcePosition,\n grid,\n map,\n options,\n false\n )\n } else {\n startPoints = getRectPoints(\n startPoint,\n sourceBBox,\n options.startDirections,\n grid,\n options\n )\n // Take into account only accessible rect points\n startPoints = startPoints.filter((p) => map.isAccessible(p))\n }\n\n // Generate smart end points based on targetPosition\n if (options.targetPosition) {\n endPoints = generateSmartPoints(\n targetEndpoint,\n targetBBox,\n options.targetPosition,\n grid,\n map,\n options,\n true\n )\n } else {\n endPoints = getRectPoints(\n targetEndpoint,\n targetBBox,\n options.endDirections,\n grid,\n options\n )\n // Take into account only accessible rect points\n endPoints = endPoints.filter((p) => map.isAccessible(p))\n }\n\n\n // Ensure we always have at least the anchor points\n // This handles edge cases where anchor is on the node boundary\n if (startPoints.length === 0) {\n startPoints = [round(startPoint, precision)]\n }\n\n // CRITICAL: If no accessible end points found, use fallback immediately\n // This prevents A* from running 5000 iterations searching for unreachable points\n if (endPoints.length === 0) {\n return ErrorRecovery.generateFallbackPath(startPoint, endPoint)\n }\n\n // Initialize A* data structures\n const openSet = new SortedSet()\n const points = new Map<string, Point>()\n const parents = new Map<string, Point>()\n const costs = new Map<string, number>()\n\n // Add all start points to open set\n for (const startPoint of startPoints) {\n const key = getKey(startPoint)\n openSet.add(key, getCost(startPoint, endPoints))\n points.set(key, startPoint)\n costs.set(key, 0)\n }\n\n const previousRouteDirectionAngle = options.previousDirectionAngle\n const isPathBeginning = previousRouteDirectionAngle === undefined\n\n // Get directions with grid offsets\n const directions = getGridOffsets(grid, options)\n const numDirections = directions.length\n\n // Create set of end point keys for quick lookup\n const endPointsKeys = new Set(endPoints.map((p) => getKey(p)))\n\n // Check if start and end points are the same\n const sameStartEndPoints = startPoints.length === endPoints.length &&\n startPoints.every((sp, i) => sp.equals(endPoints[i]))\n\n // Calculate optimal path cost estimate for early termination\n const optimalCostEstimate = startPoint.manhattanDistance(endPoint)\n const earlyTerminationThreshold = options.performance?.earlyTermination ? 1.5 : Infinity\n let bestPathFound: Point[] | null = null\n let bestPathCost = Infinity\n\n // Main A* loop\n const maxIterations = options.maxLoopCount\n let iterationCount = 0\n\n // DEBUG: Log loop start\n const loopStartTime = performance.now()\n\n while (!openSet.isEmpty() && iterationCount < maxIterations) {\n iterationCount++\n\n // DEBUG: Log every 10 iterations\n if (iterationCount % 10 === 0) {\n const elapsed = performance.now() - loopStartTime\n if (elapsed > 1000) {\n console.error(`[findRoute] Loop running for ${elapsed.toFixed(0)}ms, iteration ${iterationCount}`)\n }\n }\n\n // Early termination: if we've searched too many points without finding a path,\n // the path is likely blocked or very complex - use fallback\n if (iterationCount > 2000 && bestPathFound === null) {\n return ErrorRecovery.generateFallbackPath(startPoint, endPoint)\n }\n\n // Get the closest item and mark it CLOSED\n const currentKey = openSet.pop()\n if (!currentKey) break\n\n const currentPoint = points.get(currentKey)!\n const currentParent = parents.get(currentKey)\n const currentCost = costs.get(currentKey)!\n\n const isStartPoint = currentPoint.equals(startPoint)\n const isRouteBeginning = currentParent === undefined\n\n // Calculate previous direction angle\n let previousDirectionAngle: number | null | undefined\n if (!isRouteBeginning) {\n previousDirectionAngle = getDirectionAngle(\n currentParent!,\n currentPoint,\n numDirections,\n grid,\n options\n )\n } else if (!isPathBeginning) {\n previousDirectionAngle = previousRouteDirectionAngle\n } else if (!isStartPoint) {\n previousDirectionAngle = getDirectionAngle(\n startPoint,\n currentPoint,\n numDirections,\n grid,\n options\n )\n } else {\n previousDirectionAngle = null\n }\n\n // Check if we reached any endpoint\n const skipEndCheck = isRouteBeginning && sameStartEndPoints\n if (!skipEndCheck && endPointsKeys.has(currentKey)) {\n const route = reconstructRoute(\n parents,\n points,\n currentPoint,\n startPoint,\n endPoint\n )\n\n // Early termination: if path cost is within threshold of optimal, return immediately\n if (currentCost <= optimalCostEstimate * earlyTerminationThreshold) {\n options.previousDirectionAngle = previousDirectionAngle\n return route\n }\n\n // Track best path found so far\n if (currentCost < bestPathCost) {\n bestPathCost = currentCost\n bestPathFound = route\n }\n\n options.previousDirectionAngle = previousDirectionAngle\n return route\n }\n\n // Explore neighbors in all directions\n for (const direction of directions) {\n const directionAngle = direction.angle!\n const directionChange = getDirectionChange(\n previousDirectionAngle ?? 0,\n directionAngle\n )\n\n // Don't use the point if direction changed too rapidly\n if (\n !(isPathBeginning && isStartPoint) &&\n directionChange > options.maxDirectionChange\n ) {\n continue\n }\n\n // Calculate neighbor point and align to global grid\n const rawNeighbor = currentPoint\n .clone()\n .translate(direction.gridOffsetX || 0, direction.gridOffsetY || 0)\n\n // Align to global grid for consistent path alignment\n const neighborPoint = new Point(\n Math.round(rawNeighbor.x / grid.x) * grid.x,\n Math.round(rawNeighbor.y / grid.y) * grid.y\n ).round(precision)\n\n const neighborKey = getKey(neighborPoint)\n\n // Skip if closed or not accessible\n if (openSet.isClose(neighborKey) || !map.isAccessible(neighborPoint)) {\n continue\n }\n\n // Check if we can reach any end point directly from this neighbor\n // This allows connecting to end points that are not on the grid\n let canReachEndPoint = false\n let reachableEndPoint: Point | null = null\n\n for (const endPt of endPoints) {\n const distanceToEnd = neighborPoint.manhattanDistance(endPt)\n\n // If close enough to end point (within step distance), try direct connection\n if (distanceToEnd < options.step * 1.5) {\n // Check if we can move directly to the end point\n const dx = endPt.x - neighborPoint.x\n const dy = endPt.y - neighborPoint.y\n\n // Allow direct connection if it's orthogonal or close to orthogonal\n const isOrthogonal = (Math.abs(dx) < 0.1 || Math.abs(dy) < 0.1)\n\n if (isOrthogonal) {\n const accessible = map.isAccessible(endPt)\n if (accessible) {\n canReachEndPoint = true\n reachableEndPoint = endPt\n break\n }\n }\n }\n }\n\n // If we can reach an end point directly, add it as the final step\n if (canReachEndPoint && reachableEndPoint) {\n const endKey = getKey(reachableEndPoint)\n const endCost = neighborPoint.manhattanDistance(reachableEndPoint)\n const totalCost = currentCost + direction.cost + endCost\n\n if (!openSet.isOpen(endKey) || totalCost < (costs.get(endKey) || Infinity)) {\n points.set(endKey, reachableEndPoint)\n\n // CRITICAL FIX: Don't set parent if neighbor and endpoint are the same\n // This prevents circular reference in reconstructRoute\n if (!neighborPoint.equals(reachableEndPoint)) {\n parents.set(endKey, neighborPoint)\n } else {\n // If neighbor IS the endpoint, use currentPoint as parent\n parents.set(endKey, currentPoint)\n }\n\n costs.set(endKey, totalCost)\n\n // Also add the neighbor point if not already added\n if (!points.has(neighborKey)) {\n points.set(neighborKey, neighborPoint)\n parents.set(neighborKey, currentPoint)\n costs.set(neighborKey, currentCost + direction.cost)\n }\n\n // Check if this is our target end point\n if (endPointsKeys.has(endKey)) {\n const route = reconstructRoute(\n parents,\n points,\n reachableEndPoint,\n startPoint,\n endPoint\n )\n\n // Early termination check\n if (totalCost <= optimalCostEstimate * earlyTerminationThreshold) {\n options.previousDirectionAngle = directionAngle\n return route\n }\n\n // Track best path\n if (totalCost < bestPathCost) {\n bestPathCost = totalCost\n bestPathFound = route\n }\n\n options.previousDirectionAngle = directionAngle\n return route\n }\n }\n }\n\n // Check if neighbor is an end point (exact match)\n if (endPointsKeys.has(neighborKey)) {\n const isEndPoint = neighborPoint.equals(endPoint)\n if (!isEndPoint) {\n const endDirectionAngle = getDirectionAngle(\n neighborPoint,\n endPoint,\n numDirections,\n grid,\n options\n )\n\n const endDirectionChange = getDirectionChange(\n directionAngle,\n endDirectionAngle\n )\n\n if (endDirectionChange > options.maxDirectionChange) {\n continue\n }\n }\n }\n\n // Calculate costs\n const neighborCost = direction.cost\n const neighborPenalty = isStartPoint ? 0 : (options.penalties[directionChange] || 0)\n const costFromStart = currentCost + neighborCost + neighborPenalty\n\n // Update if not in open set or found better path\n if (\n !openSet.isOpen(neighborKey) ||\n costFromStart < (costs.get(neighborKey) || Infinity)\n ) {\n points.set(neighborKey, neighborPoint)\n parents.set(neighborKey, currentPoint)\n costs.set(neighborKey, costFromStart)\n openSet.add(\n neighborKey,\n costFromStart + getCost(neighborPoint, endPoints)\n )\n }\n }\n\n // Loop completed - check iteration count\n }\n\n // Return best path found if any\n if (bestPathFound) {\n return bestPathFound\n }\n\n // No path found, try fallback\n if (options.fallbackRoute) {\n return options.fallbackRoute(startPoint, endPoint)\n }\n\n // Use ErrorRecovery to generate fallback path\n return ErrorRecovery.generateFallbackPath(startPoint, endPoint)\n}\n", "import { Point } from '../geometry'\n\n/**\n * Check if three points form a corner (direction change)\n */\nfunction isCorner(prev: Point, current: Point, next: Point): boolean {\n const dx1 = current.x - prev.x\n const dy1 = current.y - prev.y\n const dx2 = next.x - current.x\n const dy2 = next.y - current.y\n\n // Check if direction changes (not collinear)\n // For Manhattan paths, this means one segment is horizontal and the other is vertical\n const isHorizontal1 = Math.abs(dy1) < 0.001\n const isVertical1 = Math.abs(dx1) < 0.001\n const isHorizontal2 = Math.abs(dy2) < 0.001\n const isVertical2 = Math.abs(dx2) < 0.001\n\n // Corner exists if one segment is horizontal and the other is vertical\n return (isHorizontal1 && isVertical2) || (isVertical1 && isHorizontal2)\n}\n\n/**\n * Calculate optimal border radius for a corner\n * Ensures the radius doesn't exceed half the length of adjacent segments\n */\nfunction calculateOptimalRadius(\n prev: Point,\n current: Point,\n next: Point,\n maxRadius: number\n): number {\n const dx1 = current.x - prev.x\n const dy1 = current.y - prev.y\n const dx2 = next.x - current.x\n const dy2 = next.y - current.y\n\n const dist1 = Math.sqrt(dx1 * dx1 + dy1 * dy1)\n const dist2 = Math.sqrt(dx2 * dx2 + dy2 * dy2)\n\n // Use the smaller of maxRadius or half the segment length\n return Math.min(maxRadius, dist1 / 2, dist2 / 2)\n}\n\n/**\n * Convert array of points to SVG path string\n */\nexport function pointsToPath(points: Point[], precision: number, borderRadius: number = 0): string {\n if (points.length === 0) {\n return ''\n }\n\n const factor = Math.pow(10, precision)\n const roundCoord = (value: number) => Math.round(value * factor) / factor\n\n // If no border radius or only 2 points, use simple line path\n if (borderRadius === 0 || points.length <= 2) {\n const firstPoint = points[0]\n let path = `M ${roundCoord(firstPoint.x)} ${roundCoord(firstPoint.y)}`\n\n for (let i = 1; i < points.length; i++) {\n const point = points[i]\n path += ` L ${roundCoord(point.x)} ${roundCoord(point.y)}`\n }\n\n return path\n }\n\n // Start with M (moveTo) command for first point\n const firstPoint = points[0]\n let path = `M ${roundCoord(firstPoint.x)} ${roundCoord(firstPoint.y)}`\n\n // Process each segment with rounded corners\n for (let i = 1; i < points.length - 1; i++) {\n const prev = points[i - 1]\n const current = points[i]\n const next = points[i + 1]\n\n // Check if this is actually a corner\n if (!isCorner(prev, current, next)) {\n // Not a corner, just draw a line to current point\n path += ` L ${roundCoord(current.x)} ${roundCoord(current.y)}`\n continue\n }\n\n // Calculate direction vectors\n const dx1 = current.x - prev.x\n const dy1 = current.y - prev.y\n const dx2 = next.x - current.x\n const dy2 = next.y - current.y\n\n // Calculate distances\n const dist1 = Math.sqrt(dx1 * dx1 + dy1 * dy1)\n const dist2 = Math.sqrt(dx2 * dx2 + dy2 * dy2)\n\n // Use the smaller of borderRadius or half the segment length\n const radius = calculateOptimalRadius(prev, current, next, borderRadius)\n\n // Skip if radius is too small\n if (radius < 0.5) {\n path += ` L ${roundCoord(current.x)} ${roundCoord(current.y)}`\n continue\n }\n\n // Normalize direction vectors\n const ndx1 = dx1 / dist1\n const ndy1 = dy1 / dist1\n const ndx2 = dx2 / dist2\n const ndy2 = dy2 / dist2\n\n // Calculate the point before the corner\n const beforeCorner = {\n x: current.x - ndx1 * radius,\n y: current.y - ndy1 * radius,\n }\n\n // Calculate the point after the corner\n const afterCorner = {\n x: current.x + ndx2 * radius,\n y: current.y + ndy2 * radius,\n }\n\n // Draw line to the point before corner\n path += ` L ${roundCoord(beforeCorner.x)} ${roundCoord(beforeCorner.y)}`\n\n // Draw quadratic bezier curve for the rounded corner\n // The control point is the actual corner point\n path += ` Q ${roundCoord(current.x)} ${roundCoord(current.y)} ${roundCoord(afterCorner.x)} ${roundCoord(afterCorner.y)}`\n }\n\n // Draw line to the last point\n const lastPoint = points[points.length - 1]\n path += ` L ${roundCoord(lastPoint.x)} ${roundCoord(lastPoint.y)}`\n\n return path\n}\n\n/**\n * Convert array of points to SVG path string with cubic bezier curves\n * Provides smoother corners than quadratic bezier\n */\nexport function pointsToPathCubic(points: Point[], precision: number, borderRadius: number = 0): string {\n if (points.length === 0) {\n return ''\n }\n\n const factor = Math.pow(10, precision)\n const roundCoord = (value: number) => Math.round(value * factor) / factor\n\n // If no border radius or only 2 points, use simple line path\n if (borderRadius === 0 || points.length <= 2) {\n const firstPoint = points[0]\n let path = `M ${roundCoord(firstPoint.x)} ${roundCoord(firstPoint.y)}`\n\n for (let i = 1; i < points.length; i++) {\n const point = points[i]\n path += ` L ${roundCoord(point.x)} ${roundCoord(point.y)}`\n }\n\n return path\n }\n\n // Start with M (moveTo) command for first point\n const firstPoint = points[0]\n let path = `M ${roundCoord(firstPoint.x)} ${roundCoord(firstPoint.y)}`\n\n // Process each segment with rounded corners using cubic bezier\n for (let i = 1; i < points.length - 1; i++) {\n const prev = points[i - 1]\n const current = points[i]\n const next = points[i + 1]\n\n // Check if this is actually a corner\n if (!isCorner(prev, current, next)) {\n path += ` L ${roundCoord(current.x)} ${roundCoord(current.y)}`\n continue\n }\n\n // Calculate direction vectors\n const dx1 = current.x - prev.x\n const dy1 = current.y - prev.y\n const dx2 = next.x - current.x\n const dy2 = next.y - current.y\n\n // Calculate distances\n const dist1 = Math.sqrt(dx1 * dx1 + dy1 * dy1)\n const dist2 = Math.sqrt(dx2 * dx2 + dy2 * dy2)\n\n // Use the smaller of borderRadius or half the segment length\n const radius = calculateOptimalRadius(prev, current, next, borderRadius)\n\n // Skip if radius is too small\n if (radius < 0.5) {\n path += ` L ${roundCoord(current.x)} ${roundCoord(current.y)}`\n continue\n }\n\n // Normalize direction vectors\n const ndx1 = dx1 / dist1\n const ndy1 = dy1 / dist1\n const ndx2 = dx2 / dist2\n const ndy2 = dy2 / dist2\n\n // Calculate the point before the corner\n const beforeCorner = {\n x: current.x - ndx1 * radius,\n y: current.y - ndy1 * radius,\n }\n\n // Calculate the point after the corner\n const afterCorner = {\n x: current.x + ndx2 * radius,\n y: current.y + ndy2 * radius,\n }\n\n // Draw line to the point before corner\n path += ` L ${roundCoord(beforeCorner.x)} ${roundCoord(beforeCorner.y)}`\n\n // Draw cubic bezier curve for smoother rounded corner\n // Control points are positioned to create a smooth arc\n const cp1 = {\n x: beforeCorner.x + ndx1 * radius * 0.55,\n y: beforeCorner.y + ndy1 * radius * 0.55,\n }\n const cp2 = {\n x: afterCorner.x - ndx2 * radius * 0.55,\n y: afterCorner.y - ndy2 * radius * 0.55,\n }\n\n path += ` C ${roundCoord(cp1.x)} ${roundCoord(cp1.y)} ${roundCoord(cp2.x)} ${roundCoord(cp2.y)} ${roundCoord(afterCorner.x)} ${roundCoord(afterCorner.y)}`\n }\n\n // Draw line to the last point\n const lastPoint = points[points.length - 1]\n path += ` L ${roundCoord(lastPoint.x)} ${roundCoord(lastPoint.y)}`\n\n return path\n}\n\n/**\n * Snap path to grid by aligning consecutive points\n */\nexport function snapPathToGrid(points: Point[], gridSize: number): Point[] {\n if (points.length <= 1) {\n return points\n }\n\n const snappedPoints = [...points]\n\n // Don't snap the first and last points (anchors)\n // Don't snap the second and second-to-last points (extension points)\n // Only snap intermediate segments\n for (let i = 2; i < snappedPoints.length - 3; i++) {\n const first = snappedPoints[i]\n const second = snappedPoints[i + 1]\n\n if (first.x === second.x) {\n // Vertical line - snap X coordinate\n const x = gridSize * Math.round(first.x / gridSize)\n if (first.x !== x) {\n first.x = x\n second.x = x\n }\n } else if (first.y === second.y) {\n // Horizontal line - snap Y coordinate\n const y = gridSize * Math.round(first.y / gridSize)\n if (first.y !== y) {\n first.y = y\n second.y = y\n }\n }\n }\n\n return snappedPoints\n}\n\n/**\n * Check if an SVG path contains rounded corners (Q or C commands)\n */\nexport function hasRoundedCorners(path: string): boolean {\n return /[QC]\\s/.test(path)\n}\n\n/**\n * Count the number of corners in a path\n */\nexport function countCorners(points: Point[]): number {\n let corners = 0\n\n for (let i = 1; i < points.length - 1; i++) {\n if (isCorner(points[i - 1], points[i], points[i + 1])) {\n corners++\n }\n }\n\n return corners\n}\n", "import { Point } from '../geometry'\n\n/**\n * Parse SVG path string to extract points\n * Simplified parser that handles M, L, Q commands\n */\nexport function parseSVGPath(pathString: string): Point[] {\n const points: Point[] = []\n const commands = pathString.match(/[MLQ][^MLQ]*/g)\n\n if (!commands) return points\n\n for (const command of commands) {\n const type = command[0]\n const coords = command\n .slice(1)\n .trim()\n .split(/[\\s,]+/)\n .map(Number)\n\n if (type === 'M' || type === 'L') {\n // MoveTo or LineTo: x, y\n if (coords.length >= 2) {\n points.push(new Point(coords[0], coords[1]))\n }\n } else if (type === 'Q') {\n // Quadratic Bezier: cx, cy, x, y\n // We sample points along the curve for collision detection\n if (coords.length >= 4) {\n const prevPoint = points[points.length - 1]\n if (prevPoint) {\n const cx = coords[0]\n const cy = coords[1]\n const x = coords[2]\n const y = coords[3]\n\n // Sample 10 points along the bezier curve for better accuracy\n // This ensures we don't miss intersections with obstacles\n for (let t = 0.1; t <= 1; t += 0.1) {\n const bx = (1 - t) * (1 - t) * prevPoint.x + 2 * (1 - t) * t * cx + t * t * x\n const by = (1 - t) * (1 - t) * prevPoint.y + 2 * (1 - t) * t * cy + t * t * y\n points.push(new Point(bx, by))\n }\n }\n }\n }\n }\n\n return points\n}\n\n/**\n * Simplify path by removing collinear intermediate points\n */\nexport function simplifyPath(points: Point[]): Point[] {\n if (points.length <= 2) {\n return points\n }\n\n const simplified: Point[] = [points[0]]\n\n for (let i = 1; i < points.length - 1; i++) {\n const prev = simplified[simplified.length - 1]\n const current = points[i]\n const next = points[i + 1]\n\n // Check if current point is collinear with prev and next\n const isHorizontalLine = prev.y === current.y && current.y === next.y\n const isVerticalLine = prev.x === current.x && current.x === next.x\n\n // Only keep the point if it's not collinear (i.e., it's a corner)\n if (!isHorizontalLine && !isVerticalLine) {\n simplified.push(current)\n }\n }\n\n // Always add the last point\n simplified.push(points[points.length - 1])\n\n return simplified\n}\n", "import { getSmoothStepPath, Position } from '@xyflow/react'\nimport { Point, Rectangle } from './geometry'\nimport { ObstacleMap } from './obstacle'\nimport type { ManhattanRouterOptions, NodeLookup } from './options'\nimport { resolveOptions } from './options'\nimport { findRoute } from './pathfinder'\nimport { pointsToPath, parseSVGPath } from './svg'\nimport { getNodeDimensions, getNodePosition, pathIntersectsObstacles, ErrorRecovery } from './utils'\n\n/**\n * Parameters for getManHattanPath function\n */\nexport interface GetManHattanPathParams {\n /**\n * Source node ID\n */\n sourceNodeId: string\n\n /**\n * Target node ID\n */\n targetNodeId: string;\n\n sourceX: number;\n sourceY: number;\n targetX: number;\n targetY: number;\n\n sourcePosition: Position;\n targetPosition: Position;\n /**\n * ReactFlow node lookup map\n */\n nodeLookup: NodeLookup\n\n /**\n * Router options\n */\n options?: ManhattanRouterOptions\n}\n\n/**\n * Generate Manhattan-routed path for ReactFlow edges\n *\n * @param params - Path generation parameters\n * @returns SVG path string that can be used with ReactFlow's BaseEdge\n *\n * @example\n * ```typescript\n * const path = getManHattanPath({\n * sourceNodeId: 'node1',\n * targetNodeId: 'node2',\n * sourcePosition: { x: 100, y: 100 },\n * targetPosition: { x: 300, y: 300 },\n * nodeLookup: nodes,\n * options: {\n * step: 10,\n * startDirections: ['bottom'],\n * endDirections: ['top']\n * }\n * })\n * ```\n */\nexport function getManHattanPath(params: GetManHattanPathParams): string {\n const {\n sourceNodeId,\n targetNodeId,\n sourcePosition,\n targetPosition,\n nodeLookup,\n sourceX,\n sourceY,\n targetX,\n targetY,\n options: userOptions = {},\n } = params\n\n // Resolve options and add position information\n const options = resolveOptions({\n ...userOptions,\n sourcePosition,\n targetPosition\n })\n\n // Direction control is automatically handled by getRectPoints:\n // - When anchor is on an edge, only outward directions are allowed (via isDirectionOutward)\n // - For sourcePosition=\"right\": anchor on right edge -> only extends right\n // - For targetPosition=\"left\": anchor on left edge -> path approaches from right (outward from left)\n // This ensures paths follow the sourcePosition and targetPosition constraints\n\n // Get source and target nodes\n const sourceNode = nodeLookup.get(sourceNodeId)\n const targetNode = nodeLookup.get(targetNodeId)\n\n if (!sourceNode || !targetNode) {\n // Fallback to simple straight line if nodes not found\n console.warn('[getManHattanPath] Source or target node not found in nodeLookup')\n const start = new Point(sourceX, sourceY)\n const end = new Point(targetX, targetY)\n // Use ErrorRecovery to generate a proper fallback path\n const fallbackPath = ErrorRecovery.generateFallbackPath(start, end)\n return pointsToPath(fallbackPath, options.precision, options.borderRadius)\n }\n\n // Get node dimensions using ReactFlow's priority logic\n const sourceDimensions = getNodeDimensions(sourceNode)\n const targetDimensions = getNodeDimensions(targetNode)\n\n // Get absolute positions from internals\n const sourcePos = getNodePosition(sourceNode)\n const targetPos = getNodePosition(targetNode)\n\n // Calculate bounding boxes\n const sourceBBox = new Rectangle(\n sourcePos.x,\n sourcePos.y,\n sourceDimensions.width,\n sourceDimensions.height\n )\n\n const targetBBox = new Rectangle(\n targetPos.x,\n targetPos.y,\n targetDimensions.width,\n targetDimensions.height\n )\n\n // Create anchor points\n const sourceAnchor = new Point(sourceX, sourceY)\n const targetAnchor = new Point(targetX, targetY)\n\n // Try ReactFlow's getSmoothStepPath first\n const [smoothStepPath] = getSmoothStepPath({\n sourceX,\n sourceY,\n targetX,\n targetY,\n sourcePosition,\n targetPosition,\n borderRadius: options.borderRadius,\n })\n\n // Parse the smooth step path to extract points\n const smoothStepPoints = parseSVGPath(smoothStepPath)\n\n // Check if smooth step path intersects with any obstacles\n if (smoothStepPoints.length > 0 && !pathIntersectsObstacles(smoothStepPoints, nodeLookup)) {\n return smoothStepPath\n }\n\n\n // Build obstacle map with anchor information\n const obstacleMap = new ObstacleMap(options).build(\n nodeLookup,\n sourceNodeId,\n targetNodeId,\n sourceAnchor,\n targetAnchor\n )\n\n // Find route\n let route = findRoute(\n sourceBBox,\n targetBBox,\n sourceAnchor,\n targetAnchor,\n obstacleMap,\n options\n )\n\n // Fallback to Z-shaped path if no route found\n if (!route) {\n console.warn('[getManHattanPath] Unable to find Manhattan route, using fallback path')\n route = ErrorRecovery.generateFallbackPath(sourceAnchor, targetAnchor)\n }\n\n\n // If using smart point generation (sourcePosition/targetPosition specified),\n // the route already contains the correct extension points, so skip manual processing\n const useSmartPoints = sourcePosition || targetPosition\n\n if (useSmartPoints) {\n\n // Post-process route to fix X coordinates for horizontal anchors\n // This ensures the extension distance is fixed and not affected by grid alignment\n const isSourceHorizontal = sourcePosition === Position.Left || sourcePosition === Position.Right\n const isTargetHorizontal = targetPosition === Position.Left || targetPosition === Position.Right\n\n if (isSourceHorizontal && isTargetHorizontal && route.length > 0) {\n // Calculate expected extension X coordinates\n const sourceExtensionX = sourcePosition === Position.Right\n ? sourceAnchor.x + options.extensionDistance\n : sourceAnchor.x - options.extensionDistance\n const targetExtensionX = targetPosition === Position.Left\n ? targetAnchor.x - options.extensionDistance\n : targetAnchor.x + options.extensionDistance\n\n\n // Find the horizontal segment (where Y stays constant but X changes significantly)\n // This divides the path into source-side and target-side\n let horizontalSegmentStart = -1\n let horizontalSegmentEnd = -1\n for (let i = 0; i < route.length - 1; i++) {\n const curr = route[i]\n const next = route[i + 1]\n const isHorizontalMove = Math.abs(curr.y - next.y) < 1 && Math.abs(curr.x - next.x) > options.step\n if (isHorizontalMove) {\n horizontalSegmentStart = i\n horizontalSegmentEnd = i + 1\n break\n }\n }\n\n\n // Fix route points\n for (let i = 0; i < route.length; i++) {\n const point = route[i]\n\n if (horizontalSegmentStart >= 0) {\n if (i <= horizontalSegmentStart) {\n // Source side - all vertical segment points should use sourceExtensionX\n route[i] = new Point(sourceExtensionX, point.y)\n } else if (i >= horizontalSegmentEnd) {\n // Target side - all vertical segment points should use targetExtensionX\n route[i] = new Point(targetExtensionX, point.y)\n }\n }\n }\n\n // Remove redundant points (consecutive points on same line)\n const optimized: Point[] = []\n for (let i = 0; i < route.length; i++) {\n const point = route[i]\n if (optimized.length < 2) {\n optimized.push(point)\n } else {\n const prev = optimized[optimized.length - 1]\n const prevPrev = optimized[optimized.length - 2]\n\n // Check if prev is on the same line as prevPrev and point\n const sameX = Math.abs(prevPrev.x - prev.x) < 1 && Math.abs(prev.x - point.x) < 1\n const sameY = Math.abs(prevPrev.y - prev.y) < 1 && Math.abs(prev.y - point.y) < 1\n\n if (sameX || sameY) {\n // prev is redundant, replace it with current point\n optimized[optimized.length - 1] = point\n } else {\n optimized.push(point)\n }\n }\n }\n route = optimized\n }\n\n // Add source and target anchors to route\n const finalRoute = [sourceAnchor, ...route, targetAnchor]\n return pointsToPath(finalRoute, options.precision, options.borderRadius)\n }\n\n // Remove extension points from route that were added by getRectPoints\n // We will add our own with fixed step distance\n const step = options.step\n const tolerance = 1\n\n // Check if first point is an extension point from source\n if (route.length > 0) {\n const firstPoint = route[0]\n const onLeft = Math.abs(sourceAnchor.x - sourceBBox.x) < tolerance\n const onRight = Math.abs(sourceAnchor.x - (sourceBBox.x + sourceBBox.width)) < tolerance\n const onTop = Math.abs(sourceAnchor.y - sourceBBox.y) < tolerance\n const onBottom = Math.abs(sourceAnchor.y - (sourceBBox.y + sourceBBox.height)) < tolerance\n\n // Check if firstPoint is close to source anchor (indicating it's an extension point)\n const distToFirst = sourceAnchor.manhattanDistance(firstPoint)\n if (distToFirst < step * 2) {\n // This is likely an extension point, remove it\n if ((onRight && firstPoint.x > sourceAnchor.x) ||\n (onLeft && firstPoint.x < sourceAnchor.x) ||\n (onBottom && firstPoint.y > sourceAnchor.y) ||\n (onTop && firstPoint.y < sourceAnchor.y)) {\n route.shift()\n }\n }\n }\n\n // Check if last point is an extension point from target\n if (route.length > 0) {\n const lastPoint = route[route.length - 1]\n const onLeft = Math.abs(targetAnchor.x - targetBBox.x) < tolerance\n const onRight = Math.abs(targetAnchor.x - (targetBBox.x + targetBBox.width)) < tolerance\n const onTop = Math.abs(targetAnchor.y - targetBBox.y) < tolerance\n const onBottom = Math.abs(targetAnchor.y - (targetBBox.y + targetBBox.height)) < tolerance\n\n // Check if lastPoint is close to target anchor (indicating it's an extension point)\n const distToLast = targetAnchor.manhattanDistance(lastPoint)\n if (distToLast < step * 2) {\n // This is likely an extension point, remove it\n if ((onLeft && lastPoint.x < targetAnchor.x) ||\n (onRight && lastPoint.x > targetAnchor.x) ||\n (onTop && lastPoint.y < targetAnchor.y) ||\n (onBottom && lastPoint.y > targetAnchor.y)) {\n route.pop()\n }\n }\n }\n\n // Insert extension point at source - always extend away from node edge by fixed distance\n if (route.length > 0) {\n const extensionDistance = options.extensionDistance\n const firstPoint = route[0]\n\n // Determine which edge the source anchor is on\n const onLeft = Math.abs(sourceAnchor.x - sourceBBox.x) < tolerance\n const onRight = Math.abs(sourceAnchor.x - (sourceBBox.x + sourceBBox.width)) < tolerance\n const onTop = Math.abs(sourceAnchor.y - sourceBBox.y) < tolerance\n const onBottom = Math.abs(sourceAnchor.y - (sourceBBox.y + sourceBBox.height)) < tolerance\n\n // Insert extension point and corner point to ensure orthogonal path\n if (onRight) {\n // Anchor on right edge - extend right by step + borderRadius\n const extendX = sourceAnchor.x + extensionDistance\n const extensionPoint = new Point(extendX, sourceAnchor.y)\n // Check if we need a corner point\n if (Math.abs(extensionPoint.y - firstPoint.y) > tolerance) {\n route.unshift(new Point(extendX, firstPoint.y)) // Corner point\n }\n route.unshift(extensionPoint) // Extension point (fixed distance)\n } else if (onLeft) {\n // Anchor on left edge - extend left by step + borderRadius\n const extendX = sourceAnchor.x - extensionDistance\n const extensionPoint = new Point(extendX, sourceAnchor.y)\n if (Math.abs(extensionPoint.y - firstPoint.y) > tolerance) {\n route.unshift(new Point(extendX, firstPoint.y))\n }\n route.unshift(extensionPoint)\n } else if (onBottom) {\n // Anchor on bottom edge - extend down by step + borderRadius\n const extendY = sourceAnchor.y + extensionDistance\n const extensionPoint = new Point(sourceAnchor.x, extendY)\n if (Math.abs(extensionPoint.x - firstPoint.x) > tolerance) {\n route.unshift(new Point(firstPoint.x, extendY))\n }\n route.unshift(extensionPoint)\n } else if (onTop) {\n // Anchor on top edge - extend up by step + borderRadius\n const extendY = sourceAnchor.y - extensionDistance\n const extensionPoint = new Point(sourceAnchor.x, extendY)\n if (Math.abs(extensionPoint.x - firstPoint.x) > tolerance) {\n route.unshift(new Point(firstPoint.x, extendY))\n }\n route.unshift(extensionPoint)\n }\n }\n\n // Remove redundant points after source extension\n // If the first route point has the same x or y coordinate as the source anchor, it's redundant\n if (route.length > 3) {\n const thirdRoutePoint = route[2] // Original A* point\n // Check if the third point (original A* point) is redundant\n // It's redundant if it's on the same line as the corner point and can be skipped\n const sameX = Math.abs(thirdRoutePoint.x - sourceAnchor.x) < tolerance\n const sameY = Math.abs(thirdRoutePoint.y - sourceAnchor.y) < tolerance\n\n if (sameX || sameY) {\n const secondRoutePoint = route[1] // Corner point (if exists)\n const fourthPoint = route[3]\n // If corner point and fourth point form a straight line, remove the third point\n const cornerToThird = Math.abs(secondRoutePoint.x - thirdRoutePoint.x) < tolerance ||\n Math.abs(secondRoutePoint.y - thirdRoutePoint.y) < tolerance\n const thirdToFourth = Math.abs(thirdRoutePoint.x - fourthPoint.x) < tolerance ||\n Math.abs(thirdRoutePoint.y - fourthPoint.y) < tolerance\n\n if (cornerToThird && thirdToFourth) {\n route.splice(2, 1) // Remove the third point\n }\n }\n }\n\n // Optimize zigzag patterns BEFORE inserting target extension\n // Check for patterns like: (1360, 16) -> (815, 16) -> (815, -134)\n // where the middle segment goes to target edge and then moves along it\n // Use target bbox with padding (same as ObstacleMap)\n const targetBBoxWithPadding = targetBBox.moveAndExpand(options.paddingBox)\n\n\n if (route.length >= 3) {\n let i = 0\n while (i < route.length - 2) {\n const p1 = route[i]\n const p2 = route[i + 1]\n const p3 = route[i + 2]\n\n // Check if p2 is on the target bbox edge (with padding)\n const p2OnTargetLeftEdge = Math.abs(p2.x - targetBBoxWithPadding.x) < tolerance\n const p2OnTargetRightEdge = Math.abs(p2.x - (targetBBoxWithPadding.x + targetBBoxWithPadding.width)) < tolerance\n const p2OnTargetTopEdge = Math.abs(p2.y - targetBBoxWithPadding.y) < tolerance\n const p2OnTargetBottomEdge = Math.abs(p2.y - (targetBBoxWithPadding.y + targetBBoxWithPadding.height)) < tolerance\n const p2OnTargetEdge = p2OnTargetLeftEdge || p2OnTargetRightEdge || p2OnTargetTopEdge || p2OnTargetBottomEdge\n\n\n if (p2OnTargetEdge) {\n // Check if p1 -> p2 -> p3 forms a zigzag\n const p1ToP2Horizontal = Math.abs(p1.y - p2.y) < tolerance\n const p2ToP3Vertical = Math.abs(p2.x - p3.x) < tolerance\n const p1ToP2Vertical = Math.abs(p1.x - p2.x) < tolerance\n const p2ToP3Horizontal = Math.abs(p2.y - p3.y) < tolerance\n\n\n if ((p1ToP2Horizontal && p2ToP3Vertical) || (p1ToP2Vertical && p2ToP3Horizontal)) {\n // We have a zigzag at target edge, remove p2 and p3\n route.splice(i + 1, 2) // Remove p2 and p3\n continue\n }\n }\n\n i++\n }\n }\n\n // Insert extension point at target - always extend away from node edge by fixed distance\n if (route.length > 0) {\n const extensionDistance = options.extensionDistance\n const lastPoint = route[route.length - 1]\n\n // Determine which edge the target anchor is on\n const onLeft = Math.abs(targetAnchor.x - targetBBox.x) < tolerance\n const onRight = Math.abs(targetAnchor.x - (targetBBox.x + targetBBox.width)) < tolerance\n const onTop = Math.abs(targetAnchor.y - targetBBox.y) < tolerance\n const onBottom = Math.abs(targetAnchor.y - (targetBBox.y + targetBBox.height)) < tolerance\n\n // Insert extension point and corner point to ensure orthogonal path\n if (onLeft) {\n // Anchor on left edge - extend left by step + borderRadius\n const extendX = targetAnchor.x - extensionDistance\n const extensionPoint = new Point(extendX, targetAnchor.y)\n if (Math.abs(extensionPoint.y - lastPoint.y) > tolerance) {\n route.push(new Point(extendX, lastPoint.y)) // Corner point\n }\n route.push(extensionPoint) // Extension point (fixed distance)\n } else if (onRight) {\n // Anchor on right edge - extend right by step + borderRadius\n const extendX = targetAnchor.x + extensionDistance\n const extensionPoint = new Point(extendX, targetAnchor.y)\n if (Math.abs(extensionPoint.y - lastPoint.y) > tolerance) {\n route.push(new Point(extendX, lastPoint.y))\n }\n route.push(extensionPoint)\n } else if (onTop) {\n // Anchor on top edge - extend up by step + borderRadius\n const extendY = targetAnchor.y - extensionDistance\n const extensionPoint = new Point(targetAnchor.x, extendY)\n if (Math.abs(extensionPoint.x - lastPoint.x) > tolerance) {\n route.push(new Point(lastPoint.x, extendY))\n }\n route.push(extensionPoint)\n } else if (onBottom) {\n // Anchor on bottom edge - extend down by step + borderRadius\n const extendY = targetAnchor.y + extensionDistance\n const extensionPoint = new Point(targetAnchor.x, extendY)\n if (Math.abs(extensionPoint.x - lastPoint.x) > tolerance) {\n route.push(new Point(lastPoint.x, extendY))\n }\n route.push(extensionPoint)\n }\n }\n\n // Remove redundant points before target extension\n // Similar logic for target side\n if (route.length > 2) {\n const lastIdx = route.length - 1\n const secondLastPoint = route[lastIdx - 1] // Corner point (if exists)\n const thirdLastPoint = route[lastIdx - 2] // Original A* point\n\n // Check if the third-to-last point is redundant\n const sameX = Math.abs(thirdLastPoint.x - targetAnchor.x) < tolerance\n const sameY = Math.abs(thirdLastPoint.y - targetAnchor.y) < tolerance\n\n if (sameX || sameY) {\n if (route.length > 3) {\n const fourthLastPoint = route[lastIdx - 3]\n const fourthToThird = Math.abs(fourthLastPoint.x - thirdLastPoint.x) < tolerance ||\n Math.abs(fourthLastPoint.y - thirdLastPoint.y) < tolerance\n const thirdToSecond = Math.abs(thirdLastPoint.x - secondLastPoint.x) < tolerance ||\n Math.abs(thirdLastPoint.y - secondLastPoint.y) < tolerance\n\n if (fourthToThird && thirdToSecond) {\n route.splice(lastIdx - 2, 1) // Remove the third-to-last point\n }\n }\n }\n }\n\n // Additional optimization: Remove unnecessary zigzag patterns near target\n // Check for patterns like: (1360, 16) -> (815, 16) -> (815, -134) -> (800, -134)\n // where (815, 16) and (815, -134) form a zigzag at the target edge\n let i = 0\n while (i < route.length - 2) {\n const p1 = route[i]\n const p2 = route[i + 1]\n const p3 = route[i + 2]\n\n // Check if p2 is on the target bbox edge\n const p2OnTargetLeftEdge = Math.abs(p2.x - targetBBox.x) < tolerance\n const p2OnTargetRightEdge = Math.abs(p2.x - (targetBBox.x + targetBBox.width)) < tolerance\n const p2OnTargetTopEdge = Math.abs(p2.y - targetBBox.y) < tolerance\n const p2OnTargetBottomEdge = Math.abs(p2.y - (targetBBox.y + targetBBox.height)) < tolerance\n const p2OnTargetEdge = p2OnTargetLeftEdge || p2OnTargetRightEdge || p2OnTargetTopEdge || p2OnTargetBottomEdge\n\n if (p2OnTargetEdge) {\n // Check if p1 -> p2 -> p3 forms a zigzag\n const p1ToP2Horizontal = Math.abs(p1.y - p2.y) < tolerance\n const p2ToP3Vertical = Math.abs(p2.x - p3.x) < tolerance\n\n if (p1ToP2Horizontal && p2ToP3Vertical && i < route.length - 3) {\n // We have horizontal -> vertical at target edge\n // Check if we can skip p2 and p3\n const p4 = route[i + 3]\n const p3ToP4Horizontal = Math.abs(p3.y - p4.y) < tolerance\n\n if (p3ToP4Horizontal) {\n // Pattern: horizontal -> vertical -> horizontal (zigzag)\n route.splice(i + 1, 2) // Remove p2 and p3\n continue\n }\n }\n }\n\n i++\n }\n\n // Add source and target anchors to route\n const finalRoute = [sourceAnchor, ...route, targetAnchor]\n\n\n // Convert to SVG path string\n return pointsToPath(finalRoute, options.precision, options.borderRadius)\n}\n\n\n", "/**\n * Manhattan \u8DEF\u5F84\u8BA1\u7B97 Worker\n * \u4F7F\u7528 Comlink \u66B4\u9732\u8BA1\u7B97\u63A5\u53E3\n */\nimport { expose } from 'comlink';\nimport { getManHattanPath, type GetManHattanPathParams } from '@rxflow/manhattan';\n\n/**\n * Worker \u4E2D\u7684 Manhattan \u8DEF\u5F84\u8BA1\u7B97\u670D\u52A1\n */\nconst manhattanWorker = {\n /**\n * \u8BA1\u7B97\u5355\u6761\u8FB9\u7684\u8DEF\u5F84\n */\n async calculatePath(params: GetManHattanPathParams): Promise<string> {\n return getManHattanPath(params);\n },\n\n /**\n * \u6279\u91CF\u8BA1\u7B97\u591A\u6761\u8FB9\u7684\u8DEF\u5F84\n */\n async calculatePaths(\n paramsArray: GetManHattanPathParams[]\n ): Promise<Array<{ id: string; path: string; error?: string }>> {\n return paramsArray.map((params) => {\n try {\n const path = getManHattanPath(params);\n return {\n id: `${params.sourceNodeId}-${params.targetNodeId}`,\n path,\n };\n } catch (error) {\n return {\n id: `${params.sourceNodeId}-${params.targetNodeId}`,\n path: '',\n error: error instanceof Error ? error.message : 'Unknown error',\n };\n }\n });\n },\n};\n\nexport type ManhattanWorkerType = typeof manhattanWorker;\n\nexpose(manhattanWorker);\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["require_react_jsx_runtime_production", "__commonJSMin", "exports", "REACT_ELEMENT_TYPE", "REACT_FRAGMENT_TYPE", "jsxProd", "type", "config", "maybeKey", "key", "propName", "require_jsx_runtime", "__commonJSMin", "exports", "module", "require_react_production", "__commonJSMin", "exports", "REACT_ELEMENT_TYPE", "REACT_PORTAL_TYPE", "REACT_FRAGMENT_TYPE", "REACT_STRICT_MODE_TYPE", "REACT_PROFILER_TYPE", "REACT_CONSUMER_TYPE", "REACT_CONTEXT_TYPE", "REACT_FORWARD_REF_TYPE", "REACT_SUSPENSE_TYPE", "REACT_MEMO_TYPE", "REACT_LAZY_TYPE", "REACT_ACTIVITY_TYPE", "MAYBE_ITERATOR_SYMBOL", "getIteratorFn", "maybeIterable", "ReactNoopUpdateQueue", "assign", "emptyObject", "Component", "props", "context", "updater", "partialState", "callback", "ComponentDummy", "PureComponent", "pureComponentPrototype", "isArrayImpl", "noop", "ReactSharedInternals", "hasOwnProperty", "ReactElement", "type", "key", "refProp", "cloneAndReplaceKey", "oldElement", "newKey", "isValidElement", "object", "escape", "escaperLookup", "match", "userProvidedKeyEscapeRegex", "getElementKey", "element", "index", "resolveThenable", "thenable", "fulfilledValue", "error", "mapIntoArray", "children", "array", "escapedPrefix", "nameSoFar", "invokeCallback", "c", "nextNamePrefix", "i", "mapChildren", "func", "result", "count", "child", "lazyInitializer", "payload", "ctor", "moduleObject", "reportGlobalError", "event", "Children", "forEachFunc", "forEachContext", "n", "size", "fn", "config", "propName", "childArray", "defaultValue", "childrenLength", "render", "compare", "scope", "prevTransition", "currentTransition", "returnValue", "onStartTransitionFinish", "usable", "action", "initialState", "permalink", "deps", "Context", "value", "initialValue", "create", "ref", "passthrough", "reducer", "initialArg", "init", "subscribe", "getSnapshot", "getServerSnapshot", "require_react", "__commonJSMin", "exports", "module", "require_use_sync_external_store_shim_production", "__commonJSMin", "exports", "React", "is", "x", "y", "objectIs", "useState", "useEffect", "useLayoutEffect", "useDebugValue", "useSyncExternalStore$2", "subscribe", "getSnapshot", "value", "_useState", "inst", "forceUpdate", "checkIfSnapshotChanged", "latestGetSnapshot", "nextValue", "error", "useSyncExternalStore$1", "shim", "require_shim", "__commonJSMin", "exports", "module", "require_with_selector_production", "__commonJSMin", "exports", "React", "shim", "is", "x", "y", "objectIs", "useSyncExternalStore", "useRef", "useEffect", "useMemo", "useDebugValue", "subscribe", "getSnapshot", "getServerSnapshot", "selector", "isEqual", "instRef", "inst", "memoizedSelector", "nextSnapshot", "hasMemo", "memoizedSnapshot", "currentSelection", "memoizedSelection", "nextSelection", "maybeGetServerSnapshot", "value", "require_with_selector", "__commonJSMin", "exports", "module", "require_react_dom_production", "__commonJSMin", "exports", "React", "formatProdErrorMessage", "code", "url", "i", "noop", "Internals", "REACT_PORTAL_TYPE", "createPortal$1", "children", "containerInfo", "implementation", "key", "ReactSharedInternals", "getCrossOriginStringAs", "as", "input", "container", "fn", "previousTransition", "previousUpdatePriority", "href", "options", "crossOrigin", "integrity", "fetchPriority", "form", "a", "action", "initialState", "permalink", "require_react_dom", "__commonJSMin", "exports", "module", "checkDCE", "err", "proxyMarker", "createEndpoint", "releaseProxy", "finalizer", "throwMarker", "isObject", "val", "proxyTransferHandler", "obj", "port1", "port2", "expose", "port", "wrap", "throwTransferHandler", "value", "serialized", "transferHandlers", "isAllowedOrigin", "allowedOrigins", "origin", "allowedOrigin", "ep", "callback", "ev", "id", "type", "path", "argumentList", "fromWireValue", "returnValue", "parent", "prop", "rawValue", "proxy", "transfer", "wireValue", "transferables", "toWireValue", "closeEndPoint", "error", "isMessagePort", "endpoint", "target", "pendingListeners", "data", "resolver", "createProxy", "throwIfProxyReleased", "isReleased", "releaseEndpoint", "requestResponseMessage", "proxyCounter", "proxyFinalizers", "newCount", "registerProxy", "unregisterProxy", "isProxyReleased", "_target", "r", "p", "_thisArg", "rawArgumentList", "last", "processArguments", "myFlat", "arr", "processed", "v", "transferCache", "transfers", "toWireValue", "value", "name", "handler", "transferHandlers", "serializedValue", "transferables", "transferCache", "fromWireValue", "requestResponseMessage", "ep", "pendingListeners", "msg", "transfers", "resolve", "id", "generateUUID", "import_jsx_runtime", "import_react", "cc", "names", "out", "i", "tmp", "k", "noop", "dispatch", "i", "n", "_", "t", "Dispatch", "parseTypenames", "typenames", "types", "name", "typename", "callback", "T", "get", "set", "copy", "type", "that", "args", "c", "dispatch_default", "xhtml", "namespaces_default", "namespace_default", "name", "prefix", "i", "namespaces_default", "creatorInherit", "name", "document", "uri", "xhtml", "creatorFixed", "fullname", "creator_default", "namespace_default", "none", "selector_default", "selector", "select_default", "select", "selector_default", "groups", "m", "subgroups", "j", "group", "n", "subgroup", "node", "subnode", "i", "Selection", "array", "x", "empty", "selectorAll_default", "selector", "arrayAll", "select", "array", "selectAll_default", "selectorAll_default", "groups", "m", "subgroups", "parents", "j", "group", "n", "node", "i", "Selection", "matcher_default", "selector", "childMatcher", "node", "find", "childFind", "match", "childFirst", "selectChild_default", "childMatcher", "filter", "children", "childrenFilter", "match", "selectChildren_default", "childMatcher", "filter_default", "match", "matcher_default", "groups", "m", "subgroups", "j", "group", "n", "subgroup", "node", "i", "Selection", "sparse_default", "update", "enter_default", "Selection", "sparse_default", "EnterNode", "parent", "datum", "child", "next", "selector", "constant_default", "x", "bindIndex", "parent", "group", "enter", "update", "exit", "data", "i", "node", "groupLength", "dataLength", "EnterNode", "bindKey", "key", "nodeByKeyValue", "keyValues", "keyValue", "datum", "data_default", "value", "bind", "parents", "groups", "constant_default", "m", "j", "arraylike", "enterGroup", "updateGroup", "exitGroup", "i0", "i1", "previous", "next", "Selection", "exit_default", "Selection", "sparse_default", "join_default", "onenter", "onupdate", "onexit", "enter", "update", "exit", "merge_default", "context", "selection", "groups0", "groups1", "m0", "m1", "m", "merges", "j", "group0", "group1", "n", "merge", "node", "i", "Selection", "order_default", "groups", "j", "m", "group", "i", "next", "node", "sort_default", "compare", "ascending", "compareNode", "a", "b", "groups", "m", "sortgroups", "j", "group", "n", "sortgroup", "node", "i", "Selection", "call_default", "callback", "nodes_default", "node_default", "groups", "j", "m", "group", "i", "n", "node", "size_default", "size", "node", "empty_default", "each_default", "callback", "groups", "j", "m", "group", "n", "node", "attrRemove", "name", "attrRemoveNS", "fullname", "attrConstant", "value", "attrConstantNS", "attrFunction", "v", "attrFunctionNS", "attr_default", "namespace_default", "node", "window_default", "node", "styleRemove", "name", "styleConstant", "value", "priority", "styleFunction", "v", "style_default", "styleValue", "node", "window_default", "propertyRemove", "name", "propertyConstant", "value", "propertyFunction", "v", "property_default", "classArray", "string", "classList", "node", "ClassList", "name", "i", "classedAdd", "names", "list", "n", "classedRemove", "classedTrue", "classedFalse", "classedFunction", "value", "classed_default", "textRemove", "textConstant", "value", "textFunction", "v", "text_default", "htmlRemove", "htmlConstant", "value", "htmlFunction", "v", "html_default", "raise", "raise_default", "lower", "lower_default", "append_default", "name", "create", "creator_default", "constantNull", "insert_default", "name", "before", "create", "creator_default", "select", "selector_default", "remove", "parent", "remove_default", "selection_cloneShallow", "clone", "parent", "selection_cloneDeep", "clone_default", "deep", "datum_default", "value", "contextListener", "listener", "event", "parseTypenames", "typenames", "name", "i", "onRemove", "typename", "on", "j", "m", "o", "onAdd", "value", "options", "on_default", "n", "t", "dispatchEvent", "node", "type", "params", "window", "window_default", "event", "dispatchConstant", "dispatchFunction", "dispatch_default", "iterator_default", "groups", "j", "m", "group", "i", "n", "node", "root", "Selection", "groups", "parents", "selection", "selection_selection", "select_default", "selectAll_default", "selectChild_default", "selectChildren_default", "filter_default", "data_default", "enter_default", "exit_default", "join_default", "merge_default", "order_default", "sort_default", "call_default", "nodes_default", "node_default", "size_default", "empty_default", "each_default", "attr_default", "style_default", "property_default", "classed_default", "text_default", "html_default", "raise_default", "lower_default", "append_default", "insert_default", "remove_default", "clone_default", "datum_default", "on_default", "dispatch_default", "iterator_default", "selection_default", "select_default", "selector", "Selection", "root", "sourceEvent_default", "event", "sourceEvent", "pointer_default", "event", "node", "sourceEvent_default", "svg", "point", "rect", "nonpassive", "nonpassivecapture", "nopropagation", "event", "noevent_default", "nodrag_default", "view", "root", "selection", "select_default", "noevent_default", "nonpassivecapture", "yesdrag", "noclick", "constant_default", "x", "DragEvent", "type", "sourceEvent", "subject", "target", "identifier", "active", "x", "y", "dx", "dy", "dispatch", "value", "defaultFilter", "event", "defaultContainer", "defaultSubject", "d", "defaultTouchable", "drag_default", "filter", "container", "subject", "touchable", "gestures", "listeners", "dispatch_default", "active", "mousedownx", "mousedowny", "mousemoving", "touchending", "clickDistance2", "drag", "selection", "mousedowned", "touchstarted", "touchmoved", "nonpassive", "touchended", "gesture", "beforestart", "select_default", "mousemoved", "nonpassivecapture", "mouseupped", "nodrag_default", "nopropagation", "noevent_default", "dx", "dy", "yesdrag", "touches", "c", "n", "i", "that", "identifier", "touch", "dispatch", "p", "pointer_default", "s", "DragEvent", "type", "p0", "_", "constant_default", "value", "define_default", "constructor", "factory", "prototype", "extend", "parent", "definition", "key", "Color", "darker", "brighter", "reI", "reN", "reP", "reHex", "reRgbInteger", "reRgbPercent", "reRgbaInteger", "reRgbaPercent", "reHslPercent", "reHslaPercent", "named", "define_default", "color", "channels", "color_formatHex", "color_formatHex8", "color_formatHsl", "color_formatRgb", "hslConvert", "format", "m", "l", "rgbn", "Rgb", "rgba", "hsla", "n", "r", "g", "b", "a", "rgbConvert", "o", "rgb", "opacity", "extend", "k", "clampi", "clampa", "rgb_formatHex", "rgb_formatHex8", "rgb_formatRgb", "hex", "value", "h", "s", "Hsl", "min", "max", "hsl", "m2", "m1", "hsl2rgb", "clamph", "clampt", "basis", "t1", "v0", "v1", "v2", "v3", "t2", "t3", "basis_default", "values", "n", "t", "i", "basisClosed_default", "values", "n", "t", "i", "v0", "v1", "v2", "v3", "basis", "constant_default", "x", "linear", "a", "d", "t", "exponential", "b", "y", "gamma", "y", "nogamma", "a", "b", "exponential", "constant_default", "d", "linear", "rgb_default", "rgbGamma", "y", "color", "gamma", "rgb", "start", "end", "r", "g", "b", "opacity", "nogamma", "t", "rgbSpline", "spline", "colors", "i", "rgbBasis", "basis_default", "rgbBasisClosed", "basisClosed_default", "numberArray_default", "a", "b", "c", "i", "t", "isNumberArray", "x", "genericArray", "a", "b", "nb", "na", "x", "c", "i", "value_default", "t", "date_default", "a", "b", "d", "t", "number_default", "a", "b", "t", "object_default", "a", "b", "i", "c", "k", "value_default", "t", "reA", "reB", "zero", "b", "one", "string_default", "a", "bi", "am", "bm", "bs", "i", "s", "q", "number_default", "t", "o", "value_default", "a", "b", "t", "c", "constant_default", "number_default", "color", "rgb_default", "string_default", "date_default", "isNumberArray", "numberArray_default", "genericArray", "object_default", "degrees", "identity", "decompose_default", "a", "b", "c", "d", "e", "f", "scaleX", "scaleY", "skewX", "svgNode", "parseCss", "value", "m", "identity", "decompose_default", "parseSvg", "interpolateTransform", "parse", "pxComma", "pxParen", "degParen", "pop", "s", "translate", "xa", "ya", "xb", "yb", "q", "i", "number_default", "rotate", "a", "b", "skewX", "scale", "t", "n", "o", "interpolateTransformCss", "parseCss", "interpolateTransformSvg", "parseSvg", "epsilon2", "cosh", "x", "sinh", "tanh", "zoom_default", "zoomRho", "rho", "rho2", "rho4", "zoom", "p0", "p1", "ux0", "uy0", "w0", "ux1", "uy1", "w1", "dx", "dy", "d2", "i", "S", "t", "d1", "b0", "b1", "r0", "r1", "s", "coshr0", "u", "_", "_1", "_2", "_4", "frame", "timeout", "interval", "pokeDelay", "taskHead", "taskTail", "clockLast", "clockNow", "clockSkew", "clock", "setFrame", "f", "now", "clearNow", "Timer", "timer", "callback", "delay", "time", "sleep", "t", "timerFlush", "e", "wake", "nap", "poke", "t0", "t1", "t2", "timeout_default", "callback", "delay", "time", "t", "Timer", "elapsed", "emptyOn", "dispatch_default", "emptyTween", "CREATED", "SCHEDULED", "STARTING", "STARTED", "RUNNING", "ENDING", "ENDED", "schedule_default", "node", "name", "id", "index", "group", "timing", "schedules", "create", "init", "schedule", "get", "set", "self", "tween", "timer", "elapsed", "start", "i", "j", "n", "o", "stop", "timeout_default", "tick", "t", "interrupt_default", "node", "name", "schedules", "schedule", "active", "empty", "i", "STARTING", "ENDING", "ENDED", "interrupt_default", "name", "tweenRemove", "id", "name", "tween0", "tween1", "schedule", "set", "tween", "i", "n", "tweenFunction", "value", "t", "tween_default", "get", "tweenValue", "transition", "node", "interpolate_default", "a", "b", "c", "number_default", "color", "rgb_default", "string_default", "attrRemove", "name", "attrRemoveNS", "fullname", "attrConstant", "interpolate", "value1", "string00", "string1", "interpolate0", "string0", "attrConstantNS", "attrFunction", "value", "string10", "attrFunctionNS", "attr_default", "namespace_default", "i", "interpolateTransformSvg", "interpolate_default", "tweenValue", "attrInterpolate", "name", "i", "t", "attrInterpolateNS", "fullname", "attrTweenNS", "value", "t0", "i0", "tween", "attrTween", "attrTween_default", "key", "namespace_default", "delayFunction", "id", "value", "init", "delayConstant", "delay_default", "get", "durationFunction", "id", "value", "set", "durationConstant", "duration_default", "get", "easeConstant", "id", "value", "set", "ease_default", "get", "easeVarying", "id", "value", "v", "set", "easeVarying_default", "filter_default", "match", "matcher_default", "groups", "m", "subgroups", "j", "group", "n", "subgroup", "node", "i", "Transition", "merge_default", "transition", "groups0", "groups1", "m0", "m1", "m", "merges", "j", "group0", "group1", "n", "merge", "node", "i", "Transition", "start", "name", "i", "onFunction", "id", "listener", "on0", "on1", "sit", "init", "set", "schedule", "on", "on_default", "get", "removeFunction", "id", "parent", "i", "remove_default", "select_default", "select", "name", "id", "selector_default", "groups", "m", "subgroups", "j", "group", "n", "subgroup", "node", "subnode", "i", "schedule_default", "get", "Transition", "selectAll_default", "select", "name", "id", "selectorAll_default", "groups", "m", "subgroups", "parents", "j", "group", "n", "node", "i", "children", "child", "inherit", "get", "k", "l", "schedule_default", "Transition", "Selection", "selection_default", "styleNull", "name", "interpolate", "string00", "string10", "interpolate0", "string0", "styleValue", "string1", "styleRemove", "styleConstant", "value1", "styleFunction", "value", "styleMaybeRemove", "id", "on0", "on1", "listener0", "key", "event", "remove", "schedule", "set", "on", "listener", "style_default", "priority", "i", "interpolateTransformCss", "interpolate_default", "tweenValue", "styleInterpolate", "name", "i", "priority", "t", "styleTween", "value", "i0", "tween", "styleTween_default", "key", "textConstant", "value", "textFunction", "value1", "text_default", "tweenValue", "textInterpolate", "i", "textTween", "value", "t0", "i0", "tween", "textTween_default", "key", "transition_default", "name", "id0", "id1", "newId", "groups", "m", "j", "group", "n", "node", "i", "inherit", "get", "schedule_default", "Transition", "end_default", "on0", "on1", "that", "id", "size", "resolve", "reject", "cancel", "end", "schedule", "set", "on", "id", "Transition", "groups", "parents", "name", "transition", "selection_default", "newId", "selection_prototype", "select_default", "selectAll_default", "filter_default", "merge_default", "transition_default", "on_default", "attr_default", "attrTween_default", "style_default", "styleTween_default", "text_default", "textTween_default", "remove_default", "tween_default", "delay_default", "duration_default", "ease_default", "easeVarying_default", "end_default", "cubicInOut", "t", "defaultTiming", "cubicInOut", "inherit", "node", "id", "timing", "transition_default", "name", "Transition", "newId", "now", "groups", "m", "j", "group", "n", "i", "schedule_default", "selection_default", "interrupt_default", "transition_default", "constant_default", "x", "ZoomEvent", "type", "sourceEvent", "target", "transform", "dispatch", "Transform", "k", "x", "y", "point", "location", "identity", "transform", "node", "nopropagation", "event", "noevent_default", "defaultFilter", "event", "defaultExtent", "defaultTransform", "identity", "defaultWheelDelta", "defaultTouchable", "defaultConstrain", "transform", "extent", "translateExtent", "dx0", "dx1", "dy0", "dy1", "zoom_default", "filter", "constrain", "wheelDelta", "touchable", "scaleExtent", "duration", "interpolate", "listeners", "dispatch_default", "touchstarting", "touchfirst", "touchending", "touchDelay", "wheelDelay", "clickDistance2", "tapDistance", "zoom", "selection", "wheeled", "mousedowned", "dblclicked", "touchstarted", "touchmoved", "touchended", "collection", "point", "schedule", "gesture", "k", "p", "k0", "k1", "e", "t0", "p0", "centroid", "p1", "translate", "scale", "x", "y", "t", "Transform", "transition", "that", "args", "g", "w", "a", "b", "i", "l", "clean", "Gesture", "key", "type", "d", "select_default", "ZoomEvent", "pointer_default", "interrupt_default", "noevent_default", "wheelidled", "currentTarget", "v", "mousemoved", "mouseupped", "x0", "y0", "nodrag_default", "nopropagation", "dx", "dy", "yesdrag", "t1", "touches", "n", "started", "l0", "l1", "dp", "dl", "_", "constant_default", "value", "errorMessages", "nodeType", "id", "type", "handleType", "sourceHandle", "targetHandle", "edgeType", "lib", "infiniteExtent", "elementSelectionKeys", "defaultAriaLabelConfig", "direction", "x", "y", "ConnectionMode", "PanOnScrollMode", "SelectionMode", "initialConnection", "ConnectionLineType", "MarkerType", "Position", "oppositePosition", "getConnectionStatus", "isValid", "isEdgeBase", "element", "isNodeBase", "isInternalNodeBase", "getNodePositionWithOrigin", "node", "nodeOrigin", "_a", "width", "height", "getNodeDimensions", "origin", "offsetX", "offsetY", "getNodesBounds", "nodes", "params", "box", "currBox", "nodeOrId", "isId", "currentNode", "isInternalNodeBase", "nodeBox", "nodeToBox", "getBoundsOfBoxes", "boxToRect", "getInternalNodesBounds", "nodeLookup", "hasVisibleNodes", "getNodesInside", "rect", "tx", "ty", "tScale", "partially", "excludeNonSelectableNodes", "_b", "_c", "_d", "_e", "_f", "paneRect", "pointToRendererPoint", "visibleNodes", "measured", "selectable", "hidden", "overlappingArea", "getOverlappingArea", "nodeToRect", "area", "partiallyVisible", "getConnectedEdges", "edges", "nodeIds", "edge", "getFitViewNodes", "options", "fitViewNodes", "optionNodeIds", "n", "fitViewport", "panZoom", "minZoom", "maxZoom", "nodesToFit", "bounds", "viewport", "getViewportForBounds", "calculateNodePosition", "nodeId", "nextPosition", "nodeExtent", "onError", "parentNode", "parentX", "parentY", "extent", "errorMessages", "parentWidth", "parentHeight", "isCoordinateExtent", "positionAbsolute", "clampPosition", "getElementsToRemove", "nodesToRemove", "edgesToRemove", "onBeforeDelete", "matchingNodes", "isIncluded", "parentHit", "edgeIds", "deletableEdges", "matchingEdges", "e", "onBeforeDeleteResult", "clamp", "val", "min", "max", "position", "dimensions", "clampPositionToParent", "childPosition", "childDimensions", "parent", "calcAutoPanVelocity", "value", "calcAutoPan", "pos", "speed", "distance", "xMovement", "yMovement", "box1", "box2", "rectToBox", "x", "y", "x2", "y2", "_g", "_h", "getBoundsOfRects", "rect1", "rect2", "rectA", "rectB", "xOverlap", "yOverlap", "isRectObject", "obj", "isNumeric", "devWarn", "id", "message", "snapPosition", "snapGrid", "snapToGrid", "rendererPointToPoint", "parsePadding", "padding", "paddingValue", "parsePaddings", "paddingY", "paddingX", "top", "bottom", "left", "right", "calculateAppliedPaddings", "zoom", "boundRight", "boundBottom", "p", "xZoom", "yZoom", "clampedZoom", "boundsCenterX", "boundsCenterY", "newPadding", "offset", "isMacOs", "nodeHasDimensions", "evaluateAbsolutePosition", "parentId", "areSetsEqual", "a", "b", "item", "withResolvers", "resolve", "reject", "res", "rej", "mergeAriaLabelConfig", "partial", "defaultAriaLabelConfig", "getPointerPosition", "event", "transform", "containerBounds", "getEventPosition", "pointerPos", "xSnapped", "ySnapped", "getDimensions", "getHostForElement", "element", "inputTags", "isInputDOMNode", "target", "isMouseEvent", "isMouse", "evtX", "evtY", "getHandleBounds", "type", "nodeElement", "nodeBounds", "handles", "handle", "handleBounds", "getBezierEdgeCenter", "sourceX", "sourceY", "targetX", "targetY", "sourceControlX", "sourceControlY", "targetControlX", "targetControlY", "centerX", "centerY", "calculateControlOffset", "curvature", "getControlWithCurvature", "x1", "y1", "c", "Position", "getBezierPath", "sourcePosition", "targetPosition", "labelX", "labelY", "getEdgeCenter", "xOffset", "yOffset", "getElevatedEdgeZIndex", "sourceNode", "targetNode", "selected", "zIndex", "elevateOnSelect", "edgeZ", "nodeZ", "isEdgeVisible", "edgeBox", "viewRect", "getEdgeId", "source", "sourceHandle", "targetHandle", "connectionExists", "el", "addEdge", "edgeParams", "isEdgeBase", "getStraightPath", "sourceX", "sourceY", "targetX", "targetY", "labelX", "labelY", "offsetX", "offsetY", "getEdgeCenter", "handleDirections", "Position", "getDirection", "source", "sourcePosition", "target", "distance", "a", "b", "getPoints", "targetPosition", "center", "offset", "stepPosition", "_a", "_b", "_c", "_d", "sourceDir", "targetDir", "sourceGapped", "targetGapped", "dir", "dirAccessor", "currDir", "points", "centerX", "centerY", "sourceGapOffset", "targetGapOffset", "defaultOffsetX", "defaultOffsetY", "verticalSplit", "horizontalSplit", "sourceTarget", "targetSource", "diff", "gapOffset", "dirAccessorOpposite", "isSameDir", "sourceGtTargetOppo", "sourceLtTargetOppo", "sourceGapPoint", "targetGapPoint", "maxXDistance", "maxYDistance", "getBend", "c", "size", "bendSize", "x", "y", "xDir", "yDir", "getSmoothStepPath", "borderRadius", "res", "p", "i", "segment", "isNodeInitialized", "node", "getEdgePosition", "params", "_e", "sourceNode", "targetNode", "sourceHandleBounds", "toHandleBounds", "targetHandleBounds", "sourceHandle", "getHandle$1", "targetHandle", "ConnectionMode", "errorMessages", "getHandlePosition", "handles", "handle", "fallbackPosition", "width", "height", "getNodeDimensions", "bounds", "handleId", "d", "getMarkerId", "marker", "id", "key", "createMarkerIds", "edges", "defaultColor", "defaultMarkerStart", "defaultMarkerEnd", "ids", "markers", "edge", "markerId", "SELECTED_NODE_Z", "ROOT_PARENT_Z_INCREMENT", "defaultOptions", "infiniteExtent", "adoptUserNodesDefaultOptions", "mergeObjects", "base", "incoming", "result", "key", "updateAbsolutePositions", "nodeLookup", "parentLookup", "options", "_options", "node", "updateChildNode", "positionWithOrigin", "getNodePositionWithOrigin", "extent", "isCoordinateExtent", "clampedPosition", "clampPosition", "getNodeDimensions", "parseHandles", "userNode", "internalNode", "_a", "_b", "source", "target", "handle", "handleBounds", "adoptUserNodes", "nodes", "rootParentIndex", "nodesInitialized", "tmpLookup", "selectedNodeZ", "calculateZ", "updateParentLookup", "childNodes", "elevateNodesOnSelect", "nodeOrigin", "nodeExtent", "parentId", "parentNode", "x", "y", "z", "calculateChildXYZ", "positionAbsolute", "positionChanged", "isNumeric", "childNode", "parentX", "parentY", "childDimensions", "absolutePosition", "clampPositionToParent", "childZ", "parentZ", "handleExpandParent", "children", "changes", "parentExpansions", "child", "parent", "parentRect", "nodeToRect", "expandedRect", "getBoundsOfRects", "dimensions", "origin", "xChange", "yChange", "newWidth", "newHeight", "widthChange", "heightChange", "updateNodeInternals", "updates", "domNode", "viewportNode", "updatedInternals", "style", "zoom", "parentExpandChildren", "update", "getDimensions", "dimensionChanged", "nodeBounds", "newNode", "getHandleBounds", "parentExpandChanges", "panBy", "delta", "panZoom", "transform", "translateExtent", "width", "height", "nextViewport", "transformChanged", "addConnectionToLookup", "type", "connection", "connectionKey", "connectionLookup", "nodeId", "handleId", "nodeMap", "typeMap", "handleMap", "updateConnectionLookup", "edgeLookup", "edges", "edge", "sourceNode", "targetNode", "sourceHandle", "targetHandle", "sourceKey", "targetKey", "isParentSelected", "node", "nodeLookup", "parentNode", "hasSelector", "target", "selector", "domNode", "_a", "current", "getDragItems", "nodesDraggable", "mousePos", "nodeId", "_b", "dragItems", "id", "internalNode", "getEventHandlerParams", "dragging", "_c", "nodesFromDragItems", "dragItem", "calculateSnapOffset", "snapGrid", "x", "y", "refDragItem", "refPos", "refPosSnapped", "snapPosition", "XYDrag", "onNodeMouseDown", "getStoreItems", "onDragStart", "onDrag", "onDragStop", "lastPos", "autoPanId", "autoPanStarted", "mousePosition", "containerBounds", "dragStarted", "d3Selection", "abortDrag", "nodePositionsChanged", "dragEvent", "update", "noDragClassName", "handleSelector", "isSelectable", "nodeClickDistance", "select_default", "updateNodes", "nodeExtent", "snapToGrid", "nodeOrigin", "onNodeDrag", "onSelectionDrag", "onError", "updateNodePositions", "hasChange", "isMultiDrag", "nodesBox", "rectToBox", "getInternalNodesBounds", "multiDragSnapOffset", "nextPosition", "adjustedNodeExtent", "positionAbsolute", "x1", "x2", "y1", "y2", "position", "calculateNodePosition", "currentNode", "currentNodes", "autoPan", "transform", "panBy", "autoPanSpeed", "autoPanOnNodeDrag", "xMovement", "yMovement", "calcAutoPan", "startDrag", "event", "multiSelectionActive", "selectNodesOnDrag", "onNodeDragStart", "onSelectionDragStart", "unselectNodesAndEdges", "pointerPos", "getPointerPosition", "d3DragInstance", "drag_default", "nodeDragThreshold", "getEventPosition", "currentMousePosition", "onNodeDragStop", "onSelectionDragStop", "destroy", "getNodesWithinDistance", "distance", "nodes", "rect", "getOverlappingArea", "nodeToRect", "ADDITIONAL_DISTANCE", "getClosestHandle", "connectionRadius", "fromHandle", "_d", "_e", "closestHandles", "minDistance", "closeNodes", "allHandles", "handle", "getHandlePosition", "oppositeHandleType", "getHandle", "handleType", "handleId", "connectionMode", "withAbsolutePosition", "_f", "handles", "h", "getHandleType", "edgeUpdaterType", "handleDomNode", "isConnectionValid", "isInsideConnectionRadius", "isHandleValid", "isValid", "alwaysValid", "onPointerDown", "isTarget", "lib", "autoPanOnConnect", "flowId", "cancelConnection", "onConnectStart", "onConnect", "onConnectEnd", "isValidConnection", "onReconnectEnd", "updateConnection", "getTransform", "getFromHandle", "dragThreshold", "doc", "getHostForElement", "closestHandle", "connectionStarted", "fromHandleInternal", "connection", "resultHandleDomNode", "fromNodeInternal", "previousConnection", "Position", "oppositePosition", "startConnection", "onPointerMove", "evtX", "evtY", "dx", "dy", "onPointerUp", "pointToRendererPoint", "result", "isValidHandle", "newConnection", "rendererPointToPoint", "inProgress", "connectionState", "finalConnectionState", "fromNodeId", "fromHandleId", "fromType", "handleBelow", "handleToCheck", "handleNodeId", "connectable", "connectableEnd", "ConnectionMode", "XYHandle", "XYMinimap", "panZoom", "getViewScale", "selection", "translateExtent", "width", "height", "zoomStep", "pannable", "zoomable", "inversePan", "zoomHandler", "factor", "isMacOs", "pinchDelta", "nextZoom", "panStart", "panStartHandler", "panHandler", "panCurrent", "panDelta", "moveScale", "extent", "zoomAndPanHandler", "zoom_default", "pointer_default", "transformToViewport", "viewportToTransform", "zoom", "identity", "isWrappedWithClass", "className", "isRightClickPan", "panOnDrag", "usedButton", "defaultEase", "t", "getD3Transition", "duration", "ease", "onEnd", "hasDuration", "wheelDelta", "createPanOnScrollHandler", "zoomPanValues", "noWheelClassName", "d3Zoom", "panOnScrollMode", "panOnScrollSpeed", "zoomOnPinch", "onPanZoomStart", "onPanZoom", "onPanZoomEnd", "currentZoom", "point", "deltaNormalize", "deltaX", "PanOnScrollMode", "deltaY", "nextViewport", "createZoomOnScrollHandler", "preventScrolling", "d3ZoomHandler", "d", "isWheel", "preventZoom", "hasNoWheelClass", "createPanZoomStartHandler", "onDraggingChange", "viewport", "createPanZoomHandler", "onPaneContextMenu", "onTransformChange", "createPanZoomEndHandler", "panOnScroll", "createFilter", "zoomActivationKeyPressed", "zoomOnScroll", "zoomOnDoubleClick", "userSelectionActive", "noPanClassName", "connectionInProgress", "zoomScroll", "pinchZoom", "isWheelEvent", "buttonAllowed", "XYPanZoom", "minZoom", "maxZoom", "paneClickDistance", "bbox", "d3ZoomInstance", "isNumeric", "setViewportConstrained", "clamp", "d3DblClickZoomHandler", "setTransform", "options", "resolve", "value_default", "wheelHandler", "startHandler", "panZoomHandler", "panZoomEndHandler", "filter", "nextTransform", "contrainedTransform", "setViewport", "syncViewport", "currentTransform", "getViewport", "scaleTo", "scaleBy", "setScaleExtent", "scaleExtent", "setTranslateExtent", "setClickDistance", "validDistance", "ResizeControlVariant", "getResizeDirection", "width", "prevWidth", "height", "prevHeight", "affectsX", "affectsY", "deltaWidth", "deltaHeight", "direction", "getControlDirection", "controlPosition", "isHorizontal", "isVertical", "getLowerExtentClamp", "lowerExtent", "lowerBound", "getUpperExtentClamp", "upperExtent", "upperBound", "getSizeClamp", "size", "minSize", "maxSize", "xor", "a", "b", "getDimensionsAfterResize", "startValues", "controlDirection", "pointerPosition", "boundaries", "keepAspectRatio", "nodeOrigin", "extent", "childExtent", "isDiagonal", "xSnapped", "ySnapped", "minWidth", "maxWidth", "minHeight", "maxHeight", "startX", "startY", "startWidth", "startHeight", "aspectRatio", "distX", "distY", "newWidth", "newHeight", "originOffsetX", "originOffsetY", "clampX", "clampY", "xExtentClamp", "yExtentClamp", "aspectHeightClamp", "aspectExtentClamp", "aspectWidthClamp", "x", "y", "initPrevValues", "initStartValues", "nodeToParentExtent", "node", "nodeToChildExtent", "child", "parent", "_a", "_b", "XYResizer", "domNode", "nodeId", "getStoreItems", "onChange", "onEnd", "selection", "select_default", "params", "update", "resizeDirection", "onResizeStart", "onResize", "onResizeEnd", "shouldResize", "prevValues", "containerBounds", "childNodes", "parentNode", "parentExtent", "resizeDetected", "dragHandler", "drag_default", "event", "_c", "_d", "_e", "_f", "nodeLookup", "transform", "snapGrid", "snapToGrid", "paneDomNode", "getPointerPosition", "childId", "storeNodeOrigin", "childChanges", "prevX", "prevY", "change", "isWidthChange", "isHeightChange", "isXPosChange", "isYPosChange", "xChange", "yChange", "childNode", "xLimit", "yLimit", "nextValues", "destroy", "import_react", "import_with_selector", "import_meta", "createStoreImpl", "createState", "state", "listeners", "setState", "partial", "replace", "nextState", "previousState", "listener", "getState", "api", "initialState", "createStore", "useDebugValue", "ReactExports", "useSyncExternalStoreWithSelector", "useSyncExternalStoreExports", "identity", "arg", "useStoreWithEqualityFn", "api", "selector", "equalityFn", "slice", "createWithEqualityFnImpl", "createState", "defaultEqualityFn", "createStore", "useBoundStoreWithEqualityFn", "createWithEqualityFn", "shallow$1", "objA", "objB", "key", "value", "keysA", "keyA", "import_react_dom", "StoreContext", "Provider$1", "zustandErrorMessage", "errorMessages", "useStore", "selector", "equalityFn", "store", "useStoreWithEqualityFn", "useStoreApi", "style", "ariaLiveStyle", "ARIA_NODE_DESC_KEY", "ARIA_EDGE_DESC_KEY", "ARIA_LIVE_MESSAGE", "ariaLiveSelector", "s", "ariaLabelConfigSelector", "AriaLiveMessage", "rfId", "ariaLiveMessage", "A11yDescriptions", "disableKeyboardA11y", "ariaLabelConfig", "Panel", "position", "children", "className", "rest", "ref", "positionClasses", "cc", "Attribution", "proOptions", "selector$m", "selectedNodes", "selectedEdges", "node", "edge", "selectId", "obj", "areEqual", "a", "b", "shallow$1", "SelectionListenerInner", "onSelectionChange", "params", "fn", "changeSelector", "SelectionListener", "storeHasSelectionChangeHandlers", "defaultNodeOrigin", "defaultViewport", "reactFlowFieldsToTrack", "fieldsToTrack", "selector$l", "initPrevValues", "infiniteExtent", "StoreUpdater", "props", "setNodes", "setEdges", "setMinZoom", "setMaxZoom", "setTranslateExtent", "setNodeExtent", "reset", "setDefaultNodesAndEdges", "setPaneClickDistance", "previousFields", "fieldName", "fieldValue", "previousFieldValue", "mergeAriaLabelConfig", "getMediaQuery", "useColorModeClass", "colorMode", "_a", "colorModeClass", "setColorModeClass", "mediaQuery", "updateColorModeClass", "defaultDoc", "useKeyPress", "keyCode", "options", "keyPressed", "setKeyPressed", "modifierPressed", "pressedKeys", "keyCodes", "keysToWatch", "keys", "kc", "keysFlat", "res", "item", "_b", "target", "actInsideInputWithModifier", "downHandler", "event", "isInputDOMNode", "keyOrCode", "useKeyOrCode", "isMatchingKey", "isInteractiveElement", "upHandler", "resetHandler", "isUp", "k", "eventCode", "useViewportHelper", "panZoom", "zoomLevel", "viewport", "_c", "tX", "tY", "tZoom", "x", "y", "zoom", "bounds", "width", "height", "minZoom", "maxZoom", "getViewportForBounds", "clientPosition", "transform", "snapGrid", "snapToGrid", "domNode", "domX", "domY", "correctedPosition", "_snapGrid", "_snapToGrid", "pointToRendererPoint", "flowPosition", "rendererPosition", "rendererPointToPoint", "applyChanges", "changes", "elements", "updatedElements", "changesMap", "addItemChanges", "change", "elementChanges", "element", "updatedElement", "applyChange", "applyNodeChanges", "nodes", "applyEdgeChanges", "edges", "createSelectionChange", "id", "selected", "getSelectionChanges", "items", "selectedIds", "mutateItem", "willBeSelected", "getElementsDiffChanges", "lookup", "itemsLookup", "index", "lookupItem", "storeItem", "elementToRemoveChange", "isNode", "isNodeBase", "isEdge", "isEdgeBase", "fixedForwardRef", "render", "useIsomorphicLayoutEffect", "useQueue", "runQueue", "serial", "setSerial", "queue", "createQueue", "n", "queueItems", "cb", "BatchContext", "BatchProvider", "nodeQueueHandler", "hasDefaultNodes", "onNodesChange", "nodeLookup", "fitViewQueued", "next", "payload", "nodeQueue", "edgeQueueHandler", "hasDefaultEdges", "onEdgesChange", "edgeLookup", "edgeQueue", "value", "useBatchContext", "batchContext", "selector$k", "useReactFlow", "viewportHelper", "viewportInitialized", "generalHelper", "getInternalNode", "getNodeRect", "_d", "nodeOrigin", "nodeToUse", "evaluateAbsolutePosition", "nodeWithPosition", "nodeToRect", "updateNode", "nodeUpdate", "prevNodes", "nextNode", "updateEdge", "edgeUpdate", "prevEdges", "nextEdge", "e", "newNodes", "newEdges", "nodesToRemove", "edgesToRemove", "onNodesDelete", "onEdgesDelete", "triggerNodeChanges", "triggerEdgeChanges", "onDelete", "onBeforeDelete", "matchingNodes", "matchingEdges", "getElementsToRemove", "hasMatchingEdges", "hasMatchingNodes", "edgeChanges", "nodeChanges", "nodeOrRect", "partially", "isRect", "isRectObject", "nodeRect", "hasNodesOption", "internalNode", "currNodeRect", "overlappingArea", "getOverlappingArea", "area", "dataUpdate", "nextData", "getNodesBounds", "type", "nodeId", "handleId", "fitViewResolver", "withResolvers", "win$1", "useGlobalKeyHandler", "deleteKeyCode", "multiSelectionKeyCode", "deleteElements", "deleteKeyPressed", "multiSelectionKeyPressed", "useResizeHandler", "updateDimensions", "_e", "size", "getDimensions", "resizeObserver", "containerStyle", "selector$j", "ZoomPane", "onPaneContextMenu", "zoomOnScroll", "zoomOnPinch", "panOnScroll", "panOnScrollSpeed", "panOnScrollMode", "PanOnScrollMode", "zoomOnDoubleClick", "panOnDrag", "translateExtent", "zoomActivationKeyCode", "preventScrolling", "noWheelClassName", "noPanClassName", "onViewportChange", "isControlledViewport", "paneClickDistance", "zoomPane", "userSelectionActive", "lib", "connectionInProgress", "zoomActivationKeyPressed", "onTransformChange", "XYPanZoom", "paneDragging", "vp", "onViewportChangeStart", "onMoveStart", "onMove", "onViewportChangeEnd", "onMoveEnd", "selector$i", "UserSelection", "userSelectionRect", "wrapHandler", "handler", "containerRef", "selector$h", "Pane", "isSelecting", "selectionKeyPressed", "selectionMode", "SelectionMode", "selectionOnDrag", "onSelectionStart", "onSelectionEnd", "onPaneClick", "onPaneScroll", "onPaneMouseEnter", "onPaneMouseMove", "onPaneMouseLeave", "elementsSelectable", "dragging", "hasActiveSelection", "container", "containerBounds", "selectedNodeIds", "selectedEdgeIds", "selectionInProgress", "selectionStarted", "onClick", "onContextMenu", "onWheel", "onClickCapture", "onPointerDownCapture", "resetSelectedElements", "isNoKeyEvent", "isSelectionActive", "getEventPosition", "onPointerMove", "connectionLookup", "defaultEdgeOptions", "mouseX", "mouseY", "startX", "startY", "nextUserSelectRect", "prevSelectedNodeIds", "prevSelectedEdgeIds", "getNodesInside", "edgesSelectable", "connections", "edgeId", "areSetsEqual", "onPointerUp", "draggable", "handleNodeClick", "unselect", "nodeRef", "addSelectedNodes", "unselectNodesAndEdges", "multiSelectionActive", "onError", "useDrag", "disabled", "noDragClassName", "handleSelector", "isSelectable", "nodeClickDistance", "setDragging", "xyDrag", "XYDrag", "selectedAndDraggable", "nodesDraggable", "useMoveSelectedNodes", "nodeExtent", "updateNodePositions", "nodeUpdates", "isSelected", "xVelo", "yVelo", "xDiff", "yDiff", "nextPosition", "snapPosition", "positionAbsolute", "calculateNodePosition", "NodeIdContext", "Provider", "useNodeId", "selector$g", "connectingSelector", "state", "clickHandle", "connectionMode", "connection", "fromHandle", "toHandle", "isValid", "connectingTo", "ConnectionMode", "HandleComponent", "Position", "isValidConnection", "isConnectable", "isConnectableStart", "isConnectableEnd", "onConnect", "onMouseDown", "onTouchStart", "isTarget", "connectOnClick", "connectingFrom", "clickConnecting", "isPossibleEndHandle", "connectionInProcess", "clickConnectionInProcess", "valid", "onConnectExtended", "onConnectAction", "edgeParams", "addEdge", "onPointerDown", "isMouseTriggered", "isMouseEvent", "currentStore", "XYHandle", "onClickConnectStart", "onClickConnectEnd", "connectionClickStartHandle", "isValidConnectionStore", "flowId", "connectionState", "doc", "getHostForElement", "isValidConnectionHandler", "connectionClone", "Handle", "InputNode", "data", "sourcePosition", "DefaultNode", "targetPosition", "GroupNode", "OutputNode", "arrowKeyDiffs", "builtinNodeTypes", "getNodeInlineStyleDimensions", "_f", "_g", "_h", "_i", "_j", "selector$f", "getInternalNodesBounds", "isNumeric", "NodesSelection", "onSelectionContextMenu", "transformString", "moveSelectedNodes", "onKeyDown", "win", "selector$e", "FlowRendererComponent", "selectionKeyCode", "panActivationKeyCode", "_panOnScroll", "_panOnDrag", "nodesSelectionActive", "panActivationKeyPressed", "_selectionOnDrag", "FlowRenderer", "selector$d", "onlyRenderVisible", "useVisibleNodeIds", "selector$c", "useResizeObserver", "updateNodeInternals", "entries", "updates", "entry", "useNodeObserver", "nodeType", "hasDimensions", "observedNode", "prevSourcePosition", "prevTargetPosition", "prevType", "isInitialized", "typeChanged", "sourcePosChanged", "targetPosChanged", "NodeWrapper", "onMouseEnter", "onMouseMove", "onMouseLeave", "onDoubleClick", "nodesConnectable", "nodesFocusable", "nodeTypes", "internals", "isParent", "NodeComponent", "isDraggable", "isFocusable", "nodeHasDimensions", "nodeDimensions", "getNodeDimensions", "inlineDimensions", "hasPointerEvents", "onMouseEnterHandler", "onMouseMoveHandler", "onMouseLeaveHandler", "onContextMenuHandler", "onDoubleClickHandler", "onSelectNodeHandler", "selectNodesOnDrag", "nodeDragThreshold", "elementSelectionKeys", "onFocus", "autoPanOnNodeFocus", "setCenter", "NodeWrapper$1", "selector$b", "NodeRendererComponent", "nodeIds", "NodeRenderer", "useVisibleEdgeIds", "visibleEdgeIds", "sourceNode", "targetNode", "isEdgeVisible", "ArrowSymbol", "color", "strokeWidth", "ArrowClosedSymbol", "MarkerSymbols", "MarkerType", "useMarkerSymbol", "Marker", "markerUnits", "orient", "Symbol", "MarkerDefinitions", "defaultColor", "markers", "createMarkerIds", "marker", "MarkerDefinitions$1", "EdgeTextComponent", "label", "labelStyle", "labelShowBg", "labelBgStyle", "labelBgPadding", "labelBgBorderRadius", "edgeTextBbox", "setEdgeTextBbox", "edgeTextClasses", "edgeTextRef", "textBbox", "EdgeText", "BaseEdge", "path", "labelX", "labelY", "interactionWidth", "getControl", "pos", "x1", "y1", "x2", "y2", "getSimpleBezierPath", "sourceX", "sourceY", "targetX", "targetY", "sourceControlX", "sourceControlY", "targetControlX", "targetControlY", "offsetX", "offsetY", "getBezierEdgeCenter", "createSimpleBezierEdge", "markerEnd", "markerStart", "_id", "SimpleBezierEdge", "SimpleBezierEdgeInternal", "createSmoothStepEdge", "pathOptions", "getSmoothStepPath", "SmoothStepEdge", "SmoothStepEdgeInternal", "createStepEdge", "StepEdge", "StepEdgeInternal", "createStraightEdge", "getStraightPath", "StraightEdge", "StraightEdgeInternal", "createBezierEdge", "getBezierPath", "BezierEdge", "BezierEdgeInternal", "builtinEdgeTypes", "nullPosition", "shiftX", "shift", "shiftY", "EdgeUpdaterClassName", "EdgeAnchor", "centerX", "centerY", "radius", "onMouseOut", "EdgeUpdateAnchors", "isReconnectable", "reconnectRadius", "onReconnect", "onReconnectStart", "onReconnectEnd", "setReconnecting", "setUpdateHover", "handleEdgeUpdater", "oppositeHandle", "autoPanOnConnect", "connectionRadius", "onConnectStart", "onConnectEnd", "cancelConnection", "panBy", "updateConnection", "_onReconnectEnd", "evt", "onConnectEdge", "_onConnectStart", "_event", "onReconnectSourceMouseDown", "onReconnectTargetMouseDown", "onReconnectMouseEnter", "onReconnectMouseOut", "EdgeWrapper", "edgesFocusable", "edgesReconnectable", "edgeTypes", "edgeType", "EdgeComponent", "edgeRef", "updateHover", "reconnecting", "zIndex", "edgePosition", "getEdgePosition", "getElevatedEdgeZIndex", "markerStartUrl", "getMarkerId", "markerEndUrl", "onEdgeClick", "addSelectedEdges", "onEdgeDoubleClick", "onEdgeContextMenu", "onEdgeMouseEnter", "onEdgeMouseMove", "onEdgeMouseLeave", "EdgeWrapper$1", "selector$a", "EdgeRendererComponent", "defaultMarkerColor", "onlyRenderVisibleElements", "edgeIds", "EdgeRenderer", "selector$9", "Viewport", "useOnInitHandler", "onInit", "rfInstance", "selector$8", "useViewportSync", "syncViewport", "storeSelector$1", "getSelector", "connectionSelector", "useConnection", "combinedSelector", "selector$7", "ConnectionLineWrapper", "component", "inProgress", "getConnectionStatus", "ConnectionLine", "ConnectionLineType", "CustomComponent", "from", "fromNode", "fromPosition", "to", "toNode", "toPosition", "pathParams", "emptyTypes", "useNodeOrEdgeTypesWarning", "nodeOrEdgeTypes", "typesRef", "useStylesLoadedWarning", "checked", "GraphViewComponent", "onNodeClick", "onNodeDoubleClick", "onNodeMouseEnter", "onNodeMouseMove", "onNodeMouseLeave", "onNodeContextMenu", "connectionLineType", "connectionLineStyle", "connectionLineComponent", "connectionLineContainerStyle", "GraphView", "getInitialState", "defaultNodes", "defaultEdges", "fitView", "fitViewOptions", "parentLookup", "storeEdges", "storeNodes", "storeNodeOrigin", "storeNodeExtent", "updateConnectionLookup", "nodesInitialized", "adoptUserNodes", "initialConnection", "devWarn", "defaultAriaLabelConfig", "createStore", "createWithEqualityFn", "set", "get", "resolveFitView", "fitViewport", "elevateNodesOnSelect", "debug", "updatedInternals", "updateAbsolutePositions", "nodeDragItems", "parentExpandChildren", "dragItem", "expandParent", "parentExpandChanges", "handleExpandParent", "updatedNodes", "updatedEdges", "changedEdges", "nodesToUnselect", "edgesToUnselect", "clickDistance", "nextNodeExtent", "delta", "nextZoom", "ReactFlowProvider", "Wrapper", "wrapperStyle", "ReactFlow", "onNodeDragStart", "onNodeDrag", "onNodeDragStop", "onSelectionDragStart", "onSelectionDrag", "onSelectionDragStop", "isMacOs", "defaultViewport$1", "attributionPosition", "elevateEdgesOnSelect", "autoPanOnNodeDrag", "autoPanSpeed", "connectionDragThreshold", "onScroll", "colorModeClassName", "wrapperOnScroll", "error014", "errorMessages", "LinePattern", "dimensions", "lineWidth", "variant", "className", "cc", "DotPattern", "radius", "BackgroundVariant", "defaultSize", "selector$3", "s", "BackgroundComponent", "id", "gap", "size", "offset", "color", "bgColor", "style", "patternClassName", "ref", "transform", "patternId", "useStore", "shallow$1", "patternSize", "isDots", "isCross", "gapXY", "scaledGap", "scaledSize", "offsetXY", "patternDimensions", "scaledOffset", "_patternId", "containerStyle", "Background", "PlusIcon", "MinusIcon", "FitViewIcon", "LockIcon", "UnlockIcon", "ControlButton", "children", "rest", "selector$2", "ControlsComponent", "showZoom", "showFitView", "showInteractive", "fitViewOptions", "onZoomIn", "onZoomOut", "onFitView", "onInteractiveChange", "position", "orientation", "ariaLabel", "store", "useStoreApi", "isInteractive", "minZoomReached", "maxZoomReached", "ariaLabelConfig", "zoomIn", "zoomOut", "fitView", "useReactFlow", "onZoomInHandler", "onZoomOutHandler", "onFitViewHandler", "onToggleInteractivity", "Panel", "Controls", "MiniMapNodeComponent", "x", "y", "width", "height", "strokeColor", "strokeWidth", "borderRadius", "shapeRendering", "selected", "onClick", "background", "backgroundColor", "fill", "event", "MiniMapNode", "selectorNodeIds", "node", "getAttrFunction", "func", "MiniMapNodes", "nodeStrokeColor", "nodeColor", "nodeClassName", "nodeBorderRadius", "nodeStrokeWidth", "NodeComponent", "nodeIds", "nodeColorFunc", "nodeStrokeColorFunc", "nodeClassNameFunc", "nodeId", "NodeComponentWrapper", "NodeComponentWrapperInner", "internals", "getNodeDimensions", "nodeHasDimensions", "MiniMapNodes$1", "defaultWidth", "defaultHeight", "filterHidden", "selector$1", "viewBB", "getBoundsOfRects", "getInternalNodesBounds", "ARIA_LABEL_KEY", "MiniMapComponent", "nodeComponent", "maskColor", "maskStrokeColor", "maskStrokeWidth", "onNodeClick", "pannable", "zoomable", "inversePan", "zoomStep", "offsetScale", "_a", "_b", "svg", "boundingRect", "rfId", "panZoom", "translateExtent", "flowWidth", "flowHeight", "elementWidth", "elementHeight", "scaledWidth", "scaledHeight", "viewScale", "viewWidth", "viewHeight", "labelledBy", "viewScaleRef", "minimapInstance", "XYMinimap", "onSvgClick", "onSvgNodeClick", "_ariaLabel", "MiniMap", "scaleSelector", "calculateScale", "defaultPositions", "ResizeControlVariant", "ResizeControl", "minWidth", "minHeight", "maxWidth", "maxHeight", "keepAspectRatio", "resizeDirection", "autoScale", "shouldResize", "onResizeStart", "onResize", "onResizeEnd", "contextNodeId", "useNodeId", "resizeControlRef", "isHandleControl", "scale", "resizer", "controlPosition", "XYResizer", "nodeLookup", "snapGrid", "snapToGrid", "nodeOrigin", "domNode", "change", "childChanges", "_c", "_d", "_e", "_f", "_g", "triggerNodeChanges", "parentLookup", "changes", "nextPosition", "origin", "child", "evaluateAbsolutePosition", "parentExpandChanges", "handleExpandParent", "positionChange", "dimensionChange", "childChange", "positionClassNames", "NodeResizeControl", "Point", "_Point", "x", "y", "other", "dx", "dy", "precision", "factor", "gridSize", "Rectangle", "_Rectangle", "x", "y", "width", "height", "Point", "point", "box", "Line", "start", "end", "rect", "intersections", "edges", "Point", "edge", "intersection", "p1", "p2", "p3", "p4", "x1", "y1", "x2", "y2", "x3", "y3", "x4", "y4", "denom", "t", "u", "getGrid", "step", "source", "target", "Point", "snapToGrid", "value", "gridSize", "snapPointToGrid", "point", "grid", "source", "x", "y", "Point", "align", "precision", "round", "defaults", "directionMap", "Point", "DEFAULT_ADAPTIVE_STEP_CONFIG", "DEFAULT_PERFORMANCE_CONFIG", "DEFAULT_DEBUG_CONFIG", "normalizePadding", "padding", "normalizeAngle", "angle", "validateAndFixOptions", "options", "fixed", "defaults", "resolveAdaptiveStepConfig", "config", "_a", "_b", "_c", "_d", "_e", "_f", "_g", "_h", "_i", "_j", "_k", "_l", "_m", "DEFAULT_ADAPTIVE_STEP_CONFIG", "resolvePerformanceConfig", "resolveDebugConfig", "resolveOptions", "validatedOptions", "step", "maxLoopCount", "precision", "maxDirectionChange", "startDirections", "endDirections", "excludeNodes", "excludeShapes", "excludeTerminals", "borderRadius", "extensionDistance", "penalties", "fallbackRoute", "sides", "paddingBox", "cost", "directions", "direction", "point1", "Point", "point2", "adaptiveStep", "performance", "debug", "directionMap", "fixAngleEnd", "start", "end", "grid", "options", "step", "diffX", "diffY", "gridStepsX", "gridStepsY", "distanceX", "distanceY", "Point", "getDirectionAngle", "directionCount", "quadrant", "angleTheta", "normalizedAngle", "normalizeAngle", "getDirectionChange", "angle1", "angle2", "change", "getGridOffsets", "direction", "isPointOnRectangleEdge", "point", "bbox", "tolerance", "onLeft", "onRight", "onTop", "onBottom", "withinVerticalBounds", "withinHorizontalBounds", "isDirectionOutward", "anchor", "direction", "getRectPoints", "directionList", "grid", "options", "precision", "directionMap", "centerVector", "rectPoints", "isOnEdge", "key", "extensionPoint", "Point", "target", "align", "ending", "intersections", "Line", "farthestIntersectionDistance", "farthestIntersection", "intersection", "distance", "normalizePoint", "point", "Point", "getKey", "getCost", "from", "anchors", "min", "anchor", "dist", "reconstructRoute", "parents", "points", "tailPoint", "startPoint", "endPoint", "route", "prevDiff", "currentKey", "parent", "iterationCount", "maxIterations", "diff", "nextKey", "leadPoint", "getNodeDimensions", "node", "_a", "_b", "_c", "_d", "_e", "_f", "_g", "_h", "width", "height", "getNodePosition", "getNodeBBox", "nodeId", "nodeLookup", "node", "dimensions", "getNodeDimensions", "position", "getNodePosition", "Rectangle", "findSegmentRectIntersections", "p1", "p2", "rect", "intersections", "edges", "Point", "edge", "intersection", "getLineSegmentIntersection", "existing", "p3", "p4", "d1", "direction", "d2", "d3", "d4", "t", "onSegment", "pathIntersectsObstacles", "pathPoints", "nodeBBox", "allIntersections", "i", "segmentIntersections", "PathfindingError", "type", "message", "details", "DEFAULT_RECOVERY_CONFIG", "ErrorRecovery", "config", "from", "to", "error", "obstacles", "startTime", "strategy", "path", "corner1", "Point", "path1", "corner2", "path2", "midX", "midY", "offsets", "offset", "i", "p1", "p2", "obstacle", "rect", "minX", "maxX", "minY", "maxY", "p", "p3", "p4", "d1", "d2", "d3", "d4", "iterations", "maxIterations", "PathfindingError", "message", "point", "type", "cause", "source", "target", "options", "defaults", "fixed", "key", "value", "defaultValue", "DEFAULT_CONFIG", "QuadTree", "_QuadTree", "bounds", "config", "depth", "item", "data", "results", "point", "child", "count", "maxChildDepth", "halfWidth", "halfHeight", "x", "y", "nextDepth", "Rectangle", "itemsToRedistribute", "inserted", "rect", "a", "b", "stats", "createQuadTreeFromRects", "items", "minX", "minY", "maxX", "maxY", "padding", "tree", "ObstacleMap", "options", "total", "nodeLookup", "sourceNodeId", "targetNodeId", "sourceAnchor", "targetAnchor", "excludeNodes", "excludeShapes", "excludeTerminals", "paddingBox", "node", "isExcludedNode", "isExcludedShape", "isSourceTerminal", "isTargetTerminal", "position", "getNodePosition", "dimensions", "getNodeDimensions", "bbox", "Rectangle", "createQuadTreeFromRects", "o", "point", "checkRadius", "cacheKey", "margin", "obstacles", "result", "accessible", "anchor", "direction", "step", "clearanceDistance", "dir", "dist", "testPoint", "Point", "originalSourceAnchor", "originalTargetAnchor", "maxDistance", "foundDistance", "left", "right", "bestDistance", "mid", "points", "maxRadius", "rects", "rect", "radius", "offsets", "offset", "SortedSet", "item", "value", "index", "low", "high", "mid", "generateSmartPoints", "anchor", "bbox", "position", "grid", "map", "options", "isTarget", "direction", "actualDirection", "points", "extensionPoint", "Point", "stepMultiplier", "maxSteps", "foundAccessibleDistance", "distance", "testPoint", "outerDistance", "left", "right", "bestDistance", "binarySearchIterations", "maxBinarySearchIterations", "mid", "finalPoint", "findRoute", "sourceBBox", "targetBBox", "sourceAnchor", "targetAnchor", "_a", "precision", "sourceEndpoint", "round", "targetEndpoint", "getGrid", "ErrorRecovery", "startPoint", "endPoint", "startPoints", "endPoints", "getRectPoints", "p", "openSet", "SortedSet", "parents", "costs", "key", "getKey", "getCost", "previousRouteDirectionAngle", "isPathBeginning", "directions", "getGridOffsets", "numDirections", "endPointsKeys", "sameStartEndPoints", "sp", "i", "optimalCostEstimate", "earlyTerminationThreshold", "bestPathFound", "bestPathCost", "maxIterations", "iterationCount", "loopStartTime", "elapsed", "currentKey", "currentPoint", "currentParent", "currentCost", "isStartPoint", "isRouteBeginning", "previousDirectionAngle", "getDirectionAngle", "route", "reconstructRoute", "directionAngle", "directionChange", "getDirectionChange", "rawNeighbor", "neighborPoint", "neighborKey", "canReachEndPoint", "reachableEndPoint", "endPt", "dx", "dy", "endKey", "endCost", "totalCost", "endDirectionAngle", "neighborCost", "neighborPenalty", "costFromStart", "isCorner", "prev", "current", "next", "dx1", "dy1", "dx2", "dy2", "isHorizontal1", "isVertical1", "isHorizontal2", "isVertical2", "calculateOptimalRadius", "maxRadius", "dist1", "dist2", "pointsToPath", "points", "precision", "borderRadius", "factor", "roundCoord", "value", "firstPoint", "path", "i", "point", "radius", "ndx1", "ndy1", "ndx2", "ndy2", "beforeCorner", "afterCorner", "lastPoint", "parseSVGPath", "pathString", "points", "commands", "command", "type", "coords", "Point", "prevPoint", "cx", "cy", "x", "y", "t", "bx", "by", "getManHattanPath", "params", "sourceNodeId", "targetNodeId", "sourcePosition", "targetPosition", "nodeLookup", "sourceX", "sourceY", "targetX", "targetY", "userOptions", "options", "resolveOptions", "sourceNode", "targetNode", "start", "Point", "end", "fallbackPath", "ErrorRecovery", "pointsToPath", "sourceDimensions", "getNodeDimensions", "targetDimensions", "sourcePos", "getNodePosition", "targetPos", "sourceBBox", "Rectangle", "targetBBox", "sourceAnchor", "targetAnchor", "smoothStepPath", "getSmoothStepPath", "smoothStepPoints", "parseSVGPath", "pathIntersectsObstacles", "obstacleMap", "ObstacleMap", "route", "findRoute", "isSourceHorizontal", "Position", "isTargetHorizontal", "sourceExtensionX", "targetExtensionX", "horizontalSegmentStart", "horizontalSegmentEnd", "i", "curr", "next", "point", "optimized", "prev", "prevPrev", "sameX", "sameY", "finalRoute", "step", "tolerance", "firstPoint", "onLeft", "onRight", "onTop", "onBottom", "lastPoint", "extensionDistance", "extendX", "extensionPoint", "extendY", "thirdRoutePoint", "secondRoutePoint", "fourthPoint", "cornerToThird", "thirdToFourth", "targetBBoxWithPadding", "p1", "p2", "p3", "p2OnTargetLeftEdge", "p2OnTargetRightEdge", "p2OnTargetTopEdge", "p2OnTargetBottomEdge", "p1ToP2Horizontal", "p2ToP3Vertical", "p1ToP2Vertical", "p2ToP3Horizontal", "lastIdx", "secondLastPoint", "thirdLastPoint", "fourthLastPoint", "fourthToThird", "thirdToSecond", "p4", "manhattanWorker", "params", "getManHattanPath", "paramsArray", "path", "error", "expose"]
|
|
7
|
+
}
|