likec4 1.55.1 → 1.57.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.
Files changed (244) hide show
  1. package/__app__/chunks/AIChat2.mjs +2 -0
  2. package/__app__/chunks/DiagramActorProvider.mjs +10 -0
  3. package/__app__/chunks/EmbedPage.mjs +1 -0
  4. package/__app__/chunks/ExportPage.mjs +2 -0
  5. package/__app__/chunks/LikeC4Diagram.mjs +19 -0
  6. package/__app__/chunks/LikeC4Styles.mjs +48 -0
  7. package/__app__/chunks/Markdown.mjs +1 -0
  8. package/__app__/chunks/NavigationPanel.mjs +1 -0
  9. package/__app__/chunks/ViewReact.mjs +1 -0
  10. package/__app__/chunks/adhoc-editor.mjs +1 -0
  11. package/__app__/chunks/aichat.mjs +1 -0
  12. package/__app__/chunks/box.mjs +1 -0
  13. package/__app__/chunks/create-style-context.mjs +1 -0
  14. package/__app__/chunks/css.mjs +1 -0
  15. package/__app__/chunks/factory.mjs +1 -0
  16. package/__app__/chunks/hooks.mjs +1 -0
  17. package/__app__/chunks/hstack.mjs +1 -0
  18. package/__app__/chunks/libs/@dagrejs/dagre.mjs +1 -0
  19. package/__app__/chunks/libs/@floating-ui/core.mjs +1 -0
  20. package/__app__/chunks/libs/@floating-ui/dom.mjs +1 -0
  21. package/__app__/chunks/libs/@floating-ui/react.mjs +1 -0
  22. package/__app__/chunks/libs/@mantine/core.mjs +41 -0
  23. package/__app__/chunks/libs/@mantine/hooks.mjs +1 -0
  24. package/__app__/chunks/libs/@nanostores/react.mjs +1 -0
  25. package/__app__/chunks/libs/@react-hookz/web.mjs +1 -0
  26. package/__app__/chunks/libs/@tabler/icons-react.mjs +358 -0
  27. package/__app__/chunks/libs/@tanstack/ai-client.mjs +2 -0
  28. package/__app__/chunks/libs/@tanstack/ai-react-ui.mjs +1 -0
  29. package/__app__/chunks/libs/@tanstack/ai-react.mjs +1 -0
  30. package/__app__/chunks/libs/@tanstack/ai.mjs +2 -0
  31. package/__app__/chunks/libs/@tanstack/history.mjs +1 -0
  32. package/__app__/chunks/libs/@tanstack/react-router.mjs +3 -0
  33. package/__app__/chunks/libs/@tanstack/router-core.mjs +1 -0
  34. package/__app__/chunks/libs/@xstate/react.mjs +1 -0
  35. package/__app__/chunks/libs/@xstate/store.mjs +1 -0
  36. package/__app__/chunks/libs/@xyflow/react.mjs +7 -0
  37. package/__app__/chunks/libs/@zag-js/anatomy.mjs +1 -0
  38. package/__app__/chunks/libs/@zag-js/collection.mjs +1 -0
  39. package/__app__/chunks/libs/@zag-js/core.mjs +1 -0
  40. package/__app__/chunks/libs/@zag-js/react.mjs +1 -0
  41. package/__app__/chunks/libs/@zag-js/tree-view.mjs +1 -0
  42. package/__app__/chunks/libs/bezier-js.mjs +1 -0
  43. package/__app__/chunks/libs/copy-anything.mjs +1 -0
  44. package/__app__/chunks/libs/d3-path.mjs +1 -0
  45. package/__app__/chunks/libs/d3-shape.mjs +1 -0
  46. package/__app__/chunks/libs/fast-equals.mjs +1 -0
  47. package/__app__/chunks/libs/framer-motion.mjs +9 -0
  48. package/__app__/chunks/libs/html-to-image.mjs +2 -0
  49. package/__app__/chunks/libs/motion-dom.mjs +1 -0
  50. package/__app__/chunks/libs/nanostores.mjs +1 -0
  51. package/__app__/chunks/libs/react-error-boundary.mjs +1 -0
  52. package/__app__/chunks/libs/react-resizable-panels.mjs +1 -0
  53. package/__app__/chunks/libs/remeda.mjs +1 -0
  54. package/__app__/chunks/libs/superjson.mjs +1 -0
  55. package/__app__/chunks/libs/zod.mjs +64 -0
  56. package/__app__/chunks/rolldown-runtime.mjs +1 -0
  57. package/__app__/chunks/styles.css.mjs +1 -0
  58. package/__app__/chunks/txt.mjs +1 -0
  59. package/__app__/chunks/useLikeC4Project.mjs +1 -0
  60. package/__app__/codegen/react.mjs +11 -0
  61. package/__app__/codegen/webcomponent.mjs +942 -0
  62. package/__app__/src/aichat/index.mjs +1 -0
  63. package/__app__/src/fonts.css +1 -1
  64. package/__app__/src/main.mjs +45 -0
  65. package/__app__/src/pages/AdHocViewEditor.mjs +1 -0
  66. package/__app__/src/pages/EmbedPage.mjs +1 -0
  67. package/__app__/src/pages/ExportPage.mjs +1 -0
  68. package/__app__/src/pages/ProjectsOverview.mjs +1 -0
  69. package/__app__/src/pages/ViewAsD2.mjs +1 -0
  70. package/__app__/src/pages/ViewAsDot.mjs +1 -0
  71. package/__app__/src/pages/ViewAsMmd.mjs +1 -0
  72. package/__app__/src/pages/ViewAsPuml.mjs +1 -0
  73. package/__app__/src/pages/ViewEditor.mjs +1 -0
  74. package/__app__/src/pages/ViewReact.mjs +1 -0
  75. package/__app__/src/style.css +1 -1
  76. package/config/schema.json +14 -41
  77. package/dist/chunks/enableServer.mjs +1 -0
  78. package/dist/chunks/filenames.mjs +17 -0
  79. package/dist/{_chunks → chunks}/index.d.mts +2 -1
  80. package/dist/{_chunks → chunks}/index2.d.mts +639 -388
  81. package/dist/chunks/libs/@chevrotain/gast.mjs +1 -0
  82. package/dist/chunks/libs/@chevrotain/regexp-to-ast.mjs +9 -0
  83. package/dist/chunks/libs/@chevrotain/utils.mjs +1 -0
  84. package/dist/chunks/libs/@hono/mcp.mjs +70 -0
  85. package/dist/chunks/libs/@hono/node-server.mjs +1 -0
  86. package/dist/{_chunks → chunks}/libs/@logtape/logtape.d.mts +2 -0
  87. package/dist/chunks/libs/@logtape/logtape.mjs +4 -0
  88. package/dist/chunks/libs/@lume/kiwi.mjs +1 -0
  89. package/dist/chunks/libs/@modelcontextprotocol/sdk.mjs +12 -0
  90. package/dist/chunks/libs/@ts-graphviz/ast.mjs +3 -0
  91. package/dist/chunks/libs/@ts-graphviz/common.d.mts +9 -0
  92. package/dist/chunks/libs/@ts-graphviz/core.mjs +1 -0
  93. package/dist/chunks/libs/ajv.mjs +1 -0
  94. package/dist/chunks/libs/ansi-align.mjs +2 -0
  95. package/dist/chunks/libs/ansi-regex.mjs +1 -0
  96. package/dist/chunks/libs/ansi-styles.mjs +1 -0
  97. package/dist/chunks/libs/atomically.mjs +1 -0
  98. package/dist/chunks/libs/birpc.mjs +1 -0
  99. package/dist/chunks/libs/boxen.mjs +22 -0
  100. package/dist/chunks/libs/chevrotain-allstar.mjs +2 -0
  101. package/dist/chunks/libs/chevrotain.mjs +58 -0
  102. package/dist/chunks/libs/conf.mjs +1 -0
  103. package/dist/chunks/libs/defu.mjs +1 -0
  104. package/dist/chunks/libs/destr.mjs +1 -0
  105. package/dist/chunks/libs/eventemitter3.mjs +1 -0
  106. package/dist/chunks/libs/find-up-simple.mjs +1 -0
  107. package/dist/chunks/libs/get-port.mjs +1 -0
  108. package/dist/chunks/libs/hono.mjs +1 -0
  109. package/dist/chunks/libs/is-docker.mjs +1 -0
  110. package/dist/chunks/libs/is-error-instance.mjs +1 -0
  111. package/dist/chunks/libs/is-inside-container.mjs +1 -0
  112. package/dist/chunks/libs/is-plain-obj.mjs +1 -0
  113. package/dist/chunks/libs/isexe.mjs +1 -0
  114. package/dist/chunks/libs/json5.mjs +14 -0
  115. package/dist/chunks/libs/khroma.mjs +1 -0
  116. package/dist/chunks/libs/ky.mjs +3 -0
  117. package/dist/{_chunks → chunks}/libs/langium.d.mts +9 -9
  118. package/dist/chunks/libs/langium.mjs +32 -0
  119. package/dist/chunks/libs/merge-error-cause.mjs +2 -0
  120. package/dist/chunks/libs/p-debounce.mjs +1 -0
  121. package/dist/chunks/libs/p-limit.mjs +1 -0
  122. package/dist/chunks/libs/p-queue.mjs +1 -0
  123. package/dist/chunks/libs/p-timeout.mjs +1 -0
  124. package/dist/chunks/libs/package-manager-detector.mjs +1 -0
  125. package/dist/chunks/libs/package-up.mjs +1 -0
  126. package/dist/chunks/libs/pako.mjs +3 -0
  127. package/dist/chunks/libs/parse-ms.mjs +1 -0
  128. package/dist/chunks/libs/pathe.mjs +1 -0
  129. package/dist/chunks/libs/picomatch.mjs +1 -0
  130. package/dist/chunks/libs/pretty-ms.mjs +1 -0
  131. package/dist/chunks/libs/remeda.mjs +1 -0
  132. package/dist/chunks/libs/safe-stringify.mjs +1 -0
  133. package/dist/chunks/libs/strip-indent.mjs +1 -0
  134. package/dist/chunks/libs/tinyrainbow.mjs +1 -0
  135. package/dist/chunks/libs/ts-graphviz.mjs +1 -0
  136. package/dist/chunks/libs/ufo.mjs +1 -0
  137. package/dist/chunks/libs/unctx.mjs +1 -0
  138. package/dist/chunks/libs/unstorage.mjs +1 -0
  139. package/dist/chunks/libs/vscode-languageserver.mjs +1 -0
  140. package/dist/chunks/libs/which.mjs +1 -0
  141. package/dist/chunks/libs/word-wrap.mjs +12 -0
  142. package/dist/{_chunks → chunks}/libs/zod.d.mts +62 -25
  143. package/dist/chunks/node.mjs +93 -0
  144. package/dist/chunks/plugin.mjs +593 -0
  145. package/dist/chunks/rolldown-runtime.mjs +1 -0
  146. package/dist/chunks/sequence-view.mjs +1 -0
  147. package/dist/cli/index.mjs +188 -59
  148. package/dist/config/index.d.mts +1 -2
  149. package/dist/config/index.mjs +1 -1
  150. package/dist/index.d.mts +2 -135
  151. package/dist/index.mjs +1 -1
  152. package/dist/model/index.d.mts +3 -2
  153. package/dist/model/index.mjs +1 -1
  154. package/dist/vite-plugin/index.d.mts +90 -9
  155. package/dist/vite-plugin/index.mjs +1 -1
  156. package/dist/vite-plugin/internal/chunks/libs/@nanostores/react.mjs +1 -0
  157. package/dist/vite-plugin/internal/chunks/libs/birpc.mjs +1 -0
  158. package/dist/vite-plugin/internal/chunks/libs/fast-equals.mjs +1 -0
  159. package/dist/vite-plugin/internal/chunks/libs/nanostores.mjs +1 -0
  160. package/dist/vite-plugin/internal/chunks/libs/remeda.mjs +1 -0
  161. package/dist/vite-plugin/internal/chunks/rolldown-runtime.mjs +1 -0
  162. package/dist/{_chunks/libs/@nanostores/react.d.mts → vite-plugin/internal/index.d.mts} +103 -45
  163. package/dist/vite-plugin/internal/index.mjs +1 -0
  164. package/package.json +74 -80
  165. package/react/index.d.mts +84 -78
  166. package/react/index.mjs +51954 -53701
  167. package/vite-plugin/internal/package.json +2 -2
  168. package/vite-plugin-modules.d.ts +18 -0
  169. package/__app__/react/likec4.tsx +0 -25
  170. package/__app__/src/ProjectsOverview.js +0 -16
  171. package/__app__/src/const.js +0 -19
  172. package/__app__/src/likec4.js +0 -21254
  173. package/__app__/src/main.js +0 -7
  174. package/__app__/src/routes/index.js +0 -324
  175. package/__app__/src/routes/projects.js +0 -193
  176. package/__app__/src/routes/single.js +0 -1983
  177. package/__app__/src/vendors.js +0 -52683
  178. package/__app__/src/webcomponent.js +0 -68
  179. package/dist/THIRD-PARTY-LICENSES.md +0 -1609
  180. package/dist/_chunks/libs/@chevrotain/cst-dts-gen.mjs +0 -30
  181. package/dist/_chunks/libs/@chevrotain/regexp-to-ast.mjs +0 -9
  182. package/dist/_chunks/libs/@chevrotain/types.d.mts +0 -1
  183. package/dist/_chunks/libs/@chevrotain/utils.mjs +0 -1
  184. package/dist/_chunks/libs/@hono/mcp.mjs +0 -45
  185. package/dist/_chunks/libs/@hono/node-server.mjs +0 -1
  186. package/dist/_chunks/libs/@logtape/logtape.mjs +0 -4
  187. package/dist/_chunks/libs/@lume/kiwi.mjs +0 -1
  188. package/dist/_chunks/libs/@modelcontextprotocol/sdk.mjs +0 -12
  189. package/dist/_chunks/libs/@nanostores/react.mjs +0 -1
  190. package/dist/_chunks/libs/ajv.mjs +0 -1
  191. package/dist/_chunks/libs/ansi-align.mjs +0 -2
  192. package/dist/_chunks/libs/ansi-regex.mjs +0 -1
  193. package/dist/_chunks/libs/ansi-styles.mjs +0 -1
  194. package/dist/_chunks/libs/atomically.mjs +0 -1
  195. package/dist/_chunks/libs/birpc.mjs +0 -1
  196. package/dist/_chunks/libs/boxen.mjs +0 -22
  197. package/dist/_chunks/libs/chevrotain-allstar.mjs +0 -2
  198. package/dist/_chunks/libs/chevrotain.mjs +0 -58
  199. package/dist/_chunks/libs/conf.mjs +0 -1
  200. package/dist/_chunks/libs/defu.mjs +0 -1
  201. package/dist/_chunks/libs/destr.mjs +0 -1
  202. package/dist/_chunks/libs/esm-env.mjs +0 -1
  203. package/dist/_chunks/libs/eventemitter3.mjs +0 -1
  204. package/dist/_chunks/libs/fast-equals.mjs +0 -1
  205. package/dist/_chunks/libs/find-up-simple.mjs +0 -1
  206. package/dist/_chunks/libs/get-port.mjs +0 -1
  207. package/dist/_chunks/libs/is-docker.mjs +0 -1
  208. package/dist/_chunks/libs/is-error-instance.mjs +0 -1
  209. package/dist/_chunks/libs/is-inside-container.mjs +0 -1
  210. package/dist/_chunks/libs/is-plain-obj.mjs +0 -1
  211. package/dist/_chunks/libs/isexe.mjs +0 -1
  212. package/dist/_chunks/libs/json5.mjs +0 -14
  213. package/dist/_chunks/libs/khroma.mjs +0 -1
  214. package/dist/_chunks/libs/ky.mjs +0 -3
  215. package/dist/_chunks/libs/langium.mjs +0 -33
  216. package/dist/_chunks/libs/merge-error-cause.mjs +0 -2
  217. package/dist/_chunks/libs/p-limit.mjs +0 -1
  218. package/dist/_chunks/libs/p-queue.mjs +0 -1
  219. package/dist/_chunks/libs/p-timeout.mjs +0 -1
  220. package/dist/_chunks/libs/package-manager-detector.mjs +0 -1
  221. package/dist/_chunks/libs/package-up.mjs +0 -1
  222. package/dist/_chunks/libs/pako.mjs +0 -1
  223. package/dist/_chunks/libs/parse-ms.mjs +0 -1
  224. package/dist/_chunks/libs/pathe.mjs +0 -1
  225. package/dist/_chunks/libs/picomatch.mjs +0 -1
  226. package/dist/_chunks/libs/pretty-ms.mjs +0 -1
  227. package/dist/_chunks/libs/remeda.mjs +0 -2
  228. package/dist/_chunks/libs/safe-stringify.mjs +0 -1
  229. package/dist/_chunks/libs/strip-indent.mjs +0 -1
  230. package/dist/_chunks/libs/tinyrainbow.mjs +0 -1
  231. package/dist/_chunks/libs/ts-graphviz.d.mts +0 -10
  232. package/dist/_chunks/libs/ts-graphviz.mjs +0 -4
  233. package/dist/_chunks/libs/ufo.mjs +0 -1
  234. package/dist/_chunks/libs/unstorage.mjs +0 -1
  235. package/dist/_chunks/libs/vscode-languageserver.mjs +0 -1
  236. package/dist/_chunks/libs/which.mjs +0 -1
  237. package/dist/_chunks/libs/word-wrap.mjs +0 -12
  238. package/dist/_chunks/node.mjs +0 -76
  239. package/dist/_chunks/rolldown-runtime.mjs +0 -1
  240. package/dist/_chunks/sequence.mjs +0 -1
  241. package/dist/_chunks/src.mjs +0 -17
  242. package/dist/_chunks/src2.mjs +0 -499
  243. package/dist/vite-plugin/internal.d.mts +0 -44
  244. package/dist/vite-plugin/internal.mjs +0 -1
@@ -0,0 +1,7 @@
1
+ import e,{createContext as t,forwardRef as n,memo as r,useCallback as i,useContext as a,useEffect as o,useLayoutEffect as s,useMemo as c,useRef as l,useState as u}from"react";import{Fragment as d,jsx as f,jsxs as p}from"react/jsx-runtime";import m from"use-sync-external-store/shim/with-selector.js";import{createPortal as h}from"react-dom";function g(e){if(typeof e==`string`||typeof e==`number`)return``+e;let t=``;if(Array.isArray(e))for(let n=0,r;n<e.length;n++)(r=g(e[n]))!==``&&(t+=(t&&` `)+r);else for(let n in e)e[n]&&(t+=(t&&` `)+n);return t}var _={value:()=>{}};function v(){for(var e=0,t=arguments.length,n={},r;e<t;++e){if(!(r=arguments[e]+``)||r in n||/[\s.]/.test(r))throw Error(`illegal type: `+r);n[r]=[]}return new y(n)}function y(e){this._=e}function b(e,t){return e.trim().split(/^|\s+/).map(function(e){var n=``,r=e.indexOf(`.`);if(r>=0&&(n=e.slice(r+1),e=e.slice(0,r)),e&&!t.hasOwnProperty(e))throw Error(`unknown type: `+e);return{type:e,name:n}})}y.prototype=v.prototype={constructor:y,on:function(e,t){var n=this._,r=b(e+``,n),i,a=-1,o=r.length;if(arguments.length<2){for(;++a<o;)if((i=(e=r[a]).type)&&(i=x(n[i],e.name)))return i;return}if(t!=null&&typeof t!=`function`)throw Error(`invalid callback: `+t);for(;++a<o;)if(i=(e=r[a]).type)n[i]=S(n[i],e.name,t);else if(t==null)for(i in n)n[i]=S(n[i],e.name,null);return this},copy:function(){var e={},t=this._;for(var n in t)e[n]=t[n].slice();return new y(e)},call:function(e,t){if((i=arguments.length-2)>0)for(var n=Array(i),r=0,i,a;r<i;++r)n[r]=arguments[r+2];if(!this._.hasOwnProperty(e))throw Error(`unknown type: `+e);for(a=this._[e],r=0,i=a.length;r<i;++r)a[r].value.apply(t,n)},apply:function(e,t,n){if(!this._.hasOwnProperty(e))throw Error(`unknown type: `+e);for(var r=this._[e],i=0,a=r.length;i<a;++i)r[i].value.apply(t,n)}};function x(e,t){for(var n=0,r=e.length,i;n<r;++n)if((i=e[n]).name===t)return i.value}function S(e,t,n){for(var r=0,i=e.length;r<i;++r)if(e[r].name===t){e[r]=_,e=e.slice(0,r).concat(e.slice(r+1));break}return n!=null&&e.push({name:t,value:n}),e}var C={svg:`http://www.w3.org/2000/svg`,xhtml:`http://www.w3.org/1999/xhtml`,xlink:`http://www.w3.org/1999/xlink`,xml:`http://www.w3.org/XML/1998/namespace`,xmlns:`http://www.w3.org/2000/xmlns/`};function w(e){var t=e+=``,n=t.indexOf(`:`);return n>=0&&(t=e.slice(0,n))!==`xmlns`&&(e=e.slice(n+1)),C.hasOwnProperty(t)?{space:C[t],local:e}:e}function T(e){return function(){var t=this.ownerDocument,n=this.namespaceURI;return n===`http://www.w3.org/1999/xhtml`&&t.documentElement.namespaceURI===`http://www.w3.org/1999/xhtml`?t.createElement(e):t.createElementNS(n,e)}}function E(e){return function(){return this.ownerDocument.createElementNS(e.space,e.local)}}function D(e){var t=w(e);return(t.local?E:T)(t)}function O(){}function k(e){return e==null?O:function(){return this.querySelector(e)}}function A(e){typeof e!=`function`&&(e=k(e));for(var t=this._groups,n=t.length,r=Array(n),i=0;i<n;++i)for(var a=t[i],o=a.length,s=r[i]=Array(o),c,l,u=0;u<o;++u)(c=a[u])&&(l=e.call(c,c.__data__,u,a))&&(`__data__`in c&&(l.__data__=c.__data__),s[u]=l);return new G(r,this._parents)}function j(e){return e==null?[]:Array.isArray(e)?e:Array.from(e)}function M(){return[]}function N(e){return e==null?M:function(){return this.querySelectorAll(e)}}function P(e){return function(){return j(e.apply(this,arguments))}}function F(e){e=typeof e==`function`?P(e):N(e);for(var t=this._groups,n=t.length,r=[],i=[],a=0;a<n;++a)for(var o=t[a],s=o.length,c,l=0;l<s;++l)(c=o[l])&&(r.push(e.call(c,c.__data__,l,o)),i.push(c));return new G(r,i)}function I(e){return function(){return this.matches(e)}}function L(e){return function(t){return t.matches(e)}}var R=Array.prototype.find;function ee(e){return function(){return R.call(this.children,e)}}function z(){return this.firstElementChild}function B(e){return this.select(e==null?z:ee(typeof e==`function`?e:L(e)))}var V=Array.prototype.filter;function H(){return Array.from(this.children)}function U(e){return function(){return V.call(this.children,e)}}function W(e){return this.selectAll(e==null?H:U(typeof e==`function`?e:L(e)))}function te(e){typeof e!=`function`&&(e=I(e));for(var t=this._groups,n=t.length,r=Array(n),i=0;i<n;++i)for(var a=t[i],o=a.length,s=r[i]=[],c,l=0;l<o;++l)(c=a[l])&&e.call(c,c.__data__,l,a)&&s.push(c);return new G(r,this._parents)}function ne(e){return Array(e.length)}function re(){return new G(this._enter||this._groups.map(ne),this._parents)}function ie(e,t){this.ownerDocument=e.ownerDocument,this.namespaceURI=e.namespaceURI,this._next=null,this._parent=e,this.__data__=t}ie.prototype={constructor:ie,appendChild:function(e){return this._parent.insertBefore(e,this._next)},insertBefore:function(e,t){return this._parent.insertBefore(e,t)},querySelector:function(e){return this._parent.querySelector(e)},querySelectorAll:function(e){return this._parent.querySelectorAll(e)}};function ae(e){return function(){return e}}function oe(e,t,n,r,i,a){for(var o=0,s,c=t.length,l=a.length;o<l;++o)(s=t[o])?(s.__data__=a[o],r[o]=s):n[o]=new ie(e,a[o]);for(;o<c;++o)(s=t[o])&&(i[o]=s)}function se(e,t,n,r,i,a,o){var s,c,l=new Map,u=t.length,d=a.length,f=Array(u),p;for(s=0;s<u;++s)(c=t[s])&&(f[s]=p=o.call(c,c.__data__,s,t)+``,l.has(p)?i[s]=c:l.set(p,c));for(s=0;s<d;++s)p=o.call(e,a[s],s,a)+``,(c=l.get(p))?(r[s]=c,c.__data__=a[s],l.delete(p)):n[s]=new ie(e,a[s]);for(s=0;s<u;++s)(c=t[s])&&l.get(f[s])===c&&(i[s]=c)}function ce(e){return e.__data__}function le(e,t){if(!arguments.length)return Array.from(this,ce);var n=t?se:oe,r=this._parents,i=this._groups;typeof e!=`function`&&(e=ae(e));for(var a=i.length,o=Array(a),s=Array(a),c=Array(a),l=0;l<a;++l){var u=r[l],d=i[l],f=d.length,p=ue(e.call(u,u&&u.__data__,l,r)),m=p.length,h=s[l]=Array(m),g=o[l]=Array(m);n(u,d,h,g,c[l]=Array(f),p,t);for(var _=0,v=0,y,b;_<m;++_)if(y=h[_]){for(_>=v&&(v=_+1);!(b=g[v])&&++v<m;);y._next=b||null}}return o=new G(o,r),o._enter=s,o._exit=c,o}function ue(e){return typeof e==`object`&&`length`in e?e:Array.from(e)}function de(){return new G(this._exit||this._groups.map(ne),this._parents)}function fe(e,t,n){var r=this.enter(),i=this,a=this.exit();return typeof e==`function`?(r=e(r),r&&=r.selection()):r=r.append(e+``),t!=null&&(i=t(i),i&&=i.selection()),n==null?a.remove():n(a),r&&i?r.merge(i).order():i}function pe(e){for(var t=e.selection?e.selection():e,n=this._groups,r=t._groups,i=n.length,a=r.length,o=Math.min(i,a),s=Array(i),c=0;c<o;++c)for(var l=n[c],u=r[c],d=l.length,f=s[c]=Array(d),p,m=0;m<d;++m)(p=l[m]||u[m])&&(f[m]=p);for(;c<i;++c)s[c]=n[c];return new G(s,this._parents)}function me(){for(var e=this._groups,t=-1,n=e.length;++t<n;)for(var r=e[t],i=r.length-1,a=r[i],o;--i>=0;)(o=r[i])&&(a&&o.compareDocumentPosition(a)^4&&a.parentNode.insertBefore(o,a),a=o);return this}function he(e){e||=ge;function t(t,n){return t&&n?e(t.__data__,n.__data__):!t-!n}for(var n=this._groups,r=n.length,i=Array(r),a=0;a<r;++a){for(var o=n[a],s=o.length,c=i[a]=Array(s),l,u=0;u<s;++u)(l=o[u])&&(c[u]=l);c.sort(t)}return new G(i,this._parents).order()}function ge(e,t){return e<t?-1:e>t?1:e>=t?0:NaN}function _e(){var e=arguments[0];return arguments[0]=this,e.apply(null,arguments),this}function ve(){return Array.from(this)}function ye(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var r=e[t],i=0,a=r.length;i<a;++i){var o=r[i];if(o)return o}return null}function be(){let e=0;for(let t of this)++e;return e}function xe(){return!this.node()}function Se(e){for(var t=this._groups,n=0,r=t.length;n<r;++n)for(var i=t[n],a=0,o=i.length,s;a<o;++a)(s=i[a])&&e.call(s,s.__data__,a,i);return this}function Ce(e){return function(){this.removeAttribute(e)}}function we(e){return function(){this.removeAttributeNS(e.space,e.local)}}function Te(e,t){return function(){this.setAttribute(e,t)}}function Ee(e,t){return function(){this.setAttributeNS(e.space,e.local,t)}}function De(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttribute(e):this.setAttribute(e,n)}}function Oe(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttributeNS(e.space,e.local):this.setAttributeNS(e.space,e.local,n)}}function ke(e,t){var n=w(e);if(arguments.length<2){var r=this.node();return n.local?r.getAttributeNS(n.space,n.local):r.getAttribute(n)}return this.each((t==null?n.local?we:Ce:typeof t==`function`?n.local?Oe:De:n.local?Ee:Te)(n,t))}function Ae(e){return e.ownerDocument&&e.ownerDocument.defaultView||e.document&&e||e.defaultView}function je(e){return function(){this.style.removeProperty(e)}}function Me(e,t,n){return function(){this.style.setProperty(e,t,n)}}function Ne(e,t,n){return function(){var r=t.apply(this,arguments);r==null?this.style.removeProperty(e):this.style.setProperty(e,r,n)}}function Pe(e,t,n){return arguments.length>1?this.each((t==null?je:typeof t==`function`?Ne:Me)(e,t,n??``)):Fe(this.node(),e)}function Fe(e,t){return e.style.getPropertyValue(t)||Ae(e).getComputedStyle(e,null).getPropertyValue(t)}function Ie(e){return function(){delete this[e]}}function Le(e,t){return function(){this[e]=t}}function Re(e,t){return function(){var n=t.apply(this,arguments);n==null?delete this[e]:this[e]=n}}function ze(e,t){return arguments.length>1?this.each((t==null?Ie:typeof t==`function`?Re:Le)(e,t)):this.node()[e]}function Be(e){return e.trim().split(/^|\s+/)}function Ve(e){return e.classList||new He(e)}function He(e){this._node=e,this._names=Be(e.getAttribute(`class`)||``)}He.prototype={add:function(e){this._names.indexOf(e)<0&&(this._names.push(e),this._node.setAttribute(`class`,this._names.join(` `)))},remove:function(e){var t=this._names.indexOf(e);t>=0&&(this._names.splice(t,1),this._node.setAttribute(`class`,this._names.join(` `)))},contains:function(e){return this._names.indexOf(e)>=0}};function Ue(e,t){for(var n=Ve(e),r=-1,i=t.length;++r<i;)n.add(t[r])}function We(e,t){for(var n=Ve(e),r=-1,i=t.length;++r<i;)n.remove(t[r])}function Ge(e){return function(){Ue(this,e)}}function Ke(e){return function(){We(this,e)}}function qe(e,t){return function(){(t.apply(this,arguments)?Ue:We)(this,e)}}function Je(e,t){var n=Be(e+``);if(arguments.length<2){for(var r=Ve(this.node()),i=-1,a=n.length;++i<a;)if(!r.contains(n[i]))return!1;return!0}return this.each((typeof t==`function`?qe:t?Ge:Ke)(n,t))}function Ye(){this.textContent=``}function Xe(e){return function(){this.textContent=e}}function Ze(e){return function(){var t=e.apply(this,arguments);this.textContent=t??``}}function Qe(e){return arguments.length?this.each(e==null?Ye:(typeof e==`function`?Ze:Xe)(e)):this.node().textContent}function $e(){this.innerHTML=``}function et(e){return function(){this.innerHTML=e}}function tt(e){return function(){var t=e.apply(this,arguments);this.innerHTML=t??``}}function nt(e){return arguments.length?this.each(e==null?$e:(typeof e==`function`?tt:et)(e)):this.node().innerHTML}function rt(){this.nextSibling&&this.parentNode.appendChild(this)}function it(){return this.each(rt)}function at(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function ot(){return this.each(at)}function st(e){var t=typeof e==`function`?e:D(e);return this.select(function(){return this.appendChild(t.apply(this,arguments))})}function ct(){return null}function lt(e,t){var n=typeof e==`function`?e:D(e),r=t==null?ct:typeof t==`function`?t:k(t);return this.select(function(){return this.insertBefore(n.apply(this,arguments),r.apply(this,arguments)||null)})}function ut(){var e=this.parentNode;e&&e.removeChild(this)}function dt(){return this.each(ut)}function ft(){var e=this.cloneNode(!1),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function pt(){var e=this.cloneNode(!0),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function mt(e){return this.select(e?pt:ft)}function ht(e){return arguments.length?this.property(`__data__`,e):this.node().__data__}function gt(e){return function(t){e.call(this,t,this.__data__)}}function _t(e){return e.trim().split(/^|\s+/).map(function(e){var t=``,n=e.indexOf(`.`);return n>=0&&(t=e.slice(n+1),e=e.slice(0,n)),{type:e,name:t}})}function vt(e){return function(){var t=this.__on;if(t){for(var n=0,r=-1,i=t.length,a;n<i;++n)a=t[n],(!e.type||a.type===e.type)&&a.name===e.name?this.removeEventListener(a.type,a.listener,a.options):t[++r]=a;++r?t.length=r:delete this.__on}}}function yt(e,t,n){return function(){var r=this.__on,i,a=gt(t);if(r){for(var o=0,s=r.length;o<s;++o)if((i=r[o]).type===e.type&&i.name===e.name){this.removeEventListener(i.type,i.listener,i.options),this.addEventListener(i.type,i.listener=a,i.options=n),i.value=t;return}}this.addEventListener(e.type,a,n),i={type:e.type,name:e.name,value:t,listener:a,options:n},r?r.push(i):this.__on=[i]}}function bt(e,t,n){var r=_t(e+``),i,a=r.length,o;if(arguments.length<2){var s=this.node().__on;if(s){for(var c=0,l=s.length,u;c<l;++c)for(i=0,u=s[c];i<a;++i)if((o=r[i]).type===u.type&&o.name===u.name)return u.value}return}for(s=t?yt:vt,i=0;i<a;++i)this.each(s(r[i],t,n));return this}function xt(e,t,n){var r=Ae(e),i=r.CustomEvent;typeof i==`function`?i=new i(t,n):(i=r.document.createEvent(`Event`),n?(i.initEvent(t,n.bubbles,n.cancelable),i.detail=n.detail):i.initEvent(t,!1,!1)),e.dispatchEvent(i)}function St(e,t){return function(){return xt(this,e,t)}}function Ct(e,t){return function(){return xt(this,e,t.apply(this,arguments))}}function wt(e,t){return this.each((typeof t==`function`?Ct:St)(e,t))}function*Tt(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var r=e[t],i=0,a=r.length,o;i<a;++i)(o=r[i])&&(yield o)}var Et=[null];function G(e,t){this._groups=e,this._parents=t}function Dt(){return new G([[document.documentElement]],Et)}function Ot(){return this}G.prototype=Dt.prototype={constructor:G,select:A,selectAll:F,selectChild:B,selectChildren:W,filter:te,data:le,enter:re,exit:de,join:fe,merge:pe,selection:Ot,order:me,sort:he,call:_e,nodes:ve,node:ye,size:be,empty:xe,each:Se,attr:ke,style:Pe,property:ze,classed:Je,text:Qe,html:nt,raise:it,lower:ot,append:st,insert:lt,remove:dt,clone:mt,datum:ht,on:bt,dispatch:wt,[Symbol.iterator]:Tt};function K(e){return typeof e==`string`?new G([[document.querySelector(e)]],[document.documentElement]):new G([[e]],Et)}function kt(e){let t;for(;t=e.sourceEvent;)e=t;return e}function q(e,t){if(e=kt(e),t===void 0&&(t=e.currentTarget),t){var n=t.ownerSVGElement||t;if(n.createSVGPoint){var r=n.createSVGPoint();return r.x=e.clientX,r.y=e.clientY,r=r.matrixTransform(t.getScreenCTM().inverse()),[r.x,r.y]}if(t.getBoundingClientRect){var i=t.getBoundingClientRect();return[e.clientX-i.left-t.clientLeft,e.clientY-i.top-t.clientTop]}}return[e.pageX,e.pageY]}const At={passive:!1},jt={capture:!0,passive:!1};function Mt(e){e.stopImmediatePropagation()}function Nt(e){e.preventDefault(),e.stopImmediatePropagation()}function Pt(e){var t=e.document.documentElement,n=K(e).on(`dragstart.drag`,Nt,jt);`onselectstart`in t?n.on(`selectstart.drag`,Nt,jt):(t.__noselect=t.style.MozUserSelect,t.style.MozUserSelect=`none`)}function Ft(e,t){var n=e.document.documentElement,r=K(e).on(`dragstart.drag`,null);t&&(r.on(`click.drag`,Nt,jt),setTimeout(function(){r.on(`click.drag`,null)},0)),`onselectstart`in n?r.on(`selectstart.drag`,null):(n.style.MozUserSelect=n.__noselect,delete n.__noselect)}var It=e=>()=>e;function Lt(e,{sourceEvent:t,subject:n,target:r,identifier:i,active:a,x:o,y:s,dx:c,dy:l,dispatch:u}){Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},subject:{value:n,enumerable:!0,configurable:!0},target:{value:r,enumerable:!0,configurable:!0},identifier:{value:i,enumerable:!0,configurable:!0},active:{value:a,enumerable:!0,configurable:!0},x:{value:o,enumerable:!0,configurable:!0},y:{value:s,enumerable:!0,configurable:!0},dx:{value:c,enumerable:!0,configurable:!0},dy:{value:l,enumerable:!0,configurable:!0},_:{value:u}})}Lt.prototype.on=function(){var e=this._.on.apply(this._,arguments);return e===this._?this:e};function Rt(e){return!e.ctrlKey&&!e.button}function zt(){return this.parentNode}function Bt(e,t){return t??{x:e.x,y:e.y}}function Vt(){return navigator.maxTouchPoints||`ontouchstart`in this}function Ht(){var e=Rt,t=zt,n=Bt,r=Vt,i={},a=v(`start`,`drag`,`end`),o=0,s,c,l,u,d=0;function f(e){e.on(`mousedown.drag`,p).filter(r).on(`touchstart.drag`,g).on(`touchmove.drag`,_,At).on(`touchend.drag touchcancel.drag`,y).style(`touch-action`,`none`).style(`-webkit-tap-highlight-color`,`rgba(0,0,0,0)`)}function p(n,r){if(!(u||!e.call(this,n,r))){var i=b(this,t.call(this,n,r),n,r,`mouse`);i&&(K(n.view).on(`mousemove.drag`,m,jt).on(`mouseup.drag`,h,jt),Pt(n.view),Mt(n),l=!1,s=n.clientX,c=n.clientY,i(`start`,n))}}function m(e){if(Nt(e),!l){var t=e.clientX-s,n=e.clientY-c;l=t*t+n*n>d}i.mouse(`drag`,e)}function h(e){K(e.view).on(`mousemove.drag mouseup.drag`,null),Ft(e.view,l),Nt(e),i.mouse(`end`,e)}function g(n,r){if(e.call(this,n,r)){var i=n.changedTouches,a=t.call(this,n,r),o=i.length,s,c;for(s=0;s<o;++s)(c=b(this,a,n,r,i[s].identifier,i[s]))&&(Mt(n),c(`start`,n,i[s]))}}function _(e){var t=e.changedTouches,n=t.length,r,a;for(r=0;r<n;++r)(a=i[t[r].identifier])&&(Nt(e),a(`drag`,e,t[r]))}function y(e){var t=e.changedTouches,n=t.length,r,a;for(u&&clearTimeout(u),u=setTimeout(function(){u=null},500),r=0;r<n;++r)(a=i[t[r].identifier])&&(Mt(e),a(`end`,e,t[r]))}function b(e,t,r,s,c,l){var u=a.copy(),d=q(l||r,t),p,m,h;if((h=n.call(e,new Lt(`beforestart`,{sourceEvent:r,target:f,identifier:c,active:o,x:d[0],y:d[1],dx:0,dy:0,dispatch:u}),s))!=null)return p=h.x-d[0]||0,m=h.y-d[1]||0,function n(r,a,l){var g=d,_;switch(r){case`start`:i[c]=n,_=o++;break;case`end`:delete i[c],--o;case`drag`:d=q(l||a,t),_=o;break}u.call(r,e,new Lt(r,{sourceEvent:a,subject:h,target:f,identifier:c,active:_,x:d[0]+p,y:d[1]+m,dx:d[0]-g[0],dy:d[1]-g[1],dispatch:u}),s)}}return f.filter=function(t){return arguments.length?(e=typeof t==`function`?t:It(!!t),f):e},f.container=function(e){return arguments.length?(t=typeof e==`function`?e:It(e),f):t},f.subject=function(e){return arguments.length?(n=typeof e==`function`?e:It(e),f):n},f.touchable=function(e){return arguments.length?(r=typeof e==`function`?e:It(!!e),f):r},f.on=function(){var e=a.on.apply(a,arguments);return e===a?f:e},f.clickDistance=function(e){return arguments.length?(d=(e=+e)*e,f):Math.sqrt(d)},f}function Ut(e,t,n){e.prototype=t.prototype=n,n.constructor=e}function Wt(e,t){var n=Object.create(e.prototype);for(var r in t)n[r]=t[r];return n}function Gt(){}var Kt=.7,qt=1/Kt,Jt=`\\s*([+-]?\\d+)\\s*`,Yt=`\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*`,Xt=`\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*`,Zt=/^#([0-9a-f]{3,8})$/,Qt=RegExp(`^rgb\\(${Jt},${Jt},${Jt}\\)$`),$t=RegExp(`^rgb\\(${Xt},${Xt},${Xt}\\)$`),en=RegExp(`^rgba\\(${Jt},${Jt},${Jt},${Yt}\\)$`),tn=RegExp(`^rgba\\(${Xt},${Xt},${Xt},${Yt}\\)$`),nn=RegExp(`^hsl\\(${Yt},${Xt},${Xt}\\)$`),rn=RegExp(`^hsla\\(${Yt},${Xt},${Xt},${Yt}\\)$`),an={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};Ut(Gt,un,{copy(e){return Object.assign(new this.constructor,this,e)},displayable(){return this.rgb().displayable()},hex:on,formatHex:on,formatHex8:sn,formatHsl:cn,formatRgb:ln,toString:ln});function on(){return this.rgb().formatHex()}function sn(){return this.rgb().formatHex8()}function cn(){return Sn(this).formatHsl()}function ln(){return this.rgb().formatRgb()}function un(e){var t,n;return e=(e+``).trim().toLowerCase(),(t=Zt.exec(e))?(n=t[1].length,t=parseInt(t[1],16),n===6?dn(t):n===3?new J(t>>8&15|t>>4&240,t>>4&15|t&240,(t&15)<<4|t&15,1):n===8?fn(t>>24&255,t>>16&255,t>>8&255,(t&255)/255):n===4?fn(t>>12&15|t>>8&240,t>>8&15|t>>4&240,t>>4&15|t&240,((t&15)<<4|t&15)/255):null):(t=Qt.exec(e))?new J(t[1],t[2],t[3],1):(t=$t.exec(e))?new J(t[1]*255/100,t[2]*255/100,t[3]*255/100,1):(t=en.exec(e))?fn(t[1],t[2],t[3],t[4]):(t=tn.exec(e))?fn(t[1]*255/100,t[2]*255/100,t[3]*255/100,t[4]):(t=nn.exec(e))?xn(t[1],t[2]/100,t[3]/100,1):(t=rn.exec(e))?xn(t[1],t[2]/100,t[3]/100,t[4]):an.hasOwnProperty(e)?dn(an[e]):e===`transparent`?new J(NaN,NaN,NaN,0):null}function dn(e){return new J(e>>16&255,e>>8&255,e&255,1)}function fn(e,t,n,r){return r<=0&&(e=t=n=NaN),new J(e,t,n,r)}function pn(e){return e instanceof Gt||(e=un(e)),e?(e=e.rgb(),new J(e.r,e.g,e.b,e.opacity)):new J}function mn(e,t,n,r){return arguments.length===1?pn(e):new J(e,t,n,r??1)}function J(e,t,n,r){this.r=+e,this.g=+t,this.b=+n,this.opacity=+r}Ut(J,mn,Wt(Gt,{brighter(e){return e=e==null?qt:qt**+e,new J(this.r*e,this.g*e,this.b*e,this.opacity)},darker(e){return e=e==null?Kt:Kt**+e,new J(this.r*e,this.g*e,this.b*e,this.opacity)},rgb(){return this},clamp(){return new J(yn(this.r),yn(this.g),yn(this.b),vn(this.opacity))},displayable(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:hn,formatHex:hn,formatHex8:gn,formatRgb:_n,toString:_n}));function hn(){return`#${bn(this.r)}${bn(this.g)}${bn(this.b)}`}function gn(){return`#${bn(this.r)}${bn(this.g)}${bn(this.b)}${bn((isNaN(this.opacity)?1:this.opacity)*255)}`}function _n(){let e=vn(this.opacity);return`${e===1?`rgb(`:`rgba(`}${yn(this.r)}, ${yn(this.g)}, ${yn(this.b)}${e===1?`)`:`, ${e})`}`}function vn(e){return isNaN(e)?1:Math.max(0,Math.min(1,e))}function yn(e){return Math.max(0,Math.min(255,Math.round(e)||0))}function bn(e){return e=yn(e),(e<16?`0`:``)+e.toString(16)}function xn(e,t,n,r){return r<=0?e=t=n=NaN:n<=0||n>=1?e=t=NaN:t<=0&&(e=NaN),new wn(e,t,n,r)}function Sn(e){if(e instanceof wn)return new wn(e.h,e.s,e.l,e.opacity);if(e instanceof Gt||(e=un(e)),!e)return new wn;if(e instanceof wn)return e;e=e.rgb();var t=e.r/255,n=e.g/255,r=e.b/255,i=Math.min(t,n,r),a=Math.max(t,n,r),o=NaN,s=a-i,c=(a+i)/2;return s?(o=t===a?(n-r)/s+(n<r)*6:n===a?(r-t)/s+2:(t-n)/s+4,s/=c<.5?a+i:2-a-i,o*=60):s=c>0&&c<1?0:o,new wn(o,s,c,e.opacity)}function Cn(e,t,n,r){return arguments.length===1?Sn(e):new wn(e,t,n,r??1)}function wn(e,t,n,r){this.h=+e,this.s=+t,this.l=+n,this.opacity=+r}Ut(wn,Cn,Wt(Gt,{brighter(e){return e=e==null?qt:qt**+e,new wn(this.h,this.s,this.l*e,this.opacity)},darker(e){return e=e==null?Kt:Kt**+e,new wn(this.h,this.s,this.l*e,this.opacity)},rgb(){var e=this.h%360+(this.h<0)*360,t=isNaN(e)||isNaN(this.s)?0:this.s,n=this.l,r=n+(n<.5?n:1-n)*t,i=2*n-r;return new J(Dn(e>=240?e-240:e+120,i,r),Dn(e,i,r),Dn(e<120?e+240:e-120,i,r),this.opacity)},clamp(){return new wn(Tn(this.h),En(this.s),En(this.l),vn(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){let e=vn(this.opacity);return`${e===1?`hsl(`:`hsla(`}${Tn(this.h)}, ${En(this.s)*100}%, ${En(this.l)*100}%${e===1?`)`:`, ${e})`}`}}));function Tn(e){return e=(e||0)%360,e<0?e+360:e}function En(e){return Math.max(0,Math.min(1,e||0))}function Dn(e,t,n){return(e<60?t+(n-t)*e/60:e<180?n:e<240?t+(n-t)*(240-e)/60:t)*255}var On=e=>()=>e;function kn(e,t){return function(n){return e+n*t}}function An(e,t,n){return e**=+n,t=t**+n-e,n=1/n,function(r){return(e+r*t)**+n}}function jn(e){return(e=+e)==1?Mn:function(t,n){return n-t?An(t,n,e):On(isNaN(t)?n:t)}}function Mn(e,t){var n=t-e;return n?kn(e,n):On(isNaN(e)?t:e)}var Nn=(function e(t){var n=jn(t);function r(e,t){var r=n((e=mn(e)).r,(t=mn(t)).r),i=n(e.g,t.g),a=n(e.b,t.b),o=Mn(e.opacity,t.opacity);return function(t){return e.r=r(t),e.g=i(t),e.b=a(t),e.opacity=o(t),e+``}}return r.gamma=e,r})(1);function Pn(e,t){t||=[];var n=e?Math.min(t.length,e.length):0,r=t.slice(),i;return function(a){for(i=0;i<n;++i)r[i]=e[i]*(1-a)+t[i]*a;return r}}function Fn(e){return ArrayBuffer.isView(e)&&!(e instanceof DataView)}function In(e,t){var n=t?t.length:0,r=e?Math.min(n,e.length):0,i=Array(r),a=Array(n),o;for(o=0;o<r;++o)i[o]=Gn(e[o],t[o]);for(;o<n;++o)a[o]=t[o];return function(e){for(o=0;o<r;++o)a[o]=i[o](e);return a}}function Ln(e,t){var n=new Date;return e=+e,t=+t,function(r){return n.setTime(e*(1-r)+t*r),n}}function Rn(e,t){return e=+e,t=+t,function(n){return e*(1-n)+t*n}}function zn(e,t){var n={},r={},i;for(i in(typeof e!=`object`||!e)&&(e={}),(typeof t!=`object`||!t)&&(t={}),t)i in e?n[i]=Gn(e[i],t[i]):r[i]=t[i];return function(e){for(i in n)r[i]=n[i](e);return r}}var Bn=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,Vn=new RegExp(Bn.source,`g`);function Hn(e){return function(){return e}}function Un(e){return function(t){return e(t)+``}}function Wn(e,t){var n=Bn.lastIndex=Vn.lastIndex=0,r,i,a,o=-1,s=[],c=[];for(e+=``,t+=``;(r=Bn.exec(e))&&(i=Vn.exec(t));)(a=i.index)>n&&(a=t.slice(n,a),s[o]?s[o]+=a:s[++o]=a),(r=r[0])===(i=i[0])?s[o]?s[o]+=i:s[++o]=i:(s[++o]=null,c.push({i:o,x:Rn(r,i)})),n=Vn.lastIndex;return n<t.length&&(a=t.slice(n),s[o]?s[o]+=a:s[++o]=a),s.length<2?c[0]?Un(c[0].x):Hn(t):(t=c.length,function(e){for(var n=0,r;n<t;++n)s[(r=c[n]).i]=r.x(e);return s.join(``)})}function Gn(e,t){var n=typeof t,r;return t==null||n===`boolean`?On(t):(n===`number`?Rn:n===`string`?(r=un(t))?(t=r,Nn):Wn:t instanceof un?Nn:t instanceof Date?Ln:Fn(t)?Pn:Array.isArray(t)?In:typeof t.valueOf!=`function`&&typeof t.toString!=`function`||isNaN(t)?zn:Rn)(e,t)}var Kn=180/Math.PI,qn={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function Jn(e,t,n,r,i,a){var o,s,c;return(o=Math.sqrt(e*e+t*t))&&(e/=o,t/=o),(c=e*n+t*r)&&(n-=e*c,r-=t*c),(s=Math.sqrt(n*n+r*r))&&(n/=s,r/=s,c/=s),e*r<t*n&&(e=-e,t=-t,c=-c,o=-o),{translateX:i,translateY:a,rotate:Math.atan2(t,e)*Kn,skewX:Math.atan(c)*Kn,scaleX:o,scaleY:s}}var Yn;function Xn(e){let t=new(typeof DOMMatrix==`function`?DOMMatrix:WebKitCSSMatrix)(e+``);return t.isIdentity?qn:Jn(t.a,t.b,t.c,t.d,t.e,t.f)}function Zn(e){return e==null||(Yn||=document.createElementNS(`http://www.w3.org/2000/svg`,`g`),Yn.setAttribute(`transform`,e),!(e=Yn.transform.baseVal.consolidate()))?qn:(e=e.matrix,Jn(e.a,e.b,e.c,e.d,e.e,e.f))}function Qn(e,t,n,r){function i(e){return e.length?e.pop()+` `:``}function a(e,r,i,a,o,s){if(e!==i||r!==a){var c=o.push(`translate(`,null,t,null,n);s.push({i:c-4,x:Rn(e,i)},{i:c-2,x:Rn(r,a)})}else (i||a)&&o.push(`translate(`+i+t+a+n)}function o(e,t,n,a){e===t?t&&n.push(i(n)+`rotate(`+t+r):(e-t>180?t+=360:t-e>180&&(e+=360),a.push({i:n.push(i(n)+`rotate(`,null,r)-2,x:Rn(e,t)}))}function s(e,t,n,a){e===t?t&&n.push(i(n)+`skewX(`+t+r):a.push({i:n.push(i(n)+`skewX(`,null,r)-2,x:Rn(e,t)})}function c(e,t,n,r,a,o){if(e!==n||t!==r){var s=a.push(i(a)+`scale(`,null,`,`,null,`)`);o.push({i:s-4,x:Rn(e,n)},{i:s-2,x:Rn(t,r)})}else (n!==1||r!==1)&&a.push(i(a)+`scale(`+n+`,`+r+`)`)}return function(t,n){var r=[],i=[];return t=e(t),n=e(n),a(t.translateX,t.translateY,n.translateX,n.translateY,r,i),o(t.rotate,n.rotate,r,i),s(t.skewX,n.skewX,r,i),c(t.scaleX,t.scaleY,n.scaleX,n.scaleY,r,i),t=n=null,function(e){for(var t=-1,n=i.length,a;++t<n;)r[(a=i[t]).i]=a.x(e);return r.join(``)}}}var $n=Qn(Xn,`px, `,`px)`,`deg)`),er=Qn(Zn,`, `,`)`,`)`),tr=1e-12;function nr(e){return((e=Math.exp(e))+1/e)/2}function rr(e){return((e=Math.exp(e))-1/e)/2}function ir(e){return((e=Math.exp(2*e))-1)/(e+1)}var ar=(function e(t,n,r){function i(e,i){var a=e[0],o=e[1],s=e[2],c=i[0],l=i[1],u=i[2],d=c-a,f=l-o,p=d*d+f*f,m,h;if(p<tr)h=Math.log(u/s)/t,m=function(e){return[a+e*d,o+e*f,s*Math.exp(t*e*h)]};else{var g=Math.sqrt(p),_=(u*u-s*s+r*p)/(2*s*n*g),v=(u*u-s*s-r*p)/(2*u*n*g),y=Math.log(Math.sqrt(_*_+1)-_);h=(Math.log(Math.sqrt(v*v+1)-v)-y)/t,m=function(e){var r=e*h,i=nr(y),c=s/(n*g)*(i*ir(t*r+y)-rr(y));return[a+c*d,o+c*f,s*i/nr(t*r+y)]}}return m.duration=h*1e3*t/Math.SQRT2,m}return i.rho=function(t){var n=Math.max(.001,+t),r=n*n;return e(n,r,r*r)},i})(Math.SQRT2,2,4),or=0,sr=0,cr=0,lr=1e3,ur,dr,fr=0,pr=0,mr=0,hr=typeof performance==`object`&&performance.now?performance:Date,gr=typeof window==`object`&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(e){setTimeout(e,17)};function _r(){return pr||=(gr(vr),hr.now()+mr)}function vr(){pr=0}function yr(){this._call=this._time=this._next=null}yr.prototype=br.prototype={constructor:yr,restart:function(e,t,n){if(typeof e!=`function`)throw TypeError(`callback is not a function`);n=(n==null?_r():+n)+(t==null?0:+t),!this._next&&dr!==this&&(dr?dr._next=this:ur=this,dr=this),this._call=e,this._time=n,Tr()},stop:function(){this._call&&(this._call=null,this._time=1/0,Tr())}};function br(e,t,n){var r=new yr;return r.restart(e,t,n),r}function xr(){_r(),++or;for(var e=ur,t;e;)(t=pr-e._time)>=0&&e._call.call(void 0,t),e=e._next;--or}function Sr(){pr=(fr=hr.now())+mr,or=sr=0;try{xr()}finally{or=0,wr(),pr=0}}function Cr(){var e=hr.now(),t=e-fr;t>lr&&(mr-=t,fr=e)}function wr(){for(var e,t=ur,n,r=1/0;t;)t._call?(r>t._time&&(r=t._time),e=t,t=t._next):(n=t._next,t._next=null,t=e?e._next=n:ur=n);dr=e,Tr(r)}function Tr(e){or||(sr&&=clearTimeout(sr),e-pr>24?(e<1/0&&(sr=setTimeout(Sr,e-hr.now()-mr)),cr&&=clearInterval(cr)):(cr||=(fr=hr.now(),setInterval(Cr,lr)),or=1,gr(Sr)))}function Er(e,t,n){var r=new yr;return t=t==null?0:+t,r.restart(n=>{r.stop(),e(n+t)},t,n),r}var Dr=v(`start`,`end`,`cancel`,`interrupt`),Or=[];function kr(e,t,n,r,i,a){var o=e.__transition;if(!o)e.__transition={};else if(n in o)return;Nr(e,n,{name:t,index:r,group:i,on:Dr,tween:Or,time:a.time,delay:a.delay,duration:a.duration,ease:a.ease,timer:null,state:0})}function Ar(e,t){var n=Mr(e,t);if(n.state>0)throw Error(`too late; already scheduled`);return n}function jr(e,t){var n=Mr(e,t);if(n.state>3)throw Error(`too late; already running`);return n}function Mr(e,t){var n=e.__transition;if(!n||!(n=n[t]))throw Error(`transition not found`);return n}function Nr(e,t,n){var r=e.__transition,i;r[t]=n,n.timer=br(a,0,n.time);function a(e){n.state=1,n.timer.restart(o,n.delay,n.time),n.delay<=e&&o(e-n.delay)}function o(a){var l,u,d,f;if(n.state!==1)return c();for(l in r)if(f=r[l],f.name===n.name){if(f.state===3)return Er(o);f.state===4?(f.state=6,f.timer.stop(),f.on.call(`interrupt`,e,e.__data__,f.index,f.group),delete r[l]):+l<t&&(f.state=6,f.timer.stop(),f.on.call(`cancel`,e,e.__data__,f.index,f.group),delete r[l])}if(Er(function(){n.state===3&&(n.state=4,n.timer.restart(s,n.delay,n.time),s(a))}),n.state=2,n.on.call(`start`,e,e.__data__,n.index,n.group),n.state===2){for(n.state=3,i=Array(d=n.tween.length),l=0,u=-1;l<d;++l)(f=n.tween[l].value.call(e,e.__data__,n.index,n.group))&&(i[++u]=f);i.length=u+1}}function s(t){for(var r=t<n.duration?n.ease.call(null,t/n.duration):(n.timer.restart(c),n.state=5,1),a=-1,o=i.length;++a<o;)i[a].call(e,r);n.state===5&&(n.on.call(`end`,e,e.__data__,n.index,n.group),c())}function c(){for(var i in n.state=6,n.timer.stop(),delete r[t],r)return;delete e.__transition}}function Pr(e,t){var n=e.__transition,r,i,a=!0,o;if(n){for(o in t=t==null?null:t+``,n){if((r=n[o]).name!==t){a=!1;continue}i=r.state>2&&r.state<5,r.state=6,r.timer.stop(),r.on.call(i?`interrupt`:`cancel`,e,e.__data__,r.index,r.group),delete n[o]}a&&delete e.__transition}}function Fr(e){return this.each(function(){Pr(this,e)})}function Ir(e,t){var n,r;return function(){var i=jr(this,e),a=i.tween;if(a!==n){r=n=a;for(var o=0,s=r.length;o<s;++o)if(r[o].name===t){r=r.slice(),r.splice(o,1);break}}i.tween=r}}function Lr(e,t,n){var r,i;if(typeof n!=`function`)throw Error();return function(){var a=jr(this,e),o=a.tween;if(o!==r){i=(r=o).slice();for(var s={name:t,value:n},c=0,l=i.length;c<l;++c)if(i[c].name===t){i[c]=s;break}c===l&&i.push(s)}a.tween=i}}function Rr(e,t){var n=this._id;if(e+=``,arguments.length<2){for(var r=Mr(this.node(),n).tween,i=0,a=r.length,o;i<a;++i)if((o=r[i]).name===e)return o.value;return null}return this.each((t==null?Ir:Lr)(n,e,t))}function zr(e,t,n){var r=e._id;return e.each(function(){var e=jr(this,r);(e.value||={})[t]=n.apply(this,arguments)}),function(e){return Mr(e,r).value[t]}}function Br(e,t){var n;return(typeof t==`number`?Rn:t instanceof un?Nn:(n=un(t))?(t=n,Nn):Wn)(e,t)}function Vr(e){return function(){this.removeAttribute(e)}}function Hr(e){return function(){this.removeAttributeNS(e.space,e.local)}}function Ur(e,t,n){var r,i=n+``,a;return function(){var o=this.getAttribute(e);return o===i?null:o===r?a:a=t(r=o,n)}}function Wr(e,t,n){var r,i=n+``,a;return function(){var o=this.getAttributeNS(e.space,e.local);return o===i?null:o===r?a:a=t(r=o,n)}}function Gr(e,t,n){var r,i,a;return function(){var o,s=n(this),c;return s==null?void this.removeAttribute(e):(o=this.getAttribute(e),c=s+``,o===c?null:o===r&&c===i?a:(i=c,a=t(r=o,s)))}}function Kr(e,t,n){var r,i,a;return function(){var o,s=n(this),c;return s==null?void this.removeAttributeNS(e.space,e.local):(o=this.getAttributeNS(e.space,e.local),c=s+``,o===c?null:o===r&&c===i?a:(i=c,a=t(r=o,s)))}}function qr(e,t){var n=w(e),r=n===`transform`?er:Br;return this.attrTween(e,typeof t==`function`?(n.local?Kr:Gr)(n,r,zr(this,`attr.`+e,t)):t==null?(n.local?Hr:Vr)(n):(n.local?Wr:Ur)(n,r,t))}function Jr(e,t){return function(n){this.setAttribute(e,t.call(this,n))}}function Yr(e,t){return function(n){this.setAttributeNS(e.space,e.local,t.call(this,n))}}function Xr(e,t){var n,r;function i(){var i=t.apply(this,arguments);return i!==r&&(n=(r=i)&&Yr(e,i)),n}return i._value=t,i}function Zr(e,t){var n,r;function i(){var i=t.apply(this,arguments);return i!==r&&(n=(r=i)&&Jr(e,i)),n}return i._value=t,i}function Qr(e,t){var n=`attr.`+e;if(arguments.length<2)return(n=this.tween(n))&&n._value;if(t==null)return this.tween(n,null);if(typeof t!=`function`)throw Error();var r=w(e);return this.tween(n,(r.local?Xr:Zr)(r,t))}function $r(e,t){return function(){Ar(this,e).delay=+t.apply(this,arguments)}}function ei(e,t){return t=+t,function(){Ar(this,e).delay=t}}function ti(e){var t=this._id;return arguments.length?this.each((typeof e==`function`?$r:ei)(t,e)):Mr(this.node(),t).delay}function ni(e,t){return function(){jr(this,e).duration=+t.apply(this,arguments)}}function ri(e,t){return t=+t,function(){jr(this,e).duration=t}}function ii(e){var t=this._id;return arguments.length?this.each((typeof e==`function`?ni:ri)(t,e)):Mr(this.node(),t).duration}function ai(e,t){if(typeof t!=`function`)throw Error();return function(){jr(this,e).ease=t}}function oi(e){var t=this._id;return arguments.length?this.each(ai(t,e)):Mr(this.node(),t).ease}function si(e,t){return function(){var n=t.apply(this,arguments);if(typeof n!=`function`)throw Error();jr(this,e).ease=n}}function ci(e){if(typeof e!=`function`)throw Error();return this.each(si(this._id,e))}function li(e){typeof e!=`function`&&(e=I(e));for(var t=this._groups,n=t.length,r=Array(n),i=0;i<n;++i)for(var a=t[i],o=a.length,s=r[i]=[],c,l=0;l<o;++l)(c=a[l])&&e.call(c,c.__data__,l,a)&&s.push(c);return new Ri(r,this._parents,this._name,this._id)}function ui(e){if(e._id!==this._id)throw Error();for(var t=this._groups,n=e._groups,r=t.length,i=n.length,a=Math.min(r,i),o=Array(r),s=0;s<a;++s)for(var c=t[s],l=n[s],u=c.length,d=o[s]=Array(u),f,p=0;p<u;++p)(f=c[p]||l[p])&&(d[p]=f);for(;s<r;++s)o[s]=t[s];return new Ri(o,this._parents,this._name,this._id)}function di(e){return(e+``).trim().split(/^|\s+/).every(function(e){var t=e.indexOf(`.`);return t>=0&&(e=e.slice(0,t)),!e||e===`start`})}function fi(e,t,n){var r,i,a=di(t)?Ar:jr;return function(){var o=a(this,e),s=o.on;s!==r&&(i=(r=s).copy()).on(t,n),o.on=i}}function pi(e,t){var n=this._id;return arguments.length<2?Mr(this.node(),n).on.on(e):this.each(fi(n,e,t))}function mi(e){return function(){var t=this.parentNode;for(var n in this.__transition)if(+n!==e)return;t&&t.removeChild(this)}}function hi(){return this.on(`end.remove`,mi(this._id))}function gi(e){var t=this._name,n=this._id;typeof e!=`function`&&(e=k(e));for(var r=this._groups,i=r.length,a=Array(i),o=0;o<i;++o)for(var s=r[o],c=s.length,l=a[o]=Array(c),u,d,f=0;f<c;++f)(u=s[f])&&(d=e.call(u,u.__data__,f,s))&&(`__data__`in u&&(d.__data__=u.__data__),l[f]=d,kr(l[f],t,n,f,l,Mr(u,n)));return new Ri(a,this._parents,t,n)}function _i(e){var t=this._name,n=this._id;typeof e!=`function`&&(e=N(e));for(var r=this._groups,i=r.length,a=[],o=[],s=0;s<i;++s)for(var c=r[s],l=c.length,u,d=0;d<l;++d)if(u=c[d]){for(var f=e.call(u,u.__data__,d,c),p,m=Mr(u,n),h=0,g=f.length;h<g;++h)(p=f[h])&&kr(p,t,n,h,f,m);a.push(f),o.push(u)}return new Ri(a,o,t,n)}var vi=Dt.prototype.constructor;function yi(){return new vi(this._groups,this._parents)}function bi(e,t){var n,r,i;return function(){var a=Fe(this,e),o=(this.style.removeProperty(e),Fe(this,e));return a===o?null:a===n&&o===r?i:i=t(n=a,r=o)}}function xi(e){return function(){this.style.removeProperty(e)}}function Si(e,t,n){var r,i=n+``,a;return function(){var o=Fe(this,e);return o===i?null:o===r?a:a=t(r=o,n)}}function Ci(e,t,n){var r,i,a;return function(){var o=Fe(this,e),s=n(this),c=s+``;return s??(c=s=(this.style.removeProperty(e),Fe(this,e))),o===c?null:o===r&&c===i?a:(i=c,a=t(r=o,s))}}function wi(e,t){var n,r,i,a=`style.`+t,o=`end.`+a,s;return function(){var c=jr(this,e),l=c.on,u=c.value[a]==null?s||=xi(t):void 0;(l!==n||i!==u)&&(r=(n=l).copy()).on(o,i=u),c.on=r}}function Ti(e,t,n){var r=(e+=``)==`transform`?$n:Br;return t==null?this.styleTween(e,bi(e,r)).on(`end.style.`+e,xi(e)):typeof t==`function`?this.styleTween(e,Ci(e,r,zr(this,`style.`+e,t))).each(wi(this._id,e)):this.styleTween(e,Si(e,r,t),n).on(`end.style.`+e,null)}function Ei(e,t,n){return function(r){this.style.setProperty(e,t.call(this,r),n)}}function Di(e,t,n){var r,i;function a(){var a=t.apply(this,arguments);return a!==i&&(r=(i=a)&&Ei(e,a,n)),r}return a._value=t,a}function Oi(e,t,n){var r=`style.`+(e+=``);if(arguments.length<2)return(r=this.tween(r))&&r._value;if(t==null)return this.tween(r,null);if(typeof t!=`function`)throw Error();return this.tween(r,Di(e,t,n??``))}function ki(e){return function(){this.textContent=e}}function Ai(e){return function(){var t=e(this);this.textContent=t??``}}function ji(e){return this.tween(`text`,typeof e==`function`?Ai(zr(this,`text`,e)):ki(e==null?``:e+``))}function Mi(e){return function(t){this.textContent=e.call(this,t)}}function Ni(e){var t,n;function r(){var r=e.apply(this,arguments);return r!==n&&(t=(n=r)&&Mi(r)),t}return r._value=e,r}function Pi(e){var t=`text`;if(arguments.length<1)return(t=this.tween(t))&&t._value;if(e==null)return this.tween(t,null);if(typeof e!=`function`)throw Error();return this.tween(t,Ni(e))}function Fi(){for(var e=this._name,t=this._id,n=Bi(),r=this._groups,i=r.length,a=0;a<i;++a)for(var o=r[a],s=o.length,c,l=0;l<s;++l)if(c=o[l]){var u=Mr(c,t);kr(c,e,n,l,o,{time:u.time+u.delay+u.duration,delay:0,duration:u.duration,ease:u.ease})}return new Ri(r,this._parents,e,n)}function Ii(){var e,t,n=this,r=n._id,i=n.size();return new Promise(function(a,o){var s={value:o},c={value:function(){--i===0&&a()}};n.each(function(){var n=jr(this,r),i=n.on;i!==e&&(t=(e=i).copy(),t._.cancel.push(s),t._.interrupt.push(s),t._.end.push(c)),n.on=t}),i===0&&a()})}var Li=0;function Ri(e,t,n,r){this._groups=e,this._parents=t,this._name=n,this._id=r}function zi(e){return Dt().transition(e)}function Bi(){return++Li}var Vi=Dt.prototype;Ri.prototype=zi.prototype={constructor:Ri,select:gi,selectAll:_i,selectChild:Vi.selectChild,selectChildren:Vi.selectChildren,filter:li,merge:ui,selection:yi,transition:Fi,call:Vi.call,nodes:Vi.nodes,node:Vi.node,size:Vi.size,empty:Vi.empty,each:Vi.each,on:pi,attr:qr,attrTween:Qr,style:Ti,styleTween:Oi,text:ji,textTween:Pi,remove:hi,tween:Rr,delay:ti,duration:ii,ease:oi,easeVarying:ci,end:Ii,[Symbol.iterator]:Vi[Symbol.iterator]};function Hi(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}var Ui={time:null,delay:0,duration:250,ease:Hi};function Wi(e,t){for(var n;!(n=e.__transition)||!(n=n[t]);)if(!(e=e.parentNode))throw Error(`transition ${t} not found`);return n}function Gi(e){var t,n;e instanceof Ri?(t=e._id,e=e._name):(t=Bi(),(n=Ui).time=_r(),e=e==null?null:e+``);for(var r=this._groups,i=r.length,a=0;a<i;++a)for(var o=r[a],s=o.length,c,l=0;l<s;++l)(c=o[l])&&kr(c,e,t,l,o,n||Wi(c,t));return new Ri(r,this._parents,e,t)}Dt.prototype.interrupt=Fr,Dt.prototype.transition=Gi;var Ki=e=>()=>e;function qi(e,{sourceEvent:t,target:n,transform:r,dispatch:i}){Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},transform:{value:r,enumerable:!0,configurable:!0},_:{value:i}})}function Ji(e,t,n){this.k=e,this.x=t,this.y=n}Ji.prototype={constructor:Ji,scale:function(e){return e===1?this:new Ji(this.k*e,this.x,this.y)},translate:function(e,t){return e===0&t===0?this:new Ji(this.k,this.x+this.k*e,this.y+this.k*t)},apply:function(e){return[e[0]*this.k+this.x,e[1]*this.k+this.y]},applyX:function(e){return e*this.k+this.x},applyY:function(e){return e*this.k+this.y},invert:function(e){return[(e[0]-this.x)/this.k,(e[1]-this.y)/this.k]},invertX:function(e){return(e-this.x)/this.k},invertY:function(e){return(e-this.y)/this.k},rescaleX:function(e){return e.copy().domain(e.range().map(this.invertX,this).map(e.invert,e))},rescaleY:function(e){return e.copy().domain(e.range().map(this.invertY,this).map(e.invert,e))},toString:function(){return`translate(`+this.x+`,`+this.y+`) scale(`+this.k+`)`}};var Yi=new Ji(1,0,0);Xi.prototype=Ji.prototype;function Xi(e){for(;!e.__zoom;)if(!(e=e.parentNode))return Yi;return e.__zoom}function Zi(e){e.stopImmediatePropagation()}function Qi(e){e.preventDefault(),e.stopImmediatePropagation()}function $i(e){return(!e.ctrlKey||e.type===`wheel`)&&!e.button}function ea(){var e=this;return e instanceof SVGElement?(e=e.ownerSVGElement||e,e.hasAttribute(`viewBox`)?(e=e.viewBox.baseVal,[[e.x,e.y],[e.x+e.width,e.y+e.height]]):[[0,0],[e.width.baseVal.value,e.height.baseVal.value]]):[[0,0],[e.clientWidth,e.clientHeight]]}function ta(){return this.__zoom||Yi}function na(e){return-e.deltaY*(e.deltaMode===1?.05:e.deltaMode?1:.002)*(e.ctrlKey?10:1)}function ra(){return navigator.maxTouchPoints||`ontouchstart`in this}function ia(e,t,n){var r=e.invertX(t[0][0])-n[0][0],i=e.invertX(t[1][0])-n[1][0],a=e.invertY(t[0][1])-n[0][1],o=e.invertY(t[1][1])-n[1][1];return e.translate(i>r?(r+i)/2:Math.min(0,r)||Math.max(0,i),o>a?(a+o)/2:Math.min(0,a)||Math.max(0,o))}function aa(){var e=$i,t=ea,n=ia,r=na,i=ra,a=[0,1/0],o=[[-1/0,-1/0],[1/0,1/0]],s=250,c=ar,l=v(`start`,`zoom`,`end`),u,d,f,p=500,m=150,h=0,g=10;function _(e){e.property(`__zoom`,ta).on(`wheel.zoom`,T,{passive:!1}).on(`mousedown.zoom`,E).on(`dblclick.zoom`,D).filter(i).on(`touchstart.zoom`,O).on(`touchmove.zoom`,k).on(`touchend.zoom touchcancel.zoom`,A).style(`-webkit-tap-highlight-color`,`rgba(0,0,0,0)`)}_.transform=function(e,t,n,r){var i=e.selection?e.selection():e;i.property(`__zoom`,ta),e===i?i.interrupt().each(function(){C(this,arguments).event(r).start().zoom(null,typeof t==`function`?t.apply(this,arguments):t).end()}):S(e,t,n,r)},_.scaleBy=function(e,t,n,r){_.scaleTo(e,function(){return this.__zoom.k*(typeof t==`function`?t.apply(this,arguments):t)},n,r)},_.scaleTo=function(e,r,i,a){_.transform(e,function(){var e=t.apply(this,arguments),a=this.__zoom,s=i==null?x(e):typeof i==`function`?i.apply(this,arguments):i,c=a.invert(s),l=typeof r==`function`?r.apply(this,arguments):r;return n(b(y(a,l),s,c),e,o)},i,a)},_.translateBy=function(e,r,i,a){_.transform(e,function(){return n(this.__zoom.translate(typeof r==`function`?r.apply(this,arguments):r,typeof i==`function`?i.apply(this,arguments):i),t.apply(this,arguments),o)},null,a)},_.translateTo=function(e,r,i,a,s){_.transform(e,function(){var e=t.apply(this,arguments),s=this.__zoom,c=a==null?x(e):typeof a==`function`?a.apply(this,arguments):a;return n(Yi.translate(c[0],c[1]).scale(s.k).translate(typeof r==`function`?-r.apply(this,arguments):-r,typeof i==`function`?-i.apply(this,arguments):-i),e,o)},a,s)};function y(e,t){return t=Math.max(a[0],Math.min(a[1],t)),t===e.k?e:new Ji(t,e.x,e.y)}function b(e,t,n){var r=t[0]-n[0]*e.k,i=t[1]-n[1]*e.k;return r===e.x&&i===e.y?e:new Ji(e.k,r,i)}function x(e){return[(+e[0][0]+ +e[1][0])/2,(+e[0][1]+ +e[1][1])/2]}function S(e,n,r,i){e.on(`start.zoom`,function(){C(this,arguments).event(i).start()}).on(`interrupt.zoom end.zoom`,function(){C(this,arguments).event(i).end()}).tween(`zoom`,function(){var e=this,a=arguments,o=C(e,a).event(i),s=t.apply(e,a),l=r==null?x(s):typeof r==`function`?r.apply(e,a):r,u=Math.max(s[1][0]-s[0][0],s[1][1]-s[0][1]),d=e.__zoom,f=typeof n==`function`?n.apply(e,a):n,p=c(d.invert(l).concat(u/d.k),f.invert(l).concat(u/f.k));return function(e){if(e===1)e=f;else{var t=p(e),n=u/t[2];e=new Ji(n,l[0]-t[0]*n,l[1]-t[1]*n)}o.zoom(null,e)}})}function C(e,t,n){return!n&&e.__zooming||new w(e,t)}function w(e,n){this.that=e,this.args=n,this.active=0,this.sourceEvent=null,this.extent=t.apply(e,n),this.taps=0}w.prototype={event:function(e){return e&&(this.sourceEvent=e),this},start:function(){return++this.active===1&&(this.that.__zooming=this,this.emit(`start`)),this},zoom:function(e,t){return this.mouse&&e!==`mouse`&&(this.mouse[1]=t.invert(this.mouse[0])),this.touch0&&e!==`touch`&&(this.touch0[1]=t.invert(this.touch0[0])),this.touch1&&e!==`touch`&&(this.touch1[1]=t.invert(this.touch1[0])),this.that.__zoom=t,this.emit(`zoom`),this},end:function(){return--this.active===0&&(delete this.that.__zooming,this.emit(`end`)),this},emit:function(e){var t=K(this.that).datum();l.call(e,this.that,new qi(e,{sourceEvent:this.sourceEvent,target:_,type:e,transform:this.that.__zoom,dispatch:l}),t)}};function T(t,...i){if(!e.apply(this,arguments))return;var s=C(this,i).event(t),c=this.__zoom,l=Math.max(a[0],Math.min(a[1],c.k*2**r.apply(this,arguments))),u=q(t);if(s.wheel)(s.mouse[0][0]!==u[0]||s.mouse[0][1]!==u[1])&&(s.mouse[1]=c.invert(s.mouse[0]=u)),clearTimeout(s.wheel);else if(c.k===l)return;else s.mouse=[u,c.invert(u)],Pr(this),s.start();Qi(t),s.wheel=setTimeout(d,m),s.zoom(`mouse`,n(b(y(c,l),s.mouse[0],s.mouse[1]),s.extent,o));function d(){s.wheel=null,s.end()}}function E(t,...r){if(f||!e.apply(this,arguments))return;var i=t.currentTarget,a=C(this,r,!0).event(t),s=K(t.view).on(`mousemove.zoom`,d,!0).on(`mouseup.zoom`,p,!0),c=q(t,i),l=t.clientX,u=t.clientY;Pt(t.view),Zi(t),a.mouse=[c,this.__zoom.invert(c)],Pr(this),a.start();function d(e){if(Qi(e),!a.moved){var t=e.clientX-l,r=e.clientY-u;a.moved=t*t+r*r>h}a.event(e).zoom(`mouse`,n(b(a.that.__zoom,a.mouse[0]=q(e,i),a.mouse[1]),a.extent,o))}function p(e){s.on(`mousemove.zoom mouseup.zoom`,null),Ft(e.view,a.moved),Qi(e),a.event(e).end()}}function D(r,...i){if(e.apply(this,arguments)){var a=this.__zoom,c=q(r.changedTouches?r.changedTouches[0]:r,this),l=a.invert(c),u=a.k*(r.shiftKey?.5:2),d=n(b(y(a,u),c,l),t.apply(this,i),o);Qi(r),s>0?K(this).transition().duration(s).call(S,d,c,r):K(this).call(_.transform,d,c,r)}}function O(t,...n){if(e.apply(this,arguments)){var r=t.touches,i=r.length,a=C(this,n,t.changedTouches.length===i).event(t),o,s,c,l;for(Zi(t),s=0;s<i;++s)c=r[s],l=q(c,this),l=[l,this.__zoom.invert(l),c.identifier],a.touch0?!a.touch1&&a.touch0[2]!==l[2]&&(a.touch1=l,a.taps=0):(a.touch0=l,o=!0,a.taps=1+!!u);u&&=clearTimeout(u),o&&(a.taps<2&&(d=l[0],u=setTimeout(function(){u=null},p)),Pr(this),a.start())}}function k(e,...t){if(this.__zooming){var r=C(this,t).event(e),i=e.changedTouches,a=i.length,s,c,l,u;for(Qi(e),s=0;s<a;++s)c=i[s],l=q(c,this),r.touch0&&r.touch0[2]===c.identifier?r.touch0[0]=l:r.touch1&&r.touch1[2]===c.identifier&&(r.touch1[0]=l);if(c=r.that.__zoom,r.touch1){var d=r.touch0[0],f=r.touch0[1],p=r.touch1[0],m=r.touch1[1],h=(h=p[0]-d[0])*h+(h=p[1]-d[1])*h,g=(g=m[0]-f[0])*g+(g=m[1]-f[1])*g;c=y(c,Math.sqrt(h/g)),l=[(d[0]+p[0])/2,(d[1]+p[1])/2],u=[(f[0]+m[0])/2,(f[1]+m[1])/2]}else if(r.touch0)l=r.touch0[0],u=r.touch0[1];else return;r.zoom(`touch`,n(b(c,l,u),r.extent,o))}}function A(e,...t){if(this.__zooming){var n=C(this,t).event(e),r=e.changedTouches,i=r.length,a,o;for(Zi(e),f&&clearTimeout(f),f=setTimeout(function(){f=null},p),a=0;a<i;++a)o=r[a],n.touch0&&n.touch0[2]===o.identifier?delete n.touch0:n.touch1&&n.touch1[2]===o.identifier&&delete n.touch1;if(n.touch1&&!n.touch0&&(n.touch0=n.touch1,delete n.touch1),n.touch0)n.touch0[1]=this.__zoom.invert(n.touch0[0]);else if(n.end(),n.taps===2&&(o=q(o,this),Math.hypot(d[0]-o[0],d[1]-o[1])<g)){var s=K(this).on(`dblclick.zoom`);s&&s.apply(this,arguments)}}}return _.wheelDelta=function(e){return arguments.length?(r=typeof e==`function`?e:Ki(+e),_):r},_.filter=function(t){return arguments.length?(e=typeof t==`function`?t:Ki(!!t),_):e},_.touchable=function(e){return arguments.length?(i=typeof e==`function`?e:Ki(!!e),_):i},_.extent=function(e){return arguments.length?(t=typeof e==`function`?e:Ki([[+e[0][0],+e[0][1]],[+e[1][0],+e[1][1]]]),_):t},_.scaleExtent=function(e){return arguments.length?(a[0]=+e[0],a[1]=+e[1],_):[a[0],a[1]]},_.translateExtent=function(e){return arguments.length?(o[0][0]=+e[0][0],o[1][0]=+e[1][0],o[0][1]=+e[0][1],o[1][1]=+e[1][1],_):[[o[0][0],o[0][1]],[o[1][0],o[1][1]]]},_.constrain=function(e){return arguments.length?(n=e,_):n},_.duration=function(e){return arguments.length?(s=+e,_):s},_.interpolate=function(e){return arguments.length?(c=e,_):c},_.on=function(){var e=l.on.apply(l,arguments);return e===l?_:e},_.clickDistance=function(e){return arguments.length?(h=(e=+e)*e,_):Math.sqrt(h)},_.tapDistance=function(e){return arguments.length?(g=+e,_):g},_}const Y={error001:()=>`[React Flow]: Seems like you have not used zustand provider as an ancestor. Help: https://reactflow.dev/error#001`,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.`,error003:e=>`Node type "${e}" not found. Using fallback type "default".`,error004:()=>`The React Flow parent container needs a width and a height to render the graph.`,error005:()=>`Only child nodes can use a parent extent.`,error006:()=>`Can't create edge. An edge needs a source and a target.`,error007:e=>`The old edge with id=${e} does not exist.`,error009:e=>`Marker type "${e}" doesn't exist.`,error008:(e,{id:t,sourceHandle:n,targetHandle:r})=>`Couldn't create edge for ${e} handle id: "${e===`source`?n:r}", edge id: ${t}.`,error010:()=>`Handle: No node id found. Make sure to only use a Handle inside a custom Node.`,error011:e=>`Edge type "${e}" not found. Using fallback type "default".`,error012:e=>`Node with id "${e}" does not exist, it may have been removed. This can happen when a node is deleted before the "onNodeClick" handler is called.`,error013:(e=`react`)=>`It seems that you haven't loaded the styles. Please import '@xyflow/${e}/dist/style.css' or base.css to make sure everything is working properly.`,error014:()=>`useNodeConnections: No node ID found. Call useNodeConnections inside a custom Node or provide a node ID.`,error015:()=>`It seems that you are trying to drag a node that is not initialized. Please use onNodesChange as explained in the docs.`},oa=[[-1/0,-1/0],[1/0,1/0]],sa=[`Enter`,` `,`Escape`],ca={"node.a11yDescription.default":`Press enter or space to select a node. Press delete to remove it and escape to cancel.`,"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.`,"node.a11yDescription.ariaLiveMessage":({direction:e,x:t,y:n})=>`Moved selected node ${e}. New position, x: ${t}, 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.`,"controls.ariaLabel":`Control Panel`,"controls.zoomIn.ariaLabel":`Zoom In`,"controls.zoomOut.ariaLabel":`Zoom Out`,"controls.fitView.ariaLabel":`Fit View`,"controls.interactive.ariaLabel":`Toggle Interactivity`,"minimap.ariaLabel":`Mini Map`,"handle.ariaLabel":`Handle`};var la;(function(e){e.Strict=`strict`,e.Loose=`loose`})(la||={});var ua;(function(e){e.Free=`free`,e.Vertical=`vertical`,e.Horizontal=`horizontal`})(ua||={});var da;(function(e){e.Partial=`partial`,e.Full=`full`})(da||={});const fa={inProgress:!1,isValid:null,from:null,fromHandle:null,fromPosition:null,fromNode:null,to:null,toHandle:null,toPosition:null,toNode:null,pointer:null};var pa;(function(e){e.Bezier=`default`,e.Straight=`straight`,e.Step=`step`,e.SmoothStep=`smoothstep`,e.SimpleBezier=`simplebezier`})(pa||={});var ma;(function(e){e.Arrow=`arrow`,e.ArrowClosed=`arrowclosed`})(ma||={});var X;(function(e){e.Left=`left`,e.Top=`top`,e.Right=`right`,e.Bottom=`bottom`})(X||={});const ha={[X.Left]:X.Right,[X.Right]:X.Left,[X.Top]:X.Bottom,[X.Bottom]:X.Top};function ga(e){return e===null?null:e?`valid`:`invalid`}const _a=e=>`id`in e&&`source`in e&&`target`in e,va=e=>`id`in e&&`position`in e&&!(`source`in e)&&!(`target`in e),ya=e=>`id`in e&&`internals`in e&&!(`source`in e)&&!(`target`in e),ba=(e,t=[0,0])=>{let{width:n,height:r}=$a(e),i=e.origin??t,a=n*i[0],o=r*i[1];return{x:e.position.x-a,y:e.position.y-o}},xa=(e,t={nodeOrigin:[0,0]})=>e.length===0?{x:0,y:0,width:0,height:0}:Ia(e.reduce((e,n)=>{let r=typeof n==`string`,i=!t.nodeLookup&&!r?n:void 0;return t.nodeLookup&&(i=r?t.nodeLookup.get(n):ya(n)?n:t.nodeLookup.get(n.id)),Pa(e,i?Ra(i,t.nodeOrigin):{x:0,y:0,x2:0,y2:0})},{x:1/0,y:1/0,x2:-1/0,y2:-1/0})),Sa=(e,t={})=>{let n={x:1/0,y:1/0,x2:-1/0,y2:-1/0},r=!1;return e.forEach(e=>{(t.filter===void 0||t.filter(e))&&(n=Pa(n,Ra(e)),r=!0)}),r?Ia(n):{x:0,y:0,width:0,height:0}},Ca=(e,t,[n,r,i]=[0,0,1],a=!1,o=!1)=>{let s={...Ga(t,[n,r,i]),width:t.width/i,height:t.height/i},c=[];for(let t of e.values()){let{measured:e,selectable:n=!0,hidden:r=!1}=t;if(o&&!n||r)continue;let i=e.width??t.width??t.initialWidth??null,l=e.height??t.height??t.initialHeight??null,u=Ba(s,La(t)),d=(i??0)*(l??0),f=a&&u>0;(!t.internals.handleBounds||f||u>=d||t.dragging)&&c.push(t)}return c},wa=(e,t)=>{let n=new Set;return e.forEach(e=>{n.add(e.id)}),t.filter(e=>n.has(e.source)||n.has(e.target))};function Ta(e,t){let n=new Map,r=t?.nodes?new Set(t.nodes.map(e=>e.id)):null;return e.forEach(e=>{e.measured.width&&e.measured.height&&(t?.includeHiddenNodes||!e.hidden)&&(!r||r.has(e.id))&&n.set(e.id,e)}),n}async function Ea({nodes:e,width:t,height:n,panZoom:r,minZoom:i,maxZoom:a},o){if(e.size===0)return Promise.resolve(!0);let s=Xa(Sa(Ta(e,o)),t,n,o?.minZoom??i,o?.maxZoom??a,o?.padding??.1);return await r.setViewport(s,{duration:o?.duration,ease:o?.ease,interpolate:o?.interpolate}),Promise.resolve(!0)}function Da({nodeId:e,nextPosition:t,nodeLookup:n,nodeOrigin:r=[0,0],nodeExtent:i,onError:a}){let o=n.get(e),s=o.parentId?n.get(o.parentId):void 0,{x:c,y:l}=s?s.internals.positionAbsolute:{x:0,y:0},u=o.origin??r,d=o.extent||i;if(o.extent===`parent`&&!o.expandParent)if(!s)a?.(`005`,Y.error005());else{let e=s.measured.width,t=s.measured.height;e&&t&&(d=[[c,l],[c+e,l+t]])}else s&&Qa(o.extent)&&(d=[[o.extent[0][0]+c,o.extent[0][1]+l],[o.extent[1][0]+c,o.extent[1][1]+l]]);let f=Qa(d)?Aa(t,d,o.measured):t;return(o.measured.width===void 0||o.measured.height===void 0)&&a?.(`015`,Y.error015()),{position:{x:f.x-c+(o.measured.width??0)*u[0],y:f.y-l+(o.measured.height??0)*u[1]},positionAbsolute:f}}async function Oa({nodesToRemove:e=[],edgesToRemove:t=[],nodes:n,edges:r,onBeforeDelete:i}){let a=new Set(e.map(e=>e.id)),o=[];for(let e of n){if(e.deletable===!1)continue;let t=a.has(e.id),n=!t&&e.parentId&&o.find(t=>t.id===e.parentId);(t||n)&&o.push(e)}let s=new Set(t.map(e=>e.id)),c=r.filter(e=>e.deletable!==!1),l=wa(o,c);for(let e of c)s.has(e.id)&&!l.find(t=>t.id===e.id)&&l.push(e);if(!i)return{edges:l,nodes:o};let u=await i({nodes:o,edges:l});return typeof u==`boolean`?u?{edges:l,nodes:o}:{edges:[],nodes:[]}:u}const ka=(e,t=0,n=1)=>Math.min(Math.max(e,t),n),Aa=(e={x:0,y:0},t,n)=>({x:ka(e.x,t[0][0],t[1][0]-(n?.width??0)),y:ka(e.y,t[0][1],t[1][1]-(n?.height??0))});function ja(e,t,n){let{width:r,height:i}=$a(n),{x:a,y:o}=n.internals.positionAbsolute;return Aa(e,[[a,o],[a+r,o+i]],t)}const Ma=(e,t,n)=>e<t?ka(Math.abs(e-t),1,t)/t:e>n?-ka(Math.abs(e-n),1,t)/t:0,Na=(e,t,n=15,r=40)=>[Ma(e.x,r,t.width-r)*n,Ma(e.y,r,t.height-r)*n],Pa=(e,t)=>({x:Math.min(e.x,t.x),y:Math.min(e.y,t.y),x2:Math.max(e.x2,t.x2),y2:Math.max(e.y2,t.y2)}),Fa=({x:e,y:t,width:n,height:r})=>({x:e,y:t,x2:e+n,y2:t+r}),Ia=({x:e,y:t,x2:n,y2:r})=>({x:e,y:t,width:n-e,height:r-t}),La=(e,t=[0,0])=>{let{x:n,y:r}=ya(e)?e.internals.positionAbsolute:ba(e,t);return{x:n,y:r,width:e.measured?.width??e.width??e.initialWidth??0,height:e.measured?.height??e.height??e.initialHeight??0}},Ra=(e,t=[0,0])=>{let{x:n,y:r}=ya(e)?e.internals.positionAbsolute:ba(e,t);return{x:n,y:r,x2:n+(e.measured?.width??e.width??e.initialWidth??0),y2:r+(e.measured?.height??e.height??e.initialHeight??0)}},za=(e,t)=>Ia(Pa(Fa(e),Fa(t))),Ba=(e,t)=>{let n=Math.max(0,Math.min(e.x+e.width,t.x+t.width)-Math.max(e.x,t.x)),r=Math.max(0,Math.min(e.y+e.height,t.y+t.height)-Math.max(e.y,t.y));return Math.ceil(n*r)},Va=e=>Ha(e.width)&&Ha(e.height)&&Ha(e.x)&&Ha(e.y),Ha=e=>!isNaN(e)&&isFinite(e),Ua=(e,t)=>{},Wa=(e,t=[1,1])=>({x:t[0]*Math.round(e.x/t[0]),y:t[1]*Math.round(e.y/t[1])}),Ga=({x:e,y:t},[n,r,i],a=!1,o=[1,1])=>{let s={x:(e-n)/i,y:(t-r)/i};return a?Wa(s,o):s},Ka=({x:e,y:t},[n,r,i])=>({x:e*i+n,y:t*i+r});function qa(e,t){if(typeof e==`number`)return Math.floor((t-t/(1+e))*.5);if(typeof e==`string`&&e.endsWith(`px`)){let t=parseFloat(e);if(!Number.isNaN(t))return Math.floor(t)}if(typeof e==`string`&&e.endsWith(`%`)){let n=parseFloat(e);if(!Number.isNaN(n))return Math.floor(t*n*.01)}return console.error(`[React Flow] The padding value "${e}" is invalid. Please provide a number or a string with a valid unit (px or %).`),0}function Ja(e,t,n){if(typeof e==`string`||typeof e==`number`){let r=qa(e,n),i=qa(e,t);return{top:r,right:i,bottom:r,left:i,x:i*2,y:r*2}}if(typeof e==`object`){let r=qa(e.top??e.y??0,n),i=qa(e.bottom??e.y??0,n),a=qa(e.left??e.x??0,t),o=qa(e.right??e.x??0,t);return{top:r,right:o,bottom:i,left:a,x:a+o,y:r+i}}return{top:0,right:0,bottom:0,left:0,x:0,y:0}}function Ya(e,t,n,r,i,a){let{x:o,y:s}=Ka(e,[t,n,r]),{x:c,y:l}=Ka({x:e.x+e.width,y:e.y+e.height},[t,n,r]),u=i-c,d=a-l;return{left:Math.floor(o),top:Math.floor(s),right:Math.floor(u),bottom:Math.floor(d)}}const Xa=(e,t,n,r,i,a)=>{let o=Ja(a,t,n),s=(t-o.x)/e.width,c=(n-o.y)/e.height,l=ka(Math.min(s,c),r,i),u=e.x+e.width/2,d=e.y+e.height/2,f=t/2-u*l,p=n/2-d*l,m=Ya(e,f,p,l,t,n),h={left:Math.min(m.left-o.left,0),top:Math.min(m.top-o.top,0),right:Math.min(m.right-o.right,0),bottom:Math.min(m.bottom-o.bottom,0)};return{x:f-h.left+h.right,y:p-h.top+h.bottom,zoom:l}},Za=()=>typeof navigator<`u`&&navigator?.userAgent?.indexOf(`Mac`)>=0;function Qa(e){return e!=null&&e!==`parent`}function $a(e){return{width:e.measured?.width??e.width??e.initialWidth??0,height:e.measured?.height??e.height??e.initialHeight??0}}function eo(e){return(e.measured?.width??e.width??e.initialWidth)!==void 0&&(e.measured?.height??e.height??e.initialHeight)!==void 0}function to(e,t={width:0,height:0},n,r,i){let a={...e},o=r.get(n);if(o){let e=o.origin||i;a.x+=o.internals.positionAbsolute.x-(t.width??0)*e[0],a.y+=o.internals.positionAbsolute.y-(t.height??0)*e[1]}return a}function no(e,t){if(e.size!==t.size)return!1;for(let n of e)if(!t.has(n))return!1;return!0}function ro(){let e,t;return{promise:new Promise((n,r)=>{e=n,t=r}),resolve:e,reject:t}}function io(e){return{...ca,...e||{}}}function ao(e,{snapGrid:t=[0,0],snapToGrid:n=!1,transform:r,containerBounds:i}){let{x:a,y:o}=fo(e),s=Ga({x:a-(i?.left??0),y:o-(i?.top??0)},r),{x:c,y:l}=n?Wa(s,t):s;return{xSnapped:c,ySnapped:l,...s}}const oo=e=>({width:e.offsetWidth,height:e.offsetHeight}),so=e=>e?.getRootNode?.()||window?.document,co=[`INPUT`,`SELECT`,`TEXTAREA`];function lo(e){let t=e.composedPath?.()?.[0]||e.target;return t?.nodeType===1?co.includes(t.nodeName)||t.hasAttribute(`contenteditable`)||!!t.closest(`.nokey`):!1}const uo=e=>`clientX`in e,fo=(e,t)=>{let n=uo(e),r=n?e.clientX:e.touches?.[0].clientX,i=n?e.clientY:e.touches?.[0].clientY;return{x:r-(t?.left??0),y:i-(t?.top??0)}},po=(e,t,n,r,i)=>{let a=t.querySelectorAll(`.${e}`);return!a||!a.length?null:Array.from(a).map(t=>{let a=t.getBoundingClientRect();return{id:t.getAttribute(`data-handleid`),type:e,nodeId:i,position:t.getAttribute(`data-handlepos`),x:(a.left-n.left)/r,y:(a.top-n.top)/r,...oo(t)}})};function mo({sourceX:e,sourceY:t,targetX:n,targetY:r,sourceControlX:i,sourceControlY:a,targetControlX:o,targetControlY:s}){let c=e*.125+i*.375+o*.375+n*.125,l=t*.125+a*.375+s*.375+r*.125;return[c,l,Math.abs(c-e),Math.abs(l-t)]}function ho(e,t){return e>=0?.5*e:t*25*Math.sqrt(-e)}function go({pos:e,x1:t,y1:n,x2:r,y2:i,c:a}){switch(e){case X.Left:return[t-ho(t-r,a),n];case X.Right:return[t+ho(r-t,a),n];case X.Top:return[t,n-ho(n-i,a)];case X.Bottom:return[t,n+ho(i-n,a)]}}function _o({sourceX:e,sourceY:t,sourcePosition:n=X.Bottom,targetX:r,targetY:i,targetPosition:a=X.Top,curvature:o=.25}){let[s,c]=go({pos:n,x1:e,y1:t,x2:r,y2:i,c:o}),[l,u]=go({pos:a,x1:r,y1:i,x2:e,y2:t,c:o}),[d,f,p,m]=mo({sourceX:e,sourceY:t,targetX:r,targetY:i,sourceControlX:s,sourceControlY:c,targetControlX:l,targetControlY:u});return[`M${e},${t} C${s},${c} ${l},${u} ${r},${i}`,d,f,p,m]}function vo({sourceX:e,sourceY:t,targetX:n,targetY:r}){let i=Math.abs(n-e)/2,a=n<e?n+i:n-i,o=Math.abs(r-t)/2;return[a,r<t?r+o:r-o,i,o]}function yo({sourceNode:e,targetNode:t,selected:n=!1,zIndex:r=0,elevateOnSelect:i=!1,zIndexMode:a=`basic`}){return a===`manual`?r:(i&&n?r+1e3:r)+Math.max(e.parentId||i&&e.selected?e.internals.z:0,t.parentId||i&&t.selected?t.internals.z:0)}function bo({sourceNode:e,targetNode:t,width:n,height:r,transform:i}){let a=Pa(Ra(e),Ra(t));return a.x===a.x2&&(a.x2+=1),a.y===a.y2&&(a.y2+=1),Ba({x:-i[0]/i[2],y:-i[1]/i[2],width:n/i[2],height:r/i[2]},Ia(a))>0}const xo=({source:e,sourceHandle:t,target:n,targetHandle:r})=>`xy-edge__${e}${t||``}-${n}${r||``}`,So=(e,t)=>t.some(t=>t.source===e.source&&t.target===e.target&&(t.sourceHandle===e.sourceHandle||!t.sourceHandle&&!e.sourceHandle)&&(t.targetHandle===e.targetHandle||!t.targetHandle&&!e.targetHandle)),Co=(e,t,n={})=>{if(!e.source||!e.target)return Y.error006(),t;let r=n.getEdgeId||xo,i;return i=_a(e)?{...e}:{...e,id:r(e)},So(i,t)?t:(i.sourceHandle===null&&delete i.sourceHandle,i.targetHandle===null&&delete i.targetHandle,t.concat(i))};function wo({sourceX:e,sourceY:t,targetX:n,targetY:r}){let[i,a,o,s]=vo({sourceX:e,sourceY:t,targetX:n,targetY:r});return[`M ${e},${t}L ${n},${r}`,i,a,o,s]}const To={[X.Left]:{x:-1,y:0},[X.Right]:{x:1,y:0},[X.Top]:{x:0,y:-1},[X.Bottom]:{x:0,y:1}},Eo=({source:e,sourcePosition:t=X.Bottom,target:n})=>t===X.Left||t===X.Right?e.x<n.x?{x:1,y:0}:{x:-1,y:0}:e.y<n.y?{x:0,y:1}:{x:0,y:-1},Do=(e,t)=>Math.sqrt((t.x-e.x)**2+(t.y-e.y)**2);function Oo({source:e,sourcePosition:t=X.Bottom,target:n,targetPosition:r=X.Top,center:i,offset:a,stepPosition:o}){let s=To[t],c=To[r],l={x:e.x+s.x*a,y:e.y+s.y*a},u={x:n.x+c.x*a,y:n.y+c.y*a},d=Eo({source:l,sourcePosition:t,target:u}),f=d.x===0?`y`:`x`,p=d[f],m=[],h,g,_={x:0,y:0},v={x:0,y:0},[,,y,b]=vo({sourceX:e.x,sourceY:e.y,targetX:n.x,targetY:n.y});if(s[f]*c[f]===-1){f===`x`?(h=i.x??l.x+(u.x-l.x)*o,g=i.y??(l.y+u.y)/2):(h=i.x??(l.x+u.x)/2,g=i.y??l.y+(u.y-l.y)*o);let e=[{x:h,y:l.y},{x:h,y:u.y}],t=[{x:l.x,y:g},{x:u.x,y:g}];m=s[f]===p?f===`x`?e:t:f===`x`?t:e}else{let i=[{x:l.x,y:u.y}],o=[{x:u.x,y:l.y}];if(m=f===`x`?s.x===p?o:i:s.y===p?i:o,t===r){let t=Math.abs(e[f]-n[f]);if(t<=a){let r=Math.min(a-1,a-t);s[f]===p?_[f]=(l[f]>e[f]?-1:1)*r:v[f]=(u[f]>n[f]?-1:1)*r}}if(t!==r){let e=f===`x`?`y`:`x`,t=s[f]===c[e],n=l[e]>u[e],r=l[e]<u[e];(s[f]===1&&(!t&&n||t&&r)||s[f]!==1&&(!t&&r||t&&n))&&(m=f===`x`?i:o)}let d={x:l.x+_.x,y:l.y+_.y},y={x:u.x+v.x,y:u.y+v.y};Math.max(Math.abs(d.x-m[0].x),Math.abs(y.x-m[0].x))>=Math.max(Math.abs(d.y-m[0].y),Math.abs(y.y-m[0].y))?(h=(d.x+y.x)/2,g=m[0].y):(h=m[0].x,g=(d.y+y.y)/2)}let x={x:l.x+_.x,y:l.y+_.y},S={x:u.x+v.x,y:u.y+v.y};return[[e,...x.x!==m[0].x||x.y!==m[0].y?[x]:[],...m,...S.x!==m[m.length-1].x||S.y!==m[m.length-1].y?[S]:[],n],h,g,y,b]}function ko(e,t,n,r){let i=Math.min(Do(e,t)/2,Do(t,n)/2,r),{x:a,y:o}=t;if(e.x===a&&a===n.x||e.y===o&&o===n.y)return`L${a} ${o}`;if(e.y===o){let t=e.x<n.x?-1:1,r=e.y<n.y?1:-1;return`L ${a+i*t},${o}Q ${a},${o} ${a},${o+i*r}`}let s=e.x<n.x?1:-1;return`L ${a},${o+i*(e.y<n.y?-1:1)}Q ${a},${o} ${a+i*s},${o}`}function Ao({sourceX:e,sourceY:t,sourcePosition:n=X.Bottom,targetX:r,targetY:i,targetPosition:a=X.Top,borderRadius:o=5,centerX:s,centerY:c,offset:l=20,stepPosition:u=.5}){let[d,f,p,m,h]=Oo({source:{x:e,y:t},sourcePosition:n,target:{x:r,y:i},targetPosition:a,center:{x:s,y:c},offset:l,stepPosition:u}),g=`M${d[0].x} ${d[0].y}`;for(let e=1;e<d.length-1;e++)g+=ko(d[e-1],d[e],d[e+1],o);return g+=`L${d[d.length-1].x} ${d[d.length-1].y}`,[g,f,p,m,h]}function jo(e){return e&&!!(e.internals.handleBounds||e.handles?.length)&&!!(e.measured.width||e.width||e.initialWidth)}function Mo(e){let{sourceNode:t,targetNode:n}=e;if(!jo(t)||!jo(n))return null;let r=t.internals.handleBounds||No(t.handles),i=n.internals.handleBounds||No(n.handles),a=Fo(r?.source??[],e.sourceHandle),o=Fo(e.connectionMode===la.Strict?i?.target??[]:(i?.target??[]).concat(i?.source??[]),e.targetHandle);if(!a||!o)return e.onError?.(`008`,Y.error008(a?`target`:`source`,{id:e.id,sourceHandle:e.sourceHandle,targetHandle:e.targetHandle})),null;let s=a?.position||X.Bottom,c=o?.position||X.Top,l=Po(t,a,s),u=Po(n,o,c);return{sourceX:l.x,sourceY:l.y,targetX:u.x,targetY:u.y,sourcePosition:s,targetPosition:c}}function No(e){if(!e)return null;let t=[],n=[];for(let r of e)r.width=r.width??1,r.height=r.height??1,r.type===`source`?t.push(r):r.type===`target`&&n.push(r);return{source:t,target:n}}function Po(e,t,n=X.Left,r=!1){let i=(t?.x??0)+e.internals.positionAbsolute.x,a=(t?.y??0)+e.internals.positionAbsolute.y,{width:o,height:s}=t??$a(e);if(r)return{x:i+o/2,y:a+s/2};switch(t?.position??n){case X.Top:return{x:i+o/2,y:a};case X.Right:return{x:i+o,y:a+s/2};case X.Bottom:return{x:i+o/2,y:a+s};case X.Left:return{x:i,y:a+s/2}}}function Fo(e,t){return e&&(t?e.find(e=>e.id===t):e[0])||null}function Io(e,t){return e?typeof e==`string`?e:`${t?`${t}__`:``}${Object.keys(e).sort().map(t=>`${t}=${e[t]}`).join(`&`)}`:``}function Lo(e,{id:t,defaultColor:n,defaultMarkerStart:r,defaultMarkerEnd:i}){let a=new Set;return e.reduce((e,o)=>([o.markerStart||r,o.markerEnd||i].forEach(r=>{if(r&&typeof r==`object`){let i=Io(r,t);a.has(i)||(e.push({id:i,color:r.color||n,...r}),a.add(i))}}),e),[]).sort((e,t)=>e.id.localeCompare(t.id))}function Ro(e,t,n,r,i){let a=.5;i===`start`?a=0:i===`end`&&(a=1);let o=[(e.x+e.width*a)*t.zoom+t.x,e.y*t.zoom+t.y-r],s=[-100*a,-100];switch(n){case X.Right:o=[(e.x+e.width)*t.zoom+t.x+r,(e.y+e.height*a)*t.zoom+t.y],s=[0,-100*a];break;case X.Bottom:o[1]=(e.y+e.height)*t.zoom+t.y+r,s[1]=0;break;case X.Left:o=[e.x*t.zoom+t.x-r,(e.y+e.height*a)*t.zoom+t.y],s=[-100,-100*a];break}return`translate(${o[0]}px, ${o[1]}px) translate(${s[0]}%, ${s[1]}%)`}const zo=1e3,Bo={nodeOrigin:[0,0],nodeExtent:oa,elevateNodesOnSelect:!0,zIndexMode:`basic`,defaults:{}},Vo={...Bo,checkEquality:!0};function Ho(e,t){let n={...e};for(let e in t)t[e]!==void 0&&(n[e]=t[e]);return n}function Uo(e,t,n){let r=Ho(Bo,n);for(let n of e.values())if(n.parentId)Jo(n,e,t,r);else{let e=Aa(ba(n,r.nodeOrigin),Qa(n.extent)?n.extent:r.nodeExtent,$a(n));n.internals.positionAbsolute=e}}function Wo(e,t){if(!e.handles)return e.measured?t?.internals.handleBounds:void 0;let n=[],r=[];for(let t of e.handles){let i={id:t.id,width:t.width??1,height:t.height??1,nodeId:e.id,x:t.x,y:t.y,position:t.position,type:t.type};t.type===`source`?n.push(i):t.type===`target`&&r.push(i)}return{source:n,target:r}}function Go(e){return e===`manual`}function Ko(e,t,n,r={}){let i=Ho(Vo,r),a={i:0},o=new Map(t),s=i?.elevateNodesOnSelect&&!Go(i.zIndexMode)?zo:0,c=e.length>0,l=!1;t.clear(),n.clear();for(let u of e){let e=o.get(u.id);if(i.checkEquality&&u===e?.internals.userNode)t.set(u.id,e);else{let n=Aa(ba(u,i.nodeOrigin),Qa(u.extent)?u.extent:i.nodeExtent,$a(u));e={...i.defaults,...u,measured:{width:u.measured?.width,height:u.measured?.height},internals:{positionAbsolute:n,handleBounds:Wo(u,e),z:Yo(u,s,i.zIndexMode),userNode:u}},t.set(u.id,e)}(e.measured===void 0||e.measured.width===void 0||e.measured.height===void 0)&&!e.hidden&&(c=!1),u.parentId&&Jo(e,t,n,r,a),l||=u.selected??!1}return{nodesInitialized:c,hasSelectedNodes:l}}function qo(e,t){if(!e.parentId)return;let n=t.get(e.parentId);n?n.set(e.id,e):t.set(e.parentId,new Map([[e.id,e]]))}function Jo(e,t,n,r,i){let{elevateNodesOnSelect:a,nodeOrigin:o,nodeExtent:s,zIndexMode:c}=Ho(Bo,r),l=e.parentId,u=t.get(l);if(!u){console.warn(`Parent node ${l} not found. Please make sure that parent nodes are in front of their child nodes in the nodes array.`);return}qo(e,n),i&&!u.parentId&&u.internals.rootParentIndex===void 0&&c===`auto`&&(u.internals.rootParentIndex=++i.i,u.internals.z=u.internals.z+i.i*10),i&&u.internals.rootParentIndex!==void 0&&(i.i=u.internals.rootParentIndex);let{x:d,y:f,z:p}=Xo(e,u,o,s,a&&!Go(c)?zo:0,c),{positionAbsolute:m}=e.internals,h=d!==m.x||f!==m.y;(h||p!==e.internals.z)&&t.set(e.id,{...e,internals:{...e.internals,positionAbsolute:h?{x:d,y:f}:m,z:p}})}function Yo(e,t,n){let r=Ha(e.zIndex)?e.zIndex:0;return Go(n)?r:r+(e.selected?t:0)}function Xo(e,t,n,r,i,a){let{x:o,y:s}=t.internals.positionAbsolute,c=$a(e),l=ba(e,n),u=Qa(e.extent)?Aa(l,e.extent,c):l,d=Aa({x:o+u.x,y:s+u.y},r,c);e.extent===`parent`&&(d=ja(d,c,t));let f=Yo(e,i,a),p=t.internals.z??0;return{x:d.x,y:d.y,z:p>=f?p+1:f}}function Zo(e,t,n,r=[0,0]){let i=[],a=new Map;for(let n of e){let e=t.get(n.parentId);if(!e)continue;let r=za(a.get(n.parentId)?.expandedRect??La(e),n.rect);a.set(n.parentId,{expandedRect:r,parent:e})}return a.size>0&&a.forEach(({expandedRect:t,parent:a},o)=>{let s=a.internals.positionAbsolute,c=$a(a),l=a.origin??r,u=t.x<s.x?Math.round(Math.abs(s.x-t.x)):0,d=t.y<s.y?Math.round(Math.abs(s.y-t.y)):0,f=Math.max(c.width,Math.round(t.width)),p=Math.max(c.height,Math.round(t.height)),m=(f-c.width)*l[0],h=(p-c.height)*l[1];(u>0||d>0||m||h)&&(i.push({id:o,type:`position`,position:{x:a.position.x-u+m,y:a.position.y-d+h}}),n.get(o)?.forEach(t=>{e.some(e=>e.id===t.id)||i.push({id:t.id,type:`position`,position:{x:t.position.x+u,y:t.position.y+d}})})),(c.width<t.width||c.height<t.height||u||d)&&i.push({id:o,type:`dimensions`,setAttributes:!0,dimensions:{width:f+(u?l[0]*u-m:0),height:p+(d?l[1]*d-h:0)}})}),i}function Qo(e,t,n,r,i,a,o){let s=r?.querySelector(`.xyflow__viewport`),c=!1;if(!s)return{changes:[],updatedInternals:c};let l=[],u=window.getComputedStyle(s),{m22:d}=new window.DOMMatrixReadOnly(u.transform),f=[];for(let r of e.values()){let e=t.get(r.id);if(!e)continue;if(e.hidden){t.set(e.id,{...e,internals:{...e.internals,handleBounds:void 0}}),c=!0;continue}let s=oo(r.nodeElement),u=e.measured.width!==s.width||e.measured.height!==s.height;if(s.width&&s.height&&(u||!e.internals.handleBounds||r.force)){let p=r.nodeElement.getBoundingClientRect(),m=Qa(e.extent)?e.extent:a,{positionAbsolute:h}=e.internals;e.parentId&&e.extent===`parent`?h=ja(h,s,t.get(e.parentId)):m&&(h=Aa(h,m,s));let g={...e,measured:s,internals:{...e.internals,positionAbsolute:h,handleBounds:{source:po(`source`,r.nodeElement,p,d,e.id),target:po(`target`,r.nodeElement,p,d,e.id)}}};t.set(e.id,g),e.parentId&&Jo(g,t,n,{nodeOrigin:i,zIndexMode:o}),c=!0,u&&(l.push({id:e.id,type:`dimensions`,dimensions:s}),e.expandParent&&e.parentId&&f.push({id:e.id,parentId:e.parentId,rect:La(g,i)}))}}if(f.length>0){let e=Zo(f,t,n,i);l.push(...e)}return{changes:l,updatedInternals:c}}async function $o({delta:e,panZoom:t,transform:n,translateExtent:r,width:i,height:a}){if(!t||!e.x&&!e.y)return Promise.resolve(!1);let o=await t.setViewportConstrained({x:n[0]+e.x,y:n[1]+e.y,zoom:n[2]},[[0,0],[i,a]],r),s=!!o&&(o.x!==n[0]||o.y!==n[1]||o.k!==n[2]);return Promise.resolve(s)}function es(e,t,n,r,i,a){let o=i,s=r.get(o)||new Map;r.set(o,s.set(n,t)),o=`${i}-${e}`;let c=r.get(o)||new Map;if(r.set(o,c.set(n,t)),a){o=`${i}-${e}-${a}`;let s=r.get(o)||new Map;r.set(o,s.set(n,t))}}function ts(e,t,n){e.clear(),t.clear();for(let r of n){let{source:n,target:i,sourceHandle:a=null,targetHandle:o=null}=r,s={edgeId:r.id,source:n,target:i,sourceHandle:a,targetHandle:o},c=`${n}-${a}--${i}-${o}`;es(`source`,s,`${i}-${o}--${n}-${a}`,e,n,a),es(`target`,s,c,e,i,o),t.set(r.id,r)}}function ns(e,t){if(!e.parentId)return!1;let n=t.get(e.parentId);return n?n.selected?!0:ns(n,t):!1}function rs(e,t,n){let r=e;do{if(r?.matches?.(t))return!0;if(r===n)return!1;r=r?.parentElement}while(r);return!1}function is(e,t,n,r){let i=new Map;for(let[a,o]of e)if((o.selected||o.id===r)&&(!o.parentId||!ns(o,e))&&(o.draggable||t&&o.draggable===void 0)){let t=e.get(a);t&&i.set(a,{id:a,position:t.position||{x:0,y:0},distance:{x:n.x-t.internals.positionAbsolute.x,y:n.y-t.internals.positionAbsolute.y},extent:t.extent,parentId:t.parentId,origin:t.origin,expandParent:t.expandParent,internals:{positionAbsolute:t.internals.positionAbsolute||{x:0,y:0}},measured:{width:t.measured.width??0,height:t.measured.height??0}})}return i}function as({nodeId:e,dragItems:t,nodeLookup:n,dragging:r=!0}){let i=[];for(let[e,a]of t){let t=n.get(e)?.internals.userNode;t&&i.push({...t,position:a.position,dragging:r})}if(!e)return[i[0],i];let a=n.get(e)?.internals.userNode;return[a?{...a,position:t.get(e)?.position||a.position,dragging:r}:i[0],i]}function os({dragItems:e,snapGrid:t,x:n,y:r}){let i=e.values().next().value;if(!i)return null;let a={x:n-i.distance.x,y:r-i.distance.y},o=Wa(a,t);return{x:o.x-a.x,y:o.y-a.y}}function ss({onNodeMouseDown:e,getStoreItems:t,onDragStart:n,onDrag:r,onDragStop:i}){let a={x:null,y:null},o=0,s=new Map,c=!1,l={x:0,y:0},u=null,d=!1,f=null,p=!1,m=!1,h=null;function g({noDragClassName:g,handleSelector:_,domNode:v,isSelectable:y,nodeId:b,nodeClickDistance:x=0}){f=K(v);function S({x:e,y:n}){let{nodeLookup:i,nodeExtent:o,snapGrid:c,snapToGrid:l,nodeOrigin:u,onNodeDrag:d,onSelectionDrag:f,onError:p,updateNodePositions:g}=t();a={x:e,y:n};let _=!1,v=s.size>1,y=v&&o?Fa(Sa(s)):null,x=v&&l?os({dragItems:s,snapGrid:c,x:e,y:n}):null;for(let[t,r]of s){if(!i.has(t))continue;let a={x:e-r.distance.x,y:n-r.distance.y};l&&(a=x?{x:Math.round(a.x+x.x),y:Math.round(a.y+x.y)}:Wa(a,c));let s=null;if(v&&o&&!r.extent&&y){let{positionAbsolute:e}=r.internals,t=e.x-y.x+o[0][0],n=e.x+r.measured.width-y.x2+o[1][0],i=e.y-y.y+o[0][1],a=e.y+r.measured.height-y.y2+o[1][1];s=[[t,i],[n,a]]}let{position:d,positionAbsolute:f}=Da({nodeId:t,nextPosition:a,nodeLookup:i,nodeExtent:s||o,nodeOrigin:u,onError:p});_=_||r.position.x!==d.x||r.position.y!==d.y,r.position=d,r.internals.positionAbsolute=f}if(m||=_,_&&(g(s,!0),h&&(r||d||!b&&f))){let[e,t]=as({nodeId:b,dragItems:s,nodeLookup:i});r?.(h,s,e,t),d?.(h,e,t),b||f?.(h,t)}}async function C(){if(!u)return;let{transform:e,panBy:n,autoPanSpeed:r,autoPanOnNodeDrag:i}=t();if(!i){c=!1,cancelAnimationFrame(o);return}let[s,d]=Na(l,u,r);(s!==0||d!==0)&&(a.x=(a.x??0)-s/e[2],a.y=(a.y??0)-d/e[2],await n({x:s,y:d})&&S(a)),o=requestAnimationFrame(C)}function w(r){let{nodeLookup:i,multiSelectionActive:o,nodesDraggable:c,transform:l,snapGrid:f,snapToGrid:p,selectNodesOnDrag:m,onNodeDragStart:h,onSelectionDragStart:g,unselectNodesAndEdges:_}=t();d=!0,(!m||!y)&&!o&&b&&(i.get(b)?.selected||_()),y&&m&&b&&e?.(b);let v=ao(r.sourceEvent,{transform:l,snapGrid:f,snapToGrid:p,containerBounds:u});if(a=v,s=is(i,c,v,b),s.size>0&&(n||h||!b&&g)){let[e,t]=as({nodeId:b,dragItems:s,nodeLookup:i});n?.(r.sourceEvent,s,e,t),h?.(r.sourceEvent,e,t),b||g?.(r.sourceEvent,t)}}let T=Ht().clickDistance(x).on(`start`,e=>{let{domNode:n,nodeDragThreshold:r,transform:i,snapGrid:o,snapToGrid:s}=t();u=n?.getBoundingClientRect()||null,p=!1,m=!1,h=e.sourceEvent,r===0&&w(e),a=ao(e.sourceEvent,{transform:i,snapGrid:o,snapToGrid:s,containerBounds:u}),l=fo(e.sourceEvent,u)}).on(`drag`,e=>{let{autoPanOnNodeDrag:n,transform:r,snapGrid:i,snapToGrid:o,nodeDragThreshold:f,nodeLookup:m}=t(),g=ao(e.sourceEvent,{transform:r,snapGrid:i,snapToGrid:o,containerBounds:u});if(h=e.sourceEvent,(e.sourceEvent.type===`touchmove`&&e.sourceEvent.touches.length>1||b&&!m.has(b))&&(p=!0),!p){if(!c&&n&&d&&(c=!0,C()),!d){let t=fo(e.sourceEvent,u),n=t.x-l.x,r=t.y-l.y;Math.sqrt(n*n+r*r)>f&&w(e)}(a.x!==g.xSnapped||a.y!==g.ySnapped)&&s&&d&&(l=fo(e.sourceEvent,u),S(g))}}).on(`end`,e=>{if(!(!d||p)&&(c=!1,d=!1,cancelAnimationFrame(o),s.size>0)){let{nodeLookup:n,updateNodePositions:r,onNodeDragStop:a,onSelectionDragStop:o}=t();if(m&&=(r(s,!1),!1),i||a||!b&&o){let[t,r]=as({nodeId:b,dragItems:s,nodeLookup:n,dragging:!1});i?.(e.sourceEvent,s,t,r),a?.(e.sourceEvent,t,r),b||o?.(e.sourceEvent,r)}}}).filter(e=>{let t=e.target;return!e.button&&(!g||!rs(t,`.${g}`,v))&&(!_||rs(t,_,v))});f.call(T)}function _(){f?.on(`.drag`,null)}return{update:g,destroy:_}}function cs(e,t,n){let r=[],i={x:e.x-n,y:e.y-n,width:n*2,height:n*2};for(let e of t.values())Ba(i,La(e))>0&&r.push(e);return r}function ls(e,t,n,r){let i=[],a=1/0,o=cs(e,n,t+250);for(let n of o){let o=[...n.internals.handleBounds?.source??[],...n.internals.handleBounds?.target??[]];for(let s of o){if(r.nodeId===s.nodeId&&r.type===s.type&&r.id===s.id)continue;let{x:o,y:c}=Po(n,s,s.position,!0),l=Math.sqrt((o-e.x)**2+(c-e.y)**2);l>t||(l<a?(i=[{...s,x:o,y:c}],a=l):l===a&&i.push({...s,x:o,y:c}))}}if(!i.length)return null;if(i.length>1){let e=r.type===`source`?`target`:`source`;return i.find(t=>t.type===e)??i[0]}return i[0]}function us(e,t,n,r,i,a=!1){let o=r.get(e);if(!o)return null;let s=i===`strict`?o.internals.handleBounds?.[t]:[...o.internals.handleBounds?.source??[],...o.internals.handleBounds?.target??[]],c=(n?s?.find(e=>e.id===n):s?.[0])??null;return c&&a?{...c,...Po(o,c,c.position,!0)}:c}function ds(e,t){return e||(t?.classList.contains(`target`)?`target`:t?.classList.contains(`source`)?`source`:null)}function fs(e,t){let n=null;return t?n=!0:e&&!t&&(n=!1),n}const ps=()=>!0;function ms(e,{connectionMode:t,connectionRadius:n,handleId:r,nodeId:i,edgeUpdaterType:a,isTarget:o,domNode:s,nodeLookup:c,lib:l,autoPanOnConnect:u,flowId:d,panBy:f,cancelConnection:p,onConnectStart:m,onConnect:h,onConnectEnd:g,isValidConnection:_=ps,onReconnectEnd:v,updateConnection:y,getTransform:b,getFromHandle:x,autoPanSpeed:S,dragThreshold:C=1,handleDomNode:w}){let T=so(e.target),E=0,D,{x:O,y:k}=fo(e),A=ds(a,w),j=s?.getBoundingClientRect(),M=!1;if(!j||!A)return;let N=us(i,A,r,c,t);if(!N)return;let P=fo(e,j),F=!1,I=null,L=!1,R=null;function ee(){if(!u||!j)return;let[e,t]=Na(P,j,S);f({x:e,y:t}),E=requestAnimationFrame(ee)}let z={...N,nodeId:i,type:A,position:N.position},B=c.get(i),V={inProgress:!0,isValid:null,from:Po(B,z,X.Left,!0),fromHandle:z,fromPosition:z.position,fromNode:B,to:P,toHandle:null,toPosition:ha[z.position],toNode:null,pointer:P};function H(){M=!0,y(V),m?.(e,{nodeId:i,handleId:r,handleType:A})}C===0&&H();function U(e){if(!M){let{x:t,y:n}=fo(e),r=t-O,i=n-k;if(!(r*r+i*i>C*C))return;H()}if(!x()||!z){W(e);return}let a=b();P=fo(e,j),D=ls(Ga(P,a,!1,[1,1]),n,c,z),F||=(ee(),!0);let s=hs(e,{handle:D,connectionMode:t,fromNodeId:i,fromHandleId:r,fromType:o?`target`:`source`,isValidConnection:_,doc:T,lib:l,flowId:d,nodeLookup:c});R=s.handleDomNode,I=s.connection,L=fs(!!D,s.isValid);let u=c.get(i),f=u?Po(u,z,X.Left,!0):V.from,p={...V,from:f,isValid:L,to:s.toHandle&&L?Ka({x:s.toHandle.x,y:s.toHandle.y},a):P,toHandle:s.toHandle,toPosition:L&&s.toHandle?s.toHandle.position:ha[z.position],toNode:s.toHandle?c.get(s.toHandle.nodeId):null,pointer:P};y(p),V=p}function W(e){if(!(`touches`in e&&e.touches.length>0)){if(M){(D||R)&&I&&L&&h?.(I);let{inProgress:t,...n}=V,r={...n,toPosition:V.toHandle?V.toPosition:null};g?.(e,r),a&&v?.(e,r)}p(),cancelAnimationFrame(E),F=!1,L=!1,I=null,R=null,T.removeEventListener(`mousemove`,U),T.removeEventListener(`mouseup`,W),T.removeEventListener(`touchmove`,U),T.removeEventListener(`touchend`,W)}}T.addEventListener(`mousemove`,U),T.addEventListener(`mouseup`,W),T.addEventListener(`touchmove`,U),T.addEventListener(`touchend`,W)}function hs(e,{handle:t,connectionMode:n,fromNodeId:r,fromHandleId:i,fromType:a,doc:o,lib:s,flowId:c,isValidConnection:l=ps,nodeLookup:u}){let d=a===`target`,f=t?o.querySelector(`.${s}-flow__handle[data-id="${c}-${t?.nodeId}-${t?.id}-${t?.type}"]`):null,{x:p,y:m}=fo(e),h=o.elementFromPoint(p,m),g=h?.classList.contains(`${s}-flow__handle`)?h:f,_={handleDomNode:g,isValid:!1,connection:null,toHandle:null};if(g){let e=ds(void 0,g),t=g.getAttribute(`data-nodeid`),a=g.getAttribute(`data-handleid`),o=g.classList.contains(`connectable`),s=g.classList.contains(`connectableend`);if(!t||!e)return _;let c={source:d?t:r,sourceHandle:d?a:i,target:d?r:t,targetHandle:d?i:a};_.connection=c,_.isValid=o&&s&&(n===la.Strict?d&&e===`source`||!d&&e===`target`:t!==r||a!==i)&&l(c),_.toHandle=us(t,e,a,u,n,!0)}return _}const gs={onPointerDown:ms,isValid:hs};function _s({domNode:e,panZoom:t,getTransform:n,getViewScale:r}){let i=K(e);function a({translateExtent:e,width:a,height:o,zoomStep:s=1,pannable:c=!0,zoomable:l=!0,inversePan:u=!1}){let d=e=>{if(e.sourceEvent.type!==`wheel`||!t)return;let r=n(),i=e.sourceEvent.ctrlKey&&Za()?10:1,a=-e.sourceEvent.deltaY*(e.sourceEvent.deltaMode===1?.05:e.sourceEvent.deltaMode?1:.002)*s,o=r[2]*2**(a*i);t.scaleTo(o)},f=[0,0],p=aa().on(`start`,e=>{(e.sourceEvent.type===`mousedown`||e.sourceEvent.type===`touchstart`)&&(f=[e.sourceEvent.clientX??e.sourceEvent.touches[0].clientX,e.sourceEvent.clientY??e.sourceEvent.touches[0].clientY])}).on(`zoom`,c?i=>{let s=n();if(i.sourceEvent.type!==`mousemove`&&i.sourceEvent.type!==`touchmove`||!t)return;let c=[i.sourceEvent.clientX??i.sourceEvent.touches[0].clientX,i.sourceEvent.clientY??i.sourceEvent.touches[0].clientY],l=[c[0]-f[0],c[1]-f[1]];f=c;let d=r()*Math.max(s[2],Math.log(s[2]))*(u?-1:1),p={x:s[0]-l[0]*d,y:s[1]-l[1]*d},m=[[0,0],[a,o]];t.setViewportConstrained({x:p.x,y:p.y,zoom:s[2]},m,e)}:null).on(`zoom.wheel`,l?d:null);i.call(p,{})}function o(){i.on(`zoom`,null)}return{update:a,destroy:o,pointer:q}}const vs=e=>({x:e.x,y:e.y,zoom:e.k}),ys=({x:e,y:t,zoom:n})=>Yi.translate(e,t).scale(n),bs=(e,t)=>e.target.closest(`.${t}`),xs=(e,t)=>t===2&&Array.isArray(e)&&e.includes(2),Ss=e=>((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2,Cs=(e,t=0,n=Ss,r=()=>{})=>{let i=typeof t==`number`&&t>0;return i||r(),i?e.transition().duration(t).ease(n).on(`end`,r):e},ws=e=>{let t=e.ctrlKey&&Za()?10:1;return-e.deltaY*(e.deltaMode===1?.05:e.deltaMode?1:.002)*t};function Ts({zoomPanValues:e,noWheelClassName:t,d3Selection:n,d3Zoom:r,panOnScrollMode:i,panOnScrollSpeed:a,zoomOnPinch:o,onPanZoomStart:s,onPanZoom:c,onPanZoomEnd:l}){return u=>{if(bs(u,t))return u.ctrlKey&&u.preventDefault(),!1;u.preventDefault(),u.stopImmediatePropagation();let d=n.property(`__zoom`).k||1;if(u.ctrlKey&&o){let e=q(u),t=d*2**ws(u);r.scaleTo(n,t,e,u);return}let f=u.deltaMode===1?20:1,p=i===ua.Vertical?0:u.deltaX*f,m=i===ua.Horizontal?0:u.deltaY*f;!Za()&&u.shiftKey&&i!==ua.Vertical&&(p=u.deltaY*f,m=0),r.translateBy(n,-(p/d)*a,-(m/d)*a,{internal:!0});let h=vs(n.property(`__zoom`));clearTimeout(e.panScrollTimeout),e.isPanScrolling?(c?.(u,h),e.panScrollTimeout=setTimeout(()=>{l?.(u,h),e.isPanScrolling=!1},150)):(e.isPanScrolling=!0,s?.(u,h))}}function Es({noWheelClassName:e,preventScrolling:t,d3ZoomHandler:n}){return function(r,i){let a=r.type===`wheel`,o=!t&&a&&!r.ctrlKey,s=bs(r,e);if(r.ctrlKey&&a&&s&&r.preventDefault(),o||s)return null;r.preventDefault(),n.call(this,r,i)}}function Ds({zoomPanValues:e,onDraggingChange:t,onPanZoomStart:n}){return r=>{if(r.sourceEvent?.internal)return;let i=vs(r.transform);e.mouseButton=r.sourceEvent?.button||0,e.isZoomingOrPanning=!0,e.prevViewport=i,r.sourceEvent?.type===`mousedown`&&t(!0),n&&n?.(r.sourceEvent,i)}}function Os({zoomPanValues:e,panOnDrag:t,onPaneContextMenu:n,onTransformChange:r,onPanZoom:i}){return a=>{e.usedRightMouseButton=!!(n&&xs(t,e.mouseButton??0)),a.sourceEvent?.sync||r([a.transform.x,a.transform.y,a.transform.k]),i&&!a.sourceEvent?.internal&&i?.(a.sourceEvent,vs(a.transform))}}function ks({zoomPanValues:e,panOnDrag:t,panOnScroll:n,onDraggingChange:r,onPanZoomEnd:i,onPaneContextMenu:a}){return o=>{if(!o.sourceEvent?.internal&&(e.isZoomingOrPanning=!1,a&&xs(t,e.mouseButton??0)&&!e.usedRightMouseButton&&o.sourceEvent&&a(o.sourceEvent),e.usedRightMouseButton=!1,r(!1),i)){let t=vs(o.transform);e.prevViewport=t,clearTimeout(e.timerId),e.timerId=setTimeout(()=>{i?.(o.sourceEvent,t)},n?150:0)}}}function As({zoomActivationKeyPressed:e,zoomOnScroll:t,zoomOnPinch:n,panOnDrag:r,panOnScroll:i,zoomOnDoubleClick:a,userSelectionActive:o,noWheelClassName:s,noPanClassName:c,lib:l,connectionInProgress:u}){return d=>{let f=e||t,p=n&&d.ctrlKey,m=d.type===`wheel`;if(d.button===1&&d.type===`mousedown`&&(bs(d,`${l}-flow__node`)||bs(d,`${l}-flow__edge`)))return!0;if(!r&&!f&&!i&&!a&&!n||o||u&&!m||bs(d,s)&&m||bs(d,c)&&(!m||i&&m&&!e)||!n&&d.ctrlKey&&m)return!1;if(!n&&d.type===`touchstart`&&d.touches?.length>1)return d.preventDefault(),!1;if(!f&&!i&&!p&&m||!r&&(d.type===`mousedown`||d.type===`touchstart`)||Array.isArray(r)&&!r.includes(d.button)&&d.type===`mousedown`)return!1;let h=Array.isArray(r)&&r.includes(d.button)||!d.button||d.button<=1;return(!d.ctrlKey||m)&&h}}function js({domNode:e,minZoom:t,maxZoom:n,translateExtent:r,viewport:i,onPanZoom:a,onPanZoomStart:o,onPanZoomEnd:s,onDraggingChange:c}){let l={isZoomingOrPanning:!1,usedRightMouseButton:!1,prevViewport:{x:0,y:0,zoom:0},mouseButton:0,timerId:void 0,panScrollTimeout:void 0,isPanScrolling:!1},u=e.getBoundingClientRect(),d=aa().scaleExtent([t,n]).translateExtent(r),f=K(e).call(d);v({x:i.x,y:i.y,zoom:ka(i.zoom,t,n)},[[0,0],[u.width,u.height]],r);let p=f.on(`wheel.zoom`),m=f.on(`dblclick.zoom`);d.wheelDelta(ws);function h(e,t){return f?new Promise(n=>{d?.interpolate(t?.interpolate===`linear`?Gn:ar).transform(Cs(f,t?.duration,t?.ease,()=>n(!0)),e)}):Promise.resolve(!1)}function g({noWheelClassName:e,noPanClassName:t,onPaneContextMenu:n,userSelectionActive:r,panOnScroll:i,panOnDrag:u,panOnScrollMode:h,panOnScrollSpeed:g,preventScrolling:v,zoomOnPinch:y,zoomOnScroll:b,zoomOnDoubleClick:x,zoomActivationKeyPressed:S,lib:C,onTransformChange:w,connectionInProgress:T,paneClickDistance:E,selectionOnDrag:D}){r&&!l.isZoomingOrPanning&&_();let O=i&&!S&&!r;d.clickDistance(D?1/0:!Ha(E)||E<0?0:E);let k=O?Ts({zoomPanValues:l,noWheelClassName:e,d3Selection:f,d3Zoom:d,panOnScrollMode:h,panOnScrollSpeed:g,zoomOnPinch:y,onPanZoomStart:o,onPanZoom:a,onPanZoomEnd:s}):Es({noWheelClassName:e,preventScrolling:v,d3ZoomHandler:p});if(f.on(`wheel.zoom`,k,{passive:!1}),!r){let e=Ds({zoomPanValues:l,onDraggingChange:c,onPanZoomStart:o});d.on(`start`,e);let t=Os({zoomPanValues:l,panOnDrag:u,onPaneContextMenu:!!n,onPanZoom:a,onTransformChange:w});d.on(`zoom`,t);let r=ks({zoomPanValues:l,panOnDrag:u,panOnScroll:i,onPaneContextMenu:n,onPanZoomEnd:s,onDraggingChange:c});d.on(`end`,r)}let A=As({zoomActivationKeyPressed:S,panOnDrag:u,zoomOnScroll:b,panOnScroll:i,zoomOnDoubleClick:x,zoomOnPinch:y,userSelectionActive:r,noPanClassName:t,noWheelClassName:e,lib:C,connectionInProgress:T});d.filter(A),x?f.on(`dblclick.zoom`,m):f.on(`dblclick.zoom`,null)}function _(){d.on(`zoom`,null)}async function v(e,t,n){let r=ys(e),i=d?.constrain()(r,t,n);return i&&await h(i),new Promise(e=>e(i))}async function y(e,t){let n=ys(e);return await h(n,t),new Promise(e=>e(n))}function b(e){if(f){let t=ys(e),n=f.property(`__zoom`);(n.k!==e.zoom||n.x!==e.x||n.y!==e.y)&&d?.transform(f,t,null,{sync:!0})}}function x(){let e=f?Xi(f.node()):{x:0,y:0,k:1};return{x:e.x,y:e.y,zoom:e.k}}function S(e,t){return f?new Promise(n=>{d?.interpolate(t?.interpolate===`linear`?Gn:ar).scaleTo(Cs(f,t?.duration,t?.ease,()=>n(!0)),e)}):Promise.resolve(!1)}function C(e,t){return f?new Promise(n=>{d?.interpolate(t?.interpolate===`linear`?Gn:ar).scaleBy(Cs(f,t?.duration,t?.ease,()=>n(!0)),e)}):Promise.resolve(!1)}function w(e){d?.scaleExtent(e)}function T(e){d?.translateExtent(e)}function E(e){let t=!Ha(e)||e<0?0:e;d?.clickDistance(t)}return{update:g,destroy:_,setViewport:y,setViewportConstrained:v,getViewport:x,scaleTo:S,scaleBy:C,setScaleExtent:w,setTranslateExtent:T,syncViewport:b,setClickDistance:E}}var Ms;(function(e){e.Line=`line`,e.Handle=`handle`})(Ms||={});function Ns({width:e,prevWidth:t,height:n,prevHeight:r,affectsX:i,affectsY:a}){let o=e-t,s=n-r,c=[o>0?1:o<0?-1:0,s>0?1:s<0?-1:0];return o&&i&&(c[0]*=-1),s&&a&&(c[1]*=-1),c}function Ps(e){return{isHorizontal:e.includes(`right`)||e.includes(`left`),isVertical:e.includes(`bottom`)||e.includes(`top`),affectsX:e.includes(`left`),affectsY:e.includes(`top`)}}function Fs(e,t){return Math.max(0,t-e)}function Is(e,t){return Math.max(0,e-t)}function Ls(e,t,n){return Math.max(0,t-e,e-n)}function Rs(e,t){return e?!t:t}function zs(e,t,n,r,i,a,o,s){let{affectsX:c,affectsY:l}=t,{isHorizontal:u,isVertical:d}=t,f=u&&d,{xSnapped:p,ySnapped:m}=n,{minWidth:h,maxWidth:g,minHeight:_,maxHeight:v}=r,{x:y,y:b,width:x,height:S,aspectRatio:C}=e,w=Math.floor(u?p-e.pointerX:0),T=Math.floor(d?m-e.pointerY:0),E=x+(c?-w:w),D=S+(l?-T:T),O=-a[0]*x,k=-a[1]*S,A=Ls(E,h,g),j=Ls(D,_,v);if(o){let e=0,t=0;c&&w<0?e=Fs(y+w+O,o[0][0]):!c&&w>0&&(e=Is(y+E+O,o[1][0])),l&&T<0?t=Fs(b+T+k,o[0][1]):!l&&T>0&&(t=Is(b+D+k,o[1][1])),A=Math.max(A,e),j=Math.max(j,t)}if(s){let e=0,t=0;c&&w>0?e=Is(y+w,s[0][0]):!c&&w<0&&(e=Fs(y+E,s[1][0])),l&&T>0?t=Is(b+T,s[0][1]):!l&&T<0&&(t=Fs(b+D,s[1][1])),A=Math.max(A,e),j=Math.max(j,t)}if(i){if(u){let e=Ls(E/C,_,v)*C;if(A=Math.max(A,e),o){let e=0;e=!c&&!l||c&&!l&&f?Is(b+k+E/C,o[1][1])*C:Fs(b+k+(c?w:-w)/C,o[0][1])*C,A=Math.max(A,e)}if(s){let e=0;e=!c&&!l||c&&!l&&f?Fs(b+E/C,s[1][1])*C:Is(b+(c?w:-w)/C,s[0][1])*C,A=Math.max(A,e)}}if(d){let e=Ls(D*C,h,g)/C;if(j=Math.max(j,e),o){let e=0;e=!c&&!l||l&&!c&&f?Is(y+D*C+O,o[1][0])/C:Fs(y+(l?T:-T)*C+O,o[0][0])/C,j=Math.max(j,e)}if(s){let e=0;e=!c&&!l||l&&!c&&f?Fs(y+D*C,s[1][0])/C:Is(y+(l?T:-T)*C,s[0][0])/C,j=Math.max(j,e)}}}T+=T<0?j:-j,w+=w<0?A:-A,i&&(f?E>D*C?T=(Rs(c,l)?-w:w)/C:w=(Rs(c,l)?-T:T)*C:u?(T=w/C,l=c):(w=T*C,c=l));let M=c?y+w:y,N=l?b+T:b;return{width:x+(c?-w:w),height:S+(l?-T:T),x:a[0]*w*(c?-1:1)+M,y:a[1]*T*(l?-1:1)+N}}const Bs={width:0,height:0,x:0,y:0},Vs={...Bs,pointerX:0,pointerY:0,aspectRatio:1};function Hs(e){return[[0,0],[e.measured.width,e.measured.height]]}function Us(e,t,n){let r=t.position.x+e.position.x,i=t.position.y+e.position.y,a=e.measured.width??0,o=e.measured.height??0,s=n[0]*a,c=n[1]*o;return[[r-s,i-c],[r+a-s,i+o-c]]}function Ws({domNode:e,nodeId:t,getStoreItems:n,onChange:r,onEnd:i}){let a=K(e),o={controlDirection:Ps(`bottom-right`),boundaries:{minWidth:0,minHeight:0,maxWidth:Number.MAX_VALUE,maxHeight:Number.MAX_VALUE},resizeDirection:void 0,keepAspectRatio:!1};function s({controlPosition:e,boundaries:s,keepAspectRatio:c,resizeDirection:l,onResizeStart:u,onResize:d,onResizeEnd:f,shouldResize:p}){let m={...Bs},h={...Vs};o={boundaries:s,resizeDirection:l,keepAspectRatio:c,controlDirection:Ps(e)};let g,_=null,v=[],y,b,x,S=!1,C=Ht().on(`start`,e=>{let{nodeLookup:r,transform:i,snapGrid:a,snapToGrid:o,nodeOrigin:s,paneDomNode:c}=n();if(g=r.get(t),!g)return;_=c?.getBoundingClientRect()??null;let{xSnapped:l,ySnapped:d}=ao(e.sourceEvent,{transform:i,snapGrid:a,snapToGrid:o,containerBounds:_});m={width:g.measured.width??0,height:g.measured.height??0,x:g.position.x??0,y:g.position.y??0},h={...m,pointerX:l,pointerY:d,aspectRatio:m.width/m.height},y=void 0,g.parentId&&(g.extent===`parent`||g.expandParent)&&(y=r.get(g.parentId),b=y&&g.extent===`parent`?Hs(y):void 0),v=[],x=void 0;for(let[e,n]of r)if(n.parentId===t&&(v.push({id:e,position:{...n.position},extent:n.extent}),n.extent===`parent`||n.expandParent)){let e=Us(n,g,n.origin??s);x=x?[[Math.min(e[0][0],x[0][0]),Math.min(e[0][1],x[0][1])],[Math.max(e[1][0],x[1][0]),Math.max(e[1][1],x[1][1])]]:e}u?.(e,{...m})}).on(`drag`,e=>{let{transform:t,snapGrid:i,snapToGrid:a,nodeOrigin:s}=n(),c=ao(e.sourceEvent,{transform:t,snapGrid:i,snapToGrid:a,containerBounds:_}),l=[];if(!g)return;let{x:u,y:f,width:C,height:w}=m,T={},E=g.origin??s,{width:D,height:O,x:k,y:A}=zs(h,o.controlDirection,c,o.boundaries,o.keepAspectRatio,E,b,x),j=D!==C,M=O!==w,N=k!==u&&j,P=A!==f&&M;if(!N&&!P&&!j&&!M)return;if((N||P||E[0]===1||E[1]===1)&&(T.x=N?k:m.x,T.y=P?A:m.y,m.x=T.x,m.y=T.y,v.length>0)){let e=k-u,t=A-f;for(let n of v)n.position={x:n.position.x-e+E[0]*(D-C),y:n.position.y-t+E[1]*(O-w)},l.push(n)}if((j||M)&&(T.width=j&&(!o.resizeDirection||o.resizeDirection===`horizontal`)?D:m.width,T.height=M&&(!o.resizeDirection||o.resizeDirection===`vertical`)?O:m.height,m.width=T.width,m.height=T.height),y&&g.expandParent){let e=E[0]*(T.width??0);T.x&&T.x<e&&(m.x=e,h.x-=T.x-e);let t=E[1]*(T.height??0);T.y&&T.y<t&&(m.y=t,h.y-=T.y-t)}let F=Ns({width:m.width,prevWidth:C,height:m.height,prevHeight:w,affectsX:o.controlDirection.affectsX,affectsY:o.controlDirection.affectsY}),I={...m,direction:F};p?.(e,I)!==!1&&(S=!0,d?.(e,I),r(T,l))}).on(`end`,e=>{S&&=(f?.(e,{...m}),i?.({...m}),!1)});a.call(C)}function c(){a.on(`.drag`,null)}return{update:s,destroy:c}}const Gs=e=>{let t,n=new Set,r=(e,r)=>{let i=typeof e==`function`?e(t):e;if(!Object.is(i,t)){let e=t;t=r??(typeof i!=`object`||!i)?i:Object.assign({},t,i),n.forEach(n=>n(t,e))}},i=()=>t,a={setState:r,getState:i,getInitialState:()=>o,subscribe:e=>(n.add(e),()=>n.delete(e)),destroy:()=>{(import.meta.env?import.meta.env.MODE:void 0)!==`production`&&console.warn("[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.clear()}},o=t=e(r,i,a);return a},Ks=e=>e?Gs(e):Gs,{useDebugValue:qs}=e,{useSyncExternalStoreWithSelector:Js}=m,Ys=e=>e;function Xs(e,t=Ys,n){let r=Js(e.subscribe,e.getState,e.getServerState||e.getInitialState,t,n);return qs(r),r}const Zs=(e,t)=>{let n=Ks(e),r=(e,r=t)=>Xs(n,e,r);return Object.assign(r,n),r},Qs=(e,t)=>e?Zs(e,t):Zs;function Z(e,t){if(Object.is(e,t))return!0;if(typeof e!=`object`||!e||typeof t!=`object`||!t)return!1;if(e instanceof Map&&t instanceof Map){if(e.size!==t.size)return!1;for(let[n,r]of e)if(!Object.is(r,t.get(n)))return!1;return!0}if(e instanceof Set&&t instanceof Set){if(e.size!==t.size)return!1;for(let n of e)if(!t.has(n))return!1;return!0}let n=Object.keys(e);if(n.length!==Object.keys(t).length)return!1;for(let r of n)if(!Object.prototype.hasOwnProperty.call(t,r)||!Object.is(e[r],t[r]))return!1;return!0}const $s=t(null),ec=$s.Provider,tc=Y.error001();function Q(e,t){let n=a($s);if(n===null)throw Error(tc);return Xs(n,e,t)}function $(){let e=a($s);if(e===null)throw Error(tc);return c(()=>({getState:e.getState,setState:e.setState,subscribe:e.subscribe}),[e])}const nc={display:`none`},rc={position:`absolute`,width:1,height:1,margin:-1,border:0,padding:0,overflow:`hidden`,clip:`rect(0px, 0px, 0px, 0px)`,clipPath:`inset(100%)`},ic=`react-flow__node-desc`,ac=`react-flow__edge-desc`,oc=e=>e.ariaLiveMessage,sc=e=>e.ariaLabelConfig;function cc({rfId:e}){let t=Q(oc);return f(`div`,{id:`react-flow__aria-live-${e}`,"aria-live":`assertive`,"aria-atomic":`true`,style:rc,children:t})}function lc({rfId:e,disableKeyboardA11y:t}){let n=Q(sc);return p(d,{children:[f(`div`,{id:`${ic}-${e}`,style:nc,children:t?n[`node.a11yDescription.default`]:n[`node.a11yDescription.keyboardDisabled`]}),f(`div`,{id:`${ac}-${e}`,style:nc,children:n[`edge.a11yDescription.default`]}),!t&&f(cc,{rfId:e})]})}const uc=n(({position:e=`top-left`,children:t,className:n,style:r,...i},a)=>f(`div`,{className:g([`react-flow__panel`,n,...`${e}`.split(`-`)]),style:r,ref:a,...i,children:t}));uc.displayName=`Panel`;function dc({proOptions:e,position:t=`bottom-right`}){return e?.hideAttribution?null:f(uc,{position:t,className:`react-flow__attribution`,"data-message":`Please only hide this attribution when you are subscribed to React Flow Pro: https://pro.reactflow.dev`,children:f(`a`,{href:`https://reactflow.dev`,target:`_blank`,rel:`noopener noreferrer`,"aria-label":`React Flow attribution`,children:`React Flow`})})}const fc=e=>{let t=[],n=[];for(let[,n]of e.nodeLookup)n.selected&&t.push(n.internals.userNode);for(let[,t]of e.edgeLookup)t.selected&&n.push(t);return{selectedNodes:t,selectedEdges:n}},pc=e=>e.id;function mc(e,t){return Z(e.selectedNodes.map(pc),t.selectedNodes.map(pc))&&Z(e.selectedEdges.map(pc),t.selectedEdges.map(pc))}function hc({onSelectionChange:e}){let t=$(),{selectedNodes:n,selectedEdges:r}=Q(fc,mc);return o(()=>{let i={nodes:n,edges:r};e?.(i),t.getState().onSelectionChangeHandlers.forEach(e=>e(i))},[n,r,e]),null}const gc=e=>!!e.onSelectionChangeHandlers;function _c({onSelectionChange:e}){let t=Q(gc);return e||t?f(hc,{onSelectionChange:e}):null}const vc=typeof window<`u`?s:o,yc=[0,0],bc={x:0,y:0,zoom:1},xc=[...`nodes.edges.defaultNodes.defaultEdges.onConnect.onConnectStart.onConnectEnd.onClickConnectStart.onClickConnectEnd.nodesDraggable.autoPanOnNodeFocus.nodesConnectable.nodesFocusable.edgesFocusable.edgesReconnectable.elevateNodesOnSelect.elevateEdgesOnSelect.minZoom.maxZoom.nodeExtent.onNodesChange.onEdgesChange.elementsSelectable.connectionMode.snapGrid.snapToGrid.translateExtent.connectOnClick.defaultEdgeOptions.fitView.fitViewOptions.onNodesDelete.onEdgesDelete.onDelete.onNodeDrag.onNodeDragStart.onNodeDragStop.onSelectionDrag.onSelectionDragStart.onSelectionDragStop.onMoveStart.onMove.onMoveEnd.noPanClassName.nodeOrigin.autoPanOnConnect.autoPanOnNodeDrag.onError.connectionRadius.isValidConnection.selectNodesOnDrag.nodeDragThreshold.connectionDragThreshold.onBeforeDelete.debug.autoPanSpeed.ariaLabelConfig.zIndexMode`.split(`.`),`rfId`],Sc=e=>({setNodes:e.setNodes,setEdges:e.setEdges,setMinZoom:e.setMinZoom,setMaxZoom:e.setMaxZoom,setTranslateExtent:e.setTranslateExtent,setNodeExtent:e.setNodeExtent,reset:e.reset,setDefaultNodesAndEdges:e.setDefaultNodesAndEdges}),Cc={translateExtent:oa,nodeOrigin:yc,minZoom:.5,maxZoom:2,elementsSelectable:!0,noPanClassName:`nopan`,rfId:`1`};function wc(e){let{setNodes:t,setEdges:n,setMinZoom:r,setMaxZoom:i,setTranslateExtent:a,setNodeExtent:o,reset:s,setDefaultNodesAndEdges:c}=Q(Sc,Z),u=$();vc(()=>(c(e.defaultNodes,e.defaultEdges),()=>{d.current=Cc,s()}),[]);let d=l(Cc);return vc(()=>{for(let s of xc){let c=e[s];c!==d.current[s]&&e[s]!==void 0&&(s===`nodes`?t(c):s===`edges`?n(c):s===`minZoom`?r(c):s===`maxZoom`?i(c):s===`translateExtent`?a(c):s===`nodeExtent`?o(c):s===`ariaLabelConfig`?u.setState({ariaLabelConfig:io(c)}):s===`fitView`?u.setState({fitViewQueued:c}):s===`fitViewOptions`?u.setState({fitViewOptions:c}):u.setState({[s]:c}))}d.current=e},xc.map(t=>e[t])),null}function Tc(){return typeof window>`u`||!window.matchMedia?null:window.matchMedia(`(prefers-color-scheme: dark)`)}function Ec(e){let[t,n]=u(e===`system`?null:e);return o(()=>{if(e!==`system`){n(e);return}let t=Tc(),r=()=>n(t?.matches?`dark`:`light`);return r(),t?.addEventListener(`change`,r),()=>{t?.removeEventListener(`change`,r)}},[e]),t===null?Tc()?.matches?`dark`:`light`:t}const Dc=typeof document<`u`?document:null;function Oc(e=null,t={target:Dc,actInsideInputWithModifier:!0}){let[n,r]=u(!1),i=l(!1),a=l(new Set([])),[s,d]=c(()=>{if(e!==null){let t=(Array.isArray(e)?e:[e]).filter(e=>typeof e==`string`).map(e=>e.replace(`+`,`
2
+ `).replace(`
3
+
4
+ `,`
5
+ +`).split(`
6
+ `));return[t,t.reduce((e,t)=>e.concat(...t),[])]}return[[],[]]},[e]);return o(()=>{let n=t?.target??Dc,o=t?.actInsideInputWithModifier??!0;if(e!==null){let e=e=>{if(i.current=e.ctrlKey||e.metaKey||e.shiftKey||e.altKey,(!i.current||i.current&&!o)&&lo(e))return!1;let n=Ac(e.code,d);if(a.current.add(e[n]),kc(s,a.current,!1)){let n=e.composedPath?.()?.[0]||e.target,a=n?.nodeName===`BUTTON`||n?.nodeName===`A`;t.preventDefault!==!1&&(i.current||!a)&&e.preventDefault(),r(!0)}},c=e=>{let t=Ac(e.code,d);kc(s,a.current,!0)?(r(!1),a.current.clear()):a.current.delete(e[t]),e.key===`Meta`&&a.current.clear(),i.current=!1},l=()=>{a.current.clear(),r(!1)};return n?.addEventListener(`keydown`,e),n?.addEventListener(`keyup`,c),window.addEventListener(`blur`,l),window.addEventListener(`contextmenu`,l),()=>{n?.removeEventListener(`keydown`,e),n?.removeEventListener(`keyup`,c),window.removeEventListener(`blur`,l),window.removeEventListener(`contextmenu`,l)}}},[e,r]),n}function kc(e,t,n){return e.filter(e=>n||e.length===t.size).some(e=>e.every(e=>t.has(e)))}function Ac(e,t){return t.includes(e)?`code`:`key`}const jc=()=>{let e=$();return c(()=>({zoomIn:t=>{let{panZoom:n}=e.getState();return n?n.scaleBy(1.2,t):Promise.resolve(!1)},zoomOut:t=>{let{panZoom:n}=e.getState();return n?n.scaleBy(1/1.2,t):Promise.resolve(!1)},zoomTo:(t,n)=>{let{panZoom:r}=e.getState();return r?r.scaleTo(t,n):Promise.resolve(!1)},getZoom:()=>e.getState().transform[2],setViewport:async(t,n)=>{let{transform:[r,i,a],panZoom:o}=e.getState();return o?(await o.setViewport({x:t.x??r,y:t.y??i,zoom:t.zoom??a},n),Promise.resolve(!0)):Promise.resolve(!1)},getViewport:()=>{let[t,n,r]=e.getState().transform;return{x:t,y:n,zoom:r}},setCenter:async(t,n,r)=>e.getState().setCenter(t,n,r),fitBounds:async(t,n)=>{let{width:r,height:i,minZoom:a,maxZoom:o,panZoom:s}=e.getState(),c=Xa(t,r,i,a,o,n?.padding??.1);return s?(await s.setViewport(c,{duration:n?.duration,ease:n?.ease,interpolate:n?.interpolate}),Promise.resolve(!0)):Promise.resolve(!1)},screenToFlowPosition:(t,n={})=>{let{transform:r,snapGrid:i,snapToGrid:a,domNode:o}=e.getState();if(!o)return t;let{x:s,y:c}=o.getBoundingClientRect(),l={x:t.x-s,y:t.y-c},u=n.snapGrid??i;return Ga(l,r,n.snapToGrid??a,u)},flowToScreenPosition:t=>{let{transform:n,domNode:r}=e.getState();if(!r)return t;let{x:i,y:a}=r.getBoundingClientRect(),o=Ka(t,n);return{x:o.x+i,y:o.y+a}}}),[])};function Mc(e,t){let n=[],r=new Map,i=[];for(let t of e)if(t.type===`add`){i.push(t);continue}else if(t.type===`remove`||t.type===`replace`)r.set(t.id,[t]);else{let e=r.get(t.id);e?e.push(t):r.set(t.id,[t])}for(let e of t){let t=r.get(e.id);if(!t){n.push(e);continue}if(t[0].type===`remove`)continue;if(t[0].type===`replace`){n.push({...t[0].item});continue}let i={...e};for(let e of t)Nc(e,i);n.push(i)}return i.length&&i.forEach(e=>{e.index===void 0?n.push({...e.item}):n.splice(e.index,0,{...e.item})}),n}function Nc(e,t){switch(e.type){case`select`:t.selected=e.selected;break;case`position`:e.position!==void 0&&(t.position=e.position),e.dragging!==void 0&&(t.dragging=e.dragging);break;case`dimensions`:e.dimensions!==void 0&&(t.measured={...e.dimensions},e.setAttributes&&((e.setAttributes===!0||e.setAttributes===`width`)&&(t.width=e.dimensions.width),(e.setAttributes===!0||e.setAttributes===`height`)&&(t.height=e.dimensions.height))),typeof e.resizing==`boolean`&&(t.resizing=e.resizing);break}}function Pc(e,t){return Mc(e,t)}function Fc(e,t){return Mc(e,t)}function Ic(e,t){return{id:e,type:`select`,selected:t}}function Lc(e,t=new Set,n=!1){let r=[];for(let[i,a]of e){let e=t.has(i);!(a.selected===void 0&&!e)&&a.selected!==e&&(n&&(a.selected=e),r.push(Ic(a.id,e)))}return r}function Rc({items:e=[],lookup:t}){let n=[],r=new Map(e.map(e=>[e.id,e]));for(let[r,i]of e.entries()){let e=t.get(i.id),a=e?.internals?.userNode??e;a!==void 0&&a!==i&&n.push({id:i.id,item:i,type:`replace`}),a===void 0&&n.push({item:i,type:`add`,index:r})}for(let[e]of t)r.get(e)===void 0&&n.push({id:e,type:`remove`});return n}function zc(e){return{id:e.id,type:`remove`}}const Bc=e=>va(e),Vc=e=>_a(e);function Hc(e){return n(e)}function Uc(e){let[t,n]=u(BigInt(0)),[r]=u(()=>Wc(()=>n(e=>e+BigInt(1))));return vc(()=>{let t=r.get();t.length&&(e(t),r.reset())},[t]),r}function Wc(e){let t=[];return{get:()=>t,reset:()=>{t=[]},push:n=>{t.push(n),e()}}}const Gc=t(null);function Kc({children:e}){let t=$(),n=Uc(i(e=>{let{nodes:n=[],setNodes:r,hasDefaultNodes:i,onNodesChange:a,nodeLookup:o,fitViewQueued:s,onNodesChangeMiddlewareMap:c}=t.getState(),l=n;for(let t of e)l=typeof t==`function`?t(l):t;let u=Rc({items:l,lookup:o});for(let e of c.values())u=e(u);i&&r(l),u.length>0?a?.(u):s&&window.requestAnimationFrame(()=>{let{fitViewQueued:e,nodes:n,setNodes:r}=t.getState();e&&r(n)})},[])),r=Uc(i(e=>{let{edges:n=[],setEdges:r,hasDefaultEdges:i,onEdgesChange:a,edgeLookup:o}=t.getState(),s=n;for(let t of e)s=typeof t==`function`?t(s):t;i?r(s):a&&a(Rc({items:s,lookup:o}))},[])),a=c(()=>({nodeQueue:n,edgeQueue:r}),[]);return f(Gc.Provider,{value:a,children:e})}function qc(){let e=a(Gc);if(!e)throw Error(`useBatchContext must be used within a BatchProvider`);return e}const Jc=e=>!!e.panZoom;function Yc(){let e=jc(),t=$(),n=qc(),r=Q(Jc),i=c(()=>{let e=e=>t.getState().nodeLookup.get(e),r=e=>{n.nodeQueue.push(e)},i=e=>{n.edgeQueue.push(e)},a=e=>{let{nodeLookup:n,nodeOrigin:r}=t.getState(),i=Bc(e)?e:n.get(e.id),a=i.parentId?to(i.position,i.measured,i.parentId,n,r):i.position;return La({...i,position:a,width:i.measured?.width??i.width,height:i.measured?.height??i.height})},o=(e,t,n={replace:!1})=>{r(r=>r.map(r=>{if(r.id===e){let e=typeof t==`function`?t(r):t;return n.replace&&Bc(e)?e:{...r,...e}}return r}))},s=(e,t,n={replace:!1})=>{i(r=>r.map(r=>{if(r.id===e){let e=typeof t==`function`?t(r):t;return n.replace&&Vc(e)?e:{...r,...e}}return r}))};return{getNodes:()=>t.getState().nodes.map(e=>({...e})),getNode:t=>e(t)?.internals.userNode,getInternalNode:e,getEdges:()=>{let{edges:e=[]}=t.getState();return e.map(e=>({...e}))},getEdge:e=>t.getState().edgeLookup.get(e),setNodes:r,setEdges:i,addNodes:e=>{let t=Array.isArray(e)?e:[e];n.nodeQueue.push(e=>[...e,...t])},addEdges:e=>{let t=Array.isArray(e)?e:[e];n.edgeQueue.push(e=>[...e,...t])},toObject:()=>{let{nodes:e=[],edges:n=[],transform:r}=t.getState(),[i,a,o]=r;return{nodes:e.map(e=>({...e})),edges:n.map(e=>({...e})),viewport:{x:i,y:a,zoom:o}}},deleteElements:async({nodes:e=[],edges:n=[]})=>{let{nodes:r,edges:i,onNodesDelete:a,onEdgesDelete:o,triggerNodeChanges:s,triggerEdgeChanges:c,onDelete:l,onBeforeDelete:u}=t.getState(),{nodes:d,edges:f}=await Oa({nodesToRemove:e,edgesToRemove:n,nodes:r,edges:i,onBeforeDelete:u}),p=f.length>0,m=d.length>0;if(p){let e=f.map(zc);o?.(f),c(e)}if(m){let e=d.map(zc);a?.(d),s(e)}return(m||p)&&l?.({nodes:d,edges:f}),{deletedNodes:d,deletedEdges:f}},getIntersectingNodes:(e,n=!0,r)=>{let i=Va(e),o=i?e:a(e),s=r!==void 0;return o?(r||t.getState().nodes).filter(r=>{let a=t.getState().nodeLookup.get(r.id);if(a&&!i&&(r.id===e.id||!a.internals.positionAbsolute))return!1;let c=La(s?r:a),l=Ba(c,o);return n&&l>0||l>=c.width*c.height||l>=o.width*o.height}):[]},isNodeIntersecting:(e,t,n=!0)=>{let r=Va(e)?e:a(e);if(!r)return!1;let i=Ba(r,t);return n&&i>0||i>=t.width*t.height||i>=r.width*r.height},updateNode:o,updateNodeData:(e,t,n={replace:!1})=>{o(e,e=>{let r=typeof t==`function`?t(e):t;return n.replace?{...e,data:r}:{...e,data:{...e.data,...r}}},n)},updateEdge:s,updateEdgeData:(e,t,n={replace:!1})=>{s(e,e=>{let r=typeof t==`function`?t(e):t;return n.replace?{...e,data:r}:{...e,data:{...e.data,...r}}},n)},getNodesBounds:e=>{let{nodeLookup:n,nodeOrigin:r}=t.getState();return xa(e,{nodeLookup:n,nodeOrigin:r})},getHandleConnections:({type:e,id:n,nodeId:r})=>Array.from(t.getState().connectionLookup.get(`${r}-${e}${n?`-${n}`:``}`)?.values()??[]),getNodeConnections:({type:e,handleId:n,nodeId:r})=>Array.from(t.getState().connectionLookup.get(`${r}${e?n?`-${e}-${n}`:`-${e}`:``}`)?.values()??[]),fitView:async e=>{let r=t.getState().fitViewResolver??ro();return t.setState({fitViewQueued:!0,fitViewOptions:e,fitViewResolver:r}),n.nodeQueue.push(e=>[...e]),r.promise}}},[]);return c(()=>({...i,...e,viewportInitialized:r}),[r])}const Xc=e=>e.selected,Zc=typeof window<`u`?window:void 0;function Qc({deleteKeyCode:e,multiSelectionKeyCode:t}){let n=$(),{deleteElements:r}=Yc(),i=Oc(e,{actInsideInputWithModifier:!1}),a=Oc(t,{target:Zc});o(()=>{if(i){let{edges:e,nodes:t}=n.getState();r({nodes:t.filter(Xc),edges:e.filter(Xc)}),n.setState({nodesSelectionActive:!1})}},[i]),o(()=>{n.setState({multiSelectionActive:a})},[a])}function $c(e){let t=$();o(()=>{let n=()=>{if(!e.current||!(e.current.checkVisibility?.()??!0))return!1;let n=oo(e.current);(n.height===0||n.width===0)&&t.getState().onError?.(`004`,Y.error004()),t.setState({width:n.width||500,height:n.height||500})};if(e.current){n(),window.addEventListener(`resize`,n);let t=new ResizeObserver(()=>n());return t.observe(e.current),()=>{window.removeEventListener(`resize`,n),t&&e.current&&t.unobserve(e.current)}}},[])}const el={position:`absolute`,width:`100%`,height:`100%`,top:0,left:0},tl=e=>({userSelectionActive:e.userSelectionActive,lib:e.lib,connectionInProgress:e.connection.inProgress});function nl({onPaneContextMenu:e,zoomOnScroll:t=!0,zoomOnPinch:n=!0,panOnScroll:r=!1,panOnScrollSpeed:a=.5,panOnScrollMode:s=ua.Free,zoomOnDoubleClick:c=!0,panOnDrag:u=!0,defaultViewport:d,translateExtent:p,minZoom:m,maxZoom:h,zoomActivationKeyCode:g,preventScrolling:_=!0,children:v,noWheelClassName:y,noPanClassName:b,onViewportChange:x,isControlledViewport:S,paneClickDistance:C,selectionOnDrag:w}){let T=$(),E=l(null),{userSelectionActive:D,lib:O,connectionInProgress:k}=Q(tl,Z),A=Oc(g),j=l();$c(E);let M=i(e=>{x?.({x:e[0],y:e[1],zoom:e[2]}),S||T.setState({transform:e})},[x,S]);return o(()=>{if(E.current){j.current=js({domNode:E.current,minZoom:m,maxZoom:h,translateExtent:p,viewport:d,onDraggingChange:e=>T.setState(t=>t.paneDragging===e?t:{paneDragging:e}),onPanZoomStart:(e,t)=>{let{onViewportChangeStart:n,onMoveStart:r}=T.getState();r?.(e,t),n?.(t)},onPanZoom:(e,t)=>{let{onViewportChange:n,onMove:r}=T.getState();r?.(e,t),n?.(t)},onPanZoomEnd:(e,t)=>{let{onViewportChangeEnd:n,onMoveEnd:r}=T.getState();r?.(e,t),n?.(t)}});let{x:e,y:t,zoom:n}=j.current.getViewport();return T.setState({panZoom:j.current,transform:[e,t,n],domNode:E.current.closest(`.react-flow`)}),()=>{j.current?.destroy()}}},[]),o(()=>{j.current?.update({onPaneContextMenu:e,zoomOnScroll:t,zoomOnPinch:n,panOnScroll:r,panOnScrollSpeed:a,panOnScrollMode:s,zoomOnDoubleClick:c,panOnDrag:u,zoomActivationKeyPressed:A,preventScrolling:_,noPanClassName:b,userSelectionActive:D,noWheelClassName:y,lib:O,onTransformChange:M,connectionInProgress:k,selectionOnDrag:w,paneClickDistance:C})},[e,t,n,r,a,s,c,u,A,_,b,D,y,O,M,k,w,C]),f(`div`,{className:`react-flow__renderer`,ref:E,style:el,children:v})}const rl=e=>({userSelectionActive:e.userSelectionActive,userSelectionRect:e.userSelectionRect});function il(){let{userSelectionActive:e,userSelectionRect:t}=Q(rl,Z);return e&&t?f(`div`,{className:`react-flow__selection react-flow__container`,style:{width:t.width,height:t.height,transform:`translate(${t.x}px, ${t.y}px)`}}):null}const al=(e,t)=>n=>{n.target===t.current&&e?.(n)},ol=e=>({userSelectionActive:e.userSelectionActive,elementsSelectable:e.elementsSelectable,connectionInProgress:e.connection.inProgress,dragging:e.paneDragging});function sl({isSelecting:e,selectionKeyPressed:t,selectionMode:n=da.Full,panOnDrag:r,paneClickDistance:i,selectionOnDrag:a,onSelectionStart:o,onSelectionEnd:s,onPaneClick:c,onPaneContextMenu:u,onPaneScroll:d,onPaneMouseEnter:m,onPaneMouseMove:h,onPaneMouseLeave:_,children:v}){let y=$(),{userSelectionActive:b,elementsSelectable:x,dragging:S,connectionInProgress:C}=Q(ol,Z),w=x&&(e||b),T=l(null),E=l(),D=l(new Set),O=l(new Set),k=l(!1),A=e=>{if(k.current||C){k.current=!1;return}c?.(e),y.getState().resetSelectedElements(),y.setState({nodesSelectionActive:!1})},j=e=>{if(Array.isArray(r)&&r?.includes(2)){e.preventDefault();return}u?.(e)},M=d?e=>d(e):void 0;return p(`div`,{className:g([`react-flow__pane`,{draggable:r===!0||Array.isArray(r)&&r.includes(0),dragging:S,selection:e}]),onClick:w?void 0:al(A,T),onContextMenu:al(j,T),onWheel:al(M,T),onPointerEnter:w?void 0:m,onPointerMove:w?e=>{let{userSelectionRect:r,transform:a,nodeLookup:s,edgeLookup:c,connectionLookup:l,triggerNodeChanges:u,triggerEdgeChanges:d,defaultEdgeOptions:f,resetSelectedElements:p}=y.getState();if(!E.current||!r)return;let{x:m,y:h}=fo(e.nativeEvent,E.current),{startX:g,startY:_}=r;if(!k.current){let n=t?0:i;if(Math.hypot(m-g,h-_)<=n)return;p(),o?.(e)}k.current=!0;let v={startX:g,startY:_,x:m<g?m:g,y:h<_?h:_,width:Math.abs(m-g),height:Math.abs(h-_)},b=D.current,x=O.current;D.current=new Set(Ca(s,v,a,n===da.Partial,!0).map(e=>e.id)),O.current=new Set;let S=f?.selectable??!0;for(let e of D.current){let t=l.get(e);if(t)for(let{edgeId:e}of t.values()){let t=c.get(e);t&&(t.selectable??S)&&O.current.add(e)}}no(b,D.current)||u(Lc(s,D.current,!0)),no(x,O.current)||d(Lc(c,O.current)),y.setState({userSelectionRect:v,userSelectionActive:!0,nodesSelectionActive:!1})}:h,onPointerUp:w?e=>{e.button===0&&(e.target?.releasePointerCapture?.(e.pointerId),!b&&e.target===T.current&&y.getState().userSelectionRect&&A?.(e),y.setState({userSelectionActive:!1,userSelectionRect:null}),k.current&&(s?.(e),y.setState({nodesSelectionActive:D.current.size>0})))}:void 0,onPointerDownCapture:w?n=>{let{domNode:r}=y.getState();if(E.current=r?.getBoundingClientRect(),!E.current)return;let i=n.target===T.current;if(!i&&n.target.closest(`.nokey`)||!e||!(a&&i||t)||n.button!==0||!n.isPrimary)return;n.target?.setPointerCapture?.(n.pointerId),k.current=!1;let{x:o,y:s}=fo(n.nativeEvent,E.current);y.setState({userSelectionRect:{width:0,height:0,startX:o,startY:s,x:o,y:s}}),i||(n.stopPropagation(),n.preventDefault())}:void 0,onClickCapture:w?e=>{k.current&&=(e.stopPropagation(),!1)}:void 0,onPointerLeave:_,ref:T,style:el,children:[v,f(il,{})]})}function cl({id:e,store:t,unselect:n=!1,nodeRef:r}){let{addSelectedNodes:i,unselectNodesAndEdges:a,multiSelectionActive:o,nodeLookup:s,onError:c}=t.getState(),l=s.get(e);if(!l){c?.(`012`,Y.error012(e));return}t.setState({nodesSelectionActive:!1}),l.selected?(n||l.selected&&o)&&(a({nodes:[l],edges:[]}),requestAnimationFrame(()=>r?.current?.blur())):i([e])}function ll({nodeRef:e,disabled:t=!1,noDragClassName:n,handleSelector:r,nodeId:i,isSelectable:a,nodeClickDistance:s}){let c=$(),[d,f]=u(!1),p=l();return o(()=>{p.current=ss({getStoreItems:()=>c.getState(),onNodeMouseDown:t=>{cl({id:t,store:c,nodeRef:e})},onDragStart:()=>{f(!0)},onDragStop:()=>{f(!1)}})},[]),o(()=>{if(!(t||!e.current||!p.current))return p.current.update({noDragClassName:n,handleSelector:r,domNode:e.current,isSelectable:a,nodeId:i,nodeClickDistance:s}),()=>{p.current?.destroy()}},[n,r,t,a,e,i,s]),d}const ul=e=>t=>t.selected&&(t.draggable||e&&t.draggable===void 0);function dl(){let e=$();return i(t=>{let{nodeExtent:n,snapToGrid:r,snapGrid:i,nodesDraggable:a,onError:o,updateNodePositions:s,nodeLookup:c,nodeOrigin:l}=e.getState(),u=new Map,d=ul(a),f=r?i[0]:5,p=r?i[1]:5,m=t.direction.x*f*t.factor,h=t.direction.y*p*t.factor;for(let[,e]of c){if(!d(e))continue;let t={x:e.internals.positionAbsolute.x+m,y:e.internals.positionAbsolute.y+h};r&&(t=Wa(t,i));let{position:a,positionAbsolute:s}=Da({nodeId:e.id,nextPosition:t,nodeLookup:c,nodeExtent:n,nodeOrigin:l,onError:o});e.position=a,e.internals.positionAbsolute=s,u.set(e.id,e)}s(u)},[])}const fl=t(null),pl=fl.Provider;fl.Consumer;const ml=()=>a(fl),hl=e=>({connectOnClick:e.connectOnClick,noPanClassName:e.noPanClassName,rfId:e.rfId}),gl=(e,t,n)=>r=>{let{connectionClickStartHandle:i,connectionMode:a,connection:o}=r,{fromHandle:s,toHandle:c,isValid:l}=o,u=c?.nodeId===e&&c?.id===t&&c?.type===n;return{connectingFrom:s?.nodeId===e&&s?.id===t&&s?.type===n,connectingTo:u,clickConnecting:i?.nodeId===e&&i?.id===t&&i?.type===n,isPossibleEndHandle:a===la.Strict?s?.type!==n:e!==s?.nodeId||t!==s?.id,connectionInProcess:!!s,clickConnectionInProcess:!!i,valid:u&&l}};function _l({type:e=`source`,position:t=X.Top,isValidConnection:n,isConnectable:r=!0,isConnectableStart:i=!0,isConnectableEnd:a=!0,id:o,onConnect:s,children:c,className:l,onMouseDown:u,onTouchStart:d,...p},m){let h=o||null,_=e===`target`,v=$(),y=ml(),{connectOnClick:b,noPanClassName:x,rfId:S}=Q(hl,Z),{connectingFrom:C,connectingTo:w,clickConnecting:T,isPossibleEndHandle:E,connectionInProcess:D,clickConnectionInProcess:O,valid:k}=Q(gl(y,h,e),Z);y||v.getState().onError?.(`010`,Y.error010());let A=e=>{let{defaultEdgeOptions:t,onConnect:n,hasDefaultEdges:r}=v.getState(),i={...t,...e};if(r){let{edges:e,setEdges:t}=v.getState();t(Co(i,e))}n?.(i),s?.(i)},j=e=>{if(!y)return;let t=uo(e.nativeEvent);if(i&&(t&&e.button===0||!t)){let t=v.getState();gs.onPointerDown(e.nativeEvent,{handleDomNode:e.currentTarget,autoPanOnConnect:t.autoPanOnConnect,connectionMode:t.connectionMode,connectionRadius:t.connectionRadius,domNode:t.domNode,nodeLookup:t.nodeLookup,lib:t.lib,isTarget:_,handleId:h,nodeId:y,flowId:t.rfId,panBy:t.panBy,cancelConnection:t.cancelConnection,onConnectStart:t.onConnectStart,onConnectEnd:(...e)=>v.getState().onConnectEnd?.(...e),updateConnection:t.updateConnection,onConnect:A,isValidConnection:n||((...e)=>v.getState().isValidConnection?.(...e)??!0),getTransform:()=>v.getState().transform,getFromHandle:()=>v.getState().connection.fromHandle,autoPanSpeed:t.autoPanSpeed,dragThreshold:t.connectionDragThreshold})}t?u?.(e):d?.(e)};return f(`div`,{"data-handleid":h,"data-nodeid":y,"data-handlepos":t,"data-id":`${S}-${y}-${h}-${e}`,className:g([`react-flow__handle`,`react-flow__handle-${t}`,`nodrag`,x,l,{source:!_,target:_,connectable:r,connectablestart:i,connectableend:a,clickconnecting:T,connectingfrom:C,connectingto:w,valid:k,connectionindicator:r&&(!D||E)&&(D||O?a:i)}]),onMouseDown:j,onTouchStart:j,onClick:b?t=>{let{onClickConnectStart:r,onClickConnectEnd:a,connectionClickStartHandle:o,connectionMode:s,isValidConnection:c,lib:l,rfId:u,nodeLookup:d,connection:f}=v.getState();if(!y||!o&&!i)return;if(!o){r?.(t.nativeEvent,{nodeId:y,handleId:h,handleType:e}),v.setState({connectionClickStartHandle:{nodeId:y,type:e,id:h}});return}let p=so(t.target),m=n||c,{connection:g,isValid:_}=gs.isValid(t.nativeEvent,{handle:{nodeId:y,id:h,type:e},connectionMode:s,fromNodeId:o.nodeId,fromHandleId:o.id||null,fromType:o.type,isValidConnection:m,flowId:u,doc:p,lib:l,nodeLookup:d});_&&g&&A(g);let b=structuredClone(f);delete b.inProgress,b.toPosition=b.toHandle?b.toHandle.position:null,a?.(t,b),v.setState({connectionClickStartHandle:null})}:void 0,ref:m,...p,children:c})}const vl=r(Hc(_l));function yl({data:e,isConnectable:t,sourcePosition:n=X.Bottom}){return p(d,{children:[e?.label,f(vl,{type:`source`,position:n,isConnectable:t})]})}function bl({data:e,isConnectable:t,targetPosition:n=X.Top,sourcePosition:r=X.Bottom}){return p(d,{children:[f(vl,{type:`target`,position:n,isConnectable:t}),e?.label,f(vl,{type:`source`,position:r,isConnectable:t})]})}function xl(){return null}function Sl({data:e,isConnectable:t,targetPosition:n=X.Top}){return p(d,{children:[f(vl,{type:`target`,position:n,isConnectable:t}),e?.label]})}const Cl={ArrowUp:{x:0,y:-1},ArrowDown:{x:0,y:1},ArrowLeft:{x:-1,y:0},ArrowRight:{x:1,y:0}},wl={input:yl,default:bl,output:Sl,group:xl};function Tl(e){return e.internals.handleBounds===void 0?{width:e.width??e.initialWidth??e.style?.width,height:e.height??e.initialHeight??e.style?.height}:{width:e.width??e.style?.width,height:e.height??e.style?.height}}const El=e=>{let{width:t,height:n,x:r,y:i}=Sa(e.nodeLookup,{filter:e=>!!e.selected});return{width:Ha(t)?t:null,height:Ha(n)?n:null,userSelectionActive:e.userSelectionActive,transformString:`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]}) translate(${r}px,${i}px)`}};function Dl({onSelectionContextMenu:e,noPanClassName:t,disableKeyboardA11y:n}){let r=$(),{width:i,height:a,transformString:s,userSelectionActive:c}=Q(El,Z),u=dl(),d=l(null);o(()=>{n||d.current?.focus({preventScroll:!0})},[n]);let p=!c&&i!==null&&a!==null;if(ll({nodeRef:d,disabled:!p}),!p)return null;let m=e?t=>{e(t,r.getState().nodes.filter(e=>e.selected))}:void 0;return f(`div`,{className:g([`react-flow__nodesselection`,`react-flow__container`,t]),style:{transform:s},children:f(`div`,{ref:d,className:`react-flow__nodesselection-rect`,onContextMenu:m,tabIndex:n?void 0:-1,onKeyDown:n?void 0:e=>{Object.prototype.hasOwnProperty.call(Cl,e.key)&&(e.preventDefault(),u({direction:Cl[e.key],factor:e.shiftKey?4:1}))},style:{width:i,height:a}})})}const Ol=typeof window<`u`?window:void 0,kl=e=>({nodesSelectionActive:e.nodesSelectionActive,userSelectionActive:e.userSelectionActive});function Al({children:e,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:r,onPaneMouseLeave:i,onPaneContextMenu:a,onPaneScroll:o,paneClickDistance:s,deleteKeyCode:c,selectionKeyCode:l,selectionOnDrag:u,selectionMode:d,onSelectionStart:m,onSelectionEnd:h,multiSelectionKeyCode:g,panActivationKeyCode:_,zoomActivationKeyCode:v,elementsSelectable:y,zoomOnScroll:b,zoomOnPinch:x,panOnScroll:S,panOnScrollSpeed:C,panOnScrollMode:w,zoomOnDoubleClick:T,panOnDrag:E,defaultViewport:D,translateExtent:O,minZoom:k,maxZoom:A,preventScrolling:j,onSelectionContextMenu:M,noWheelClassName:N,noPanClassName:P,disableKeyboardA11y:F,onViewportChange:I,isControlledViewport:L}){let{nodesSelectionActive:R,userSelectionActive:ee}=Q(kl,Z),z=Oc(l,{target:Ol}),B=Oc(_,{target:Ol}),V=B||E,H=B||S,U=u&&V!==!0,W=z||ee||U;return Qc({deleteKeyCode:c,multiSelectionKeyCode:g}),f(nl,{onPaneContextMenu:a,elementsSelectable:y,zoomOnScroll:b,zoomOnPinch:x,panOnScroll:H,panOnScrollSpeed:C,panOnScrollMode:w,zoomOnDoubleClick:T,panOnDrag:!z&&V,defaultViewport:D,translateExtent:O,minZoom:k,maxZoom:A,zoomActivationKeyCode:v,preventScrolling:j,noWheelClassName:N,noPanClassName:P,onViewportChange:I,isControlledViewport:L,paneClickDistance:s,selectionOnDrag:U,children:p(sl,{onSelectionStart:m,onSelectionEnd:h,onPaneClick:t,onPaneMouseEnter:n,onPaneMouseMove:r,onPaneMouseLeave:i,onPaneContextMenu:a,onPaneScroll:o,panOnDrag:V,isSelecting:!!W,selectionMode:d,selectionKeyPressed:z,paneClickDistance:s,selectionOnDrag:U,children:[e,R&&f(Dl,{onSelectionContextMenu:M,noPanClassName:P,disableKeyboardA11y:F})]})})}Al.displayName=`FlowRenderer`;const jl=r(Al),Ml=e=>t=>e?Ca(t.nodeLookup,{x:0,y:0,width:t.width,height:t.height},t.transform,!0).map(e=>e.id):Array.from(t.nodeLookup.keys());function Nl(e){return Q(i(Ml(e),[e]),Z)}const Pl=e=>e.updateNodeInternals;function Fl(){let e=Q(Pl),[t]=u(()=>typeof ResizeObserver>`u`?null:new ResizeObserver(t=>{let n=new Map;t.forEach(e=>{let t=e.target.getAttribute(`data-id`);n.set(t,{id:t,nodeElement:e.target,force:!0})}),e(n)}));return o(()=>()=>{t?.disconnect()},[t]),t}function Il({node:e,nodeType:t,hasDimensions:n,resizeObserver:r}){let i=$(),a=l(null),s=l(null),c=l(e.sourcePosition),u=l(e.targetPosition),d=l(t),f=n&&!!e.internals.handleBounds;return o(()=>{a.current&&!e.hidden&&(!f||s.current!==a.current)&&(s.current&&r?.unobserve(s.current),r?.observe(a.current),s.current=a.current)},[f,e.hidden]),o(()=>()=>{s.current&&=(r?.unobserve(s.current),null)},[]),o(()=>{if(a.current){let n=d.current!==t,r=c.current!==e.sourcePosition,o=u.current!==e.targetPosition;(n||r||o)&&(d.current=t,c.current=e.sourcePosition,u.current=e.targetPosition,i.getState().updateNodeInternals(new Map([[e.id,{id:e.id,nodeElement:a.current,force:!0}]])))}},[e.id,t,e.sourcePosition,e.targetPosition]),a}function Ll({id:e,onClick:t,onMouseEnter:n,onMouseMove:r,onMouseLeave:i,onContextMenu:a,onDoubleClick:o,nodesDraggable:s,elementsSelectable:c,nodesConnectable:l,nodesFocusable:u,resizeObserver:d,noDragClassName:p,noPanClassName:m,disableKeyboardA11y:h,rfId:_,nodeTypes:v,nodeClickDistance:y,onError:b}){let{node:x,internals:S,isParent:C}=Q(t=>{let n=t.nodeLookup.get(e),r=t.parentLookup.has(e);return{node:n,internals:n.internals,isParent:r}},Z),w=x.type||`default`,T=v?.[w]||wl[w];T===void 0&&(b?.(`003`,Y.error003(w)),w=`default`,T=v?.default||wl.default);let E=!!(x.draggable||s&&x.draggable===void 0),D=!!(x.selectable||c&&x.selectable===void 0),O=!!(x.connectable||l&&x.connectable===void 0),k=!!(x.focusable||u&&x.focusable===void 0),A=$(),j=eo(x),M=Il({node:x,nodeType:w,hasDimensions:j,resizeObserver:d}),N=ll({nodeRef:M,disabled:x.hidden||!E,noDragClassName:p,handleSelector:x.dragHandle,nodeId:e,isSelectable:D,nodeClickDistance:y}),P=dl();if(x.hidden)return null;let F=$a(x),I=Tl(x),L=D||E||t||n||r||i,R=n?e=>n(e,{...S.userNode}):void 0,ee=r?e=>r(e,{...S.userNode}):void 0,z=i?e=>i(e,{...S.userNode}):void 0,B=a?e=>a(e,{...S.userNode}):void 0,V=o?e=>o(e,{...S.userNode}):void 0,H=n=>{let{selectNodesOnDrag:r,nodeDragThreshold:i}=A.getState();D&&(!r||!E||i>0)&&cl({id:e,store:A,nodeRef:M}),t&&t(n,{...S.userNode})},U=t=>{if(!(lo(t.nativeEvent)||h)){if(sa.includes(t.key)&&D)cl({id:e,store:A,unselect:t.key===`Escape`,nodeRef:M});else if(E&&x.selected&&Object.prototype.hasOwnProperty.call(Cl,t.key)){t.preventDefault();let{ariaLabelConfig:e}=A.getState();A.setState({ariaLiveMessage:e[`node.a11yDescription.ariaLiveMessage`]({direction:t.key.replace(`Arrow`,``).toLowerCase(),x:~~S.positionAbsolute.x,y:~~S.positionAbsolute.y})}),P({direction:Cl[t.key],factor:t.shiftKey?4:1})}}},W=()=>{if(h||!M.current?.matches(`:focus-visible`))return;let{transform:t,width:n,height:r,autoPanOnNodeFocus:i,setCenter:a}=A.getState();i&&(Ca(new Map([[e,x]]),{x:0,y:0,width:n,height:r},t,!0).length>0||a(x.position.x+F.width/2,x.position.y+F.height/2,{zoom:t[2]}))};return f(`div`,{className:g([`react-flow__node`,`react-flow__node-${w}`,{[m]:E},x.className,{selected:x.selected,selectable:D,parent:C,draggable:E,dragging:N}]),ref:M,style:{zIndex:S.z,transform:`translate(${S.positionAbsolute.x}px,${S.positionAbsolute.y}px)`,pointerEvents:L?`all`:`none`,visibility:j?`visible`:`hidden`,...x.style,...I},"data-id":e,"data-testid":`rf__node-${e}`,onMouseEnter:R,onMouseMove:ee,onMouseLeave:z,onContextMenu:B,onClick:H,onDoubleClick:V,onKeyDown:k?U:void 0,tabIndex:k?0:void 0,onFocus:k?W:void 0,role:x.ariaRole??(k?`group`:void 0),"aria-roledescription":`node`,"aria-describedby":h?void 0:`${ic}-${_}`,"aria-label":x.ariaLabel,...x.domAttributes,children:f(pl,{value:e,children:f(T,{id:e,data:x.data,type:w,positionAbsoluteX:S.positionAbsolute.x,positionAbsoluteY:S.positionAbsolute.y,selected:x.selected??!1,selectable:D,draggable:E,deletable:x.deletable??!0,isConnectable:O,sourcePosition:x.sourcePosition,targetPosition:x.targetPosition,dragging:N,dragHandle:x.dragHandle,zIndex:S.z,parentId:x.parentId,...F})})})}var Rl=r(Ll);const zl=e=>({nodesDraggable:e.nodesDraggable,nodesConnectable:e.nodesConnectable,nodesFocusable:e.nodesFocusable,elementsSelectable:e.elementsSelectable,onError:e.onError});function Bl(e){let{nodesDraggable:t,nodesConnectable:n,nodesFocusable:r,elementsSelectable:i,onError:a}=Q(zl,Z),o=Nl(e.onlyRenderVisibleElements),s=Fl();return f(`div`,{className:`react-flow__nodes`,style:el,children:o.map(o=>f(Rl,{id:o,nodeTypes:e.nodeTypes,nodeExtent:e.nodeExtent,onClick:e.onNodeClick,onMouseEnter:e.onNodeMouseEnter,onMouseMove:e.onNodeMouseMove,onMouseLeave:e.onNodeMouseLeave,onContextMenu:e.onNodeContextMenu,onDoubleClick:e.onNodeDoubleClick,noDragClassName:e.noDragClassName,noPanClassName:e.noPanClassName,rfId:e.rfId,disableKeyboardA11y:e.disableKeyboardA11y,resizeObserver:s,nodesDraggable:t,nodesConnectable:n,nodesFocusable:r,elementsSelectable:i,nodeClickDistance:e.nodeClickDistance,onError:a},o))})}Bl.displayName=`NodeRenderer`;const Vl=r(Bl);function Hl(e){return Q(i(t=>{if(!e)return t.edges.map(e=>e.id);let n=[];if(t.width&&t.height)for(let e of t.edges){let r=t.nodeLookup.get(e.source),i=t.nodeLookup.get(e.target);r&&i&&bo({sourceNode:r,targetNode:i,width:t.width,height:t.height,transform:t.transform})&&n.push(e.id)}return n},[e]),Z)}const Ul=({color:e=`none`,strokeWidth:t=1})=>f(`polyline`,{className:`arrow`,style:{strokeWidth:t,...e&&{stroke:e}},strokeLinecap:`round`,fill:`none`,strokeLinejoin:`round`,points:`-5,-4 0,0 -5,4`}),Wl=({color:e=`none`,strokeWidth:t=1})=>f(`polyline`,{className:`arrowclosed`,style:{strokeWidth:t,...e&&{stroke:e,fill:e}},strokeLinecap:`round`,strokeLinejoin:`round`,points:`-5,-4 0,0 -5,4 -5,-4`}),Gl={[ma.Arrow]:Ul,[ma.ArrowClosed]:Wl};function Kl(e){let t=$();return c(()=>Object.prototype.hasOwnProperty.call(Gl,e)?Gl[e]:(t.getState().onError?.(`009`,Y.error009(e)),null),[e])}const ql=({id:e,type:t,color:n,width:r=12.5,height:i=12.5,markerUnits:a=`strokeWidth`,strokeWidth:o,orient:s=`auto-start-reverse`})=>{let c=Kl(t);return c?f(`marker`,{className:`react-flow__arrowhead`,id:e,markerWidth:`${r}`,markerHeight:`${i}`,viewBox:`-10 -10 20 20`,markerUnits:a,orient:s,refX:`0`,refY:`0`,children:f(c,{color:n,strokeWidth:o})}):null},Jl=({defaultColor:e,rfId:t})=>{let n=Q(e=>e.edges),r=Q(e=>e.defaultEdgeOptions),i=c(()=>Lo(n,{id:t,defaultColor:e,defaultMarkerStart:r?.markerStart,defaultMarkerEnd:r?.markerEnd}),[n,r,t,e]);return i.length?f(`svg`,{className:`react-flow__marker`,"aria-hidden":`true`,children:f(`defs`,{children:i.map(e=>f(ql,{id:e.id,type:e.type,color:e.color,width:e.width,height:e.height,markerUnits:e.markerUnits,strokeWidth:e.strokeWidth,orient:e.orient},e.id))})}):null};Jl.displayName=`MarkerDefinitions`;var Yl=r(Jl);function Xl({x:e,y:t,label:n,labelStyle:r,labelShowBg:i=!0,labelBgStyle:a,labelBgPadding:s=[2,4],labelBgBorderRadius:c=2,children:d,className:m,...h}){let[_,v]=u({x:1,y:0,width:0,height:0}),y=g([`react-flow__edge-textwrapper`,m]),b=l(null);return o(()=>{if(b.current){let e=b.current.getBBox();v({x:e.x,y:e.y,width:e.width,height:e.height})}},[n]),n?p(`g`,{transform:`translate(${e-_.width/2} ${t-_.height/2})`,className:y,visibility:_.width?`visible`:`hidden`,...h,children:[i&&f(`rect`,{width:_.width+2*s[0],x:-s[0],y:-s[1],height:_.height+2*s[1],className:`react-flow__edge-textbg`,style:a,rx:c,ry:c}),f(`text`,{className:`react-flow__edge-text`,y:_.height/2,dy:`0.3em`,ref:b,style:r,children:n}),d]}):null}Xl.displayName=`EdgeText`;const Zl=r(Xl);function Ql({path:e,labelX:t,labelY:n,label:r,labelStyle:i,labelShowBg:a,labelBgStyle:o,labelBgPadding:s,labelBgBorderRadius:c,interactionWidth:l=20,...u}){return p(d,{children:[f(`path`,{...u,d:e,fill:`none`,className:g([`react-flow__edge-path`,u.className])}),l?f(`path`,{d:e,fill:`none`,strokeOpacity:0,strokeWidth:l,className:`react-flow__edge-interaction`}):null,r&&Ha(t)&&Ha(n)?f(Zl,{x:t,y:n,label:r,labelStyle:i,labelShowBg:a,labelBgStyle:o,labelBgPadding:s,labelBgBorderRadius:c}):null]})}function $l({pos:e,x1:t,y1:n,x2:r,y2:i}){return e===X.Left||e===X.Right?[.5*(t+r),n]:[t,.5*(n+i)]}function eu({sourceX:e,sourceY:t,sourcePosition:n=X.Bottom,targetX:r,targetY:i,targetPosition:a=X.Top}){let[o,s]=$l({pos:n,x1:e,y1:t,x2:r,y2:i}),[c,l]=$l({pos:a,x1:r,y1:i,x2:e,y2:t}),[u,d,f,p]=mo({sourceX:e,sourceY:t,targetX:r,targetY:i,sourceControlX:o,sourceControlY:s,targetControlX:c,targetControlY:l});return[`M${e},${t} C${o},${s} ${c},${l} ${r},${i}`,u,d,f,p]}function tu(e){return r(({id:t,sourceX:n,sourceY:r,targetX:i,targetY:a,sourcePosition:o,targetPosition:s,label:c,labelStyle:l,labelShowBg:u,labelBgStyle:d,labelBgPadding:p,labelBgBorderRadius:m,style:h,markerEnd:g,markerStart:_,interactionWidth:v})=>{let[y,b,x]=eu({sourceX:n,sourceY:r,sourcePosition:o,targetX:i,targetY:a,targetPosition:s});return f(Ql,{id:e.isInternal?void 0:t,path:y,labelX:b,labelY:x,label:c,labelStyle:l,labelShowBg:u,labelBgStyle:d,labelBgPadding:p,labelBgBorderRadius:m,style:h,markerEnd:g,markerStart:_,interactionWidth:v})})}const nu=tu({isInternal:!1}),ru=tu({isInternal:!0});nu.displayName=`SimpleBezierEdge`,ru.displayName=`SimpleBezierEdgeInternal`;function iu(e){return r(({id:t,sourceX:n,sourceY:r,targetX:i,targetY:a,label:o,labelStyle:s,labelShowBg:c,labelBgStyle:l,labelBgPadding:u,labelBgBorderRadius:d,style:p,sourcePosition:m=X.Bottom,targetPosition:h=X.Top,markerEnd:g,markerStart:_,pathOptions:v,interactionWidth:y})=>{let[b,x,S]=Ao({sourceX:n,sourceY:r,sourcePosition:m,targetX:i,targetY:a,targetPosition:h,borderRadius:v?.borderRadius,offset:v?.offset,stepPosition:v?.stepPosition});return f(Ql,{id:e.isInternal?void 0:t,path:b,labelX:x,labelY:S,label:o,labelStyle:s,labelShowBg:c,labelBgStyle:l,labelBgPadding:u,labelBgBorderRadius:d,style:p,markerEnd:g,markerStart:_,interactionWidth:y})})}const au=iu({isInternal:!1}),ou=iu({isInternal:!0});au.displayName=`SmoothStepEdge`,ou.displayName=`SmoothStepEdgeInternal`;function su(e){return r(({id:t,...n})=>{let r=e.isInternal?void 0:t;return f(au,{...n,id:r,pathOptions:c(()=>({borderRadius:0,offset:n.pathOptions?.offset}),[n.pathOptions?.offset])})})}const cu=su({isInternal:!1}),lu=su({isInternal:!0});cu.displayName=`StepEdge`,lu.displayName=`StepEdgeInternal`;function uu(e){return r(({id:t,sourceX:n,sourceY:r,targetX:i,targetY:a,label:o,labelStyle:s,labelShowBg:c,labelBgStyle:l,labelBgPadding:u,labelBgBorderRadius:d,style:p,markerEnd:m,markerStart:h,interactionWidth:g})=>{let[_,v,y]=wo({sourceX:n,sourceY:r,targetX:i,targetY:a});return f(Ql,{id:e.isInternal?void 0:t,path:_,labelX:v,labelY:y,label:o,labelStyle:s,labelShowBg:c,labelBgStyle:l,labelBgPadding:u,labelBgBorderRadius:d,style:p,markerEnd:m,markerStart:h,interactionWidth:g})})}const du=uu({isInternal:!1}),fu=uu({isInternal:!0});du.displayName=`StraightEdge`,fu.displayName=`StraightEdgeInternal`;function pu(e){return r(({id:t,sourceX:n,sourceY:r,targetX:i,targetY:a,sourcePosition:o=X.Bottom,targetPosition:s=X.Top,label:c,labelStyle:l,labelShowBg:u,labelBgStyle:d,labelBgPadding:p,labelBgBorderRadius:m,style:h,markerEnd:g,markerStart:_,pathOptions:v,interactionWidth:y})=>{let[b,x,S]=_o({sourceX:n,sourceY:r,sourcePosition:o,targetX:i,targetY:a,targetPosition:s,curvature:v?.curvature});return f(Ql,{id:e.isInternal?void 0:t,path:b,labelX:x,labelY:S,label:c,labelStyle:l,labelShowBg:u,labelBgStyle:d,labelBgPadding:p,labelBgBorderRadius:m,style:h,markerEnd:g,markerStart:_,interactionWidth:y})})}const mu=pu({isInternal:!1}),hu=pu({isInternal:!0});mu.displayName=`BezierEdge`,hu.displayName=`BezierEdgeInternal`;const gu={default:hu,straight:fu,step:lu,smoothstep:ou,simplebezier:ru},_u={sourceX:null,sourceY:null,targetX:null,targetY:null,sourcePosition:null,targetPosition:null},vu=(e,t,n)=>n===X.Left?e-t:n===X.Right?e+t:e,yu=(e,t,n)=>n===X.Top?e-t:n===X.Bottom?e+t:e,bu=`react-flow__edgeupdater`;function xu({position:e,centerX:t,centerY:n,radius:r=10,onMouseDown:i,onMouseEnter:a,onMouseOut:o,type:s}){return f(`circle`,{onMouseDown:i,onMouseEnter:a,onMouseOut:o,className:g([bu,`${bu}-${s}`]),cx:vu(t,r,e),cy:yu(n,r,e),r,stroke:`transparent`,fill:`transparent`})}function Su({isReconnectable:e,reconnectRadius:t,edge:n,sourceX:r,sourceY:i,targetX:a,targetY:o,sourcePosition:s,targetPosition:c,onReconnect:l,onReconnectStart:u,onReconnectEnd:m,setReconnecting:h,setUpdateHover:g}){let _=$(),v=(e,t)=>{if(e.button!==0)return;let{autoPanOnConnect:r,domNode:i,connectionMode:a,connectionRadius:o,lib:s,onConnectStart:c,cancelConnection:d,nodeLookup:f,rfId:p,panBy:g,updateConnection:v}=_.getState(),y=t.type===`target`;gs.onPointerDown(e.nativeEvent,{autoPanOnConnect:r,connectionMode:a,connectionRadius:o,domNode:i,handleId:t.id,nodeId:t.nodeId,nodeLookup:f,isTarget:y,edgeUpdaterType:t.type,lib:s,flowId:p,cancelConnection:d,panBy:g,isValidConnection:(...e)=>_.getState().isValidConnection?.(...e)??!0,onConnect:e=>l?.(n,e),onConnectStart:(r,i)=>{h(!0),u?.(e,n,t.type),c?.(r,i)},onConnectEnd:(...e)=>_.getState().onConnectEnd?.(...e),onReconnectEnd:(e,r)=>{h(!1),m?.(e,n,t.type,r)},updateConnection:v,getTransform:()=>_.getState().transform,getFromHandle:()=>_.getState().connection.fromHandle,dragThreshold:_.getState().connectionDragThreshold,handleDomNode:e.currentTarget})},y=e=>v(e,{nodeId:n.target,id:n.targetHandle??null,type:`target`}),b=e=>v(e,{nodeId:n.source,id:n.sourceHandle??null,type:`source`}),x=()=>g(!0),S=()=>g(!1);return p(d,{children:[(e===!0||e===`source`)&&f(xu,{position:s,centerX:r,centerY:i,radius:t,onMouseDown:y,onMouseEnter:x,onMouseOut:S,type:`source`}),(e===!0||e===`target`)&&f(xu,{position:c,centerX:a,centerY:o,radius:t,onMouseDown:b,onMouseEnter:x,onMouseOut:S,type:`target`})]})}function Cu({id:e,edgesFocusable:t,edgesReconnectable:n,elementsSelectable:r,onClick:a,onDoubleClick:o,onContextMenu:s,onMouseEnter:d,onMouseMove:m,onMouseLeave:h,reconnectRadius:_,onReconnect:v,onReconnectStart:y,onReconnectEnd:b,rfId:x,edgeTypes:S,noPanClassName:C,onError:w,disableKeyboardA11y:T}){let E=Q(t=>t.edgeLookup.get(e)),D=Q(e=>e.defaultEdgeOptions);E=D?{...D,...E}:E;let O=E.type||`default`,k=S?.[O]||gu[O];k===void 0&&(w?.(`011`,Y.error011(O)),O=`default`,k=S?.default||gu.default);let A=!!(E.focusable||t&&E.focusable===void 0),j=v!==void 0&&(E.reconnectable||n&&E.reconnectable===void 0),M=!!(E.selectable||r&&E.selectable===void 0),N=l(null),[P,F]=u(!1),[I,L]=u(!1),R=$(),{zIndex:ee,sourceX:z,sourceY:B,targetX:V,targetY:H,sourcePosition:U,targetPosition:W}=Q(i(t=>{let n=t.nodeLookup.get(E.source),r=t.nodeLookup.get(E.target);if(!n||!r)return{zIndex:E.zIndex,..._u};let i=Mo({id:e,sourceNode:n,targetNode:r,sourceHandle:E.sourceHandle||null,targetHandle:E.targetHandle||null,connectionMode:t.connectionMode,onError:w});return{zIndex:yo({selected:E.selected,zIndex:E.zIndex,sourceNode:n,targetNode:r,elevateOnSelect:t.elevateEdgesOnSelect,zIndexMode:t.zIndexMode}),...i||_u}},[E.source,E.target,E.sourceHandle,E.targetHandle,E.selected,E.zIndex]),Z),te=c(()=>E.markerStart?`url('#${Io(E.markerStart,x)}')`:void 0,[E.markerStart,x]),ne=c(()=>E.markerEnd?`url('#${Io(E.markerEnd,x)}')`:void 0,[E.markerEnd,x]);if(E.hidden||z===null||B===null||V===null||H===null)return null;let re=t=>{let{addSelectedEdges:n,unselectNodesAndEdges:r,multiSelectionActive:i}=R.getState();M&&(R.setState({nodesSelectionActive:!1}),E.selected&&i?(r({nodes:[],edges:[E]}),N.current?.blur()):n([e])),a&&a(t,E)},ie=o?e=>{o(e,{...E})}:void 0,ae=s?e=>{s(e,{...E})}:void 0,oe=d?e=>{d(e,{...E})}:void 0,se=m?e=>{m(e,{...E})}:void 0,ce=h?e=>{h(e,{...E})}:void 0;return f(`svg`,{style:{zIndex:ee},children:p(`g`,{className:g([`react-flow__edge`,`react-flow__edge-${O}`,E.className,C,{selected:E.selected,animated:E.animated,inactive:!M&&!a,updating:P,selectable:M}]),onClick:re,onDoubleClick:ie,onContextMenu:ae,onMouseEnter:oe,onMouseMove:se,onMouseLeave:ce,onKeyDown:A?t=>{if(!T&&sa.includes(t.key)&&M){let{unselectNodesAndEdges:n,addSelectedEdges:r}=R.getState();t.key===`Escape`?(N.current?.blur(),n({edges:[E]})):r([e])}}:void 0,tabIndex:A?0:void 0,role:E.ariaRole??(A?`group`:`img`),"aria-roledescription":`edge`,"data-id":e,"data-testid":`rf__edge-${e}`,"aria-label":E.ariaLabel===null?void 0:E.ariaLabel||`Edge from ${E.source} to ${E.target}`,"aria-describedby":A?`${ac}-${x}`:void 0,ref:N,...E.domAttributes,children:[!I&&f(k,{id:e,source:E.source,target:E.target,type:E.type,selected:E.selected,animated:E.animated,selectable:M,deletable:E.deletable??!0,label:E.label,labelStyle:E.labelStyle,labelShowBg:E.labelShowBg,labelBgStyle:E.labelBgStyle,labelBgPadding:E.labelBgPadding,labelBgBorderRadius:E.labelBgBorderRadius,sourceX:z,sourceY:B,targetX:V,targetY:H,sourcePosition:U,targetPosition:W,data:E.data,style:E.style,sourceHandleId:E.sourceHandle,targetHandleId:E.targetHandle,markerStart:te,markerEnd:ne,pathOptions:`pathOptions`in E?E.pathOptions:void 0,interactionWidth:E.interactionWidth}),j&&f(Su,{edge:E,isReconnectable:j,reconnectRadius:_,onReconnect:v,onReconnectStart:y,onReconnectEnd:b,sourceX:z,sourceY:B,targetX:V,targetY:H,sourcePosition:U,targetPosition:W,setUpdateHover:F,setReconnecting:L})]})})}var wu=r(Cu);const Tu=e=>({edgesFocusable:e.edgesFocusable,edgesReconnectable:e.edgesReconnectable,elementsSelectable:e.elementsSelectable,connectionMode:e.connectionMode,onError:e.onError});function Eu({defaultMarkerColor:e,onlyRenderVisibleElements:t,rfId:n,edgeTypes:r,noPanClassName:i,onReconnect:a,onEdgeContextMenu:o,onEdgeMouseEnter:s,onEdgeMouseMove:c,onEdgeMouseLeave:l,onEdgeClick:u,reconnectRadius:d,onEdgeDoubleClick:m,onReconnectStart:h,onReconnectEnd:g,disableKeyboardA11y:_}){let{edgesFocusable:v,edgesReconnectable:y,elementsSelectable:b,onError:x}=Q(Tu,Z),S=Hl(t);return p(`div`,{className:`react-flow__edges`,children:[f(Yl,{defaultColor:e,rfId:n}),S.map(e=>f(wu,{id:e,edgesFocusable:v,edgesReconnectable:y,elementsSelectable:b,noPanClassName:i,onReconnect:a,onContextMenu:o,onMouseEnter:s,onMouseMove:c,onMouseLeave:l,onClick:u,reconnectRadius:d,onDoubleClick:m,onReconnectStart:h,onReconnectEnd:g,rfId:n,onError:x,edgeTypes:r,disableKeyboardA11y:_},e))]})}Eu.displayName=`EdgeRenderer`;const Du=r(Eu),Ou=e=>`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]})`;function ku({children:e}){return f(`div`,{className:`react-flow__viewport xyflow__viewport react-flow__container`,style:{transform:Q(Ou)},children:e})}function Au(e){let t=Yc(),n=l(!1);o(()=>{!n.current&&t.viewportInitialized&&e&&(setTimeout(()=>e(t),1),n.current=!0)},[e,t.viewportInitialized])}const ju=e=>e.panZoom?.syncViewport;function Mu(e){let t=Q(ju),n=$();return o(()=>{e&&(t?.(e),n.setState({transform:[e.x,e.y,e.zoom]}))},[e,t]),null}function Nu(e){return e.connection.inProgress?{...e.connection,to:Ga(e.connection.to,e.transform)}:{...e.connection}}function Pu(e){return e?t=>e(Nu(t)):Nu}function Fu(e){return Q(Pu(e),Z)}const Iu=e=>({nodesConnectable:e.nodesConnectable,isValid:e.connection.isValid,inProgress:e.connection.inProgress,width:e.width,height:e.height});function Lu({containerStyle:e,style:t,type:n,component:r}){let{nodesConnectable:i,width:a,height:o,isValid:s,inProgress:c}=Q(Iu,Z);return a&&i&&c?f(`svg`,{style:e,width:a,height:o,className:`react-flow__connectionline react-flow__container`,children:f(`g`,{className:g([`react-flow__connection`,ga(s)]),children:f(Ru,{style:t,type:n,CustomComponent:r,isValid:s})})}):null}const Ru=({style:e,type:t=pa.Bezier,CustomComponent:n,isValid:r})=>{let{inProgress:i,from:a,fromNode:o,fromHandle:s,fromPosition:c,to:l,toNode:u,toHandle:d,toPosition:p,pointer:m}=Fu();if(!i)return;if(n)return f(n,{connectionLineType:t,connectionLineStyle:e,fromNode:o,fromHandle:s,fromX:a.x,fromY:a.y,toX:l.x,toY:l.y,fromPosition:c,toPosition:p,connectionStatus:ga(r),toNode:u,toHandle:d,pointer:m});let h=``,g={sourceX:a.x,sourceY:a.y,sourcePosition:c,targetX:l.x,targetY:l.y,targetPosition:p};switch(t){case pa.Bezier:[h]=_o(g);break;case pa.SimpleBezier:[h]=eu(g);break;case pa.Step:[h]=Ao({...g,borderRadius:0});break;case pa.SmoothStep:[h]=Ao(g);break;default:[h]=wo(g)}return f(`path`,{d:h,fill:`none`,className:`react-flow__connection-path`,style:e})};Ru.displayName=`ConnectionLine`;const zu={};function Bu(e=zu){l(e),$(),o(()=>{},[e])}function Vu(){$(),l(!1),o(()=>{},[])}function Hu({nodeTypes:e,edgeTypes:t,onInit:n,onNodeClick:r,onEdgeClick:i,onNodeDoubleClick:a,onEdgeDoubleClick:o,onNodeMouseEnter:s,onNodeMouseMove:c,onNodeMouseLeave:l,onNodeContextMenu:u,onSelectionContextMenu:d,onSelectionStart:m,onSelectionEnd:h,connectionLineType:g,connectionLineStyle:_,connectionLineComponent:v,connectionLineContainerStyle:y,selectionKeyCode:b,selectionOnDrag:x,selectionMode:S,multiSelectionKeyCode:C,panActivationKeyCode:w,zoomActivationKeyCode:T,deleteKeyCode:E,onlyRenderVisibleElements:D,elementsSelectable:O,defaultViewport:k,translateExtent:A,minZoom:j,maxZoom:M,preventScrolling:N,defaultMarkerColor:P,zoomOnScroll:F,zoomOnPinch:I,panOnScroll:L,panOnScrollSpeed:R,panOnScrollMode:ee,zoomOnDoubleClick:z,panOnDrag:B,onPaneClick:V,onPaneMouseEnter:H,onPaneMouseMove:U,onPaneMouseLeave:W,onPaneScroll:te,onPaneContextMenu:ne,paneClickDistance:re,nodeClickDistance:ie,onEdgeContextMenu:ae,onEdgeMouseEnter:oe,onEdgeMouseMove:se,onEdgeMouseLeave:ce,reconnectRadius:le,onReconnect:ue,onReconnectStart:de,onReconnectEnd:fe,noDragClassName:pe,noWheelClassName:me,noPanClassName:he,disableKeyboardA11y:ge,nodeExtent:_e,rfId:ve,viewport:ye,onViewportChange:be}){return Bu(e),Bu(t),Vu(),Au(n),Mu(ye),f(jl,{onPaneClick:V,onPaneMouseEnter:H,onPaneMouseMove:U,onPaneMouseLeave:W,onPaneContextMenu:ne,onPaneScroll:te,paneClickDistance:re,deleteKeyCode:E,selectionKeyCode:b,selectionOnDrag:x,selectionMode:S,onSelectionStart:m,onSelectionEnd:h,multiSelectionKeyCode:C,panActivationKeyCode:w,zoomActivationKeyCode:T,elementsSelectable:O,zoomOnScroll:F,zoomOnPinch:I,zoomOnDoubleClick:z,panOnScroll:L,panOnScrollSpeed:R,panOnScrollMode:ee,panOnDrag:B,defaultViewport:k,translateExtent:A,minZoom:j,maxZoom:M,onSelectionContextMenu:d,preventScrolling:N,noDragClassName:pe,noWheelClassName:me,noPanClassName:he,disableKeyboardA11y:ge,onViewportChange:be,isControlledViewport:!!ye,children:p(ku,{children:[f(Du,{edgeTypes:t,onEdgeClick:i,onEdgeDoubleClick:o,onReconnect:ue,onReconnectStart:de,onReconnectEnd:fe,onlyRenderVisibleElements:D,onEdgeContextMenu:ae,onEdgeMouseEnter:oe,onEdgeMouseMove:se,onEdgeMouseLeave:ce,reconnectRadius:le,defaultMarkerColor:P,noPanClassName:he,disableKeyboardA11y:ge,rfId:ve}),f(Lu,{style:_,type:g,component:v,containerStyle:y}),f(`div`,{className:`react-flow__edgelabel-renderer`}),f(Vl,{nodeTypes:e,onNodeClick:r,onNodeDoubleClick:a,onNodeMouseEnter:s,onNodeMouseMove:c,onNodeMouseLeave:l,onNodeContextMenu:u,nodeClickDistance:ie,onlyRenderVisibleElements:D,noPanClassName:he,noDragClassName:pe,disableKeyboardA11y:ge,nodeExtent:_e,rfId:ve}),f(`div`,{className:`react-flow__viewport-portal`})]})})}Hu.displayName=`GraphView`;const Uu=r(Hu),Wu=({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,width:i,height:a,fitView:o,fitViewOptions:s,minZoom:c=.5,maxZoom:l=2,nodeOrigin:u,nodeExtent:d,zIndexMode:f=`basic`}={})=>{let p=new Map,m=new Map,h=new Map,g=new Map,_=r??t??[],v=n??e??[],y=u??[0,0],b=d??oa;ts(h,g,_);let{nodesInitialized:x}=Ko(v,p,m,{nodeOrigin:y,nodeExtent:b,zIndexMode:f}),S=[0,0,1];if(o&&i&&a){let{x:e,y:t,zoom:n}=Xa(Sa(p,{filter:e=>!!((e.width||e.initialWidth)&&(e.height||e.initialHeight))}),i,a,c,l,s?.padding??.1);S=[e,t,n]}return{rfId:`1`,width:i??0,height:a??0,transform:S,nodes:v,nodesInitialized:x,nodeLookup:p,parentLookup:m,edges:_,edgeLookup:g,connectionLookup:h,onNodesChange:null,onEdgesChange:null,hasDefaultNodes:n!==void 0,hasDefaultEdges:r!==void 0,panZoom:null,minZoom:c,maxZoom:l,translateExtent:oa,nodeExtent:b,nodesSelectionActive:!1,userSelectionActive:!1,userSelectionRect:null,connectionMode:la.Strict,domNode:null,paneDragging:!1,noPanClassName:`nopan`,nodeOrigin:y,nodeDragThreshold:1,connectionDragThreshold:1,snapGrid:[15,15],snapToGrid:!1,nodesDraggable:!0,nodesConnectable:!0,nodesFocusable:!0,edgesFocusable:!0,edgesReconnectable:!0,elementsSelectable:!0,elevateNodesOnSelect:!0,elevateEdgesOnSelect:!0,selectNodesOnDrag:!0,multiSelectionActive:!1,fitViewQueued:o??!1,fitViewOptions:s,fitViewResolver:null,connection:{...fa},connectionClickStartHandle:null,connectOnClick:!0,ariaLiveMessage:``,autoPanOnConnect:!0,autoPanOnNodeDrag:!0,autoPanOnNodeFocus:!0,autoPanSpeed:15,connectionRadius:20,onError:Ua,isValidConnection:void 0,onSelectionChangeHandlers:[],lib:`react`,debug:!1,ariaLabelConfig:ca,zIndexMode:f,onNodesChangeMiddlewareMap:new Map,onEdgesChangeMiddlewareMap:new Map}},Gu=({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,width:i,height:a,fitView:o,fitViewOptions:s,minZoom:c,maxZoom:l,nodeOrigin:u,nodeExtent:d,zIndexMode:f})=>Qs((p,m)=>{async function h(){let{nodeLookup:e,panZoom:t,fitViewOptions:n,fitViewResolver:r,width:i,height:a,minZoom:o,maxZoom:s}=m();t&&(await Ea({nodes:e,width:i,height:a,panZoom:t,minZoom:o,maxZoom:s},n),r?.resolve(!0),p({fitViewResolver:null}))}return{...Wu({nodes:e,edges:t,width:i,height:a,fitView:o,fitViewOptions:s,minZoom:c,maxZoom:l,nodeOrigin:u,nodeExtent:d,defaultNodes:n,defaultEdges:r,zIndexMode:f}),setNodes:e=>{let{nodeLookup:t,parentLookup:n,nodeOrigin:r,elevateNodesOnSelect:i,fitViewQueued:a,zIndexMode:o,nodesSelectionActive:s}=m(),{nodesInitialized:c,hasSelectedNodes:l}=Ko(e,t,n,{nodeOrigin:r,nodeExtent:d,elevateNodesOnSelect:i,checkEquality:!0,zIndexMode:o}),u=s&&l;a&&c?(h(),p({nodes:e,nodesInitialized:c,fitViewQueued:!1,fitViewOptions:void 0,nodesSelectionActive:u})):p({nodes:e,nodesInitialized:c,nodesSelectionActive:u})},setEdges:e=>{let{connectionLookup:t,edgeLookup:n}=m();ts(t,n,e),p({edges:e})},setDefaultNodesAndEdges:(e,t)=>{if(e){let{setNodes:t}=m();t(e),p({hasDefaultNodes:!0})}if(t){let{setEdges:e}=m();e(t),p({hasDefaultEdges:!0})}},updateNodeInternals:e=>{let{triggerNodeChanges:t,nodeLookup:n,parentLookup:r,domNode:i,nodeOrigin:a,nodeExtent:o,debug:s,fitViewQueued:c,zIndexMode:l}=m(),{changes:u,updatedInternals:d}=Qo(e,n,r,i,a,o,l);d&&(Uo(n,r,{nodeOrigin:a,nodeExtent:o,zIndexMode:l}),c?(h(),p({fitViewQueued:!1,fitViewOptions:void 0})):p({}),u?.length>0&&(s&&console.log(`React Flow: trigger node changes`,u),t?.(u)))},updateNodePositions:(e,t=!1)=>{let n=[],r=[],{nodeLookup:i,triggerNodeChanges:a,connection:o,updateConnection:s,onNodesChangeMiddlewareMap:c}=m();for(let[a,c]of e){let e=i.get(a),l=!!(e?.expandParent&&e?.parentId&&c?.position),u={id:a,type:`position`,position:l?{x:Math.max(0,c.position.x),y:Math.max(0,c.position.y)}:c.position,dragging:t};if(e&&o.inProgress&&o.fromNode.id===e.id){let t=Po(e,o.fromHandle,X.Left,!0);s({...o,from:t})}l&&e.parentId&&n.push({id:a,parentId:e.parentId,rect:{...c.internals.positionAbsolute,width:c.measured.width??0,height:c.measured.height??0}}),r.push(u)}if(n.length>0){let{parentLookup:e,nodeOrigin:t}=m(),a=Zo(n,i,e,t);r.push(...a)}for(let e of c.values())r=e(r);a(r)},triggerNodeChanges:e=>{let{onNodesChange:t,setNodes:n,nodes:r,hasDefaultNodes:i,debug:a}=m();e?.length&&(i&&n(Pc(e,r)),a&&console.log(`React Flow: trigger node changes`,e),t?.(e))},triggerEdgeChanges:e=>{let{onEdgesChange:t,setEdges:n,edges:r,hasDefaultEdges:i,debug:a}=m();e?.length&&(i&&n(Fc(e,r)),a&&console.log(`React Flow: trigger edge changes`,e),t?.(e))},addSelectedNodes:e=>{let{multiSelectionActive:t,edgeLookup:n,nodeLookup:r,triggerNodeChanges:i,triggerEdgeChanges:a}=m();if(t){i(e.map(e=>Ic(e,!0)));return}i(Lc(r,new Set([...e]),!0)),a(Lc(n))},addSelectedEdges:e=>{let{multiSelectionActive:t,edgeLookup:n,nodeLookup:r,triggerNodeChanges:i,triggerEdgeChanges:a}=m();if(t){a(e.map(e=>Ic(e,!0)));return}a(Lc(n,new Set([...e]))),i(Lc(r,new Set,!0))},unselectNodesAndEdges:({nodes:e,edges:t}={})=>{let{edges:n,nodes:r,nodeLookup:i,triggerNodeChanges:a,triggerEdgeChanges:o}=m(),s=e||r,c=t||n,l=[];for(let e of s){if(!e.selected)continue;let t=i.get(e.id);t&&(t.selected=!1),l.push(Ic(e.id,!1))}let u=[];for(let e of c)e.selected&&u.push(Ic(e.id,!1));a(l),o(u)},setMinZoom:e=>{let{panZoom:t,maxZoom:n}=m();t?.setScaleExtent([e,n]),p({minZoom:e})},setMaxZoom:e=>{let{panZoom:t,minZoom:n}=m();t?.setScaleExtent([n,e]),p({maxZoom:e})},setTranslateExtent:e=>{m().panZoom?.setTranslateExtent(e),p({translateExtent:e})},resetSelectedElements:()=>{let{edges:e,nodes:t,triggerNodeChanges:n,triggerEdgeChanges:r,elementsSelectable:i}=m();if(!i)return;let a=t.reduce((e,t)=>t.selected?[...e,Ic(t.id,!1)]:e,[]),o=e.reduce((e,t)=>t.selected?[...e,Ic(t.id,!1)]:e,[]);n(a),r(o)},setNodeExtent:e=>{let{nodes:t,nodeLookup:n,parentLookup:r,nodeOrigin:i,elevateNodesOnSelect:a,nodeExtent:o,zIndexMode:s}=m();e[0][0]===o[0][0]&&e[0][1]===o[0][1]&&e[1][0]===o[1][0]&&e[1][1]===o[1][1]||(Ko(t,n,r,{nodeOrigin:i,nodeExtent:e,elevateNodesOnSelect:a,checkEquality:!1,zIndexMode:s}),p({nodeExtent:e}))},panBy:e=>{let{transform:t,width:n,height:r,panZoom:i,translateExtent:a}=m();return $o({delta:e,panZoom:i,transform:t,translateExtent:a,width:n,height:r})},setCenter:async(e,t,n)=>{let{width:r,height:i,maxZoom:a,panZoom:o}=m();if(!o)return Promise.resolve(!1);let s=n?.zoom===void 0?a:n.zoom;return await o.setViewport({x:r/2-e*s,y:i/2-t*s,zoom:s},{duration:n?.duration,ease:n?.ease,interpolate:n?.interpolate}),Promise.resolve(!0)},cancelConnection:()=>{p({connection:{...fa}})},updateConnection:e=>{p({connection:e})},reset:()=>p({...Wu()})}},Object.is);function Ku({initialNodes:e,initialEdges:t,defaultNodes:n,defaultEdges:r,initialWidth:i,initialHeight:a,initialMinZoom:o,initialMaxZoom:s,initialFitViewOptions:c,fitView:l,nodeOrigin:d,nodeExtent:p,zIndexMode:m,children:h}){let[g]=u(()=>Gu({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,width:i,height:a,fitView:l,minZoom:o,maxZoom:s,fitViewOptions:c,nodeOrigin:d,nodeExtent:p,zIndexMode:m}));return f(ec,{value:g,children:f(Kc,{children:h})})}function qu({children:e,nodes:t,edges:n,defaultNodes:r,defaultEdges:i,width:o,height:s,fitView:c,fitViewOptions:l,minZoom:u,maxZoom:p,nodeOrigin:m,nodeExtent:h,zIndexMode:g}){return a($s)?f(d,{children:e}):f(Ku,{initialNodes:t,initialEdges:n,defaultNodes:r,defaultEdges:i,initialWidth:o,initialHeight:s,fitView:c,initialFitViewOptions:l,initialMinZoom:u,initialMaxZoom:p,nodeOrigin:m,nodeExtent:h,zIndexMode:g,children:e})}const Ju={width:`100%`,height:`100%`,overflow:`hidden`,position:`relative`,zIndex:0};function Yu({nodes:e,edges:t,defaultNodes:n,defaultEdges:r,className:a,nodeTypes:o,edgeTypes:s,onNodeClick:c,onEdgeClick:l,onInit:u,onMove:d,onMoveStart:m,onMoveEnd:h,onConnect:_,onConnectStart:v,onConnectEnd:y,onClickConnectStart:b,onClickConnectEnd:x,onNodeMouseEnter:S,onNodeMouseMove:C,onNodeMouseLeave:w,onNodeContextMenu:T,onNodeDoubleClick:E,onNodeDragStart:D,onNodeDrag:O,onNodeDragStop:k,onNodesDelete:A,onEdgesDelete:j,onDelete:M,onSelectionChange:N,onSelectionDragStart:P,onSelectionDrag:F,onSelectionDragStop:I,onSelectionContextMenu:L,onSelectionStart:R,onSelectionEnd:ee,onBeforeDelete:z,connectionMode:B,connectionLineType:V=pa.Bezier,connectionLineStyle:H,connectionLineComponent:U,connectionLineContainerStyle:W,deleteKeyCode:te=`Backspace`,selectionKeyCode:ne=`Shift`,selectionOnDrag:re=!1,selectionMode:ie=da.Full,panActivationKeyCode:ae=`Space`,multiSelectionKeyCode:oe=Za()?`Meta`:`Control`,zoomActivationKeyCode:se=Za()?`Meta`:`Control`,snapToGrid:ce,snapGrid:le,onlyRenderVisibleElements:ue=!1,selectNodesOnDrag:de,nodesDraggable:fe,autoPanOnNodeFocus:pe,nodesConnectable:me,nodesFocusable:he,nodeOrigin:ge=yc,edgesFocusable:_e,edgesReconnectable:ve,elementsSelectable:ye=!0,defaultViewport:be=bc,minZoom:xe=.5,maxZoom:Se=2,translateExtent:Ce=oa,preventScrolling:we=!0,nodeExtent:Te,defaultMarkerColor:Ee=`#b1b1b7`,zoomOnScroll:De=!0,zoomOnPinch:Oe=!0,panOnScroll:ke=!1,panOnScrollSpeed:Ae=.5,panOnScrollMode:je=ua.Free,zoomOnDoubleClick:Me=!0,panOnDrag:Ne=!0,onPaneClick:Pe,onPaneMouseEnter:Fe,onPaneMouseMove:Ie,onPaneMouseLeave:Le,onPaneScroll:Re,onPaneContextMenu:ze,paneClickDistance:Be=1,nodeClickDistance:Ve=0,children:He,onReconnect:Ue,onReconnectStart:We,onReconnectEnd:Ge,onEdgeContextMenu:Ke,onEdgeDoubleClick:qe,onEdgeMouseEnter:Je,onEdgeMouseMove:Ye,onEdgeMouseLeave:Xe,reconnectRadius:Ze=10,onNodesChange:Qe,onEdgesChange:$e,noDragClassName:et=`nodrag`,noWheelClassName:tt=`nowheel`,noPanClassName:nt=`nopan`,fitView:rt,fitViewOptions:it,connectOnClick:at,attributionPosition:ot,proOptions:st,defaultEdgeOptions:ct,elevateNodesOnSelect:lt=!0,elevateEdgesOnSelect:ut=!1,disableKeyboardA11y:dt=!1,autoPanOnConnect:ft,autoPanOnNodeDrag:pt,autoPanSpeed:mt,connectionRadius:ht,isValidConnection:gt,onError:_t,style:vt,id:yt,nodeDragThreshold:bt,connectionDragThreshold:xt,viewport:St,onViewportChange:Ct,width:wt,height:Tt,colorMode:Et=`light`,debug:G,onScroll:Dt,ariaLabelConfig:Ot,zIndexMode:K=`basic`,...kt},q){let At=yt||`1`,jt=Ec(Et),Mt=i(e=>{e.currentTarget.scrollTo({top:0,left:0,behavior:`instant`}),Dt?.(e)},[Dt]);return f(`div`,{"data-testid":`rf__wrapper`,...kt,onScroll:Mt,style:{...vt,...Ju},ref:q,className:g([`react-flow`,a,jt]),id:yt,role:`application`,children:p(qu,{nodes:e,edges:t,width:wt,height:Tt,fitView:rt,fitViewOptions:it,minZoom:xe,maxZoom:Se,nodeOrigin:ge,nodeExtent:Te,zIndexMode:K,children:[f(wc,{nodes:e,edges:t,defaultNodes:n,defaultEdges:r,onConnect:_,onConnectStart:v,onConnectEnd:y,onClickConnectStart:b,onClickConnectEnd:x,nodesDraggable:fe,autoPanOnNodeFocus:pe,nodesConnectable:me,nodesFocusable:he,edgesFocusable:_e,edgesReconnectable:ve,elementsSelectable:ye,elevateNodesOnSelect:lt,elevateEdgesOnSelect:ut,minZoom:xe,maxZoom:Se,nodeExtent:Te,onNodesChange:Qe,onEdgesChange:$e,snapToGrid:ce,snapGrid:le,connectionMode:B,translateExtent:Ce,connectOnClick:at,defaultEdgeOptions:ct,fitView:rt,fitViewOptions:it,onNodesDelete:A,onEdgesDelete:j,onDelete:M,onNodeDragStart:D,onNodeDrag:O,onNodeDragStop:k,onSelectionDrag:F,onSelectionDragStart:P,onSelectionDragStop:I,onMove:d,onMoveStart:m,onMoveEnd:h,noPanClassName:nt,nodeOrigin:ge,rfId:At,autoPanOnConnect:ft,autoPanOnNodeDrag:pt,autoPanSpeed:mt,onError:_t,connectionRadius:ht,isValidConnection:gt,selectNodesOnDrag:de,nodeDragThreshold:bt,connectionDragThreshold:xt,onBeforeDelete:z,debug:G,ariaLabelConfig:Ot,zIndexMode:K}),f(Uu,{onInit:u,onNodeClick:c,onEdgeClick:l,onNodeMouseEnter:S,onNodeMouseMove:C,onNodeMouseLeave:w,onNodeContextMenu:T,onNodeDoubleClick:E,nodeTypes:o,edgeTypes:s,connectionLineType:V,connectionLineStyle:H,connectionLineComponent:U,connectionLineContainerStyle:W,selectionKeyCode:ne,selectionOnDrag:re,selectionMode:ie,deleteKeyCode:te,multiSelectionKeyCode:oe,panActivationKeyCode:ae,zoomActivationKeyCode:se,onlyRenderVisibleElements:ue,defaultViewport:be,translateExtent:Ce,minZoom:xe,maxZoom:Se,preventScrolling:we,zoomOnScroll:De,zoomOnPinch:Oe,zoomOnDoubleClick:Me,panOnScroll:ke,panOnScrollSpeed:Ae,panOnScrollMode:je,panOnDrag:Ne,onPaneClick:Pe,onPaneMouseEnter:Fe,onPaneMouseMove:Ie,onPaneMouseLeave:Le,onPaneScroll:Re,onPaneContextMenu:ze,paneClickDistance:Be,nodeClickDistance:Ve,onSelectionContextMenu:L,onSelectionStart:R,onSelectionEnd:ee,onReconnect:Ue,onReconnectStart:We,onReconnectEnd:Ge,onEdgeContextMenu:Ke,onEdgeDoubleClick:qe,onEdgeMouseEnter:Je,onEdgeMouseMove:Ye,onEdgeMouseLeave:Xe,reconnectRadius:Ze,defaultMarkerColor:Ee,noDragClassName:et,noWheelClassName:tt,noPanClassName:nt,rfId:At,disableKeyboardA11y:dt,nodeExtent:Te,viewport:St,onViewportChange:Ct}),f(_c,{onSelectionChange:N}),He,f(dc,{proOptions:st,position:ot}),f(lc,{rfId:At,disableKeyboardA11y:dt})]})})}var Xu=Hc(Yu);const Zu=e=>e.domNode?.querySelector(`.react-flow__edgelabel-renderer`);function Qu({children:e}){let t=Q(Zu);return t?h(e,t):null}const $u=e=>e.domNode?.querySelector(`.react-flow__viewport-portal`);function ed({children:e}){let t=Q($u);return t?h(e,t):null}Y.error014();function td({dimensions:e,lineWidth:t,variant:n,className:r}){return f(`path`,{strokeWidth:t,d:`M${e[0]/2} 0 V${e[1]} M0 ${e[1]/2} H${e[0]}`,className:g([`react-flow__background-pattern`,n,r])})}function nd({radius:e,className:t}){return f(`circle`,{cx:e,cy:e,r:e,className:g([`react-flow__background-pattern`,`dots`,t])})}var rd;(function(e){e.Lines=`lines`,e.Dots=`dots`,e.Cross=`cross`})(rd||={});const id={[rd.Dots]:1,[rd.Lines]:1,[rd.Cross]:6},ad=e=>({transform:e.transform,patternId:`pattern-${e.rfId}`});function od({id:e,variant:t=rd.Dots,gap:n=20,size:r,lineWidth:i=1,offset:a=0,color:o,bgColor:s,style:c,className:u,patternClassName:d}){let m=l(null),{transform:h,patternId:_}=Q(ad,Z),v=r||id[t],y=t===rd.Dots,b=t===rd.Cross,x=Array.isArray(n)?n:[n,n],S=[x[0]*h[2]||1,x[1]*h[2]||1],C=v*h[2],w=Array.isArray(a)?a:[a,a],T=b?[C,C]:S,E=[w[0]*h[2]||1+T[0]/2,w[1]*h[2]||1+T[1]/2],D=`${_}${e||``}`;return p(`svg`,{className:g([`react-flow__background`,u]),style:{...c,...el,"--xy-background-color-props":s,"--xy-background-pattern-color-props":o},ref:m,"data-testid":`rf__background`,children:[f(`pattern`,{id:D,x:h[0]%S[0],y:h[1]%S[1],width:S[0],height:S[1],patternUnits:`userSpaceOnUse`,patternTransform:`translate(-${E[0]},-${E[1]})`,children:y?f(nd,{radius:C/2,className:d}):f(td,{dimensions:T,lineWidth:i,variant:t,className:d})}),f(`rect`,{x:`0`,y:`0`,width:`100%`,height:`100%`,fill:`url(#${D})`})]})}od.displayName=`Background`;const sd=r(od);function cd(){return f(`svg`,{xmlns:`http://www.w3.org/2000/svg`,viewBox:`0 0 32 32`,children:f(`path`,{d:`M32 18.133H18.133V32h-4.266V18.133H0v-4.266h13.867V0h4.266v13.867H32z`})})}function ld(){return f(`svg`,{xmlns:`http://www.w3.org/2000/svg`,viewBox:`0 0 32 5`,children:f(`path`,{d:`M0 0h32v4.2H0z`})})}function ud(){return f(`svg`,{xmlns:`http://www.w3.org/2000/svg`,viewBox:`0 0 32 30`,children:f(`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`})})}function dd(){return f(`svg`,{xmlns:`http://www.w3.org/2000/svg`,viewBox:`0 0 25 32`,children:f(`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`})})}function fd(){return f(`svg`,{xmlns:`http://www.w3.org/2000/svg`,viewBox:`0 0 25 32`,children:f(`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`})})}function pd({children:e,className:t,...n}){return f(`button`,{type:`button`,className:g([`react-flow__controls-button`,t]),...n,children:e})}const md=e=>({isInteractive:e.nodesDraggable||e.nodesConnectable||e.elementsSelectable,minZoomReached:e.transform[2]<=e.minZoom,maxZoomReached:e.transform[2]>=e.maxZoom,ariaLabelConfig:e.ariaLabelConfig});function hd({style:e,showZoom:t=!0,showFitView:n=!0,showInteractive:r=!0,fitViewOptions:i,onZoomIn:a,onZoomOut:o,onFitView:s,onInteractiveChange:c,className:l,children:u,position:m=`bottom-left`,orientation:h=`vertical`,"aria-label":_}){let v=$(),{isInteractive:y,minZoomReached:b,maxZoomReached:x,ariaLabelConfig:S}=Q(md,Z),{zoomIn:C,zoomOut:w,fitView:T}=Yc();return p(uc,{className:g([`react-flow__controls`,h===`horizontal`?`horizontal`:`vertical`,l]),position:m,style:e,"data-testid":`rf__controls`,"aria-label":_??S[`controls.ariaLabel`],children:[t&&p(d,{children:[f(pd,{onClick:()=>{C(),a?.()},className:`react-flow__controls-zoomin`,title:S[`controls.zoomIn.ariaLabel`],"aria-label":S[`controls.zoomIn.ariaLabel`],disabled:x,children:f(cd,{})}),f(pd,{onClick:()=>{w(),o?.()},className:`react-flow__controls-zoomout`,title:S[`controls.zoomOut.ariaLabel`],"aria-label":S[`controls.zoomOut.ariaLabel`],disabled:b,children:f(ld,{})})]}),n&&f(pd,{className:`react-flow__controls-fitview`,onClick:()=>{T(i),s?.()},title:S[`controls.fitView.ariaLabel`],"aria-label":S[`controls.fitView.ariaLabel`],children:f(ud,{})}),r&&f(pd,{className:`react-flow__controls-interactive`,onClick:()=>{v.setState({nodesDraggable:!y,nodesConnectable:!y,elementsSelectable:!y}),c?.(!y)},title:S[`controls.interactive.ariaLabel`],"aria-label":S[`controls.interactive.ariaLabel`],children:f(y?fd:dd,{})}),u]})}hd.displayName=`Controls`,r(hd);function gd({id:e,x:t,y:n,width:r,height:i,style:a,color:o,strokeColor:s,strokeWidth:c,className:l,borderRadius:u,shapeRendering:d,selected:p,onClick:m}){let{background:h,backgroundColor:_}=a||{},v=o||h||_;return f(`rect`,{className:g([`react-flow__minimap-node`,{selected:p},l]),x:t,y:n,rx:u,ry:u,width:r,height:i,style:{fill:v,stroke:s,strokeWidth:c},shapeRendering:d,onClick:m?t=>m(t,e):void 0})}const _d=r(gd),vd=e=>e.nodes.map(e=>e.id),yd=e=>e instanceof Function?e:()=>e;function bd({nodeStrokeColor:e,nodeColor:t,nodeClassName:n=``,nodeBorderRadius:r=5,nodeStrokeWidth:i,nodeComponent:a=_d,onClick:o}){let s=Q(vd,Z),c=yd(t),l=yd(e),u=yd(n),p=typeof window>`u`||window.chrome?`crispEdges`:`geometricPrecision`;return f(d,{children:s.map(e=>f(Sd,{id:e,nodeColorFunc:c,nodeStrokeColorFunc:l,nodeClassNameFunc:u,nodeBorderRadius:r,nodeStrokeWidth:i,NodeComponent:a,onClick:o,shapeRendering:p},e))})}function xd({id:e,nodeColorFunc:t,nodeStrokeColorFunc:n,nodeClassNameFunc:r,nodeBorderRadius:i,nodeStrokeWidth:a,shapeRendering:o,NodeComponent:s,onClick:c}){let{node:l,x:u,y:d,width:p,height:m}=Q(t=>{let n=t.nodeLookup.get(e);if(!n)return{node:void 0,x:0,y:0,width:0,height:0};let r=n.internals.userNode,{x:i,y:a}=n.internals.positionAbsolute,{width:o,height:s}=$a(r);return{node:r,x:i,y:a,width:o,height:s}},Z);return!l||l.hidden||!eo(l)?null:f(s,{x:u,y:d,width:p,height:m,style:l.style,selected:!!l.selected,className:r(l),color:t(l),borderRadius:i,strokeColor:n(l),strokeWidth:a,shapeRendering:o,onClick:c,id:l.id})}const Sd=r(xd);var Cd=r(bd);const wd=e=>!e.hidden,Td=e=>{let t={x:-e.transform[0]/e.transform[2],y:-e.transform[1]/e.transform[2],width:e.width/e.transform[2],height:e.height/e.transform[2]};return{viewBB:t,boundingRect:e.nodeLookup.size>0?za(Sa(e.nodeLookup,{filter:wd}),t):t,rfId:e.rfId,panZoom:e.panZoom,translateExtent:e.translateExtent,flowWidth:e.width,flowHeight:e.height,ariaLabelConfig:e.ariaLabelConfig}};function Ed({style:e,className:t,nodeStrokeColor:n,nodeColor:r,nodeClassName:a=``,nodeBorderRadius:s=5,nodeStrokeWidth:c,nodeComponent:u,bgColor:d,maskColor:m,maskStrokeColor:h,maskStrokeWidth:_,position:v=`bottom-right`,onClick:y,onNodeClick:b,pannable:x=!1,zoomable:S=!1,ariaLabel:C,inversePan:w,zoomStep:T=1,offsetScale:E=5}){let D=$(),O=l(null),{boundingRect:k,viewBB:A,rfId:j,panZoom:M,translateExtent:N,flowWidth:P,flowHeight:F,ariaLabelConfig:I}=Q(Td,Z),L=e?.width??200,R=e?.height??150,ee=k.width/L,z=k.height/R,B=Math.max(ee,z),V=B*L,H=B*R,U=E*B,W=k.x-(V-k.width)/2-U,te=k.y-(H-k.height)/2-U,ne=V+U*2,re=H+U*2,ie=`react-flow__minimap-desc-${j}`,ae=l(0),oe=l();ae.current=B,o(()=>{if(O.current&&M)return oe.current=_s({domNode:O.current,panZoom:M,getTransform:()=>D.getState().transform,getViewScale:()=>ae.current}),()=>{oe.current?.destroy()}},[M]),o(()=>{oe.current?.update({translateExtent:N,width:P,height:F,inversePan:w,pannable:x,zoomStep:T,zoomable:S})},[x,S,w,T,N,P,F]);let se=y?e=>{let[t,n]=oe.current?.pointer(e)||[0,0];y(e,{x:t,y:n})}:void 0,ce=b?i((e,t)=>{let n=D.getState().nodeLookup.get(t).internals.userNode;b(e,n)},[]):void 0,le=C??I[`minimap.ariaLabel`];return f(uc,{position:v,style:{...e,"--xy-minimap-background-color-props":typeof d==`string`?d:void 0,"--xy-minimap-mask-background-color-props":typeof m==`string`?m:void 0,"--xy-minimap-mask-stroke-color-props":typeof h==`string`?h:void 0,"--xy-minimap-mask-stroke-width-props":typeof _==`number`?_*B:void 0,"--xy-minimap-node-background-color-props":typeof r==`string`?r:void 0,"--xy-minimap-node-stroke-color-props":typeof n==`string`?n:void 0,"--xy-minimap-node-stroke-width-props":typeof c==`number`?c:void 0},className:g([`react-flow__minimap`,t]),"data-testid":`rf__minimap`,children:p(`svg`,{width:L,height:R,viewBox:`${W} ${te} ${ne} ${re}`,className:`react-flow__minimap-svg`,role:`img`,"aria-labelledby":ie,ref:O,onClick:se,children:[le&&f(`title`,{id:ie,children:le}),f(Cd,{onClick:ce,nodeColor:r,nodeStrokeColor:n,nodeBorderRadius:s,nodeClassName:a,nodeStrokeWidth:c,nodeComponent:u}),f(`path`,{className:`react-flow__minimap-mask`,d:`M${W-U},${te-U}h${ne+U*2}v${re+U*2}h${-ne-U*2}z
7
+ M${A.x},${A.y}h${A.width}v${A.height}h${-A.width}z`,fillRule:`evenodd`,pointerEvents:`none`})]})})}Ed.displayName=`MiniMap`,r(Ed);const Dd=e=>t=>e?`${Math.max(1/t.transform[2],1)}`:void 0,Od={[Ms.Line]:`right`,[Ms.Handle]:`bottom-right`};function kd({nodeId:e,position:t,variant:n=Ms.Handle,className:r,style:a=void 0,children:s,color:c,minWidth:u=10,minHeight:d=10,maxWidth:p=Number.MAX_VALUE,maxHeight:m=Number.MAX_VALUE,keepAspectRatio:h=!1,resizeDirection:_,autoScale:v=!0,shouldResize:y,onResizeStart:b,onResize:x,onResizeEnd:S}){let C=ml(),w=typeof e==`string`?e:C,T=$(),E=l(null),D=n===Ms.Handle,O=Q(i(Dd(D&&v),[D,v]),Z),k=l(null),A=t??Od[n];return o(()=>{if(!(!E.current||!w))return k.current||=Ws({domNode:E.current,nodeId:w,getStoreItems:()=>{let{nodeLookup:e,transform:t,snapGrid:n,snapToGrid:r,nodeOrigin:i,domNode:a}=T.getState();return{nodeLookup:e,transform:t,snapGrid:n,snapToGrid:r,nodeOrigin:i,paneDomNode:a}},onChange:(e,t)=>{let{triggerNodeChanges:n,nodeLookup:r,parentLookup:i,nodeOrigin:a}=T.getState(),o=[],s={x:e.x,y:e.y},c=r.get(w);if(c&&c.expandParent&&c.parentId){let t=c.origin??a,n=e.width??c.measured.width??0,l=e.height??c.measured.height??0,u=Zo([{id:c.id,parentId:c.parentId,rect:{width:n,height:l,...to({x:e.x??c.position.x,y:e.y??c.position.y},{width:n,height:l},c.parentId,r,t)}}],r,i,a);o.push(...u),s.x=e.x?Math.max(t[0]*n,e.x):void 0,s.y=e.y?Math.max(t[1]*l,e.y):void 0}if(s.x!==void 0&&s.y!==void 0){let e={id:w,type:`position`,position:{...s}};o.push(e)}if(e.width!==void 0&&e.height!==void 0){let t={id:w,type:`dimensions`,resizing:!0,setAttributes:_?_===`horizontal`?`width`:`height`:!0,dimensions:{width:e.width,height:e.height}};o.push(t)}for(let e of t){let t={...e,type:`position`};o.push(t)}n(o)},onEnd:({width:e,height:t})=>{let n={id:w,type:`dimensions`,resizing:!1,dimensions:{width:e,height:t}};T.getState().triggerNodeChanges([n])}}),k.current.update({controlPosition:A,boundaries:{minWidth:u,minHeight:d,maxWidth:p,maxHeight:m},keepAspectRatio:h,resizeDirection:_,onResizeStart:b,onResize:x,onResizeEnd:S,shouldResize:y}),()=>{k.current?.destroy()}},[A,u,d,p,m,h,b,x,S,y]),f(`div`,{className:g([`react-flow__resize-control`,`nodrag`,...A.split(`-`),n,r]),ref:E,style:{...a,scale:O,...c&&{[D?`backgroundColor`:`borderColor`]:c}},children:s})}r(kd);const Ad=e=>e.domNode?.querySelector(`.react-flow__renderer`);function jd({children:e}){let t=Q(Ad);return t?h(e,t):null}const Md=(e,t)=>e?.internals.positionAbsolute.x!==t?.internals.positionAbsolute.x||e?.internals.positionAbsolute.y!==t?.internals.positionAbsolute.y||e?.measured.width!==t?.measured.width||e?.measured.height!==t?.measured.height||e?.selected!==t?.selected||e?.internals.z!==t?.internals.z,Nd=(e,t)=>{if(e.size!==t.size)return!1;for(let[n,r]of e)if(Md(r,t.get(n)))return!1;return!0},Pd=e=>({x:e.transform[0],y:e.transform[1],zoom:e.transform[2],selectedNodesCount:e.nodes.filter(e=>e.selected).length});function Fd({nodeId:e,children:t,className:n,style:r,isVisible:a,position:o=X.Top,offset:s=10,align:c=`center`,...l}){let u=ml(),d=Q(i(t=>(Array.isArray(e)?e:[e||u||``]).reduce((e,n)=>{let r=t.nodeLookup.get(n);return r&&e.set(r.id,r),e},new Map),[e,u]),Nd),{x:p,y:m,zoom:h,selectedNodesCount:_}=Q(Pd,Z);if(!(typeof a==`boolean`?a:d.size===1&&d.values().next().value?.selected&&_===1)||!d.size)return null;let v=Sa(d),y=Array.from(d.values()),b=Math.max(...y.map(e=>e.internals.z+1));return f(jd,{children:f(`div`,{style:{position:`absolute`,transform:Ro(v,{x:p,y:m,zoom:h},o,s,c),zIndex:b,...r},className:g([`react-flow__node-toolbar`,n]),...l,"data-id":y.reduce((e,t)=>`${e}${t.id} `,``).trim(),children:t})})}export{La as C,Za as S,Mo as _,Fd as a,Ao as b,ed as c,Xu as d,Yc as f,_o as g,X as h,vl as i,Fc as l,$ as m,rd as n,uc as o,Q as p,Qu as r,Ku as s,sd as t,Pc as u,$a as v,Xa as x,xa as y};
@@ -0,0 +1 @@
1
+ var e=(r,i=[])=>({parts:(...t)=>{if(n(i))return e(r,t);throw Error(`createAnatomy().parts(...) should only be called once. Did you mean to use .extendWith(...) ?`)},extendWith:(...t)=>e(r,[...i,...t]),omit:(...t)=>e(r,i.filter(e=>!t.includes(e))),rename:t=>e(t,i),keys:()=>i,build:()=>[...new Set(i)].reduce((e,n)=>Object.assign(e,{[n]:{selector:[`&[data-scope="${t(r)}"][data-part="${t(n)}"]`,`& [data-scope="${t(r)}"][data-part="${t(n)}"]`].join(`, `),attrs:{"data-scope":t(r),"data-part":t(n)}}}),{})}),t=e=>e.replace(/([A-Z])([A-Z])/g,`$1-$2`).replace(/([a-z])([A-Z])/g,`$1-$2`).replace(/[\s_]+/g,`-`).toLowerCase(),n=e=>e.length===0;export{e as t};
@@ -0,0 +1 @@
1
+ function e(e){return e==null?[]:Array.isArray(e)?e:[e]}var t=e=>e[0],n=e=>e[e.length-1],r=(e,t)=>e.indexOf(t)!==-1,i=(e,...t)=>e.concat(t),a=(e,...t)=>e.filter(e=>!t.includes(e)),o=e=>Array.from(new Set(e)),s=(e,t)=>{let n=new Set(t);return e.filter(e=>!n.has(e))},c=(e,t)=>r(e,t)?a(e,t):i(e,t);function l(e,t){return e.reduce(([e,n],r)=>(t(r)?e.push(r):n.push(r),[e,n]),[[],[]])}var u=e=>e?.constructor.name===`Array`,d=(e,t)=>{if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(!f(e[n],t[n]))return!1;return!0},f=(e,t)=>{if(Object.is(e,t))return!0;if(e==null&&t!=null||e!=null&&t==null)return!1;if(typeof e?.isEqual==`function`&&typeof t?.isEqual==`function`)return e.isEqual(t);if(typeof e==`function`&&typeof t==`function`)return e.toString()===t.toString();if(u(e)&&u(t))return d(Array.from(e),Array.from(t));if(typeof e!=`object`||typeof t!=`object`)return!1;let n=Object.keys(t??Object.create(null)),r=n.length;for(let t=0;t<r;t++)if(!Reflect.has(e,n[t]))return!1;for(let i=0;i<r;i++){let r=n[i];if(!f(e[r],t[r]))return!1}return!0},p=e=>Array.isArray(e),m=e=>typeof e==`object`&&!!e,h=e=>m(e)&&!p(e),g=e=>typeof e==`string`,_=e=>typeof e==`function`,v=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),y=e=>Object.prototype.toString.call(e),b=Function.prototype.toString,x=b.call(Object),S=e=>{if(!m(e)||y(e)!=`[object Object]`||te(e))return!1;let t=Object.getPrototypeOf(e);if(t===null)return!0;let n=v(t,`constructor`)&&t.constructor;return typeof n==`function`&&n instanceof n&&b.call(n)==x},C=e=>typeof e==`object`&&!!e&&`$$typeof`in e&&`props`in e,ee=e=>typeof e==`object`&&!!e&&`__v_isVNode`in e,te=e=>C(e)||ee(e),ne=e=>e(),re=(...e)=>(...t)=>{e.forEach(function(e){e?.(...t)})},{floor:ie,abs:ae,round:oe,min:se,max:ce,pow:le,sign:ue}=Math;function w(e){if(!S(e)||e===void 0)return e;let t=Reflect.ownKeys(e).filter(e=>typeof e==`string`),n={};for(let r of t){let t=e[r];t!==void 0&&(n[r]=w(t))}return n}function T(e,t){let n={},r={},i=new Set(t),a=Reflect.ownKeys(e);for(let t of a)i.has(t)?r[t]=e[t]:n[t]=e[t];return[r,n]}var E=e=>function(t){return T(t,e)};function D(...e){e.length===1?e[0]:e[1],e.length===2&&e[0]}function O(e,t){if(e==null)throw Error(t())}var k=Object.defineProperty,A=(e,t,n)=>t in e?k(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,j=(e,t,n)=>A(e,typeof t==`symbol`?t:t+``,n);function M(e,t,n){for(let r=0;r<t.length;r++)e=n.getChildren(e,t.slice(r+1))[t[r]];return e}function N(e){let t=F(e),n=[],r=new Set;for(let e of t){let t=e.join();r.has(t)||(r.add(t),n.push(e))}return n}function P(e,t){for(let n=0;n<Math.min(e.length,t.length);n++){if(e[n]<t[n])return-1;if(e[n]>t[n])return 1}return e.length-t.length}function F(e){return e.sort(P)}function I(e,t){let n;return Z(e,{...t,onEnter:(e,r)=>{if(t.predicate(e,r))return n=e,`stop`}}),n}function de(e,t){let n=[];return Z(e,{onEnter:(e,r)=>{t.predicate(e,r)&&n.push(e)},getChildren:t.getChildren}),n}function L(e,t){let n;return Z(e,{onEnter:(e,r)=>{if(t.predicate(e,r))return n=[...r],`stop`},getChildren:t.getChildren}),n}function R(e,t){let n=t.initialResult;return Z(e,{...t,onEnter:(e,r)=>{n=t.nextResult(n,e,r)}}),n}function z(e,t){return R(e,{...t,initialResult:[],nextResult:(e,n,r)=>(e.push(...t.transform(n,r)),e)})}function B(e,t){let{predicate:n,create:r,getChildren:i}=t,a=(e,t)=>{let o=i(e,t),s=[];o.forEach((e,n)=>{let r=a(e,[...t,n]);r&&s.push(r)});let c=t.length===0,l=n(e,t),u=s.length>0;return c||l||u?r(e,s,t):null};return a(e,[])||r(e,[],[])}function V(e,t){let n=[],r=0,i=new Map,a=new Map;return Z(e,{getChildren:t.getChildren,onEnter:(e,o)=>{i.has(e)||i.set(e,r++);let s=t.getChildren(e,o);s.forEach(t=>{a.has(t)||a.set(t,e),i.has(t)||i.set(t,r++)});let c=s.length>0?s.map(e=>i.get(e)):void 0,l=a.get(e),u=l?i.get(l):void 0,d=i.get(e);n.push({...e,_children:c,_parent:u,_index:d})}}),n}function H(e,t){return{type:`insert`,index:e,nodes:t}}function U(e){return{type:`remove`,indexes:e}}function W(){return{type:`replace`}}function G(e){return[e.slice(0,-1),e[e.length-1]]}function K(e,t,n=new Map){let[r,i]=G(e);for(let e=r.length-1;e>=0;e--){let t=r.slice(0,e).join();switch(n.get(t)?.type){case`remove`:continue}n.set(t,W())}let a=n.get(r.join());switch(a?.type){case`remove`:n.set(r.join(),{type:`removeThenInsert`,removeIndexes:a.indexes,insertIndex:i,insertNodes:t});break;default:n.set(r.join(),H(i,t))}return n}function q(e){let t=new Map,n=new Map;for(let t of e){let e=t.slice(0,-1).join(),r=n.get(e)??[];r.push(t[t.length-1]),n.set(e,r.sort((e,t)=>e-t))}for(let n of e)for(let e=n.length-2;e>=0;e--){let r=n.slice(0,e).join();t.has(r)||t.set(r,W())}for(let[e,r]of n)t.set(e,U(r));return t}function fe(e,t){let n=new Map,[r,i]=G(e);for(let e=r.length-1;e>=0;e--){let t=r.slice(0,e).join();n.set(t,W())}return n.set(r.join(),{type:`removeThenInsert`,removeIndexes:[i],insertIndex:i,insertNodes:[t]}),n}function J(e,t,n){return X(e,{...n,getChildren:(e,r)=>{let i=r.join();switch(t.get(i)?.type){case`replace`:case`remove`:case`removeThenInsert`:case`insert`:return n.getChildren(e,r);default:return[]}},transform:(e,r,i)=>{let a=i.join(),o=t.get(a);switch(o?.type){case`remove`:return n.create(e,r.filter((e,t)=>!o.indexes.includes(t)),i);case`removeThenInsert`:let t=r.filter((e,t)=>!o.removeIndexes.includes(t)),a=o.removeIndexes.reduce((e,t)=>t<e?e-1:e,o.insertIndex);return n.create(e,Y(t,a,0,...o.insertNodes),i);case`insert`:return n.create(e,Y(r,o.index,0,...o.nodes),i);case`replace`:return n.create(e,r,i);default:return e}}})}function Y(e,t,n,...r){return[...e.slice(0,t),...r,...e.slice(t+n)]}function X(e,t){let n={};return Z(e,{...t,onLeave:(e,r)=>{let i=[0,...r],a=i.join(),o=t.transform(e,n[a]??[],r),s=i.slice(0,-1).join(),c=n[s]??[];c.push(o),n[s]=c}}),n[``][0]}function pe(e,t){let{nodes:n,at:r}=t;if(r.length===0)throw Error(`Can't insert nodes at the root`);return J(e,K(r,n),t)}function me(e,t){return t.at.length===0?t.node:J(e,fe(t.at,t.node),t)}function he(e,t){if(t.indexPaths.length===0)return e;for(let e of t.indexPaths)if(e.length===0)throw Error(`Can't remove the root node`);return J(e,q(t.indexPaths),t)}function ge(e,t){if(t.indexPaths.length===0)return e;for(let e of t.indexPaths)if(e.length===0)throw Error(`Can't move the root node`);if(t.to.length===0)throw Error(`Can't move nodes to the root`);let n=N(t.indexPaths),r=n.map(n=>M(e,n,t));return J(e,K(t.to,r,q(n)),t)}function Z(e,t){let{onEnter:n,onLeave:r,getChildren:i}=t,a=[],o=[{node:e}],s=t.reuseIndexPath?()=>a:()=>a.slice();for(;o.length>0;){let e=o[o.length-1];if(e.state===void 0){let t=n?.(e.node,s());if(t===`stop`)return;e.state=t===`skip`?-1:0}let t=e.children||i(e.node,s());if(e.children||=t,e.state!==-1){if(e.state<t.length){let n=e.state;a.push(n),o.push({node:t[n]}),e.state=n+1;continue}if(r?.(e.node,s())===`stop`)return}a.pop(),o.pop()}}var Q=class e{constructor(t){this.options=t,j(this,`rootNode`),j(this,`isEqual`,e=>f(this.rootNode,e.rootNode)),j(this,`getNodeChildren`,e=>this.options.nodeToChildren?.(e)??$.nodeToChildren(e)??[]),j(this,`resolveIndexPath`,e=>typeof e==`string`?this.getIndexPath(e):e),j(this,`resolveNode`,e=>{let t=this.resolveIndexPath(e);return t?this.at(t):void 0}),j(this,`getNodeChildrenCount`,e=>this.options.nodeToChildrenCount?.(e)??$.nodeToChildrenCount(e)),j(this,`getNodeValue`,e=>this.options.nodeToValue?.(e)??$.nodeToValue(e)),j(this,`getNodeDisabled`,e=>this.options.isNodeDisabled?.(e)??$.isNodeDisabled(e)),j(this,`stringify`,e=>{let t=this.findNode(e);return t?this.stringifyNode(t):null}),j(this,`stringifyNode`,e=>this.options.nodeToString?.(e)??$.nodeToString(e)),j(this,`getFirstNode`,(e=this.rootNode,t={})=>{let n;return Z(e,{getChildren:this.getNodeChildren,onEnter:(r,i)=>{if(!this.isSameNode(r,e)){if(t.skip?.({value:this.getNodeValue(r),node:r,indexPath:i}))return`skip`;if(!n&&i.length>0&&!this.getNodeDisabled(r))return n=r,`stop`}}}),n}),j(this,`getLastNode`,(e=this.rootNode,t={})=>{let n;return Z(e,{getChildren:this.getNodeChildren,onEnter:(r,i)=>{if(!this.isSameNode(r,e)){if(t.skip?.({value:this.getNodeValue(r),node:r,indexPath:i}))return`skip`;i.length>0&&!this.getNodeDisabled(r)&&(n=r)}}}),n}),j(this,`at`,e=>M(this.rootNode,e,{getChildren:this.getNodeChildren})),j(this,`findNode`,(e,t=this.rootNode)=>I(t,{getChildren:this.getNodeChildren,predicate:t=>this.getNodeValue(t)===e})),j(this,`findNodes`,(e,t=this.rootNode)=>{let n=new Set(e.filter(e=>e!=null));return de(t,{getChildren:this.getNodeChildren,predicate:e=>n.has(this.getNodeValue(e))})}),j(this,`sort`,e=>e.reduce((e,t)=>{let n=this.getIndexPath(t);return n&&e.push({value:t,indexPath:n}),e},[]).sort((e,t)=>P(e.indexPath,t.indexPath)).map(({value:e})=>e)),j(this,`getIndexPath`,e=>L(this.rootNode,{getChildren:this.getNodeChildren,predicate:t=>this.getNodeValue(t)===e})),j(this,`getValue`,e=>{let t=this.at(e);return t?this.getNodeValue(t):void 0}),j(this,`getValuePath`,e=>{if(!e)return[];let t=[],n=[...e];for(;n.length>0;){let e=this.at(n);e&&t.unshift(this.getNodeValue(e)),n.pop()}return t}),j(this,`getDepth`,e=>L(this.rootNode,{getChildren:this.getNodeChildren,predicate:t=>this.getNodeValue(t)===e})?.length??0),j(this,`isSameNode`,(e,t)=>this.getNodeValue(e)===this.getNodeValue(t)),j(this,`isRootNode`,e=>this.isSameNode(e,this.rootNode)),j(this,`contains`,(e,t)=>!e||!t?!1:t.slice(0,e.length).every((n,r)=>e[r]===t[r])),j(this,`getNextNode`,(e,t={})=>{let n=!1,r;return Z(this.rootNode,{getChildren:this.getNodeChildren,onEnter:(i,a)=>{if(this.isRootNode(i))return;let o=this.getNodeValue(i);if(t.skip?.({value:o,node:i,indexPath:a}))return o===e&&(n=!0),`skip`;if(n&&!this.getNodeDisabled(i))return r=i,`stop`;o===e&&(n=!0)}}),r}),j(this,`getPreviousNode`,(e,t={})=>{let n,r=!1;return Z(this.rootNode,{getChildren:this.getNodeChildren,onEnter:(i,a)=>{if(this.isRootNode(i))return;let o=this.getNodeValue(i);if(t.skip?.({value:o,node:i,indexPath:a}))return`skip`;if(o===e)return r=!0,`stop`;this.getNodeDisabled(i)||(n=i)}}),r?n:void 0}),j(this,`getParentNodes`,e=>{let t=this.resolveIndexPath(e)?.slice();if(!t)return[];let n=[];for(;t.length>0;){t.pop();let e=this.at(t);e&&!this.isRootNode(e)&&n.unshift(e)}return n}),j(this,`getDescendantNodes`,(e,t)=>{let n=this.resolveNode(e);if(!n)return[];let r=[];return Z(n,{getChildren:this.getNodeChildren,onEnter:(e,n)=>{n.length!==0&&(!t?.withBranch&&this.isBranchNode(e)||r.push(e))}}),r}),j(this,`getDescendantValues`,(e,t)=>this.getDescendantNodes(e,t).map(e=>this.getNodeValue(e))),j(this,`getParentIndexPath`,e=>e.slice(0,-1)),j(this,`getParentNode`,e=>{let t=this.resolveIndexPath(e);return t?this.at(this.getParentIndexPath(t)):void 0}),j(this,`visit`,e=>{let{skip:t,...n}=e;Z(this.rootNode,{...n,getChildren:this.getNodeChildren,onEnter:(e,r)=>{if(!this.isRootNode(e))return t?.({value:this.getNodeValue(e),node:e,indexPath:r})?`skip`:n.onEnter?.(e,r)}})}),j(this,`getPreviousSibling`,e=>{let t=this.getParentNode(e);if(!t)return;let n=this.getNodeChildren(t),r=e[e.length-1];for(;--r>=0;){let e=n[r];if(!this.getNodeDisabled(e))return e}}),j(this,`getNextSibling`,e=>{let t=this.getParentNode(e);if(!t)return;let n=this.getNodeChildren(t),r=e[e.length-1];for(;++r<n.length;){let e=n[r];if(!this.getNodeDisabled(e))return e}}),j(this,`getSiblingNodes`,e=>{let t=this.getParentNode(e);return t?this.getNodeChildren(t):[]}),j(this,`getValues`,(e=this.rootNode)=>z(e,{getChildren:this.getNodeChildren,transform:e=>[this.getNodeValue(e)]}).slice(1)),j(this,`isValidDepth`,(e,t)=>t==null?!0:typeof t==`function`?t(e.length):e.length===t),j(this,`isBranchNode`,e=>this.getNodeChildren(e).length>0||this.getNodeChildrenCount(e)!=null),j(this,`getBranchValues`,(e=this.rootNode,t={})=>{let n=[];return Z(e,{getChildren:this.getNodeChildren,onEnter:(e,r)=>{if(r.length===0)return;let i=this.getNodeValue(e);if(t.skip?.({value:i,node:e,indexPath:r}))return`skip`;this.isBranchNode(e)&&this.isValidDepth(r,t.depth)&&n.push(this.getNodeValue(e))}}),n}),j(this,`flatten`,(e=this.rootNode)=>V(e,{getChildren:this.getNodeChildren})),j(this,`_create`,(e,t)=>this.getNodeChildren(e).length>0||t.length>0?{...e,children:t}:{...e}),j(this,`_insert`,(e,t,n)=>this.copy(pe(e,{at:t,nodes:n,getChildren:this.getNodeChildren,create:this._create}))),j(this,`copy`,t=>new e({...this.options,rootNode:t})),j(this,`_replace`,(e,t,n)=>this.copy(me(e,{at:t,node:n,getChildren:this.getNodeChildren,create:this._create}))),j(this,`_move`,(e,t,n)=>this.copy(ge(e,{indexPaths:t,to:n,getChildren:this.getNodeChildren,create:this._create}))),j(this,`_remove`,(e,t)=>this.copy(he(e,{indexPaths:t,getChildren:this.getNodeChildren,create:this._create}))),j(this,`replace`,(e,t)=>this._replace(this.rootNode,e,t)),j(this,`remove`,e=>this._remove(this.rootNode,e)),j(this,`insertBefore`,(e,t)=>this.getParentNode(e)?this._insert(this.rootNode,e,t):void 0),j(this,`insertAfter`,(e,t)=>{if(!this.getParentNode(e))return;let n=[...e.slice(0,-1),e[e.length-1]+1];return this._insert(this.rootNode,n,t)}),j(this,`move`,(e,t)=>this._move(this.rootNode,e,t)),j(this,`filter`,e=>{let t=B(this.rootNode,{predicate:e,getChildren:this.getNodeChildren,create:this._create});return this.copy(t)}),j(this,`toJSON`,()=>this.getValues(this.rootNode)),this.rootNode=t.rootNode}},$={nodeToValue(e){return typeof e==`string`?e:h(e)&&v(e,`value`)?e.value:``},nodeToString(e){return typeof e==`string`?e:h(e)&&v(e,`label`)?e.label:$.nodeToValue(e)},isNodeDisabled(e){return h(e)&&v(e,`disabled`)?!!e.disabled:!1},nodeToChildren(e){return e.children},nodeToChildrenCount(e){if(h(e)&&v(e,`childrenCount`))return e.childrenCount}};export{a as _,w as a,D as b,O as c,p as d,f,l as g,n as h,re as i,t as l,g as m,i as n,E as o,_ as p,c as r,s,Q as t,ne as u,e as v,o as y};
@@ -0,0 +1 @@
1
+ import{i as e,m as t}from"./collection.mjs";var n=Object.defineProperty,r=(e,t,r)=>t in e?n(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,i=(e,t,n)=>r(e,typeof t==`symbol`?t:t+``,n),a=(e,t)=>e.map((n,r)=>e[(Math.max(t,0)+r)%e.length]),o=e=>typeof e==`object`&&!!e,s=e=>e?``:void 0,c=e=>e?`true`:void 0,l=1,u=9,d=11,f=e=>o(e)&&e.nodeType===l&&typeof e.nodeName==`string`,p=e=>o(e)&&e.nodeType===u,m=e=>o(e)&&e===e.window,h=e=>o(e)&&e.nodeType!==void 0,g=e=>h(e)&&e.nodeType===d&&`host`in e,_=e=>f(e)&&e.localName===`input`,v=e=>!!e?.matches(`a[href]`);function y(e){return e?C(e.getRootNode())===e:!1}var ee=/(textarea|select)/;function b(e){if(e==null||!f(e))return!1;try{return _(e)&&e.selectionStart!=null||ee.test(e.localName)||e.isContentEditable||e.getAttribute(`contenteditable`)===`true`||e.getAttribute(`contenteditable`)===``}catch{return!1}}function x(e){return p(e)?e:m(e)?e.document:e?.ownerDocument??document}function S(e){return g(e)?S(e.host):p(e)?e.defaultView??window:f(e)?e.ownerDocument?.defaultView??window:window}function C(e){let t=e.activeElement;for(;t?.shadowRoot;){let e=t.shadowRoot.activeElement;if(!e||e===t)break;t=e}return t}function w(e){return e.composedPath?.()??e.nativeEvent?.composedPath?.()}function T(e){return w(e)?.[0]??e.target}function E(e){return M(e).isComposing||e.keyCode===229}var D=e=>e.button===0,O=e=>e.ctrlKey||e.altKey||e.metaKey,k={Up:`ArrowUp`,Down:`ArrowDown`,Esc:`Escape`," ":`Space`,",":`Comma`,Left:`ArrowLeft`,Right:`ArrowRight`},A={ArrowLeft:`ArrowRight`,ArrowRight:`ArrowLeft`};function j(e,t={}){let{dir:n=`ltr`,orientation:r=`horizontal`}=t,i=e.key;return i=k[i]??i,n===`rtl`&&r===`horizontal`&&i in A&&(i=A[i]),i}function M(e){return e.nativeEvent??e}function N(e,t){let{type:n=`HTMLInputElement`,property:r=`value`}=t,i=S(e)[n].prototype;return Object.getOwnPropertyDescriptor(i,r)??{}}function P(e){if(e.localName===`input`)return`HTMLInputElement`;if(e.localName===`textarea`)return`HTMLTextAreaElement`;if(e.localName===`select`)return`HTMLSelectElement`}function F(e,t,n=`value`){if(!e)return;let r=P(e);r&&N(e,{type:r,property:n}).set?.call(e,t),e.setAttribute(n,t)}var te=class e{constructor(){i(this,`id`,null),i(this,`fn_cleanup`),i(this,`cleanup`,()=>{this.cancel()})}static create(){return new e}request(e){this.cancel(),this.id=globalThis.requestAnimationFrame(()=>{this.id=null,this.fn_cleanup=e?.()})}cancel(){this.id!==null&&(globalThis.cancelAnimationFrame(this.id),this.id=null),this.fn_cleanup?.(),this.fn_cleanup=void 0}isActive(){return this.id!==null}};function I(e){let t=te.create();return t.request(e),t.cleanup}var L=e=>e.id;function R(e,t,n=L){return e.find(e=>n(e)===t)}function z(e,t,n=L){let r=R(e,t,n);return r?e.indexOf(r):-1}var B=e=>e.split(``).map(e=>{let t=e.charCodeAt(0);return t>0&&t<128?e:t>=128&&t<=255?`/x${t.toString(16)}`.replace(`/`,`\\`):``}).join(``).trim(),V=e=>B(e.dataset?.valuetext??e.textContent??``),H=(e,t)=>e.trim().toLowerCase().startsWith(t.toLowerCase());function U(e,t,n,r=L){let i=n?z(e,n,r):-1,o=n?a(e,i):e;return t.length===1&&(o=o.filter(e=>r(e)!==n)),o.find(e=>H(V(e),t))}function W(e,t){let{state:n,activeId:r,key:i,timeout:a=350,itemToId:o}=t,s=n.keysSoFar+i,c=s.length>1&&Array.from(s).every(e=>e===s[0])?s[0]:s,l=U(e.slice(),c,r,o);function u(){clearTimeout(n.timer),n.timer=-1}function d(e){n.keysSoFar=e,u(),e!==``&&(n.timer=+setTimeout(()=>{d(``),u()},a))}return d(s),l}var G=Object.assign(W,{defaultOptions:{keysSoFar:``,timer:-1},isValidEvent:K});function K(e){return e.key.length===1&&!e.ctrlKey&&!e.metaKey}var q=(...e)=>e.map(e=>e?.trim?.()).filter(Boolean).join(` `),J=/((?:--)?(?:\w+-?)+)\s*:\s*([^;]*)/g,Y=e=>{let t={},n;for(;n=J.exec(e);)t[n[1]]=n[2];return t},X=(e,n)=>{if(t(e)){if(t(n))return`${e};${n}`;e=Y(e)}else t(n)&&(n=Y(n));return Object.assign({},e??{},n??{})};function Z(...t){let n={};for(let r of t){if(!r)continue;for(let t in n){if(t.startsWith(`on`)&&typeof n[t]==`function`&&typeof r[t]==`function`){n[t]=e(r[t],n[t]);continue}if(t===`className`||t===`class`){n[t]=q(n[t],r[t]);continue}if(t===`style`){n[t]=X(n[t],r[t]);continue}n[t]=r[t]===void 0?n[t]:r[t]}for(let e in r)n[e]===void 0&&(n[e]=r[e]);let t=Object.getOwnPropertySymbols(r);for(let e of t)n[e]=r[e]}return n}function Q(){return{and:(...e)=>function(t){return e.every(e=>t.guard(e))},or:(...e)=>function(t){return e.some(e=>t.guard(e))},not:e=>function(t){return!t.guard(e)}}}function ne(e){return e}var $=(e=>(e.NotStarted=`Not Started`,e.Started=`Started`,e.Stopped=`Stopped`,e))($||{}),re=`__init__`;function ie(e){let t=()=>e.getRootNode?.()??document,n=()=>x(t()),r=()=>n().defaultView??window,i=()=>C(t()),a=e=>t().getElementById(e);return{...e,getRootNode:t,getDoc:n,getWin:r,getActiveElement:i,isActiveElement:y,getById:a}}export{I as _,ie as a,s as c,T as d,v as f,O as g,D as h,ne as i,G as l,b as m,$ as n,Z as o,E as p,Q as r,c as s,re as t,j as u,F as v};
@@ -0,0 +1 @@
1
+ import{a as e,b as t,c as n,m as r,p as i,u as a,v as o}from"./collection.mjs";import{a as s,n as c,t as l}from"./core.mjs";import{useEffect as u,useLayoutEffect as d,useMemo as f,useRef as p,useState as m}from"react";import"react/jsx-runtime";import{flushSync as h}from"react-dom";function g(e){return new Proxy({},{get(t,n){return n===`style`?t=>e({style:t}).style:e}})}var _=()=>e=>Array.from(new Set(e)),v=globalThis.document===void 0?u:d;function y(e){let t=e().value??e().defaultValue,n=e().isEqual??Object.is,[r]=m(t),[o,s]=m(r),c=e().value!==void 0,l=p(o);l.current=c?e().value:o;let u=p(l.current);v(()=>{u.current=l.current},[o,e().value]);let d=t=>{let r=u.current,a=i(t)?t(r):t;e().debug&&console.log(`[bindable > ${e().debug}] setValue`,{next:a,prev:r}),c||s(a),n(a,r)||e().onChange?.(a,r)};function f(){return c?e().value:o}return{initial:r,ref:l,get:f,set(t){(e().sync?h:a)(()=>d(t))},invoke(t,n){e().onChange?.(t,n)},hash(t){return e().hash?.(t)??String(t)}}}y.cleanup=e=>{u(()=>e,[])},y.ref=e=>{let t=p(e);return{get:()=>t.current,set:e=>{t.current=e}}};function b(e){let t=p(e);return{get(e){return t.current[e]},set(e,n){t.current[e]=n}}}var x=(e,t)=>{let n=p(!1),r=p(!1);u(()=>{if(n.current&&r.current)return t();r.current=!0},[...(e??[]).map(e=>typeof e==`function`?e():e)]),u(()=>(n.current=!0,()=>{n.current=!1}),[])};function S(a,u={}){let d=f(()=>{let{id:e,ids:t,getRootNode:n}=u;return s({id:e,ids:t,getRootNode:n})},[u]),m=(...e)=>{a.debug&&console.log(...e)},g=w(a.props?.({props:e(u),scope:d})??u),_=a.context?.({prop:g,bindable:y,scope:d,flush:T,getContext(){return E},getComputed(){return z},getRefs(){return N},getEvent(){return j()}}),S=C(_),E={get(e){return S.current?.[e].ref.current},set(e,t){S.current?.[e].set(t)},initial(e){return S.current?.[e].initial},hash(e){let t=S.current?.[e].get();return S.current?.[e].hash(t)}},D=p(new Map),O=p(null),k=p(null),A=p({type:``}),j=()=>({...A.current,current(){return A.current},previous(){return k.current}}),M=()=>({...B,matches(...e){return e.includes(B.ref.current)},hasTag(e){return!!a.states[B.ref.current]?.tags?.includes(e)}}),N=b(a.refs?.({prop:g,context:E})??{}),P=()=>({state:M(),context:E,event:j(),prop:g,send:W,action:F,guard:I,track:x,refs:N,computed:z,flush:T,scope:d,choose:R}),F=e=>{let n=i(e)?e(P()):e;if(!n)return;let r=n.map(e=>{let n=a.implementations?.actions?.[e];return n||t(`[zag-js] No implementation found for action "${JSON.stringify(e)}"`),n});for(let e of r)e?.(P())},I=e=>i(e)?e(P()):a.implementations?.guards?.[e](P()),L=e=>{let n=i(e)?e(P()):e;if(!n)return;let r=n.map(e=>{let n=a.implementations?.effects?.[e];return n||t(`[zag-js] No implementation found for effect "${JSON.stringify(e)}"`),n}),o=[];for(let e of r){let t=e?.(P());t&&o.push(t)}return()=>o.forEach(e=>e?.())},R=e=>o(e).find(e=>{let t=!e.guard;return r(e.guard)?t=!!I(e.guard):i(e.guard)&&(t=e.guard(P())),t}),z=e=>{n(a.computed,()=>`[zag-js] No computed object found on machine`);let t=a.computed[e];return t({context:E,event:j(),prop:g,refs:N,scope:d,computed:z})},B=y(()=>({defaultValue:a.initialState({prop:g}),onChange(e,t){t&&(D.current.get(t)?.(),D.current.delete(t)),t&&F(a.states[t]?.exit),F(O.current?.actions);let n=L(a.states[e]?.effects);if(n&&D.current.set(e,n),t===`__init__`){F(a.entry);let e=L(a.effects);e&&D.current.set(l,e)}F(a.states[e]?.entry)}})),V=p(void 0),H=p(c.NotStarted);v(()=>{queueMicrotask(()=>{let e=H.current===c.Started;H.current=c.Started,m(e?`rehydrating...`:`initializing...`);let t=V.current??B.initial;B.invoke(t,e?B.get():l)});let e=D.current,t=B.ref.current;return()=>{m(`unmounting...`),V.current=t,H.current=c.Stopped,e.forEach(e=>e?.()),D.current=new Map,O.current=null,queueMicrotask(()=>{F(a.exit)})}},[]);let U=()=>`ref`in B?B.ref.current:B.get(),W=e=>{queueMicrotask(()=>{if(H.current!==c.Started)return;k.current=A.current,A.current=e;let t=U(),n=R(a.states[t].on?.[e.type]??a.on?.[e.type]);if(!n)return;O.current=n;let r=n.target??t;m(`transition`,e.type,n.target||t,`(${n.actions})`);let i=r!==t;i?h(()=>B.set(r)):n.reenter&&!i?B.invoke(t,t):F(n.actions??[])})};return a.watch?.(P()),{state:M(),send:W,context:E,prop:g,scope:d,refs:N,computed:z,event:j(),getStatus:()=>H.current}}function C(e){let t=p(e);return t.current=e,t}function w(e){let t=C(e);return function(e){return t.current[e]}}function T(e){queueMicrotask(()=>{h(()=>e())})}var E=g(e=>e);export{S as n,_ as r,E as t};
@@ -0,0 +1 @@
1
+ import{_ as e,c as t,d as n,f as r,g as i,h as a,l as o,n as s,o as c,r as l,s as u,t as d,v as f,y as p}from"./collection.mjs";import{_ as m,c as h,d as g,f as _,g as v,h as y,i as b,l as x,m as S,p as C,r as w,s as T,u as E,v as D}from"./core.mjs";import{r as O}from"./react.mjs";import{t as k}from"./anatomy.mjs";var A=k(`tree-view`).parts(`branch`,`branchContent`,`branchControl`,`branchIndentGuide`,`branchIndicator`,`branchText`,`branchTrigger`,`item`,`itemIndicator`,`itemText`,`label`,`nodeCheckbox`,`nodeRenameInput`,`root`,`tree`).build(),j=e=>new d(e);j.empty=()=>new d({rootNode:{children:[]}});var M=e=>e.ids?.root??`tree:${e.id}:root`,N=e=>e.ids?.label??`tree:${e.id}:label`,P=(e,t)=>e.ids?.node?.(t)??`tree:${e.id}:node:${t}`,F=e=>e.ids?.tree??`tree:${e.id}:tree`,I=(e,t)=>{t!=null&&e.getById(P(e,t))?.focus()},L=(e,t)=>`tree:${e.id}:rename-input:${t}`,R=(e,t)=>e.getById(L(e,t));function z(e,t,n){let r=e.getNodeValue(t);if(!e.isBranchNode(t))return n.includes(r);let i=e.getDescendantValues(r),a=i.every(e=>n.includes(e)),o=i.some(e=>n.includes(e));return a?!0:o?`indeterminate`:!1}function B(t,n,r){let i=t.getDescendantValues(n);return p(i.every(e=>r.includes(e))?e(r,...i):s(r,...i))}function V(e,t){let n=new Map;return e.visit({onEnter:r=>{let i=e.getNodeValue(r),a=e.isBranchNode(r),o=z(e,r,t);n.set(i,{type:a?`branch`:`leaf`,checked:o})}}),n}function H(e,t){let{context:n,scope:r,computed:i,prop:a,send:o}=e,c=a(`collection`),l=Array.from(n.get(`expandedValue`)),u=Array.from(n.get(`selectedValue`)),d=Array.from(n.get(`checkedValue`)),f=i(`isTypingAhead`),m=n.get(`focusedValue`),b=n.get(`loadingStatus`),w=n.get(`renamingValue`),D=c.getFirstNode(void 0,{skip:({indexPath:e})=>c.getValuePath(e).slice(0,-1).some(e=>!l.includes(e))}),O=D?c.getNodeValue(D):null;function k(e){let{node:t,indexPath:n}=e,i=c.getNodeValue(t);return{id:P(r,i),value:i,indexPath:n,valuePath:c.getValuePath(n),disabled:!!t.disabled,focused:m==null?O===i:m===i,selected:u.includes(i),expanded:l.includes(i),loading:b[i]===`loading`,depth:n.length,isBranch:c.isBranchNode(t),renaming:w===i,get checked(){return z(c,t,d)}}}return{collection:c,expandedValue:l,selectedValue:u,checkedValue:d,toggleChecked(e,t){o({type:`CHECKED.TOGGLE`,value:e,isBranch:t})},setChecked(e){o({type:`CHECKED.SET`,value:e})},clearChecked(){o({type:`CHECKED.CLEAR`})},getCheckedMap(){return V(c,d)},expand(e){o({type:e?`BRANCH.EXPAND`:`EXPANDED.ALL`,value:e})},collapse(e){o({type:e?`BRANCH.COLLAPSE`:`EXPANDED.CLEAR`,value:e})},deselect(e){o({type:e?`NODE.DESELECT`:`SELECTED.CLEAR`,value:e})},select(e){o({type:e?`NODE.SELECT`:`SELECTED.ALL`,value:e,isTrusted:!1})},getVisibleNodes(){return i(`visibleNodes`)},focus(e){I(r,e)},selectParent(e){let t=c.getParentNode(e);t&&o({type:`SELECTED.SET`,value:s(u,c.getNodeValue(t)),src:`select.parent`})},expandParent(e){let t=c.getParentNode(e);t&&o({type:`EXPANDED.SET`,value:s(l,c.getNodeValue(t)),src:`expand.parent`})},setExpandedValue(e){o({type:`EXPANDED.SET`,value:p(e)})},setSelectedValue(e){o({type:`SELECTED.SET`,value:p(e)})},startRenaming(e){o({type:`NODE.RENAME`,value:e})},submitRenaming(e,t){o({type:`RENAME.SUBMIT`,value:e,label:t})},cancelRenaming(){o({type:`RENAME.CANCEL`})},getRootProps(){return t.element({...A.root.attrs,id:M(r),dir:a(`dir`)})},getLabelProps(){return t.element({...A.label.attrs,id:N(r),dir:a(`dir`)})},getTreeProps(){return t.element({...A.tree.attrs,id:F(r),dir:a(`dir`),role:`tree`,"aria-label":`Tree View`,"aria-labelledby":N(r),"aria-multiselectable":a(`selectionMode`)===`multiple`||void 0,tabIndex:-1,onKeyDown(e){if(e.defaultPrevented||C(e))return;let t=g(e);if(S(t))return;let n=t?.closest(`[data-part=branch-control], [data-part=item]`);if(!n)return;let r=n.dataset.value;if(r==null){console.warn(`[zag-js/tree-view] Node id not found for node`,n);return}let i=n.matches(`[data-part=branch-control]`),s={ArrowDown(e){v(e)||(e.preventDefault(),o({type:`NODE.ARROW_DOWN`,id:r,shiftKey:e.shiftKey}))},ArrowUp(e){v(e)||(e.preventDefault(),o({type:`NODE.ARROW_UP`,id:r,shiftKey:e.shiftKey}))},ArrowLeft(e){v(e)||n.dataset.disabled||(e.preventDefault(),o({type:i?`BRANCH_NODE.ARROW_LEFT`:`NODE.ARROW_LEFT`,id:r}))},ArrowRight(e){!i||n.dataset.disabled||(e.preventDefault(),o({type:`BRANCH_NODE.ARROW_RIGHT`,id:r}))},Home(e){v(e)||(e.preventDefault(),o({type:`NODE.HOME`,id:r,shiftKey:e.shiftKey}))},End(e){v(e)||(e.preventDefault(),o({type:`NODE.END`,id:r,shiftKey:e.shiftKey}))},Space(e){n.dataset.disabled||(f?o({type:`TREE.TYPEAHEAD`,key:e.key}):s.Enter?.(e))},Enter(e){n.dataset.disabled||_(t)&&v(e)||(o({type:i?`BRANCH_NODE.CLICK`:`NODE.CLICK`,id:r,src:`keyboard`}),_(t)||e.preventDefault())},"*"(e){n.dataset.disabled||(e.preventDefault(),o({type:`SIBLINGS.EXPAND`,id:r}))},a(e){!e.metaKey||n.dataset.disabled||(e.preventDefault(),o({type:`SELECTED.ALL`,moveFocus:!0}))},F2(e){if(n.dataset.disabled)return;let t=a(`canRename`);if(!t)return;let i=c.getIndexPath(r);if(i){let e=c.at(i);if(e&&!t(e,i))return}e.preventDefault(),o({type:`NODE.RENAME`,value:r})}},l=s[E(e,{dir:a(`dir`)})];if(l){l(e);return}x.isValidEvent(e)&&(o({type:`TREE.TYPEAHEAD`,key:e.key,id:r}),e.preventDefault())}})},getNodeState:k,getItemProps(e){let n=k(e);return t.element({...A.item.attrs,id:n.id,dir:a(`dir`),"data-ownedby":F(r),"data-path":e.indexPath.join(`/`),"data-value":n.value,tabIndex:n.focused?0:-1,"data-focus":h(n.focused),role:`treeitem`,"aria-current":n.selected?`true`:void 0,"aria-selected":n.disabled?void 0:n.selected,"data-selected":h(n.selected),"aria-disabled":T(n.disabled),"data-disabled":h(n.disabled),"data-renaming":h(n.renaming),"aria-level":n.depth,"data-depth":n.depth,style:{"--depth":n.depth},onFocus(e){e.stopPropagation(),o({type:`NODE.FOCUS`,id:n.value})},onClick(e){if(n.disabled||!y(e)||_(e.currentTarget)&&v(e))return;let t=e.metaKey||e.ctrlKey;o({type:`NODE.CLICK`,id:n.value,shiftKey:e.shiftKey,ctrlKey:t}),e.stopPropagation(),_(e.currentTarget)||e.preventDefault()}})},getItemTextProps(e){let n=k(e);return t.element({...A.itemText.attrs,"data-disabled":h(n.disabled),"data-selected":h(n.selected),"data-focus":h(n.focused)})},getItemIndicatorProps(e){let n=k(e);return t.element({...A.itemIndicator.attrs,"aria-hidden":!0,"data-disabled":h(n.disabled),"data-selected":h(n.selected),"data-focus":h(n.focused),hidden:!n.selected})},getBranchProps(e){let n=k(e);return t.element({...A.branch.attrs,"data-depth":n.depth,dir:a(`dir`),"data-branch":n.value,role:`treeitem`,"data-ownedby":F(r),"data-value":n.value,"aria-level":n.depth,"aria-selected":n.disabled?void 0:n.selected,"data-path":e.indexPath.join(`/`),"data-selected":h(n.selected),"aria-expanded":n.expanded,"data-state":n.expanded?`open`:`closed`,"aria-disabled":T(n.disabled),"data-disabled":h(n.disabled),"data-loading":h(n.loading),"aria-busy":T(n.loading),style:{"--depth":n.depth}})},getBranchIndicatorProps(e){let n=k(e);return t.element({...A.branchIndicator.attrs,"aria-hidden":!0,"data-state":n.expanded?`open`:`closed`,"data-disabled":h(n.disabled),"data-selected":h(n.selected),"data-focus":h(n.focused),"data-loading":h(n.loading)})},getBranchTriggerProps(e){let n=k(e);return t.element({...A.branchTrigger.attrs,role:`button`,dir:a(`dir`),"data-disabled":h(n.disabled),"data-state":n.expanded?`open`:`closed`,"data-value":n.value,"data-loading":h(n.loading),disabled:n.loading,onClick(e){n.disabled||n.loading||(o({type:`BRANCH_TOGGLE.CLICK`,id:n.value}),e.stopPropagation())}})},getBranchControlProps(e){let n=k(e);return t.element({...A.branchControl.attrs,role:`button`,id:n.id,dir:a(`dir`),tabIndex:n.focused?0:-1,"data-path":e.indexPath.join(`/`),"data-state":n.expanded?`open`:`closed`,"data-disabled":h(n.disabled),"data-selected":h(n.selected),"data-focus":h(n.focused),"data-renaming":h(n.renaming),"data-value":n.value,"data-depth":n.depth,"data-loading":h(n.loading),"aria-busy":T(n.loading),onFocus(e){o({type:`NODE.FOCUS`,id:n.value}),e.stopPropagation()},onClick(e){if(n.disabled||n.loading||!y(e)||_(e.currentTarget)&&v(e))return;let t=e.metaKey||e.ctrlKey;o({type:`BRANCH_NODE.CLICK`,id:n.value,shiftKey:e.shiftKey,ctrlKey:t}),e.stopPropagation()}})},getBranchTextProps(e){let n=k(e);return t.element({...A.branchText.attrs,dir:a(`dir`),"data-disabled":h(n.disabled),"data-state":n.expanded?`open`:`closed`,"data-loading":h(n.loading)})},getBranchContentProps(e){let n=k(e);return t.element({...A.branchContent.attrs,role:`group`,dir:a(`dir`),"data-state":n.expanded?`open`:`closed`,"data-depth":n.depth,"data-path":e.indexPath.join(`/`),"data-value":n.value,hidden:!n.expanded})},getBranchIndentGuideProps(e){let n=k(e);return t.element({...A.branchIndentGuide.attrs,"data-depth":n.depth})},getNodeCheckboxProps(e){let n=k(e),r=n.checked;return t.element({...A.nodeCheckbox.attrs,tabIndex:-1,role:`checkbox`,"data-state":r===!0?`checked`:r===!1?`unchecked`:`indeterminate`,"aria-checked":r===!0?`true`:r===!1?`false`:`mixed`,"data-disabled":h(n.disabled),onClick(e){e.defaultPrevented||n.disabled||y(e)&&(o({type:`CHECKED.TOGGLE`,value:n.value,isBranch:n.isBranch}),e.stopPropagation(),e.currentTarget.closest(`[role=treeitem]`)?.focus({preventScroll:!0}))}})},getNodeRenameInputProps(e){let n=k(e);return t.input({...A.nodeRenameInput.attrs,id:L(r,n.value),type:`text`,"aria-label":`Rename tree item`,hidden:!n.renaming,onKeyDown(e){C(e)||(e.key===`Escape`&&(o({type:`RENAME.CANCEL`}),e.preventDefault()),e.key===`Enter`&&(o({type:`RENAME.SUBMIT`,label:e.currentTarget.value}),e.preventDefault()),e.stopPropagation())},onBlur(e){o({type:`RENAME.SUBMIT`,label:e.currentTarget.value})}})}}}function U(e,n){let{context:r,prop:a,refs:o}=e;if(!a(`loadChildren`)){r.set(`expandedValue`,e=>p(s(e,...n)));return}let c=r.get(`loadingStatus`),[l,u]=i(n,e=>c[e]===`loaded`);if(l.length>0&&r.set(`expandedValue`,e=>p(s(e,...l))),u.length===0)return;let d=a(`collection`),[f,m]=i(u,e=>{let t=d.findNode(e);return d.getNodeChildren(t).length>0});if(f.length>0&&r.set(`expandedValue`,e=>p(s(e,...f))),m.length===0)return;r.set(`loadingStatus`,e=>({...e,...m.reduce((e,t)=>({...e,[t]:`loading`}),{})}));let h=m.map(e=>{let t=d.getIndexPath(e);return{id:e,indexPath:t,valuePath:d.getValuePath(t),node:d.findNode(e)}}),g=o.get(`pendingAborts`),_=a(`loadChildren`);t(_,()=>"[zag-js/tree-view] `loadChildren` is required for async expansion");let v=h.map(({id:e,indexPath:t,valuePath:n,node:r})=>{let i=g.get(e);i&&(i.abort(),g.delete(e));let a=new AbortController;return g.set(e,a),_({valuePath:n,indexPath:t,node:r,signal:a.signal})});Promise.allSettled(v).then(e=>{let t=[],n=[],i=r.get(`loadingStatus`),o=a(`collection`);e.forEach((e,r)=>{let{id:a,indexPath:s,node:c,valuePath:l}=h[r];e.status===`fulfilled`?(i[a]=`loaded`,t.push(a),o=o.replace(s,{...c,children:e.value})):(g.delete(a),Reflect.deleteProperty(i,a),n.push({node:c,error:e.reason,indexPath:s,valuePath:l}))}),r.set(`loadingStatus`,i),t.length&&(r.set(`expandedValue`,e=>p(s(e,...t))),a(`onLoadChildrenComplete`)?.({collection:o})),n.length&&a(`onLoadChildrenError`)?.({nodes:n})})}function W(e){let{prop:t,context:n}=e;return function({indexPath:e}){return t(`collection`).getValuePath(e).slice(0,-1).some(e=>!n.get(`expandedValue`).includes(e))}}var{and:G}=w(),K=b({props({props:e}){return{selectionMode:`single`,collection:j.empty(),typeahead:!0,expandOnClick:!0,defaultExpandedValue:[],defaultSelectedValue:[],...e}},initialState(){return`idle`},context({prop:e,bindable:t,getContext:n}){return{expandedValue:t(()=>({defaultValue:e(`defaultExpandedValue`),value:e(`expandedValue`),isEqual:r,onChange(t){let r=n().get(`focusedValue`);e(`onExpandedChange`)?.({expandedValue:t,focusedValue:r,get expandedNodes(){return e(`collection`).findNodes(t)}})}})),selectedValue:t(()=>({defaultValue:e(`defaultSelectedValue`),value:e(`selectedValue`),isEqual:r,onChange(t){let r=n().get(`focusedValue`);e(`onSelectionChange`)?.({selectedValue:t,focusedValue:r,get selectedNodes(){return e(`collection`).findNodes(t)}})}})),focusedValue:t(()=>({defaultValue:e(`defaultFocusedValue`)||null,value:e(`focusedValue`),onChange(t){e(`onFocusChange`)?.({focusedValue:t,get focusedNode(){return t?e(`collection`).findNode(t):null}})}})),loadingStatus:t(()=>({defaultValue:{}})),checkedValue:t(()=>({defaultValue:e(`defaultCheckedValue`)||[],value:e(`checkedValue`),isEqual:r,onChange(t){e(`onCheckedChange`)?.({checkedValue:t})}})),renamingValue:t(()=>({sync:!0,defaultValue:null}))}},refs(){return{typeaheadState:{...x.defaultOptions},pendingAborts:new Map}},computed:{isMultipleSelection:({prop:e})=>e(`selectionMode`)===`multiple`,isTypingAhead:({refs:e})=>e.get(`typeaheadState`).keysSoFar.length>0,visibleNodes:({prop:e,context:t})=>{let n=[];return e(`collection`).visit({skip:W({prop:e,context:t}),onEnter:(e,t)=>{n.push({node:e,indexPath:t})}}),n}},on:{"EXPANDED.SET":{actions:[`setExpanded`]},"EXPANDED.CLEAR":{actions:[`clearExpanded`]},"EXPANDED.ALL":{actions:[`expandAllBranches`]},"BRANCH.EXPAND":{actions:[`expandBranches`]},"BRANCH.COLLAPSE":{actions:[`collapseBranches`]},"SELECTED.SET":{actions:[`setSelected`]},"SELECTED.ALL":[{guard:G(`isMultipleSelection`,`moveFocus`),actions:[`selectAllNodes`,`focusTreeLastNode`]},{guard:`isMultipleSelection`,actions:[`selectAllNodes`]}],"SELECTED.CLEAR":{actions:[`clearSelected`]},"NODE.SELECT":{actions:[`selectNode`]},"NODE.DESELECT":{actions:[`deselectNode`]},"CHECKED.TOGGLE":{actions:[`toggleChecked`]},"CHECKED.SET":{actions:[`setChecked`]},"CHECKED.CLEAR":{actions:[`clearChecked`]},"NODE.FOCUS":{actions:[`setFocusedNode`]},"NODE.ARROW_DOWN":[{guard:G(`isShiftKey`,`isMultipleSelection`),actions:[`focusTreeNextNode`,`extendSelectionToNextNode`]},{actions:[`focusTreeNextNode`]}],"NODE.ARROW_UP":[{guard:G(`isShiftKey`,`isMultipleSelection`),actions:[`focusTreePrevNode`,`extendSelectionToPrevNode`]},{actions:[`focusTreePrevNode`]}],"NODE.ARROW_LEFT":{actions:[`focusBranchNode`]},"BRANCH_NODE.ARROW_LEFT":[{guard:`isBranchExpanded`,actions:[`collapseBranch`]},{actions:[`focusBranchNode`]}],"BRANCH_NODE.ARROW_RIGHT":[{guard:G(`isBranchFocused`,`isBranchExpanded`),actions:[`focusBranchFirstNode`]},{actions:[`expandBranch`]}],"SIBLINGS.EXPAND":{actions:[`expandSiblingBranches`]},"NODE.HOME":[{guard:G(`isShiftKey`,`isMultipleSelection`),actions:[`extendSelectionToFirstNode`,`focusTreeFirstNode`]},{actions:[`focusTreeFirstNode`]}],"NODE.END":[{guard:G(`isShiftKey`,`isMultipleSelection`),actions:[`extendSelectionToLastNode`,`focusTreeLastNode`]},{actions:[`focusTreeLastNode`]}],"NODE.CLICK":[{guard:G(`isCtrlKey`,`isMultipleSelection`),actions:[`toggleNodeSelection`]},{guard:G(`isShiftKey`,`isMultipleSelection`),actions:[`extendSelectionToNode`]},{actions:[`selectNode`]}],"BRANCH_NODE.CLICK":[{guard:G(`isCtrlKey`,`isMultipleSelection`),actions:[`toggleNodeSelection`]},{guard:G(`isShiftKey`,`isMultipleSelection`),actions:[`extendSelectionToNode`]},{guard:`expandOnClick`,actions:[`selectNode`,`toggleBranchNode`]},{actions:[`selectNode`]}],"BRANCH_TOGGLE.CLICK":{actions:[`toggleBranchNode`]},"TREE.TYPEAHEAD":{actions:[`focusMatchedNode`]}},exit:[`clearPendingAborts`],states:{idle:{on:{"NODE.RENAME":{target:`renaming`,actions:[`setRenamingValue`]}}},renaming:{entry:[`syncRenameInput`,`focusRenameInput`],on:{"RENAME.SUBMIT":{guard:`isRenameLabelValid`,target:`idle`,actions:[`submitRenaming`]},"RENAME.CANCEL":{target:`idle`,actions:[`cancelRenaming`]}}}},implementations:{guards:{isBranchFocused:({context:e,event:t})=>e.get(`focusedValue`)===t.id,isBranchExpanded:({context:e,event:t})=>e.get(`expandedValue`).includes(t.id),isShiftKey:({event:e})=>e.shiftKey,isCtrlKey:({event:e})=>e.ctrlKey,hasSelectedItems:({context:e})=>e.get(`selectedValue`).length>0,isMultipleSelection:({prop:e})=>e(`selectionMode`)===`multiple`,moveFocus:({event:e})=>!!e.moveFocus,expandOnClick:({prop:e})=>!!e(`expandOnClick`),isRenameLabelValid:({event:e})=>e.label.trim()!==``},actions:{selectNode({context:e,event:t}){let r=t.id||t.value;e.set(`selectedValue`,e=>r==null?e:!t.isTrusted&&n(r)?e.concat(...r):[n(r)?a(r):r].filter(Boolean))},deselectNode({context:t,event:n}){let r=f(n.id||n.value);t.set(`selectedValue`,t=>e(t,...r))},setFocusedNode({context:e,event:t}){e.set(`focusedValue`,t.id)},clearFocusedNode({context:e}){e.set(`focusedValue`,null)},clearSelectedItem({context:e}){e.set(`selectedValue`,[])},toggleBranchNode({context:e,event:t,action:n}){n(e.get(`expandedValue`).includes(t.id)?[`collapseBranch`]:[`expandBranch`])},expandBranch(e){let{event:t}=e;U(e,[t.id])},expandBranches(e){let{context:t,event:n}=e;U(e,u(f(n.value),t.get(`expandedValue`)))},collapseBranch({context:t,event:n}){t.set(`expandedValue`,t=>e(t,n.id))},collapseBranches(t){let{context:n,event:r}=t,i=f(r.value);n.set(`expandedValue`,t=>e(t,...i))},setExpanded({context:e,event:t}){n(t.value)&&e.set(`expandedValue`,t.value)},clearExpanded({context:e}){e.set(`expandedValue`,[])},setSelected({context:e,event:t}){n(t.value)&&e.set(`selectedValue`,t.value)},clearSelected({context:e}){e.set(`selectedValue`,[])},focusTreeFirstNode(e){let{prop:t,scope:n}=e,r=t(`collection`),i=r.getFirstNode(void 0,{skip:W(e)});if(!i)return;let a=r.getNodeValue(i);q(e,a)?m(()=>I(n,a)):I(n,a)},focusTreeLastNode(e){let{prop:t,scope:n}=e,r=t(`collection`),i=r.getLastNode(void 0,{skip:W(e)}),a=r.getNodeValue(i);q(e,a)?m(()=>I(n,a)):I(n,a)},focusBranchFirstNode(e){let{event:t,prop:n,scope:r}=e,i=n(`collection`),a=i.findNode(t.id),o=i.getFirstNode(a,{skip:W(e)});if(!o)return;let s=i.getNodeValue(o);q(e,s)?m(()=>I(r,s)):I(r,s)},focusTreeNextNode(e){let{event:t,prop:n,scope:r}=e,i=n(`collection`),a=i.getNextNode(t.id,{skip:W(e)});if(!a)return;let o=i.getNodeValue(a);q(e,o)?m(()=>I(r,o)):I(r,o)},focusTreePrevNode(e){let{event:t,prop:n,scope:r}=e,i=n(`collection`),a=i.getPreviousNode(t.id,{skip:W(e)});if(!a)return;let o=i.getNodeValue(a);q(e,o)?m(()=>I(r,o)):I(r,o)},focusBranchNode(e){let{event:t,prop:n,scope:r}=e,i=n(`collection`),a=i.getParentNode(t.id),o=a?i.getNodeValue(a):void 0;o&&(q(e,o)?m(()=>I(r,o)):I(r,o))},selectAllNodes({context:e,prop:t}){e.set(`selectedValue`,t(`collection`).getValues())},focusMatchedNode(e){let{context:t,prop:n,refs:r,event:i,scope:a,computed:o}=e,s=x(o(`visibleNodes`).map(({node:e})=>({textContent:n(`collection`).stringifyNode(e),id:n(`collection`).getNodeValue(e)})),{state:r.get(`typeaheadState`),activeId:t.get(`focusedValue`),key:i.key});s?.id&&(q(e,s.id)?m(()=>I(a,s.id)):I(a,s.id))},toggleNodeSelection({context:e,event:t}){let n=l(e.get(`selectedValue`),t.id);e.set(`selectedValue`,n)},expandAllBranches(e){let{context:t,prop:n}=e;U(e,u(n(`collection`).getBranchValues(),t.get(`expandedValue`)))},expandSiblingBranches(e){let{context:t,event:n,prop:r}=e,i=r(`collection`),a=i.getIndexPath(n.id);a&&U(e,u(i.getSiblingNodes(a).map(e=>i.getNodeValue(e)),t.get(`expandedValue`)))},extendSelectionToNode(e){let{context:t,event:n,prop:r,computed:i}=e,a=r(`collection`),s=o(t.get(`selectedValue`))||a.getNodeValue(a.getFirstNode()),c=n.id,l=[s,c],u=0;i(`visibleNodes`).forEach(({node:e})=>{let t=a.getNodeValue(e);u===1&&l.push(t),(t===s||t===c)&&u++}),t.set(`selectedValue`,p(l))},extendSelectionToNextNode(e){let{context:t,event:n,prop:r}=e,i=r(`collection`),a=i.getNextNode(n.id,{skip:W(e)});if(!a)return;let o=new Set(t.get(`selectedValue`)),s=i.getNodeValue(a);s!=null&&(o.has(n.id)&&o.has(s)?o.delete(n.id):o.has(s)||o.add(s),t.set(`selectedValue`,Array.from(o)))},extendSelectionToPrevNode(e){let{context:t,event:n,prop:r}=e,i=r(`collection`),a=i.getPreviousNode(n.id,{skip:W(e)});if(!a)return;let o=new Set(t.get(`selectedValue`)),s=i.getNodeValue(a);s!=null&&(o.has(n.id)&&o.has(s)?o.delete(n.id):o.has(s)||o.add(s),t.set(`selectedValue`,Array.from(o)))},extendSelectionToFirstNode(e){let{context:t,prop:n}=e,r=n(`collection`),i=o(t.get(`selectedValue`)),a=[];r.visit({skip:W(e),onEnter:e=>{let t=r.getNodeValue(e);if(a.push(t),t===i)return`stop`}}),t.set(`selectedValue`,a)},extendSelectionToLastNode(e){let{context:t,prop:n}=e,r=n(`collection`),i=o(t.get(`selectedValue`)),a=[],s=!1;r.visit({skip:W(e),onEnter:e=>{let t=r.getNodeValue(e);t===i&&(s=!0),s&&a.push(t)}}),t.set(`selectedValue`,a)},clearPendingAborts({refs:e}){let t=e.get(`pendingAborts`);t.forEach(e=>e.abort()),t.clear()},toggleChecked({context:e,event:t,prop:n}){let r=n(`collection`);e.set(`checkedValue`,e=>t.isBranch?B(r,t.value,e):l(e,t.value))},setChecked({context:e,event:t}){e.set(`checkedValue`,t.value)},clearChecked({context:e}){e.set(`checkedValue`,[])},setRenamingValue({context:e,event:t,prop:n}){e.set(`renamingValue`,t.value);let r=n(`onRenameStart`);if(r){let e=n(`collection`),i=e.getIndexPath(t.value);if(i){let n=e.at(i);n&&r({value:t.value,node:n,indexPath:i})}}},submitRenaming({context:e,event:t,prop:n,scope:r}){let i=e.get(`renamingValue`);if(!i)return;let a=n(`collection`).getIndexPath(i);if(!a)return;let o=t.label.trim(),s=n(`onBeforeRename`);if(s&&!s({value:i,label:o,indexPath:a})){e.set(`renamingValue`,null),I(r,i);return}n(`onRenameComplete`)?.({value:i,label:o,indexPath:a}),e.set(`renamingValue`,null),I(r,i)},cancelRenaming({context:e,scope:t}){let n=e.get(`renamingValue`);e.set(`renamingValue`,null),n&&I(t,n)},syncRenameInput({context:e,scope:t,prop:n}){let r=e.get(`renamingValue`);if(!r)return;let i=n(`collection`),a=i.findNode(r);if(!a)return;let o=i.stringifyNode(a);D(R(t,r),o)},focusRenameInput({context:e,scope:t}){let n=e.get(`renamingValue`);if(!n)return;let r=R(t,n);r&&(r.focus(),r.select())}}}});function q(e,t){let{prop:n,scope:r,computed:i}=e,a=n(`scrollToIndexFn`);if(!a)return!1;let o=n(`collection`),s=i(`visibleNodes`);for(let e=0;e<s.length;e++){let{node:n,indexPath:i}=s[e];if(o.getNodeValue(n)===t)return a({index:e,node:n,indexPath:i,getElement:()=>r.getById(P(r,t))}),!0}return!1}c(O()(`ids.collection.dir.expandedValue.expandOnClick.defaultFocusedValue.focusedValue.getRootNode.id.onExpandedChange.onFocusChange.onSelectionChange.checkedValue.selectedValue.selectionMode.typeahead.defaultExpandedValue.defaultSelectedValue.defaultCheckedValue.onCheckedChange.onLoadChildrenComplete.onLoadChildrenError.loadChildren.canRename.onRenameStart.onBeforeRename.onRenameComplete.scrollToIndexFn`.split(`.`))),c(O()([`node`,`indexPath`]));export{H as n,K as r,j as t};