@vtj/pro 0.13.34 → 0.13.35

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 (71) hide show
  1. package/dist/@vtj/materials/assets/antdv/index.umd.js +2 -2
  2. package/dist/@vtj/materials/assets/charts/index.umd.js +2 -2
  3. package/dist/@vtj/materials/assets/element/index.umd.js +2 -2
  4. package/dist/@vtj/materials/assets/icons/index.umd.js +2 -2
  5. package/dist/@vtj/materials/assets/ui/index.umd.js +2 -2
  6. package/dist/@vtj/materials/assets/uni-h5/index.umd.js +2 -2
  7. package/dist/@vtj/materials/assets/uni-ui/index.umd.js +2 -2
  8. package/dist/@vtj/materials/assets/vant/index.umd.js +2 -2
  9. package/dist/@vtj/materials/deps/@vtj/charts/index.umd.js +2 -2
  10. package/dist/@vtj/materials/deps/@vtj/icons/index.umd.js +2 -2
  11. package/dist/@vtj/materials/deps/@vtj/ui/index.umd.js +2 -2
  12. package/dist/@vtj/materials/deps/@vtj/utils/index.umd.js +16 -16
  13. package/dist/@vtj/materials/deps/@vueuse/core/index.iife.min.js +1 -1
  14. package/dist/@vtj/materials/deps/element-plus/index.css +1 -1
  15. package/dist/@vtj/materials/deps/element-plus/index.full.min.js +17 -24
  16. package/dist/@vtj/materials/deps/element-plus/zh-cn.js +1 -1
  17. package/dist/@vtj/materials/deps/vue/vue.global.js +2470 -2428
  18. package/dist/@vtj/materials/deps/vue/vue.global.prod.js +9 -9
  19. package/dist/@vtj/materials/deps/vue-i18n/vue-i18n.global.js +73 -50
  20. package/dist/@vtj/materials/deps/vue-i18n/vue-i18n.global.prod.js +2 -2
  21. package/dist/@vtj/materials/deps/vue-router/vue-router.global.js +3005 -3926
  22. package/dist/@vtj/materials/deps/vue-router/vue-router.global.prod.js +5 -5
  23. package/dist/__devtools__/assets/{IconTitle.vue_vue_type_script_setup_true_lang-Enp_Ksfn.js → IconTitle.vue_vue_type_script_setup_true_lang-CZMqpyXE.js} +1 -1
  24. package/dist/__devtools__/assets/{SectionBlock-BTPkVZM2.js → SectionBlock-BSuGDm7s.js} +1 -1
  25. package/dist/__devtools__/assets/{assets-D3XLNB-6.js → assets-BoMHV8O-.js} +1 -1
  26. package/dist/__devtools__/assets/{components-Dza6_XRl.js → components-7VuIBWJA.js} +1 -1
  27. package/dist/__devtools__/assets/{custom-inspector-tab-view-_L81oF56.js → custom-inspector-tab-view-B5LB_kcZ.js} +1 -1
  28. package/dist/__devtools__/assets/{custom-tab-view-CmLn18C4.js → custom-tab-view-BZBfeauf.js} +1 -1
  29. package/dist/__devtools__/assets/{graph-fTuEulvH.js → graph-CyWkycf4.js} +2 -2
  30. package/dist/__devtools__/assets/index-C5qqC9jB.css +1 -0
  31. package/dist/__devtools__/assets/{index-DH8HZ7DP.js → index-C8hFs1GM.js} +3 -3
  32. package/dist/__devtools__/assets/{overview-DFLns6CN.js → overview-UGcO1fsl.js} +1 -1
  33. package/dist/__devtools__/assets/{pages-yIVwEfZL.js → pages-CDARBtn3.js} +1 -1
  34. package/dist/__devtools__/assets/{pinia-Cq2YPuZV.js → pinia-0IbFM1TZ.js} +1 -1
  35. package/dist/__devtools__/assets/{router-Drkf543k.js → router-BkwlZeKx.js} +1 -1
  36. package/dist/__devtools__/assets/{settings-DyJW_A0F.js → settings-CljpRPty.js} +1 -1
  37. package/dist/__devtools__/assets/{timeline-R3j-Lp7H.js → timeline-l7ZovCcC.js} +1 -1
  38. package/dist/__devtools__/index.html +2 -2
  39. package/dist/assets/{@element-plus-icons-vue-CKd904ON.js → @element-plus-icons-vue-BKci8WR4.js} +1 -1
  40. package/dist/assets/@vueuse-CFu7Lllw.js +1 -0
  41. package/dist/assets/{Editor-DoqFIqOf-DiNYaRxo.js → Editor-s4O3HVWM-DYKyA19e.js} +123 -123
  42. package/dist/assets/{auth-BV8TXi4D.js → auth-BXO_wENu.js} +1 -1
  43. package/dist/assets/element-plus-CXrize55.css +1 -0
  44. package/dist/assets/element-plus-D5HcOZ0Y.js +12 -0
  45. package/dist/assets/{index-B8SwXmce.js → index-BdGdRoBR.js} +2 -2
  46. package/dist/assets/index-D4kOm-tE.js +1 -0
  47. package/dist/assets/{mockjs-D0SPmEx8.js → mockjs-D1skojwT.js} +1 -1
  48. package/dist/assets/{page-oejxnkbe.js → page-BO8FzBlK.js} +2 -2
  49. package/dist/assets/{preview-DoFDYFiX.js → preview-C0XjFOP5.js} +2 -2
  50. package/dist/assets/{uni-page-CN_KQGX3.js → uni-page-BA3KNMq4.js} +1 -1
  51. package/dist/assets/utils-Cg-oX5qd.js +1 -0
  52. package/dist/assets/vue-CAMRmZ-8.js +35 -0
  53. package/dist/assets/vue-router-CwSAuTE4.js +9 -0
  54. package/dist/assets/{vxe-yh3jV1_V.js → vxe-Cx_7PEYn.js} +1 -1
  55. package/dist/index.html +9 -9
  56. package/dist/uni/assets/{@dcloudio-uni-h5-vue-BtM9Eyib.js → @dcloudio-uni-h5-vue-8GkSpuEV.js} +1 -1
  57. package/dist/uni/assets/index-CRYWUl-q.js +74 -0
  58. package/dist/uni/assets/vue-router-eQVOEjEf.js +9 -0
  59. package/dist/uni/index.html +3 -3
  60. package/package.json +13 -13
  61. package/dist/__devtools__/assets/index-DVOrYgP_.css +0 -1
  62. package/dist/assets/@vueuse-DtTb23_4.js +0 -1
  63. package/dist/assets/element-plus-CDp6lqni.js +0 -19
  64. package/dist/assets/element-plus-CIHaA-Vw.css +0 -1
  65. package/dist/assets/index-DD1XM0NE.js +0 -1
  66. package/dist/assets/utils-itkxsukj.js +0 -1
  67. package/dist/assets/vue-Bzk1dLH9.js +0 -35
  68. package/dist/assets/vue-router-Bj6KLPos.js +0 -5
  69. package/dist/uni/assets/index-Ct-q2iWi.js +0 -74
  70. package/dist/uni/assets/vue-router-CbZ0Q__O.js +0 -5
  71. /package/dist/assets/{Editor-DoqFIqOf-CIjQSqmy.css → Editor-s4O3HVWM-CIjQSqmy.css} +0 -0
@@ -1,4 +1,4 @@
1
- import{q as Bn,ap as RX,i as PX,aq as xX,ah as Pte,p as oO,aj as $A,ac as xte,ar as $te,d as oI,as as Dte,e as Nte,o as Xt,w as $R,b as et,c as ar,z as wA,a as BO,t as $n,u as Pe,n as Wo,F as DA,v as NA,s as es,M as Mte,B as $X,at as qte,Y as Fte,aa as kte,f as Bte,au as zte,av as jte,a8 as Lte,D as Gte,aw as Wte,N as Vte,a1 as Zte,ax as IA}from"./index-DH8HZ7DP.js";/**
1
+ import{q as Bn,ap as RX,i as PX,aq as xX,ah as Pte,p as oO,aj as $A,ac as xte,ar as $te,d as oI,as as Dte,e as Nte,o as Xt,w as $R,b as et,c as ar,z as wA,a as BO,t as $n,u as Pe,n as Wo,F as DA,v as NA,s as es,M as Mte,B as $X,at as qte,Y as Fte,aa as kte,f as Bte,au as zte,av as jte,a8 as Lte,D as Gte,aw as Wte,N as Vte,a1 as Zte,ax as IA}from"./index-C8hFs1GM.js";/**
2
2
  * vis-network
3
3
  * https://visjs.github.io/vis-network/
4
4
  *
@@ -934,7 +934,7 @@ input.vis-configuration.vis-config-range:focus::-ms-fill-upper {
934
934
  `,vt()):re+=Ie,vt();if(Ie!='"')throw Bt('End of string " expected');vt(),Kt=kt.IDENTIFIER;return}for(Kt=kt.UNKNOWN;Ie!="";)re+=Ie,vt();throw new SyntaxError('Syntax error in part "'+XQ(re,30)+'"')}function Mse(){var n={};if($se(),Fe(),re==="strict"&&(n.strict=!0,Fe()),(re==="graph"||re==="digraph")&&(n.type=re,Fe()),Kt===kt.IDENTIFIER&&(n.id=re,Fe()),re!="{")throw Bt("Angle bracket { expected");if(Fe(),UQ(n),re!="}")throw Bt("Angle bracket } expected");if(Fe(),re!=="")throw Bt("End of file expected");return Fe(),delete n.node,delete n.edge,delete n.graph,n}function UQ(n){for(;re!==""&&re!="}";)qse(n),re===";"&&Fe()}function qse(n){var e=KQ(n);if(e){YQ(n,e);return}var t=Fse(n);if(!t){if(Kt!=kt.IDENTIFIER)throw Bt("Identifier expected");var r=re;if(Fe(),re==="="){if(Fe(),Kt!=kt.IDENTIFIER)throw Bt("Identifier expected");n[r]=re,Fe()}else kse(n,r)}}function KQ(n){var e=null;if(re==="subgraph"&&(e={},e.type="subgraph",Fe(),Kt===kt.IDENTIFIER&&(e.id=re,Fe())),re==="{"){if(Fe(),e||(e={}),e.parent=n,e.node=n.node,e.edge=n.edge,e.graph=n.graph,UQ(e),re!="}")throw Bt("Angle bracket } expected");Fe(),delete e.node,delete e.edge,delete e.graph,delete e.parent,n.subgraphs||(n.subgraphs=[]),n.subgraphs.push(e)}return e}function Fse(n){return re==="node"?(Fe(),n.node=Da(),"node"):re==="edge"?(Fe(),n.edge=Da(),"edge"):re==="graph"?(Fe(),n.graph=Da(),"graph"):null}function kse(n,e){var t={id:e},r=Da();r&&(t.attr=r),ZQ(n,t),YQ(n,e)}function YQ(n,e){for(;re==="->"||re==="--";){var t,r=re;Fe();var i=KQ(n);if(i)t=i;else{if(Kt!=kt.IDENTIFIER)throw Bt("Identifier or subgraph expected");t=re,ZQ(n,{id:t}),Fe()}var o=Da(),s=HQ(n,e,t,r,o);Nse(n,s),e=t}}function Da(){for(var n,e=null,t={dashed:!0,solid:!1,dotted:[1,5]},r={dot:"circle",box:"box",crow:"crow",curve:"curve",icurve:"inv_curve",normal:"triangle",inv:"inv_triangle",diamond:"diamond",tee:"bar",vee:"vee"},i=new Array,o=new Array;re==="[";){for(Fe(),e={};re!==""&&re!="]";){if(Kt!=kt.IDENTIFIER)throw Bt("Attribute name expected");var s=re;if(Fe(),re!="=")throw Bt("Equal sign = expected");if(Fe(),Kt!=kt.IDENTIFIER)throw Bt("Attribute value expected");var a=re;s==="style"&&(a=t[a]);var g;s==="arrowhead"&&(g=r[a],s="arrows",a={to:{enabled:!0,type:g}}),s==="arrowtail"&&(g=r[a],s="arrows",a={from:{enabled:!0,type:g}}),i.push({attr:e,name:s,value:a}),o.push(s),Fe(),re==","&&Fe()}if(re!="]")throw Bt("Bracket ] expected");Fe()}if(rn(o).call(o,"dir")){var A={};for(A.arrows={},n=0;n<i.length;n++)if(i[n].name==="arrows")if(i[n].value.to!=null)A.arrows.to=n;else if(i[n].value.from!=null)A.arrows.from=n;else throw Bt("Invalid value of arrows");else i[n].name==="dir"&&(A.dir=n);var I=i[A.dir].value;if(!rn(o).call(o,"arrows"))if(I==="both")i.push({attr:i[A.dir].attr,name:"arrows",value:{to:{enabled:!0}}}),A.arrows.to=i.length-1,i.push({attr:i[A.dir].attr,name:"arrows",value:{from:{enabled:!0}}}),A.arrows.from=i.length-1;else if(I==="forward")i.push({attr:i[A.dir].attr,name:"arrows",value:{to:{enabled:!0}}}),A.arrows.to=i.length-1;else if(I==="back")i.push({attr:i[A.dir].attr,name:"arrows",value:{from:{enabled:!0}}}),A.arrows.from=i.length-1;else if(I==="none")i.push({attr:i[A.dir].attr,name:"arrows",value:""}),A.arrows.to=i.length-1;else throw Bt('Invalid dir type "'+I+'"');var C,l;if(I==="both")A.arrows.to&&A.arrows.from?(l=i[A.arrows.to].value.to.type,C=i[A.arrows.from].value.from.type,i[A.arrows.to]={attr:i[A.arrows.to].attr,name:i[A.arrows.to].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}},ti(i).call(i,A.arrows.from,1)):A.arrows.to?(l=i[A.arrows.to].value.to.type,C="arrow",i[A.arrows.to]={attr:i[A.arrows.to].attr,name:i[A.arrows.to].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}}):A.arrows.from&&(l="arrow",C=i[A.arrows.from].value.from.type,i[A.arrows.from]={attr:i[A.arrows.from].attr,name:i[A.arrows.from].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}});else if(I==="back")A.arrows.to&&A.arrows.from?(l="",C=i[A.arrows.from].value.from.type,i[A.arrows.from]={attr:i[A.arrows.from].attr,name:i[A.arrows.from].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}}):A.arrows.to?(l="",C="arrow",A.arrows.from=A.arrows.to,i[A.arrows.from]={attr:i[A.arrows.from].attr,name:i[A.arrows.from].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}}):A.arrows.from&&(l="",C=i[A.arrows.from].value.from.type,i[A.arrows.to]={attr:i[A.arrows.from].attr,name:i[A.arrows.from].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}}),i[A.arrows.from]={attr:i[A.arrows.from].attr,name:i[A.arrows.from].name,value:{from:{enabled:!0,type:i[A.arrows.from].value.from.type}}};else if(I==="none"){var d;A.arrows.to?d=A.arrows.to:d=A.arrows.from,i[d]={attr:i[d].attr,name:i[d].name,value:""}}else if(I==="forward")A.arrows.to&&A.arrows.from?(l=i[A.arrows.to].value.to.type,C="",i[A.arrows.to]={attr:i[A.arrows.to].attr,name:i[A.arrows.to].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}}):A.arrows.to?(l=i[A.arrows.to].value.to.type,C="",i[A.arrows.to]={attr:i[A.arrows.to].attr,name:i[A.arrows.to].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}}):A.arrows.from&&(l="arrow",C="",A.arrows.to=A.arrows.from,i[A.arrows.to]={attr:i[A.arrows.to].attr,name:i[A.arrows.to].name,value:{to:{enabled:!0,type:l},from:{enabled:!0,type:C}}}),i[A.arrows.to]={attr:i[A.arrows.to].attr,name:i[A.arrows.to].name,value:{to:{enabled:!0,type:i[A.arrows.to].value.to.type}}};else throw Bt('Invalid dir type "'+I+'"');ti(i).call(i,A.dir,1)}var u;if(rn(o).call(o,"penwidth")){var h=[];for(u=i.length,n=0;n<u;n++)i[n].name!=="width"&&(i[n].name==="penwidth"&&(i[n].name="width"),h.push(i[n]));i=h}for(u=i.length,n=0;n<u;n++)Dse(i[n].attr,i[n].name,i[n].value);return e}function Bt(n){return new SyntaxError(n+', got "'+XQ(re,30)+'" (char '+ds+")")}function XQ(n,e){return n.length<=e?n:n.substr(0,27)+"..."}function Bse(n,e,t){we(n)?be(n).call(n,function(r){we(e)?be(e).call(e,function(i){t(r,i)}):t(r,e)}):we(e)?be(e).call(e,function(r){t(n,r)}):t(n,e)}function Xu(n,e,t){for(var r=e.split("."),i=r.pop(),o=n,s=0;s<r.length;s++){var a=r[s];a in o||(o[a]={}),o=o[a]}return o[i]=t,n}function xN(n,e){var t={};for(var r in n)if(n.hasOwnProperty(r)){var i=e[r];we(i)?be(i).call(i,function(o){Xu(t,o,n[r])}):typeof i=="string"?Xu(t,i,n[r]):Xu(t,r,n[r])}return t}function zse(n){var e=xse(n),t={nodes:[],edges:[],options:{}};if(e.nodes){var r;be(r=e.nodes).call(r,function(s){var a={id:s.id,label:String(s.label||s.id)};dn(a,xN(s.attr,VQ)),a.image&&(a.shape="image"),t.nodes.push(a)})}if(e.edges){var i,o=function(s){var a={from:s.from,to:s.to};return dn(a,xN(s.attr,CT)),a.arrows==null&&s.type==="->"&&(a.arrows="to"),a};be(i=e.edges).call(i,function(s){var a,g;if(s.from instanceof Object?a=s.from.nodes:a={id:s.from},s.to instanceof Object?g=s.to.nodes:g={id:s.to},s.from instanceof Object&&s.from.edges){var A;be(A=s.from.edges).call(A,function(C){var l=o(C);t.edges.push(l)})}if(Bse(a,g,function(C,l){var d=HQ(t,C.id,l.id,s.type,s.attr),u=o(d);t.edges.push(u)}),s.to instanceof Object&&s.to.edges){var I;be(I=s.to.edges).call(I,function(C){var l=o(C);t.edges.push(l)})}})}return e.attr&&(t.options=e.attr),t}function jse(n,e){var t;const r={edges:{inheritColor:!1},nodes:{fixed:!1,parseColor:!1}};e!=null&&(e.fixed!=null&&(r.nodes.fixed=e.fixed),e.parseColor!=null&&(r.nodes.parseColor=e.parseColor),e.inheritColor!=null&&(r.edges.inheritColor=e.inheritColor));const i=n.edges,o=Mt(i).call(i,a=>{const g={from:a.source,id:a.id,to:a.target};return a.attributes!=null&&(g.attributes=a.attributes),a.label!=null&&(g.label=a.label),a.attributes!=null&&a.attributes.title!=null&&(g.title=a.attributes.title),a.type==="Directed"&&(g.arrows="to"),a.color&&r.edges.inheritColor===!1&&(g.color=a.color),g});return{nodes:Mt(t=n.nodes).call(t,a=>{const g={id:a.id,fixed:r.nodes.fixed&&a.x!=null&&a.y!=null};return a.attributes!=null&&(g.attributes=a.attributes),a.label!=null&&(g.label=a.label),a.size!=null&&(g.size=a.size),a.attributes!=null&&a.attributes.title!=null&&(g.title=a.attributes.title),a.title!=null&&(g.title=a.title),a.x!=null&&(g.x=a.x),a.y!=null&&(g.y=a.y),a.color!=null&&(r.nodes.parseColor===!0?g.color=a.color:g.color={background:a.color,border:a.color,highlight:{background:a.color,border:a.color},hover:{background:a.color,border:a.color}}),g}),edges:o}}const Lse={addDescription:"Click in an empty space to place a new node.",addEdge:"Add Edge",addNode:"Add Node",back:"Back",close:"Close",createEdgeError:"Cannot link edges to a cluster.",del:"Delete selected",deleteClusterError:"Clusters cannot be deleted.",edgeDescription:"Click on a node and drag the edge to another node to connect them.",edit:"Edit",editClusterError:"Clusters cannot be edited.",editEdge:"Edit Edge",editEdgeDescription:"Click on the control points and drag them to a node to connect to it.",editNode:"Edit Node"},Gse={addDescription:"Klicke auf eine freie Stelle, um einen neuen Knoten zu plazieren.",addEdge:"Kante hinzufügen",addNode:"Knoten hinzufügen",back:"Zurück",close:"Schließen",createEdgeError:"Es ist nicht möglich, Kanten mit Clustern zu verbinden.",del:"Lösche Auswahl",deleteClusterError:"Cluster können nicht gelöscht werden.",edgeDescription:"Klicke auf einen Knoten und ziehe die Kante zu einem anderen Knoten, um diese zu verbinden.",edit:"Editieren",editClusterError:"Cluster können nicht editiert werden.",editEdge:"Kante editieren",editEdgeDescription:"Klicke auf die Verbindungspunkte und ziehe diese auf einen Knoten, um sie zu verbinden.",editNode:"Knoten editieren"},Wse={addDescription:"Haga clic en un lugar vacío para colocar un nuevo nodo.",addEdge:"Añadir arista",addNode:"Añadir nodo",back:"Atrás",close:"Cerrar",createEdgeError:"No se puede conectar una arista a un grupo.",del:"Eliminar selección",deleteClusterError:"No es posible eliminar grupos.",edgeDescription:"Haga clic en un nodo y arrastre la arista hacia otro nodo para conectarlos.",edit:"Editar",editClusterError:"No es posible editar grupos.",editEdge:"Editar arista",editEdgeDescription:"Haga clic en un punto de control y arrastrelo a un nodo para conectarlo.",editNode:"Editar nodo"},Vse={addDescription:"Clicca per aggiungere un nuovo nodo",addEdge:"Aggiungi un vertice",addNode:"Aggiungi un nodo",back:"Indietro",close:"Chiudere",createEdgeError:"Non si possono collegare vertici ad un cluster",del:"Cancella la selezione",deleteClusterError:"I cluster non possono essere cancellati",edgeDescription:"Clicca su un nodo e trascinalo ad un altro nodo per connetterli.",edit:"Modifica",editClusterError:"I clusters non possono essere modificati.",editEdge:"Modifica il vertice",editEdgeDescription:"Clicca sui Punti di controllo e trascinali ad un nodo per connetterli.",editNode:"Modifica il nodo"},Zse={addDescription:"Klik op een leeg gebied om een nieuwe node te maken.",addEdge:"Link toevoegen",addNode:"Node toevoegen",back:"Terug",close:"Sluiten",createEdgeError:"Kan geen link maken naar een cluster.",del:"Selectie verwijderen",deleteClusterError:"Clusters kunnen niet worden verwijderd.",edgeDescription:"Klik op een node en sleep de link naar een andere node om ze te verbinden.",edit:"Wijzigen",editClusterError:"Clusters kunnen niet worden aangepast.",editEdge:"Link wijzigen",editEdgeDescription:"Klik op de verbindingspunten en sleep ze naar een node om daarmee te verbinden.",editNode:"Node wijzigen"},Hse={addDescription:"Clique em um espaço em branco para adicionar um novo nó",addEdge:"Adicionar aresta",addNode:"Adicionar nó",back:"Voltar",close:"Fechar",createEdgeError:"Não foi possível linkar arestas a um cluster.",del:"Remover selecionado",deleteClusterError:"Clusters não puderam ser removidos.",edgeDescription:"Clique em um nó e arraste a aresta até outro nó para conectá-los",edit:"Editar",editClusterError:"Clusters não puderam ser editados.",editEdge:"Editar aresta",editEdgeDescription:"Clique nos pontos de controle e os arraste para um nó para conectá-los",editNode:"Editar nó"},Use={addDescription:"Кликните в свободное место, чтобы добавить новый узел.",addEdge:"Добавить ребро",addNode:"Добавить узел",back:"Назад",close:"Закрывать",createEdgeError:"Невозможно соединить ребра в кластер.",del:"Удалить выбранное",deleteClusterError:"Кластеры не могут быть удалены",edgeDescription:"Кликните на узел и протяните ребро к другому узлу, чтобы соединить их.",edit:"Редактировать",editClusterError:"Кластеры недоступны для редактирования.",editEdge:"Редактировать ребро",editEdgeDescription:"Кликните на контрольные точки и перетащите их в узел, чтобы подключиться к нему.",editNode:"Редактировать узел"},Kse={addDescription:"单击空白处放置新节点。",addEdge:"添加连接线",addNode:"添加节点",back:"返回",close:"關閉",createEdgeError:"无法将连接线连接到群集。",del:"删除选定",deleteClusterError:"无法删除群集。",edgeDescription:"单击某个节点并将该连接线拖动到另一个节点以连接它们。",edit:"编辑",editClusterError:"无法编辑群集。",editEdge:"编辑连接线",editEdgeDescription:"单击控制节点并将它们拖到节点上连接。",editNode:"编辑节点"},Yse={addDescription:"Kлікніть на вільне місце, щоб додати новий вузол.",addEdge:"Додати край",addNode:"Додати вузол",back:"Назад",close:"Закрити",createEdgeError:"Не можливо об'єднати краї в групу.",del:"Видалити обране",deleteClusterError:"Групи не можуть бути видалені.",edgeDescription:"Клікніть на вузол і перетягніть край до іншого вузла, щоб їх з'єднати.",edit:"Редагувати",editClusterError:"Групи недоступні для редагування.",editEdge:"Редагувати край",editEdgeDescription:"Клікніть на контрольні точки і перетягніть їх у вузол, щоб підключитися до нього.",editNode:"Редагувати вузол"},Xse={addDescription:"Cliquez dans un endroit vide pour placer un nœud.",addEdge:"Ajouter un lien",addNode:"Ajouter un nœud",back:"Retour",close:"Fermer",createEdgeError:"Impossible de créer un lien vers un cluster.",del:"Effacer la sélection",deleteClusterError:"Les clusters ne peuvent pas être effacés.",edgeDescription:"Cliquez sur un nœud et glissez le lien vers un autre nœud pour les connecter.",edit:"Éditer",editClusterError:"Les clusters ne peuvent pas être édités.",editEdge:"Éditer le lien",editEdgeDescription:"Cliquez sur les points de contrôle et glissez-les pour connecter un nœud.",editNode:"Éditer le nœud"},Qse={addDescription:"Kluknutím do prázdného prostoru můžete přidat nový vrchol.",addEdge:"Přidat hranu",addNode:"Přidat vrchol",back:"Zpět",close:"Zavřít",createEdgeError:"Nelze připojit hranu ke shluku.",del:"Smazat výběr",deleteClusterError:"Nelze mazat shluky.",edgeDescription:"Přetažením z jednoho vrcholu do druhého můžete spojit tyto vrcholy novou hranou.",edit:"Upravit",editClusterError:"Nelze upravovat shluky.",editEdge:"Upravit hranu",editEdgeDescription:"Přetažením kontrolního vrcholu hrany ji můžete připojit k jinému vrcholu.",editNode:"Upravit vrchol"};var Jse=Object.freeze({__proto__:null,cn:Kse,cs:Qse,de:Gse,en:Lse,es:Wse,fr:Xse,it:Vse,nl:Zse,pt:Hse,ru:Use,uk:Yse});function eae(n,e){try{const[r,i]=e.split(/[-_ /]/,2),o=r!=null?r.toLowerCase():null,s=i!=null?i.toUpperCase():null;if(o&&s){const a=o+"-"+s;if(Object.prototype.hasOwnProperty.call(n,a))return a;var t;console.warn(aQ(t="Unknown variant ".concat(s," of language ")).call(t,o,"."))}if(o){const a=o;if(Object.prototype.hasOwnProperty.call(n,a))return a;console.warn("Unknown language ".concat(o))}return console.warn("Unknown locale ".concat(e,", falling back to English.")),"en"}catch(r){return console.error(r),console.warn("Unexpected error while normalizing locale ".concat(e,", falling back to English.")),"en"}}let tae=class{constructor(){this.NUM_ITERATIONS=4,this.image=new Image,this.canvas=document.createElement("canvas")}init(){if(this.initialized())return;this.src=this.image.src;const e=this.image.width,t=this.image.height;this.width=e,this.height=t;const r=Math.floor(t/2),i=Math.floor(t/4),o=Math.floor(t/8),s=Math.floor(t/16),a=Math.floor(e/2),g=Math.floor(e/4),A=Math.floor(e/8),I=Math.floor(e/16);this.canvas.width=3*g,this.canvas.height=r,this.coordinates=[[0,0,a,r],[a,0,g,i],[a,i,A,o],[5*A,i,I,s]],this._fillMipMap()}initialized(){return this.coordinates!==void 0}_fillMipMap(){const e=this.canvas.getContext("2d"),t=this.coordinates[0];e.drawImage(this.image,t[0],t[1],t[2],t[3]);for(let r=1;r<this.NUM_ITERATIONS;r++){const i=this.coordinates[r-1],o=this.coordinates[r];e.drawImage(this.canvas,i[0],i[1],i[2],i[3],o[0],o[1],o[2],o[3])}}drawImageAtPosition(e,t,r,i,o,s){if(this.initialized())if(t>2){t*=.5;let a=0;for(;t>2&&a<this.NUM_ITERATIONS;)t*=.5,a+=1;a>=this.NUM_ITERATIONS&&(a=this.NUM_ITERATIONS-1);const g=this.coordinates[a];e.drawImage(this.canvas,g[0],g[1],g[2],g[3],r,i,o,s)}else e.drawImage(this.image,r,i,o,s)}},rae=class{constructor(e){this.images={},this.imageBroken={},this.callback=e}_tryloadBrokenUrl(e,t,r){if(!(e===void 0||r===void 0)){if(t===void 0){console.warn("No broken url image defined");return}r.image.onerror=()=>{console.error("Could not load brokenImage:",t)},r.image.src=t}}_redrawWithImage(e){this.callback&&this.callback(e)}load(e,t){const r=this.images[e];if(r)return r;const i=new tae;return this.images[e]=i,i.image.onload=()=>{this._fixImageCoordinates(i.image),i.init(),this._redrawWithImage(i)},i.image.onerror=()=>{console.error("Could not load image:",e),this._tryloadBrokenUrl(e,t,i)},i.image.src=e,i}_fixImageCoordinates(e){e.width===0&&(document.body.appendChild(e),e.width=e.offsetWidth,e.height=e.offsetHeight,document.body.removeChild(e))}};var $N={},DN={},Qu={exports:{}},Ju,NN;function iae(){if(NN)return Ju;NN=1;var n=ce();return Ju=n(function(){if(typeof ArrayBuffer=="function"){var e=new ArrayBuffer(8);Object.isExtensible(e)&&Object.defineProperty(e,"a",{value:8})}}),Ju}var eh,MN;function nae(){if(MN)return eh;MN=1;var n=ce(),e=bt(),t=Ai(),r=iae(),i=Object.isExtensible,o=n(function(){});return eh=o||r?function(a){return!e(a)||r&&t(a)==="ArrayBuffer"?!1:i?i(a):!0}:i,eh}var th,qN;function QQ(){if(qN)return th;qN=1;var n=ce();return th=!n(function(){return Object.isExtensible(Object.preventExtensions({}))}),th}var FN;function bI(){if(FN)return Qu.exports;FN=1;var n=ee(),e=me(),t=Cg(),r=bt(),i=ct(),o=mr().f,s=cI(),a=YO(),g=nae(),A=AI(),I=QQ(),C=!1,l=A("meta"),d=0,u=function(p){o(p,l,{value:{objectID:"O"+d++,weakData:{}}})},h=function(p,y){if(!r(p))return typeof p=="symbol"?p:(typeof p=="string"?"S":"P")+p;if(!i(p,l)){if(!g(p))return"F";if(!y)return"E";u(p)}return p[l].objectID},v=function(p,y){if(!i(p,l)){if(!g(p))return!0;if(!y)return!1;u(p)}return p[l].weakData},f=function(p){return I&&C&&g(p)&&!i(p,l)&&u(p),p},c=function(){b.enable=function(){},C=!0;var p=s.f,y=e([].splice),E={};E[l]=1,p(E).length&&(s.f=function(S){for(var m=p(S),w=0,_=m.length;w<_;w++)if(m[w]===l){y(m,w,1);break}return m},n({target:"Object",stat:!0,forced:!0},{getOwnPropertyNames:a.f}))},b=Qu.exports={enable:c,fastKey:h,getWeakData:v,onFreeze:f};return t[l]=!0,Qu.exports}var rh,kN;function oae(){if(kN)return rh;kN=1;var n=Ct(),e=qs(),t=n("iterator"),r=Array.prototype;return rh=function(i){return i!==void 0&&(e.Array===i||r[t]===i)},rh}var ih,BN;function JQ(){if(BN)return ih;BN=1;var n=fn(),e=jO(),t=Os(),r=qs(),i=Ct(),o=i("iterator");return ih=function(s){if(!t(s))return e(s,o)||e(s,"@@iterator")||r[n(s)]},ih}var nh,zN;function e7(){if(zN)return nh;zN=1;var n=rr(),e=Pi(),t=Ii(),r=Ps(),i=JQ(),o=TypeError;return nh=function(s,a){var g=arguments.length<2?i(s):a;if(e(g))return t(n(g,s));throw new o(r(s)+" is not iterable")},nh}var oh,jN;function lT(){if(jN)return oh;jN=1;var n=rr(),e=Ii(),t=jO();return oh=function(r,i,o){var s,a;e(r);try{if(s=t(r,"return"),!s){if(i==="throw")throw o;return o}s=n(s,r)}catch(g){a=!0,s=g}if(i==="throw")throw o;if(a)throw s;return e(s),o},oh}var sh,LN;function wI(){if(LN)return sh;LN=1;var n=CI(),e=rr(),t=Ii(),r=Ps(),i=oae(),o=xi(),s=Je(),a=e7(),g=JQ(),A=lT(),I=TypeError,C=function(d,u){this.stopped=d,this.result=u},l=C.prototype;return sh=function(d,u,h){var v=h&&h.that,f=!!(h&&h.AS_ENTRIES),c=!!(h&&h.IS_RECORD),b=!!(h&&h.IS_ITERATOR),p=!!(h&&h.INTERRUPTED),y=n(u,v),E,S,m,w,_,T,R,O=function(x){return E&&A(E,"normal"),new C(!0,x)},P=function(x){return f?(t(x),p?y(x[0],x[1],O):y(x[0],x[1])):p?y(x,O):y(x)};if(c)E=d.iterator;else if(b)E=d;else{if(S=g(d),!S)throw new I(r(d)+" is not iterable");if(i(S)){for(m=0,w=o(d);w>m;m++)if(_=P(d[m]),_&&s(l,_))return _;return new C(!1)}E=a(d,S)}for(T=c?d.next:E.next;!(R=e(T,E)).done;){try{_=P(R.value)}catch(x){A(E,"throw",x)}if(typeof _=="object"&&_&&s(l,_))return _}return new C(!1)},sh}var ah,GN;function dT(){if(GN)return ah;GN=1;var n=Je(),e=TypeError;return ah=function(t,r){if(n(r,t))return t;throw new e("Incorrect invocation")},ah}var gh,WN;function uT(){if(WN)return gh;WN=1;var n=ee(),e=Le(),t=bI(),r=ce(),i=Ds(),o=wI(),s=dT(),a=yt(),g=bt(),A=Os(),I=Ao(),C=mr().f,l=pn().forEach,d=nt(),u=Io(),h=u.set,v=u.getterFor;return gh=function(f,c,b){var p=f.indexOf("Map")!==-1,y=f.indexOf("Weak")!==-1,E=p?"set":"add",S=e[f],m=S&&S.prototype,w={},_;if(!d||!a(S)||!(y||m.forEach&&!r(function(){new S().entries().next()})))_=b.getConstructor(c,f,p,E),t.enable();else{_=c(function(O,P){h(s(O,T),{type:f,collection:new S}),A(P)||o(P,O[E],{that:O,AS_ENTRIES:p})});var T=_.prototype,R=v(f);l(["add","clear","delete","forEach","get","has","set","keys","values","entries"],function(O){var P=O==="add"||O==="set";O in m&&!(y&&O==="clear")&&i(T,O,function(x,V){var M=R(this).collection;if(!P&&y&&!g(x))return O==="get"?void 0:!1;var U=M[O](x===0?0:x,V);return P?this:U})}),y||C(T,"size",{configurable:!0,get:function(){return R(this).collection.size}})}return I(_,f,!1,!0),w[f]=_,n({global:!0,forced:!0},w),y||b.setStrong(_,f,p),_},gh}var Ah,VN;function hT(){if(VN)return Ah;VN=1;var n=hg();return Ah=function(e,t,r){for(var i in t)r&&r.unsafe&&e[i]?e[i]=t[i]:n(e,i,t[i],r);return e},Ah}var Ih,ZN;function sae(){if(ZN)return Ih;ZN=1;var n=gr(),e=XO(),t=Ct(),r=nt(),i=t("species");return Ih=function(o){var s=n(o);r&&s&&!s[i]&&e(s,i,{configurable:!0,get:function(){return this}})},Ih}var Ch,HN;function t7(){if(HN)return Ch;HN=1;var n=ug(),e=XO(),t=hT(),r=CI(),i=dT(),o=Os(),s=wI(),a=JO(),g=eT(),A=sae(),I=nt(),C=bI().fastKey,l=Io(),d=l.set,u=l.getterFor;return Ch={getConstructor:function(h,v,f,c){var b=h(function(m,w){i(m,p),d(m,{type:v,index:n(null),first:null,last:null,size:0}),I||(m.size=0),o(w)||s(w,m[c],{that:m,AS_ENTRIES:f})}),p=b.prototype,y=u(v),E=function(m,w,_){var T=y(m),R=S(m,w),O,P;return R?R.value=_:(T.last=R={index:P=C(w,!0),key:w,value:_,previous:O=T.last,next:null,removed:!1},T.first||(T.first=R),O&&(O.next=R),I?T.size++:m.size++,P!=="F"&&(T.index[P]=R)),m},S=function(m,w){var _=y(m),T=C(w),R;if(T!=="F")return _.index[T];for(R=_.first;R;R=R.next)if(R.key===w)return R};return t(p,{clear:function(){for(var w=this,_=y(w),T=_.first;T;)T.removed=!0,T.previous&&(T.previous=T.previous.next=null),T=T.next;_.first=_.last=null,_.index=n(null),I?_.size=0:w.size=0},delete:function(m){var w=this,_=y(w),T=S(w,m);if(T){var R=T.next,O=T.previous;delete _.index[T.index],T.removed=!0,O&&(O.next=R),R&&(R.previous=O),_.first===T&&(_.first=R),_.last===T&&(_.last=O),I?_.size--:w.size--}return!!T},forEach:function(w){for(var _=y(this),T=r(w,arguments.length>1?arguments[1]:void 0),R;R=R?R.next:_.first;)for(T(R.value,R.key,this);R&&R.removed;)R=R.previous},has:function(w){return!!S(this,w)}}),t(p,f?{get:function(w){var _=S(this,w);return _&&_.value},set:function(w,_){return E(this,w===0?0:w,_)}}:{add:function(w){return E(this,w=w===0?0:w,w)}}),I&&e(p,"size",{configurable:!0,get:function(){return y(this).size}}),b},setStrong:function(h,v,f){var c=v+" Iterator",b=u(v),p=u(c);a(h,v,function(y,E){d(this,{type:c,target:y,state:b(y),kind:E,last:null})},function(){for(var y=p(this),E=y.kind,S=y.last;S&&S.removed;)S=S.previous;return!y.target||!(y.last=S=S?S.next:y.state.first)?(y.target=null,g(void 0,!0)):g(E==="keys"?S.key:E==="values"?S.value:[S.key,S.value],!1)},f?"entries":"values",!f,!0),A(v)}},Ch}var UN;function aae(){if(UN)return DN;UN=1;var n=uT(),e=t7();return n("Map",function(t){return function(){return t(this,arguments.length?arguments[0]:void 0)}},e),DN}var KN;function gae(){return KN||(KN=1,aae()),$N}var YN={},lh,XN;function r7(){return XN||(XN=1,lh=function(n,e){return e===1?function(t,r){return t[n](r)}:function(t,r,i){return t[n](r,i)}}),lh}var dh,QN;function Aae(){if(QN)return dh;QN=1;var n=gr(),e=r7(),t=n("Map");return dh={Map:t,set:e("set",2),get:e("get",1),has:e("has",1),remove:e("delete",1),proto:t.prototype},dh}var JN;function Iae(){if(JN)return YN;JN=1;var n=ee(),e=me(),t=Pi(),r=Ri(),i=wI(),o=Aae(),s=xs(),a=ce(),g=o.Map,A=o.has,I=o.get,C=o.set,l=e([].push),d=s||a(function(){return g.groupBy("ab",function(u){return u}).get("a").length!==1});return n({target:"Map",stat:!0,forced:s||d},{groupBy:function(h,v){r(h),t(v);var f=new g,c=0;return i(h,function(b){var p=v(b,c++);A(f,p)?l(I(f,p),b):C(f,p,[b])}),f}}),YN}var eM={},uh,tM;function Cae(){if(tM)return uh;tM=1;var n=me(),e=Ns(),t=yr(),r=Ri(),i=n("".charAt),o=n("".charCodeAt),s=n("".slice),a=function(g){return function(A,I){var C=t(r(A)),l=e(I),d=C.length,u,h;return l<0||l>=d?g?"":void 0:(u=o(C,l),u<55296||u>56319||l+1===d||(h=o(C,l+1))<56320||h>57343?g?i(C,l):u:g?s(C,l,l+2):(u-55296<<10)+(h-56320)+65536)}};return uh={codeAt:a(!1),charAt:a(!0)},uh}var rM;function EI(){if(rM)return eM;rM=1;var n=Cae().charAt,e=yr(),t=Io(),r=JO(),i=eT(),o="String Iterator",s=t.set,a=t.getterFor(o);return r(String,"String",function(g){s(this,{type:o,string:e(g),index:0})},function(){var A=a(this),I=A.string,C=A.index,l;return C>=I.length?i(void 0,!0):(l=n(I,C),A.index+=l.length,i(l,!1))}),eM}var hh,iM;function lae(){if(iM)return hh;iM=1,$i(),gae(),Iae(),EI();var n=Ee();return hh=n.Map,hh}var ch,nM;function dae(){if(nM)return ch;nM=1;var n=lae();return Di(),ch=n,ch}var fh,oM;function uae(){return oM||(oM=1,fh=dae()),fh}var hae=uae(),bg=ne(hae);let cae=class{constructor(){this.clear(),this._defaultIndex=0,this._groupIndex=0,this._defaultGroups=[{border:"#2B7CE9",background:"#97C2FC",highlight:{border:"#2B7CE9",background:"#D2E5FF"},hover:{border:"#2B7CE9",background:"#D2E5FF"}},{border:"#FFA500",background:"#FFFF00",highlight:{border:"#FFA500",background:"#FFFFA3"},hover:{border:"#FFA500",background:"#FFFFA3"}},{border:"#FA0A10",background:"#FB7E81",highlight:{border:"#FA0A10",background:"#FFAFB1"},hover:{border:"#FA0A10",background:"#FFAFB1"}},{border:"#41A906",background:"#7BE141",highlight:{border:"#41A906",background:"#A1EC76"},hover:{border:"#41A906",background:"#A1EC76"}},{border:"#E129F0",background:"#EB7DF4",highlight:{border:"#E129F0",background:"#F0B3F5"},hover:{border:"#E129F0",background:"#F0B3F5"}},{border:"#7C29F0",background:"#AD85E4",highlight:{border:"#7C29F0",background:"#D3BDF0"},hover:{border:"#7C29F0",background:"#D3BDF0"}},{border:"#C37F00",background:"#FFA807",highlight:{border:"#C37F00",background:"#FFCA66"},hover:{border:"#C37F00",background:"#FFCA66"}},{border:"#4220FB",background:"#6E6EFD",highlight:{border:"#4220FB",background:"#9B9BFD"},hover:{border:"#4220FB",background:"#9B9BFD"}},{border:"#FD5A77",background:"#FFC0CB",highlight:{border:"#FD5A77",background:"#FFD1D9"},hover:{border:"#FD5A77",background:"#FFD1D9"}},{border:"#4AD63A",background:"#C2FABC",highlight:{border:"#4AD63A",background:"#E6FFE3"},hover:{border:"#4AD63A",background:"#E6FFE3"}},{border:"#990000",background:"#EE0000",highlight:{border:"#BB0000",background:"#FF3333"},hover:{border:"#BB0000",background:"#FF3333"}},{border:"#FF6000",background:"#FF6000",highlight:{border:"#FF6000",background:"#FF6000"},hover:{border:"#FF6000",background:"#FF6000"}},{border:"#97C2FC",background:"#2B7CE9",highlight:{border:"#D2E5FF",background:"#2B7CE9"},hover:{border:"#D2E5FF",background:"#2B7CE9"}},{border:"#399605",background:"#255C03",highlight:{border:"#399605",background:"#255C03"},hover:{border:"#399605",background:"#255C03"}},{border:"#B70054",background:"#FF007E",highlight:{border:"#B70054",background:"#FF007E"},hover:{border:"#B70054",background:"#FF007E"}},{border:"#AD85E4",background:"#7C29F0",highlight:{border:"#D3BDF0",background:"#7C29F0"},hover:{border:"#D3BDF0",background:"#7C29F0"}},{border:"#4557FA",background:"#000EA1",highlight:{border:"#6E6EFD",background:"#000EA1"},hover:{border:"#6E6EFD",background:"#000EA1"}},{border:"#FFC0CB",background:"#FD5A77",highlight:{border:"#FFD1D9",background:"#FD5A77"},hover:{border:"#FFD1D9",background:"#FD5A77"}},{border:"#C2FABC",background:"#74D66A",highlight:{border:"#E6FFE3",background:"#74D66A"},hover:{border:"#E6FFE3",background:"#74D66A"}},{border:"#EE0000",background:"#990000",highlight:{border:"#FF3333",background:"#BB0000"},hover:{border:"#FF3333",background:"#BB0000"}}],this.options={},this.defaultOptions={useDefaultGroups:!0},tt(this.options,this.defaultOptions)}setOptions(e){const t=["useDefaultGroups"];if(e!==void 0){for(const r in e)if(Object.prototype.hasOwnProperty.call(e,r)&&_e(t).call(t,r)===-1){const i=e[r];this.add(r,i)}}}clear(){this._groups=new bg,this._groupNames=[]}get(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0,r=this._groups.get(e);if(r===void 0&&t)if(this.options.useDefaultGroups===!1&&this._groupNames.length>0){const i=this._groupIndex%this._groupNames.length;++this._groupIndex,r={},r.color=this._groups.get(this._groupNames[i]),this._groups.set(e,r)}else{const i=this._defaultIndex%this._defaultGroups.length;this._defaultIndex++,r={},r.color=this._defaultGroups[i],this._groups.set(e,r)}return r}add(e,t){return this._groups.has(e)||this._groupNames.push(e),this._groups.set(e,t),t}};var sM={},aM;function fae(){if(aM)return sM;aM=1;var n=ee();return n({target:"Number",stat:!0},{isNaN:function(t){return t!==t}}),sM}var ph,gM;function pae(){if(gM)return ph;gM=1,fae();var n=Ee();return ph=n.Number.isNaN,ph}var vh,AM;function vae(){if(AM)return vh;AM=1;var n=pae();return vh=n,vh}var mh,IM;function mae(){return IM||(IM=1,mh=vae()),mh}var yae=mae(),hO=ne(yae),CM={},yh,lM;function bae(){if(lM)return yh;lM=1;var n=Le(),e=n.isFinite;return yh=Number.isFinite||function(r){return typeof r=="number"&&e(r)},yh}var dM;function wae(){if(dM)return CM;dM=1;var n=ee(),e=bae();return n({target:"Number",stat:!0},{isFinite:e}),CM}var bh,uM;function Eae(){if(uM)return bh;uM=1,wae();var n=Ee();return bh=n.Number.isFinite,bh}var wh,hM;function Sae(){if(hM)return wh;hM=1;var n=Eae();return wh=n,wh}var Eh,cM;function _ae(){return cM||(cM=1,Eh=Sae()),Eh}var Oae=_ae(),Nn=ne(Oae),fM={},pM;function Tae(){if(pM)return fM;pM=1;var n=ee(),e=pn().some,t=Fs(),r=t("some");return n({target:"Array",proto:!0,forced:!r},{some:function(o){return e(this,o,arguments.length>1?arguments[1]:void 0)}}),fM}var Sh,vM;function Rae(){if(vM)return Sh;vM=1,Tae();var n=ft();return Sh=n("Array","some"),Sh}var _h,mM;function Pae(){if(mM)return _h;mM=1;var n=Je(),e=Rae(),t=Array.prototype;return _h=function(r){var i=r.some;return r===t||n(t,r)&&i===t.some?e:i},_h}var Oh,yM;function xae(){if(yM)return Oh;yM=1;var n=Pae();return Oh=n,Oh}var Th,bM;function $ae(){return bM||(bM=1,Th=xae()),Th}var Dae=$ae(),i7=ne(Dae),Rh,wM;function Nae(){if(wM)return Rh;wM=1,XX();var n=Ee();return Rh=n.Object.getOwnPropertySymbols,Rh}var Ph,EM;function Mae(){if(EM)return Ph;EM=1;var n=Nae();return Ph=n,Ph}var xh,SM;function qae(){return SM||(SM=1,xh=Mae()),xh}var Fae=qae(),ai=ne(Fae),$h={exports:{}},_M={},OM;function kae(){if(OM)return _M;OM=1;var n=ee(),e=ce(),t=Vr(),r=II().f,i=nt(),o=!i||e(function(){r(1)});return n({target:"Object",stat:!0,forced:o,sham:!i},{getOwnPropertyDescriptor:function(a,g){return r(t(a),g)}}),_M}var TM;function Bae(){if(TM)return $h.exports;TM=1,kae();var n=Ee(),e=n.Object,t=$h.exports=function(i,o){return e.getOwnPropertyDescriptor(i,o)};return e.getOwnPropertyDescriptor.sham&&(t.sham=!0),$h.exports}var Dh,RM;function zae(){if(RM)return Dh;RM=1;var n=Bae();return Dh=n,Dh}var Nh,PM;function jae(){return PM||(PM=1,Nh=zae()),Nh}var Lae=jae(),Ci=ne(Lae),xM={},$M;function Gae(){if($M)return xM;$M=1;var n=ee(),e=nt(),t=oQ(),r=Vr(),i=II(),o=uI();return n({target:"Object",stat:!0,sham:!e},{getOwnPropertyDescriptors:function(a){for(var g=r(a),A=i.f,I=t(g),C={},l=0,d,u;I.length>l;)u=A(g,d=I[l++]),u!==void 0&&o(C,d,u);return C}}),xM}var Mh,DM;function Wae(){if(DM)return Mh;DM=1,Gae();var n=Ee();return Mh=n.Object.getOwnPropertyDescriptors,Mh}var qh,NM;function Vae(){if(NM)return qh;NM=1;var n=Wae();return qh=n,qh}var Fh,MM;function Zae(){return MM||(MM=1,Fh=Vae()),Fh}var Hae=Zae(),gi=ne(Hae),kh={exports:{}},qM={},FM;function Uae(){if(FM)return qM;FM=1;var n=ee(),e=nt(),t=KO().f;return n({target:"Object",stat:!0,forced:Object.defineProperties!==t,sham:!e},{defineProperties:t}),qM}var kM;function Kae(){if(kM)return kh.exports;kM=1,Uae();var n=Ee(),e=n.Object,t=kh.exports=function(i,o){return e.defineProperties(i,o)};return e.defineProperties.sham&&(t.sham=!0),kh.exports}var Bh,BM;function Yae(){if(BM)return Bh;BM=1;var n=Kae();return Bh=n,Bh}var zh,zM;function Xae(){return zM||(zM=1,zh=Yae()),zh}var Qae=Xae(),wg=ne(Qae),jh={exports:{}},jM={},LM;function Jae(){if(LM)return jM;LM=1;var n=ee(),e=nt(),t=mr().f;return n({target:"Object",stat:!0,forced:Object.defineProperty!==t,sham:!e},{defineProperty:t}),jM}var GM;function ege(){if(GM)return jh.exports;GM=1,Jae();var n=Ee(),e=n.Object,t=jh.exports=function(i,o,s){return e.defineProperty(i,o,s)};return e.defineProperty.sham&&(t.sham=!0),jh.exports}var Lh,WM;function n7(){if(WM)return Lh;WM=1;var n=ege();return Lh=n,Lh}var Gh,VM;function tge(){if(VM)return Gh;VM=1;var n=n7();return Gh=n,Gh}var Wh,ZM;function rge(){if(ZM)return Wh;ZM=1;var n=tge();return Wh=n,Wh}var Vh,HM;function ige(){return HM||(HM=1,Vh=rge()),Vh}var nge=ige(),oge=ne(nge),UM={},KM;function sge(){if(KM)return UM;KM=1;var n=Ct(),e=mr().f,t=n("metadata"),r=Function.prototype;return r[t]===void 0&&e(r,t,{value:null}),UM}var YM={},XM;function age(){return XM||(XM=1,QX()),YM}var QM={},JM;function gge(){return JM||(JM=1,JX()),QM}var eq={},tq;function Age(){if(tq)return eq;tq=1;var n=Ze();return n("metadata"),eq}var Zh,rq;function Ige(){if(rq)return Zh;rq=1;var n=nQ();return sge(),age(),gge(),Age(),Zh=n,Zh}var iq={},Hh,nq;function o7(){if(nq)return Hh;nq=1;var n=gr(),e=me(),t=n("Symbol"),r=t.keyFor,i=e(t.prototype.valueOf);return Hh=t.isRegisteredSymbol||function(s){try{return r(i(s))!==void 0}catch{return!1}},Hh}var oq;function Cge(){if(oq)return iq;oq=1;var n=ee(),e=o7();return n({target:"Symbol",stat:!0},{isRegisteredSymbol:e}),iq}var sq={},Uh,aq;function s7(){if(aq)return Uh;aq=1;for(var n=$s(),e=gr(),t=me(),r=Ig(),i=Ct(),o=e("Symbol"),s=o.isWellKnownSymbol,a=e("Object","getOwnPropertyNames"),g=t(o.prototype.valueOf),A=n("wks"),I=0,C=a(o),l=C.length;I<l;I++)try{var d=C[I];r(o[d])&&i(d)}catch{}return Uh=function(h){if(s&&s(h))return!0;try{for(var v=g(h),f=0,c=a(A),b=c.length;f<b;f++)if(A[c[f]]==v)return!0}catch{}return!1},Uh}var gq;function lge(){if(gq)return sq;gq=1;var n=ee(),e=s7();return n({target:"Symbol",stat:!0,forced:!0},{isWellKnownSymbol:e}),sq}var Aq={},Iq;function dge(){if(Iq)return Aq;Iq=1;var n=Ze();return n("customMatcher"),Aq}var Cq={},lq;function uge(){if(lq)return Cq;lq=1;var n=Ze();return n("observable"),Cq}var dq={},uq;function hge(){if(uq)return dq;uq=1;var n=ee(),e=o7();return n({target:"Symbol",stat:!0,name:"isRegisteredSymbol"},{isRegistered:e}),dq}var hq={},cq;function cge(){if(cq)return hq;cq=1;var n=ee(),e=s7();return n({target:"Symbol",stat:!0,name:"isWellKnownSymbol",forced:!0},{isWellKnown:e}),hq}var fq={},pq;function fge(){if(pq)return fq;pq=1;var n=Ze();return n("matcher"),fq}var vq={},mq;function pge(){if(mq)return vq;mq=1;var n=Ze();return n("metadataKey"),vq}var yq={},bq;function vge(){if(bq)return yq;bq=1;var n=Ze();return n("patternMatch"),yq}var wq={},Eq;function mge(){if(Eq)return wq;Eq=1;var n=Ze();return n("replaceAll"),wq}var Kh,Sq;function yge(){if(Sq)return Kh;Sq=1;var n=Ige();return Cge(),lge(),dge(),uge(),hge(),cge(),fge(),pge(),vge(),mge(),Kh=n,Kh}var Yh,_q;function bge(){return _q||(_q=1,Yh=yge()),Yh}var wge=bge(),uA=ne(wge),Xh,Oq;function Ege(){if(Oq)return Xh;Oq=1,$i(),EI(),eQ();var n=fI();return Xh=n.f("iterator"),Xh}var Qh,Tq;function a7(){if(Tq)return Qh;Tq=1;var n=Ege();return Di(),Qh=n,Qh}var Jh,Rq;function Sge(){if(Rq)return Jh;Rq=1;var n=a7();return Jh=n,Jh}var ec,Pq;function _ge(){if(Pq)return ec;Pq=1;var n=Sge();return ec=n,ec}var tc,xq;function Oge(){return xq||(xq=1,tc=_ge()),tc}var Tge=Oge(),Rge=ne(Tge);function Ua(n){"@babel/helpers - typeof";return Ua=typeof uA=="function"&&typeof Rge=="symbol"?function(e){return typeof e}:function(e){return e&&typeof uA=="function"&&e.constructor===uA&&e!==uA.prototype?"symbol":typeof e},Ua(n)}var rc,$q;function Pge(){if($q)return rc;$q=1,tQ();var n=fI();return rc=n.f("toPrimitive"),rc}var ic,Dq;function xge(){if(Dq)return ic;Dq=1;var n=Pge();return ic=n,ic}var nc,Nq;function $ge(){if(Nq)return nc;Nq=1;var n=xge();return nc=n,nc}var oc,Mq;function Dge(){if(Mq)return oc;Mq=1;var n=$ge();return oc=n,oc}var sc,qq;function Nge(){return qq||(qq=1,sc=Dge()),sc}var Mge=Nge(),qge=ne(Mge);function Fge(n,e){if(Ua(n)!="object"||!n)return n;var t=n[qge];if(t!==void 0){var r=t.call(n,e);if(Ua(r)!="object")return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(n)}function kge(n){var e=Fge(n,"string");return Ua(e)=="symbol"?e:e+""}function ze(n,e,t){return(e=kge(e))in n?oge(n,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):n[e]=t,n}var Fq={},ac,kq;function Bge(){if(kq)return ac;kq=1;var n=Pi(),e=Ar(),t=gI(),r=xi(),i=TypeError,o="Reduce of empty array with no initial value",s=function(a){return function(g,A,I,C){var l=e(g),d=t(l),u=r(l);if(n(A),u===0&&I<2)throw new i(o);var h=a?u-1:0,v=a?-1:1;if(I<2)for(;;){if(h in d){C=d[h],h+=v;break}if(h+=v,a?h<0:u<=h)throw new i(o)}for(;a?h>=0:u>h;h+=v)h in d&&(C=A(C,d[h],h,l));return C}};return ac={left:s(!1),right:s(!0)},ac}var gc,Bq;function zge(){if(Bq)return gc;Bq=1;var n=AQ();return gc=n==="NODE",gc}var zq;function jge(){if(zq)return Fq;zq=1;var n=ee(),e=Bge().left,t=Fs(),r=Ag(),i=zge(),o=!i&&r>79&&r<83,s=o||!t("reduce");return n({target:"Array",proto:!0,forced:s},{reduce:function(g){var A=arguments.length;return e(this,g,A,A>1?arguments[1]:void 0)}}),Fq}var Ac,jq;function Lge(){if(jq)return Ac;jq=1,jge();var n=ft();return Ac=n("Array","reduce"),Ac}var Ic,Lq;function Gge(){if(Lq)return Ic;Lq=1;var n=Je(),e=Lge(),t=Array.prototype;return Ic=function(r){var i=r.reduce;return r===t||n(t,r)&&i===t.reduce?e:i},Ic}var Cc,Gq;function Wge(){if(Gq)return Cc;Gq=1;var n=Gge();return Cc=n,Cc}var lc,Wq;function Vge(){return Wq||(Wq=1,lc=Wge()),lc}var Zge=Vge(),cT=ne(Zge),dc,Vq;function Hge(){return Vq||(Vq=1,dc=a7()),dc}var Uge=Hge(),Ho=ne(Uge),Zq={},Hq={},Uq;function Kge(){if(Uq)return Hq;Uq=1;var n=uT(),e=t7();return n("Set",function(t){return function(){return t(this,arguments.length?arguments[0]:void 0)}},e),Hq}var Kq;function Yge(){return Kq||(Kq=1,Kge()),Zq}var Yq={},uc,Xq;function lo(){if(Xq)return uc;Xq=1;var n=Ps(),e=TypeError;return uc=function(t){if(typeof t=="object"&&"size"in t&&"has"in t&&"add"in t&&"delete"in t&&"keys"in t)return t;throw new e(n(t)+" is not a set")},uc}var hc,Qq;function uo(){if(Qq)return hc;Qq=1;var n=gr(),e=r7(),t=n("Set"),r=t.prototype;return hc={Set:t,add:e("add",1),has:e("has",1),remove:e("delete",1),proto:r},hc}var cc,Jq;function ho(){if(Jq)return cc;Jq=1;var n=rr();return cc=function(e,t,r){for(var i=r?e:e.iterator,o=e.next,s,a;!(s=n(o,i)).done;)if(a=t(s.value),a!==void 0)return a},cc}var fc,eF;function Eg(){if(eF)return fc;eF=1;var n=ho();return fc=function(e,t,r){return r?n(e.keys(),t,!0):e.forEach(t)},fc}var pc,tF;function fT(){if(tF)return pc;tF=1;var n=uo(),e=Eg(),t=n.Set,r=n.add;return pc=function(i){var o=new t;return e(i,function(s){r(o,s)}),o},pc}var vc,rF;function Sg(){return rF||(rF=1,vc=function(n){return n.size}),vc}var mc,iF;function Xge(){return iF||(iF=1,mc=function(n){return{iterator:n,next:n.next,done:!1}}),mc}var yc,nF;function co(){if(nF)return yc;nF=1;var n=Pi(),e=Ii(),t=rr(),r=Ns(),i=Xge(),o="Invalid size",s=RangeError,a=TypeError,g=Math.max,A=function(I,C){this.set=I,this.size=g(C,0),this.has=n(I.has),this.keys=n(I.keys)};return A.prototype={getIterator:function(){return i(e(t(this.keys,this.set)))},includes:function(I){return t(this.has,this.set,I)}},yc=function(I){e(I);var C=+I.size;if(C!==C)throw new a(o);var l=r(C);if(l<0)throw new s(o);return new A(I,l)},yc}var bc,oF;function Qge(){if(oF)return bc;oF=1;var n=lo(),e=uo(),t=fT(),r=Sg(),i=co(),o=Eg(),s=ho(),a=e.has,g=e.remove;return bc=function(I){var C=n(this),l=i(I),d=t(C);return r(C)<=l.size?o(C,function(u){l.includes(u)&&g(d,u)}):s(l.getIterator(),function(u){a(d,u)&&g(d,u)}),d},bc}var wc,sF;function fo(){return sF||(sF=1,wc=function(){return!1}),wc}var aF;function Jge(){if(aF)return Yq;aF=1;var n=ee(),e=Qge(),t=ce(),r=fo(),i=!r("difference",function(s){return s.size===0}),o=i||t(function(){var s={size:1,has:function(){return!0},keys:function(){var g=0;return{next:function(){var A=g++>1;return a.has(1)&&a.clear(),{done:A,value:2}}}}},a=new Set([1,2,3,4]);return a.difference(s).size!==3});return n({target:"Set",proto:!0,real:!0,forced:o},{difference:e}),Yq}var gF={},Ec,AF;function eAe(){if(AF)return Ec;AF=1;var n=lo(),e=uo(),t=Sg(),r=co(),i=Eg(),o=ho(),s=e.Set,a=e.add,g=e.has;return Ec=function(I){var C=n(this),l=r(I),d=new s;return t(C)>l.size?o(l.getIterator(),function(u){g(C,u)&&a(d,u)}):i(C,function(u){l.includes(u)&&a(d,u)}),d},Ec}var IF;function tAe(){if(IF)return gF;IF=1;var n=ee(),e=ce(),t=eAe(),r=fo(),i=!r("intersection",function(o){return o.size===2&&o.has(1)&&o.has(2)})||e(function(){return String(Array.from(new Set([1,2,3]).intersection(new Set([3,2]))))!=="3,2"});return n({target:"Set",proto:!0,real:!0,forced:i},{intersection:t}),gF}var CF={},Sc,lF;function rAe(){if(lF)return Sc;lF=1;var n=lo(),e=uo().has,t=Sg(),r=co(),i=Eg(),o=ho(),s=lT();return Sc=function(g){var A=n(this),I=r(g);if(t(A)<=I.size)return i(A,function(l){if(I.includes(l))return!1},!0)!==!1;var C=I.getIterator();return o(C,function(l){if(e(A,l))return s(C,"normal",!1)})!==!1},Sc}var dF;function iAe(){if(dF)return CF;dF=1;var n=ee(),e=rAe(),t=fo(),r=!t("isDisjointFrom",function(i){return!i});return n({target:"Set",proto:!0,real:!0,forced:r},{isDisjointFrom:e}),CF}var uF={},_c,hF;function nAe(){if(hF)return _c;hF=1;var n=lo(),e=Sg(),t=Eg(),r=co();return _c=function(o){var s=n(this),a=r(o);return e(s)>a.size?!1:t(s,function(g){if(!a.includes(g))return!1},!0)!==!1},_c}var cF;function oAe(){if(cF)return uF;cF=1;var n=ee(),e=nAe(),t=fo(),r=!t("isSubsetOf",function(i){return i});return n({target:"Set",proto:!0,real:!0,forced:r},{isSubsetOf:e}),uF}var fF={},Oc,pF;function sAe(){if(pF)return Oc;pF=1;var n=lo(),e=uo().has,t=Sg(),r=co(),i=ho(),o=lT();return Oc=function(a){var g=n(this),A=r(a);if(t(g)<A.size)return!1;var I=A.getIterator();return i(I,function(C){if(!e(g,C))return o(I,"normal",!1)})!==!1},Oc}var vF;function aAe(){if(vF)return fF;vF=1;var n=ee(),e=sAe(),t=fo(),r=!t("isSupersetOf",function(i){return!i});return n({target:"Set",proto:!0,real:!0,forced:r},{isSupersetOf:e}),fF}var mF={},Tc,yF;function gAe(){if(yF)return Tc;yF=1;var n=lo(),e=uo(),t=fT(),r=co(),i=ho(),o=e.add,s=e.has,a=e.remove;return Tc=function(A){var I=n(this),C=r(A).getIterator(),l=t(I);return i(C,function(d){s(I,d)?a(l,d):o(l,d)}),l},Tc}var Rc,bF;function g7(){return bF||(bF=1,Rc=function(n){try{var e=new Set,t={size:0,has:function(){return!0},keys:function(){return Object.defineProperty({},"next",{get:function(){return e.clear(),e.add(4),function(){return{done:!0}}}})}},r=e[n](t);return r.size===1&&r.values().next().value===4}catch{return!1}}),Rc}var wF;function AAe(){if(wF)return mF;wF=1;var n=ee(),e=gAe(),t=g7(),r=fo(),i=!r("symmetricDifference")||!t("symmetricDifference");return n({target:"Set",proto:!0,real:!0,forced:i},{symmetricDifference:e}),mF}var EF={},Pc,SF;function IAe(){if(SF)return Pc;SF=1;var n=lo(),e=uo().add,t=fT(),r=co(),i=ho();return Pc=function(s){var a=n(this),g=r(s).getIterator(),A=t(a);return i(g,function(I){e(A,I)}),A},Pc}var _F;function CAe(){if(_F)return EF;_F=1;var n=ee(),e=IAe(),t=g7(),r=fo(),i=!r("union")||!t("union");return n({target:"Set",proto:!0,real:!0,forced:i},{union:e}),EF}var xc,OF;function lAe(){if(OF)return xc;OF=1,$i(),Yge(),Jge(),tAe(),iAe(),oAe(),aAe(),AAe(),CAe(),EI();var n=Ee();return xc=n.Set,xc}var $c,TF;function dAe(){if(TF)return $c;TF=1;var n=lAe();return Di(),$c=n,$c}var Dc,RF;function uAe(){return RF||(RF=1,Dc=dAe()),Dc}var hAe=uAe(),jr=ne(hAe),Nc,PF;function cAe(){if(PF)return Nc;PF=1,$i(),EI();var n=e7();return Nc=n,Nc}var Mc,xF;function fAe(){if(xF)return Mc;xF=1;var n=cAe();return Di(),Mc=n,Mc}var qc,$F;function pAe(){if($F)return qc;$F=1;var n=fAe();return qc=n,qc}var Fc,DF;function vAe(){if(DF)return Fc;DF=1;var n=pAe();return Fc=n,Fc}var kc,NF;function mAe(){return NF||(NF=1,kc=vAe()),kc}var Bc,MF;function yAe(){return MF||(MF=1,Bc=mAe()),Bc}var bAe=yAe(),zc=ne(bAe),qF={},jc,FF;function wAe(){if(FF)return jc;FF=1;var n=Ms(),e=Math.floor,t=function(r,i){var o=r.length;if(o<8)for(var s=1,a,g;s<o;){for(g=s,a=r[s];g&&i(r[g-1],a)>0;)r[g]=r[--g];g!==s++&&(r[g]=a)}else for(var A=e(o/2),I=t(n(r,0,A),i),C=t(n(r,A),i),l=I.length,d=C.length,u=0,h=0;u<l||h<d;)r[u+h]=u<l&&h<d?i(I[u],C[h])<=0?I[u++]:C[h++]:u<l?I[u++]:C[h++];return r};return jc=t,jc}var Lc,kF;function EAe(){if(kF)return Lc;kF=1;var n=Ts(),e=n.match(/firefox\/(\d+)/i);return Lc=!!e&&+e[1],Lc}var Gc,BF;function SAe(){if(BF)return Gc;BF=1;var n=Ts();return Gc=/MSIE|Trident/.test(n),Gc}var Wc,zF;function _Ae(){if(zF)return Wc;zF=1;var n=Ts(),e=n.match(/AppleWebKit\/(\d+)\./);return Wc=!!e&&+e[1],Wc}var jF;function OAe(){if(jF)return qF;jF=1;var n=ee(),e=me(),t=Pi(),r=Ar(),i=xi(),o=sQ(),s=yr(),a=ce(),g=wAe(),A=Fs(),I=EAe(),C=SAe(),l=Ag(),d=_Ae(),u=[],h=e(u.sort),v=e(u.push),f=a(function(){u.sort(void 0)}),c=a(function(){u.sort(null)}),b=A("sort"),p=!a(function(){if(l)return l<70;if(!(I&&I>3)){if(C)return!0;if(d)return d<603;var S="",m,w,_,T;for(m=65;m<76;m++){switch(w=String.fromCharCode(m),m){case 66:case 69:case 70:case 72:_=3;break;case 68:case 71:_=4;break;default:_=2}for(T=0;T<47;T++)u.push({k:w+T,v:_})}for(u.sort(function(R,O){return O.v-R.v}),T=0;T<u.length;T++)w=u[T].k.charAt(0),S.charAt(S.length-1)!==w&&(S+=w);return S!=="DGBEFHACIJK"}}),y=f||!c||!b||!p,E=function(S){return function(m,w){return w===void 0?-1:m===void 0?1:S!==void 0?+S(m,w)||0:s(m)>s(w)?1:-1}};return n({target:"Array",proto:!0,forced:y},{sort:function(m){m!==void 0&&t(m);var w=r(this);if(p)return m===void 0?h(w):h(w,m);var _=[],T=i(w),R,O;for(O=0;O<T;O++)O in w&&v(_,w[O]);for(g(_,E(m)),R=i(_),O=0;O<R;)w[O]=_[O++];for(;O<T;)o(w,O++);return w}}),qF}var Vc,LF;function TAe(){if(LF)return Vc;LF=1,OAe();var n=ft();return Vc=n("Array","sort"),Vc}var Zc,GF;function RAe(){if(GF)return Zc;GF=1;var n=Je(),e=TAe(),t=Array.prototype;return Zc=function(r){var i=r.sort;return r===t||n(t,r)&&i===t.sort?e:i},Zc}var Hc,WF;function PAe(){if(WF)return Hc;WF=1;var n=RAe();return Hc=n,Hc}var Uc,VF;function xAe(){return VF||(VF=1,Uc=PAe()),Uc}var $Ae=xAe(),mi=ne($Ae),Kc,ZF;function DAe(){if(ZF)return Kc;ZF=1,$i();var n=ft();return Kc=n("Array","keys"),Kc}var Yc,HF;function NAe(){if(HF)return Yc;HF=1;var n=DAe();return Yc=n,Yc}var Xc,UF;function MAe(){if(UF)return Xc;UF=1,Di();var n=fn(),e=ct(),t=Je(),r=NAe(),i=Array.prototype,o={DOMTokenList:!0,NodeList:!0};return Xc=function(s){var a=s.keys;return s===i||t(i,s)&&a===i.keys||e(o,n(s))?r:a},Xc}var Qc,KF;function qAe(){return KF||(KF=1,Qc=MAe()),Qc}var FAe=qAe(),Bo=ne(FAe),Jc,YF;function kAe(){if(YF)return Jc;YF=1,$i();var n=ft();return Jc=n("Array","values"),Jc}var ef,XF;function BAe(){if(XF)return ef;XF=1;var n=kAe();return ef=n,ef}var tf,QF;function zAe(){if(QF)return tf;QF=1,Di();var n=fn(),e=ct(),t=Je(),r=BAe(),i=Array.prototype,o={DOMTokenList:!0,NodeList:!0};return tf=function(s){var a=s.values;return s===i||t(i,s)&&a===i.values||e(o,n(s))?r:a},tf}var rf,JF;function jAe(){return JF||(JF=1,rf=zAe()),rf}var LAe=jAe(),LA=ne(LAe),nf,ek;function GAe(){if(ek)return nf;ek=1,$i();var n=ft();return nf=n("Array","entries"),nf}var of,tk;function WAe(){if(tk)return of;tk=1;var n=GAe();return of=n,of}var sf,rk;function VAe(){if(rk)return sf;rk=1,Di();var n=fn(),e=ct(),t=Je(),r=WAe(),i=Array.prototype,o={DOMTokenList:!0,NodeList:!0};return sf=function(s){var a=s.entries;return s===i||t(i,s)&&a===i.entries||e(o,n(s))?r:a},sf}var af,ik;function ZAe(){return ik||(ik=1,af=VAe()),af}var HAe=ZAe(),UAe=ne(HAe),gf,nk;function KAe(){return nk||(nk=1,gf=n7()),gf}var YAe=KAe(),_g=ne(YAe);const $t=[];for(let n=0;n<256;++n)$t.push((n+256).toString(16).slice(1));function XAe(n,e=0){return($t[n[e+0]]+$t[n[e+1]]+$t[n[e+2]]+$t[n[e+3]]+"-"+$t[n[e+4]]+$t[n[e+5]]+"-"+$t[n[e+6]]+$t[n[e+7]]+"-"+$t[n[e+8]]+$t[n[e+9]]+"-"+$t[n[e+10]]+$t[n[e+11]]+$t[n[e+12]]+$t[n[e+13]]+$t[n[e+14]]+$t[n[e+15]]).toLowerCase()}let Af;const QAe=new Uint8Array(16);function JAe(){if(!Af){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");Af=crypto.getRandomValues.bind(crypto)}return Af(QAe)}const eIe=typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto);var ok={randomUUID:eIe};function tIe(n,e,t){n=n||{};const r=n.random??n.rng?.()??JAe();if(r.length<16)throw new Error("Random bytes length must be >= 16");return r[6]=r[6]&15|64,r[8]=r[8]&63|128,XAe(r)}function is(n,e,t){return ok.randomUUID&&!n?ok.randomUUID():tIe(n)}function sk(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function ak(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=sk(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=sk(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}function gk(n){return typeof n=="string"||typeof n=="number"}let rIe=class A7{constructor(e){ze(this,"delay",void 0),ze(this,"max",void 0),ze(this,"_queue",[]),ze(this,"_timeout",null),ze(this,"_extended",null),this.delay=null,this.max=1/0,this.setOptions(e)}setOptions(e){e&&typeof e.delay<"u"&&(this.delay=e.delay),e&&typeof e.max<"u"&&(this.max=e.max),this._flushIfNeeded()}static extend(e,t){const r=new A7(t);if(e.flush!==void 0)throw new Error("Target object already has a property flush");e.flush=()=>{r.flush()};const i=[{name:"flush",original:void 0}];if(t&&t.replace)for(let o=0;o<t.replace.length;o++){const s=t.replace[o];i.push({name:s,original:e[s]}),r.replace(e,s)}return r._extended={object:e,methods:i},r}destroy(){if(this.flush(),this._extended){const e=this._extended.object,t=this._extended.methods;for(let r=0;r<t.length;r++){const i=t[r];i.original?e[i.name]=i.original:delete e[i.name]}this._extended=null}}replace(e,t){const r=this,i=e[t];if(!i)throw new Error("Method "+t+" undefined");e[t]=function(){for(var o=arguments.length,s=new Array(o),a=0;a<o;a++)s[a]=arguments[a];r.queue({args:s,fn:i,context:this})}}queue(e){typeof e=="function"?this._queue.push({fn:e}):this._queue.push(e),this._flushIfNeeded()}_flushIfNeeded(){this._queue.length>this.max&&this.flush(),this._timeout!=null&&(clearTimeout(this._timeout),this._timeout=null),this.queue.length>0&&typeof this.delay=="number"&&(this._timeout=ri(()=>{this.flush()},this.delay))}flush(){var e,t;be(e=ti(t=this._queue).call(t,0)).call(e,r=>{r.fn.apply(r.context||r.fn,r.args||[])})}},iIe=class cO{constructor(){ze(this,"_subscribers",{"*":[],add:[],remove:[],update:[]}),ze(this,"subscribe",cO.prototype.on),ze(this,"unsubscribe",cO.prototype.off)}_trigger(e,t,r){var i;if(e==="*")throw new Error("Cannot trigger event *");be(i=[...this._subscribers[e],...this._subscribers["*"]]).call(i,o=>{o(e,t,r??null)})}on(e,t){typeof t=="function"&&this._subscribers[e].push(t)}off(e,t){var r;this._subscribers[e]=st(r=this._subscribers[e]).call(r,i=>i!==t)}},Ak=class Oa{constructor(e){ze(this,"_pairs",void 0),this._pairs=e}*[Ho](){for(const[e,t]of this._pairs)yield[e,t]}*entries(){for(const[e,t]of this._pairs)yield[e,t]}*keys(){for(const[e]of this._pairs)yield e}*values(){for(const[,e]of this._pairs)yield e}toIdArray(){var e;return Mt(e=[...this._pairs]).call(e,t=>t[0])}toItemArray(){var e;return Mt(e=[...this._pairs]).call(e,t=>t[1])}toEntryArray(){return[...this._pairs]}toObjectMap(){const e=nn(null);for(const[t,r]of this._pairs)e[t]=r;return e}toMap(){return new bg(this._pairs)}toIdSet(){return new jr(this.toIdArray())}toItemSet(){return new jr(this.toItemArray())}cache(){return new Oa([...this._pairs])}distinct(e){const t=new jr;for(const[r,i]of this._pairs)t.add(e(i,r));return t}filter(e){const t=this._pairs;return new Oa({*[Ho](){for(const[r,i]of t)e(i,r)&&(yield[r,i])}})}forEach(e){for(const[t,r]of this._pairs)e(r,t)}map(e){const t=this._pairs;return new Oa({*[Ho](){for(const[r,i]of t)yield[r,e(i,r)]}})}max(e){const t=zc(this._pairs);let r=t.next();if(r.done)return null;let i=r.value[1],o=e(r.value[1],r.value[0]);for(;!(r=t.next()).done;){const[s,a]=r.value,g=e(a,s);g>o&&(o=g,i=a)}return i}min(e){const t=zc(this._pairs);let r=t.next();if(r.done)return null;let i=r.value[1],o=e(r.value[1],r.value[0]);for(;!(r=t.next()).done;){const[s,a]=r.value,g=e(a,s);g<o&&(o=g,i=a)}return i}reduce(e,t){for(const[r,i]of this._pairs)t=e(t,i,r);return t}sort(e){return new Oa({[Ho]:()=>{var t;return zc(mi(t=[...this._pairs]).call(t,(r,i)=>{let[o,s]=r,[a,g]=i;return e(s,g,o,a)}))}})}};function nIe(n,e){return n[e]==null&&(n[e]=is()),n}let us=class extends iIe{get idProp(){return this._idProp}constructor(e,t){super(),ze(this,"flush",void 0),ze(this,"length",void 0),ze(this,"_options",void 0),ze(this,"_data",void 0),ze(this,"_idProp",void 0),ze(this,"_queue",null),e&&!we(e)&&(t=e,e=[]),this._options=t||{},this._data=new bg,this.length=0,this._idProp=this._options.fieldId||"id",e&&e.length&&this.add(e),this.setOptions(t)}setOptions(e){e&&e.queue!==void 0&&(e.queue===!1?this._queue&&(this._queue.destroy(),this._queue=null):(this._queue||(this._queue=rIe.extend(this,{replace:["add","update","remove"]})),e.queue&&typeof e.queue=="object"&&this._queue.setOptions(e.queue)))}add(e,t){const r=[];let i;if(we(e)){const o=Mt(e).call(e,s=>s[this._idProp]);if(i7(o).call(o,s=>this._data.has(s)))throw new Error("A duplicate id was found in the parameter array.");for(let s=0,a=e.length;s<a;s++)i=this._addItem(e[s]),r.push(i)}else if(e&&typeof e=="object")i=this._addItem(e),r.push(i);else throw new Error("Unknown dataType");return r.length&&this._trigger("add",{items:r},t),r}update(e,t){const r=[],i=[],o=[],s=[],a=this._idProp,g=A=>{const I=A[a];if(I!=null&&this._data.has(I)){const C=A,l=tt({},this._data.get(I)),d=this._updateItem(C);i.push(d),s.push(C),o.push(l)}else{const C=this._addItem(A);r.push(C)}};if(we(e))for(let A=0,I=e.length;A<I;A++)e[A]&&typeof e[A]=="object"?g(e[A]):console.warn("Ignoring input item, which is not an object at index "+A);else if(e&&typeof e=="object")g(e);else throw new Error("Unknown dataType");if(r.length&&this._trigger("add",{items:r},t),i.length){const A={items:i,oldData:o,data:s};this._trigger("update",A,t)}return aQ(r).call(r,i)}updateOnly(e,t){var r;we(e)||(e=[e]);const i=Mt(r=Mt(e).call(e,o=>{const s=this._data.get(o[this._idProp]);if(s==null)throw new Error("Updating non-existent items is not allowed.");return{oldData:s,update:o}})).call(r,o=>{let{oldData:s,update:a}=o;const g=s[this._idProp],A=sse(s,a);return this._data.set(g,A),{id:g,oldData:s,updatedData:A}});if(i.length){const o={items:Mt(i).call(i,s=>s.id),oldData:Mt(i).call(i,s=>s.oldData),data:Mt(i).call(i,s=>s.updatedData)};return this._trigger("update",o,t),o.items}else return[]}get(e,t){let r,i,o;gk(e)?(r=e,o=t):we(e)?(i=e,o=t):o=e;const s=o&&o.returnType==="Object"?"Object":"Array",a=o&&st(o),g=[];let A,I,C;if(r!=null)A=this._data.get(r),A&&a&&!a(A)&&(A=void 0);else if(i!=null)for(let d=0,u=i.length;d<u;d++)A=this._data.get(i[d]),A!=null&&(!a||a(A))&&g.push(A);else{var l;I=[...Bo(l=this._data).call(l)];for(let d=0,u=I.length;d<u;d++)C=I[d],A=this._data.get(C),A!=null&&(!a||a(A))&&g.push(A)}if(o&&o.order&&r==null&&this._sort(g,o.order),o&&o.fields){const d=o.fields;if(r!=null&&A!=null)A=this._filterFields(A,d);else for(let u=0,h=g.length;u<h;u++)g[u]=this._filterFields(g[u],d)}if(s=="Object"){const d={};for(let u=0,h=g.length;u<h;u++){const v=g[u],f=v[this._idProp];d[f]=v}return d}else return r!=null?A??null:g}getIds(e){const t=this._data,r=e&&st(e),i=e&&e.order,o=[...Bo(t).call(t)],s=[];if(r)if(i){const a=[];for(let g=0,A=o.length;g<A;g++){const I=o[g],C=this._data.get(I);C!=null&&r(C)&&a.push(C)}this._sort(a,i);for(let g=0,A=a.length;g<A;g++)s.push(a[g][this._idProp])}else for(let a=0,g=o.length;a<g;a++){const A=o[a],I=this._data.get(A);I!=null&&r(I)&&s.push(I[this._idProp])}else if(i){const a=[];for(let g=0,A=o.length;g<A;g++){const I=o[g];a.push(t.get(I))}this._sort(a,i);for(let g=0,A=a.length;g<A;g++)s.push(a[g][this._idProp])}else for(let a=0,g=o.length;a<g;a++){const A=o[a],I=t.get(A);I!=null&&s.push(I[this._idProp])}return s}getDataSet(){return this}forEach(e,t){const r=t&&st(t),i=this._data,o=[...Bo(i).call(i)];if(t&&t.order){const s=this.get(t);for(let a=0,g=s.length;a<g;a++){const A=s[a],I=A[this._idProp];e(A,I)}}else for(let s=0,a=o.length;s<a;s++){const g=o[s],A=this._data.get(g);A!=null&&(!r||r(A))&&e(A,g)}}map(e,t){const r=t&&st(t),i=[],o=this._data,s=[...Bo(o).call(o)];for(let a=0,g=s.length;a<g;a++){const A=s[a],I=this._data.get(A);I!=null&&(!r||r(I))&&i.push(e(I,A))}return t&&t.order&&this._sort(i,t.order),i}_filterFields(e,t){var r;return e&&cT(r=we(t)?t:Be(t)).call(r,(i,o)=>(i[o]=e[o],i),{})}_sort(e,t){if(typeof t=="string"){const r=t;mi(e).call(e,(i,o)=>{const s=i[r],a=o[r];return s>a?1:s<a?-1:0})}else if(typeof t=="function")mi(e).call(e,t);else throw new TypeError("Order must be a function or a string")}remove(e,t){const r=[],i=[],o=we(e)?e:[e];for(let s=0,a=o.length;s<a;s++){const g=this._remove(o[s]);if(g){const A=g[this._idProp];A!=null&&(r.push(A),i.push(g))}}return r.length&&this._trigger("remove",{items:r,oldData:i},t),r}_remove(e){let t;if(gk(e)?t=e:e&&typeof e=="object"&&(t=e[this._idProp]),t!=null&&this._data.has(t)){const r=this._data.get(t)||null;return this._data.delete(t),--this.length,r}return null}clear(e){var t;const r=[...Bo(t=this._data).call(t)],i=[];for(let o=0,s=r.length;o<s;o++)i.push(this._data.get(r[o]));return this._data.clear(),this.length=0,this._trigger("remove",{items:r,oldData:i},e),r}max(e){let t=null,r=null;for(const o of LA(i=this._data).call(i)){var i;const s=o[e];typeof s=="number"&&(r==null||s>r)&&(t=o,r=s)}return t||null}min(e){let t=null,r=null;for(const o of LA(i=this._data).call(i)){var i;const s=o[e];typeof s=="number"&&(r==null||s<r)&&(t=o,r=s)}return t||null}distinct(e){const t=this._data,r=[...Bo(t).call(t)],i=[];let o=0;for(let s=0,a=r.length;s<a;s++){const g=r[s],I=t.get(g)[e];let C=!1;for(let l=0;l<o;l++)if(i[l]==I){C=!0;break}!C&&I!==void 0&&(i[o]=I,o++)}return i}_addItem(e){const t=nIe(e,this._idProp),r=t[this._idProp];if(this._data.has(r))throw new Error("Cannot add item: item with id "+r+" already exists");return this._data.set(r,t),++this.length,r}_updateItem(e){const t=e[this._idProp];if(t==null)throw new Error("Cannot update item: item has no id (item: "+ks(e)+")");const r=this._data.get(t);if(!r)throw new Error("Cannot update item: no item with id "+t+" found");return this._data.set(t,ak(ak({},r),e)),t}stream(e){if(e){const r=this._data;return new Ak({*[Ho](){for(const i of e){const o=r.get(i);o!=null&&(yield[i,o])}}})}else{var t;return new Ak({[Ho]:z(t=UAe(this._data)).call(t,this._data)})}}};function oIe(n,e){return typeof e=="object"&&e!==null&&n===e.idProp&&typeof e.add=="function"&&typeof e.clear=="function"&&typeof e.distinct=="function"&&typeof be(e)=="function"&&typeof e.get=="function"&&typeof e.getDataSet=="function"&&typeof e.getIds=="function"&&typeof e.length=="number"&&typeof Mt(e)=="function"&&typeof e.max=="function"&&typeof e.min=="function"&&typeof e.off=="function"&&typeof e.on=="function"&&typeof e.remove=="function"&&typeof e.setOptions=="function"&&typeof e.stream=="function"&&typeof e.update=="function"&&typeof e.updateOnly=="function"}function I7(n,e){return typeof e=="object"&&e!==null&&n===e.idProp&&typeof be(e)=="function"&&typeof e.get=="function"&&typeof e.getDataSet=="function"&&typeof e.getIds=="function"&&typeof e.length=="number"&&typeof Mt(e)=="function"&&typeof e.off=="function"&&typeof e.on=="function"&&typeof e.stream=="function"&&oIe(n,e.getDataSet())}var Ik={},If,Ck;function sIe(){if(Ck)return If;Ck=1;var n=Le(),e=ce(),t=me(),r=yr(),i=gQ().trim,o=tT(),s=t("".charAt),a=n.parseFloat,g=n.Symbol,A=g&&g.iterator,I=1/a(o+"-0")!==-1/0||A&&!e(function(){a(Object(A))});return If=I?function(l){var d=i(r(l)),u=a(d);return u===0&&s(d,0)==="-"?-0:u}:a,If}var lk;function aIe(){if(lk)return Ik;lk=1;var n=ee(),e=sIe();return n({global:!0,forced:parseFloat!==e},{parseFloat:e}),Ik}var Cf,dk;function gIe(){if(dk)return Cf;dk=1,aIe();var n=Ee();return Cf=n.parseFloat,Cf}var lf,uk;function AIe(){if(uk)return lf;uk=1;var n=gIe();return lf=n,lf}var df,hk;function IIe(){return hk||(hk=1,df=AIe()),df}var CIe=IIe(),C7=ne(CIe),ck={},fk;function lIe(){if(fk)return ck;fk=1;var n=ee(),e=ce(),t=YO().f,r=e(function(){return!Object.getOwnPropertyNames(1)});return n({target:"Object",stat:!0,forced:r},{getOwnPropertyNames:t}),ck}var uf,pk;function dIe(){if(pk)return uf;pk=1,lIe();var n=Ee(),e=n.Object;return uf=function(r){return e.getOwnPropertyNames(r)},uf}var hf,vk;function uIe(){if(vk)return hf;vk=1;var n=dIe();return hf=n,hf}var cf,mk;function hIe(){return mk||(mk=1,cf=uIe()),cf}var cIe=hIe(),fIe=ne(cIe);function pT(n,e){const t=["node","edge","label"];let r=!0;const i=Yi(e,"chosen");if(typeof i=="boolean")r=i;else if(typeof i=="object"){if(_e(t).call(t,n)===-1)throw new Error("choosify: subOption '"+n+"' should be one of '"+t.join("', '")+"'");const o=Yi(e,["chosen",n]);(typeof o=="boolean"||typeof o=="function")&&(r=o)}return r}function fO(n,e,t){if(n.width<=0||n.height<=0)return!1;if(t!==void 0){const o={x:e.x-t.x,y:e.y-t.y};if(t.angle!==0){const s=-t.angle;e={x:Math.cos(s)*o.x-Math.sin(s)*o.y,y:Math.sin(s)*o.x+Math.cos(s)*o.y}}else e=o}const r=n.x+n.width,i=n.y+n.width;return n.left<e.x&&r>e.x&&n.top<e.y&&i>e.y}function GA(n){return typeof n=="string"&&n!==""}function l7(n,e,t,r){let i=r.x,o=r.y;if(typeof r.distanceToBorder=="function"){const s=r.distanceToBorder(n,e),a=Math.sin(e)*s,g=Math.cos(e)*s;g===s?(i+=s,o=r.y):a===s?(i=r.x,o-=s):(i+=g,o-=a)}else r.shape.width>r.shape.height?(i=r.x+r.shape.width*.5,o=r.y-t):(i=r.x+t,o=r.y-r.shape.height*.5);return{x:i,y:o}}let pIe=class{constructor(e){this.measureText=e,this.current=0,this.width=0,this.height=0,this.lines=[]}_add(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:"normal";this.lines[e]===void 0&&(this.lines[e]={width:0,height:0,blocks:[]});let i=t;(t===void 0||t==="")&&(i=" ");const o=this.measureText(i,r),s=tt({},LA(o));s.text=t,s.width=o.width,s.mod=r,(t===void 0||t==="")&&(s.width=0),this.lines[e].blocks.push(s),this.lines[e].width+=s.width}curWidth(){const e=this.lines[this.current];return e===void 0?0:e.width}append(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"normal";this._add(this.current,e,t)}newLine(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"normal";this._add(this.current,e,t),this.current++}determineLineHeights(){for(let e=0;e<this.lines.length;e++){const t=this.lines[e];let r=0;if(t.blocks!==void 0)for(let i=0;i<t.blocks.length;i++){const o=t.blocks[i];r<o.height&&(r=o.height)}t.height=r}}determineLabelSize(){let e=0,t=0;for(let r=0;r<this.lines.length;r++){const i=this.lines[r];i.width>e&&(e=i.width),t+=i.height}this.width=e,this.height=t}removeEmptyBlocks(){const e=[];for(let t=0;t<this.lines.length;t++){const r=this.lines[t];if(r.blocks.length===0||t===this.lines.length-1&&r.width===0)continue;const i={};tt(i,r),i.blocks=[];let o;const s=[];for(let a=0;a<r.blocks.length;a++){const g=r.blocks[a];g.width!==0?s.push(g):o===void 0&&(o=g)}s.length===0&&o!==void 0&&s.push(o),i.blocks=s,e.push(i)}return e}finalize(){this.determineLineHeights(),this.determineLabelSize();const e=this.removeEmptyBlocks();return{width:this.width,height:this.height,lines:e}}};const vIe={"<b>":/<b>/,"<i>":/<i>/,"<code>":/<code>/,"</b>":/<\/b>/,"</i>":/<\/i>/,"</code>":/<\/code>/,"*":/\*/,_:/_/,"`":/`/,afterBold:/[^*]/,afterItal:/[^_]/,afterMono:/[^`]/};let yk=class{constructor(e){this.text=e,this.bold=!1,this.ital=!1,this.mono=!1,this.spacing=!1,this.position=0,this.buffer="",this.modStack=[],this.blocks=[]}mod(){return this.modStack.length===0?"normal":this.modStack[0]}modName(){if(this.modStack.length===0)return"normal";if(this.modStack[0]==="mono")return"mono";if(this.bold&&this.ital)return"boldital";if(this.bold)return"bold";if(this.ital)return"ital"}emitBlock(){this.spacing&&(this.add(" "),this.spacing=!1),this.buffer.length>0&&(this.blocks.push({text:this.buffer,mod:this.modName()}),this.buffer="")}add(e){e===" "&&(this.spacing=!0),this.spacing&&(this.buffer+=" ",this.spacing=!1),e!=" "&&(this.buffer+=e)}parseWS(e){return/[ \t]/.test(e)?(this.mono?this.add(e):this.spacing=!0,!0):!1}setTag(e){this.emitBlock(),this[e]=!0,this.modStack.unshift(e)}unsetTag(e){this.emitBlock(),this[e]=!1,this.modStack.shift()}parseStartTag(e,t){return!this.mono&&!this[e]&&this.match(t)?(this.setTag(e),!0):!1}match(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;const[r,i]=this.prepareRegExp(e),o=r.test(this.text.substr(this.position,i));return o&&t&&(this.position+=i-1),o}parseEndTag(e,t,r){let i=this.mod()===e;return e==="mono"?i=i&&this.mono:i=i&&!this.mono,i&&this.match(t)?(r!==void 0?(this.position===this.text.length-1||this.match(r,!1))&&this.unsetTag(e):this.unsetTag(e),!0):!1}replace(e,t){return this.match(e)?(this.add(t),this.position+=length-1,!0):!1}prepareRegExp(e){let t,r;if(e instanceof RegExp)r=e,t=1;else{const i=vIe[e];i!==void 0?r=i:r=new RegExp(e),t=e.length}return[r,t]}},mIe=class{constructor(e,t,r,i){this.ctx=e,this.parent=t,this.selected=r,this.hover=i;const o=(s,a)=>{if(s===void 0)return 0;const g=this.parent.getFormattingValues(e,r,i,a);let A=0;return s!==""&&(A=this.ctx.measureText(s).width),{width:A,values:g}};this.lines=new pIe(o)}process(e){if(!GA(e))return this.lines.finalize();const t=this.parent.fontOptions;e=e.replace(/\r\n/g,`
935
935
  `),e=e.replace(/\r/g,`
936
936
  `);const r=String(e).split(`
937
- `),i=r.length;if(t.multi)for(let o=0;o<i;o++){const s=this.splitBlocks(r[o],t.multi);if(s!==void 0){if(s.length===0){this.lines.newLine("");continue}if(t.maxWdt>0)for(let a=0;a<s.length;a++){const g=s[a].mod,A=s[a].text;this.splitStringIntoLines(A,g,!0)}else for(let a=0;a<s.length;a++){const g=s[a].mod,A=s[a].text;this.lines.append(A,g)}this.lines.newLine()}}else if(t.maxWdt>0)for(let o=0;o<i;o++)this.splitStringIntoLines(r[o]);else for(let o=0;o<i;o++)this.lines.newLine(r[o]);return this.lines.finalize()}decodeMarkupSystem(e){let t="none";return e==="markdown"||e==="md"?t="markdown":(e===!0||e==="html")&&(t="html"),t}splitHtmlBlocks(e){const t=new yk(e),r=i=>/&/.test(i)?(t.replace(t.text,"&lt;","<")||t.replace(t.text,"&amp;","&")||t.add("&"),!0):!1;for(;t.position<t.text.length;){const i=t.text.charAt(t.position);t.parseWS(i)||/</.test(i)&&(t.parseStartTag("bold","<b>")||t.parseStartTag("ital","<i>")||t.parseStartTag("mono","<code>")||t.parseEndTag("bold","</b>")||t.parseEndTag("ital","</i>")||t.parseEndTag("mono","</code>"))||r(i)||t.add(i),t.position++}return t.emitBlock(),t.blocks}splitMarkdownBlocks(e){const t=new yk(e);let r=!0;const i=o=>/\\/.test(o)?(t.position<this.text.length+1&&(t.position++,o=this.text.charAt(t.position),/ \t/.test(o)?t.spacing=!0:(t.add(o),r=!1)),!0):!1;for(;t.position<t.text.length;){const o=t.text.charAt(t.position);t.parseWS(o)||i(o)||(r||t.spacing)&&(t.parseStartTag("bold","*")||t.parseStartTag("ital","_")||t.parseStartTag("mono","`"))||t.parseEndTag("bold","*","afterBold")||t.parseEndTag("ital","_","afterItal")||t.parseEndTag("mono","`","afterMono")||(t.add(o),r=!1),t.position++}return t.emitBlock(),t.blocks}splitBlocks(e,t){const r=this.decodeMarkupSystem(t);if(r==="none")return[{text:e,mod:"normal"}];if(r==="markdown")return this.splitMarkdownBlocks(e);if(r==="html")return this.splitHtmlBlocks(e)}overMaxWidth(e){const t=this.ctx.measureText(e).width;return this.lines.curWidth()+t>this.parent.fontOptions.maxWdt}getLongestFit(e){let t="",r=0;for(;r<e.length;){const o=t+(t===""?"":" ")+e[r];if(this.overMaxWidth(o))break;t=o,r++}return r}getLongestFitWord(e){let t=0;for(;t<e.length&&!this.overMaxWidth(zr(e).call(e,0,t));)t++;return t}splitStringIntoLines(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"normal",r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;this.parent.getFormattingValues(this.ctx,this.selected,this.hover,t),e=e.replace(/^( +)/g,"$1\r"),e=e.replace(/([^\r][^ ]*)( +)/g,"$1\r$2\r");let i=e.split("\r");for(;i.length>0;){let o=this.getLongestFit(i);if(o===0){const s=i[0],a=this.getLongestFitWord(s);this.lines.newLine(zr(s).call(s,0,a),t),i[0]=zr(s).call(s,a)}else{let s=o;i[o-1]===" "?o--:i[s]===" "&&s++;const a=zr(i).call(i,0,o).join("");o==i.length&&r?this.lines.append(a,t):this.lines.newLine(a,t),i=zr(i).call(i,s)}}}};const ya=["bold","ital","boldital","mono"];let d7=class _A{constructor(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;this.body=e,this.pointToSelf=!1,this.baseSize=void 0,this.fontOptions={},this.setOptions(t),this.size={top:0,left:0,width:0,height:0,yLine:0},this.isEdgeLabel=r}setOptions(e){if(this.elementOptions=e,this.initFontOptions(e.font),GA(e.label)?this.labelDirty=!0:e.label=void 0,e.font!==void 0&&e.font!==null){if(typeof e.font=="string")this.baseSize=this.fontOptions.size;else if(typeof e.font=="object"){const t=e.font.size;t!==void 0&&(this.baseSize=t)}}}initFontOptions(e){if(de(ya,t=>{this.fontOptions[t]={}}),_A.parseFontString(this.fontOptions,e)){this.fontOptions.vadjust=0;return}de(e,(t,r)=>{t!=null&&typeof t!="object"&&(this.fontOptions[r]=t)})}static parseFontString(e,t){if(!t||typeof t!="string")return!1;const r=t.split(" ");return e.size=+r[0].replace("px",""),e.face=r[1],e.color=r[2],!0}constrain(e){const t={constrainWidth:!1,maxWdt:-1,minWdt:-1,constrainHeight:!1,minHgt:-1,valign:"middle"},r=Yi(e,"widthConstraint");if(typeof r=="number")t.maxWdt=Number(r),t.minWdt=Number(r);else if(typeof r=="object"){const o=Yi(e,["widthConstraint","maximum"]);typeof o=="number"&&(t.maxWdt=Number(o));const s=Yi(e,["widthConstraint","minimum"]);typeof s=="number"&&(t.minWdt=Number(s))}const i=Yi(e,"heightConstraint");if(typeof i=="number")t.minHgt=Number(i);else if(typeof i=="object"){const o=Yi(e,["heightConstraint","minimum"]);typeof o=="number"&&(t.minHgt=Number(o));const s=Yi(e,["heightConstraint","valign"]);typeof s=="string"&&(s==="top"||s==="bottom")&&(t.valign=s)}return t}update(e,t){this.setOptions(e,!0),this.propagateFonts(t),Me(this.fontOptions,this.constrain(t)),this.fontOptions.chooser=pT("label",t)}adjustSizes(e){const t=e?e.right+e.left:0;this.fontOptions.constrainWidth&&(this.fontOptions.maxWdt-=t,this.fontOptions.minWdt-=t);const r=e?e.top+e.bottom:0;this.fontOptions.constrainHeight&&(this.fontOptions.minHgt-=r)}addFontOptionsToPile(e,t){for(let r=0;r<t.length;++r)this.addFontToPile(e,t[r])}addFontToPile(e,t){if(t===void 0||t.font===void 0||t.font===null)return;const r=t.font;e.push(r)}getBasicOptions(e){const t={};for(let r=0;r<e.length;++r){let i=e[r];const o={};_A.parseFontString(o,i)&&(i=o),de(i,(s,a)=>{s!==void 0&&(Object.prototype.hasOwnProperty.call(t,a)||(_e(ya).call(ya,a)!==-1?t[a]={}:t[a]=s))})}return t}getFontOption(e,t,r){let i;for(let o=0;o<e.length;++o){const s=e[o];if(Object.prototype.hasOwnProperty.call(s,t)){if(i=s[t],i==null)continue;const a={};if(_A.parseFontString(a,i)&&(i=a),Object.prototype.hasOwnProperty.call(i,r))return i[r]}}if(Object.prototype.hasOwnProperty.call(this.fontOptions,r))return this.fontOptions[r];throw new Error("Did not find value for multi-font for property: '"+r+"'")}getFontOptions(e,t){const r={},i=["color","size","face","mod","vadjust"];for(let o=0;o<i.length;++o){const s=i[o];r[s]=this.getFontOption(e,t,s)}return r}propagateFonts(e){const t=[];this.addFontOptionsToPile(t,e),this.fontOptions=this.getBasicOptions(t);for(let r=0;r<ya.length;++r){const i=ya[r],o=this.fontOptions[i],s=this.getFontOptions(t,i);de(s,(a,g)=>{o[g]=a}),o.size=Number(o.size),o.vadjust=Number(o.vadjust)}}draw(e,t,r,i,o){let s=arguments.length>5&&arguments[5]!==void 0?arguments[5]:"middle";if(this.elementOptions.label===void 0)return;let a=this.fontOptions.size*this.body.view.scale;this.elementOptions.label&&a<this.elementOptions.scaling.label.drawThreshold-1||(a>=this.elementOptions.scaling.label.maxVisible&&(a=Number(this.elementOptions.scaling.label.maxVisible)/this.body.view.scale),this.calculateLabelSize(e,i,o,t,r,s),this._drawBackground(e),this._drawText(e,t,this.size.yLine,s,a))}_drawBackground(e){if(this.fontOptions.background!==void 0&&this.fontOptions.background!=="none"){e.fillStyle=this.fontOptions.background;const t=this.getSize();e.fillRect(t.left,t.top,t.width,t.height)}}_drawText(e,t,r){let i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:"middle",o=arguments.length>4?arguments[4]:void 0;[t,r]=this._setAlignment(e,t,r,i),e.textAlign="left",t=t-this.size.width/2,this.fontOptions.valign&&this.size.height>this.size.labelHeight&&(this.fontOptions.valign==="top"&&(r-=(this.size.height-this.size.labelHeight)/2),this.fontOptions.valign==="bottom"&&(r+=(this.size.height-this.size.labelHeight)/2));for(let s=0;s<this.lineCount;s++){const a=this.lines[s];if(a&&a.blocks){let g=0;this.isEdgeLabel||this.fontOptions.align==="center"?g+=(this.size.width-a.width)/2:this.fontOptions.align==="right"&&(g+=this.size.width-a.width);for(let A=0;A<a.blocks.length;A++){const I=a.blocks[A];e.font=I.font;const[C,l]=this._getColor(I.color,o,I.strokeColor);I.strokeWidth>0&&(e.lineWidth=I.strokeWidth,e.strokeStyle=l,e.lineJoin="round"),e.fillStyle=C,I.strokeWidth>0&&e.strokeText(I.text,t+g,r+I.vadjust),e.fillText(I.text,t+g,r+I.vadjust),g+=I.width}r+=a.height}}}_setAlignment(e,t,r,i){if(this.isEdgeLabel&&this.fontOptions.align!=="horizontal"&&this.pointToSelf===!1){t=0,r=0;const o=2;this.fontOptions.align==="top"?(e.textBaseline="alphabetic",r-=2*o):this.fontOptions.align==="bottom"?(e.textBaseline="hanging",r+=2*o):e.textBaseline="middle"}else e.textBaseline=i;return[t,r]}_getColor(e,t,r){let i=e||"#000000",o=r||"#ffffff";if(t<=this.elementOptions.scaling.label.drawThreshold){const s=Math.max(0,Math.min(1,1-(this.elementOptions.scaling.label.drawThreshold-t)));i=hr(i,s),o=hr(o,s)}return[i,o]}getTextSize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;return this._processLabel(e,t,r),{width:this.size.width,height:this.size.height,lineCount:this.lineCount}}getSize(){let t=this.size.left,r=this.size.top-.5*2;if(this.isEdgeLabel){const o=-this.size.width*.5;switch(this.fontOptions.align){case"middle":t=o,r=-this.size.height*.5;break;case"top":t=o,r=-(this.size.height+2);break;case"bottom":t=o,r=2;break}}return{left:t,top:r,width:this.size.width,height:this.size.height}}calculateLabelSize(e,t,r){let i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0,o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:0,s=arguments.length>5&&arguments[5]!==void 0?arguments[5]:"middle";this._processLabel(e,t,r),this.size.left=i-this.size.width*.5,this.size.top=o-this.size.height*.5,this.size.yLine=o+(1-this.lineCount)*.5*this.fontOptions.size,s==="hanging"&&(this.size.top+=.5*this.fontOptions.size,this.size.top+=4,this.size.yLine+=4)}getFormattingValues(e,t,r,i){const o=function(g,A,I){return A==="normal"?I==="mod"?"":g[I]:g[A][I]!==void 0?g[A][I]:g[I]},s={color:o(this.fontOptions,i,"color"),size:o(this.fontOptions,i,"size"),face:o(this.fontOptions,i,"face"),mod:o(this.fontOptions,i,"mod"),vadjust:o(this.fontOptions,i,"vadjust"),strokeWidth:this.fontOptions.strokeWidth,strokeColor:this.fontOptions.strokeColor};(t||r)&&(i==="normal"&&this.fontOptions.chooser===!0&&this.elementOptions.labelHighlightBold?s.mod="bold":typeof this.fontOptions.chooser=="function"&&this.fontOptions.chooser(s,this.elementOptions.id,t,r));let a="";return s.mod!==void 0&&s.mod!==""&&(a+=s.mod+" "),a+=s.size+"px "+s.face,e.font=a.replace(/"/g,""),s.font=e.font,s.height=s.size,s}differentState(e,t){return e!==this.selectedState||t!==this.hoverState}_processLabelText(e,t,r,i){return new mIe(e,this,t,r).process(i)}_processLabel(e,t,r){if(this.labelDirty===!1&&!this.differentState(t,r))return;const i=this._processLabelText(e,t,r,this.elementOptions.label);this.fontOptions.minWdt>0&&i.width<this.fontOptions.minWdt&&(i.width=this.fontOptions.minWdt),this.size.labelHeight=i.height,this.fontOptions.minHgt>0&&i.height<this.fontOptions.minHgt&&(i.height=this.fontOptions.minHgt),this.lines=i.lines,this.lineCount=i.lines.length,this.size.width=i.width,this.size.height=i.height,this.selectedState=t,this.hoverState=r,this.labelDirty=!1}visible(){return!(this.size.width===0||this.size.height===0||this.elementOptions.label===void 0||this.fontOptions.size*this.body.view.scale<this.elementOptions.scaling.label.drawThreshold-1)}},po=class{constructor(e,t,r){this.body=t,this.labelModule=r,this.setOptions(e),this.top=void 0,this.left=void 0,this.height=void 0,this.width=void 0,this.radius=void 0,this.margin=void 0,this.refreshNeeded=!0,this.boundingBox={top:0,left:0,right:0,bottom:0}}setOptions(e){this.options=e}_setMargins(e){this.margin={},this.options.margin&&(typeof this.options.margin=="object"?(this.margin.top=this.options.margin.top,this.margin.right=this.options.margin.right,this.margin.bottom=this.options.margin.bottom,this.margin.left=this.options.margin.left):(this.margin.top=this.options.margin,this.margin.right=this.options.margin,this.margin.bottom=this.options.margin,this.margin.left=this.options.margin)),e.adjustSizes(this.margin)}_distanceToBorder(e,t){const r=this.options.borderWidth;return e&&this.resize(e),Math.min(Math.abs(this.width/2/Math.cos(t)),Math.abs(this.height/2/Math.sin(t)))+r}enableShadow(e,t){t.shadow&&(e.shadowColor=t.shadowColor,e.shadowBlur=t.shadowSize,e.shadowOffsetX=t.shadowX,e.shadowOffsetY=t.shadowY)}disableShadow(e,t){t.shadow&&(e.shadowColor="rgba(0,0,0,0)",e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0)}enableBorderDashes(e,t){if(t.borderDashes!==!1)if(e.setLineDash!==void 0){let r=t.borderDashes;r===!0&&(r=[5,15]),e.setLineDash(r)}else console.warn("setLineDash is not supported in this browser. The dashed borders cannot be used."),this.options.shapeProperties.borderDashes=!1,t.borderDashes=!1}disableBorderDashes(e,t){t.borderDashes!==!1&&(e.setLineDash!==void 0?e.setLineDash([0]):(console.warn("setLineDash is not supported in this browser. The dashed borders cannot be used."),this.options.shapeProperties.borderDashes=!1,t.borderDashes=!1))}needsRefresh(e,t){return this.refreshNeeded===!0?(this.refreshNeeded=!1,!0):this.width===void 0||this.labelModule.differentState(e,t)}initContextForDraw(e,t){const r=t.borderWidth/this.body.view.scale;e.lineWidth=Math.min(this.width,r),e.strokeStyle=t.borderColor,e.fillStyle=t.color}performStroke(e,t){const r=t.borderWidth/this.body.view.scale;e.save(),r>0&&(this.enableBorderDashes(e,t),e.stroke(),this.disableBorderDashes(e,t)),e.restore()}performFill(e,t){e.save(),e.fillStyle=t.color,this.enableShadow(e,t),cg(e).call(e),this.disableShadow(e,t),e.restore(),this.performStroke(e,t)}_addBoundingBoxMargin(e){this.boundingBox.left-=e,this.boundingBox.top-=e,this.boundingBox.bottom+=e,this.boundingBox.right+=e}_updateBoundingBox(e,t,r,i,o){r!==void 0&&this.resize(r,i,o),this.left=e-this.width/2,this.top=t-this.height/2,this.boundingBox.left=this.left,this.boundingBox.top=this.top,this.boundingBox.bottom=this.top+this.height,this.boundingBox.right=this.left+this.width}updateBoundingBox(e,t,r,i,o){this._updateBoundingBox(e,t,r,i,o)}getDimensionsFromLabel(e,t,r){this.textSize=this.labelModule.getTextSize(e,t,r);let i=this.textSize.width,o=this.textSize.height;const s=14;return i===0&&(i=s,o=s),{width:i,height:o}}},yIe=class extends po{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.needsRefresh(t,r)){const i=this.getDimensionsFromLabel(e,t,r);this.width=i.width+this.margin.right+this.margin.left,this.height=i.height+this.margin.top+this.margin.bottom,this.radius=this.width/2}}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width/2,this.top=r-this.height/2,this.initContextForDraw(e,s),zX(e,this.left,this.top,this.width,this.height,s.borderRadius),this.performFill(e,s),this.updateBoundingBox(t,r,e,i,o),this.labelModule.draw(e,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,i,o)}updateBoundingBox(e,t,r,i,o){this._updateBoundingBox(e,t,r,i,o);const s=this.options.shapeProperties.borderRadius;this._addBoundingBoxMargin(s)}distanceToBorder(e,t){e&&this.resize(e);const r=this.options.borderWidth;return Math.min(Math.abs(this.width/2/Math.cos(t)),Math.abs(this.height/2/Math.sin(t)))+r}},vT=class extends po{constructor(e,t,r){super(e,t,r),this.labelOffset=0,this.selected=!1}setOptions(e,t,r){this.options=e,t===void 0&&r===void 0||this.setImages(t,r)}setImages(e,t){t&&this.selected?(this.imageObj=t,this.imageObjAlt=e):(this.imageObj=e,this.imageObjAlt=t)}switchImages(e){const t=e&&!this.selected||!e&&this.selected;if(this.selected=e,this.imageObjAlt!==void 0&&t){const r=this.imageObj;this.imageObj=this.imageObjAlt,this.imageObjAlt=r}}_getImagePadding(){const e={top:0,right:0,bottom:0,left:0};if(this.options.imagePadding){const t=this.options.imagePadding;typeof t=="object"?(e.top=t.top,e.right=t.right,e.bottom=t.bottom,e.left=t.left):(e.top=t,e.right=t,e.bottom=t,e.left=t)}return e}_resizeImage(){let e,t;if(this.options.shapeProperties.useImageSize===!1){let r=1,i=1;this.imageObj.width&&this.imageObj.height&&(this.imageObj.width>this.imageObj.height?r=this.imageObj.width/this.imageObj.height:i=this.imageObj.height/this.imageObj.width),e=this.options.size*2*r,t=this.options.size*2*i}else{const r=this._getImagePadding();e=this.imageObj.width+r.left+r.right,t=this.imageObj.height+r.top+r.bottom}this.width=e,this.height=t,this.radius=.5*this.width}_drawRawCircle(e,t,r,i){this.initContextForDraw(e,i),ZO(e,t,r,i.size),this.performFill(e,i)}_drawImageAtPosition(e,t){if(this.imageObj.width!=0){e.globalAlpha=t.opacity!==void 0?t.opacity:1,this.enableShadow(e,t);let r=1;this.options.shapeProperties.interpolation===!0&&(r=this.imageObj.width/this.width/this.body.view.scale);const i=this._getImagePadding(),o=this.left+i.left,s=this.top+i.top,a=this.width-i.left-i.right,g=this.height-i.top-i.bottom;this.imageObj.drawImageAtPosition(e,r,o,s,a,g),this.disableShadow(e,t)}}_drawImageLabel(e,t,r,i,o){let s=0;if(this.height!==void 0){s=this.height*.5;const g=this.labelModule.getTextSize(e,i,o);g.lineCount>=1&&(s+=g.height/2)}const a=r+s;this.options.label&&(this.labelOffset=s),this.labelModule.draw(e,t,a,i,o,"hanging")}},bIe=class extends vT{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.needsRefresh(t,r)){const i=this.getDimensionsFromLabel(e,t,r),o=Math.max(i.width+this.margin.right+this.margin.left,i.height+this.margin.top+this.margin.bottom);this.options.size=o/2,this.width=o,this.height=o,this.radius=this.width/2}}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width/2,this.top=r-this.height/2,this._drawRawCircle(e,t,r,s),this.updateBoundingBox(t,r),this.labelModule.draw(e,this.left+this.textSize.width/2+this.margin.left,r,i,o)}updateBoundingBox(e,t){this.boundingBox.top=t-this.options.size,this.boundingBox.left=e-this.options.size,this.boundingBox.right=e+this.options.size,this.boundingBox.bottom=t+this.options.size}distanceToBorder(e){return e&&this.resize(e),this.width*.5}},wIe=class extends vT{constructor(e,t,r,i,o){super(e,t,r),this.setImages(i,o)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.imageObj.src===void 0||this.imageObj.width===void 0||this.imageObj.height===void 0){const o=this.options.size*2;this.width=o,this.height=o,this.radius=.5*this.width;return}this.needsRefresh(t,r)&&this._resizeImage()}draw(e,t,r,i,o,s){this.switchImages(i),this.resize();let a=t,g=r;this.options.shapeProperties.coordinateOrigin==="top-left"?(this.left=t,this.top=r,a+=this.width/2,g+=this.height/2):(this.left=t-this.width/2,this.top=r-this.height/2),this._drawRawCircle(e,a,g,s),e.save(),e.clip(),this._drawImageAtPosition(e,s),e.restore(),this._drawImageLabel(e,a,g,i,o),this.updateBoundingBox(t,r)}updateBoundingBox(e,t){this.options.shapeProperties.coordinateOrigin==="top-left"?(this.boundingBox.top=t,this.boundingBox.left=e,this.boundingBox.right=e+this.options.size*2,this.boundingBox.bottom=t+this.options.size*2):(this.boundingBox.top=t-this.options.size,this.boundingBox.left=e-this.options.size,this.boundingBox.right=e+this.options.size,this.boundingBox.bottom=t+this.options.size),this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left),this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width),this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelOffset)}distanceToBorder(e){return e&&this.resize(e),this.width*.5}},vn=class extends po{constructor(e,t,r){super(e,t,r)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover,i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:{size:this.options.size};if(this.needsRefresh(t,r)){var o,s;this.labelModule.getTextSize(e,t,r);const a=2*i.size;this.width=(o=this.customSizeWidth)!==null&&o!==void 0?o:a,this.height=(s=this.customSizeHeight)!==null&&s!==void 0?s:a,this.radius=.5*this.width}}_drawShape(e,t,r,i,o,s,a,g){return this.resize(e,s,a,g),this.left=i-this.width/2,this.top=o-this.height/2,this.initContextForDraw(e,g),wre(t)(e,i,o,g.size),this.performFill(e,g),this.options.icon!==void 0&&this.options.icon.code!==void 0&&(e.font=(s?"bold ":"")+this.height/2+"px "+(this.options.icon.face||"FontAwesome"),e.fillStyle=this.options.icon.color||"black",e.textAlign="center",e.textBaseline="middle",e.fillText(this.options.icon.code,i,o)),{drawExternalLabel:()=>{if(this.options.label!==void 0){this.labelModule.calculateLabelSize(e,s,a,i,o,"hanging");const A=o+.5*this.height+.5*this.labelModule.size.height;this.labelModule.draw(e,i,A,s,a,"hanging")}this.updateBoundingBox(i,o)}}}updateBoundingBox(e,t){this.boundingBox.top=t-this.options.size,this.boundingBox.left=e-this.options.size,this.boundingBox.right=e+this.options.size,this.boundingBox.bottom=t+this.options.size,this.options.label!==void 0&&this.labelModule.size.width>0&&(this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left),this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width),this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelModule.size.height))}};function bk(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function EIe(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=bk(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=bk(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}let SIe=class extends vn{constructor(e,t,r,i){super(e,t,r,i),this.ctxRenderer=i}draw(e,t,r,i,o,s){this.resize(e,i,o,s),this.left=t-this.width/2,this.top=r-this.height/2,e.save();const a=this.ctxRenderer({ctx:e,id:this.options.id,x:t,y:r,state:{selected:i,hover:o},style:EIe({},s),label:this.options.label});if(a.drawNode!=null&&a.drawNode(),e.restore(),a.drawExternalLabel){const g=a.drawExternalLabel;a.drawExternalLabel=()=>{e.save(),g(),e.restore()}}return a.nodeDimensions&&(this.customSizeWidth=a.nodeDimensions.width,this.customSizeHeight=a.nodeDimensions.height),a}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},_Ie=class extends po{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e,t,r){if(this.needsRefresh(t,r)){const o=this.getDimensionsFromLabel(e,t,r).width+this.margin.right+this.margin.left;this.width=o,this.height=o,this.radius=this.width/2}}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width/2,this.top=r-this.height/2,this.initContextForDraw(e,s),jX(e,t-this.width/2,r-this.height/2,this.width,this.height),this.performFill(e,s),this.updateBoundingBox(t,r,e,i,o),this.labelModule.draw(e,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,i,o)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},OIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"diamond",4,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},TIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"circle",2,t,r,i,o,s)}distanceToBorder(e){return e&&this.resize(e),this.options.size}},wk=class extends po{constructor(e,t,r){super(e,t,r)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.needsRefresh(t,r)){const i=this.getDimensionsFromLabel(e,t,r);this.height=i.height*2,this.width=i.width+i.height,this.radius=.5*this.width}}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width*.5,this.top=r-this.height*.5,this.initContextForDraw(e,s),sO(e,this.left,this.top,this.width,this.height),this.performFill(e,s),this.updateBoundingBox(t,r,e,i,o),this.labelModule.draw(e,t,r,i,o)}distanceToBorder(e,t){e&&this.resize(e);const r=this.width*.5,i=this.height*.5,o=Math.sin(t)*r,s=Math.cos(t)*i;return r*i/Math.sqrt(o*o+s*s)}},RIe=class extends po{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e,t,r){this.needsRefresh(t,r)&&(this.iconSize={width:Number(this.options.icon.size),height:Number(this.options.icon.size)},this.width=this.iconSize.width+this.margin.right+this.margin.left,this.height=this.iconSize.height+this.margin.top+this.margin.bottom,this.radius=.5*this.width)}draw(e,t,r,i,o,s){return this.resize(e,i,o),this.options.icon.size=this.options.icon.size||50,this.left=t-this.width/2,this.top=r-this.height/2,this._icon(e,t,r,i,o,s),{drawExternalLabel:()=>{this.options.label!==void 0&&this.labelModule.draw(e,this.left+this.iconSize.width/2+this.margin.left,r+this.height/2+5,i),this.updateBoundingBox(t,r)}}}updateBoundingBox(e,t){this.boundingBox.top=t-this.options.icon.size*.5,this.boundingBox.left=e-this.options.icon.size*.5,this.boundingBox.right=e+this.options.icon.size*.5,this.boundingBox.bottom=t+this.options.icon.size*.5,this.options.label!==void 0&&this.labelModule.size.width>0&&(this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left),this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width),this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelModule.size.height+5))}_icon(e,t,r,i,o,s){const a=Number(this.options.icon.size);this.options.icon.code!==void 0?(e.font=[this.options.icon.weight!=null?this.options.icon.weight:i?"bold":"",(this.options.icon.weight!=null&&i?5:0)+a+"px",this.options.icon.face].join(" "),e.fillStyle=this.options.icon.color||"black",e.textAlign="center",e.textBaseline="middle",this.enableShadow(e,s),e.fillText(this.options.icon.code,t,r),this.disableShadow(e,s)):console.error("When using the icon shape, you need to define the code in the icon options object. This can be done per node or globally.")}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},PIe=class extends vT{constructor(e,t,r,i,o){super(e,t,r),this.setImages(i,o)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.imageObj.src===void 0||this.imageObj.width===void 0||this.imageObj.height===void 0){const o=this.options.size*2;this.width=o,this.height=o;return}this.needsRefresh(t,r)&&this._resizeImage()}draw(e,t,r,i,o,s){e.save(),this.switchImages(i),this.resize();let a=t,g=r;if(this.options.shapeProperties.coordinateOrigin==="top-left"?(this.left=t,this.top=r,a+=this.width/2,g+=this.height/2):(this.left=t-this.width/2,this.top=r-this.height/2),this.options.shapeProperties.useBorderWithImage===!0){const A=this.options.borderWidth,I=this.options.borderWidthSelected||2*this.options.borderWidth,C=(i?I:A)/this.body.view.scale;e.lineWidth=Math.min(this.width,C),e.beginPath();let l=i?this.options.color.highlight.border:o?this.options.color.hover.border:this.options.color.border,d=i?this.options.color.highlight.background:o?this.options.color.hover.background:this.options.color.background;s.opacity!==void 0&&(l=hr(l,s.opacity),d=hr(d,s.opacity)),e.strokeStyle=l,e.fillStyle=d,e.rect(this.left-.5*e.lineWidth,this.top-.5*e.lineWidth,this.width+e.lineWidth,this.height+e.lineWidth),cg(e).call(e),this.performStroke(e,s),e.closePath()}this._drawImageAtPosition(e,s),this._drawImageLabel(e,a,g,i,o),this.updateBoundingBox(t,r),e.restore()}updateBoundingBox(e,t){this.resize(),this.options.shapeProperties.coordinateOrigin==="top-left"?(this.left=e,this.top=t):(this.left=e-this.width/2,this.top=t-this.height/2),this.boundingBox.left=this.left,this.boundingBox.top=this.top,this.boundingBox.bottom=this.top+this.height,this.boundingBox.right=this.left+this.width,this.options.label!==void 0&&this.labelModule.size.width>0&&(this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left),this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width),this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelOffset))}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},xIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"square",2,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},$Ie=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"hexagon",4,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},DIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"star",4,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},NIe=class extends po{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e,t,r){this.needsRefresh(t,r)&&(this.textSize=this.labelModule.getTextSize(e,t,r),this.width=this.textSize.width+this.margin.right+this.margin.left,this.height=this.textSize.height+this.margin.top+this.margin.bottom,this.radius=.5*this.width)}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width/2,this.top=r-this.height/2,this.enableShadow(e,s),this.labelModule.draw(e,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,i,o),this.disableShadow(e,s),this.updateBoundingBox(t,r,e,i,o)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},MIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"triangle",3,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},qIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"triangleDown",3,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}};function Ek(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function Sk(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=Ek(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=Ek(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}let sr=class qr{constructor(e,t,r,i,o,s){this.options=sn(o),this.globalOptions=o,this.defaultOptions=s,this.body=t,this.edges=[],this.id=void 0,this.imagelist=r,this.grouplist=i,this.x=void 0,this.y=void 0,this.baseSize=this.options.size,this.baseFontSize=this.options.font.size,this.predefinedPosition=!1,this.selected=!1,this.hover=!1,this.labelModule=new d7(this.body,this.options,!1),this.setOptions(e)}attachEdge(e){var t;_e(t=this.edges).call(t,e)===-1&&this.edges.push(e)}detachEdge(e){var t;const r=_e(t=this.edges).call(t,e);if(r!=-1){var i;ti(i=this.edges).call(i,r,1)}}setOptions(e){const t=this.options.shape;if(!e)return;if(typeof e.color<"u"&&(this._localColor=e.color),e.id!==void 0&&(this.id=e.id),this.id===void 0)throw new Error("Node must have an id");qr.checkMass(e,this.id),e.x!==void 0&&(e.x===null?(this.x=void 0,this.predefinedPosition=!1):(this.x=Fr(e.x),this.predefinedPosition=!0)),e.y!==void 0&&(e.y===null?(this.y=void 0,this.predefinedPosition=!1):(this.y=Fr(e.y),this.predefinedPosition=!0)),e.size!==void 0&&(this.baseSize=e.size),e.value!==void 0&&(e.value=C7(e.value)),qr.parseOptions(this.options,e,!0,this.globalOptions,this.grouplist);const r=[e,this.options,this.defaultOptions];return this.chooser=pT("node",r),this._load_images(),this.updateLabelModule(e),e.opacity!==void 0&&qr.checkOpacity(e.opacity)&&(this.options.opacity=e.opacity),this.updateShape(t),e.hidden!==void 0||e.physics!==void 0}_load_images(){if((this.options.shape==="circularImage"||this.options.shape==="image")&&this.options.image===void 0)throw new Error("Option image must be defined for node type '"+this.options.shape+"'");if(this.options.image!==void 0){if(this.imagelist===void 0)throw new Error("Internal Error: No images provided");if(typeof this.options.image=="string")this.imageObj=this.imagelist.load(this.options.image,this.options.brokenImage,this.id);else{if(this.options.image.unselected===void 0)throw new Error("No unselected image provided");this.imageObj=this.imagelist.load(this.options.image.unselected,this.options.brokenImage,this.id),this.options.image.selected!==void 0?this.imageObjAlt=this.imagelist.load(this.options.image.selected,this.options.brokenImage,this.id):this.imageObjAlt=void 0}}}static checkOpacity(e){return 0<=e&&e<=1}static checkCoordinateOrigin(e){return e===void 0||e==="center"||e==="top-left"}static updateGroupOptions(e,t,r){var i;if(r===void 0)return;const o=e.group;if(t!==void 0&&t.group!==void 0&&o!==t.group)throw new Error("updateGroupOptions: group values in options don't match.");if(!(typeof o=="number"||typeof o=="string"&&o!=""))return;const a=r.get(o);a.opacity!==void 0&&t.opacity===void 0&&(qr.checkOpacity(a.opacity)||(console.error("Invalid option for node opacity. Value must be between 0 and 1, found: "+a.opacity),a.opacity=void 0));const g=st(i=fIe(t)).call(i,A=>t[A]!=null);g.push("font"),zA(g,e,a),e.color=CO(e.color)}static parseOptions(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1,i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:{},o=arguments.length>4?arguments[4]:void 0;if(zA(["color","fixed","shadow"],e,t,r),qr.checkMass(t),e.opacity!==void 0&&(qr.checkOpacity(e.opacity)||(console.error("Invalid option for node opacity. Value must be between 0 and 1, found: "+e.opacity),e.opacity=void 0)),t.opacity!==void 0&&(qr.checkOpacity(t.opacity)||(console.error("Invalid option for node opacity. Value must be between 0 and 1, found: "+t.opacity),t.opacity=void 0)),t.shapeProperties&&!qr.checkCoordinateOrigin(t.shapeProperties.coordinateOrigin)&&console.error("Invalid option for node coordinateOrigin, found: "+t.shapeProperties.coordinateOrigin),dr(e,t,"shadow",i),t.color!==void 0&&t.color!==null){const a=CO(t.color);zQ(e.color,a)}else r===!0&&t.color===null&&(e.color=sn(i.color));t.fixed!==void 0&&t.fixed!==null&&(typeof t.fixed=="boolean"?(e.fixed.x=t.fixed,e.fixed.y=t.fixed):(t.fixed.x!==void 0&&typeof t.fixed.x=="boolean"&&(e.fixed.x=t.fixed.x),t.fixed.y!==void 0&&typeof t.fixed.y=="boolean"&&(e.fixed.y=t.fixed.y))),r===!0&&t.font===null&&(e.font=sn(i.font)),qr.updateGroupOptions(e,t,o),t.scaling!==void 0&&dr(e.scaling,t.scaling,"label",i.scaling)}getFormattingValues(){const e={color:this.options.color.background,opacity:this.options.opacity,borderWidth:this.options.borderWidth,borderColor:this.options.color.border,size:this.options.size,borderDashes:this.options.shapeProperties.borderDashes,borderRadius:this.options.shapeProperties.borderRadius,shadow:this.options.shadow.enabled,shadowColor:this.options.shadow.color,shadowSize:this.options.shadow.size,shadowX:this.options.shadow.x,shadowY:this.options.shadow.y};if(this.selected||this.hover?this.chooser===!0?this.selected?(this.options.borderWidthSelected!=null?e.borderWidth=this.options.borderWidthSelected:e.borderWidth*=2,e.color=this.options.color.highlight.background,e.borderColor=this.options.color.highlight.border,e.shadow=this.options.shadow.enabled):this.hover&&(e.color=this.options.color.hover.background,e.borderColor=this.options.color.hover.border,e.shadow=this.options.shadow.enabled):typeof this.chooser=="function"&&(this.chooser(e,this.options.id,this.selected,this.hover),e.shadow===!1&&(e.shadowColor!==this.options.shadow.color||e.shadowSize!==this.options.shadow.size||e.shadowX!==this.options.shadow.x||e.shadowY!==this.options.shadow.y)&&(e.shadow=!0)):e.shadow=this.options.shadow.enabled,this.options.opacity!==void 0){const t=this.options.opacity;e.borderColor=hr(e.borderColor,t),e.color=hr(e.color,t),e.shadowColor=hr(e.shadowColor,t)}return e}updateLabelModule(e){(this.options.label===void 0||this.options.label===null)&&(this.options.label=""),qr.updateGroupOptions(this.options,Sk(Sk({},e),{},{color:e&&e.color||this._localColor||void 0}),this.grouplist);const t=this.grouplist.get(this.options.group,!1),r=[e,this.options,t,this.globalOptions,this.defaultOptions];this.labelModule.update(this.options,r),this.labelModule.baseSize!==void 0&&(this.baseFontSize=this.labelModule.baseSize)}updateShape(e){if(e===this.options.shape&&this.shape)this.shape.setOptions(this.options,this.imageObj,this.imageObjAlt);else switch(this.options.shape){case"box":this.shape=new yIe(this.options,this.body,this.labelModule);break;case"circle":this.shape=new bIe(this.options,this.body,this.labelModule);break;case"circularImage":this.shape=new wIe(this.options,this.body,this.labelModule,this.imageObj,this.imageObjAlt);break;case"custom":this.shape=new SIe(this.options,this.body,this.labelModule,this.options.ctxRenderer);break;case"database":this.shape=new _Ie(this.options,this.body,this.labelModule);break;case"diamond":this.shape=new OIe(this.options,this.body,this.labelModule);break;case"dot":this.shape=new TIe(this.options,this.body,this.labelModule);break;case"ellipse":this.shape=new wk(this.options,this.body,this.labelModule);break;case"icon":this.shape=new RIe(this.options,this.body,this.labelModule);break;case"image":this.shape=new PIe(this.options,this.body,this.labelModule,this.imageObj,this.imageObjAlt);break;case"square":this.shape=new xIe(this.options,this.body,this.labelModule);break;case"hexagon":this.shape=new $Ie(this.options,this.body,this.labelModule);break;case"star":this.shape=new DIe(this.options,this.body,this.labelModule);break;case"text":this.shape=new NIe(this.options,this.body,this.labelModule);break;case"triangle":this.shape=new MIe(this.options,this.body,this.labelModule);break;case"triangleDown":this.shape=new qIe(this.options,this.body,this.labelModule);break;default:this.shape=new wk(this.options,this.body,this.labelModule);break}this.needsRefresh()}select(){this.selected=!0,this.needsRefresh()}unselect(){this.selected=!1,this.needsRefresh()}needsRefresh(){this.shape.refreshNeeded=!0}getTitle(){return this.options.title}distanceToBorder(e,t){return this.shape.distanceToBorder(e,t)}isFixed(){return this.options.fixed.x&&this.options.fixed.y}isSelected(){return this.selected}getValue(){return this.options.value}getLabelSize(){return this.labelModule.size()}setValueRange(e,t,r){if(this.options.value!==void 0){const i=this.options.scaling.customScalingFunction(e,t,r,this.options.value),o=this.options.scaling.max-this.options.scaling.min;if(this.options.scaling.label.enabled===!0){const s=this.options.scaling.label.max-this.options.scaling.label.min;this.options.font.size=this.options.scaling.label.min+i*s}this.options.size=this.options.scaling.min+i*o}else this.options.size=this.baseSize,this.options.font.size=this.baseFontSize;this.updateLabelModule()}draw(e){const t=this.getFormattingValues();return this.shape.draw(e,this.x,this.y,this.selected,this.hover,t)||{}}updateBoundingBox(e){this.shape.updateBoundingBox(this.x,this.y,e)}resize(e){const t=this.getFormattingValues();this.shape.resize(e,this.selected,this.hover,t)}getItemsOnPoint(e){const t=[];return this.labelModule.visible()&&fO(this.labelModule.getSize(),e)&&t.push({nodeId:this.id,labelId:0}),fO(this.shape.boundingBox,e)&&t.push({nodeId:this.id}),t}isOverlappingWith(e){return this.shape.left<e.right&&this.shape.left+this.shape.width>e.left&&this.shape.top<e.bottom&&this.shape.top+this.shape.height>e.top}isBoundingBoxOverlappingWith(e){return this.shape.boundingBox.left<e.right&&this.shape.boundingBox.right>e.left&&this.shape.boundingBox.top<e.bottom&&this.shape.boundingBox.bottom>e.top}static checkMass(e,t){if(e.mass!==void 0&&e.mass<=0){let r="";t!==void 0&&(r=" in node id: "+t),console.error("%cNegative or zero mass disallowed"+r+", setting mass to 1.",WQ),e.mass=1}}},FIe=class{constructor(e,t,r,i){var o;if(this.body=e,this.images=t,this.groups=r,this.layoutEngine=i,this.body.functions.createNode=z(o=this.create).call(o,this),this.nodesListeners={add:(s,a)=>{this.add(a.items)},update:(s,a)=>{this.update(a.items,a.data,a.oldData)},remove:(s,a)=>{this.remove(a.items)}},this.defaultOptions={borderWidth:1,borderWidthSelected:void 0,brokenImage:void 0,color:{border:"#2B7CE9",background:"#97C2FC",highlight:{border:"#2B7CE9",background:"#D2E5FF"},hover:{border:"#2B7CE9",background:"#D2E5FF"}},opacity:void 0,fixed:{x:!1,y:!1},font:{color:"#343434",size:14,face:"arial",background:"none",strokeWidth:0,strokeColor:"#ffffff",align:"center",vadjust:0,multi:!1,bold:{mod:"bold"},boldital:{mod:"bold italic"},ital:{mod:"italic"},mono:{mod:"",size:15,face:"monospace",vadjust:2}},group:void 0,hidden:!1,icon:{face:"FontAwesome",code:void 0,size:50,color:"#2B7CE9"},image:void 0,imagePadding:{top:0,right:0,bottom:0,left:0},label:void 0,labelHighlightBold:!0,level:void 0,margin:{top:5,right:5,bottom:5,left:5},mass:1,physics:!0,scaling:{min:10,max:30,label:{enabled:!1,min:14,max:30,maxVisible:30,drawThreshold:5},customScalingFunction:function(s,a,g,A){if(a===s)return .5;{const I=1/(a-s);return Math.max(0,(A-s)*I)}}},shadow:{enabled:!1,color:"rgba(0,0,0,0.5)",size:10,x:5,y:5},shape:"ellipse",shapeProperties:{borderDashes:!1,borderRadius:6,interpolation:!0,useImageSize:!1,useBorderWithImage:!1,coordinateOrigin:"center"},size:25,title:void 0,value:void 0,x:void 0,y:void 0},this.defaultOptions.mass<=0)throw"Internal error: mass in defaultOptions of NodesHandler may not be zero or negative";this.options=sn(this.defaultOptions),this.bindEventListeners()}bindEventListeners(){var e,t;this.body.emitter.on("refreshNodes",z(e=this.refresh).call(e,this)),this.body.emitter.on("refresh",z(t=this.refresh).call(t,this)),this.body.emitter.on("destroy",()=>{de(this.nodesListeners,(r,i)=>{this.body.data.nodes&&this.body.data.nodes.off(i,r)}),delete this.body.functions.createNode,delete this.nodesListeners.add,delete this.nodesListeners.update,delete this.nodesListeners.remove,delete this.nodesListeners})}setOptions(e){if(e!==void 0){if(sr.parseOptions(this.options,e),e.opacity!==void 0&&(hO(e.opacity)||!Nn(e.opacity)||e.opacity<0||e.opacity>1?console.error("Invalid option for node opacity. Value must be between 0 and 1, found: "+e.opacity):this.options.opacity=e.opacity),e.shape!==void 0)for(const t in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,t)&&this.body.nodes[t].updateShape();if(typeof e.font<"u"||typeof e.widthConstraint<"u"||typeof e.heightConstraint<"u")for(const t of Be(this.body.nodes))this.body.nodes[t].updateLabelModule(),this.body.nodes[t].needsRefresh();if(e.size!==void 0)for(const t in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,t)&&this.body.nodes[t].needsRefresh();(e.hidden!==void 0||e.physics!==void 0)&&this.body.emitter.emit("_dataChanged")}}setData(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;const r=this.body.data.nodes;if(I7("id",e))this.body.data.nodes=e;else if(we(e))this.body.data.nodes=new us,this.body.data.nodes.add(e);else if(!e)this.body.data.nodes=new us;else throw new TypeError("Array or DataSet expected");if(r&&de(this.nodesListeners,function(i,o){r.off(o,i)}),this.body.nodes={},this.body.data.nodes){const i=this;de(this.nodesListeners,function(s,a){i.body.data.nodes.on(a,s)});const o=this.body.data.nodes.getIds();this.add(o,!0)}t===!1&&this.body.emitter.emit("_dataChanged")}add(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,r;const i=[];for(let o=0;o<e.length;o++){r=e[o];const s=this.body.data.nodes.get(r),a=this.create(s);i.push(a),this.body.nodes[r]=a}this.layoutEngine.positionInitially(i),t===!1&&this.body.emitter.emit("_dataChanged")}update(e,t,r){const i=this.body.nodes;let o=!1;for(let s=0;s<e.length;s++){const a=e[s];let g=i[a];const A=t[s];g!==void 0?g.setOptions(A)&&(o=!0):(o=!0,g=this.create(A),i[a]=g)}!o&&r!==void 0&&(o=i7(t).call(t,function(s,a){const g=r[a];return g&&g.level!==s.level})),o===!0?this.body.emitter.emit("_dataChanged"):this.body.emitter.emit("_dataUpdated")}remove(e){const t=this.body.nodes;for(let r=0;r<e.length;r++){const i=e[r];delete t[i]}this.body.emitter.emit("_dataChanged")}create(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:sr;return new t(e,this.body,this.images,this.groups,this.options,this.defaultOptions)}refresh(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;de(this.body.nodes,(t,r)=>{const i=this.body.data.nodes.get(r);i!==void 0&&(e===!0&&t.setOptions({x:null,y:null}),t.setOptions({fixed:!1}),t.setOptions(i))})}getPositions(e){const t={};if(e!==void 0){if(we(e)===!0){for(let r=0;r<e.length;r++)if(this.body.nodes[e[r]]!==void 0){const i=this.body.nodes[e[r]];t[e[r]]={x:Math.round(i.x),y:Math.round(i.y)}}}else if(this.body.nodes[e]!==void 0){const r=this.body.nodes[e];t[e]={x:Math.round(r.x),y:Math.round(r.y)}}}else for(let r=0;r<this.body.nodeIndices.length;r++){const i=this.body.nodes[this.body.nodeIndices[r]];t[this.body.nodeIndices[r]]={x:Math.round(i.x),y:Math.round(i.y)}}return t}getPosition(e){if(e==null)throw new TypeError("No id was specified for getPosition method.");if(this.body.nodes[e]==null)throw new ReferenceError("NodeId provided for getPosition does not exist. Provided: ".concat(e));return{x:Math.round(this.body.nodes[e].x),y:Math.round(this.body.nodes[e].y)}}storePositions(){const e=[],t=this.body.data.nodes.getDataSet();for(const r of t.get()){const i=r.id,o=this.body.nodes[i],s=Math.round(o.x),a=Math.round(o.y);(r.x!==s||r.y!==a)&&e.push({id:i,x:s,y:a})}t.update(e)}getBoundingBox(e){if(this.body.nodes[e]!==void 0)return this.body.nodes[e].shape.boundingBox}getConnectedNodes(e,t){const r=[];if(this.body.nodes[e]!==void 0){const i=this.body.nodes[e],o={};for(let s=0;s<i.edges.length;s++){const a=i.edges[s];t!=="to"&&a.toId==i.id?o[a.fromId]===void 0&&(r.push(a.fromId),o[a.fromId]=!0):t!=="from"&&a.fromId==i.id&&o[a.toId]===void 0&&(r.push(a.toId),o[a.toId]=!0)}}return r}getConnectedEdges(e){const t=[];if(this.body.nodes[e]!==void 0){const r=this.body.nodes[e];for(let i=0;i<r.edges.length;i++)t.push(r.edges[i].id)}else console.error("NodeId provided for getConnectedEdges does not exist. Provided: ",e);return t}moveNode(e,t,r){this.body.nodes[e]!==void 0?(this.body.nodes[e].x=Number(t),this.body.nodes[e].y=Number(r),ri(()=>{this.body.emitter.emit("startSimulation")},0)):console.error("Node id supplied to moveNode does not exist. Provided: ",e)}};var _k={},Ok;function kIe(){if(Ok)return _k;Ok=1;var n=ee(),e=Math.hypot,t=Math.abs,r=Math.sqrt,i=!!e&&e(1/0,NaN)!==1/0;return n({target:"Math",stat:!0,arity:2,forced:i},{hypot:function(s,a){for(var g=0,A=0,I=arguments.length,C=0,l,d;A<I;)l=t(arguments[A++]),C<l?(d=C/l,g=g*d*d+1,C=l):l>0?(d=l/C,g+=d*d):g+=l;return C===1/0?1/0:C*r(g)}}),_k}var ff,Tk;function BIe(){if(Tk)return ff;Tk=1,kIe();var n=Ee();return ff=n.Math.hypot,ff}var pf,Rk;function zIe(){if(Rk)return pf;Rk=1;var n=BIe();return pf=n,pf}var vf,Pk;function jIe(){return Pk||(Pk=1,vf=zIe()),vf}var LIe=jIe(),GIe=ne(LIe);let rt=class{static transform(e,t){we(e)||(e=[e]);const r=t.point.x,i=t.point.y,o=t.angle,s=t.length;for(let a=0;a<e.length;++a){const g=e[a],A=g.x*Math.cos(o)-g.y*Math.sin(o),I=g.x*Math.sin(o)+g.y*Math.cos(o);g.x=r+s*A,g.y=i+s*I}}static drawPath(e,t){e.beginPath(),e.moveTo(t[0].x,t[0].y);for(let r=1;r<t.length;++r)e.lineTo(t[r].x,t[r].y);e.closePath()}},WIe=class extends rt{static draw(e,t){if(t.image){e.save(),e.translate(t.point.x,t.point.y),e.rotate(Math.PI/2+t.angle);const r=t.imageWidth!=null?t.imageWidth:t.image.width,i=t.imageHeight!=null?t.imageHeight:t.image.height;t.image.drawImageAtPosition(e,1,-r/2,0,r,i),e.restore()}return!1}},VIe=class extends rt{static draw(e,t){const r=[{x:0,y:0},{x:-1,y:.3},{x:-.9,y:0},{x:-1,y:-.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},ZIe=class{static draw(e,t){const r=[{x:-1,y:0},{x:0,y:.3},{x:-.4,y:0},{x:0,y:-.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},HIe=class{static draw(e,t){const r={x:-.4,y:0};rt.transform(r,t),e.strokeStyle=e.fillStyle,e.fillStyle="rgba(0, 0, 0, 0)";const i=Math.PI,o=t.angle-i/2,s=t.angle+i/2;return e.beginPath(),e.arc(r.x,r.y,t.length*.4,o,s,!1),e.stroke(),!0}},UIe=class{static draw(e,t){const r={x:-.3,y:0};rt.transform(r,t),e.strokeStyle=e.fillStyle,e.fillStyle="rgba(0, 0, 0, 0)";const i=Math.PI,o=t.angle+i/2,s=t.angle+3*i/2;return e.beginPath(),e.arc(r.x,r.y,t.length*.4,o,s,!1),e.stroke(),!0}},KIe=class{static draw(e,t){const r=[{x:.02,y:0},{x:-1,y:.3},{x:-1,y:-.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},YIe=class{static draw(e,t){const r=[{x:0,y:.3},{x:0,y:-.3},{x:-1,y:0}];return rt.transform(r,t),rt.drawPath(e,r),!0}},XIe=class{static draw(e,t){const r={x:-.4,y:0};return rt.transform(r,t),ZO(e,r.x,r.y,t.length*.4),!0}},QIe=class{static draw(e,t){const r=[{x:0,y:.5},{x:0,y:-.5},{x:-.15,y:-.5},{x:-.15,y:.5}];return rt.transform(r,t),rt.drawPath(e,r),!0}},JIe=class{static draw(e,t){const r=[{x:0,y:.3},{x:0,y:-.3},{x:-.6,y:-.3},{x:-.6,y:.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},eCe=class{static draw(e,t){const r=[{x:0,y:0},{x:-.5,y:-.3},{x:-1,y:0},{x:-.5,y:.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},tCe=class{static draw(e,t){const r=[{x:-1,y:.3},{x:-.5,y:0},{x:-1,y:-.3},{x:0,y:0}];return rt.transform(r,t),rt.drawPath(e,r),!0}},u7=class{static draw(e,t){let r;switch(t.type&&(r=t.type.toLowerCase()),r){case"image":return WIe.draw(e,t);case"circle":return XIe.draw(e,t);case"box":return JIe.draw(e,t);case"crow":return ZIe.draw(e,t);case"curve":return HIe.draw(e,t);case"diamond":return eCe.draw(e,t);case"inv_curve":return UIe.draw(e,t);case"triangle":return KIe.draw(e,t);case"inv_triangle":return YIe.draw(e,t);case"bar":return QIe.draw(e,t);case"vee":return tCe.draw(e,t);case"arrow":default:return VIe.draw(e,t)}}};function xk(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function $k(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=xk(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=xk(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}let h7=class{constructor(e,t,r){ze(this,"color",{}),ze(this,"colorDirty",!0),ze(this,"hoverWidth",1.5),ze(this,"selectionWidth",2),this._body=t,this._labelModule=r,this.setOptions(e),this.fromPoint=this.from,this.toPoint=this.to}connect(){this.from=this._body.nodes[this.options.from],this.to=this._body.nodes[this.options.to]}cleanup(){return!1}setOptions(e){this.options=e,this.from=this._body.nodes[this.options.from],this.to=this._body.nodes[this.options.to],this.id=this.options.id}drawLine(e,t,r,i){let o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:this.getViaNode();e.strokeStyle=this.getColor(e,t),e.lineWidth=t.width,t.dashes!==!1?this._drawDashedLine(e,t,o):this._drawLine(e,t,o)}_drawLine(e,t,r,i,o){if(this.from!=this.to)this._line(e,t,r,i,o);else{const[s,a,g]=this._getCircleData(e);this._circle(e,t,s,a,g)}}_drawDashedLine(e,t,r,i,o){e.lineCap="round";const s=we(t.dashes)?t.dashes:[5,5];if(e.setLineDash!==void 0){if(e.save(),e.setLineDash(s),e.lineDashOffset=0,this.from!=this.to)this._line(e,t,r);else{const[a,g,A]=this._getCircleData(e);this._circle(e,t,a,g,A)}e.setLineDash([0]),e.lineDashOffset=0,e.restore()}else{if(this.from!=this.to)LX(e,this.from.x,this.from.y,this.to.x,this.to.y,s);else{const[a,g,A]=this._getCircleData(e);this._circle(e,t,a,g,A)}this.enableShadow(e,t),e.stroke(),this.disableShadow(e,t)}}findBorderPosition(e,t,r){return this.from!=this.to?this._findBorderPosition(e,t,r):this._findBorderPositionCircle(e,t,r)}findBorderPositions(e){if(this.from!=this.to)return{from:this._findBorderPosition(this.from,e),to:this._findBorderPosition(this.to,e)};{var t;const[r,i]=zr(t=this._getCircleData(e)).call(t,0,2);return{from:this._findBorderPositionCircle(this.from,e,{x:r,y:i,low:.25,high:.6,direction:-1}),to:this._findBorderPositionCircle(this.from,e,{x:r,y:i,low:.6,high:.8,direction:1})}}}_getCircleData(e){const t=this.options.selfReference.size;e!==void 0&&this.from.shape.width===void 0&&this.from.shape.resize(e);const r=l7(e,this.options.selfReference.angle,t,this.from);return[r.x,r.y,t]}_pointOnCircle(e,t,r,i){const o=i*2*Math.PI;return{x:e+r*Math.cos(o),y:t-r*Math.sin(o)}}_findBorderPositionCircle(e,t,r){const i=r.x,o=r.y;let s=r.low,a=r.high;const g=r.direction,A=10,I=this.options.selfReference.size,C=.05;let l,d=(s+a)*.5,u=0;this.options.arrowStrikethrough===!0&&(g===-1?u=this.options.endPointOffset.from:g===1&&(u=this.options.endPointOffset.to));let h=0;do{d=(s+a)*.5,l=this._pointOnCircle(i,o,I,d);const v=Math.atan2(e.y-l.y,e.x-l.x),f=e.distanceToBorder(t,v)+u,c=Math.sqrt(Math.pow(l.x-e.x,2)+Math.pow(l.y-e.y,2)),b=f-c;if(Math.abs(b)<C)break;b>0?g>0?s=d:a=d:g>0?a=d:s=d,++h}while(s<=a&&h<A);return $k($k({},l),{},{t:d})}getLineWidth(e,t){return e===!0?Math.max(this.selectionWidth,.3/this._body.view.scale):t===!0?Math.max(this.hoverWidth,.3/this._body.view.scale):Math.max(this.options.width,.3/this._body.view.scale)}getColor(e,t){if(t.inheritsColor!==!1){if(t.inheritsColor==="both"&&this.from.id!==this.to.id){const r=e.createLinearGradient(this.from.x,this.from.y,this.to.x,this.to.y);let i=this.from.options.color.highlight.border,o=this.to.options.color.highlight.border;return this.from.selected===!1&&this.to.selected===!1?(i=hr(this.from.options.color.border,t.opacity),o=hr(this.to.options.color.border,t.opacity)):this.from.selected===!0&&this.to.selected===!1?o=this.to.options.color.border:this.from.selected===!1&&this.to.selected===!0&&(i=this.from.options.color.border),r.addColorStop(0,i),r.addColorStop(1,o),r}return t.inheritsColor==="to"?hr(this.to.options.color.border,t.opacity):hr(this.from.options.color.border,t.opacity)}else return hr(t.color,t.opacity)}_circle(e,t,r,i,o){this.enableShadow(e,t);let s=0,a=Math.PI*2;if(!this.options.selfReference.renderBehindTheNode){const g=this.options.selfReference.angle,A=this.options.selfReference.angle+Math.PI,I=this._findBorderPositionCircle(this.from,e,{x:r,y:i,low:g,high:A,direction:-1}),C=this._findBorderPositionCircle(this.from,e,{x:r,y:i,low:g,high:A,direction:1});s=Math.atan2(I.y-i,I.x-r),a=Math.atan2(C.y-i,C.x-r)}e.beginPath(),e.arc(r,i,o,s,a,!1),e.stroke(),this.disableShadow(e,t)}getDistanceToEdge(e,t,r,i,o,s){if(this.from!=this.to)return this._getDistanceToEdge(e,t,r,i,o,s);{const[a,g,A]=this._getCircleData(void 0),I=a-o,C=g-s;return Math.abs(Math.sqrt(I*I+C*C)-A)}}_getDistanceToLine(e,t,r,i,o,s){const a=r-e,g=i-t,A=a*a+g*g;let I=((o-e)*a+(s-t)*g)/A;I>1?I=1:I<0&&(I=0);const C=e+I*a,l=t+I*g,d=C-o,u=l-s;return Math.sqrt(d*d+u*u)}getArrowData(e,t,r,i,o,s){let a,g,A,I,C,l,d;const u=s.width;t==="from"?(A=this.from,I=this.to,C=s.fromArrowScale<0,l=Math.abs(s.fromArrowScale),d=s.fromArrowType):t==="to"?(A=this.to,I=this.from,C=s.toArrowScale<0,l=Math.abs(s.toArrowScale),d=s.toArrowType):(A=this.to,I=this.from,C=s.middleArrowScale<0,l=Math.abs(s.middleArrowScale),d=s.middleArrowType);const h=15*l+3*u;if(A!=I){const b=GIe(A.x-I.x,A.y-I.y),p=h/b;if(t!=="middle")if(this.options.smooth.enabled===!0){const y=this._findBorderPosition(A,e,{via:r}),E=this.getPoint(y.t+p*(t==="from"?1:-1),r);a=Math.atan2(y.y-E.y,y.x-E.x),g=y}else a=Math.atan2(A.y-I.y,A.x-I.x),g=this._findBorderPosition(A,e);else{const y=(C?-p:p)/2,E=this.getPoint(.5+y,r),S=this.getPoint(.5-y,r);a=Math.atan2(E.y-S.y,E.x-S.x),g=this.getPoint(.5,r)}}else{const[b,p,y]=this._getCircleData(e);if(t==="from"){const E=this.options.selfReference.angle,S=this.options.selfReference.angle+Math.PI,m=this._findBorderPositionCircle(this.from,e,{x:b,y:p,low:E,high:S,direction:-1});a=m.t*-2*Math.PI+1.5*Math.PI+.1*Math.PI,g=m}else if(t==="to"){const E=this.options.selfReference.angle,S=this.options.selfReference.angle+Math.PI,m=this._findBorderPositionCircle(this.from,e,{x:b,y:p,low:E,high:S,direction:1});a=m.t*-2*Math.PI+1.5*Math.PI-1.1*Math.PI,g=m}else{const E=this.options.selfReference.angle/(2*Math.PI);g=this._pointOnCircle(b,p,y,E),a=E*-2*Math.PI+1.5*Math.PI+.1*Math.PI}}const v=g.x-h*.9*Math.cos(a),f=g.y-h*.9*Math.sin(a);return{point:g,core:{x:v,y:f},angle:a,length:h,type:d}}drawArrowHead(e,t,r,i,o){e.strokeStyle=this.getColor(e,t),e.fillStyle=e.strokeStyle,e.lineWidth=t.width,u7.draw(e,o)&&(this.enableShadow(e,t),cg(e).call(e),this.disableShadow(e,t))}enableShadow(e,t){t.shadow===!0&&(e.shadowColor=t.shadowColor,e.shadowBlur=t.shadowSize,e.shadowOffsetX=t.shadowX,e.shadowOffsetY=t.shadowY)}disableShadow(e,t){t.shadow===!0&&(e.shadowColor="rgba(0,0,0,0)",e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0)}drawBackground(e,t){if(t.background!==!1){const r={strokeStyle:e.strokeStyle,lineWidth:e.lineWidth,dashes:e.dashes};e.strokeStyle=t.backgroundColor,e.lineWidth=t.backgroundSize,this.setStrokeDashed(e,t.backgroundDashes),e.stroke(),e.strokeStyle=r.strokeStyle,e.lineWidth=r.lineWidth,e.dashes=r.dashes,this.setStrokeDashed(e,t.dashes)}}setStrokeDashed(e,t){if(t!==!1)if(e.setLineDash!==void 0){const r=we(t)?t:[5,5];e.setLineDash(r)}else console.warn("setLineDash is not supported in this browser. The dashed stroke cannot be used.");else e.setLineDash!==void 0?e.setLineDash([]):console.warn("setLineDash is not supported in this browser. The dashed stroke cannot be used.")}};function Dk(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function Nk(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=Dk(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=Dk(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}let mT=class extends h7{constructor(e,t,r){super(e,t,r)}_findBorderPositionBezier(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this._getViaCoordinates();const i=10,o=.2;let s=!1,a=1,g=0,A=this.to,I,C,l=this.options.endPointOffset?this.options.endPointOffset.to:0;e.id===this.from.id&&(A=this.from,s=!0,l=this.options.endPointOffset?this.options.endPointOffset.from:0),this.options.arrowStrikethrough===!1&&(l=0);let d=0;do{C=(g+a)*.5,I=this.getPoint(C,r);const u=Math.atan2(A.y-I.y,A.x-I.x),h=A.distanceToBorder(t,u)+l,v=Math.sqrt(Math.pow(I.x-A.x,2)+Math.pow(I.y-A.y,2)),f=h-v;if(Math.abs(f)<o)break;f<0?s===!1?g=C:a=C:s===!1?a=C:g=C,++d}while(g<=a&&d<i);return Nk(Nk({},I),{},{t:C})}_getDistanceToBezierEdge(e,t,r,i,o,s,a){let g=1e9,A,I,C,l,d,u=e,h=t;for(I=1;I<10;I++)C=.1*I,l=Math.pow(1-C,2)*e+2*C*(1-C)*a.x+Math.pow(C,2)*r,d=Math.pow(1-C,2)*t+2*C*(1-C)*a.y+Math.pow(C,2)*i,I>0&&(A=this._getDistanceToLine(u,h,l,d,o,s),g=A<g?A:g),u=l,h=d;return g}_bezierCurve(e,t,r,i){e.beginPath(),e.moveTo(this.fromPoint.x,this.fromPoint.y),r!=null&&r.x!=null?i!=null&&i.x!=null?e.bezierCurveTo(r.x,r.y,i.x,i.y,this.toPoint.x,this.toPoint.y):e.quadraticCurveTo(r.x,r.y,this.toPoint.x,this.toPoint.y):e.lineTo(this.toPoint.x,this.toPoint.y),this.drawBackground(e,t),this.enableShadow(e,t),e.stroke(),this.disableShadow(e,t)}getViaNode(){return this._getViaCoordinates()}},Mk=class extends mT{constructor(e,t,r){super(e,t,r),ze(this,"via",this.via),this._boundFunction=()=>{this.positionBezierNode()},this._body.emitter.on("_repositionBezierNodes",this._boundFunction)}setOptions(e){super.setOptions(e);let t=!1;this.options.physics!==e.physics&&(t=!0),this.options=e,this.id=this.options.id,this.from=this._body.nodes[this.options.from],this.to=this._body.nodes[this.options.to],this.setupSupportNode(),this.connect(),t===!0&&(this.via.setOptions({physics:this.options.physics}),this.positionBezierNode())}connect(){this.from=this._body.nodes[this.options.from],this.to=this._body.nodes[this.options.to],this.from===void 0||this.to===void 0||this.options.physics===!1?this.via.setOptions({physics:!1}):this.from.id===this.to.id?this.via.setOptions({physics:!1}):this.via.setOptions({physics:!0})}cleanup(){return this._body.emitter.off("_repositionBezierNodes",this._boundFunction),this.via!==void 0?(delete this._body.nodes[this.via.id],this.via=void 0,!0):!1}setupSupportNode(){if(this.via===void 0){const e="edgeId:"+this.id,t=this._body.functions.createNode({id:e,shape:"circle",physics:!0,hidden:!0});this._body.nodes[e]=t,this.via=t,this.via.parentEdgeId=this.id,this.positionBezierNode()}}positionBezierNode(){this.via!==void 0&&this.from!==void 0&&this.to!==void 0?(this.via.x=.5*(this.from.x+this.to.x),this.via.y=.5*(this.from.y+this.to.y)):this.via!==void 0&&(this.via.x=0,this.via.y=0)}_line(e,t,r){this._bezierCurve(e,t,r)}_getViaCoordinates(){return this.via}getViaNode(){return this.via}getPoint(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.via;if(this.from===this.to){const[r,i,o]=this._getCircleData(),s=2*Math.PI*(1-e);return{x:r+o*Math.sin(s),y:i+o-o*(1-Math.cos(s))}}else return{x:Math.pow(1-e,2)*this.fromPoint.x+2*e*(1-e)*t.x+Math.pow(e,2)*this.toPoint.x,y:Math.pow(1-e,2)*this.fromPoint.y+2*e*(1-e)*t.y+Math.pow(e,2)*this.toPoint.y}}_findBorderPosition(e,t){return this._findBorderPositionBezier(e,t,this.via)}_getDistanceToEdge(e,t,r,i,o,s){return this._getDistanceToBezierEdge(e,t,r,i,o,s,this.via)}},qk=class extends mT{constructor(e,t,r){super(e,t,r)}_line(e,t,r){this._bezierCurve(e,t,r)}getViaNode(){return this._getViaCoordinates()}_getViaCoordinates(){const e=this.options.smooth.roundness,t=this.options.smooth.type;let r=Math.abs(this.from.x-this.to.x),i=Math.abs(this.from.y-this.to.y);if(t==="discrete"||t==="diagonalCross"){let o,s;r<=i?o=s=e*i:o=s=e*r,this.from.x>this.to.x&&(o=-o),this.from.y>=this.to.y&&(s=-s);let a=this.from.x+o,g=this.from.y+s;return t==="discrete"&&(r<=i?a=r<e*i?this.from.x:a:g=i<e*r?this.from.y:g),{x:a,y:g}}else if(t==="straightCross"){let o=(1-e)*r,s=(1-e)*i;return r<=i?(o=0,this.from.y<this.to.y&&(s=-s)):(this.from.x<this.to.x&&(o=-o),s=0),{x:this.to.x+o,y:this.to.y+s}}else if(t==="horizontal"){let o=(1-e)*r;return this.from.x<this.to.x&&(o=-o),{x:this.to.x+o,y:this.from.y}}else if(t==="vertical"){let o=(1-e)*i;return this.from.y<this.to.y&&(o=-o),{x:this.from.x,y:this.to.y+o}}else if(t==="curvedCW"){r=this.to.x-this.from.x,i=this.from.y-this.to.y;const o=Math.sqrt(r*r+i*i),s=Math.PI,g=(Math.atan2(i,r)+(e*.5+.5)*s)%(2*s);return{x:this.from.x+(e*.5+.5)*o*Math.sin(g),y:this.from.y+(e*.5+.5)*o*Math.cos(g)}}else if(t==="curvedCCW"){r=this.to.x-this.from.x,i=this.from.y-this.to.y;const o=Math.sqrt(r*r+i*i),s=Math.PI,g=(Math.atan2(i,r)+(-e*.5+.5)*s)%(2*s);return{x:this.from.x+(e*.5+.5)*o*Math.sin(g),y:this.from.y+(e*.5+.5)*o*Math.cos(g)}}else{let o,s;r<=i?o=s=e*i:o=s=e*r,this.from.x>this.to.x&&(o=-o),this.from.y>=this.to.y&&(s=-s);let a=this.from.x+o,g=this.from.y+s;return r<=i?this.from.x<=this.to.x?a=this.to.x<a?this.to.x:a:a=this.to.x>a?this.to.x:a:this.from.y>=this.to.y?g=this.to.y>g?this.to.y:g:g=this.to.y<g?this.to.y:g,{x:a,y:g}}}_findBorderPosition(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};return this._findBorderPositionBezier(e,t,r.via)}_getDistanceToEdge(e,t,r,i,o,s){let a=arguments.length>6&&arguments[6]!==void 0?arguments[6]:this._getViaCoordinates();return this._getDistanceToBezierEdge(e,t,r,i,o,s,a)}getPoint(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this._getViaCoordinates();const r=e,i=Math.pow(1-r,2)*this.fromPoint.x+2*r*(1-r)*t.x+Math.pow(r,2)*this.toPoint.x,o=Math.pow(1-r,2)*this.fromPoint.y+2*r*(1-r)*t.y+Math.pow(r,2)*this.toPoint.y;return{x:i,y:o}}},rCe=class extends mT{constructor(e,t,r){super(e,t,r)}_getDistanceToBezierEdge2(e,t,r,i,o,s,a,g){let A=1e9,I=e,C=t;const l=[0,0,0,0];for(let d=1;d<10;d++){const u=.1*d;l[0]=Math.pow(1-u,3),l[1]=3*u*Math.pow(1-u,2),l[2]=3*Math.pow(u,2)*(1-u),l[3]=Math.pow(u,3);const h=l[0]*e+l[1]*a.x+l[2]*g.x+l[3]*r,v=l[0]*t+l[1]*a.y+l[2]*g.y+l[3]*i;if(d>0){const f=this._getDistanceToLine(I,C,h,v,o,s);A=f<A?f:A}I=h,C=v}return A}},Fk=class extends rCe{constructor(e,t,r){super(e,t,r)}_line(e,t,r){const i=r[0],o=r[1];this._bezierCurve(e,t,i,o)}_getViaCoordinates(){const e=this.from.x-this.to.x,t=this.from.y-this.to.y;let r,i,o,s;const a=this.options.smooth.roundness;return(Math.abs(e)>Math.abs(t)||this.options.smooth.forceDirection===!0||this.options.smooth.forceDirection==="horizontal")&&this.options.smooth.forceDirection!=="vertical"?(i=this.from.y,s=this.to.y,r=this.from.x-a*e,o=this.to.x+a*e):(i=this.from.y-a*t,s=this.to.y+a*t,r=this.from.x,o=this.to.x),[{x:r,y:i},{x:o,y:s}]}getViaNode(){return this._getViaCoordinates()}_findBorderPosition(e,t){return this._findBorderPositionBezier(e,t)}_getDistanceToEdge(e,t,r,i,o,s){let[a,g]=arguments.length>6&&arguments[6]!==void 0?arguments[6]:this._getViaCoordinates();return this._getDistanceToBezierEdge2(e,t,r,i,o,s,a,g)}getPoint(e){let[t,r]=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this._getViaCoordinates();const i=e,o=[Math.pow(1-i,3),3*i*Math.pow(1-i,2),3*Math.pow(i,2)*(1-i),Math.pow(i,3)],s=o[0]*this.fromPoint.x+o[1]*t.x+o[2]*r.x+o[3]*this.toPoint.x,a=o[0]*this.fromPoint.y+o[1]*t.y+o[2]*r.y+o[3]*this.toPoint.y;return{x:s,y:a}}},kk=class extends h7{constructor(e,t,r){super(e,t,r)}_line(e,t){e.beginPath(),e.moveTo(this.fromPoint.x,this.fromPoint.y),e.lineTo(this.toPoint.x,this.toPoint.y),this.enableShadow(e,t),e.stroke(),this.disableShadow(e,t)}getViaNode(){}getPoint(e){return{x:(1-e)*this.fromPoint.x+e*this.toPoint.x,y:(1-e)*this.fromPoint.y+e*this.toPoint.y}}_findBorderPosition(e,t){let r=this.to,i=this.from;e.id===this.from.id&&(r=this.from,i=this.to);const o=Math.atan2(r.y-i.y,r.x-i.x),s=r.x-i.x,a=r.y-i.y,g=Math.sqrt(s*s+a*a),A=e.distanceToBorder(t,o),I=(g-A)/g;return{x:(1-I)*i.x+I*r.x,y:(1-I)*i.y+I*r.y,t:0}}_getDistanceToEdge(e,t,r,i,o,s){return this._getDistanceToLine(e,t,r,i,o,s)}},ns=class c7{constructor(e,t,r,i,o){if(t===void 0)throw new Error("No body provided");this.options=sn(i),this.globalOptions=i,this.defaultOptions=o,this.body=t,this.imagelist=r,this.id=void 0,this.fromId=void 0,this.toId=void 0,this.selected=!1,this.hover=!1,this.labelDirty=!0,this.baseWidth=this.options.width,this.baseFontSize=this.options.font.size,this.from=void 0,this.to=void 0,this.edgeType=void 0,this.connected=!1,this.labelModule=new d7(this.body,this.options,!0),this.setOptions(e)}setOptions(e){if(!e)return;let t=typeof e.physics<"u"&&this.options.physics!==e.physics||typeof e.hidden<"u"&&(this.options.hidden||!1)!==(e.hidden||!1)||typeof e.from<"u"&&this.options.from!==e.from||typeof e.to<"u"&&this.options.to!==e.to;c7.parseOptions(this.options,e,!0,this.globalOptions),e.id!==void 0&&(this.id=e.id),e.from!==void 0&&(this.fromId=e.from),e.to!==void 0&&(this.toId=e.to),e.title!==void 0&&(this.title=e.title),e.value!==void 0&&(e.value=C7(e.value));const r=[e,this.options,this.defaultOptions];return this.chooser=pT("edge",r),this.updateLabelModule(e),t=this.updateEdgeType()||t,this._setInteractionWidths(),this.connect(),t}static parseOptions(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1,i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:{},o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!1;if(zs(["endPointOffset","arrowStrikethrough","id","from","hidden","hoverWidth","labelHighlightBold","length","line","opacity","physics","scaling","selectionWidth","selfReferenceSize","selfReference","to","title","value","width","font","chosen","widthConstraint"],e,t,r),t.endPointOffset!==void 0&&t.endPointOffset.from!==void 0&&(Nn(t.endPointOffset.from)?e.endPointOffset.from=t.endPointOffset.from:(e.endPointOffset.from=i.endPointOffset.from!==void 0?i.endPointOffset.from:0,console.error("endPointOffset.from is not a valid number"))),t.endPointOffset!==void 0&&t.endPointOffset.to!==void 0&&(Nn(t.endPointOffset.to)?e.endPointOffset.to=t.endPointOffset.to:(e.endPointOffset.to=i.endPointOffset.to!==void 0?i.endPointOffset.to:0,console.error("endPointOffset.to is not a valid number"))),GA(t.label)?e.label=t.label:GA(e.label)||(e.label=void 0),dr(e,t,"smooth",i),dr(e,t,"shadow",i),dr(e,t,"background",i),t.dashes!==void 0&&t.dashes!==null?e.dashes=t.dashes:r===!0&&t.dashes===null&&(e.dashes=nn(i.dashes)),t.scaling!==void 0&&t.scaling!==null?(t.scaling.min!==void 0&&(e.scaling.min=t.scaling.min),t.scaling.max!==void 0&&(e.scaling.max=t.scaling.max),dr(e.scaling,t.scaling,"label",i.scaling)):r===!0&&t.scaling===null&&(e.scaling=nn(i.scaling)),t.arrows!==void 0&&t.arrows!==null)if(typeof t.arrows=="string"){const a=t.arrows.toLowerCase();e.arrows.to.enabled=_e(a).call(a,"to")!=-1,e.arrows.middle.enabled=_e(a).call(a,"middle")!=-1,e.arrows.from.enabled=_e(a).call(a,"from")!=-1}else if(typeof t.arrows=="object")dr(e.arrows,t.arrows,"to",i.arrows),dr(e.arrows,t.arrows,"middle",i.arrows),dr(e.arrows,t.arrows,"from",i.arrows);else throw new Error("The arrow newOptions can only be an object or a string. Refer to the documentation. You used:"+ks(t.arrows));else r===!0&&t.arrows===null&&(e.arrows=nn(i.arrows));if(t.color!==void 0&&t.color!==null){const a=ts(t.color)?{color:t.color,highlight:t.color,hover:t.color,inherit:!1,opacity:1}:t.color,g=e.color;if(o)Me(g,i.color,!1,r);else for(const A in g)Object.prototype.hasOwnProperty.call(g,A)&&delete g[A];if(ts(g))g.color=g,g.highlight=g,g.hover=g,g.inherit=!1,a.opacity===void 0&&(g.opacity=1);else{let A=!1;a.color!==void 0&&(g.color=a.color,A=!0),a.highlight!==void 0&&(g.highlight=a.highlight,A=!0),a.hover!==void 0&&(g.hover=a.hover,A=!0),a.inherit!==void 0&&(g.inherit=a.inherit),a.opacity!==void 0&&(g.opacity=Math.min(1,Math.max(0,a.opacity))),A===!0?g.inherit=!1:g.inherit===void 0&&(g.inherit="from")}}else r===!0&&t.color===null&&(e.color=sn(i.color));r===!0&&t.font===null&&(e.font=sn(i.font)),Object.prototype.hasOwnProperty.call(t,"selfReferenceSize")&&(console.warn("The selfReferenceSize property has been deprecated. Please use selfReference property instead. The selfReference can be set like thise selfReference:{size:30, angle:Math.PI / 4}"),e.selfReference.size=t.selfReferenceSize)}getFormattingValues(){const e=this.options.arrows.to===!0||this.options.arrows.to.enabled===!0,t=this.options.arrows.from===!0||this.options.arrows.from.enabled===!0,r=this.options.arrows.middle===!0||this.options.arrows.middle.enabled===!0,i=this.options.color.inherit,o={toArrow:e,toArrowScale:this.options.arrows.to.scaleFactor,toArrowType:this.options.arrows.to.type,toArrowSrc:this.options.arrows.to.src,toArrowImageWidth:this.options.arrows.to.imageWidth,toArrowImageHeight:this.options.arrows.to.imageHeight,middleArrow:r,middleArrowScale:this.options.arrows.middle.scaleFactor,middleArrowType:this.options.arrows.middle.type,middleArrowSrc:this.options.arrows.middle.src,middleArrowImageWidth:this.options.arrows.middle.imageWidth,middleArrowImageHeight:this.options.arrows.middle.imageHeight,fromArrow:t,fromArrowScale:this.options.arrows.from.scaleFactor,fromArrowType:this.options.arrows.from.type,fromArrowSrc:this.options.arrows.from.src,fromArrowImageWidth:this.options.arrows.from.imageWidth,fromArrowImageHeight:this.options.arrows.from.imageHeight,arrowStrikethrough:this.options.arrowStrikethrough,color:i?void 0:this.options.color.color,inheritsColor:i,opacity:this.options.color.opacity,hidden:this.options.hidden,length:this.options.length,shadow:this.options.shadow.enabled,shadowColor:this.options.shadow.color,shadowSize:this.options.shadow.size,shadowX:this.options.shadow.x,shadowY:this.options.shadow.y,dashes:this.options.dashes,width:this.options.width,background:this.options.background.enabled,backgroundColor:this.options.background.color,backgroundSize:this.options.background.size,backgroundDashes:this.options.background.dashes};if(this.selected||this.hover)if(this.chooser===!0){if(this.selected){const s=this.options.selectionWidth;typeof s=="function"?o.width=s(o.width):typeof s=="number"&&(o.width+=s),o.width=Math.max(o.width,.3/this.body.view.scale),o.color=this.options.color.highlight,o.shadow=this.options.shadow.enabled}else if(this.hover){const s=this.options.hoverWidth;typeof s=="function"?o.width=s(o.width):typeof s=="number"&&(o.width+=s),o.width=Math.max(o.width,.3/this.body.view.scale),o.color=this.options.color.hover,o.shadow=this.options.shadow.enabled}}else typeof this.chooser=="function"&&(this.chooser(o,this.options.id,this.selected,this.hover),o.color!==void 0&&(o.inheritsColor=!1),o.shadow===!1&&(o.shadowColor!==this.options.shadow.color||o.shadowSize!==this.options.shadow.size||o.shadowX!==this.options.shadow.x||o.shadowY!==this.options.shadow.y)&&(o.shadow=!0));else o.shadow=this.options.shadow.enabled,o.width=Math.max(o.width,.3/this.body.view.scale);return o}updateLabelModule(e){const t=[e,this.options,this.globalOptions,this.defaultOptions];this.labelModule.update(this.options,t),this.labelModule.baseSize!==void 0&&(this.baseFontSize=this.labelModule.baseSize)}updateEdgeType(){const e=this.options.smooth;let t=!1,r=!0;return this.edgeType!==void 0&&((this.edgeType instanceof Mk&&e.enabled===!0&&e.type==="dynamic"||this.edgeType instanceof Fk&&e.enabled===!0&&e.type==="cubicBezier"||this.edgeType instanceof qk&&e.enabled===!0&&e.type!=="dynamic"&&e.type!=="cubicBezier"||this.edgeType instanceof kk&&e.type.enabled===!1)&&(r=!1),r===!0&&(t=this.cleanup())),r===!0?e.enabled===!0?e.type==="dynamic"?(t=!0,this.edgeType=new Mk(this.options,this.body,this.labelModule)):e.type==="cubicBezier"?this.edgeType=new Fk(this.options,this.body,this.labelModule):this.edgeType=new qk(this.options,this.body,this.labelModule):this.edgeType=new kk(this.options,this.body,this.labelModule):this.edgeType.setOptions(this.options),t}connect(){this.disconnect(),this.from=this.body.nodes[this.fromId]||void 0,this.to=this.body.nodes[this.toId]||void 0,this.connected=this.from!==void 0&&this.to!==void 0,this.connected===!0?(this.from.attachEdge(this),this.to.attachEdge(this)):(this.from&&this.from.detachEdge(this),this.to&&this.to.detachEdge(this)),this.edgeType.connect()}disconnect(){this.from&&(this.from.detachEdge(this),this.from=void 0),this.to&&(this.to.detachEdge(this),this.to=void 0),this.connected=!1}getTitle(){return this.title}isSelected(){return this.selected}getValue(){return this.options.value}setValueRange(e,t,r){if(this.options.value!==void 0){const i=this.options.scaling.customScalingFunction(e,t,r,this.options.value),o=this.options.scaling.max-this.options.scaling.min;if(this.options.scaling.label.enabled===!0){const s=this.options.scaling.label.max-this.options.scaling.label.min;this.options.font.size=this.options.scaling.label.min+i*s}this.options.width=this.options.scaling.min+i*o}else this.options.width=this.baseWidth,this.options.font.size=this.baseFontSize;this._setInteractionWidths(),this.updateLabelModule()}_setInteractionWidths(){typeof this.options.hoverWidth=="function"?this.edgeType.hoverWidth=this.options.hoverWidth(this.options.width):this.edgeType.hoverWidth=this.options.hoverWidth+this.options.width,typeof this.options.selectionWidth=="function"?this.edgeType.selectionWidth=this.options.selectionWidth(this.options.width):this.edgeType.selectionWidth=this.options.selectionWidth+this.options.width}draw(e){const t=this.getFormattingValues();if(t.hidden)return;const r=this.edgeType.getViaNode();this.edgeType.drawLine(e,t,this.selected,this.hover,r),this.drawLabel(e,r)}drawArrows(e){const t=this.getFormattingValues();if(t.hidden)return;const r=this.edgeType.getViaNode(),i={};this.edgeType.fromPoint=this.edgeType.from,this.edgeType.toPoint=this.edgeType.to,t.fromArrow&&(i.from=this.edgeType.getArrowData(e,"from",r,this.selected,this.hover,t),t.arrowStrikethrough===!1&&(this.edgeType.fromPoint=i.from.core),t.fromArrowSrc&&(i.from.image=this.imagelist.load(t.fromArrowSrc)),t.fromArrowImageWidth&&(i.from.imageWidth=t.fromArrowImageWidth),t.fromArrowImageHeight&&(i.from.imageHeight=t.fromArrowImageHeight)),t.toArrow&&(i.to=this.edgeType.getArrowData(e,"to",r,this.selected,this.hover,t),t.arrowStrikethrough===!1&&(this.edgeType.toPoint=i.to.core),t.toArrowSrc&&(i.to.image=this.imagelist.load(t.toArrowSrc)),t.toArrowImageWidth&&(i.to.imageWidth=t.toArrowImageWidth),t.toArrowImageHeight&&(i.to.imageHeight=t.toArrowImageHeight)),t.middleArrow&&(i.middle=this.edgeType.getArrowData(e,"middle",r,this.selected,this.hover,t),t.middleArrowSrc&&(i.middle.image=this.imagelist.load(t.middleArrowSrc)),t.middleArrowImageWidth&&(i.middle.imageWidth=t.middleArrowImageWidth),t.middleArrowImageHeight&&(i.middle.imageHeight=t.middleArrowImageHeight)),t.fromArrow&&this.edgeType.drawArrowHead(e,t,this.selected,this.hover,i.from),t.middleArrow&&this.edgeType.drawArrowHead(e,t,this.selected,this.hover,i.middle),t.toArrow&&this.edgeType.drawArrowHead(e,t,this.selected,this.hover,i.to)}drawLabel(e,t){if(this.options.label!==void 0){const r=this.from,i=this.to;this.labelModule.differentState(this.selected,this.hover)&&this.labelModule.getTextSize(e,this.selected,this.hover);let o;if(r.id!=i.id){this.labelModule.pointToSelf=!1,o=this.edgeType.getPoint(.5,t),e.save();const s=this._getRotation(e);s.angle!=0&&(e.translate(s.x,s.y),e.rotate(s.angle)),this.labelModule.draw(e,o.x,o.y,this.selected,this.hover),e.restore()}else{this.labelModule.pointToSelf=!0;const s=l7(e,this.options.selfReference.angle,this.options.selfReference.size,r);o=this._pointOnCircle(s.x,s.y,this.options.selfReference.size,this.options.selfReference.angle),this.labelModule.draw(e,o.x,o.y,this.selected,this.hover)}}}getItemsOnPoint(e){const t=[];if(this.labelModule.visible()){const i=this._getRotation();fO(this.labelModule.getSize(),e,i)&&t.push({edgeId:this.id,labelId:0})}const r={left:e.x,top:e.y};return this.isOverlappingWith(r)&&t.push({edgeId:this.id}),t}isOverlappingWith(e){if(this.connected){const r=this.from.x,i=this.from.y,o=this.to.x,s=this.to.y,a=e.left,g=e.top;return this.edgeType.getDistanceToEdge(r,i,o,s,a,g)<10}else return!1}_getRotation(e){const t=this.edgeType.getViaNode(),r=this.edgeType.getPoint(.5,t);e!==void 0&&this.labelModule.calculateLabelSize(e,this.selected,this.hover,r.x,r.y);const i={x:r.x,y:this.labelModule.size.yLine,angle:0};if(!this.labelModule.visible()||this.options.font.align==="horizontal")return i;const o=this.from.y-this.to.y,s=this.from.x-this.to.x;let a=Math.atan2(o,s);return(a<-1&&s<0||a>0&&s<0)&&(a+=Math.PI),i.angle=a,i}_pointOnCircle(e,t,r,i){return{x:e+r*Math.cos(i),y:t-r*Math.sin(i)}}select(){this.selected=!0}unselect(){this.selected=!1}cleanup(){return this.edgeType.cleanup()}remove(){this.cleanup(),this.disconnect(),delete this.body.edges[this.id]}endPointsValid(){return this.body.nodes[this.fromId]!==void 0&&this.body.nodes[this.toId]!==void 0}},iCe=class{constructor(e,t,r){var i;this.body=e,this.images=t,this.groups=r,this.body.functions.createEdge=z(i=this.create).call(i,this),this.edgesListeners={add:(o,s)=>{this.add(s.items)},update:(o,s)=>{this.update(s.items)},remove:(o,s)=>{this.remove(s.items)}},this.options={},this.defaultOptions={arrows:{to:{enabled:!1,scaleFactor:1,type:"arrow"},middle:{enabled:!1,scaleFactor:1,type:"arrow"},from:{enabled:!1,scaleFactor:1,type:"arrow"}},endPointOffset:{from:0,to:0},arrowStrikethrough:!0,color:{color:"#848484",highlight:"#848484",hover:"#848484",inherit:"from",opacity:1},dashes:!1,font:{color:"#343434",size:14,face:"arial",background:"none",strokeWidth:2,strokeColor:"#ffffff",align:"horizontal",multi:!1,vadjust:0,bold:{mod:"bold"},boldital:{mod:"bold italic"},ital:{mod:"italic"},mono:{mod:"",size:15,face:"courier new",vadjust:2}},hidden:!1,hoverWidth:1.5,label:void 0,labelHighlightBold:!0,length:void 0,physics:!0,scaling:{min:1,max:15,label:{enabled:!0,min:14,max:30,maxVisible:30,drawThreshold:5},customScalingFunction:function(o,s,a,g){if(s===o)return .5;{const A=1/(s-o);return Math.max(0,(g-o)*A)}}},selectionWidth:1.5,selfReference:{size:20,angle:Math.PI/4,renderBehindTheNode:!0},shadow:{enabled:!1,color:"rgba(0,0,0,0.5)",size:10,x:5,y:5},background:{enabled:!1,color:"rgba(111,111,111,1)",size:10,dashes:!1},smooth:{enabled:!0,type:"dynamic",forceDirection:"none",roundness:.5},title:void 0,width:1,value:void 0},Me(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){var e=this,t,r;this.body.emitter.on("_forceDisableDynamicCurves",function(i){let o=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;i==="dynamic"&&(i="continuous");let s=!1;for(const a in e.body.edges)if(Object.prototype.hasOwnProperty.call(e.body.edges,a)){const g=e.body.edges[a],A=e.body.data.edges.get(a);if(A!=null){const I=A.smooth;I!==void 0&&I.enabled===!0&&I.type==="dynamic"&&(i===void 0?g.setOptions({smooth:!1}):g.setOptions({smooth:{type:i}}),s=!0)}}o===!0&&s===!0&&e.body.emitter.emit("_dataChanged")}),this.body.emitter.on("_dataUpdated",()=>{this.reconnectEdges()}),this.body.emitter.on("refreshEdges",z(t=this.refresh).call(t,this)),this.body.emitter.on("refresh",z(r=this.refresh).call(r,this)),this.body.emitter.on("destroy",()=>{de(this.edgesListeners,(i,o)=>{this.body.data.edges&&this.body.data.edges.off(o,i)}),delete this.body.functions.createEdge,delete this.edgesListeners.add,delete this.edgesListeners.update,delete this.edgesListeners.remove,delete this.edgesListeners})}setOptions(e){if(e!==void 0){ns.parseOptions(this.options,e,!0,this.defaultOptions,!0);let t=!1;if(e.smooth!==void 0)for(const r in this.body.edges)Object.prototype.hasOwnProperty.call(this.body.edges,r)&&(t=this.body.edges[r].updateEdgeType()||t);if(e.font!==void 0)for(const r in this.body.edges)Object.prototype.hasOwnProperty.call(this.body.edges,r)&&this.body.edges[r].updateLabelModule();(e.hidden!==void 0||e.physics!==void 0||t===!0)&&this.body.emitter.emit("_dataChanged")}}setData(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;const r=this.body.data.edges;if(I7("id",e))this.body.data.edges=e;else if(we(e))this.body.data.edges=new us,this.body.data.edges.add(e);else if(!e)this.body.data.edges=new us;else throw new TypeError("Array or DataSet expected");if(r&&de(this.edgesListeners,(i,o)=>{r.off(o,i)}),this.body.edges={},this.body.data.edges){de(this.edgesListeners,(o,s)=>{this.body.data.edges.on(s,o)});const i=this.body.data.edges.getIds();this.add(i,!0)}this.body.emitter.emit("_adjustEdgesForHierarchicalLayout"),t===!1&&this.body.emitter.emit("_dataChanged")}add(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;const r=this.body.edges,i=this.body.data.edges;for(let o=0;o<e.length;o++){const s=e[o],a=r[s];a&&a.disconnect();const g=i.get(s,{showInternalIds:!0});r[s]=this.create(g)}this.body.emitter.emit("_adjustEdgesForHierarchicalLayout"),t===!1&&this.body.emitter.emit("_dataChanged")}update(e){const t=this.body.edges,r=this.body.data.edges;let i=!1;for(let o=0;o<e.length;o++){const s=e[o],a=r.get(s),g=t[s];g!==void 0?(g.disconnect(),i=g.setOptions(a)||i,g.connect()):(this.body.edges[s]=this.create(a),i=!0)}i===!0?(this.body.emitter.emit("_adjustEdgesForHierarchicalLayout"),this.body.emitter.emit("_dataChanged")):this.body.emitter.emit("_dataUpdated")}remove(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;if(e.length===0)return;const r=this.body.edges;de(e,i=>{const o=r[i];o!==void 0&&o.remove()}),t&&this.body.emitter.emit("_dataChanged")}refresh(){de(this.body.edges,(e,t)=>{const r=this.body.data.edges.get(t);r!==void 0&&e.setOptions(r)})}create(e){return new ns(e,this.body,this.images,this.options,this.defaultOptions)}reconnectEdges(){let e;const t=this.body.nodes,r=this.body.edges;for(e in t)Object.prototype.hasOwnProperty.call(t,e)&&(t[e].edges=[]);for(e in r)if(Object.prototype.hasOwnProperty.call(r,e)){const i=r[e];i.from=null,i.to=null,i.connect()}}getConnectedNodes(e){const t=[];if(this.body.edges[e]!==void 0){const r=this.body.edges[e];r.fromId!==void 0&&t.push(r.fromId),r.toId!==void 0&&t.push(r.toId)}return t}_updateState(){this._addMissingEdges(),this._removeInvalidEdges()}_removeInvalidEdges(){const e=[];de(this.body.edges,(t,r)=>{const i=this.body.nodes[t.toId],o=this.body.nodes[t.fromId];i!==void 0&&i.isCluster===!0||o!==void 0&&o.isCluster===!0||(i===void 0||o===void 0)&&e.push(r)}),this.remove(e,!1)}_addMissingEdges(){const e=this.body.data.edges;if(e==null)return;const t=this.body.edges,r=[];be(e).call(e,(i,o)=>{t[o]===void 0&&r.push(o)}),this.add(r,!0)}},f7=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.barnesHutTree,this.setOptions(r),this._rng=yI("BARNES HUT SOLVER")}setOptions(e){this.options=e,this.thetaInversed=1/this.options.theta,this.overlapAvoidanceFactor=1-Math.max(0,Math.min(1,this.options.avoidOverlap))}solve(){if(this.options.gravitationalConstant!==0&&this.physicsBody.physicsNodeIndices.length>0){let e;const t=this.body.nodes,r=this.physicsBody.physicsNodeIndices,i=r.length,o=this._formBarnesHutTree(t,r);this.barnesHutTree=o;for(let s=0;s<i;s++)e=t[r[s]],e.options.mass>0&&this._getForceContributions(o.root,e)}}_getForceContributions(e,t){this._getForceContribution(e.children.NW,t),this._getForceContribution(e.children.NE,t),this._getForceContribution(e.children.SW,t),this._getForceContribution(e.children.SE,t)}_getForceContribution(e,t){if(e.childrenCount>0){const r=e.centerOfMass.x-t.x,i=e.centerOfMass.y-t.y,o=Math.sqrt(r*r+i*i);o*e.calcSize>this.thetaInversed?this._calculateForces(o,r,i,t,e):e.childrenCount===4?this._getForceContributions(e,t):e.children.data.id!=t.id&&this._calculateForces(o,r,i,t,e)}}_calculateForces(e,t,r,i,o){e===0&&(e=.1,t=e),this.overlapAvoidanceFactor<1&&i.shape.radius&&(e=Math.max(.1+this.overlapAvoidanceFactor*i.shape.radius,e-i.shape.radius));const s=this.options.gravitationalConstant*o.mass*i.options.mass/Math.pow(e,3),a=t*s,g=r*s;this.physicsBody.forces[i.id].x+=a,this.physicsBody.forces[i.id].y+=g}_formBarnesHutTree(e,t){let r;const i=t.length;let o=e[t[0]].x,s=e[t[0]].y,a=e[t[0]].x,g=e[t[0]].y;for(let v=1;v<i;v++){const f=e[t[v]],c=f.x,b=f.y;f.options.mass>0&&(c<o&&(o=c),c>a&&(a=c),b<s&&(s=b),b>g&&(g=b))}const A=Math.abs(a-o)-Math.abs(g-s);A>0?(s-=.5*A,g+=.5*A):(o+=.5*A,a-=.5*A);const C=Math.max(1e-5,Math.abs(a-o)),l=.5*C,d=.5*(o+a),u=.5*(s+g),h={root:{centerOfMass:{x:0,y:0},mass:0,range:{minX:d-l,maxX:d+l,minY:u-l,maxY:u+l},size:C,calcSize:1/C,children:{data:null},maxWidth:0,level:0,childrenCount:4}};this._splitBranch(h.root);for(let v=0;v<i;v++)r=e[t[v]],r.options.mass>0&&this._placeInTree(h.root,r);return h}_updateBranchMass(e,t){const r=e.centerOfMass,i=e.mass+t.options.mass,o=1/i;r.x=r.x*e.mass+t.x*t.options.mass,r.x*=o,r.y=r.y*e.mass+t.y*t.options.mass,r.y*=o,e.mass=i;const s=Math.max(Math.max(t.height,t.radius),t.width);e.maxWidth=e.maxWidth<s?s:e.maxWidth}_placeInTree(e,t,r){(r!=!0||r===void 0)&&this._updateBranchMass(e,t);const i=e.children.NW.range;let o;i.maxX>t.x?i.maxY>t.y?o="NW":o="SW":i.maxY>t.y?o="NE":o="SE",this._placeInRegion(e,t,o)}_placeInRegion(e,t,r){const i=e.children[r];switch(i.childrenCount){case 0:i.children.data=t,i.childrenCount=1,this._updateBranchMass(i,t);break;case 1:i.children.data.x===t.x&&i.children.data.y===t.y?(t.x+=this._rng(),t.y+=this._rng()):(this._splitBranch(i),this._placeInTree(i,t));break;case 4:this._placeInTree(i,t);break}}_splitBranch(e){let t=null;e.childrenCount===1&&(t=e.children.data,e.mass=0,e.centerOfMass.x=0,e.centerOfMass.y=0),e.childrenCount=4,e.children.data=null,this._insertRegion(e,"NW"),this._insertRegion(e,"NE"),this._insertRegion(e,"SW"),this._insertRegion(e,"SE"),t!=null&&this._placeInTree(e,t)}_insertRegion(e,t){let r,i,o,s;const a=.5*e.size;switch(t){case"NW":r=e.range.minX,i=e.range.minX+a,o=e.range.minY,s=e.range.minY+a;break;case"NE":r=e.range.minX+a,i=e.range.maxX,o=e.range.minY,s=e.range.minY+a;break;case"SW":r=e.range.minX,i=e.range.minX+a,o=e.range.minY+a,s=e.range.maxY;break;case"SE":r=e.range.minX+a,i=e.range.maxX,o=e.range.minY+a,s=e.range.maxY;break}e.children[t]={centerOfMass:{x:0,y:0},mass:0,range:{minX:r,maxX:i,minY:o,maxY:s},size:.5*e.size,calcSize:2*e.calcSize,children:{data:null},maxWidth:0,level:e.level+1,childrenCount:0}}_debug(e,t){this.barnesHutTree!==void 0&&(e.lineWidth=1,this._drawBranch(this.barnesHutTree.root,e,t))}_drawBranch(e,t,r){r===void 0&&(r="#FF0000"),e.childrenCount===4&&(this._drawBranch(e.children.NW,t),this._drawBranch(e.children.NE,t),this._drawBranch(e.children.SE,t),this._drawBranch(e.children.SW,t)),t.strokeStyle=r,t.beginPath(),t.moveTo(e.range.minX,e.range.minY),t.lineTo(e.range.maxX,e.range.minY),t.stroke(),t.beginPath(),t.moveTo(e.range.maxX,e.range.minY),t.lineTo(e.range.maxX,e.range.maxY),t.stroke(),t.beginPath(),t.moveTo(e.range.maxX,e.range.maxY),t.lineTo(e.range.minX,e.range.maxY),t.stroke(),t.beginPath(),t.moveTo(e.range.minX,e.range.maxY),t.lineTo(e.range.minX,e.range.minY),t.stroke()}},nCe=class{constructor(e,t,r){this._rng=yI("REPULSION SOLVER"),this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e}solve(){let e,t,r,i,o,s,a,g;const A=this.body.nodes,I=this.physicsBody.physicsNodeIndices,C=this.physicsBody.forces,l=this.options.nodeDistance,d=-2/3/l,u=4/3;for(let h=0;h<I.length-1;h++){a=A[I[h]];for(let v=h+1;v<I.length;v++)g=A[I[v]],e=g.x-a.x,t=g.y-a.y,r=Math.sqrt(e*e+t*t),r===0&&(r=.1*this._rng(),e=r),r<2*l&&(r<.5*l?s=1:s=d*r+u,s=s/r,i=e*s,o=t*s,C[a.id].x-=i,C[a.id].y-=o,C[g.id].x+=i,C[g.id].y+=o)}}},oCe=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e,this.overlapAvoidanceFactor=Math.max(0,Math.min(1,this.options.avoidOverlap||0))}solve(){const e=this.body.nodes,t=this.physicsBody.physicsNodeIndices,r=this.physicsBody.forces,i=this.options.nodeDistance;for(let o=0;o<t.length-1;o++){const s=e[t[o]];for(let a=o+1;a<t.length;a++){const g=e[t[a]];if(s.level===g.level){const A=i+this.overlapAvoidanceFactor*((s.shape.radius||0)/2+(g.shape.radius||0)/2),I=g.x-s.x,C=g.y-s.y,l=Math.sqrt(I*I+C*C),d=.05;let u;l<A?u=-Math.pow(d*l,2)+Math.pow(d*A,2):u=0,l!==0&&(u=u/l);const h=I*u,v=C*u;r[s.id].x-=h,r[s.id].y-=v,r[g.id].x+=h,r[g.id].y+=v}}}}},mf=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e}solve(){let e,t;const r=this.physicsBody.physicsEdgeIndices,i=this.body.edges;let o,s,a;for(let g=0;g<r.length;g++)t=i[r[g]],t.connected===!0&&t.toId!==t.fromId&&this.body.nodes[t.toId]!==void 0&&this.body.nodes[t.fromId]!==void 0&&(t.edgeType.via!==void 0?(e=t.options.length===void 0?this.options.springLength:t.options.length,o=t.to,s=t.edgeType.via,a=t.from,this._calculateSpringForce(o,s,.5*e),this._calculateSpringForce(s,a,.5*e)):(e=t.options.length===void 0?this.options.springLength*1.5:t.options.length,this._calculateSpringForce(t.from,t.to,e)))}_calculateSpringForce(e,t,r){const i=e.x-t.x,o=e.y-t.y,s=Math.max(Math.sqrt(i*i+o*o),.01),a=this.options.springConstant*(r-s)/s,g=i*a,A=o*a;this.physicsBody.forces[e.id]!==void 0&&(this.physicsBody.forces[e.id].x+=g,this.physicsBody.forces[e.id].y+=A),this.physicsBody.forces[t.id]!==void 0&&(this.physicsBody.forces[t.id].x-=g,this.physicsBody.forces[t.id].y-=A)}},sCe=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e}solve(){let e,t,r,i,o,s,a,g;const A=this.body.edges,I=.5,C=this.physicsBody.physicsEdgeIndices,l=this.physicsBody.physicsNodeIndices,d=this.physicsBody.forces;for(let p=0;p<l.length;p++){const y=l[p];d[y].springFx=0,d[y].springFy=0}for(let p=0;p<C.length;p++)t=A[C[p]],t.connected===!0&&(e=t.options.length===void 0?this.options.springLength:t.options.length,r=t.from.x-t.to.x,i=t.from.y-t.to.y,g=Math.sqrt(r*r+i*i),g=g===0?.01:g,a=this.options.springConstant*(e-g)/g,o=r*a,s=i*a,t.to.level!=t.from.level?(d[t.toId]!==void 0&&(d[t.toId].springFx-=o,d[t.toId].springFy-=s),d[t.fromId]!==void 0&&(d[t.fromId].springFx+=o,d[t.fromId].springFy+=s)):(d[t.toId]!==void 0&&(d[t.toId].x-=I*o,d[t.toId].y-=I*s),d[t.fromId]!==void 0&&(d[t.fromId].x+=I*o,d[t.fromId].y+=I*s)));a=1;let u,h;for(let p=0;p<l.length;p++){const y=l[p];u=Math.min(a,Math.max(-a,d[y].springFx)),h=Math.min(a,Math.max(-a,d[y].springFy)),d[y].x+=u,d[y].y+=h}let v=0,f=0;for(let p=0;p<l.length;p++){const y=l[p];v+=d[y].x,f+=d[y].y}const c=v/l.length,b=f/l.length;for(let p=0;p<l.length;p++){const y=l[p];d[y].x-=c,d[y].y-=b}}},OA=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e}solve(){let e,t,r,i;const o=this.body.nodes,s=this.physicsBody.physicsNodeIndices,a=this.physicsBody.forces;for(let g=0;g<s.length;g++){const A=s[g];i=o[A],e=-i.x,t=-i.y,r=Math.sqrt(e*e+t*t),this._calculateForces(r,e,t,a,i)}}_calculateForces(e,t,r,i,o){const s=e===0?0:this.options.centralGravity/e;i[o.id].x=t*s,i[o.id].y=r*s}},aCe=class extends f7{constructor(e,t,r){super(e,t,r),this._rng=yI("FORCE ATLAS 2 BASED REPULSION SOLVER")}_calculateForces(e,t,r,i,o){e===0&&(e=.1*this._rng(),t=e),this.overlapAvoidanceFactor<1&&i.shape.radius&&(e=Math.max(.1+this.overlapAvoidanceFactor*i.shape.radius,e-i.shape.radius));const s=i.edges.length+1,a=this.options.gravitationalConstant*o.mass*i.options.mass*s/Math.pow(e,2),g=t*a,A=r*a;this.physicsBody.forces[i.id].x+=g,this.physicsBody.forces[i.id].y+=A}},gCe=class extends OA{constructor(e,t,r){super(e,t,r)}_calculateForces(e,t,r,i,o){if(e>0){const s=o.edges.length+1,a=this.options.centralGravity*s*o.options.mass;i[o.id].x=t*a,i[o.id].y=r*a}}},ACe=class{constructor(e){this.body=e,this.physicsBody={physicsNodeIndices:[],physicsEdgeIndices:[],forces:{},velocities:{}},this.physicsEnabled=!0,this.simulationInterval=1e3/60,this.requiresTimeout=!0,this.previousStates={},this.referenceState={},this.freezeCache={},this.renderTimer=void 0,this.adaptiveTimestep=!1,this.adaptiveTimestepEnabled=!1,this.adaptiveCounter=0,this.adaptiveInterval=3,this.stabilized=!1,this.startedStabilization=!1,this.stabilizationIterations=0,this.ready=!1,this.options={},this.defaultOptions={enabled:!0,barnesHut:{theta:.5,gravitationalConstant:-2e3,centralGravity:.3,springLength:95,springConstant:.04,damping:.09,avoidOverlap:0},forceAtlas2Based:{theta:.5,gravitationalConstant:-50,centralGravity:.01,springConstant:.08,springLength:100,damping:.4,avoidOverlap:0},repulsion:{centralGravity:.2,springLength:200,springConstant:.05,nodeDistance:100,damping:.09,avoidOverlap:0},hierarchicalRepulsion:{centralGravity:0,springLength:100,springConstant:.01,nodeDistance:120,damping:.09},maxVelocity:50,minVelocity:.75,solver:"barnesHut",stabilization:{enabled:!0,iterations:1e3,updateInterval:50,onlyDynamicEdges:!1,fit:!0},timestep:.5,adaptiveTimestep:!0,wind:{x:0,y:0}},tt(this.options,this.defaultOptions),this.timestep=.5,this.layoutFailed=!1,this.bindEventListeners()}bindEventListeners(){this.body.emitter.on("initPhysics",()=>{this.initPhysics()}),this.body.emitter.on("_layoutFailed",()=>{this.layoutFailed=!0}),this.body.emitter.on("resetPhysics",()=>{this.stopSimulation(),this.ready=!1}),this.body.emitter.on("disablePhysics",()=>{this.physicsEnabled=!1,this.stopSimulation()}),this.body.emitter.on("restorePhysics",()=>{this.setOptions(this.options),this.ready===!0&&this.startSimulation()}),this.body.emitter.on("startSimulation",()=>{this.ready===!0&&this.startSimulation()}),this.body.emitter.on("stopSimulation",()=>{this.stopSimulation()}),this.body.emitter.on("destroy",()=>{this.stopSimulation(!1),this.body.emitter.off()}),this.body.emitter.on("_dataChanged",()=>{this.updatePhysicsData()})}setOptions(e){if(e!==void 0)if(e===!1)this.options.enabled=!1,this.physicsEnabled=!1,this.stopSimulation();else if(e===!0)this.options.enabled=!0,this.physicsEnabled=!0,this.startSimulation();else{this.physicsEnabled=!0,zA(["stabilization"],this.options,e),dr(this.options,e,"stabilization"),e.enabled===void 0&&(this.options.enabled=!0),this.options.enabled===!1&&(this.physicsEnabled=!1,this.stopSimulation());const t=this.options.wind;t&&((typeof t.x!="number"||hO(t.x))&&(t.x=0),(typeof t.y!="number"||hO(t.y))&&(t.y=0)),this.timestep=this.options.timestep}this.init()}init(){let e;this.options.solver==="forceAtlas2Based"?(e=this.options.forceAtlas2Based,this.nodesSolver=new aCe(this.body,this.physicsBody,e),this.edgesSolver=new mf(this.body,this.physicsBody,e),this.gravitySolver=new gCe(this.body,this.physicsBody,e)):this.options.solver==="repulsion"?(e=this.options.repulsion,this.nodesSolver=new nCe(this.body,this.physicsBody,e),this.edgesSolver=new mf(this.body,this.physicsBody,e),this.gravitySolver=new OA(this.body,this.physicsBody,e)):this.options.solver==="hierarchicalRepulsion"?(e=this.options.hierarchicalRepulsion,this.nodesSolver=new oCe(this.body,this.physicsBody,e),this.edgesSolver=new sCe(this.body,this.physicsBody,e),this.gravitySolver=new OA(this.body,this.physicsBody,e)):(e=this.options.barnesHut,this.nodesSolver=new f7(this.body,this.physicsBody,e),this.edgesSolver=new mf(this.body,this.physicsBody,e),this.gravitySolver=new OA(this.body,this.physicsBody,e)),this.modelOptions=e}initPhysics(){this.physicsEnabled===!0&&this.options.enabled===!0?this.options.stabilization.enabled===!0?this.stabilize():(this.stabilized=!1,this.ready=!0,this.body.emitter.emit("fit",{},this.layoutFailed),this.startSimulation()):(this.ready=!0,this.body.emitter.emit("fit"))}startSimulation(){if(this.physicsEnabled===!0&&this.options.enabled===!0){if(this.stabilized=!1,this.adaptiveTimestep=!1,this.body.emitter.emit("_resizeNodes"),this.viewFunction===void 0){var e;this.viewFunction=z(e=this.simulationStep).call(e,this),this.body.emitter.on("initRedraw",this.viewFunction),this.body.emitter.emit("_startRendering")}}else this.body.emitter.emit("_redraw")}stopSimulation(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!0;this.stabilized=!0,e===!0&&this._emitStabilized(),this.viewFunction!==void 0&&(this.body.emitter.off("initRedraw",this.viewFunction),this.viewFunction=void 0,e===!0&&this.body.emitter.emit("_stopRendering"))}simulationStep(){const e=MA();this.physicsTick(),(MA()-e<.4*this.simulationInterval||this.runDoubleSpeed===!0)&&this.stabilized===!1&&(this.physicsTick(),this.runDoubleSpeed=!0),this.stabilized===!0&&this.stopSimulation()}_emitStabilized(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.stabilizationIterations;(this.stabilizationIterations>1||this.startedStabilization===!0)&&ri(()=>{this.body.emitter.emit("stabilized",{iterations:e}),this.startedStabilization=!1,this.stabilizationIterations=0},0)}physicsStep(){this.gravitySolver.solve(),this.nodesSolver.solve(),this.edgesSolver.solve(),this.moveNodes()}adjustTimeStep(){this._evaluateStepQuality()===!0?this.timestep=1.2*this.timestep:this.timestep/1.2<this.options.timestep?this.timestep=this.options.timestep:(this.adaptiveCounter=-1,this.timestep=Math.max(this.options.timestep,this.timestep/1.2))}physicsTick(){this._startStabilizing(),this.stabilized!==!0&&(this.adaptiveTimestep===!0&&this.adaptiveTimestepEnabled===!0?(this.adaptiveCounter%this.adaptiveInterval===0?(this.timestep=2*this.timestep,this.physicsStep(),this.revert(),this.timestep=.5*this.timestep,this.physicsStep(),this.physicsStep(),this.adjustTimeStep()):this.physicsStep(),this.adaptiveCounter+=1):(this.timestep=this.options.timestep,this.physicsStep()),this.stabilized===!0&&this.revert(),this.stabilizationIterations++)}updatePhysicsData(){this.physicsBody.forces={},this.physicsBody.physicsNodeIndices=[],this.physicsBody.physicsEdgeIndices=[];const e=this.body.nodes,t=this.body.edges;for(const r in e)Object.prototype.hasOwnProperty.call(e,r)&&e[r].options.physics===!0&&this.physicsBody.physicsNodeIndices.push(e[r].id);for(const r in t)Object.prototype.hasOwnProperty.call(t,r)&&t[r].options.physics===!0&&this.physicsBody.physicsEdgeIndices.push(t[r].id);for(let r=0;r<this.physicsBody.physicsNodeIndices.length;r++){const i=this.physicsBody.physicsNodeIndices[r];this.physicsBody.forces[i]={x:0,y:0},this.physicsBody.velocities[i]===void 0&&(this.physicsBody.velocities[i]={x:0,y:0})}for(const r in this.physicsBody.velocities)e[r]===void 0&&delete this.physicsBody.velocities[r]}revert(){const e=Be(this.previousStates),t=this.body.nodes,r=this.physicsBody.velocities;this.referenceState={};for(let i=0;i<e.length;i++){const o=e[i];t[o]!==void 0?t[o].options.physics===!0&&(this.referenceState[o]={positions:{x:t[o].x,y:t[o].y}},r[o].x=this.previousStates[o].vx,r[o].y=this.previousStates[o].vy,t[o].x=this.previousStates[o].x,t[o].y=this.previousStates[o].y):delete this.previousStates[o]}}_evaluateStepQuality(){let e,t,r;const i=this.body.nodes,o=this.referenceState,s=.3;for(const a in this.referenceState)if(Object.prototype.hasOwnProperty.call(this.referenceState,a)&&i[a]!==void 0&&(e=i[a].x-o[a].positions.x,t=i[a].y-o[a].positions.y,r=Math.sqrt(Math.pow(e,2)+Math.pow(t,2)),r>s))return!1;return!0}moveNodes(){const e=this.physicsBody.physicsNodeIndices;let t=0,r=0;const i=5;for(let o=0;o<e.length;o++){const s=e[o],a=this._performStep(s);t=Math.max(t,a),r+=a}this.adaptiveTimestepEnabled=r/e.length<i,this.stabilized=t<this.options.minVelocity}calculateComponentVelocity(e,t,r){const i=this.modelOptions.damping*e,o=(t-i)/r;e+=o*this.timestep;const s=this.options.maxVelocity||1e9;return Math.abs(e)>s&&(e=e>0?s:-s),e}_performStep(e){const t=this.body.nodes[e],r=this.physicsBody.forces[e];this.options.wind&&(r.x+=this.options.wind.x,r.y+=this.options.wind.y);const i=this.physicsBody.velocities[e];return this.previousStates[e]={x:t.x,y:t.y,vx:i.x,vy:i.y},t.options.fixed.x===!1?(i.x=this.calculateComponentVelocity(i.x,r.x,t.options.mass),t.x+=i.x*this.timestep):(r.x=0,i.x=0),t.options.fixed.y===!1?(i.y=this.calculateComponentVelocity(i.y,r.y,t.options.mass),t.y+=i.y*this.timestep):(r.y=0,i.y=0),Math.sqrt(Math.pow(i.x,2)+Math.pow(i.y,2))}_freezeNodes(){const e=this.body.nodes;for(const t in e)if(Object.prototype.hasOwnProperty.call(e,t)&&e[t].x&&e[t].y){const r=e[t].options.fixed;this.freezeCache[t]={x:r.x,y:r.y},r.x=!0,r.y=!0}}_restoreFrozenNodes(){const e=this.body.nodes;for(const t in e)Object.prototype.hasOwnProperty.call(e,t)&&this.freezeCache[t]!==void 0&&(e[t].options.fixed.x=this.freezeCache[t].x,e[t].options.fixed.y=this.freezeCache[t].y);this.freezeCache={}}stabilize(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.options.stabilization.iterations;if(typeof e!="number"&&(e=this.options.stabilization.iterations,console.error("The stabilize method needs a numeric amount of iterations. Switching to default: ",e)),this.physicsBody.physicsNodeIndices.length===0){this.ready=!0;return}this.adaptiveTimestep=this.options.adaptiveTimestep,this.body.emitter.emit("_resizeNodes"),this.stopSimulation(),this.stabilized=!1,this.body.emitter.emit("_blockRedraw"),this.targetIterations=e,this.options.stabilization.onlyDynamicEdges===!0&&this._freezeNodes(),this.stabilizationIterations=0,ri(()=>this._stabilizationBatch(),0)}_startStabilizing(){return this.startedStabilization===!0?!1:(this.body.emitter.emit("startStabilizing"),this.startedStabilization=!0,!0)}_stabilizationBatch(){const e=()=>this.stabilized===!1&&this.stabilizationIterations<this.targetIterations,t=()=>{this.body.emitter.emit("stabilizationProgress",{iterations:this.stabilizationIterations,total:this.targetIterations})};this._startStabilizing()&&t();let r=0;for(;e()&&r<this.options.stabilization.updateInterval;)this.physicsTick(),r++;if(t(),e()){var i;ri(z(i=this._stabilizationBatch).call(i,this),0)}else this._finalizeStabilization()}_finalizeStabilization(){this.body.emitter.emit("_allowRedraw"),this.options.stabilization.fit===!0&&this.body.emitter.emit("fit"),this.options.stabilization.onlyDynamicEdges===!0&&this._restoreFrozenNodes(),this.body.emitter.emit("stabilizationIterationsDone"),this.body.emitter.emit("_requestRedraw"),this.stabilized===!0?this._emitStabilized():this.startSimulation(),this.ready=!0}_drawForces(e){for(let t=0;t<this.physicsBody.physicsNodeIndices.length;t++){const r=this.physicsBody.physicsNodeIndices[t],i=this.body.nodes[r],o=this.physicsBody.forces[r],s=20,a=.03,g=Math.sqrt(Math.pow(o.x,2)+Math.pow(o.x,2)),A=Math.min(Math.max(5,g),15),I=3*A,C=lO((180-Math.min(1,Math.max(0,a*g))*180)/360,1,1),l={x:i.x+s*o.x,y:i.y+s*o.y};e.lineWidth=A,e.strokeStyle=C,e.beginPath(),e.moveTo(i.x,i.y),e.lineTo(l.x,l.y),e.stroke();const d=Math.atan2(o.y,o.x);e.fillStyle=C,u7.draw(e,{type:"arrow",point:l,angle:d,length:I}),cg(e).call(e)}}},Lt=class{constructor(){}static getRange(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],r=1e9,i=-1e9,o=1e9,s=-1e9,a;if(t.length>0)for(let g=0;g<t.length;g++)a=e[t[g]],o>a.shape.boundingBox.left&&(o=a.shape.boundingBox.left),s<a.shape.boundingBox.right&&(s=a.shape.boundingBox.right),r>a.shape.boundingBox.top&&(r=a.shape.boundingBox.top),i<a.shape.boundingBox.bottom&&(i=a.shape.boundingBox.bottom);return o===1e9&&s===-1e9&&r===1e9&&i===-1e9&&(r=0,i=0,o=0,s=0),{minX:o,maxX:s,minY:r,maxY:i}}static getRangeCore(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],r=1e9,i=-1e9,o=1e9,s=-1e9,a;if(t.length>0)for(let g=0;g<t.length;g++)a=e[t[g]],o>a.x&&(o=a.x),s<a.x&&(s=a.x),r>a.y&&(r=a.y),i<a.y&&(i=a.y);return o===1e9&&s===-1e9&&r===1e9&&i===-1e9&&(r=0,i=0,o=0,s=0),{minX:o,maxX:s,minY:r,maxY:i}}static findCenter(e){return{x:.5*(e.maxX+e.minX),y:.5*(e.maxY+e.minY)}}static cloneOptions(e,t){const r={};return t===void 0||t==="node"?(Me(r,e.options,!0),r.x=e.x,r.y=e.y,r.amountOfConnections=e.edges.length):Me(r,e.options,!0),r}},ICe=class extends sr{constructor(e,t,r,i,o,s){super(e,t,r,i,o,s),this.isCluster=!0,this.containedNodes={},this.containedEdges={}}_openChildCluster(e){const t=this.body.nodes[e];if(this.containedNodes[e]===void 0)throw new Error("node with id: "+e+" not in current cluster");if(!t.isCluster)throw new Error("node with id: "+e+" is not a cluster");delete this.containedNodes[e],de(t.edges,r=>{delete this.containedEdges[r.id]}),de(t.containedNodes,(r,i)=>{this.containedNodes[i]=r}),t.containedNodes={},de(t.containedEdges,(r,i)=>{this.containedEdges[i]=r}),t.containedEdges={},de(t.edges,r=>{de(this.edges,i=>{var o,s;const a=_e(o=i.clusteringEdgeReplacingIds).call(o,r.id);a!==-1&&(de(r.clusteringEdgeReplacingIds,g=>{i.clusteringEdgeReplacingIds.push(g),this.body.edges[g].edgeReplacedById=i.id}),ti(s=i.clusteringEdgeReplacingIds).call(s,a,1))})}),t.edges=[]}},CCe=class{constructor(e){this.body=e,this.clusteredNodes={},this.clusteredEdges={},this.options={},this.defaultOptions={},tt(this.options,this.defaultOptions),this.body.emitter.on("_resetData",()=>{this.clusteredNodes={},this.clusteredEdges={}})}clusterByHubsize(e,t){e===void 0?e=this._getHubSize():typeof e=="object"&&(t=this._checkOptions(e),e=this._getHubSize());const r=[];for(let i=0;i<this.body.nodeIndices.length;i++){const o=this.body.nodes[this.body.nodeIndices[i]];o.edges.length>=e&&r.push(o.id)}for(let i=0;i<r.length;i++)this.clusterByConnection(r[i],t,!0);this.body.emitter.emit("_dataChanged")}cluster(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;if(e.joinCondition===void 0)throw new Error("Cannot call clusterByNodeData without a joinCondition function in the options.");e=this._checkOptions(e);const r={},i={};de(this.body.nodes,(o,s)=>{o.options&&e.joinCondition(o.options)===!0&&(r[s]=o,de(o.edges,a=>{this.clusteredEdges[a.id]===void 0&&(i[a.id]=a)}))}),this._cluster(r,i,e,t)}clusterByEdgeCount(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0;t=this._checkOptions(t);const i=[],o={};let s,a,g;for(let A=0;A<this.body.nodeIndices.length;A++){const I={},C={},l=this.body.nodeIndices[A],d=this.body.nodes[l];if(o[l]===void 0){g=0,a=[];for(let u=0;u<d.edges.length;u++)s=d.edges[u],this.clusteredEdges[s.id]===void 0&&(s.toId!==s.fromId&&g++,a.push(s));if(g===e){const u=function(v){if(t.joinCondition===void 0||t.joinCondition===null)return!0;const f=Lt.cloneOptions(v);return t.joinCondition(f)};let h=!0;for(let v=0;v<a.length;v++){s=a[v];const f=this._getConnectedId(s,l);if(u(d))C[s.id]=s,I[l]=d,I[f]=this.body.nodes[f],o[l]=!0;else{h=!1;break}}if(Be(I).length>0&&Be(C).length>0&&h===!0){const f=function(){for(let c=0;c<i.length;++c)for(const b in I)if(i[c].nodes[b]!==void 0)return i[c]}();if(f!==void 0){for(const c in I)f.nodes[c]===void 0&&(f.nodes[c]=I[c]);for(const c in C)f.edges[c]===void 0&&(f.edges[c]=C[c])}else i.push({nodes:I,edges:C})}}}}for(let A=0;A<i.length;A++)this._cluster(i[A].nodes,i[A].edges,t,!1);r===!0&&this.body.emitter.emit("_dataChanged")}clusterOutliers(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;this.clusterByEdgeCount(1,e,t)}clusterBridges(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;this.clusterByEdgeCount(2,e,t)}clusterByConnection(e,t){var r;let i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0;if(e===void 0)throw new Error("No nodeId supplied to clusterByConnection!");if(this.body.nodes[e]===void 0)throw new Error("The nodeId given to clusterByConnection does not exist!");const o=this.body.nodes[e];t=this._checkOptions(t,o),t.clusterNodeProperties.x===void 0&&(t.clusterNodeProperties.x=o.x),t.clusterNodeProperties.y===void 0&&(t.clusterNodeProperties.y=o.y),t.clusterNodeProperties.fixed===void 0&&(t.clusterNodeProperties.fixed={},t.clusterNodeProperties.fixed.x=o.options.fixed.x,t.clusterNodeProperties.fixed.y=o.options.fixed.y);const s={},a={},g=o.id,A=Lt.cloneOptions(o);s[g]=o;for(let C=0;C<o.edges.length;C++){const l=o.edges[C];if(this.clusteredEdges[l.id]===void 0){const d=this._getConnectedId(l,g);if(this.clusteredNodes[d]===void 0)if(d!==g)if(t.joinCondition===void 0)a[l.id]=l,s[d]=this.body.nodes[d];else{const u=Lt.cloneOptions(this.body.nodes[d]);t.joinCondition(A,u)===!0&&(a[l.id]=l,s[d]=this.body.nodes[d])}else a[l.id]=l}}const I=Mt(r=Be(s)).call(r,function(C){return s[C].id});for(const C in s){if(!Object.prototype.hasOwnProperty.call(s,C))continue;const l=s[C];for(let d=0;d<l.edges.length;d++){const u=l.edges[d];_e(I).call(I,this._getConnectedId(u,l.id))>-1&&(a[u.id]=u)}}this._cluster(s,a,t,i)}_createClusterEdges(e,t,r,i){let o,s,a,g,A,I;const C=Be(e),l=[];for(let h=0;h<C.length;h++){s=C[h],a=e[s];for(let v=0;v<a.edges.length;v++)o=a.edges[v],this.clusteredEdges[o.id]===void 0&&(o.toId==o.fromId?t[o.id]=o:o.toId==s?(g=r.id,A=o.fromId,I=A):(g=o.toId,A=r.id,I=g),e[I]===void 0&&l.push({edge:o,fromId:A,toId:g}))}const d=[],u=function(h){for(let v=0;v<d.length;v++){const f=d[v],c=h.fromId===f.fromId&&h.toId===f.toId,b=h.fromId===f.toId&&h.toId===f.fromId;if(c||b)return f}return null};for(let h=0;h<l.length;h++){const v=l[h],f=v.edge;let c=u(v);c===null?(c=this._createClusteredEdge(v.fromId,v.toId,f,i),d.push(c)):c.clusteringEdgeReplacingIds.push(f.id),this.body.edges[f.id].edgeReplacedById=c.id,this._backupEdgeOptions(f),f.setOptions({physics:!1})}}_checkOptions(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return e.clusterEdgeProperties===void 0&&(e.clusterEdgeProperties={}),e.clusterNodeProperties===void 0&&(e.clusterNodeProperties={}),e}_cluster(e,t,r){let i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!0;const o=[];for(const I in e)Object.prototype.hasOwnProperty.call(e,I)&&this.clusteredNodes[I]!==void 0&&o.push(I);for(let I=0;I<o.length;++I)delete e[o[I]];if(Be(e).length==0||Be(e).length==1&&r.clusterNodeProperties.allowSingleNodeCluster!=!0)return;let s=Me({},r.clusterNodeProperties);if(r.processProperties!==void 0){const I=[];for(const l in e)if(Object.prototype.hasOwnProperty.call(e,l)){const d=Lt.cloneOptions(e[l]);I.push(d)}const C=[];for(const l in t)if(Object.prototype.hasOwnProperty.call(t,l)&&l.substr(0,12)!=="clusterEdge:"){const d=Lt.cloneOptions(t[l],"edge");C.push(d)}if(s=r.processProperties(s,I,C),!s)throw new Error("The processProperties function does not return properties!")}s.id===void 0&&(s.id="cluster:"+is());const a=s.id;s.label===void 0&&(s.label="cluster");let g;s.x===void 0&&(g=this._getClusterPosition(e),s.x=g.x),s.y===void 0&&(g===void 0&&(g=this._getClusterPosition(e)),s.y=g.y),s.id=a;const A=this.body.functions.createNode(s,ICe);A.containedNodes=e,A.containedEdges=t,A.clusterEdgeProperties=r.clusterEdgeProperties,this.body.nodes[s.id]=A,this._clusterEdges(e,t,s,r.clusterEdgeProperties),s.id=void 0,i===!0&&this.body.emitter.emit("_dataChanged")}_backupEdgeOptions(e){this.clusteredEdges[e.id]===void 0&&(this.clusteredEdges[e.id]={physics:e.options.physics})}_restoreEdge(e){const t=this.clusteredEdges[e.id];t!==void 0&&(e.setOptions({physics:t.physics}),delete this.clusteredEdges[e.id])}isCluster(e){return this.body.nodes[e]!==void 0?this.body.nodes[e].isCluster===!0:(console.error("Node does not exist."),!1)}_getClusterPosition(e){const t=Be(e);let r=e[t[0]].x,i=e[t[0]].x,o=e[t[0]].y,s=e[t[0]].y,a;for(let g=1;g<t.length;g++)a=e[t[g]],r=a.x<r?a.x:r,i=a.x>i?a.x:i,o=a.y<o?a.y:o,s=a.y>s?a.y:s;return{x:.5*(r+i),y:.5*(o+s)}}openCluster(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0;if(e===void 0)throw new Error("No clusterNodeId supplied to openCluster.");const i=this.body.nodes[e];if(i===void 0)throw new Error("The clusterNodeId supplied to openCluster does not exist.");if(i.isCluster!==!0||i.containedNodes===void 0||i.containedEdges===void 0)throw new Error("The node:"+e+" is not a valid cluster.");const o=this.findNode(e),s=_e(o).call(o,e)-1;if(s>=0){const I=o[s];this.body.nodes[I]._openChildCluster(e),delete this.body.nodes[e],r===!0&&this.body.emitter.emit("_dataChanged");return}const a=i.containedNodes,g=i.containedEdges;if(t!==void 0&&t.releaseFunction!==void 0&&typeof t.releaseFunction=="function"){const I={},C={x:i.x,y:i.y};for(const d in a)if(Object.prototype.hasOwnProperty.call(a,d)){const u=this.body.nodes[d];I[d]={x:u.x,y:u.y}}const l=t.releaseFunction(C,I);for(const d in a)if(Object.prototype.hasOwnProperty.call(a,d)){const u=this.body.nodes[d];l[d]!==void 0&&(u.x=l[d].x===void 0?i.x:l[d].x,u.y=l[d].y===void 0?i.y:l[d].y)}}else de(a,function(I){I.options.fixed.x===!1&&(I.x=i.x),I.options.fixed.y===!1&&(I.y=i.y)});for(const I in a)if(Object.prototype.hasOwnProperty.call(a,I)){const C=this.body.nodes[I];C.vx=i.vx,C.vy=i.vy,C.setOptions({physics:!0}),delete this.clusteredNodes[I]}const A=[];for(let I=0;I<i.edges.length;I++)A.push(i.edges[I]);for(let I=0;I<A.length;I++){const C=A[I],l=this._getConnectedId(C,e),d=this.clusteredNodes[l];for(let u=0;u<C.clusteringEdgeReplacingIds.length;u++){const h=C.clusteringEdgeReplacingIds[u],v=this.body.edges[h];if(v!==void 0)if(d!==void 0){const f=this.body.nodes[d.clusterId];f.containedEdges[v.id]=v,delete g[v.id];let c=v.fromId,b=v.toId;v.toId==l?b=d.clusterId:c=d.clusterId,this._createClusteredEdge(c,b,v,f.clusterEdgeProperties,{hidden:!1,physics:!0})}else this._restoreEdge(v)}C.remove()}for(const I in g)Object.prototype.hasOwnProperty.call(g,I)&&this._restoreEdge(g[I]);delete this.body.nodes[e],r===!0&&this.body.emitter.emit("_dataChanged")}getNodesInCluster(e){const t=[];if(this.isCluster(e)===!0){const r=this.body.nodes[e].containedNodes;for(const i in r)Object.prototype.hasOwnProperty.call(r,i)&&t.push(this.body.nodes[i].id)}return t}findNode(e){const t=[];let i=0,o;for(;this.clusteredNodes[e]!==void 0&&i<100;){if(o=this.body.nodes[e],o===void 0)return[];t.push(o.id),e=this.clusteredNodes[e].clusterId,i++}return o=this.body.nodes[e],o===void 0?[]:(t.push(o.id),zn(t).call(t),t)}updateClusteredNode(e,t){if(e===void 0)throw new Error("No clusteredNodeId supplied to updateClusteredNode.");if(t===void 0)throw new Error("No newOptions supplied to updateClusteredNode.");if(this.body.nodes[e]===void 0)throw new Error("The clusteredNodeId supplied to updateClusteredNode does not exist.");this.body.nodes[e].setOptions(t),this.body.emitter.emit("_dataChanged")}updateEdge(e,t){if(e===void 0)throw new Error("No startEdgeId supplied to updateEdge.");if(t===void 0)throw new Error("No newOptions supplied to updateEdge.");if(this.body.edges[e]===void 0)throw new Error("The startEdgeId supplied to updateEdge does not exist.");const r=this.getClusteredEdges(e);for(let i=0;i<r.length;i++)this.body.edges[r[i]].setOptions(t);this.body.emitter.emit("_dataChanged")}getClusteredEdges(e){const t=[];let i=0;for(;e!==void 0&&this.body.edges[e]!==void 0&&i<100;)t.push(this.body.edges[e].id),e=this.body.edges[e].edgeReplacedById,i++;return zn(t).call(t),t}getBaseEdge(e){return this.getBaseEdges(e)[0]}getBaseEdges(e){const t=[e],r=[],i=[],o=100;let s=0;for(;t.length>0&&s<o;){const a=t.pop();if(a===void 0)continue;const g=this.body.edges[a];if(g===void 0)continue;s++;const A=g.clusteringEdgeReplacingIds;if(A===void 0)i.push(a);else for(let I=0;I<A.length;++I){const C=A[I];_e(t).call(t,A)!==-1||_e(r).call(r,A)!==-1||t.push(C)}r.push(a)}return i}_getConnectedId(e,t){return e.toId!=t?e.toId:(e.fromId!=t,e.fromId)}_getHubSize(){let e=0,t=0,r=0,i=0;for(let g=0;g<this.body.nodeIndices.length;g++){const A=this.body.nodes[this.body.nodeIndices[g]];A.edges.length>i&&(i=A.edges.length),e+=A.edges.length,t+=Math.pow(A.edges.length,2),r+=1}e=e/r,t=t/r;const o=t-Math.pow(e,2),s=Math.sqrt(o);let a=Math.floor(e+2*s);return a>i&&(a=i),a}_createClusteredEdge(e,t,r,i,o){const s=Lt.cloneOptions(r,"edge");Me(s,i),s.from=e,s.to=t,s.id="clusterEdge:"+is(),o!==void 0&&Me(s,o);const a=this.body.functions.createEdge(s);return a.clusteringEdgeReplacingIds=[r.id],a.connect(),this.body.edges[a.id]=a,a}_clusterEdges(e,t,r,i){if(t instanceof ns){const o=t,s={};s[o.id]=o,t=s}if(e instanceof sr){const o=e,s={};s[o.id]=o,e=s}if(r==null)throw new Error("_clusterEdges: parameter clusterNode required");i===void 0&&(i=r.clusterEdgeProperties),this._createClusterEdges(e,t,r,i);for(const o in t)if(Object.prototype.hasOwnProperty.call(t,o)&&this.body.edges[o]!==void 0){const s=this.body.edges[o];this._backupEdgeOptions(s),s.setOptions({physics:!1})}for(const o in e)Object.prototype.hasOwnProperty.call(e,o)&&(this.clusteredNodes[o]={clusterId:r.id,node:this.body.nodes[o]},this.body.nodes[o].setOptions({physics:!1}))}_getClusterNodeForNode(e){if(e===void 0)return;const t=this.clusteredNodes[e];if(t===void 0)return;const r=t.clusterId;if(r!==void 0)return this.body.nodes[r]}_filter(e,t){const r=[];return de(e,i=>{t(i)&&r.push(i)}),r}_updateState(){let e;const t=[],r={},i=g=>{de(this.body.nodes,A=>{A.isCluster===!0&&g(A)})};for(e in this.clusteredNodes){if(!Object.prototype.hasOwnProperty.call(this.clusteredNodes,e))continue;this.body.nodes[e]===void 0&&t.push(e)}i(function(g){for(let A=0;A<t.length;A++)delete g.containedNodes[t[A]]});for(let g=0;g<t.length;g++)delete this.clusteredNodes[t[g]];de(this.clusteredEdges,g=>{const A=this.body.edges[g];(A===void 0||!A.endPointsValid())&&(r[g]=g)}),i(function(g){de(g.containedEdges,(A,I)=>{!A.endPointsValid()&&!r[I]&&(r[I]=I)})}),de(this.body.edges,(g,A)=>{let I=!0;const C=g.clusteringEdgeReplacingIds;if(C!==void 0){let l=0;de(C,d=>{const u=this.body.edges[d];u!==void 0&&u.endPointsValid()&&(l+=1)}),I=l>0}(!g.endPointsValid()||!I)&&(r[A]=A)}),i(g=>{de(r,A=>{delete g.containedEdges[A],de(g.edges,(I,C)=>{if(I.id===A){g.edges[C]=null;return}I.clusteringEdgeReplacingIds=this._filter(I.clusteringEdgeReplacingIds,function(l){return!r[l]})}),g.edges=this._filter(g.edges,function(I){return I!==null})})}),de(r,g=>{delete this.clusteredEdges[g]}),de(r,g=>{delete this.body.edges[g]});const o=Be(this.body.edges);de(o,g=>{const A=this.body.edges[g],I=this._isClusteredNode(A.fromId)||this._isClusteredNode(A.toId);if(I!==this._isClusteredEdge(A.id))if(I){const C=this._getClusterNodeForNode(A.fromId);C!==void 0&&this._clusterEdges(this.body.nodes[A.fromId],A,C);const l=this._getClusterNodeForNode(A.toId);l!==void 0&&this._clusterEdges(this.body.nodes[A.toId],A,l)}else delete this._clusterEdges[g],this._restoreEdge(A)});let s=!1,a=!0;for(;a;){const g=[];i(function(A){const I=Be(A.containedNodes).length,C=A.options.allowSingleNodeCluster===!0;(C&&I<1||!C&&I<2)&&g.push(A.id)});for(let A=0;A<g.length;++A)this.openCluster(g[A],{},!1);a=g.length>0,s=s||a}s&&this._updateState()}_isClusteredNode(e){return this.clusteredNodes[e]!==void 0}_isClusteredEdge(e){return this.clusteredEdges[e]!==void 0}},lCe=class{constructor(e,t){this.body=e,this.canvas=t,this.redrawRequested=!1,this.requestAnimationFrameRequestId=void 0,this.renderingActive=!1,this.renderRequests=0,this.allowRedraw=!0,this.dragging=!1,this.zooming=!1,this.options={},this.defaultOptions={hideEdgesOnDrag:!1,hideEdgesOnZoom:!1,hideNodesOnDrag:!1},tt(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){var e;this.body.emitter.on("dragStart",()=>{this.dragging=!0}),this.body.emitter.on("dragEnd",()=>{this.dragging=!1}),this.body.emitter.on("zoom",()=>{this.zooming=!0,window.clearTimeout(this.zoomTimeoutId),this.zoomTimeoutId=ri(()=>{var t;this.zooming=!1,z(t=this._requestRedraw).call(t,this)()},250)}),this.body.emitter.on("_resizeNodes",()=>{this._resizeNodes()}),this.body.emitter.on("_redraw",()=>{this.renderingActive===!1&&this._redraw()}),this.body.emitter.on("_blockRedraw",()=>{this.allowRedraw=!1}),this.body.emitter.on("_allowRedraw",()=>{this.allowRedraw=!0,this.redrawRequested=!1}),this.body.emitter.on("_requestRedraw",z(e=this._requestRedraw).call(e,this)),this.body.emitter.on("_startRendering",()=>{this.renderRequests+=1,this.renderingActive=!0,this._startRendering()}),this.body.emitter.on("_stopRendering",()=>{this.renderRequests-=1,this.renderingActive=this.renderRequests>0,this.requestAnimationFrameRequestId=void 0}),this.body.emitter.on("destroy",()=>{this.renderRequests=0,this.allowRedraw=!1,this.renderingActive=!1,window.cancelAnimationFrame(this.requestAnimationFrameRequestId),this.body.emitter.off()})}setOptions(e){e!==void 0&&zs(["hideEdgesOnDrag","hideEdgesOnZoom","hideNodesOnDrag"],this.options,e)}_startRendering(){if(this.renderingActive===!0&&this.requestAnimationFrameRequestId===void 0){var e;this.requestAnimationFrameRequestId=window.requestAnimationFrame(z(e=this._renderStep).call(e,this),this.simulationInterval)}}_renderStep(){this.renderingActive===!0&&(this.requestAnimationFrameRequestId=void 0,this._startRendering(),this._redraw())}redraw(){this.body.emitter.emit("setSize"),this._redraw()}_requestRedraw(){this.redrawRequested!==!0&&this.renderingActive===!1&&this.allowRedraw===!0&&(this.redrawRequested=!0,window.requestAnimationFrame(()=>{this._redraw(!1)}))}_redraw(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;if(this.allowRedraw===!0){this.body.emitter.emit("initRedraw"),this.redrawRequested=!1;const t={drawExternalLabels:null};(this.canvas.frame.canvas.width===0||this.canvas.frame.canvas.height===0)&&this.canvas.setSize(),this.canvas.setTransform();const r=this.canvas.getContext(),i=this.canvas.frame.canvas.clientWidth,o=this.canvas.frame.canvas.clientHeight;if(r.clearRect(0,0,i,o),this.canvas.frame.clientWidth===0)return;if(r.save(),r.translate(this.body.view.translation.x,this.body.view.translation.y),r.scale(this.body.view.scale,this.body.view.scale),r.beginPath(),this.body.emitter.emit("beforeDrawing",r),r.closePath(),e===!1&&(this.dragging===!1||this.dragging===!0&&this.options.hideEdgesOnDrag===!1)&&(this.zooming===!1||this.zooming===!0&&this.options.hideEdgesOnZoom===!1)&&this._drawEdges(r),this.dragging===!1||this.dragging===!0&&this.options.hideNodesOnDrag===!1){const{drawExternalLabels:s}=this._drawNodes(r,e);t.drawExternalLabels=s}e===!1&&(this.dragging===!1||this.dragging===!0&&this.options.hideEdgesOnDrag===!1)&&(this.zooming===!1||this.zooming===!0&&this.options.hideEdgesOnZoom===!1)&&this._drawArrows(r),t.drawExternalLabels!=null&&t.drawExternalLabels(),e===!1&&this._drawSelectionBox(r),r.beginPath(),this.body.emitter.emit("afterDrawing",r),r.closePath(),r.restore(),e===!0&&r.clearRect(0,0,i,o)}}_resizeNodes(){this.canvas.setTransform();const e=this.canvas.getContext();e.save(),e.translate(this.body.view.translation.x,this.body.view.translation.y),e.scale(this.body.view.scale,this.body.view.scale);const t=this.body.nodes;let r;for(const i in t)Object.prototype.hasOwnProperty.call(t,i)&&(r=t[i],r.resize(e),r.updateBoundingBox(e,r.selected));e.restore()}_drawNodes(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;const r=this.body.nodes,i=this.body.nodeIndices;let o;const s=[],a=[],g=20,A=this.canvas.DOMtoCanvas({x:-g,y:-g}),I=this.canvas.DOMtoCanvas({x:this.canvas.frame.canvas.clientWidth+g,y:this.canvas.frame.canvas.clientHeight+g}),C={top:A.y,left:A.x,bottom:I.y,right:I.x},l=[];for(let v=0;v<i.length;v++)if(o=r[i[v]],o.hover)a.push(i[v]);else if(o.isSelected())s.push(i[v]);else if(t===!0){const f=o.draw(e);f.drawExternalLabel!=null&&l.push(f.drawExternalLabel)}else if(o.isBoundingBoxOverlappingWith(C)===!0){const f=o.draw(e);f.drawExternalLabel!=null&&l.push(f.drawExternalLabel)}else o.updateBoundingBox(e,o.selected);let d;const u=s.length,h=a.length;for(d=0;d<u;d++){o=r[s[d]];const v=o.draw(e);v.drawExternalLabel!=null&&l.push(v.drawExternalLabel)}for(d=0;d<h;d++){o=r[a[d]];const v=o.draw(e);v.drawExternalLabel!=null&&l.push(v.drawExternalLabel)}return{drawExternalLabels:()=>{for(const v of l)v()}}}_drawEdges(e){const t=this.body.edges,r=this.body.edgeIndices;for(let i=0;i<r.length;i++){const o=t[r[i]];o.connected===!0&&o.draw(e)}}_drawArrows(e){const t=this.body.edges,r=this.body.edgeIndices;for(let i=0;i<r.length;i++){const o=t[r[i]];o.connected===!0&&o.drawArrows(e)}}_drawSelectionBox(e){if(this.body.selectionBox.show){e.beginPath();const t=this.body.selectionBox.position.end.x-this.body.selectionBox.position.start.x,r=this.body.selectionBox.position.end.y-this.body.selectionBox.position.start.y;e.rect(this.body.selectionBox.position.start.x,this.body.selectionBox.position.start.y,t,r),e.fillStyle="rgba(151, 194, 252, 0.2)",e.fillRect(this.body.selectionBox.position.start.x,this.body.selectionBox.position.start.y,t,r),e.strokeStyle="rgba(151, 194, 252, 1)",e.stroke()}else e.closePath()}};var yf,Bk;function dCe(){if(Bk)return yf;Bk=1,CQ();var n=Ee();return yf=n.setInterval,yf}var bf,zk;function uCe(){return zk||(zk=1,bf=dCe()),bf}var hCe=uCe(),cCe=ne(hCe);function WA(n,e){e.inputHandler=function(t){t.isFirst&&e(t)},n.on("hammer.input",e.inputHandler)}function p7(n,e){return e.inputHandler=function(t){t.isFinal&&e(t)},n.on("hammer.input",e.inputHandler)}let fCe=class{constructor(e){this.body=e,this.pixelRatio=1,this.cameraState={},this.initialized=!1,this.canvasViewCenter={},this._cleanupCallbacks=[],this.options={},this.defaultOptions={autoResize:!0,height:"100%",width:"100%"},tt(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){var e;this.body.emitter.once("resize",t=>{t.width!==0&&(this.body.view.translation.x=t.width*.5),t.height!==0&&(this.body.view.translation.y=t.height*.5)}),this.body.emitter.on("setSize",z(e=this.setSize).call(e,this)),this.body.emitter.on("destroy",()=>{this.hammerFrame.destroy(),this.hammer.destroy(),this._cleanUp()})}setOptions(e){if(e!==void 0&&zs(["width","height","autoResize"],this.options,e),this._cleanUp(),this.options.autoResize===!0){var t;if(window.ResizeObserver){const i=new ResizeObserver(()=>{this.setSize()===!0&&this.body.emitter.emit("_requestRedraw")}),{frame:o}=this;i.observe(o),this._cleanupCallbacks.push(()=>{i.unobserve(o)})}else{const i=cCe(()=>{this.setSize()===!0&&this.body.emitter.emit("_requestRedraw")},1e3);this._cleanupCallbacks.push(()=>{clearInterval(i)})}const r=z(t=this._onResize).call(t,this);window.addEventListener("resize",r),this._cleanupCallbacks.push(()=>{window.removeEventListener("resize",r)})}}_cleanUp(){var e,t,r;be(e=zn(t=ti(r=this._cleanupCallbacks).call(r,0)).call(t)).call(e,i=>{try{i()}catch(o){console.error(o)}})}_onResize(){this.setSize(),this.body.emitter.emit("_redraw")}_getCameraState(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.pixelRatio;this.initialized===!0&&(this.cameraState.previousWidth=this.frame.canvas.width/e,this.cameraState.previousHeight=this.frame.canvas.height/e,this.cameraState.scale=this.body.view.scale,this.cameraState.position=this.DOMtoCanvas({x:.5*this.frame.canvas.width/e,y:.5*this.frame.canvas.height/e}))}_setCameraState(){if(this.cameraState.scale!==void 0&&this.frame.canvas.clientWidth!==0&&this.frame.canvas.clientHeight!==0&&this.pixelRatio!==0&&this.cameraState.previousWidth>0&&this.cameraState.previousHeight>0){const e=this.frame.canvas.width/this.pixelRatio/this.cameraState.previousWidth,t=this.frame.canvas.height/this.pixelRatio/this.cameraState.previousHeight;let r=this.cameraState.scale;e!=1&&t!=1?r=this.cameraState.scale*.5*(e+t):e!=1?r=this.cameraState.scale*e:t!=1&&(r=this.cameraState.scale*t),this.body.view.scale=r;const i=this.DOMtoCanvas({x:.5*this.frame.canvas.clientWidth,y:.5*this.frame.canvas.clientHeight}),o={x:i.x-this.cameraState.position.x,y:i.y-this.cameraState.position.y};this.body.view.translation.x+=o.x*this.body.view.scale,this.body.view.translation.y+=o.y*this.body.view.scale}}_prepareValue(e){if(typeof e=="number")return e+"px";if(typeof e=="string"){if(_e(e).call(e,"%")!==-1||_e(e).call(e,"px")!==-1)return e;if(_e(e).call(e,"%")===-1)return e+"px"}throw new Error("Could not use the value supplied for width or height:"+e)}_create(){for(;this.body.container.hasChildNodes();)this.body.container.removeChild(this.body.container.firstChild);if(this.frame=document.createElement("div"),this.frame.className="vis-network",this.frame.style.position="relative",this.frame.style.overflow="hidden",this.frame.tabIndex=0,this.frame.canvas=document.createElement("canvas"),this.frame.canvas.style.position="relative",this.frame.appendChild(this.frame.canvas),this.frame.canvas.getContext)this._setPixelRatio(),this.setTransform();else{const e=document.createElement("DIV");e.style.color="red",e.style.fontWeight="bold",e.style.padding="10px",e.innerText="Error: your browser does not support HTML canvas",this.frame.canvas.appendChild(e)}this.body.container.appendChild(this.frame),this.body.view.scale=1,this.body.view.translation={x:.5*this.frame.canvas.clientWidth,y:.5*this.frame.canvas.clientHeight},this._bindHammer()}_bindHammer(){this.hammer!==void 0&&this.hammer.destroy(),this.drag={},this.pinch={},this.hammer=new rs(this.frame.canvas),this.hammer.get("pinch").set({enable:!0}),this.hammer.get("pan").set({threshold:5,direction:rs.DIRECTION_ALL}),WA(this.hammer,e=>{this.body.eventListeners.onTouch(e)}),this.hammer.on("tap",e=>{this.body.eventListeners.onTap(e)}),this.hammer.on("doubletap",e=>{this.body.eventListeners.onDoubleTap(e)}),this.hammer.on("press",e=>{this.body.eventListeners.onHold(e)}),this.hammer.on("panstart",e=>{this.body.eventListeners.onDragStart(e)}),this.hammer.on("panmove",e=>{this.body.eventListeners.onDrag(e)}),this.hammer.on("panend",e=>{this.body.eventListeners.onDragEnd(e)}),this.hammer.on("pinch",e=>{this.body.eventListeners.onPinch(e)}),this.frame.canvas.addEventListener("wheel",e=>{this.body.eventListeners.onMouseWheel(e)}),this.frame.canvas.addEventListener("mousemove",e=>{this.body.eventListeners.onMouseMove(e)}),this.frame.canvas.addEventListener("contextmenu",e=>{this.body.eventListeners.onContext(e)}),this.hammerFrame=new rs(this.frame),p7(this.hammerFrame,e=>{this.body.eventListeners.onRelease(e)})}setSize(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.options.width,t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.options.height;e=this._prepareValue(e),t=this._prepareValue(t);let r=!1;const i=this.frame.canvas.width,o=this.frame.canvas.height,s=this.pixelRatio;if(this._setPixelRatio(),e!=this.options.width||t!=this.options.height||this.frame.style.width!=e||this.frame.style.height!=t)this._getCameraState(s),this.frame.style.width=e,this.frame.style.height=t,this.frame.canvas.style.width="100%",this.frame.canvas.style.height="100%",this.frame.canvas.width=Math.round(this.frame.canvas.clientWidth*this.pixelRatio),this.frame.canvas.height=Math.round(this.frame.canvas.clientHeight*this.pixelRatio),this.options.width=e,this.options.height=t,this.canvasViewCenter={x:.5*this.frame.clientWidth,y:.5*this.frame.clientHeight},r=!0;else{const a=Math.round(this.frame.canvas.clientWidth*this.pixelRatio),g=Math.round(this.frame.canvas.clientHeight*this.pixelRatio);(this.frame.canvas.width!==a||this.frame.canvas.height!==g)&&this._getCameraState(s),this.frame.canvas.width!==a&&(this.frame.canvas.width=a,r=!0),this.frame.canvas.height!==g&&(this.frame.canvas.height=g,r=!0)}return r===!0&&(this.body.emitter.emit("resize",{width:Math.round(this.frame.canvas.width/this.pixelRatio),height:Math.round(this.frame.canvas.height/this.pixelRatio),oldWidth:Math.round(i/this.pixelRatio),oldHeight:Math.round(o/this.pixelRatio)}),this._setCameraState()),this.initialized=!0,r}getContext(){return this.frame.canvas.getContext("2d")}_determinePixelRatio(){const e=this.getContext();if(e===void 0)throw new Error("Could not get canvax context");let t=1;typeof window<"u"&&(t=window.devicePixelRatio||1);const r=e.webkitBackingStorePixelRatio||e.mozBackingStorePixelRatio||e.msBackingStorePixelRatio||e.oBackingStorePixelRatio||e.backingStorePixelRatio||1;return t/r}_setPixelRatio(){this.pixelRatio=this._determinePixelRatio()}setTransform(){const e=this.getContext();if(e===void 0)throw new Error("Could not get canvax context");e.setTransform(this.pixelRatio,0,0,this.pixelRatio,0,0)}_XconvertDOMtoCanvas(e){return(e-this.body.view.translation.x)/this.body.view.scale}_XconvertCanvasToDOM(e){return e*this.body.view.scale+this.body.view.translation.x}_YconvertDOMtoCanvas(e){return(e-this.body.view.translation.y)/this.body.view.scale}_YconvertCanvasToDOM(e){return e*this.body.view.scale+this.body.view.translation.y}canvasToDOM(e){return{x:this._XconvertCanvasToDOM(e.x),y:this._YconvertCanvasToDOM(e.y)}}DOMtoCanvas(e){return{x:this._XconvertDOMtoCanvas(e.x),y:this._YconvertDOMtoCanvas(e.y)}}};function pCe(n,e){const t=tt({nodes:e,minZoomLevel:Number.MIN_VALUE,maxZoomLevel:1},n??{});if(!we(t.nodes))throw new TypeError("Nodes has to be an array of ids.");if(t.nodes.length===0&&(t.nodes=e),!(typeof t.minZoomLevel=="number"&&t.minZoomLevel>0))throw new TypeError("Min zoom level has to be a number higher than zero.");if(!(typeof t.maxZoomLevel=="number"&&t.minZoomLevel<=t.maxZoomLevel))throw new TypeError("Max zoom level has to be a number higher than min zoom level.");return t}let vCe=class{constructor(e,t){var r,i;this.body=e,this.canvas=t,this.animationSpeed=1/this.renderRefreshRate,this.animationEasingFunction="easeInOutQuint",this.easingTime=0,this.sourceScale=0,this.targetScale=0,this.sourceTranslation=0,this.targetTranslation=0,this.lockedOnNodeId=void 0,this.lockedOnNodeOffset=void 0,this.touchTime=0,this.viewFunction=void 0,this.body.emitter.on("fit",z(r=this.fit).call(r,this)),this.body.emitter.on("animationFinished",()=>{this.body.emitter.emit("_stopRendering")}),this.body.emitter.on("unlockNode",z(i=this.releaseNode).call(i,this))}setOptions(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};this.options=e}fit(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;e=pCe(e,this.body.nodeIndices);const r=this.canvas.frame.canvas.clientWidth,i=this.canvas.frame.canvas.clientHeight;let o,s;if(r===0||i===0)s=1,o=Lt.getRange(this.body.nodes,e.nodes);else if(t===!0){let A=0;for(const l in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,l)&&this.body.nodes[l].predefinedPosition===!0&&(A+=1);if(A>.5*this.body.nodeIndices.length){this.fit(e,!1);return}o=Lt.getRange(this.body.nodes,e.nodes),s=12.662/(this.body.nodeIndices.length+7.4147)+.0964822;const C=Math.min(r/600,i/600);s*=C}else{this.body.emitter.emit("_resizeNodes"),o=Lt.getRange(this.body.nodes,e.nodes);const A=Math.abs(o.maxX-o.minX)*1.1,I=Math.abs(o.maxY-o.minY)*1.1,C=r/A,l=i/I;s=C<=l?C:l}s>e.maxZoomLevel?s=e.maxZoomLevel:s<e.minZoomLevel&&(s=e.minZoomLevel);const g={position:Lt.findCenter(o),scale:s,animation:e.animation};this.moveTo(g)}focus(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};if(this.body.nodes[e]!==void 0){const r={x:this.body.nodes[e].x,y:this.body.nodes[e].y};t.position=r,t.lockedOnNode=e,this.moveTo(t)}else console.error("Node: "+e+" cannot be found.")}moveTo(e){if(e===void 0){e={};return}if(e.offset!=null){if(e.offset.x!=null){if(e.offset.x=+e.offset.x,!Nn(e.offset.x))throw new TypeError('The option "offset.x" has to be a finite number.')}else e.offset.x=0;if(e.offset.y!=null){if(e.offset.y=+e.offset.y,!Nn(e.offset.y))throw new TypeError('The option "offset.y" has to be a finite number.')}else e.offset.x=0}else e.offset={x:0,y:0};if(e.position!=null){if(e.position.x!=null){if(e.position.x=+e.position.x,!Nn(e.position.x))throw new TypeError('The option "position.x" has to be a finite number.')}else e.position.x=0;if(e.position.y!=null){if(e.position.y=+e.position.y,!Nn(e.position.y))throw new TypeError('The option "position.y" has to be a finite number.')}else e.position.x=0}else e.position=this.getViewPosition();if(e.scale!=null){if(e.scale=+e.scale,!(e.scale>0))throw new TypeError('The option "scale" has to be a number greater than zero.')}else e.scale=this.body.view.scale;e.animation===void 0&&(e.animation={duration:0}),e.animation===!1&&(e.animation={duration:0}),e.animation===!0&&(e.animation={}),e.animation.duration===void 0&&(e.animation.duration=1e3),e.animation.easingFunction===void 0&&(e.animation.easingFunction="easeInOutQuad"),this.animateView(e)}animateView(e){if(e===void 0)return;this.animationEasingFunction=e.animation.easingFunction,this.releaseNode(),e.locked===!0&&(this.lockedOnNodeId=e.lockedOnNode,this.lockedOnNodeOffset=e.offset),this.easingTime!=0&&this._transitionRedraw(!0),this.sourceScale=this.body.view.scale,this.sourceTranslation=this.body.view.translation,this.targetScale=e.scale,this.body.view.scale=this.targetScale;const t=this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight}),r={x:t.x-e.position.x,y:t.y-e.position.y};if(this.targetTranslation={x:this.sourceTranslation.x+r.x*this.targetScale+e.offset.x,y:this.sourceTranslation.y+r.y*this.targetScale+e.offset.y},e.animation.duration===0)if(this.lockedOnNodeId!=null){var i;this.viewFunction=z(i=this._lockedRedraw).call(i,this),this.body.emitter.on("initRedraw",this.viewFunction)}else this.body.view.scale=this.targetScale,this.body.view.translation=this.targetTranslation,this.body.emitter.emit("_requestRedraw");else{var o;this.animationSpeed=1/(60*e.animation.duration*.001)||1/60,this.animationEasingFunction=e.animation.easingFunction,this.viewFunction=z(o=this._transitionRedraw).call(o,this),this.body.emitter.on("initRedraw",this.viewFunction),this.body.emitter.emit("_startRendering")}}_lockedRedraw(){const e={x:this.body.nodes[this.lockedOnNodeId].x,y:this.body.nodes[this.lockedOnNodeId].y},t=this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight}),r={x:t.x-e.x,y:t.y-e.y},i=this.body.view.translation,o={x:i.x+r.x*this.body.view.scale+this.lockedOnNodeOffset.x,y:i.y+r.y*this.body.view.scale+this.lockedOnNodeOffset.y};this.body.view.translation=o}releaseNode(){this.lockedOnNodeId!==void 0&&this.viewFunction!==void 0&&(this.body.emitter.off("initRedraw",this.viewFunction),this.lockedOnNodeId=void 0,this.lockedOnNodeOffset=void 0)}_transitionRedraw(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;this.easingTime+=this.animationSpeed,this.easingTime=e===!0?1:this.easingTime;const t=yse[this.animationEasingFunction](this.easingTime);if(this.body.view.scale=this.sourceScale+(this.targetScale-this.sourceScale)*t,this.body.view.translation={x:this.sourceTranslation.x+(this.targetTranslation.x-this.sourceTranslation.x)*t,y:this.sourceTranslation.y+(this.targetTranslation.y-this.sourceTranslation.y)*t},this.easingTime>=1){if(this.body.emitter.off("initRedraw",this.viewFunction),this.easingTime=0,this.lockedOnNodeId!=null){var r;this.viewFunction=z(r=this._lockedRedraw).call(r,this),this.body.emitter.on("initRedraw",this.viewFunction)}this.body.emitter.emit("animationFinished")}}getScale(){return this.body.view.scale}getViewPosition(){return this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight})}};function jk(n){var e=n&&n.preventDefault||!1,t=n&&n.container||window,r={},i={keydown:{},keyup:{}},o={},s;for(s=97;s<=122;s++)o[String.fromCharCode(s)]={code:65+(s-97),shift:!1};for(s=65;s<=90;s++)o[String.fromCharCode(s)]={code:s,shift:!0};for(s=0;s<=9;s++)o[""+s]={code:48+s,shift:!1};for(s=1;s<=12;s++)o["F"+s]={code:111+s,shift:!1};for(s=0;s<=9;s++)o["num"+s]={code:96+s,shift:!1};o["num*"]={code:106,shift:!1},o["num+"]={code:107,shift:!1},o["num-"]={code:109,shift:!1},o["num/"]={code:111,shift:!1},o["num."]={code:110,shift:!1},o.left={code:37,shift:!1},o.up={code:38,shift:!1},o.right={code:39,shift:!1},o.down={code:40,shift:!1},o.space={code:32,shift:!1},o.enter={code:13,shift:!1},o.shift={code:16,shift:void 0},o.esc={code:27,shift:!1},o.backspace={code:8,shift:!1},o.tab={code:9,shift:!1},o.ctrl={code:17,shift:!1},o.alt={code:18,shift:!1},o.delete={code:46,shift:!1},o.pageup={code:33,shift:!1},o.pagedown={code:34,shift:!1},o["="]={code:187,shift:!1},o["-"]={code:189,shift:!1},o["]"]={code:221,shift:!1},o["["]={code:219,shift:!1};var a=function(I){A(I,"keydown")},g=function(I){A(I,"keyup")},A=function(I,C){if(i[C][I.keyCode]!==void 0){for(var l=i[C][I.keyCode],d=0;d<l.length;d++)(l[d].shift===void 0||l[d].shift==!0&&I.shiftKey==!0||l[d].shift==!1&&I.shiftKey==!1)&&l[d].fn(I);e==!0&&I.preventDefault()}};return r.bind=function(I,C,l){if(l===void 0&&(l="keydown"),o[I]===void 0)throw new Error("unsupported key: "+I);i[l][o[I].code]===void 0&&(i[l][o[I].code]=[]),i[l][o[I].code].push({fn:C,shift:o[I].shift})},r.bindAll=function(I,C){C===void 0&&(C="keydown");for(var l in o)o.hasOwnProperty(l)&&r.bind(l,I,C)},r.getKey=function(I){for(var C in o)if(o.hasOwnProperty(C)){if(I.shiftKey==!0&&o[C].shift==!0&&I.keyCode==o[C].code)return C;if(I.shiftKey==!1&&o[C].shift==!1&&I.keyCode==o[C].code)return C;if(I.keyCode==o[C].code&&C=="shift")return C}return"unknown key, currently not supported"},r.unbind=function(I,C,l){if(l===void 0&&(l="keydown"),o[I]===void 0)throw new Error("unsupported key: "+I);if(C!==void 0){var d=[],u=i[l][o[I].code];if(u!==void 0)for(var h=0;h<u.length;h++)u[h].fn==C&&u[h].shift==o[I].shift||d.push(i[l][o[I].code][h]);i[l][o[I].code]=d}else i[l][o[I].code]=[]},r.reset=function(){i={keydown:{},keyup:{}}},r.destroy=function(){i={keydown:{},keyup:{}},t.removeEventListener("keydown",a,!0),t.removeEventListener("keyup",g,!0)},t.addEventListener("keydown",a,!0),t.addEventListener("keyup",g,!0),r}let mCe=class{constructor(e,t){this.body=e,this.canvas=t,this.iconsCreated=!1,this.navigationHammers=[],this.boundFunctions={},this.touchTime=0,this.activated=!1,this.body.emitter.on("activate",()=>{this.activated=!0,this.configureKeyboardBindings()}),this.body.emitter.on("deactivate",()=>{this.activated=!1,this.configureKeyboardBindings()}),this.body.emitter.on("destroy",()=>{this.keycharm!==void 0&&this.keycharm.destroy()}),this.options={}}setOptions(e){e!==void 0&&(this.options=e,this.create())}create(){this.options.navigationButtons===!0?this.iconsCreated===!1&&this.loadNavigationElements():this.iconsCreated===!0&&this.cleanNavigation(),this.configureKeyboardBindings()}cleanNavigation(){if(this.navigationHammers.length!=0){for(let e=0;e<this.navigationHammers.length;e++)this.navigationHammers[e].destroy();this.navigationHammers=[]}this.navigationDOM&&this.navigationDOM.wrapper&&this.navigationDOM.wrapper.parentNode&&this.navigationDOM.wrapper.parentNode.removeChild(this.navigationDOM.wrapper),this.iconsCreated=!1}loadNavigationElements(){this.cleanNavigation(),this.navigationDOM={};const e=["up","down","left","right","zoomIn","zoomOut","zoomExtends"],t=["_moveUp","_moveDown","_moveLeft","_moveRight","_zoomIn","_zoomOut","_fit"];this.navigationDOM.wrapper=document.createElement("div"),this.navigationDOM.wrapper.className="vis-navigation",this.canvas.frame.appendChild(this.navigationDOM.wrapper);for(let s=0;s<e.length;s++){this.navigationDOM[e[s]]=document.createElement("div"),this.navigationDOM[e[s]].className="vis-button vis-"+e[s],this.navigationDOM.wrapper.appendChild(this.navigationDOM[e[s]]);const a=new rs(this.navigationDOM[e[s]]);if(t[s]==="_fit"){var r;WA(a,z(r=this._fit).call(r,this))}else{var i;WA(a,z(i=this.bindToRedraw).call(i,this,t[s]))}this.navigationHammers.push(a)}const o=new rs(this.canvas.frame);p7(o,()=>{this._stopMovement()}),this.navigationHammers.push(o),this.iconsCreated=!0}bindToRedraw(e){if(this.boundFunctions[e]===void 0){var t;this.boundFunctions[e]=z(t=this[e]).call(t,this),this.body.emitter.on("initRedraw",this.boundFunctions[e]),this.body.emitter.emit("_startRendering")}}unbindFromRedraw(e){this.boundFunctions[e]!==void 0&&(this.body.emitter.off("initRedraw",this.boundFunctions[e]),this.body.emitter.emit("_stopRendering"),delete this.boundFunctions[e])}_fit(){new Date().valueOf()-this.touchTime>700&&(this.body.emitter.emit("fit",{duration:700}),this.touchTime=new Date().valueOf())}_stopMovement(){for(const e in this.boundFunctions)Object.prototype.hasOwnProperty.call(this.boundFunctions,e)&&(this.body.emitter.off("initRedraw",this.boundFunctions[e]),this.body.emitter.emit("_stopRendering"));this.boundFunctions={}}_moveUp(){this.body.view.translation.y+=this.options.keyboard.speed.y}_moveDown(){this.body.view.translation.y-=this.options.keyboard.speed.y}_moveLeft(){this.body.view.translation.x+=this.options.keyboard.speed.x}_moveRight(){this.body.view.translation.x-=this.options.keyboard.speed.x}_zoomIn(){const e=this.body.view.scale,t=this.body.view.scale*(1+this.options.keyboard.speed.zoom),r=this.body.view.translation,i=t/e,o=(1-i)*this.canvas.canvasViewCenter.x+r.x*i,s=(1-i)*this.canvas.canvasViewCenter.y+r.y*i;this.body.view.scale=t,this.body.view.translation={x:o,y:s},this.body.emitter.emit("zoom",{direction:"+",scale:this.body.view.scale,pointer:null})}_zoomOut(){const e=this.body.view.scale,t=this.body.view.scale/(1+this.options.keyboard.speed.zoom),r=this.body.view.translation,i=t/e,o=(1-i)*this.canvas.canvasViewCenter.x+r.x*i,s=(1-i)*this.canvas.canvasViewCenter.y+r.y*i;this.body.view.scale=t,this.body.view.translation={x:o,y:s},this.body.emitter.emit("zoom",{direction:"-",scale:this.body.view.scale,pointer:null})}configureKeyboardBindings(){if(this.keycharm!==void 0&&this.keycharm.destroy(),this.options.keyboard.enabled===!0&&(this.options.keyboard.bindToWindow===!0?this.keycharm=jk({container:window,preventDefault:!0}):this.keycharm=jk({container:this.canvas.frame,preventDefault:!0}),this.keycharm.reset(),this.activated===!0)){var e,t,r,i,o,s,a,g,A,I,C,l,d,u,h,v,f,c,b,p,y,E,S,m;z(e=this.keycharm).call(e,"up",()=>{this.bindToRedraw("_moveUp")},"keydown"),z(t=this.keycharm).call(t,"down",()=>{this.bindToRedraw("_moveDown")},"keydown"),z(r=this.keycharm).call(r,"left",()=>{this.bindToRedraw("_moveLeft")},"keydown"),z(i=this.keycharm).call(i,"right",()=>{this.bindToRedraw("_moveRight")},"keydown"),z(o=this.keycharm).call(o,"=",()=>{this.bindToRedraw("_zoomIn")},"keydown"),z(s=this.keycharm).call(s,"num+",()=>{this.bindToRedraw("_zoomIn")},"keydown"),z(a=this.keycharm).call(a,"num-",()=>{this.bindToRedraw("_zoomOut")},"keydown"),z(g=this.keycharm).call(g,"-",()=>{this.bindToRedraw("_zoomOut")},"keydown"),z(A=this.keycharm).call(A,"[",()=>{this.bindToRedraw("_zoomOut")},"keydown"),z(I=this.keycharm).call(I,"]",()=>{this.bindToRedraw("_zoomIn")},"keydown"),z(C=this.keycharm).call(C,"pageup",()=>{this.bindToRedraw("_zoomIn")},"keydown"),z(l=this.keycharm).call(l,"pagedown",()=>{this.bindToRedraw("_zoomOut")},"keydown"),z(d=this.keycharm).call(d,"up",()=>{this.unbindFromRedraw("_moveUp")},"keyup"),z(u=this.keycharm).call(u,"down",()=>{this.unbindFromRedraw("_moveDown")},"keyup"),z(h=this.keycharm).call(h,"left",()=>{this.unbindFromRedraw("_moveLeft")},"keyup"),z(v=this.keycharm).call(v,"right",()=>{this.unbindFromRedraw("_moveRight")},"keyup"),z(f=this.keycharm).call(f,"=",()=>{this.unbindFromRedraw("_zoomIn")},"keyup"),z(c=this.keycharm).call(c,"num+",()=>{this.unbindFromRedraw("_zoomIn")},"keyup"),z(b=this.keycharm).call(b,"num-",()=>{this.unbindFromRedraw("_zoomOut")},"keyup"),z(p=this.keycharm).call(p,"-",()=>{this.unbindFromRedraw("_zoomOut")},"keyup"),z(y=this.keycharm).call(y,"[",()=>{this.unbindFromRedraw("_zoomOut")},"keyup"),z(E=this.keycharm).call(E,"]",()=>{this.unbindFromRedraw("_zoomIn")},"keyup"),z(S=this.keycharm).call(S,"pageup",()=>{this.unbindFromRedraw("_zoomIn")},"keyup"),z(m=this.keycharm).call(m,"pagedown",()=>{this.unbindFromRedraw("_zoomOut")},"keyup")}}},yCe=class{constructor(e,t,r){var i,o,s,a,g,A,I,C,l,d,u,h,v;this.body=e,this.canvas=t,this.selectionHandler=r,this.navigationHandler=new mCe(e,t),this.body.eventListeners.onTap=z(i=this.onTap).call(i,this),this.body.eventListeners.onTouch=z(o=this.onTouch).call(o,this),this.body.eventListeners.onDoubleTap=z(s=this.onDoubleTap).call(s,this),this.body.eventListeners.onHold=z(a=this.onHold).call(a,this),this.body.eventListeners.onDragStart=z(g=this.onDragStart).call(g,this),this.body.eventListeners.onDrag=z(A=this.onDrag).call(A,this),this.body.eventListeners.onDragEnd=z(I=this.onDragEnd).call(I,this),this.body.eventListeners.onMouseWheel=z(C=this.onMouseWheel).call(C,this),this.body.eventListeners.onPinch=z(l=this.onPinch).call(l,this),this.body.eventListeners.onMouseMove=z(d=this.onMouseMove).call(d,this),this.body.eventListeners.onRelease=z(u=this.onRelease).call(u,this),this.body.eventListeners.onContext=z(h=this.onContext).call(h,this),this.touchTime=0,this.drag={},this.pinch={},this.popup=void 0,this.popupObj=void 0,this.popupTimer=void 0,this.body.functions.getPointer=z(v=this.getPointer).call(v,this),this.options={},this.defaultOptions={dragNodes:!0,dragView:!0,hover:!1,keyboard:{enabled:!1,speed:{x:10,y:10,zoom:.02},bindToWindow:!0,autoFocus:!0},navigationButtons:!1,tooltipDelay:300,zoomView:!0,zoomSpeed:1},tt(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){this.body.emitter.on("destroy",()=>{clearTimeout(this.popupTimer),delete this.body.functions.getPointer})}setOptions(e){e!==void 0&&(zA(["hideEdgesOnDrag","hideEdgesOnZoom","hideNodesOnDrag","keyboard","multiselect","selectable","selectConnectedEdges"],this.options,e),dr(this.options,e,"keyboard"),e.tooltip&&(tt(this.options.tooltip,e.tooltip),e.tooltip.color&&(this.options.tooltip.color=CO(e.tooltip.color)))),this.navigationHandler.setOptions(this.options)}getPointer(e){return{x:e.x-fse(this.canvas.frame.canvas),y:e.y-pse(this.canvas.frame.canvas)}}onTouch(e){new Date().valueOf()-this.touchTime>50&&(this.drag.pointer=this.getPointer(e.center),this.drag.pinched=!1,this.pinch.scale=this.body.view.scale,this.touchTime=new Date().valueOf())}onTap(e){const t=this.getPointer(e.center),r=this.selectionHandler.options.multiselect&&(e.changedPointers[0].ctrlKey||e.changedPointers[0].metaKey);this.checkSelectionChanges(t,r),this.selectionHandler.commitAndEmit(t,e),this.selectionHandler.generateClickEvent("click",e,t)}onDoubleTap(e){const t=this.getPointer(e.center);this.selectionHandler.generateClickEvent("doubleClick",e,t)}onHold(e){const t=this.getPointer(e.center),r=this.selectionHandler.options.multiselect;this.checkSelectionChanges(t,r),this.selectionHandler.commitAndEmit(t,e),this.selectionHandler.generateClickEvent("click",e,t),this.selectionHandler.generateClickEvent("hold",e,t)}onRelease(e){if(new Date().valueOf()-this.touchTime>10){const t=this.getPointer(e.center);this.selectionHandler.generateClickEvent("release",e,t),this.touchTime=new Date().valueOf()}}onContext(e){const t=this.getPointer({x:e.clientX,y:e.clientY});this.selectionHandler.generateClickEvent("oncontext",e,t)}checkSelectionChanges(e){(arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1)===!0?this.selectionHandler.selectAdditionalOnPoint(e):this.selectionHandler.selectOnPoint(e)}_determineDifference(e,t){const r=function(i,o){const s=[];for(let a=0;a<i.length;a++){const g=i[a];_e(o).call(o,g)===-1&&s.push(g)}return s};return{nodes:r(e.nodes,t.nodes),edges:r(e.edges,t.edges)}}onDragStart(e){if(this.drag.dragging)return;this.drag.pointer===void 0&&this.onTouch(e);const t=this.selectionHandler.getNodeAt(this.drag.pointer);if(this.drag.dragging=!0,this.drag.selection=[],this.drag.translation=tt({},this.body.view.translation),this.drag.nodeId=void 0,e.srcEvent.shiftKey){this.body.selectionBox.show=!0;const r=this.getPointer(e.center);this.body.selectionBox.position.start={x:this.canvas._XconvertDOMtoCanvas(r.x),y:this.canvas._YconvertDOMtoCanvas(r.y)},this.body.selectionBox.position.end={x:this.canvas._XconvertDOMtoCanvas(r.x),y:this.canvas._YconvertDOMtoCanvas(r.y)}}else if(t!==void 0&&this.options.dragNodes===!0){this.drag.nodeId=t.id,t.isSelected()===!1&&this.selectionHandler.setSelection({nodes:[t.id]}),this.selectionHandler.generateClickEvent("dragStart",e,this.drag.pointer);for(const r of this.selectionHandler.getSelectedNodes()){const i={id:r.id,node:r,x:r.x,y:r.y,xFixed:r.options.fixed.x,yFixed:r.options.fixed.y};r.options.fixed.x=!0,r.options.fixed.y=!0,this.drag.selection.push(i)}}else this.selectionHandler.generateClickEvent("dragStart",e,this.drag.pointer,void 0,!0)}onDrag(e){if(this.drag.pinched===!0)return;this.body.emitter.emit("unlockNode");const t=this.getPointer(e.center),r=this.drag.selection;if(r&&r.length&&this.options.dragNodes===!0){this.selectionHandler.generateClickEvent("dragging",e,t);const i=t.x-this.drag.pointer.x,o=t.y-this.drag.pointer.y;be(r).call(r,s=>{const a=s.node;s.xFixed===!1&&(a.x=this.canvas._XconvertDOMtoCanvas(this.canvas._XconvertCanvasToDOM(s.x)+i)),s.yFixed===!1&&(a.y=this.canvas._YconvertDOMtoCanvas(this.canvas._YconvertCanvasToDOM(s.y)+o))}),this.body.emitter.emit("startSimulation")}else{if(e.srcEvent.shiftKey){if(this.selectionHandler.generateClickEvent("dragging",e,t,void 0,!0),this.drag.pointer===void 0){this.onDragStart(e);return}this.body.selectionBox.position.end={x:this.canvas._XconvertDOMtoCanvas(t.x),y:this.canvas._YconvertDOMtoCanvas(t.y)},this.body.emitter.emit("_requestRedraw")}if(this.options.dragView===!0&&!e.srcEvent.shiftKey){if(this.selectionHandler.generateClickEvent("dragging",e,t,void 0,!0),this.drag.pointer===void 0){this.onDragStart(e);return}const i=t.x-this.drag.pointer.x,o=t.y-this.drag.pointer.y;this.body.view.translation={x:this.drag.translation.x+i,y:this.drag.translation.y+o},this.body.emitter.emit("_requestRedraw")}}}onDragEnd(e){if(this.drag.dragging=!1,this.body.selectionBox.show){var t;this.body.selectionBox.show=!1;const r=this.body.selectionBox.position,i={minX:Math.min(r.start.x,r.end.x),minY:Math.min(r.start.y,r.end.y),maxX:Math.max(r.start.x,r.end.x),maxY:Math.max(r.start.y,r.end.y)},o=st(t=this.body.nodeIndices).call(t,a=>{const g=this.body.nodes[a];return g.x>=i.minX&&g.x<=i.maxX&&g.y>=i.minY&&g.y<=i.maxY});be(o).call(o,a=>this.selectionHandler.selectObject(this.body.nodes[a]));const s=this.getPointer(e.center);this.selectionHandler.commitAndEmit(s,e),this.selectionHandler.generateClickEvent("dragEnd",e,this.getPointer(e.center),void 0,!0),this.body.emitter.emit("_requestRedraw")}else{const r=this.drag.selection;r&&r.length?(be(r).call(r,function(i){i.node.options.fixed.x=i.xFixed,i.node.options.fixed.y=i.yFixed}),this.selectionHandler.generateClickEvent("dragEnd",e,this.getPointer(e.center)),this.body.emitter.emit("startSimulation")):(this.selectionHandler.generateClickEvent("dragEnd",e,this.getPointer(e.center),void 0,!0),this.body.emitter.emit("_requestRedraw"))}}onPinch(e){const t=this.getPointer(e.center);this.drag.pinched=!0,this.pinch.scale===void 0&&(this.pinch.scale=1);const r=this.pinch.scale*e.scale;this.zoom(r,t)}zoom(e,t){if(this.options.zoomView===!0){const r=this.body.view.scale;e<1e-5&&(e=1e-5),e>10&&(e=10);let i;this.drag!==void 0&&this.drag.dragging===!0&&(i=this.canvas.DOMtoCanvas(this.drag.pointer));const o=this.body.view.translation,s=e/r,a=(1-s)*t.x+o.x*s,g=(1-s)*t.y+o.y*s;if(this.body.view.scale=e,this.body.view.translation={x:a,y:g},i!=null){const A=this.canvas.canvasToDOM(i);this.drag.pointer.x=A.x,this.drag.pointer.y=A.y}this.body.emitter.emit("_requestRedraw"),r<e?this.body.emitter.emit("zoom",{direction:"+",scale:this.body.view.scale,pointer:t}):this.body.emitter.emit("zoom",{direction:"-",scale:this.body.view.scale,pointer:t})}}onMouseWheel(e){if(this.options.zoomView===!0){if(e.deltaY!==0){let t=this.body.view.scale;t*=1+(e.deltaY<0?1:-1)*(this.options.zoomSpeed*.1);const r=this.getPointer({x:e.clientX,y:e.clientY});this.zoom(t,r)}e.preventDefault()}}onMouseMove(e){const t=this.getPointer({x:e.clientX,y:e.clientY});let r=!1;this.popup!==void 0&&(this.popup.hidden===!1&&this._checkHidePopup(t),this.popup.hidden===!1&&(r=!0,this.popup.setPosition(t.x+3,t.y-5),this.popup.show())),this.options.keyboard.autoFocus&&this.options.keyboard.bindToWindow===!1&&this.options.keyboard.enabled===!0&&this.canvas.frame.focus(),r===!1&&(this.popupTimer!==void 0&&(clearInterval(this.popupTimer),this.popupTimer=void 0),this.drag.dragging||(this.popupTimer=ri(()=>this._checkShowPopup(t),this.options.tooltipDelay))),this.options.hover===!0&&this.selectionHandler.hoverObject(e,t)}_checkShowPopup(e){const t=this.canvas._XconvertDOMtoCanvas(e.x),r=this.canvas._YconvertDOMtoCanvas(e.y),i={left:t,top:r,right:t,bottom:r},o=this.popupObj===void 0?void 0:this.popupObj.id;let s=!1,a="node";if(this.popupObj===void 0){const g=this.body.nodeIndices,A=this.body.nodes;let I;const C=[];for(let l=0;l<g.length;l++)I=A[g[l]],I.isOverlappingWith(i)===!0&&(s=!0,I.getTitle()!==void 0&&C.push(g[l]));C.length>0&&(this.popupObj=A[C[C.length-1]],s=!0)}if(this.popupObj===void 0&&s===!1){const g=this.body.edgeIndices,A=this.body.edges;let I;const C=[];for(let l=0;l<g.length;l++)I=A[g[l]],I.isOverlappingWith(i)===!0&&I.connected===!0&&I.getTitle()!==void 0&&C.push(g[l]);C.length>0&&(this.popupObj=A[C[C.length-1]],a="edge")}this.popupObj!==void 0?this.popupObj.id!==o&&(this.popup===void 0&&(this.popup=new Rse(this.canvas.frame)),this.popup.popupTargetType=a,this.popup.popupTargetId=this.popupObj.id,this.popup.setPosition(e.x+3,e.y-5),this.popup.setText(this.popupObj.getTitle()),this.popup.show(),this.body.emitter.emit("showPopup",this.popupObj.id)):this.popup!==void 0&&(this.popup.hide(),this.body.emitter.emit("hidePopup"))}_checkHidePopup(e){const t=this.selectionHandler._pointerToPositionObject(e);let r=!1;if(this.popup.popupTargetType==="node"){if(this.body.nodes[this.popup.popupTargetId]!==void 0&&(r=this.body.nodes[this.popup.popupTargetId].isOverlappingWith(t),r===!0)){const i=this.selectionHandler.getNodeAt(e);r=i===void 0?!1:i.id===this.popup.popupTargetId}}else this.selectionHandler.getNodeAt(e)===void 0&&this.body.edges[this.popup.popupTargetId]!==void 0&&(r=this.body.edges[this.popup.popupTargetId].isOverlappingWith(t));r===!1&&(this.popupObj=void 0,this.popup.hide(),this.body.emitter.emit("hidePopup"))}};var Lk={},Gk={},wf,Wk;function bCe(){if(Wk)return wf;Wk=1;var n=me(),e=hT(),t=bI().getWeakData,r=dT(),i=Ii(),o=Os(),s=bt(),a=wI(),g=pn(),A=ct(),I=Io(),C=I.set,l=I.getterFor,d=g.find,u=g.findIndex,h=n([].splice),v=0,f=function(p){return p.frozen||(p.frozen=new c)},c=function(){this.entries=[]},b=function(p,y){return d(p.entries,function(E){return E[0]===y})};return c.prototype={get:function(p){var y=b(this,p);if(y)return y[1]},has:function(p){return!!b(this,p)},set:function(p,y){var E=b(this,p);E?E[1]=y:this.entries.push([p,y])},delete:function(p){var y=u(this.entries,function(E){return E[0]===p});return~y&&h(this.entries,y,1),!!~y}},wf={getConstructor:function(p,y,E,S){var m=p(function(R,O){r(R,w),C(R,{type:y,id:v++,frozen:null}),o(O)||a(O,R[S],{that:R,AS_ENTRIES:E})}),w=m.prototype,_=l(y),T=function(R,O,P){var x=_(R),V=t(i(O),!0);return V===!0?f(x).set(O,P):V[x.id]=P,R};return e(w,{delete:function(R){var O=_(this);if(!s(R))return!1;var P=t(R);return P===!0?f(O).delete(R):P&&A(P,O.id)&&delete P[O.id]},has:function(O){var P=_(this);if(!s(O))return!1;var x=t(O);return x===!0?f(P).has(O):x&&A(x,P.id)}}),e(w,E?{get:function(O){var P=_(this);if(s(O)){var x=t(O);if(x===!0)return f(P).get(O);if(x)return x[P.id]}},set:function(O,P){return T(this,O,P)}}:{add:function(O){return T(this,O,!0)}}),m}},wf}var Vk;function wCe(){if(Vk)return Gk;Vk=1;var n=QQ(),e=Le(),t=me(),r=hT(),i=bI(),o=uT(),s=bCe(),a=bt(),g=Io().enforce,A=ce(),I=UX(),C=Object,l=Array.isArray,d=C.isExtensible,u=C.isFrozen,h=C.isSealed,v=C.freeze,f=C.seal,c=!e.ActiveXObject&&"ActiveXObject"in e,b,p=function(R){return function(){return R(this,arguments.length?arguments[0]:void 0)}},y=o("WeakMap",p,s),E=y.prototype,S=t(E.set),m=function(){return n&&A(function(){var R=v([]);return S(new y,R,1),!u(R)})};if(I)if(c){b=s.getConstructor(p,"WeakMap",!0),i.enable();var w=t(E.delete),_=t(E.has),T=t(E.get);r(E,{delete:function(R){if(a(R)&&!d(R)){var O=g(this);return O.frozen||(O.frozen=new b),w(this,R)||O.frozen.delete(R)}return w(this,R)},has:function(O){if(a(O)&&!d(O)){var P=g(this);return P.frozen||(P.frozen=new b),_(this,O)||P.frozen.has(O)}return _(this,O)},get:function(O){if(a(O)&&!d(O)){var P=g(this);return P.frozen||(P.frozen=new b),_(this,O)?T(this,O):P.frozen.get(O)}return T(this,O)},set:function(O,P){if(a(O)&&!d(O)){var x=g(this);x.frozen||(x.frozen=new b),_(this,O)?S(this,O,P):x.frozen.set(O,P)}else S(this,O,P);return this}})}else m()&&r(E,{set:function(O,P){var x;return l(O)&&(u(O)?x=v:h(O)&&(x=f)),S(this,O,P),x&&x(O),this}});return Gk}var Zk;function ECe(){return Zk||(Zk=1,wCe()),Lk}var Ef,Hk;function SCe(){if(Hk)return Ef;Hk=1,$i(),ECe();var n=Ee();return Ef=n.WeakMap,Ef}var Sf,Uk;function _Ce(){if(Uk)return Sf;Uk=1;var n=SCe();return Di(),Sf=n,Sf}var _f,Kk;function OCe(){return Kk||(Kk=1,_f=_Ce()),_f}var TCe=OCe(),Og=ne(TCe);function Na(n,e,t){RCe(n,e),e.set(n,t)}function RCe(n,e){if(e.has(n))throw new TypeError("Cannot initialize the same private elements twice on an object")}function pO(n,e,t){return n.set(v7(n,e),t),t}function De(n,e){return n.get(v7(n,e))}function v7(n,e,t){if(typeof n=="function"?n===e:n.has(e))return arguments.length<3?e:t;throw new TypeError("Private element is not present on this object")}function Yk(n,e){const t=new jr;for(const r of e)n.has(r)||t.add(r);return t}var zo=new Og,Nr=new Og;let Xk=class{constructor(){Na(this,zo,new jr),Na(this,Nr,new jr)}get size(){return De(Nr,this).size}add(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];for(const i of t)De(Nr,this).add(i)}delete(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];for(const i of t)De(Nr,this).delete(i)}clear(){De(Nr,this).clear()}getSelection(){return[...De(Nr,this)]}getChanges(){return{added:[...Yk(De(zo,this),De(Nr,this))],deleted:[...Yk(De(Nr,this),De(zo,this))],previous:[...new jr(De(zo,this))],current:[...new jr(De(Nr,this))]}}commit(){const e=this.getChanges();pO(zo,this,De(Nr,this)),pO(Nr,this,new jr(De(zo,this)));for(const t of e.added)t.select();for(const t of e.deleted)t.unselect();return e}};var Tn=new Og,Rn=new Og,Of=new Og;let PCe=class{constructor(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:()=>{};Na(this,Tn,new Xk),Na(this,Rn,new Xk),Na(this,Of,void 0),pO(Of,this,e)}get sizeNodes(){return De(Tn,this).size}get sizeEdges(){return De(Rn,this).size}getNodes(){return De(Tn,this).getSelection()}getEdges(){return De(Rn,this).getSelection()}addNodes(){De(Tn,this).add(...arguments)}addEdges(){De(Rn,this).add(...arguments)}deleteNodes(e){De(Tn,this).delete(e)}deleteEdges(e){De(Rn,this).delete(e)}clear(){De(Tn,this).clear(),De(Rn,this).clear()}commit(){const e={nodes:De(Tn,this).commit(),edges:De(Rn,this).commit()};for(var t=arguments.length,r=new Array(t),i=0;i<t;i++)r[i]=arguments[i];return De(Of,this).call(this,e,...r),e}},xCe=class{constructor(e,t){this.body=e,this.canvas=t,this._selectionAccumulator=new PCe,this.hoverObj={nodes:{},edges:{}},this.options={},this.defaultOptions={multiselect:!1,selectable:!0,selectConnectedEdges:!0,hoverConnectedEdges:!0},tt(this.options,this.defaultOptions),this.body.emitter.on("_dataChanged",()=>{this.updateSelection()})}setOptions(e){e!==void 0&&zs(["multiselect","hoverConnectedEdges","selectable","selectConnectedEdges"],this.options,e)}selectOnPoint(e){let t=!1;if(this.options.selectable===!0){const r=this.getNodeAt(e)||this.getEdgeAt(e);this.unselectAll(),r!==void 0&&(t=this.selectObject(r)),this.body.emitter.emit("_requestRedraw")}return t}selectAdditionalOnPoint(e){let t=!1;if(this.options.selectable===!0){const r=this.getNodeAt(e)||this.getEdgeAt(e);r!==void 0&&(t=!0,r.isSelected()===!0?this.deselectObject(r):this.selectObject(r),this.body.emitter.emit("_requestRedraw"))}return t}_initBaseEvent(e,t){const r={};return r.pointer={DOM:{x:t.x,y:t.y},canvas:this.canvas.DOMtoCanvas(t)},r.event=e,r}generateClickEvent(e,t,r,i){let o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!1;const s=this._initBaseEvent(t,r);if(o===!0)s.nodes=[],s.edges=[];else{const a=this.getSelection();s.nodes=a.nodes,s.edges=a.edges}i!==void 0&&(s.previousSelection=i),e=="click"&&(s.items=this.getClickedItems(r)),t.controlEdge!==void 0&&(s.controlEdge=t.controlEdge),this.body.emitter.emit(e,s)}selectObject(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.options.selectConnectedEdges;return e!==void 0?(e instanceof sr?(t===!0&&this._selectionAccumulator.addEdges(...e.edges),this._selectionAccumulator.addNodes(e)):this._selectionAccumulator.addEdges(e),!0):!1}deselectObject(e){e.isSelected()===!0&&(e.selected=!1,this._removeFromSelection(e))}_getAllNodesOverlappingWith(e){const t=[],r=this.body.nodes;for(let i=0;i<this.body.nodeIndices.length;i++){const o=this.body.nodeIndices[i];r[o].isOverlappingWith(e)&&t.push(o)}return t}_pointerToPositionObject(e){const t=this.canvas.DOMtoCanvas(e);return{left:t.x-1,top:t.y+1,right:t.x+1,bottom:t.y-1}}getNodeAt(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;const r=this._pointerToPositionObject(e),i=this._getAllNodesOverlappingWith(r);if(i.length>0)return t===!0?this.body.nodes[i[i.length-1]]:i[i.length-1]}_getEdgesOverlappingWith(e,t){const r=this.body.edges;for(let i=0;i<this.body.edgeIndices.length;i++){const o=this.body.edgeIndices[i];r[o].isOverlappingWith(e)&&t.push(o)}}_getAllEdgesOverlappingWith(e){const t=[];return this._getEdgesOverlappingWith(e,t),t}getEdgeAt(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;const r=this.canvas.DOMtoCanvas(e);let i=10,o=null;const s=this.body.edges;for(let a=0;a<this.body.edgeIndices.length;a++){const g=this.body.edgeIndices[a],A=s[g];if(A.connected){const I=A.from.x,C=A.from.y,l=A.to.x,d=A.to.y,u=A.edgeType.getDistanceToEdge(I,C,l,d,r.x,r.y);u<i&&(o=g,i=u)}}if(o!==null)return t===!0?this.body.edges[o]:o}_addToHover(e){e instanceof sr?this.hoverObj.nodes[e.id]=e:this.hoverObj.edges[e.id]=e}_removeFromSelection(e){e instanceof sr?(this._selectionAccumulator.deleteNodes(e),this._selectionAccumulator.deleteEdges(...e.edges)):this._selectionAccumulator.deleteEdges(e)}unselectAll(){this._selectionAccumulator.clear()}getSelectedNodeCount(){return this._selectionAccumulator.sizeNodes}getSelectedEdgeCount(){return this._selectionAccumulator.sizeEdges}_hoverConnectedEdges(e){for(let t=0;t<e.edges.length;t++){const r=e.edges[t];r.hover=!0,this._addToHover(r)}}emitBlurEvent(e,t,r){const i=this._initBaseEvent(e,t);r.hover===!0&&(r.hover=!1,r instanceof sr?(i.node=r.id,this.body.emitter.emit("blurNode",i)):(i.edge=r.id,this.body.emitter.emit("blurEdge",i)))}emitHoverEvent(e,t,r){const i=this._initBaseEvent(e,t);let o=!1;return r.hover===!1&&(r.hover=!0,this._addToHover(r),o=!0,r instanceof sr?(i.node=r.id,this.body.emitter.emit("hoverNode",i)):(i.edge=r.id,this.body.emitter.emit("hoverEdge",i))),o}hoverObject(e,t){let r=this.getNodeAt(t);r===void 0&&(r=this.getEdgeAt(t));let i=!1;for(const o in this.hoverObj.nodes)Object.prototype.hasOwnProperty.call(this.hoverObj.nodes,o)&&(r===void 0||r instanceof sr&&r.id!=o||r instanceof ns)&&(this.emitBlurEvent(e,t,this.hoverObj.nodes[o]),delete this.hoverObj.nodes[o],i=!0);for(const o in this.hoverObj.edges)Object.prototype.hasOwnProperty.call(this.hoverObj.edges,o)&&(i===!0?(this.hoverObj.edges[o].hover=!1,delete this.hoverObj.edges[o]):(r===void 0||r instanceof ns&&r.id!=o||r instanceof sr&&!r.hover)&&(this.emitBlurEvent(e,t,this.hoverObj.edges[o]),delete this.hoverObj.edges[o],i=!0));if(r!==void 0){const o=Be(this.hoverObj.edges).length,s=Be(this.hoverObj.nodes).length,a=r instanceof ns&&o===0&&s===0,g=r instanceof sr&&o===0&&s===0;(i||a||g)&&(i=this.emitHoverEvent(e,t,r)),r instanceof sr&&this.options.hoverConnectedEdges===!0&&this._hoverConnectedEdges(r)}i===!0&&this.body.emitter.emit("_requestRedraw")}commitWithoutEmitting(){this._selectionAccumulator.commit()}commitAndEmit(e,t){let r=!1;const i=this._selectionAccumulator.commit(),o={nodes:i.nodes.previous,edges:i.edges.previous};i.edges.deleted.length>0&&(this.generateClickEvent("deselectEdge",t,e,o),r=!0),i.nodes.deleted.length>0&&(this.generateClickEvent("deselectNode",t,e,o),r=!0),i.nodes.added.length>0&&(this.generateClickEvent("selectNode",t,e),r=!0),i.edges.added.length>0&&(this.generateClickEvent("selectEdge",t,e),r=!0),r===!0&&this.generateClickEvent("select",t,e)}getSelection(){return{nodes:this.getSelectedNodeIds(),edges:this.getSelectedEdgeIds()}}getSelectedNodes(){return this._selectionAccumulator.getNodes()}getSelectedEdges(){return this._selectionAccumulator.getEdges()}getSelectedNodeIds(){var e;return Mt(e=this._selectionAccumulator.getNodes()).call(e,t=>t.id)}getSelectedEdgeIds(){var e;return Mt(e=this._selectionAccumulator.getEdges()).call(e,t=>t.id)}setSelection(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};if(!e||!e.nodes&&!e.edges)throw new TypeError("Selection must be an object with nodes and/or edges properties");if((t.unselectAll||t.unselectAll===void 0)&&this.unselectAll(),e.nodes)for(const r of e.nodes){const i=this.body.nodes[r];if(!i)throw new RangeError('Node with id "'+r+'" not found');this.selectObject(i,t.highlightEdges)}if(e.edges)for(const r of e.edges){const i=this.body.edges[r];if(!i)throw new RangeError('Edge with id "'+r+'" not found');this.selectObject(i)}this.body.emitter.emit("_requestRedraw"),this._selectionAccumulator.commit()}selectNodes(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;if(!e||e.length===void 0)throw"Selection must be an array with ids";this.setSelection({nodes:e},{highlightEdges:t})}selectEdges(e){if(!e||e.length===void 0)throw"Selection must be an array with ids";this.setSelection({edges:e})}updateSelection(){for(const e in this._selectionAccumulator.getNodes())Object.prototype.hasOwnProperty.call(this.body.nodes,e.id)||this._selectionAccumulator.deleteNodes(e);for(const e in this._selectionAccumulator.getEdges())Object.prototype.hasOwnProperty.call(this.body.edges,e.id)||this._selectionAccumulator.deleteEdges(e)}getClickedItems(e){const t=this.canvas.DOMtoCanvas(e),r=[],i=this.body.nodeIndices,o=this.body.nodes;for(let g=i.length-1;g>=0;g--){const I=o[i[g]].getItemsOnPoint(t);r.push.apply(r,I)}const s=this.body.edgeIndices,a=this.body.edges;for(let g=s.length-1;g>=0;g--){const I=a[s[g]].getItemsOnPoint(t);r.push.apply(r,I)}return r}},m7=class{abstract(){throw new Error("Can't instantiate abstract class!")}fake_use(){}curveType(){return this.abstract()}getPosition(e){return this.fake_use(e),this.abstract()}setPosition(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:void 0;this.fake_use(e,t,r),this.abstract()}getTreeSize(e){return this.fake_use(e),this.abstract()}sort(e){this.fake_use(e),this.abstract()}fix(e,t){this.fake_use(e,t),this.abstract()}shift(e,t){this.fake_use(e,t),this.abstract()}},$Ce=class extends m7{constructor(e){super(),this.layout=e}curveType(){return"horizontal"}getPosition(e){return e.x}setPosition(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:void 0;r!==void 0&&this.layout.hierarchical.addToOrdering(e,r),e.x=t}getTreeSize(e){const t=this.layout.hierarchical.getTreeSize(this.layout.body.nodes,e);return{min:t.min_x,max:t.max_x}}sort(e){mi(e).call(e,function(t,r){return t.x-r.x})}fix(e,t){e.y=this.layout.options.hierarchical.levelSeparation*t,e.options.fixed.y=!0}shift(e,t){this.layout.body.nodes[e].x+=t}},DCe=class extends m7{constructor(e){super(),this.layout=e}curveType(){return"vertical"}getPosition(e){return e.y}setPosition(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:void 0;r!==void 0&&this.layout.hierarchical.addToOrdering(e,r),e.y=t}getTreeSize(e){const t=this.layout.hierarchical.getTreeSize(this.layout.body.nodes,e);return{min:t.min_y,max:t.max_y}}sort(e){mi(e).call(e,function(t,r){return t.y-r.y})}fix(e,t){e.x=this.layout.options.hierarchical.levelSeparation*t,e.options.fixed.x=!0}shift(e,t){this.layout.body.nodes[e].y+=t}};var Qk={},Jk;function NCe(){if(Jk)return Qk;Jk=1;var n=ee(),e=pn().every,t=Fs(),r=t("every");return n({target:"Array",proto:!0,forced:!r},{every:function(o){return e(this,o,arguments.length>1?arguments[1]:void 0)}}),Qk}var Tf,eB;function MCe(){if(eB)return Tf;eB=1,NCe();var n=ft();return Tf=n("Array","every"),Tf}var Rf,tB;function qCe(){if(tB)return Rf;tB=1;var n=Je(),e=MCe(),t=Array.prototype;return Rf=function(r){var i=r.every;return r===t||n(t,r)&&i===t.every?e:i},Rf}var Pf,rB;function FCe(){if(rB)return Pf;rB=1;var n=qCe();return Pf=n,Pf}var xf,iB;function kCe(){return iB||(iB=1,xf=FCe()),xf}var BCe=kCe(),y7=ne(BCe);function zCe(n,e){const t=new jr;return be(n).call(n,r=>{var i;be(i=r.edges).call(i,o=>{o.connected&&t.add(o)})}),be(t).call(t,r=>{const i=r.from.id,o=r.to.id;e[i]==null&&(e[i]=0),(e[o]==null||e[i]>=e[o])&&(e[o]=e[i]+1)}),e}function jCe(n){return b7(e=>{var t,r;return y7(t=st(r=e.edges).call(r,i=>n.has(i.toId))).call(t,i=>i.to===e)},(e,t)=>t>e,"from",n)}function LCe(n){return b7(e=>{var t,r;return y7(t=st(r=e.edges).call(r,i=>n.has(i.toId))).call(t,i=>i.from===e)},(e,t)=>t<e,"to",n)}function b7(n,e,t,r){var i;const o=nn(null),s=cT(i=[...LA(r).call(r)]).call(i,(C,l)=>C+1+l.edges.length,0),a=t+"Id",g=t==="to"?1:-1;for(const[C,l]of r){if(!r.has(C)||!n(l))continue;o[C]=0;const d=[l];let u=0,h;for(;h=d.pop();){var A,I;if(!r.has(C))continue;const v=o[h.id]+g;if(be(A=st(I=h.edges).call(I,f=>f.connected&&f.to!==f.from&&f[t]!==h&&r.has(f.toId)&&r.has(f.fromId))).call(A,f=>{const c=f[a],b=o[c];(b==null||e(v,b))&&(o[c]=v,d.push(f[t]))}),u>s)return zCe(r,o);++u}}return o}let GCe=class{constructor(){this.childrenReference={},this.parentReference={},this.trees={},this.distributionOrdering={},this.levels={},this.distributionIndex={},this.isTree=!1,this.treeIndex=-1}addRelation(e,t){this.childrenReference[e]===void 0&&(this.childrenReference[e]=[]),this.childrenReference[e].push(t),this.parentReference[t]===void 0&&(this.parentReference[t]=[]),this.parentReference[t].push(e)}checkIfTree(){for(const e in this.parentReference)if(this.parentReference[e].length>1){this.isTree=!1;return}this.isTree=!0}numTrees(){return this.treeIndex+1}setTreeIndex(e,t){t!==void 0&&this.trees[e.id]===void 0&&(this.trees[e.id]=t,this.treeIndex=Math.max(t,this.treeIndex))}ensureLevel(e){this.levels[e]===void 0&&(this.levels[e]=0)}getMaxLevel(e){const t={},r=i=>{if(t[i]!==void 0)return t[i];let o=this.levels[i];if(this.childrenReference[i]){const s=this.childrenReference[i];if(s.length>0)for(let a=0;a<s.length;a++)o=Math.max(o,r(s[a]))}return t[i]=o,o};return r(e)}levelDownstream(e,t){this.levels[t.id]===void 0&&(this.levels[e.id]===void 0&&(this.levels[e.id]=0),this.levels[t.id]=this.levels[e.id]+1)}setMinLevelToZero(){var e;const t=new bg;let r=0;const i=mi(e=[...new jr(qne(this.levels))]).call(e,(o,s)=>o-s);for(const o of i)t.set(o,r++);for(const o in this.levels)Object.prototype.hasOwnProperty.call(this.levels,o)&&(this.levels[o]=t.get(this.levels[o]))}getTreeSize(e,t){let r=1e9,i=-1e9,o=1e9,s=-1e9;for(const a in this.trees)if(Object.prototype.hasOwnProperty.call(this.trees,a)&&this.trees[a]===t){const g=e[a];r=Math.min(g.x,r),i=Math.max(g.x,i),o=Math.min(g.y,o),s=Math.max(g.y,s)}return{min_x:r,max_x:i,min_y:o,max_y:s}}hasSameParent(e,t){const r=this.parentReference[e.id],i=this.parentReference[t.id];if(r===void 0||i===void 0)return!1;for(let o=0;o<r.length;o++)for(let s=0;s<i.length;s++)if(r[o]==i[s])return!0;return!1}inSameSubNetwork(e,t){return this.trees[e.id]===this.trees[t.id]}getLevels(){return Be(this.distributionOrdering)}addToOrdering(e,t){this.distributionOrdering[t]===void 0&&(this.distributionOrdering[t]=[]);let r=!1;const i=this.distributionOrdering[t];for(const o in i)if(i[o]===e){r=!0;break}r||(this.distributionOrdering[t].push(e),this.distributionIndex[e.id]=this.distributionOrdering[t].length-1)}},WCe=class{constructor(e){this.body=e,this._resetRNG(Math.random()+":"+MA()),this.setPhysics=!1,this.options={},this.optionsBackup={physics:{}},this.defaultOptions={randomSeed:void 0,improvedLayout:!0,clusterThreshold:150,hierarchical:{enabled:!1,levelSeparation:150,nodeSpacing:100,treeSpacing:200,blockShifting:!0,edgeMinimization:!0,parentCentralization:!0,direction:"UD",sortMethod:"hubsize"}},tt(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){this.body.emitter.on("_dataChanged",()=>{this.setupHierarchicalLayout()}),this.body.emitter.on("_dataLoaded",()=>{this.layoutNetwork()}),this.body.emitter.on("_resetHierarchicalLayout",()=>{this.setupHierarchicalLayout()}),this.body.emitter.on("_adjustEdgesForHierarchicalLayout",()=>{if(this.options.hierarchical.enabled!==!0)return;const e=this.direction.curveType();this.body.emitter.emit("_forceDisableDynamicCurves",e,!1)})}setOptions(e,t){if(e!==void 0){const r=this.options.hierarchical,i=r.enabled;if(zs(["randomSeed","improvedLayout","clusterThreshold"],this.options,e),dr(this.options,e,"hierarchical"),e.randomSeed!==void 0&&this._resetRNG(e.randomSeed),r.enabled===!0)return i===!0&&this.body.emitter.emit("refresh",!0),r.direction==="RL"||r.direction==="DU"?r.levelSeparation>0&&(r.levelSeparation*=-1):r.levelSeparation<0&&(r.levelSeparation*=-1),this.setDirectionStrategy(),this.body.emitter.emit("_resetHierarchicalLayout"),this.adaptAllOptionsForHierarchicalLayout(t);if(i===!0)return this.body.emitter.emit("refresh"),Me(t,this.optionsBackup)}return t}_resetRNG(e){this.initialRandomSeed=e,this._rng=yI(this.initialRandomSeed)}adaptAllOptionsForHierarchicalLayout(e){if(this.options.hierarchical.enabled===!0){const t=this.optionsBackup.physics;e.physics===void 0||e.physics===!0?(e.physics={enabled:t.enabled===void 0?!0:t.enabled,solver:"hierarchicalRepulsion"},t.enabled=t.enabled===void 0?!0:t.enabled,t.solver=t.solver||"barnesHut"):typeof e.physics=="object"?(t.enabled=e.physics.enabled===void 0?!0:e.physics.enabled,t.solver=e.physics.solver||"barnesHut",e.physics.solver="hierarchicalRepulsion"):e.physics!==!1&&(t.solver="barnesHut",e.physics={solver:"hierarchicalRepulsion"});let r=this.direction.curveType();if(e.edges===void 0)this.optionsBackup.edges={smooth:{enabled:!0,type:"dynamic"}},e.edges={smooth:!1};else if(e.edges.smooth===void 0)this.optionsBackup.edges={smooth:{enabled:!0,type:"dynamic"}},e.edges.smooth=!1;else if(typeof e.edges.smooth=="boolean")this.optionsBackup.edges={smooth:e.edges.smooth},e.edges.smooth={enabled:e.edges.smooth,type:r};else{const i=e.edges.smooth;i.type!==void 0&&i.type!=="dynamic"&&(r=i.type),this.optionsBackup.edges={smooth:{enabled:i.enabled===void 0?!0:i.enabled,type:i.type===void 0?"dynamic":i.type,roundness:i.roundness===void 0?.5:i.roundness,forceDirection:i.forceDirection===void 0?!1:i.forceDirection}},e.edges.smooth={enabled:i.enabled===void 0?!0:i.enabled,type:r,roundness:i.roundness===void 0?.5:i.roundness,forceDirection:i.forceDirection===void 0?!1:i.forceDirection}}this.body.emitter.emit("_forceDisableDynamicCurves",r)}return e}positionInitially(e){if(this.options.hierarchical.enabled!==!0){this._resetRNG(this.initialRandomSeed);const t=e.length+50;for(let r=0;r<e.length;r++){const i=e[r],o=2*Math.PI*this._rng();i.x===void 0&&(i.x=t*Math.cos(o)),i.y===void 0&&(i.y=t*Math.sin(o))}}}layoutNetwork(){if(this.options.hierarchical.enabled!==!0&&this.options.improvedLayout===!0){const e=this.body.nodeIndices;let t=0;for(let r=0;r<e.length;r++)this.body.nodes[e[r]].predefinedPosition===!0&&(t+=1);if(t<.5*e.length){let i=0;const o=this.options.clusterThreshold,s={clusterNodeProperties:{shape:"ellipse",label:"",group:"",font:{multi:!1}},clusterEdgeProperties:{label:"",font:{multi:!1},smooth:{enabled:!1}}};if(e.length>o){const g=e.length;for(;e.length>o&&i<=10;){i+=1;const A=e.length;i%3===0?this.body.modules.clustering.clusterBridges(s):this.body.modules.clustering.clusterOutliers(s);const I=e.length;if(A==I&&i%3!==0){this._declusterAll(),this.body.emitter.emit("_layoutFailed"),console.info("This network could not be positioned by this version of the improved layout algorithm. Please disable improvedLayout for better performance.");return}}this.body.modules.kamadaKawai.setOptions({springLength:Math.max(150,2*g)})}i>10&&console.info("The clustering didn't succeed within the amount of interations allowed, progressing with partial result."),this.body.modules.kamadaKawai.solve(e,this.body.edgeIndices,!0),this._shiftToCenter();const a=70;for(let g=0;g<e.length;g++){const A=this.body.nodes[e[g]];A.predefinedPosition===!1&&(A.x+=(.5-this._rng())*a,A.y+=(.5-this._rng())*a)}this._declusterAll(),this.body.emitter.emit("_repositionBezierNodes")}}}_shiftToCenter(){const e=Lt.getRangeCore(this.body.nodes,this.body.nodeIndices),t=Lt.findCenter(e);for(let r=0;r<this.body.nodeIndices.length;r++){const i=this.body.nodes[this.body.nodeIndices[r]];i.x-=t.x,i.y-=t.y}}_declusterAll(){let e=!0;for(;e===!0;){e=!1;for(let t=0;t<this.body.nodeIndices.length;t++)this.body.nodes[this.body.nodeIndices[t]].isCluster===!0&&(e=!0,this.body.modules.clustering.openCluster(this.body.nodeIndices[t],{},!1));e===!0&&this.body.emitter.emit("_dataChanged")}}getSeed(){return this.initialRandomSeed}setupHierarchicalLayout(){if(this.options.hierarchical.enabled===!0&&this.body.nodeIndices.length>0){let e,t,r=!1,i=!1;this.lastNodeOnLevel={},this.hierarchical=new GCe;for(t in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,t)&&(e=this.body.nodes[t],e.options.level!==void 0?(r=!0,this.hierarchical.levels[t]=e.options.level):i=!0);if(i===!0&&r===!0)throw new Error("To use the hierarchical layout, nodes require either no predefined levels or levels have to be defined for all nodes.");{if(i===!0){const s=this.options.hierarchical.sortMethod;s==="hubsize"?this._determineLevelsByHubsize():s==="directed"?this._determineLevelsDirected():s==="custom"&&this._determineLevelsCustomCallback()}for(const s in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,s)&&this.hierarchical.ensureLevel(s);const o=this._getDistribution();this._generateMap(),this._placeNodesByHierarchy(o),this._condenseHierarchy(),this._shiftToCenter()}}}_condenseHierarchy(){var e=this;let t=!1;const r={},i=()=>{const f=s();let c=0;for(let b=0;b<f.length-1;b++){const p=f[b].max-f[b+1].min;c+=p+this.options.hierarchical.treeSpacing,o(b+1,c)}},o=(f,c)=>{const b=this.hierarchical.trees;for(const p in b)Object.prototype.hasOwnProperty.call(b,p)&&b[p]===f&&this.direction.shift(p,c)},s=()=>{const f=[];for(let c=0;c<this.hierarchical.numTrees();c++)f.push(this.direction.getTreeSize(c));return f},a=(f,c)=>{if(!c[f.id]&&(c[f.id]=!0,this.hierarchical.childrenReference[f.id])){const b=this.hierarchical.childrenReference[f.id];if(b.length>0)for(let p=0;p<b.length;p++)a(this.body.nodes[b[p]],c)}},g=function(f){let c=arguments.length>1&&arguments[1]!==void 0?arguments[1]:1e9,b=1e9,p=1e9,y=1e9,E=-1e9;for(const S in f)if(Object.prototype.hasOwnProperty.call(f,S)){const m=e.body.nodes[S],w=e.hierarchical.levels[m.id],_=e.direction.getPosition(m),[T,R]=e._getSpaceAroundNode(m,f);b=Math.min(T,b),p=Math.min(R,p),w<=c&&(y=Math.min(_,y),E=Math.max(_,E))}return[y,E,b,p]},A=(f,c)=>{const b=this.hierarchical.getMaxLevel(f.id),p=this.hierarchical.getMaxLevel(c.id);return Math.min(b,p)},I=(f,c,b)=>{const p=this.hierarchical;for(let y=0;y<c.length;y++){const E=c[y],S=p.distributionOrdering[E];if(S.length>1)for(let m=0;m<S.length-1;m++){const w=S[m],_=S[m+1];p.hasSameParent(w,_)&&p.inSameSubNetwork(w,_)&&f(w,_,b)}}},C=function(f,c){let b=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;const p=e.direction.getPosition(f),y=e.direction.getPosition(c),E=Math.abs(y-p),S=e.options.hierarchical.nodeSpacing;if(E>S){const m={},w={};a(f,m),a(c,w);const _=A(f,c),T=g(m,_),R=g(w,_),O=T[1],P=R[0],x=R[2];if(Math.abs(O-P)>S){let M=O-P+S;M<-x+S&&(M=-x+S),M<0&&(e._shiftBlock(c.id,M),t=!0,b===!0&&e._centerParent(c))}}},l=(f,c)=>{const b=c.id,p=c.edges,y=this.hierarchical.levels[c.id],E=this.options.hierarchical.levelSeparation*this.options.hierarchical.levelSeparation,S={},m=[];for(let x=0;x<p.length;x++){const V=p[x];if(V.toId!=V.fromId){const M=V.toId==b?V.from:V.to;S[p[x].id]=M,this.hierarchical.levels[M.id]<y&&m.push(V)}}const w=(x,V)=>{let M=0;for(let U=0;U<V.length;U++)if(S[V[U].id]!==void 0){const K=this.direction.getPosition(S[V[U].id])-x;M+=K/Math.sqrt(K*K+E)}return M},_=(x,V)=>{let M=0;for(let U=0;U<V.length;U++)if(S[V[U].id]!==void 0){const K=this.direction.getPosition(S[V[U].id])-x;M-=E*Math.pow(K*K+E,-1.5)}return M},T=(x,V)=>{let M=this.direction.getPosition(c);const U={};for(let K=0;K<x;K++){const oe=w(M,V),L=_(M,V),ae=40,he=Math.max(-ae,Math.min(ae,Math.round(oe/L)));if(M=M-he,U[M]!==void 0)break;U[M]=K}return M},R=x=>{const V=this.direction.getPosition(c);if(r[c.id]===void 0){const ae={};a(c,ae),r[c.id]=ae}const M=g(r[c.id]),U=M[2],K=M[3],oe=x-V;let L=0;oe>0?L=Math.min(oe,K-this.options.hierarchical.nodeSpacing):oe<0&&(L=-Math.min(-oe,U-this.options.hierarchical.nodeSpacing)),L!=0&&(this._shiftBlock(c.id,L),t=!0)},O=x=>{const V=this.direction.getPosition(c),[M,U]=this._getSpaceAroundNode(c),K=x-V;let oe=V;K>0?oe=Math.min(V+(U-this.options.hierarchical.nodeSpacing),x):K<0&&(oe=Math.max(V-(M-this.options.hierarchical.nodeSpacing),x)),oe!==V&&(this.direction.setPosition(c,oe),t=!0)};let P=T(f,m);R(P),P=T(f,p),O(P)},d=f=>{let c=this.hierarchical.getLevels();c=zn(c).call(c);for(let b=0;b<f;b++){t=!1;for(let p=0;p<c.length;p++){const y=c[p],E=this.hierarchical.distributionOrdering[y];for(let S=0;S<E.length;S++)l(1e3,E[S])}if(t!==!0)break}},u=f=>{let c=this.hierarchical.getLevels();c=zn(c).call(c);for(let b=0;b<f&&(t=!1,I(C,c,!0),t===!0);b++);},h=()=>{for(const f in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,f)&&this._centerParent(this.body.nodes[f])},v=()=>{let f=this.hierarchical.getLevels();f=zn(f).call(f);for(let c=0;c<f.length;c++){const b=f[c],p=this.hierarchical.distributionOrdering[b];for(let y=0;y<p.length;y++)this._centerParent(p[y])}};this.options.hierarchical.blockShifting===!0&&(u(5),h()),this.options.hierarchical.edgeMinimization===!0&&d(20),this.options.hierarchical.parentCentralization===!0&&v(),i()}_getSpaceAroundNode(e,t){let r=!0;t===void 0&&(r=!1);const i=this.hierarchical.levels[e.id];if(i!==void 0){const o=this.hierarchical.distributionIndex[e.id],s=this.direction.getPosition(e),a=this.hierarchical.distributionOrdering[i];let g=1e9,A=1e9;if(o!==0){const I=a[o-1];if(r===!0&&t[I.id]===void 0||r===!1){const C=this.direction.getPosition(I);g=s-C}}if(o!=a.length-1){const I=a[o+1];if(r===!0&&t[I.id]===void 0||r===!1){const C=this.direction.getPosition(I);A=Math.min(A,C-s)}}return[g,A]}else return[0,0]}_centerParent(e){if(this.hierarchical.parentReference[e.id]){const t=this.hierarchical.parentReference[e.id];for(let r=0;r<t.length;r++){const i=t[r],o=this.body.nodes[i],s=this.hierarchical.childrenReference[i];if(s!==void 0){const a=this._getCenterPosition(s),g=this.direction.getPosition(o),[A,I]=this._getSpaceAroundNode(o),C=g-a;(C<0&&Math.abs(C)<I-this.options.hierarchical.nodeSpacing||C>0&&Math.abs(C)<A-this.options.hierarchical.nodeSpacing)&&this.direction.setPosition(o,a)}}}}_placeNodesByHierarchy(e){this.positionedNodes={};for(const r in e)if(Object.prototype.hasOwnProperty.call(e,r)){var t;let i=Be(e[r]);i=this._indexArrayToNodes(i),mi(t=this.direction).call(t,i);let o=0;for(let s=0;s<i.length;s++){const a=i[s];if(this.positionedNodes[a.id]===void 0){const g=this.options.hierarchical.nodeSpacing;let A=g*o;o>0&&(A=this.direction.getPosition(i[s-1])+g),this.direction.setPosition(a,A,r),this._validatePositionAndContinue(a,r,A),o++}}}}_placeBranchNodes(e,t){var r;const i=this.hierarchical.childrenReference[e];if(i===void 0)return;const o=[];for(let a=0;a<i.length;a++)o.push(this.body.nodes[i[a]]);mi(r=this.direction).call(r,o);for(let a=0;a<o.length;a++){const g=o[a],A=this.hierarchical.levels[g.id];if(A>t&&this.positionedNodes[g.id]===void 0){const I=this.options.hierarchical.nodeSpacing;let C;a===0?C=this.direction.getPosition(this.body.nodes[e]):C=this.direction.getPosition(o[a-1])+I,this.direction.setPosition(g,C,A),this._validatePositionAndContinue(g,A,C)}else return}const s=this._getCenterPosition(o);this.direction.setPosition(this.body.nodes[e],s,t)}_validatePositionAndContinue(e,t,r){if(this.hierarchical.isTree){if(this.lastNodeOnLevel[t]!==void 0){const i=this.direction.getPosition(this.body.nodes[this.lastNodeOnLevel[t]]);if(r-i<this.options.hierarchical.nodeSpacing){const o=i+this.options.hierarchical.nodeSpacing-r,s=this._findCommonParent(this.lastNodeOnLevel[t],e.id);this._shiftBlock(s.withChild,o)}}this.lastNodeOnLevel[t]=e.id,this.positionedNodes[e.id]=!0,this._placeBranchNodes(e.id,t)}}_indexArrayToNodes(e){const t=[];for(let r=0;r<e.length;r++)t.push(this.body.nodes[e[r]]);return t}_getDistribution(){const e={};let t,r;for(t in this.body.nodes)if(Object.prototype.hasOwnProperty.call(this.body.nodes,t)){r=this.body.nodes[t];const i=this.hierarchical.levels[t]===void 0?0:this.hierarchical.levels[t];this.direction.fix(r,i),e[i]===void 0&&(e[i]={}),e[i][t]=r}return e}_getActiveEdges(e){const t=[];return de(e.edges,r=>{var i;_e(i=this.body.edgeIndices).call(i,r.id)!==-1&&t.push(r)}),t}_getHubSizes(){const e={},t=this.body.nodeIndices;de(t,i=>{const o=this.body.nodes[i],s=this._getActiveEdges(o).length;e[s]=!0});const r=[];return de(e,i=>{r.push(Number(i))}),mi(r).call(r,function(i,o){return o-i}),r}_determineLevelsByHubsize(){const e=(r,i)=>{this.hierarchical.levelDownstream(r,i)},t=this._getHubSizes();for(let r=0;r<t.length;++r){const i=t[r];if(i===0)break;de(this.body.nodeIndices,o=>{const s=this.body.nodes[o];i===this._getActiveEdges(s).length&&this._crawlNetwork(e,o)})}}_determineLevelsCustomCallback(){const t=function(i,o,s){},r=(i,o,s)=>{let a=this.hierarchical.levels[i.id];a===void 0&&(a=this.hierarchical.levels[i.id]=1e5);const g=t(Lt.cloneOptions(i,"node"),Lt.cloneOptions(o,"node"),Lt.cloneOptions(s,"edge"));this.hierarchical.levels[o.id]=a+g};this._crawlNetwork(r),this.hierarchical.setMinLevelToZero()}_determineLevelsDirected(){var e;const t=cT(e=this.body.nodeIndices).call(e,(r,i)=>(r.set(i,this.body.nodes[i]),r),new bg);this.options.hierarchical.shakeTowards==="roots"?this.hierarchical.levels=LCe(t):this.hierarchical.levels=jCe(t),this.hierarchical.setMinLevelToZero()}_generateMap(){const e=(t,r)=>{this.hierarchical.levels[r.id]>this.hierarchical.levels[t.id]&&this.hierarchical.addRelation(t.id,r.id)};this._crawlNetwork(e),this.hierarchical.checkIfTree()}_crawlNetwork(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:function(){},t=arguments.length>1?arguments[1]:void 0;const r={},i=(o,s)=>{if(r[o.id]===void 0){this.hierarchical.setTreeIndex(o,s),r[o.id]=!0;let a;const g=this._getActiveEdges(o);for(let A=0;A<g.length;A++){const I=g[A];I.connected===!0&&(I.toId==o.id?a=I.from:a=I.to,o.id!=a.id&&(e(o,a,I),i(a,s)))}}};if(t===void 0){let o=0;for(let s=0;s<this.body.nodeIndices.length;s++){const a=this.body.nodeIndices[s];if(r[a]===void 0){const g=this.body.nodes[a];i(g,o),o+=1}}}else{const o=this.body.nodes[t];if(o===void 0){console.error("Node not found:",t);return}i(o)}}_shiftBlock(e,t){const r={},i=o=>{if(r[o])return;r[o]=!0,this.direction.shift(o,t);const s=this.hierarchical.childrenReference[o];if(s!==void 0)for(let a=0;a<s.length;a++)i(s[a])};i(e)}_findCommonParent(e,t){const r={},i=(s,a)=>{const g=this.hierarchical.parentReference[a];if(g!==void 0)for(let A=0;A<g.length;A++){const I=g[A];s[I]=!0,i(s,I)}},o=(s,a)=>{const g=this.hierarchical.parentReference[a];if(g!==void 0)for(let A=0;A<g.length;A++){const I=g[A];if(s[I]!==void 0)return{foundParent:I,withChild:a};const C=o(s,I);if(C.foundParent!==null)return C}return{foundParent:null,withChild:a}};return i(r,e),o(r,t)}setDirectionStrategy(){this.options.hierarchical.direction==="UD"||this.options.hierarchical.direction==="DU"?this.direction=new $Ce(this):this.direction=new DCe(this)}_getCenterPosition(e){let t=1e9,r=-1e9;for(let i=0;i<e.length;i++){let o;if(e[i].id!==void 0)o=e[i];else{const a=e[i];o=this.body.nodes[a]}const s=this.direction.getPosition(o);t=Math.min(t,s),r=Math.max(r,s)}return .5*(t+r)}},VCe=class{constructor(e,t,r,i){var o,s;this.body=e,this.canvas=t,this.selectionHandler=r,this.interactionHandler=i,this.editMode=!1,this.manipulationDiv=void 0,this.editModeDiv=void 0,this.closeDiv=void 0,this._domEventListenerCleanupQueue=[],this.temporaryUIFunctions={},this.temporaryEventFunctions=[],this.touchTime=0,this.temporaryIds={nodes:[],edges:[]},this.guiEnabled=!1,this.inMode=!1,this.selectedControlNode=void 0,this.options={},this.defaultOptions={enabled:!1,initiallyActive:!1,addNode:!0,addEdge:!0,editNode:void 0,editEdge:!0,deleteNode:!0,deleteEdge:!0,controlNodeStyle:{shape:"dot",size:6,color:{background:"#ff0000",border:"#3c3c3c",highlight:{background:"#07f968",border:"#3c3c3c"}},borderWidth:2,borderWidthSelected:2}},tt(this.options,this.defaultOptions),this.body.emitter.on("destroy",()=>{this._clean()}),this.body.emitter.on("_dataChanged",z(o=this._restore).call(o,this)),this.body.emitter.on("_resetData",z(s=this._restore).call(s,this))}_restore(){this.inMode!==!1&&(this.options.initiallyActive===!0?this.enableEditMode():this.disableEditMode())}setOptions(e,t,r){t!==void 0&&(t.locale!==void 0?this.options.locale=t.locale:this.options.locale=r.locale,t.locales!==void 0?this.options.locales=t.locales:this.options.locales=r.locales),e!==void 0&&(typeof e=="boolean"?this.options.enabled=e:(this.options.enabled=!0,Me(this.options,e)),this.options.initiallyActive===!0&&(this.editMode=!0),this._setup())}toggleEditMode(){this.editMode===!0?this.disableEditMode():this.enableEditMode()}enableEditMode(){this.editMode=!0,this._clean(),this.guiEnabled===!0&&(this.manipulationDiv.style.display="block",this.closeDiv.style.display="block",this.editModeDiv.style.display="none",this.showManipulatorToolbar())}disableEditMode(){this.editMode=!1,this._clean(),this.guiEnabled===!0&&(this.manipulationDiv.style.display="none",this.closeDiv.style.display="none",this.editModeDiv.style.display="block",this._createEditButton())}showManipulatorToolbar(){if(this._clean(),this.manipulationDOM={},this.guiEnabled===!0){var e,t;this.editMode=!0,this.manipulationDiv.style.display="block",this.closeDiv.style.display="block";const r=this.selectionHandler.getSelectedNodeCount(),i=this.selectionHandler.getSelectedEdgeCount(),o=r+i,s=this.options.locales[this.options.locale];let a=!1;this.options.addNode!==!1&&(this._createAddNodeButton(s),a=!0),this.options.addEdge!==!1&&(a===!0?this._createSeperator(1):a=!0,this._createAddEdgeButton(s)),r===1&&typeof this.options.editNode=="function"?(a===!0?this._createSeperator(2):a=!0,this._createEditNodeButton(s)):i===1&&r===0&&this.options.editEdge!==!1&&(a===!0?this._createSeperator(3):a=!0,this._createEditEdgeButton(s)),o!==0&&(r>0&&this.options.deleteNode!==!1?(a===!0&&this._createSeperator(4),this._createDeleteButton(s)):r===0&&this.options.deleteEdge!==!1&&(a===!0&&this._createSeperator(4),this._createDeleteButton(s))),this._bindElementEvents(this.closeDiv,z(e=this.toggleEditMode).call(e,this)),this._temporaryBindEvent("select",z(t=this.showManipulatorToolbar).call(t,this))}this.body.emitter.emit("_redraw")}addNodeMode(){var e;if(this.editMode!==!0&&this.enableEditMode(),this._clean(),this.inMode="addNode",this.guiEnabled===!0){var t;const r=this.options.locales[this.options.locale];this.manipulationDOM={},this._createBackButton(r),this._createSeperator(),this._createDescription(r.addDescription||this.options.locales.en.addDescription),this._bindElementEvents(this.closeDiv,z(t=this.toggleEditMode).call(t,this))}this._temporaryBindEvent("click",z(e=this._performAddNode).call(e,this))}editNode(){this.editMode!==!0&&this.enableEditMode(),this._clean();const e=this.selectionHandler.getSelectedNodes()[0];if(e!==void 0)if(this.inMode="editNode",typeof this.options.editNode=="function")if(e.isCluster!==!0){const t=Me({},e.options,!1);if(t.x=e.x,t.y=e.y,this.options.editNode.length===2)this.options.editNode(t,r=>{r!=null&&this.inMode==="editNode"&&this.body.data.nodes.getDataSet().update(r),this.showManipulatorToolbar()});else throw new Error("The function for edit does not support two arguments (data, callback)")}else alert(this.options.locales[this.options.locale].editClusterError||this.options.locales.en.editClusterError);else throw new Error("No function has been configured to handle the editing of nodes.");else this.showManipulatorToolbar()}addEdgeMode(){var e,t,r,i,o;if(this.editMode!==!0&&this.enableEditMode(),this._clean(),this.inMode="addEdge",this.guiEnabled===!0){var s;const a=this.options.locales[this.options.locale];this.manipulationDOM={},this._createBackButton(a),this._createSeperator(),this._createDescription(a.edgeDescription||this.options.locales.en.edgeDescription),this._bindElementEvents(this.closeDiv,z(s=this.toggleEditMode).call(s,this))}this._temporaryBindUI("onTouch",z(e=this._handleConnect).call(e,this)),this._temporaryBindUI("onDragEnd",z(t=this._finishConnect).call(t,this)),this._temporaryBindUI("onDrag",z(r=this._dragControlNode).call(r,this)),this._temporaryBindUI("onRelease",z(i=this._finishConnect).call(i,this)),this._temporaryBindUI("onDragStart",z(o=this._dragStartEdge).call(o,this)),this._temporaryBindUI("onHold",()=>{})}editEdgeMode(){if(this.editMode!==!0&&this.enableEditMode(),this._clean(),this.inMode="editEdge",typeof this.options.editEdge=="object"&&typeof this.options.editEdge.editWithoutDrag=="function"&&(this.edgeBeingEditedId=this.selectionHandler.getSelectedEdgeIds()[0],this.edgeBeingEditedId!==void 0)){const s=this.body.edges[this.edgeBeingEditedId];this._performEditEdge(s.from.id,s.to.id);return}if(this.guiEnabled===!0){var e;const s=this.options.locales[this.options.locale];this.manipulationDOM={},this._createBackButton(s),this._createSeperator(),this._createDescription(s.editEdgeDescription||this.options.locales.en.editEdgeDescription),this._bindElementEvents(this.closeDiv,z(e=this.toggleEditMode).call(e,this))}if(this.edgeBeingEditedId=this.selectionHandler.getSelectedEdgeIds()[0],this.edgeBeingEditedId!==void 0){var t,r,i,o;const s=this.body.edges[this.edgeBeingEditedId],a=this._getNewTargetNode(s.from.x,s.from.y),g=this._getNewTargetNode(s.to.x,s.to.y);this.temporaryIds.nodes.push(a.id),this.temporaryIds.nodes.push(g.id),this.body.nodes[a.id]=a,this.body.nodeIndices.push(a.id),this.body.nodes[g.id]=g,this.body.nodeIndices.push(g.id),this._temporaryBindUI("onTouch",z(t=this._controlNodeTouch).call(t,this)),this._temporaryBindUI("onTap",()=>{}),this._temporaryBindUI("onHold",()=>{}),this._temporaryBindUI("onDragStart",z(r=this._controlNodeDragStart).call(r,this)),this._temporaryBindUI("onDrag",z(i=this._controlNodeDrag).call(i,this)),this._temporaryBindUI("onDragEnd",z(o=this._controlNodeDragEnd).call(o,this)),this._temporaryBindUI("onMouseMove",()=>{}),this._temporaryBindEvent("beforeDrawing",A=>{const I=s.edgeType.findBorderPositions(A);a.selected===!1&&(a.x=I.from.x,a.y=I.from.y),g.selected===!1&&(g.x=I.to.x,g.y=I.to.y)}),this.body.emitter.emit("_redraw")}else this.showManipulatorToolbar()}deleteSelected(){this.editMode!==!0&&this.enableEditMode(),this._clean(),this.inMode="delete";const e=this.selectionHandler.getSelectedNodeIds(),t=this.selectionHandler.getSelectedEdgeIds();let r;if(e.length>0){for(let i=0;i<e.length;i++)if(this.body.nodes[e[i]].isCluster===!0){alert(this.options.locales[this.options.locale].deleteClusterError||this.options.locales.en.deleteClusterError);return}typeof this.options.deleteNode=="function"&&(r=this.options.deleteNode)}else t.length>0&&typeof this.options.deleteEdge=="function"&&(r=this.options.deleteEdge);if(typeof r=="function"){const i={nodes:e,edges:t};if(r.length===2)r(i,o=>{o!=null&&this.inMode==="delete"?(this.body.data.edges.getDataSet().remove(o.edges),this.body.data.nodes.getDataSet().remove(o.nodes),this.body.emitter.emit("startSimulation"),this.showManipulatorToolbar()):(this.body.emitter.emit("startSimulation"),this.showManipulatorToolbar())});else throw new Error("The function for delete does not support two arguments (data, callback)")}else this.body.data.edges.getDataSet().remove(t),this.body.data.nodes.getDataSet().remove(e),this.body.emitter.emit("startSimulation"),this.showManipulatorToolbar()}_setup(){this.options.enabled===!0?(this.guiEnabled=!0,this._createWrappers(),this.editMode===!1?this._createEditButton():this.showManipulatorToolbar()):(this._removeManipulationDOM(),this.guiEnabled=!1)}_createWrappers(){if(this.manipulationDiv===void 0&&(this.manipulationDiv=document.createElement("div"),this.manipulationDiv.className="vis-manipulation",this.editMode===!0?this.manipulationDiv.style.display="block":this.manipulationDiv.style.display="none",this.canvas.frame.appendChild(this.manipulationDiv)),this.editModeDiv===void 0&&(this.editModeDiv=document.createElement("div"),this.editModeDiv.className="vis-edit-mode",this.editMode===!0?this.editModeDiv.style.display="none":this.editModeDiv.style.display="block",this.canvas.frame.appendChild(this.editModeDiv)),this.closeDiv===void 0){var e,t;this.closeDiv=document.createElement("button"),this.closeDiv.className="vis-close",this.closeDiv.setAttribute("aria-label",(e=(t=this.options.locales[this.options.locale])===null||t===void 0?void 0:t.close)!==null&&e!==void 0?e:this.options.locales.en.close),this.closeDiv.style.display=this.manipulationDiv.style.display,this.canvas.frame.appendChild(this.closeDiv)}}_getNewTargetNode(e,t){const r=Me({},this.options.controlNodeStyle);r.id="targetNode"+is(),r.hidden=!1,r.physics=!1,r.x=e,r.y=t;const i=this.body.functions.createNode(r);return i.shape.boundingBox={left:e,right:e,top:t,bottom:t},i}_createEditButton(){var e;this._clean(),this.manipulationDOM={},Ki(this.editModeDiv);const t=this.options.locales[this.options.locale],r=this._createButton("editMode","vis-edit vis-edit-mode",t.edit||this.options.locales.en.edit);this.editModeDiv.appendChild(r),this._bindElementEvents(r,z(e=this.toggleEditMode).call(e,this))}_clean(){this.inMode=!1,this.guiEnabled===!0&&(Ki(this.editModeDiv),Ki(this.manipulationDiv),this._cleanupDOMEventListeners()),this._cleanupTemporaryNodesAndEdges(),this._unbindTemporaryUIs(),this._unbindTemporaryEvents(),this.body.emitter.emit("restorePhysics")}_cleanupDOMEventListeners(){for(const t of ti(e=this._domEventListenerCleanupQueue).call(e,0)){var e;t()}}_removeManipulationDOM(){this._clean(),Ki(this.manipulationDiv),Ki(this.editModeDiv),Ki(this.closeDiv),this.manipulationDiv&&this.canvas.frame.removeChild(this.manipulationDiv),this.editModeDiv&&this.canvas.frame.removeChild(this.editModeDiv),this.closeDiv&&this.canvas.frame.removeChild(this.closeDiv),this.manipulationDiv=void 0,this.editModeDiv=void 0,this.closeDiv=void 0}_createSeperator(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:1;this.manipulationDOM["seperatorLineDiv"+e]=document.createElement("div"),this.manipulationDOM["seperatorLineDiv"+e].className="vis-separator-line",this.manipulationDiv.appendChild(this.manipulationDOM["seperatorLineDiv"+e])}_createAddNodeButton(e){var t;const r=this._createButton("addNode","vis-add",e.addNode||this.options.locales.en.addNode);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.addNodeMode).call(t,this))}_createAddEdgeButton(e){var t;const r=this._createButton("addEdge","vis-connect",e.addEdge||this.options.locales.en.addEdge);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.addEdgeMode).call(t,this))}_createEditNodeButton(e){var t;const r=this._createButton("editNode","vis-edit",e.editNode||this.options.locales.en.editNode);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.editNode).call(t,this))}_createEditEdgeButton(e){var t;const r=this._createButton("editEdge","vis-edit",e.editEdge||this.options.locales.en.editEdge);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.editEdgeMode).call(t,this))}_createDeleteButton(e){var t;let r;this.options.rtl?r="vis-delete-rtl":r="vis-delete";const i=this._createButton("delete",r,e.del||this.options.locales.en.del);this.manipulationDiv.appendChild(i),this._bindElementEvents(i,z(t=this.deleteSelected).call(t,this))}_createBackButton(e){var t;const r=this._createButton("back","vis-back",e.back||this.options.locales.en.back);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.showManipulatorToolbar).call(t,this))}_createButton(e,t,r){let i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:"vis-label";return this.manipulationDOM[e+"Div"]=document.createElement("button"),this.manipulationDOM[e+"Div"].className="vis-button "+t,this.manipulationDOM[e+"Label"]=document.createElement("div"),this.manipulationDOM[e+"Label"].className=i,this.manipulationDOM[e+"Label"].innerText=r,this.manipulationDOM[e+"Div"].appendChild(this.manipulationDOM[e+"Label"]),this.manipulationDOM[e+"Div"]}_createDescription(e){this.manipulationDOM.descriptionLabel=document.createElement("div"),this.manipulationDOM.descriptionLabel.className="vis-none",this.manipulationDOM.descriptionLabel.innerText=e,this.manipulationDiv.appendChild(this.manipulationDOM.descriptionLabel)}_temporaryBindEvent(e,t){this.temporaryEventFunctions.push({event:e,boundFunction:t}),this.body.emitter.on(e,t)}_temporaryBindUI(e,t){if(this.body.eventListeners[e]!==void 0)this.temporaryUIFunctions[e]=this.body.eventListeners[e],this.body.eventListeners[e]=t;else throw new Error("This UI function does not exist. Typo? You tried: "+e+" possible are: "+ks(Be(this.body.eventListeners)))}_unbindTemporaryUIs(){for(const e in this.temporaryUIFunctions)Object.prototype.hasOwnProperty.call(this.temporaryUIFunctions,e)&&(this.body.eventListeners[e]=this.temporaryUIFunctions[e],delete this.temporaryUIFunctions[e]);this.temporaryUIFunctions={}}_unbindTemporaryEvents(){for(let e=0;e<this.temporaryEventFunctions.length;e++){const t=this.temporaryEventFunctions[e].event,r=this.temporaryEventFunctions[e].boundFunction;this.body.emitter.off(t,r)}this.temporaryEventFunctions=[]}_bindElementEvents(e,t){const r=new rs(e,{});WA(r,t),this._domEventListenerCleanupQueue.push(()=>{r.destroy()});const i=o=>{let{keyCode:s,key:a}=o;(a==="Enter"||a===" "||s===13||s===32)&&t()};e.addEventListener("keyup",i,!1),this._domEventListenerCleanupQueue.push(()=>{e.removeEventListener("keyup",i,!1)})}_cleanupTemporaryNodesAndEdges(){for(let o=0;o<this.temporaryIds.edges.length;o++){var e;this.body.edges[this.temporaryIds.edges[o]].disconnect(),delete this.body.edges[this.temporaryIds.edges[o]];const s=_e(e=this.body.edgeIndices).call(e,this.temporaryIds.edges[o]);if(s!==-1){var t;ti(t=this.body.edgeIndices).call(t,s,1)}}for(let o=0;o<this.temporaryIds.nodes.length;o++){var r;delete this.body.nodes[this.temporaryIds.nodes[o]];const s=_e(r=this.body.nodeIndices).call(r,this.temporaryIds.nodes[o]);if(s!==-1){var i;ti(i=this.body.nodeIndices).call(i,s,1)}}this.temporaryIds={nodes:[],edges:[]}}_controlNodeTouch(e){this.selectionHandler.unselectAll(),this.lastTouch=this.body.functions.getPointer(e.center),this.lastTouch.translation=tt({},this.body.view.translation)}_controlNodeDragStart(){const e=this.lastTouch,t=this.selectionHandler._pointerToPositionObject(e),r=this.body.nodes[this.temporaryIds.nodes[0]],i=this.body.nodes[this.temporaryIds.nodes[1]],o=this.body.edges[this.edgeBeingEditedId];this.selectedControlNode=void 0;const s=r.isOverlappingWith(t),a=i.isOverlappingWith(t);s===!0?(this.selectedControlNode=r,o.edgeType.from=r):a===!0&&(this.selectedControlNode=i,o.edgeType.to=i),this.selectedControlNode!==void 0&&this.selectionHandler.selectObject(this.selectedControlNode),this.body.emitter.emit("_redraw")}_controlNodeDrag(e){this.body.emitter.emit("disablePhysics");const t=this.body.functions.getPointer(e.center),r=this.canvas.DOMtoCanvas(t);this.selectedControlNode!==void 0?(this.selectedControlNode.x=r.x,this.selectedControlNode.y=r.y):this.interactionHandler.onDrag(e),this.body.emitter.emit("_redraw")}_controlNodeDragEnd(e){const t=this.body.functions.getPointer(e.center),r=this.selectionHandler._pointerToPositionObject(t),i=this.body.edges[this.edgeBeingEditedId];if(this.selectedControlNode===void 0)return;this.selectionHandler.unselectAll();const o=this.selectionHandler._getAllNodesOverlappingWith(r);let s;for(let a=o.length-1;a>=0;a--)if(o[a]!==this.selectedControlNode.id){s=this.body.nodes[o[a]];break}if(s!==void 0&&this.selectedControlNode!==void 0)if(s.isCluster===!0)alert(this.options.locales[this.options.locale].createEdgeError||this.options.locales.en.createEdgeError);else{const a=this.body.nodes[this.temporaryIds.nodes[0]];this.selectedControlNode.id===a.id?this._performEditEdge(s.id,i.to.id):this._performEditEdge(i.from.id,s.id)}else i.updateEdgeType(),this.body.emitter.emit("restorePhysics");this.body.emitter.emit("_redraw")}_handleConnect(e){if(new Date().valueOf()-this.touchTime>100){this.lastTouch=this.body.functions.getPointer(e.center),this.lastTouch.translation=tt({},this.body.view.translation),this.interactionHandler.drag.pointer=this.lastTouch,this.interactionHandler.drag.translation=this.lastTouch.translation;const t=this.lastTouch,r=this.selectionHandler.getNodeAt(t);if(r!==void 0)if(r.isCluster===!0)alert(this.options.locales[this.options.locale].createEdgeError||this.options.locales.en.createEdgeError);else{const i=this._getNewTargetNode(r.x,r.y);this.body.nodes[i.id]=i,this.body.nodeIndices.push(i.id);const o=this.body.functions.createEdge({id:"connectionEdge"+is(),from:r.id,to:i.id,physics:!1,smooth:{enabled:!0,type:"continuous",roundness:.5}});this.body.edges[o.id]=o,this.body.edgeIndices.push(o.id),this.temporaryIds.nodes.push(i.id),this.temporaryIds.edges.push(o.id)}this.touchTime=new Date().valueOf()}}_dragControlNode(e){const t=this.body.functions.getPointer(e.center),r=this.selectionHandler._pointerToPositionObject(t);let i;this.temporaryIds.edges[0]!==void 0&&(i=this.body.edges[this.temporaryIds.edges[0]].fromId);const o=this.selectionHandler._getAllNodesOverlappingWith(r);let s;for(let g=o.length-1;g>=0;g--){var a;if(_e(a=this.temporaryIds.nodes).call(a,o[g])===-1){s=this.body.nodes[o[g]];break}}if(e.controlEdge={from:i,to:s?s.id:void 0},this.selectionHandler.generateClickEvent("controlNodeDragging",e,t),this.temporaryIds.nodes[0]!==void 0){const g=this.body.nodes[this.temporaryIds.nodes[0]];g.x=this.canvas._XconvertDOMtoCanvas(t.x),g.y=this.canvas._YconvertDOMtoCanvas(t.y),this.body.emitter.emit("_redraw")}else this.interactionHandler.onDrag(e)}_finishConnect(e){const t=this.body.functions.getPointer(e.center),r=this.selectionHandler._pointerToPositionObject(t);let i;this.temporaryIds.edges[0]!==void 0&&(i=this.body.edges[this.temporaryIds.edges[0]].fromId);const o=this.selectionHandler._getAllNodesOverlappingWith(r);let s;for(let g=o.length-1;g>=0;g--){var a;if(_e(a=this.temporaryIds.nodes).call(a,o[g])===-1){s=this.body.nodes[o[g]];break}}this._cleanupTemporaryNodesAndEdges(),s!==void 0&&(s.isCluster===!0?alert(this.options.locales[this.options.locale].createEdgeError||this.options.locales.en.createEdgeError):this.body.nodes[i]!==void 0&&this.body.nodes[s.id]!==void 0&&this._performAddEdge(i,s.id)),e.controlEdge={from:i,to:s?s.id:void 0},this.selectionHandler.generateClickEvent("controlNodeDragEnd",e,t),this.body.emitter.emit("_redraw")}_dragStartEdge(e){const t=this.lastTouch;this.selectionHandler.generateClickEvent("dragStart",e,t,void 0,!0)}_performAddNode(e){const t={id:is(),x:e.pointer.canvas.x,y:e.pointer.canvas.y,label:"new"};if(typeof this.options.addNode=="function")if(this.options.addNode.length===2)this.options.addNode(t,r=>{r!=null&&this.inMode==="addNode"&&this.body.data.nodes.getDataSet().add(r),this.showManipulatorToolbar()});else throw this.showManipulatorToolbar(),new Error("The function for add does not support two arguments (data,callback)");else this.body.data.nodes.getDataSet().add(t),this.showManipulatorToolbar()}_performAddEdge(e,t){const r={from:e,to:t};if(typeof this.options.addEdge=="function")if(this.options.addEdge.length===2)this.options.addEdge(r,i=>{i!=null&&this.inMode==="addEdge"&&(this.body.data.edges.getDataSet().add(i),this.selectionHandler.unselectAll(),this.showManipulatorToolbar())});else throw new Error("The function for connect does not support two arguments (data,callback)");else this.body.data.edges.getDataSet().add(r),this.selectionHandler.unselectAll(),this.showManipulatorToolbar()}_performEditEdge(e,t){const r={id:this.edgeBeingEditedId,from:e,to:t,label:this.body.data.edges.get(this.edgeBeingEditedId).label};let i=this.options.editEdge;if(typeof i=="object"&&(i=i.editWithoutDrag),typeof i=="function")if(i.length===2)i(r,o=>{o==null||this.inMode!=="editEdge"?(this.body.edges[r.id].updateEdgeType(),this.body.emitter.emit("_redraw"),this.showManipulatorToolbar()):(this.body.data.edges.getDataSet().update(o),this.selectionHandler.unselectAll(),this.showManipulatorToolbar())});else throw new Error("The function for edit does not support two arguments (data, callback)");else this.body.data.edges.getDataSet().update(r),this.selectionHandler.unselectAll(),this.showManipulatorToolbar()}};const G="string",k="boolean",$="number",Ta="array",Q="object",w7="dom",ZCe="any",$f=["arrow","bar","box","circle","crow","curve","diamond","image","inv_curve","inv_triangle","triangle","vee"],Df={borderWidth:{number:$},borderWidthSelected:{number:$,undefined:"undefined"},brokenImage:{string:G,undefined:"undefined"},chosen:{label:{boolean:k,function:"function"},node:{boolean:k,function:"function"},__type__:{object:Q,boolean:k}},color:{border:{string:G},background:{string:G},highlight:{border:{string:G},background:{string:G},__type__:{object:Q,string:G}},hover:{border:{string:G},background:{string:G},__type__:{object:Q,string:G}},__type__:{object:Q,string:G}},opacity:{number:$,undefined:"undefined"},fixed:{x:{boolean:k},y:{boolean:k},__type__:{object:Q,boolean:k}},font:{align:{string:G},color:{string:G},size:{number:$},face:{string:G},background:{string:G},strokeWidth:{number:$},strokeColor:{string:G},vadjust:{number:$},multi:{boolean:k,string:G},bold:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},boldital:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},ital:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},mono:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},__type__:{object:Q,string:G}},group:{string:G,number:$,undefined:"undefined"},heightConstraint:{minimum:{number:$},valign:{string:G},__type__:{object:Q,boolean:k,number:$}},hidden:{boolean:k},icon:{face:{string:G},code:{string:G},size:{number:$},color:{string:G},weight:{string:G,number:$},__type__:{object:Q}},id:{string:G,number:$},image:{selected:{string:G,undefined:"undefined"},unselected:{string:G,undefined:"undefined"},__type__:{object:Q,string:G}},imagePadding:{top:{number:$},right:{number:$},bottom:{number:$},left:{number:$},__type__:{object:Q,number:$}},label:{string:G,undefined:"undefined"},labelHighlightBold:{boolean:k},level:{number:$,undefined:"undefined"},margin:{top:{number:$},right:{number:$},bottom:{number:$},left:{number:$},__type__:{object:Q,number:$}},mass:{number:$},physics:{boolean:k},scaling:{min:{number:$},max:{number:$},label:{enabled:{boolean:k},min:{number:$},max:{number:$},maxVisible:{number:$},drawThreshold:{number:$},__type__:{object:Q,boolean:k}},customScalingFunction:{function:"function"},__type__:{object:Q}},shadow:{enabled:{boolean:k},color:{string:G},size:{number:$},x:{number:$},y:{number:$},__type__:{object:Q,boolean:k}},shape:{string:["custom","ellipse","circle","database","box","text","image","circularImage","diamond","dot","star","triangle","triangleDown","square","icon","hexagon"]},ctxRenderer:{function:"function"},shapeProperties:{borderDashes:{boolean:k,array:Ta},borderRadius:{number:$},interpolation:{boolean:k},useImageSize:{boolean:k},useBorderWithImage:{boolean:k},coordinateOrigin:{string:["center","top-left"]},__type__:{object:Q}},size:{number:$},title:{string:G,dom:w7,undefined:"undefined"},value:{number:$,undefined:"undefined"},widthConstraint:{minimum:{number:$},maximum:{number:$},__type__:{object:Q,boolean:k,number:$}},x:{number:$},y:{number:$},__type__:{object:Q}},HCe={configure:{enabled:{boolean:k},filter:{boolean:k,string:G,array:Ta,function:"function"},container:{dom:w7},showButton:{boolean:k},__type__:{object:Q,boolean:k,string:G,array:Ta,function:"function"}},edges:{arrows:{to:{enabled:{boolean:k},scaleFactor:{number:$},type:{string:$f},imageHeight:{number:$},imageWidth:{number:$},src:{string:G},__type__:{object:Q,boolean:k}},middle:{enabled:{boolean:k},scaleFactor:{number:$},type:{string:$f},imageWidth:{number:$},imageHeight:{number:$},src:{string:G},__type__:{object:Q,boolean:k}},from:{enabled:{boolean:k},scaleFactor:{number:$},type:{string:$f},imageWidth:{number:$},imageHeight:{number:$},src:{string:G},__type__:{object:Q,boolean:k}},__type__:{string:["from","to","middle"],object:Q}},endPointOffset:{from:{number:$},to:{number:$},__type__:{object:Q,number:$}},arrowStrikethrough:{boolean:k},background:{enabled:{boolean:k},color:{string:G},size:{number:$},dashes:{boolean:k,array:Ta},__type__:{object:Q,boolean:k}},chosen:{label:{boolean:k,function:"function"},edge:{boolean:k,function:"function"},__type__:{object:Q,boolean:k}},color:{color:{string:G},highlight:{string:G},hover:{string:G},inherit:{string:["from","to","both"],boolean:k},opacity:{number:$},__type__:{object:Q,string:G}},dashes:{boolean:k,array:Ta},font:{color:{string:G},size:{number:$},face:{string:G},background:{string:G},strokeWidth:{number:$},strokeColor:{string:G},align:{string:["horizontal","top","middle","bottom"]},vadjust:{number:$},multi:{boolean:k,string:G},bold:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},boldital:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},ital:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},mono:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},__type__:{object:Q,string:G}},hidden:{boolean:k},hoverWidth:{function:"function",number:$},label:{string:G,undefined:"undefined"},labelHighlightBold:{boolean:k},length:{number:$,undefined:"undefined"},physics:{boolean:k},scaling:{min:{number:$},max:{number:$},label:{enabled:{boolean:k},min:{number:$},max:{number:$},maxVisible:{number:$},drawThreshold:{number:$},__type__:{object:Q,boolean:k}},customScalingFunction:{function:"function"},__type__:{object:Q}},selectionWidth:{function:"function",number:$},selfReferenceSize:{number:$},selfReference:{size:{number:$},angle:{number:$},renderBehindTheNode:{boolean:k},__type__:{object:Q}},shadow:{enabled:{boolean:k},color:{string:G},size:{number:$},x:{number:$},y:{number:$},__type__:{object:Q,boolean:k}},smooth:{enabled:{boolean:k},type:{string:["dynamic","continuous","discrete","diagonalCross","straightCross","horizontal","vertical","curvedCW","curvedCCW","cubicBezier"]},roundness:{number:$},forceDirection:{string:["horizontal","vertical","none"],boolean:k},__type__:{object:Q,boolean:k}},title:{string:G,undefined:"undefined"},width:{number:$},widthConstraint:{maximum:{number:$},__type__:{object:Q,boolean:k,number:$}},value:{number:$,undefined:"undefined"},__type__:{object:Q}},groups:{useDefaultGroups:{boolean:k},__any__:Df,__type__:{object:Q}},interaction:{dragNodes:{boolean:k},dragView:{boolean:k},hideEdgesOnDrag:{boolean:k},hideEdgesOnZoom:{boolean:k},hideNodesOnDrag:{boolean:k},hover:{boolean:k},keyboard:{enabled:{boolean:k},speed:{x:{number:$},y:{number:$},zoom:{number:$},__type__:{object:Q}},bindToWindow:{boolean:k},autoFocus:{boolean:k},__type__:{object:Q,boolean:k}},multiselect:{boolean:k},navigationButtons:{boolean:k},selectable:{boolean:k},selectConnectedEdges:{boolean:k},hoverConnectedEdges:{boolean:k},tooltipDelay:{number:$},zoomView:{boolean:k},zoomSpeed:{number:$},__type__:{object:Q}},layout:{randomSeed:{undefined:"undefined",number:$,string:G},improvedLayout:{boolean:k},clusterThreshold:{number:$},hierarchical:{enabled:{boolean:k},levelSeparation:{number:$},nodeSpacing:{number:$},treeSpacing:{number:$},blockShifting:{boolean:k},edgeMinimization:{boolean:k},parentCentralization:{boolean:k},direction:{string:["UD","DU","LR","RL"]},sortMethod:{string:["hubsize","directed"]},shakeTowards:{string:["leaves","roots"]},__type__:{object:Q,boolean:k}},__type__:{object:Q}},manipulation:{enabled:{boolean:k},initiallyActive:{boolean:k},addNode:{boolean:k,function:"function"},addEdge:{boolean:k,function:"function"},editNode:{function:"function"},editEdge:{editWithoutDrag:{function:"function"},__type__:{object:Q,boolean:k,function:"function"}},deleteNode:{boolean:k,function:"function"},deleteEdge:{boolean:k,function:"function"},controlNodeStyle:Df,__type__:{object:Q,boolean:k}},nodes:Df,physics:{enabled:{boolean:k},barnesHut:{theta:{number:$},gravitationalConstant:{number:$},centralGravity:{number:$},springLength:{number:$},springConstant:{number:$},damping:{number:$},avoidOverlap:{number:$},__type__:{object:Q}},forceAtlas2Based:{theta:{number:$},gravitationalConstant:{number:$},centralGravity:{number:$},springLength:{number:$},springConstant:{number:$},damping:{number:$},avoidOverlap:{number:$},__type__:{object:Q}},repulsion:{centralGravity:{number:$},springLength:{number:$},springConstant:{number:$},nodeDistance:{number:$},damping:{number:$},__type__:{object:Q}},hierarchicalRepulsion:{centralGravity:{number:$},springLength:{number:$},springConstant:{number:$},nodeDistance:{number:$},damping:{number:$},avoidOverlap:{number:$},__type__:{object:Q}},maxVelocity:{number:$},minVelocity:{number:$},solver:{string:["barnesHut","repulsion","hierarchicalRepulsion","forceAtlas2Based"]},stabilization:{enabled:{boolean:k},iterations:{number:$},updateInterval:{number:$},onlyDynamicEdges:{boolean:k},fit:{boolean:k},__type__:{object:Q,boolean:k}},timestep:{number:$},adaptiveTimestep:{boolean:k},wind:{x:{number:$},y:{number:$},__type__:{object:Q}},__type__:{object:Q,boolean:k}},autoResize:{boolean:k},clickToUse:{boolean:k},locale:{string:G},locales:{__any__:{any:ZCe},__type__:{object:Q}},height:{string:G},width:{string:G},__type__:{object:Q}},E7={nodes:{borderWidth:[1,0,10,1],borderWidthSelected:[2,0,10,1],color:{border:["color","#2B7CE9"],background:["color","#97C2FC"],highlight:{border:["color","#2B7CE9"],background:["color","#D2E5FF"]},hover:{border:["color","#2B7CE9"],background:["color","#D2E5FF"]}},opacity:[0,0,1,.1],fixed:{x:!1,y:!1},font:{color:["color","#343434"],size:[14,0,100,1],face:["arial","verdana","tahoma"],background:["color","none"],strokeWidth:[0,0,50,1],strokeColor:["color","#ffffff"]},hidden:!1,labelHighlightBold:!0,physics:!0,scaling:{min:[10,0,200,1],max:[30,0,200,1],label:{enabled:!1,min:[14,0,200,1],max:[30,0,200,1],maxVisible:[30,0,200,1],drawThreshold:[5,0,20,1]}},shadow:{enabled:!1,color:"rgba(0,0,0,0.5)",size:[10,0,20,1],x:[5,-30,30,1],y:[5,-30,30,1]},shape:["ellipse","box","circle","database","diamond","dot","square","star","text","triangle","triangleDown","hexagon"],shapeProperties:{borderDashes:!1,borderRadius:[6,0,20,1],interpolation:!0,useImageSize:!1},size:[25,0,200,1]},edges:{arrows:{to:{enabled:!1,scaleFactor:[1,0,3,.05],type:"arrow"},middle:{enabled:!1,scaleFactor:[1,0,3,.05],type:"arrow"},from:{enabled:!1,scaleFactor:[1,0,3,.05],type:"arrow"}},endPointOffset:{from:[0,-10,10,1],to:[0,-10,10,1]},arrowStrikethrough:!0,color:{color:["color","#848484"],highlight:["color","#848484"],hover:["color","#848484"],inherit:["from","to","both",!0,!1],opacity:[1,0,1,.05]},dashes:!1,font:{color:["color","#343434"],size:[14,0,100,1],face:["arial","verdana","tahoma"],background:["color","none"],strokeWidth:[2,0,50,1],strokeColor:["color","#ffffff"],align:["horizontal","top","middle","bottom"]},hidden:!1,hoverWidth:[1.5,0,5,.1],labelHighlightBold:!0,physics:!0,scaling:{min:[1,0,100,1],max:[15,0,100,1],label:{enabled:!0,min:[14,0,200,1],max:[30,0,200,1],maxVisible:[30,0,200,1],drawThreshold:[5,0,20,1]}},selectionWidth:[1.5,0,5,.1],selfReferenceSize:[20,0,200,1],selfReference:{size:[20,0,200,1],angle:[Math.PI/2,-6*Math.PI,6*Math.PI,Math.PI/8],renderBehindTheNode:!0},shadow:{enabled:!1,color:"rgba(0,0,0,0.5)",size:[10,0,20,1],x:[5,-30,30,1],y:[5,-30,30,1]},smooth:{enabled:!0,type:["dynamic","continuous","discrete","diagonalCross","straightCross","horizontal","vertical","curvedCW","curvedCCW","cubicBezier"],forceDirection:["horizontal","vertical","none"],roundness:[.5,0,1,.05]},width:[1,0,30,1]},layout:{hierarchical:{enabled:!1,levelSeparation:[150,20,500,5],nodeSpacing:[100,20,500,5],treeSpacing:[200,20,500,5],blockShifting:!0,edgeMinimization:!0,parentCentralization:!0,direction:["UD","DU","LR","RL"],sortMethod:["hubsize","directed"],shakeTowards:["leaves","roots"]}},interaction:{dragNodes:!0,dragView:!0,hideEdgesOnDrag:!1,hideEdgesOnZoom:!1,hideNodesOnDrag:!1,hover:!1,keyboard:{enabled:!1,speed:{x:[10,0,40,1],y:[10,0,40,1],zoom:[.02,0,.1,.005]},bindToWindow:!0,autoFocus:!0},multiselect:!1,navigationButtons:!1,selectable:!0,selectConnectedEdges:!0,hoverConnectedEdges:!0,tooltipDelay:[300,0,1e3,25],zoomView:!0,zoomSpeed:[1,.1,2,.1]},manipulation:{enabled:!1,initiallyActive:!1},physics:{enabled:!0,barnesHut:{theta:[.5,.1,1,.05],gravitationalConstant:[-2e3,-3e4,0,50],centralGravity:[.3,0,10,.05],springLength:[95,0,500,5],springConstant:[.04,0,1.2,.005],damping:[.09,0,1,.01],avoidOverlap:[0,0,1,.01]},forceAtlas2Based:{theta:[.5,.1,1,.05],gravitationalConstant:[-50,-500,0,1],centralGravity:[.01,0,1,.005],springLength:[95,0,500,5],springConstant:[.08,0,1.2,.005],damping:[.4,0,1,.01],avoidOverlap:[0,0,1,.01]},repulsion:{centralGravity:[.2,0,10,.05],springLength:[200,0,500,5],springConstant:[.05,0,1.2,.005],nodeDistance:[100,0,500,5],damping:[.09,0,1,.01]},hierarchicalRepulsion:{centralGravity:[.2,0,10,.05],springLength:[100,0,500,5],springConstant:[.01,0,1.2,.005],nodeDistance:[120,0,500,5],damping:[.09,0,1,.01],avoidOverlap:[0,0,1,.01]},maxVelocity:[50,0,150,1],minVelocity:[.1,.01,.5,.01],solver:["barnesHut","forceAtlas2Based","repulsion","hierarchicalRepulsion"],timestep:[.5,.01,1,.01],wind:{x:[0,-10,10,.1],y:[0,-10,10,.1]}}},UCe=(n,e,t)=>{var r;return!!(rn(n).call(n,"physics")&&rn(r=E7.physics.solver).call(r,e)&&t.physics.solver!==e&&e!=="wind")};let KCe=class{constructor(){}getDistances(e,t,r){const i={},o=e.edges;for(let a=0;a<t.length;a++){const g=t[a],A={};i[g]=A;for(let I=0;I<t.length;I++)A[t[I]]=a==I?0:1e9}for(let a=0;a<r.length;a++){const g=o[r[a]];g.connected===!0&&i[g.fromId]!==void 0&&i[g.toId]!==void 0&&(i[g.fromId][g.toId]=1,i[g.toId][g.fromId]=1)}const s=t.length;for(let a=0;a<s;a++){const g=t[a],A=i[g];for(let I=0;I<s-1;I++){const C=t[I],l=i[C];for(let d=I+1;d<s;d++){const u=t[d],h=i[u],v=Math.min(l[u],l[g]+A[u]);l[u]=v,h[C]=v}}}return i}},YCe=class{constructor(e,t,r){this.body=e,this.springLength=t,this.springConstant=r,this.distanceSolver=new KCe}setOptions(e){e&&(e.springLength&&(this.springLength=e.springLength),e.springConstant&&(this.springConstant=e.springConstant))}solve(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;const i=this.distanceSolver.getDistances(this.body,e,t);this._createL_matrix(i),this._createK_matrix(i),this._createE_matrix();const o=.01,s=1;let a=0;const g=Math.max(1e3,Math.min(10*this.body.nodeIndices.length,6e3)),A=5;let I=1e9,C=0,l=0,d=0,u=0,h=0;for(;I>o&&a<g;)for(a+=1,[C,I,l,d]=this._getHighestEnergyNode(r),u=I,h=0;u>s&&h<A;)h+=1,this._moveNode(C,l,d),[u,l,d]=this._getEnergy(C)}_getHighestEnergyNode(e){const t=this.body.nodeIndices,r=this.body.nodes;let i=0,o=t[0],s=0,a=0;for(let g=0;g<t.length;g++){const A=t[g];if(r[A].predefinedPosition!==!0||r[A].isCluster===!0&&e===!0||r[A].options.fixed.x!==!0||r[A].options.fixed.y!==!0){const[I,C,l]=this._getEnergy(A);i<I&&(i=I,o=A,s=C,a=l)}}return[o,i,s,a]}_getEnergy(e){const[t,r]=this.E_sums[e];return[Math.sqrt(t**2+r**2),t,r]}_moveNode(e,t,r){const i=this.body.nodeIndices,o=this.body.nodes;let s=0,a=0,g=0;const A=o[e].x,I=o[e].y,C=this.K_matrix[e],l=this.L_matrix[e];for(let p=0;p<i.length;p++){const y=i[p];if(y!==e){const E=o[y].x,S=o[y].y,m=C[y],w=l[y],_=1/((A-E)**2+(I-S)**2)**1.5;s+=m*(1-w*(I-S)**2*_),a+=m*(w*(A-E)*(I-S)*_),g+=m*(1-w*(A-E)**2*_)}}const d=s,u=a,h=t,v=g,f=r,c=(h/d+f/u)/(u/d-v/u),b=-(u*c+h)/d;o[e].x+=b,o[e].y+=c,this._updateE_matrix(e)}_createL_matrix(e){const t=this.body.nodeIndices,r=this.springLength;this.L_matrix=[];for(let i=0;i<t.length;i++){this.L_matrix[t[i]]={};for(let o=0;o<t.length;o++)this.L_matrix[t[i]][t[o]]=r*e[t[i]][t[o]]}}_createK_matrix(e){const t=this.body.nodeIndices,r=this.springConstant;this.K_matrix=[];for(let i=0;i<t.length;i++){this.K_matrix[t[i]]={};for(let o=0;o<t.length;o++)this.K_matrix[t[i]][t[o]]=r*e[t[i]][t[o]]**-2}}_createE_matrix(){const e=this.body.nodeIndices,t=this.body.nodes;this.E_matrix={},this.E_sums={};for(let r=0;r<e.length;r++)this.E_matrix[e[r]]=[];for(let r=0;r<e.length;r++){const i=e[r],o=t[i].x,s=t[i].y;let a=0,g=0;for(let A=r;A<e.length;A++){const I=e[A];if(I!==i){const C=t[I].x,l=t[I].y,d=1/Math.sqrt((o-C)**2+(s-l)**2);this.E_matrix[i][A]=[this.K_matrix[i][I]*(o-C-this.L_matrix[i][I]*(o-C)*d),this.K_matrix[i][I]*(s-l-this.L_matrix[i][I]*(s-l)*d)],this.E_matrix[I][r]=this.E_matrix[i][A],a+=this.E_matrix[i][A][0],g+=this.E_matrix[i][A][1]}}this.E_sums[i]=[a,g]}}_updateE_matrix(e){const t=this.body.nodeIndices,r=this.body.nodes,i=this.E_matrix[e],o=this.K_matrix[e],s=this.L_matrix[e],a=r[e].x,g=r[e].y;let A=0,I=0;for(let C=0;C<t.length;C++){const l=t[C];if(l!==e){const d=i[C],u=d[0],h=d[1],v=r[l].x,f=r[l].y,c=1/Math.sqrt((a-v)**2+(g-f)**2),b=o[l]*(a-v-s[l]*(a-v)*c),p=o[l]*(g-f-s[l]*(g-f)*c);i[C]=[b,p],A+=b,I+=p;const y=this.E_sums[l];y[0]+=b-u,y[1]+=p-h}}this.E_sums[e]=[A,I]}};function X(n,e,t){var r,i,o,s;if(!(this instanceof X))throw new SyntaxError("Constructor must be called with the new operator");this.options={},this.defaultOptions={locale:"en",locales:Jse,clickToUse:!1},tt(this.options,this.defaultOptions),this.body={container:n,nodes:{},nodeIndices:[],edges:{},edgeIndices:[],emitter:{on:z(r=this.on).call(r,this),off:z(i=this.off).call(i,this),emit:z(o=this.emit).call(o,this),once:z(s=this.once).call(s,this)},eventListeners:{onTap:function(){},onTouch:function(){},onDoubleTap:function(){},onHold:function(){},onDragStart:function(){},onDrag:function(){},onDragEnd:function(){},onMouseWheel:function(){},onPinch:function(){},onMouseMove:function(){},onRelease:function(){},onContext:function(){}},data:{nodes:null,edges:null},functions:{createNode:function(){},createEdge:function(){},getPointer:function(){}},modules:{},view:{scale:1,translation:{x:0,y:0}},selectionBox:{show:!1,position:{start:{x:0,y:0},end:{x:0,y:0}}}},this.bindEventListeners(),this.images=new rae(()=>this.body.emitter.emit("_requestRedraw")),this.groups=new cae,this.canvas=new fCe(this.body),this.selectionHandler=new xCe(this.body,this.canvas),this.interactionHandler=new yCe(this.body,this.canvas,this.selectionHandler),this.view=new vCe(this.body,this.canvas),this.renderer=new lCe(this.body,this.canvas),this.physics=new ACe(this.body),this.layoutEngine=new WCe(this.body),this.clustering=new CCe(this.body),this.manipulation=new VCe(this.body,this.canvas,this.selectionHandler,this.interactionHandler),this.nodesHandler=new FIe(this.body,this.images,this.groups,this.layoutEngine),this.edgesHandler=new iCe(this.body,this.images,this.groups),this.body.modules.kamadaKawai=new YCe(this.body,150,.05),this.body.modules.clustering=this.clustering,this.canvas._create(),this.setOptions(t),this.setData(e)}GX(X.prototype);X.prototype.setOptions=function(n){if(n===null&&(n=void 0),n!==void 0){if(Pse.validate(n,HCe)===!0&&console.error("%cErrors have been found in the supplied options object.",WQ),zs(["locale","locales","clickToUse"],this.options,n),n.locale!==void 0&&(n.locale=eae(n.locales||this.options.locales,n.locale)),n=this.layoutEngine.setOptions(n.layout,n),this.canvas.setOptions(n),this.groups.setOptions(n.groups),this.nodesHandler.setOptions(n.nodes),this.edgesHandler.setOptions(n.edges),this.physics.setOptions(n.physics),this.manipulation.setOptions(n.manipulation,n,this.options),this.interactionHandler.setOptions(n.interaction),this.renderer.setOptions(n.interaction),this.selectionHandler.setOptions(n.interaction),n.groups!==void 0&&this.body.emitter.emit("refreshNodes"),"configure"in n&&(this.configurator||(this.configurator=new Tse(this,this.body.container,E7,this.canvas.pixelRatio,UCe)),this.configurator.setOptions(n.configure)),this.configurator&&this.configurator.options.enabled===!0){const r={nodes:{},edges:{},layout:{},interaction:{},manipulation:{},physics:{},global:{}};Me(r.nodes,this.nodesHandler.options),Me(r.edges,this.edgesHandler.options),Me(r.layout,this.layoutEngine.options),Me(r.interaction,this.selectionHandler.options),Me(r.interaction,this.renderer.options),Me(r.interaction,this.interactionHandler.options),Me(r.manipulation,this.manipulation.options),Me(r.physics,this.physics.options),Me(r.global,this.canvas.options),Me(r.global,this.options),this.configurator.setModuleOptions(r)}n.clickToUse!==void 0?n.clickToUse===!0?this.activator===void 0&&(this.activator=new Ose(this.canvas.frame),this.activator.on("change",()=>{this.body.emitter.emit("activate")})):(this.activator!==void 0&&(this.activator.destroy(),delete this.activator),this.body.emitter.emit("activate")):this.body.emitter.emit("activate"),this.canvas.setSize(),this.body.emitter.emit("startSimulation")}};X.prototype._updateVisibleIndices=function(){const n=this.body.nodes,e=this.body.edges;this.body.nodeIndices=[],this.body.edgeIndices=[];for(const t in n)Object.prototype.hasOwnProperty.call(n,t)&&!this.clustering._isClusteredNode(t)&&n[t].options.hidden===!1&&this.body.nodeIndices.push(n[t].id);for(const t in e)if(Object.prototype.hasOwnProperty.call(e,t)){const r=e[t],i=n[r.fromId],o=n[r.toId],s=i!==void 0&&o!==void 0;!this.clustering._isClusteredEdge(t)&&r.options.hidden===!1&&s&&i.options.hidden===!1&&o.options.hidden===!1&&this.body.edgeIndices.push(r.id)}};X.prototype.bindEventListeners=function(){this.body.emitter.on("_dataChanged",()=>{this.edgesHandler._updateState(),this.body.emitter.emit("_dataUpdated")}),this.body.emitter.on("_dataUpdated",()=>{this.clustering._updateState(),this._updateVisibleIndices(),this._updateValueRange(this.body.nodes),this._updateValueRange(this.body.edges),this.body.emitter.emit("startSimulation"),this.body.emitter.emit("_requestRedraw")})};X.prototype.setData=function(n){if(this.body.emitter.emit("resetPhysics"),this.body.emitter.emit("_resetData"),this.selectionHandler.unselectAll(),n&&n.dot&&(n.nodes||n.edges))throw new SyntaxError('Data must contain either parameter "dot" or parameter pair "nodes" and "edges", but not both.');if(this.setOptions(n&&n.options),n&&n.dot){console.warn("The dot property has been deprecated. Please use the static convertDot method to convert DOT into vis.network format and use the normal data format with nodes and edges. This converter is used like this: var data = vis.network.convertDot(dotString);");const e=zse(n.dot);this.setData(e);return}else if(n&&n.gephi){console.warn("The gephi property has been deprecated. Please use the static convertGephi method to convert gephi into vis.network format and use the normal data format with nodes and edges. This converter is used like this: var data = vis.network.convertGephi(gephiJson);");const e=jse(n.gephi);this.setData(e);return}else this.nodesHandler.setData(n&&n.nodes,!0),this.edgesHandler.setData(n&&n.edges,!0);this.body.emitter.emit("_dataChanged"),this.body.emitter.emit("_dataLoaded"),this.body.emitter.emit("initPhysics")};X.prototype.destroy=function(){this.body.emitter.emit("destroy"),this.body.emitter.off(),this.off(),delete this.groups,delete this.canvas,delete this.selectionHandler,delete this.interactionHandler,delete this.view,delete this.renderer,delete this.physics,delete this.layoutEngine,delete this.clustering,delete this.manipulation,delete this.nodesHandler,delete this.edgesHandler,delete this.configurator,delete this.images;for(const n in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,n)&&delete this.body.nodes[n];for(const n in this.body.edges)Object.prototype.hasOwnProperty.call(this.body.edges,n)&&delete this.body.edges[n];Ki(this.body.container)};X.prototype._updateValueRange=function(n){let e,t,r,i=0;for(e in n)if(Object.prototype.hasOwnProperty.call(n,e)){const o=n[e].getValue();o!==void 0&&(t=t===void 0?o:Math.min(o,t),r=r===void 0?o:Math.max(o,r),i+=o)}if(t!==void 0&&r!==void 0)for(e in n)Object.prototype.hasOwnProperty.call(n,e)&&n[e].setValueRange(t,r,i)};X.prototype.isActive=function(){return!this.activator||this.activator.active};X.prototype.setSize=function(){return this.canvas.setSize.apply(this.canvas,arguments)};X.prototype.canvasToDOM=function(){return this.canvas.canvasToDOM.apply(this.canvas,arguments)};X.prototype.DOMtoCanvas=function(){return this.canvas.DOMtoCanvas.apply(this.canvas,arguments)};X.prototype.findNode=function(){return this.clustering.findNode.apply(this.clustering,arguments)};X.prototype.isCluster=function(){return this.clustering.isCluster.apply(this.clustering,arguments)};X.prototype.openCluster=function(){return this.clustering.openCluster.apply(this.clustering,arguments)};X.prototype.cluster=function(){return this.clustering.cluster.apply(this.clustering,arguments)};X.prototype.getNodesInCluster=function(){return this.clustering.getNodesInCluster.apply(this.clustering,arguments)};X.prototype.clusterByConnection=function(){return this.clustering.clusterByConnection.apply(this.clustering,arguments)};X.prototype.clusterByHubsize=function(){return this.clustering.clusterByHubsize.apply(this.clustering,arguments)};X.prototype.updateClusteredNode=function(){return this.clustering.updateClusteredNode.apply(this.clustering,arguments)};X.prototype.getClusteredEdges=function(){return this.clustering.getClusteredEdges.apply(this.clustering,arguments)};X.prototype.getBaseEdge=function(){return this.clustering.getBaseEdge.apply(this.clustering,arguments)};X.prototype.getBaseEdges=function(){return this.clustering.getBaseEdges.apply(this.clustering,arguments)};X.prototype.updateEdge=function(){return this.clustering.updateEdge.apply(this.clustering,arguments)};X.prototype.clusterOutliers=function(){return this.clustering.clusterOutliers.apply(this.clustering,arguments)};X.prototype.getSeed=function(){return this.layoutEngine.getSeed.apply(this.layoutEngine,arguments)};X.prototype.enableEditMode=function(){return this.manipulation.enableEditMode.apply(this.manipulation,arguments)};X.prototype.disableEditMode=function(){return this.manipulation.disableEditMode.apply(this.manipulation,arguments)};X.prototype.addNodeMode=function(){return this.manipulation.addNodeMode.apply(this.manipulation,arguments)};X.prototype.editNode=function(){return this.manipulation.editNode.apply(this.manipulation,arguments)};X.prototype.editNodeMode=function(){return console.warn("Deprecated: Please use editNode instead of editNodeMode."),this.manipulation.editNode.apply(this.manipulation,arguments)};X.prototype.addEdgeMode=function(){return this.manipulation.addEdgeMode.apply(this.manipulation,arguments)};X.prototype.editEdgeMode=function(){return this.manipulation.editEdgeMode.apply(this.manipulation,arguments)};X.prototype.deleteSelected=function(){return this.manipulation.deleteSelected.apply(this.manipulation,arguments)};X.prototype.getPositions=function(){return this.nodesHandler.getPositions.apply(this.nodesHandler,arguments)};X.prototype.getPosition=function(){return this.nodesHandler.getPosition.apply(this.nodesHandler,arguments)};X.prototype.storePositions=function(){return this.nodesHandler.storePositions.apply(this.nodesHandler,arguments)};X.prototype.moveNode=function(){return this.nodesHandler.moveNode.apply(this.nodesHandler,arguments)};X.prototype.getBoundingBox=function(){return this.nodesHandler.getBoundingBox.apply(this.nodesHandler,arguments)};X.prototype.getConnectedNodes=function(n){return this.body.nodes[n]!==void 0?this.nodesHandler.getConnectedNodes.apply(this.nodesHandler,arguments):this.edgesHandler.getConnectedNodes.apply(this.edgesHandler,arguments)};X.prototype.getConnectedEdges=function(){return this.nodesHandler.getConnectedEdges.apply(this.nodesHandler,arguments)};X.prototype.startSimulation=function(){return this.physics.startSimulation.apply(this.physics,arguments)};X.prototype.stopSimulation=function(){return this.physics.stopSimulation.apply(this.physics,arguments)};X.prototype.stabilize=function(){return this.physics.stabilize.apply(this.physics,arguments)};X.prototype.getSelection=function(){return this.selectionHandler.getSelection.apply(this.selectionHandler,arguments)};X.prototype.setSelection=function(){return this.selectionHandler.setSelection.apply(this.selectionHandler,arguments)};X.prototype.getSelectedNodes=function(){return this.selectionHandler.getSelectedNodeIds.apply(this.selectionHandler,arguments)};X.prototype.getSelectedEdges=function(){return this.selectionHandler.getSelectedEdgeIds.apply(this.selectionHandler,arguments)};X.prototype.getNodeAt=function(){const n=this.selectionHandler.getNodeAt.apply(this.selectionHandler,arguments);return n!==void 0&&n.id!==void 0?n.id:n};X.prototype.getEdgeAt=function(){const n=this.selectionHandler.getEdgeAt.apply(this.selectionHandler,arguments);return n!==void 0&&n.id!==void 0?n.id:n};X.prototype.selectNodes=function(){return this.selectionHandler.selectNodes.apply(this.selectionHandler,arguments)};X.prototype.selectEdges=function(){return this.selectionHandler.selectEdges.apply(this.selectionHandler,arguments)};X.prototype.unselectAll=function(){this.selectionHandler.unselectAll.apply(this.selectionHandler,arguments),this.selectionHandler.commitWithoutEmitting.apply(this.selectionHandler),this.redraw()};X.prototype.redraw=function(){return this.renderer.redraw.apply(this.renderer,arguments)};X.prototype.getScale=function(){return this.view.getScale.apply(this.view,arguments)};X.prototype.getViewPosition=function(){return this.view.getViewPosition.apply(this.view,arguments)};X.prototype.fit=function(){return this.view.fit.apply(this.view,arguments)};X.prototype.moveTo=function(){return this.view.moveTo.apply(this.view,arguments)};X.prototype.focus=function(){return this.view.focus.apply(this.view,arguments)};X.prototype.releaseNode=function(){return this.view.releaseNode.apply(this.view,arguments)};X.prototype.getOptionsFromConfigurator=function(){let n={};return this.configurator&&(n=this.configurator.getOptions.apply(this.configurator)),n};const S7={vue:{color:"#42b883"},ts:{color:"#3B86CB"},js:{color:"#d6cb2d"},json:{color:"#cf8f30"},css:{color:"#e6659a"},html:{color:"#e34c26"},jsx:{color:"#54B9D1"},tsx:{color:"#4FC7FF"},other:{color:"#B86542"}},XCe=["vue","other"];function QCe(){const[n,e]=RX(!0);return{fileTypeData:Object.entries(S7).map(([t,r])=>({key:t,color:r.color,capitalize:XCe.includes(t)})),fileTypeShow:n,toggleFileType:e}}const{isDark:JCe}=Pte(),nB=PX(()=>({nodes:{shape:"dot",size:16,font:{color:JCe.value?"#fff":"#000",multi:"html"}},interaction:{hover:!0},physics:{maxVelocity:146,solver:"forceAtlas2Based",timestep:.35,stabilization:{enabled:!0,iterations:200}},groups:S7})),Ma=PX({get:()=>oO.value.graphSettings,set:n=>{oO.value.graphSettings=n}});$A(Ma,()=>{ET()},{deep:!0});const yT=Bn("");xte(yT,()=>{ET()},{debounce:350});const bT=Bn(""),hs=new us([]),cs=new us([]),wT=xX([]),_7=new Map,ni=new Map,os=new Map,ele=n=>n.reduce((e,t)=>(e.some(r=>r.id===t.id)||e.push(t),e),[]),O7=n=>n.reduce((e,t)=>(e.some(r=>r.from===t.from&&r.to===t.to)||e.push(t),e),[]);function tle(){wT.value=[],_7.clear(),hs.clear(),cs.clear(),ni.clear(),os.clear()}function fs(n){const e=n.id.includes("node_modules");return!(!Ma.value.node_modules&&e||!Ma.value.virtual&&n.virtual&&!e||!Ma.value.lib&&!n.id.includes(bT.value)&&!n.virtual)}function T7(n){const e=os.get(n);return e?e.some(t=>fs(t.mod)):!0}const rle=/(?:.*\/){3}([^/]+$)/;function ET(){hs.clear(),cs.clear(),sle();const n=[],e=[],t=[],r=gle();(r?r.slice():wT.value.slice()).forEach(({node:s,edges:a,mod:g})=>{fs(g)&&T7(g.id)&&(n.push(s),e.push({id:g.id.match(rle)?.[0]??g.id,fullId:g.id,node:s,edges:a,deps:g.deps}),t.push(...a))});const o=yT.value;if(o.trim().length){const s=e.filter(({id:a})=>a.includes(o));if(t.length=0,n.length=0,s.length){const{node:a,edges:g}=ile(s);n.push(...a),t.push(...g)}}hs.add(ele(n)),cs.add(O7(t))}function ile(n){const e=new Map,t=new Map;return n.forEach(r=>{r=$te(r),r.node.font||(r.node.font={color:"#F19B4A"}),r.node.label=`<b>${r.node.label}</b>`,e.set(r.fullId,r.node),r.deps.forEach(i=>{const o=ni.get(i);o&&fs(o.mod)&&(e.set(o.mod.id,o.node),t.set(`${r.fullId}-${o.mod.id}`,vO(o.mod.id,r.fullId)),o.edges.forEach(s=>t.set(`${s.from}-${s.to}`,s)))})}),{node:Array.from(e.values()),edges:Array.from(t.values())}}function vO(n,e){return{from:n,to:e,arrows:{to:{enabled:!0,scaleFactor:.8}}}}function ST(n){return n.replace(/\?.*$/,"").replace(/#.*$/,"").replace(/\/{2,}/g,"/")}function R7(n){return n.includes("vue&type=style")}function mO(n){return n.replace(bT.value,"")}function oB(n){return 15+Math.min(n/2,8)}function sB(n,e){const t=[];return n.forEach(r=>{R7(r)||(r=ST(r),!t.includes(r)&&(t.push(r),e?.(r)))}),t}function nle(n,e){if(!n)return;bT.value=e,hs.clear(),cs.clear();const t=[],r=[];n.forEach(i=>{if(R7(i.id))return;if(i.id=ST(i.id),r.some(C=>C.id===i.id)){const C=ni.get(i.id);C.node.size=oB(C.edges.length+i.deps.length);const l=[],u=sB(i.deps,h=>{l.push(vO(i.id,h))}).filter(h=>!C.mod.deps.includes(h));if(!u.length)return;C.mod.deps.push(...u),t.push(...l);return}const o=i.id,a=o.split("/").at(-1)??"",g=mO(o),A={mod:i,info:{displayName:a,displayPath:g},node:{id:i.id,label:a,group:o.match(/\.(\w+)$/)?.[1]||"unknown",size:oB(i.deps.length),shape:i.id.includes("/node_modules/")?"hexagon":i.virtual?"diamond":"dot"},edges:[]},I=sB(i.deps,C=>{A.edges.push(vO(i.id,C)),os.has(C)||os.set(C,[]);const l=os.get(C),d=mO(o);l.find(h=>h.path===o&&h.displayPath===d&&h.mod.id===i.id)||l.push({path:o,displayPath:d,mod:i})});i.deps=I,wT.value.push(A),_7.set(i.id,A),ni.set(i.id,A),fs(i)&&T7(i.id)&&(r.push(A.node),t.push(...A.edges))}),hs.add(r.slice()),cs.add(O7(t))}const P7=Bn(),[ole,yO]=RX(!1);function sle(){yO(!1)}function ale(n){const e=ni.get(n);if(!e)return;const t=e.mod.deps.reduce((o,s)=>{const a=ni.get(s);return a&&fs(a.mod)&&o.push({path:s,displayPath:mO(ST(s))}),o},[]),i=(os.get(e.mod.id)||[]).reduce((o,s)=>{const a=ni.get(s.path);return a&&fs(a.mod)&&o.push({path:s.path,displayPath:s.displayPath}),o},[]);P7.value={name:e.info.displayName,displayPath:e.info.displayPath,path:e.mod.id,deps:t,refs:i}}const ps=Bn("");$A(ps,()=>{ET()});function gle(){const n=ps.value;return ps.value=n,!n||!ni.get(n)?null:x7(n)}function x7(n,e=0){const t=ni.get(n);if(e+=1,!t||e>20)return[];const r=[t];return t.mod.deps.forEach(i=>{const o=ni.get(i);o&&r.push(...x7(o.mod.id,e))}),r.reduce((i,o)=>(i.some(s=>s.mod.id===o.mod.id)||i.push(o),i),[])}const Ale={class:"w-300px","h-full":"","of-auto":""},Ile={"text-md":"","h-80px":"","border-b":"","border-base":"",p3:"",flex:"~ col gap1"},Cle={"text-lg":"",flex:"~ gap2 items-center"},lle={key:0,"i-material-symbols-check-small":"","text-primary-500":""},dle=["title"],ule={pb2:"","text-gray-500":""},hle={"text-primary-500":""},cle={flex:"~ col gap2 items-start"},fle=["onClick"],ple={p3:""},aB=1500,vle=oI({__name:"GraphDrawer",props:{top:{}},setup(n){const e=P7,t=ole,r=ps,i=Fte(),o=C=>{if(i.vitePluginDetected.value&&kte.value){Bte(C);return}A(C)},{copy:s,isSupported:a,copied:g}=Dte({copiedDuring:aB});function A(C){s(C),zte({message:"Copied to clipboard",type:"success",duration:aB})}const I=[["refs","references"],["deps","dependencies"]];return(C,l)=>(Xt(),Nte(Pe(qte),{modelValue:Pe(t),"onUpdate:modelValue":l[3]||(l[3]=d=>$X(t)?t.value=d:null),top:n.top,"close-outside":!1,permanent:!0,"content-blur":!0,position:"absolute","mount-to":".graph-body"},{default:$R(()=>[et("div",Ale,[et("div",Ile,[et("span",Cle,[wA($n(Pe(e)?.name)+" ",1),Pe(g)?(Xt(),ar("span",lle)):Pe(e)?(Xt(),ar("span",{key:1,hover:"op-100","i-carbon-copy":"","cursor-pointer":"","text-sm":"","op-50":"",class:Wo({"text-gray-200":!Pe(a)}),onClick:l[0]||(l[0]=d=>A(Pe(e).name))},null,2)):BO("",!0)]),et("button",{hover:"underline",truncate:"","text-left":"","text-gray-500":"",title:Pe(e)?.displayPath,onClick:l[1]||(l[1]=d=>o(Pe(e).path))},$n(Pe(e)?.displayPath),9,dle)]),(Xt(),ar(DA,null,NA(I,([d,u])=>et("div",{key:d,"max-h-60":"","of-auto":"","border-b":"","border-base":"",p3:"","text-sm":""},[et("div",ule,[et("span",hle,$n(Pe(e)?.[d].length),1),wA(" "+$n(u),1)]),et("div",cle,[(Xt(!0),ar(DA,null,NA(Pe(e)?.[d],h=>(Xt(),ar("button",{key:h.path,dark:"text-gray-200","of-hidden":"",truncate:"","ws-nowrap":"","pr-3":"","text-gray-800":"",hover:"underline",onClick:v=>o(h.path)},$n(h.displayPath),9,fle))),128))])])),64)),et("div",ple,[es(Pe(Mte),{type:"primary",onClick:l[2]||(l[2]=d=>r.value=Pe(e).path)},{default:$R(()=>[...l[4]||(l[4]=[wA(" Filter to this module ",-1)])]),_:1})])])]),_:1},8,["modelValue","top"]))}}),mle=oI({__name:"GraphFileType",setup(n){const{fileTypeData:e,fileTypeShow:t,toggleFileType:r}=QCe();return(i,o)=>(Xt(),ar("div",{absolute:"","bottom-0":"",grid:"","grid-cols-3":"","w-260px":"","gap-2":"","b-1":"","b-l-0":"","border-base":"","rounded-tr-lg":"","glass-effect":"",px4:"",py2:"","text-sm":"","transition-transform":"","duration-300":"",class:Wo(["group",{"translate-x-[calc(-100%+30px)] translate-y-[calc(100%-30px)]":!Pe(t)}])},[et("div",{class:Wo(["group",{"rounded-bl-lg opacity-0 group-hover:opacity-100":Pe(t)}]),absolute:"","right-0":"",h30px:"",w30px:"","cursor-pointer":"","rounded-tr-lg":"","bg-primary-500":"","text-white":"","transition-opacity":"",flex:"~ justify-center items-center",onClick:o[0]||(o[0]=()=>Pe(r)())},[et("div",{"transition-transform":"",class:Wo([Pe(t)?"i-material-symbols-arrow-downward-alt rotate-45 hover:translate-x--10% hover:translate-y-10%":"i-mdi-file-outline"])},null,2)],2),(Xt(!0),ar(DA,null,NA(Pe(e),s=>(Xt(),ar("div",{key:s.key,flex:"","items-center":"","gap-2":""},[et("div",{h12px:"",w12px:"","rounded-full":"",style:jte({backgroundColor:s.color})},null,4),et("span",{class:Wo([s.capitalize?"capitalize":"uppercase"])},$n(s.key),3)]))),128))],2))}}),yle={flex:"~ items-center gap-4 nowrap",class:"[&_>*]:flex-[0_0_auto]",absolute:"","left-0":"","top-0":"","z-10":"","navbar-base":"","w-full":"","overflow-x-auto":"","glass-effect":"",px4:"","text-sm":""},ble=oI({__name:"GraphNavbar",setup(n){const e=yT,t=Ma,r=[["node_modules"],["virtual","virtual module"],["lib","library module"]],i=ps;return(o,s)=>(Xt(),ar("div",yle,[es(Pe(Lte),{modelValue:Pe(e),"onUpdate:modelValue":s[0]||(s[0]=a=>$X(e)?e.value=a:null),placeholder:"Search modules..."},null,8,["modelValue"]),(Xt(),ar(DA,null,NA(r,a=>et("div",{key:a[0],flex:"~ gap-2 items-center"},[es(Pe(Gte),{modelValue:Pe(t)[a[0]],"onUpdate:modelValue":g=>Pe(t)[a[0]]=g},null,8,["modelValue","onUpdate:modelValue"]),et("span",{class:Wo({"text-gray-400 dark:text-gray-600":!Pe(t)[a[0]]})},"Show "+$n(a[1]??a[0]),3)])),64)),s[3]||(s[3]=et("div",{"flex-auto":""},null,-1)),Pe(i)?(Xt(),ar("button",{key:0,"rounded-full":"","bg-gray:20":"",py1:"",pl3:"",pr2:"","text-xs":"",op50:"","hover:op100":"",onClick:s[1]||(s[1]=a=>i.value="")},[...s[2]||(s[2]=[wA(" Clear filter ",-1),et("div",{"i-carbon-close":"",mb2px:""},null,-1)])])):BO("",!0)]))}});/**
937
+ `),i=r.length;if(t.multi)for(let o=0;o<i;o++){const s=this.splitBlocks(r[o],t.multi);if(s!==void 0){if(s.length===0){this.lines.newLine("");continue}if(t.maxWdt>0)for(let a=0;a<s.length;a++){const g=s[a].mod,A=s[a].text;this.splitStringIntoLines(A,g,!0)}else for(let a=0;a<s.length;a++){const g=s[a].mod,A=s[a].text;this.lines.append(A,g)}this.lines.newLine()}}else if(t.maxWdt>0)for(let o=0;o<i;o++)this.splitStringIntoLines(r[o]);else for(let o=0;o<i;o++)this.lines.newLine(r[o]);return this.lines.finalize()}decodeMarkupSystem(e){let t="none";return e==="markdown"||e==="md"?t="markdown":(e===!0||e==="html")&&(t="html"),t}splitHtmlBlocks(e){const t=new yk(e),r=i=>/&/.test(i)?(t.replace(t.text,"&lt;","<")||t.replace(t.text,"&amp;","&")||t.add("&"),!0):!1;for(;t.position<t.text.length;){const i=t.text.charAt(t.position);t.parseWS(i)||/</.test(i)&&(t.parseStartTag("bold","<b>")||t.parseStartTag("ital","<i>")||t.parseStartTag("mono","<code>")||t.parseEndTag("bold","</b>")||t.parseEndTag("ital","</i>")||t.parseEndTag("mono","</code>"))||r(i)||t.add(i),t.position++}return t.emitBlock(),t.blocks}splitMarkdownBlocks(e){const t=new yk(e);let r=!0;const i=o=>/\\/.test(o)?(t.position<this.text.length+1&&(t.position++,o=this.text.charAt(t.position),/ \t/.test(o)?t.spacing=!0:(t.add(o),r=!1)),!0):!1;for(;t.position<t.text.length;){const o=t.text.charAt(t.position);t.parseWS(o)||i(o)||(r||t.spacing)&&(t.parseStartTag("bold","*")||t.parseStartTag("ital","_")||t.parseStartTag("mono","`"))||t.parseEndTag("bold","*","afterBold")||t.parseEndTag("ital","_","afterItal")||t.parseEndTag("mono","`","afterMono")||(t.add(o),r=!1),t.position++}return t.emitBlock(),t.blocks}splitBlocks(e,t){const r=this.decodeMarkupSystem(t);if(r==="none")return[{text:e,mod:"normal"}];if(r==="markdown")return this.splitMarkdownBlocks(e);if(r==="html")return this.splitHtmlBlocks(e)}overMaxWidth(e){const t=this.ctx.measureText(e).width;return this.lines.curWidth()+t>this.parent.fontOptions.maxWdt}getLongestFit(e){let t="",r=0;for(;r<e.length;){const o=t+(t===""?"":" ")+e[r];if(this.overMaxWidth(o))break;t=o,r++}return r}getLongestFitWord(e){let t=0;for(;t<e.length&&!this.overMaxWidth(zr(e).call(e,0,t));)t++;return t}splitStringIntoLines(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"normal",r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;this.parent.getFormattingValues(this.ctx,this.selected,this.hover,t),e=e.replace(/^( +)/g,"$1\r"),e=e.replace(/([^\r][^ ]*)( +)/g,"$1\r$2\r");let i=e.split("\r");for(;i.length>0;){let o=this.getLongestFit(i);if(o===0){const s=i[0],a=this.getLongestFitWord(s);this.lines.newLine(zr(s).call(s,0,a),t),i[0]=zr(s).call(s,a)}else{let s=o;i[o-1]===" "?o--:i[s]===" "&&s++;const a=zr(i).call(i,0,o).join("");o==i.length&&r?this.lines.append(a,t):this.lines.newLine(a,t),i=zr(i).call(i,s)}}}};const ya=["bold","ital","boldital","mono"];let d7=class _A{constructor(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;this.body=e,this.pointToSelf=!1,this.baseSize=void 0,this.fontOptions={},this.setOptions(t),this.size={top:0,left:0,width:0,height:0,yLine:0},this.isEdgeLabel=r}setOptions(e){if(this.elementOptions=e,this.initFontOptions(e.font),GA(e.label)?this.labelDirty=!0:e.label=void 0,e.font!==void 0&&e.font!==null){if(typeof e.font=="string")this.baseSize=this.fontOptions.size;else if(typeof e.font=="object"){const t=e.font.size;t!==void 0&&(this.baseSize=t)}}}initFontOptions(e){if(de(ya,t=>{this.fontOptions[t]={}}),_A.parseFontString(this.fontOptions,e)){this.fontOptions.vadjust=0;return}de(e,(t,r)=>{t!=null&&typeof t!="object"&&(this.fontOptions[r]=t)})}static parseFontString(e,t){if(!t||typeof t!="string")return!1;const r=t.split(" ");return e.size=+r[0].replace("px",""),e.face=r[1],e.color=r[2],!0}constrain(e){const t={constrainWidth:!1,maxWdt:-1,minWdt:-1,constrainHeight:!1,minHgt:-1,valign:"middle"},r=Yi(e,"widthConstraint");if(typeof r=="number")t.maxWdt=Number(r),t.minWdt=Number(r);else if(typeof r=="object"){const o=Yi(e,["widthConstraint","maximum"]);typeof o=="number"&&(t.maxWdt=Number(o));const s=Yi(e,["widthConstraint","minimum"]);typeof s=="number"&&(t.minWdt=Number(s))}const i=Yi(e,"heightConstraint");if(typeof i=="number")t.minHgt=Number(i);else if(typeof i=="object"){const o=Yi(e,["heightConstraint","minimum"]);typeof o=="number"&&(t.minHgt=Number(o));const s=Yi(e,["heightConstraint","valign"]);typeof s=="string"&&(s==="top"||s==="bottom")&&(t.valign=s)}return t}update(e,t){this.setOptions(e,!0),this.propagateFonts(t),Me(this.fontOptions,this.constrain(t)),this.fontOptions.chooser=pT("label",t)}adjustSizes(e){const t=e?e.right+e.left:0;this.fontOptions.constrainWidth&&(this.fontOptions.maxWdt-=t,this.fontOptions.minWdt-=t);const r=e?e.top+e.bottom:0;this.fontOptions.constrainHeight&&(this.fontOptions.minHgt-=r)}addFontOptionsToPile(e,t){for(let r=0;r<t.length;++r)this.addFontToPile(e,t[r])}addFontToPile(e,t){if(t===void 0||t.font===void 0||t.font===null)return;const r=t.font;e.push(r)}getBasicOptions(e){const t={};for(let r=0;r<e.length;++r){let i=e[r];const o={};_A.parseFontString(o,i)&&(i=o),de(i,(s,a)=>{s!==void 0&&(Object.prototype.hasOwnProperty.call(t,a)||(_e(ya).call(ya,a)!==-1?t[a]={}:t[a]=s))})}return t}getFontOption(e,t,r){let i;for(let o=0;o<e.length;++o){const s=e[o];if(Object.prototype.hasOwnProperty.call(s,t)){if(i=s[t],i==null)continue;const a={};if(_A.parseFontString(a,i)&&(i=a),Object.prototype.hasOwnProperty.call(i,r))return i[r]}}if(Object.prototype.hasOwnProperty.call(this.fontOptions,r))return this.fontOptions[r];throw new Error("Did not find value for multi-font for property: '"+r+"'")}getFontOptions(e,t){const r={},i=["color","size","face","mod","vadjust"];for(let o=0;o<i.length;++o){const s=i[o];r[s]=this.getFontOption(e,t,s)}return r}propagateFonts(e){const t=[];this.addFontOptionsToPile(t,e),this.fontOptions=this.getBasicOptions(t);for(let r=0;r<ya.length;++r){const i=ya[r],o=this.fontOptions[i],s=this.getFontOptions(t,i);de(s,(a,g)=>{o[g]=a}),o.size=Number(o.size),o.vadjust=Number(o.vadjust)}}draw(e,t,r,i,o){let s=arguments.length>5&&arguments[5]!==void 0?arguments[5]:"middle";if(this.elementOptions.label===void 0)return;let a=this.fontOptions.size*this.body.view.scale;this.elementOptions.label&&a<this.elementOptions.scaling.label.drawThreshold-1||(a>=this.elementOptions.scaling.label.maxVisible&&(a=Number(this.elementOptions.scaling.label.maxVisible)/this.body.view.scale),this.calculateLabelSize(e,i,o,t,r,s),this._drawBackground(e),this._drawText(e,t,this.size.yLine,s,a))}_drawBackground(e){if(this.fontOptions.background!==void 0&&this.fontOptions.background!=="none"){e.fillStyle=this.fontOptions.background;const t=this.getSize();e.fillRect(t.left,t.top,t.width,t.height)}}_drawText(e,t,r){let i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:"middle",o=arguments.length>4?arguments[4]:void 0;[t,r]=this._setAlignment(e,t,r,i),e.textAlign="left",t=t-this.size.width/2,this.fontOptions.valign&&this.size.height>this.size.labelHeight&&(this.fontOptions.valign==="top"&&(r-=(this.size.height-this.size.labelHeight)/2),this.fontOptions.valign==="bottom"&&(r+=(this.size.height-this.size.labelHeight)/2));for(let s=0;s<this.lineCount;s++){const a=this.lines[s];if(a&&a.blocks){let g=0;this.isEdgeLabel||this.fontOptions.align==="center"?g+=(this.size.width-a.width)/2:this.fontOptions.align==="right"&&(g+=this.size.width-a.width);for(let A=0;A<a.blocks.length;A++){const I=a.blocks[A];e.font=I.font;const[C,l]=this._getColor(I.color,o,I.strokeColor);I.strokeWidth>0&&(e.lineWidth=I.strokeWidth,e.strokeStyle=l,e.lineJoin="round"),e.fillStyle=C,I.strokeWidth>0&&e.strokeText(I.text,t+g,r+I.vadjust),e.fillText(I.text,t+g,r+I.vadjust),g+=I.width}r+=a.height}}}_setAlignment(e,t,r,i){if(this.isEdgeLabel&&this.fontOptions.align!=="horizontal"&&this.pointToSelf===!1){t=0,r=0;const o=2;this.fontOptions.align==="top"?(e.textBaseline="alphabetic",r-=2*o):this.fontOptions.align==="bottom"?(e.textBaseline="hanging",r+=2*o):e.textBaseline="middle"}else e.textBaseline=i;return[t,r]}_getColor(e,t,r){let i=e||"#000000",o=r||"#ffffff";if(t<=this.elementOptions.scaling.label.drawThreshold){const s=Math.max(0,Math.min(1,1-(this.elementOptions.scaling.label.drawThreshold-t)));i=hr(i,s),o=hr(o,s)}return[i,o]}getTextSize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;return this._processLabel(e,t,r),{width:this.size.width,height:this.size.height,lineCount:this.lineCount}}getSize(){let t=this.size.left,r=this.size.top-.5*2;if(this.isEdgeLabel){const o=-this.size.width*.5;switch(this.fontOptions.align){case"middle":t=o,r=-this.size.height*.5;break;case"top":t=o,r=-(this.size.height+2);break;case"bottom":t=o,r=2;break}}return{left:t,top:r,width:this.size.width,height:this.size.height}}calculateLabelSize(e,t,r){let i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0,o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:0,s=arguments.length>5&&arguments[5]!==void 0?arguments[5]:"middle";this._processLabel(e,t,r),this.size.left=i-this.size.width*.5,this.size.top=o-this.size.height*.5,this.size.yLine=o+(1-this.lineCount)*.5*this.fontOptions.size,s==="hanging"&&(this.size.top+=.5*this.fontOptions.size,this.size.top+=4,this.size.yLine+=4)}getFormattingValues(e,t,r,i){const o=function(g,A,I){return A==="normal"?I==="mod"?"":g[I]:g[A][I]!==void 0?g[A][I]:g[I]},s={color:o(this.fontOptions,i,"color"),size:o(this.fontOptions,i,"size"),face:o(this.fontOptions,i,"face"),mod:o(this.fontOptions,i,"mod"),vadjust:o(this.fontOptions,i,"vadjust"),strokeWidth:this.fontOptions.strokeWidth,strokeColor:this.fontOptions.strokeColor};(t||r)&&(i==="normal"&&this.fontOptions.chooser===!0&&this.elementOptions.labelHighlightBold?s.mod="bold":typeof this.fontOptions.chooser=="function"&&this.fontOptions.chooser(s,this.elementOptions.id,t,r));let a="";return s.mod!==void 0&&s.mod!==""&&(a+=s.mod+" "),a+=s.size+"px "+s.face,e.font=a.replace(/"/g,""),s.font=e.font,s.height=s.size,s}differentState(e,t){return e!==this.selectedState||t!==this.hoverState}_processLabelText(e,t,r,i){return new mIe(e,this,t,r).process(i)}_processLabel(e,t,r){if(this.labelDirty===!1&&!this.differentState(t,r))return;const i=this._processLabelText(e,t,r,this.elementOptions.label);this.fontOptions.minWdt>0&&i.width<this.fontOptions.minWdt&&(i.width=this.fontOptions.minWdt),this.size.labelHeight=i.height,this.fontOptions.minHgt>0&&i.height<this.fontOptions.minHgt&&(i.height=this.fontOptions.minHgt),this.lines=i.lines,this.lineCount=i.lines.length,this.size.width=i.width,this.size.height=i.height,this.selectedState=t,this.hoverState=r,this.labelDirty=!1}visible(){return!(this.size.width===0||this.size.height===0||this.elementOptions.label===void 0||this.fontOptions.size*this.body.view.scale<this.elementOptions.scaling.label.drawThreshold-1)}},po=class{constructor(e,t,r){this.body=t,this.labelModule=r,this.setOptions(e),this.top=void 0,this.left=void 0,this.height=void 0,this.width=void 0,this.radius=void 0,this.margin=void 0,this.refreshNeeded=!0,this.boundingBox={top:0,left:0,right:0,bottom:0}}setOptions(e){this.options=e}_setMargins(e){this.margin={},this.options.margin&&(typeof this.options.margin=="object"?(this.margin.top=this.options.margin.top,this.margin.right=this.options.margin.right,this.margin.bottom=this.options.margin.bottom,this.margin.left=this.options.margin.left):(this.margin.top=this.options.margin,this.margin.right=this.options.margin,this.margin.bottom=this.options.margin,this.margin.left=this.options.margin)),e.adjustSizes(this.margin)}_distanceToBorder(e,t){const r=this.options.borderWidth;return e&&this.resize(e),Math.min(Math.abs(this.width/2/Math.cos(t)),Math.abs(this.height/2/Math.sin(t)))+r}enableShadow(e,t){t.shadow&&(e.shadowColor=t.shadowColor,e.shadowBlur=t.shadowSize,e.shadowOffsetX=t.shadowX,e.shadowOffsetY=t.shadowY)}disableShadow(e,t){t.shadow&&(e.shadowColor="rgba(0,0,0,0)",e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0)}enableBorderDashes(e,t){if(t.borderDashes!==!1)if(e.setLineDash!==void 0){let r=t.borderDashes;r===!0&&(r=[5,15]),e.setLineDash(r)}else console.warn("setLineDash is not supported in this browser. The dashed borders cannot be used."),this.options.shapeProperties.borderDashes=!1,t.borderDashes=!1}disableBorderDashes(e,t){t.borderDashes!==!1&&(e.setLineDash!==void 0?e.setLineDash([0]):(console.warn("setLineDash is not supported in this browser. The dashed borders cannot be used."),this.options.shapeProperties.borderDashes=!1,t.borderDashes=!1))}needsRefresh(e,t){return this.refreshNeeded===!0?(this.refreshNeeded=!1,!0):this.width===void 0||this.labelModule.differentState(e,t)}initContextForDraw(e,t){const r=t.borderWidth/this.body.view.scale;e.lineWidth=Math.min(this.width,r),e.strokeStyle=t.borderColor,e.fillStyle=t.color}performStroke(e,t){const r=t.borderWidth/this.body.view.scale;e.save(),r>0&&(this.enableBorderDashes(e,t),e.stroke(),this.disableBorderDashes(e,t)),e.restore()}performFill(e,t){e.save(),e.fillStyle=t.color,this.enableShadow(e,t),cg(e).call(e),this.disableShadow(e,t),e.restore(),this.performStroke(e,t)}_addBoundingBoxMargin(e){this.boundingBox.left-=e,this.boundingBox.top-=e,this.boundingBox.bottom+=e,this.boundingBox.right+=e}_updateBoundingBox(e,t,r,i,o){r!==void 0&&this.resize(r,i,o),this.left=e-this.width/2,this.top=t-this.height/2,this.boundingBox.left=this.left,this.boundingBox.top=this.top,this.boundingBox.bottom=this.top+this.height,this.boundingBox.right=this.left+this.width}updateBoundingBox(e,t,r,i,o){this._updateBoundingBox(e,t,r,i,o)}getDimensionsFromLabel(e,t,r){this.textSize=this.labelModule.getTextSize(e,t,r);let i=this.textSize.width,o=this.textSize.height;const s=14;return i===0&&(i=s,o=s),{width:i,height:o}}},yIe=class extends po{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.needsRefresh(t,r)){const i=this.getDimensionsFromLabel(e,t,r);this.width=i.width+this.margin.right+this.margin.left,this.height=i.height+this.margin.top+this.margin.bottom,this.radius=this.width/2}}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width/2,this.top=r-this.height/2,this.initContextForDraw(e,s),zX(e,this.left,this.top,this.width,this.height,s.borderRadius),this.performFill(e,s),this.updateBoundingBox(t,r,e,i,o),this.labelModule.draw(e,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,i,o)}updateBoundingBox(e,t,r,i,o){this._updateBoundingBox(e,t,r,i,o);const s=this.options.shapeProperties.borderRadius;this._addBoundingBoxMargin(s)}distanceToBorder(e,t){e&&this.resize(e);const r=this.options.borderWidth;return Math.min(Math.abs(this.width/2/Math.cos(t)),Math.abs(this.height/2/Math.sin(t)))+r}},vT=class extends po{constructor(e,t,r){super(e,t,r),this.labelOffset=0,this.selected=!1}setOptions(e,t,r){this.options=e,t===void 0&&r===void 0||this.setImages(t,r)}setImages(e,t){t&&this.selected?(this.imageObj=t,this.imageObjAlt=e):(this.imageObj=e,this.imageObjAlt=t)}switchImages(e){const t=e&&!this.selected||!e&&this.selected;if(this.selected=e,this.imageObjAlt!==void 0&&t){const r=this.imageObj;this.imageObj=this.imageObjAlt,this.imageObjAlt=r}}_getImagePadding(){const e={top:0,right:0,bottom:0,left:0};if(this.options.imagePadding){const t=this.options.imagePadding;typeof t=="object"?(e.top=t.top,e.right=t.right,e.bottom=t.bottom,e.left=t.left):(e.top=t,e.right=t,e.bottom=t,e.left=t)}return e}_resizeImage(){let e,t;if(this.options.shapeProperties.useImageSize===!1){let r=1,i=1;this.imageObj.width&&this.imageObj.height&&(this.imageObj.width>this.imageObj.height?r=this.imageObj.width/this.imageObj.height:i=this.imageObj.height/this.imageObj.width),e=this.options.size*2*r,t=this.options.size*2*i}else{const r=this._getImagePadding();e=this.imageObj.width+r.left+r.right,t=this.imageObj.height+r.top+r.bottom}this.width=e,this.height=t,this.radius=.5*this.width}_drawRawCircle(e,t,r,i){this.initContextForDraw(e,i),ZO(e,t,r,i.size),this.performFill(e,i)}_drawImageAtPosition(e,t){if(this.imageObj.width!=0){e.globalAlpha=t.opacity!==void 0?t.opacity:1,this.enableShadow(e,t);let r=1;this.options.shapeProperties.interpolation===!0&&(r=this.imageObj.width/this.width/this.body.view.scale);const i=this._getImagePadding(),o=this.left+i.left,s=this.top+i.top,a=this.width-i.left-i.right,g=this.height-i.top-i.bottom;this.imageObj.drawImageAtPosition(e,r,o,s,a,g),this.disableShadow(e,t)}}_drawImageLabel(e,t,r,i,o){let s=0;if(this.height!==void 0){s=this.height*.5;const g=this.labelModule.getTextSize(e,i,o);g.lineCount>=1&&(s+=g.height/2)}const a=r+s;this.options.label&&(this.labelOffset=s),this.labelModule.draw(e,t,a,i,o,"hanging")}},bIe=class extends vT{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.needsRefresh(t,r)){const i=this.getDimensionsFromLabel(e,t,r),o=Math.max(i.width+this.margin.right+this.margin.left,i.height+this.margin.top+this.margin.bottom);this.options.size=o/2,this.width=o,this.height=o,this.radius=this.width/2}}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width/2,this.top=r-this.height/2,this._drawRawCircle(e,t,r,s),this.updateBoundingBox(t,r),this.labelModule.draw(e,this.left+this.textSize.width/2+this.margin.left,r,i,o)}updateBoundingBox(e,t){this.boundingBox.top=t-this.options.size,this.boundingBox.left=e-this.options.size,this.boundingBox.right=e+this.options.size,this.boundingBox.bottom=t+this.options.size}distanceToBorder(e){return e&&this.resize(e),this.width*.5}},wIe=class extends vT{constructor(e,t,r,i,o){super(e,t,r),this.setImages(i,o)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.imageObj.src===void 0||this.imageObj.width===void 0||this.imageObj.height===void 0){const o=this.options.size*2;this.width=o,this.height=o,this.radius=.5*this.width;return}this.needsRefresh(t,r)&&this._resizeImage()}draw(e,t,r,i,o,s){this.switchImages(i),this.resize();let a=t,g=r;this.options.shapeProperties.coordinateOrigin==="top-left"?(this.left=t,this.top=r,a+=this.width/2,g+=this.height/2):(this.left=t-this.width/2,this.top=r-this.height/2),this._drawRawCircle(e,a,g,s),e.save(),e.clip(),this._drawImageAtPosition(e,s),e.restore(),this._drawImageLabel(e,a,g,i,o),this.updateBoundingBox(t,r)}updateBoundingBox(e,t){this.options.shapeProperties.coordinateOrigin==="top-left"?(this.boundingBox.top=t,this.boundingBox.left=e,this.boundingBox.right=e+this.options.size*2,this.boundingBox.bottom=t+this.options.size*2):(this.boundingBox.top=t-this.options.size,this.boundingBox.left=e-this.options.size,this.boundingBox.right=e+this.options.size,this.boundingBox.bottom=t+this.options.size),this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left),this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width),this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelOffset)}distanceToBorder(e){return e&&this.resize(e),this.width*.5}},vn=class extends po{constructor(e,t,r){super(e,t,r)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover,i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:{size:this.options.size};if(this.needsRefresh(t,r)){var o,s;this.labelModule.getTextSize(e,t,r);const a=2*i.size;this.width=(o=this.customSizeWidth)!==null&&o!==void 0?o:a,this.height=(s=this.customSizeHeight)!==null&&s!==void 0?s:a,this.radius=.5*this.width}}_drawShape(e,t,r,i,o,s,a,g){return this.resize(e,s,a,g),this.left=i-this.width/2,this.top=o-this.height/2,this.initContextForDraw(e,g),wre(t)(e,i,o,g.size),this.performFill(e,g),this.options.icon!==void 0&&this.options.icon.code!==void 0&&(e.font=(s?"bold ":"")+this.height/2+"px "+(this.options.icon.face||"FontAwesome"),e.fillStyle=this.options.icon.color||"black",e.textAlign="center",e.textBaseline="middle",e.fillText(this.options.icon.code,i,o)),{drawExternalLabel:()=>{if(this.options.label!==void 0){this.labelModule.calculateLabelSize(e,s,a,i,o,"hanging");const A=o+.5*this.height+.5*this.labelModule.size.height;this.labelModule.draw(e,i,A,s,a,"hanging")}this.updateBoundingBox(i,o)}}}updateBoundingBox(e,t){this.boundingBox.top=t-this.options.size,this.boundingBox.left=e-this.options.size,this.boundingBox.right=e+this.options.size,this.boundingBox.bottom=t+this.options.size,this.options.label!==void 0&&this.labelModule.size.width>0&&(this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left),this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width),this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelModule.size.height))}};function bk(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function EIe(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=bk(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=bk(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}let SIe=class extends vn{constructor(e,t,r,i){super(e,t,r,i),this.ctxRenderer=i}draw(e,t,r,i,o,s){this.resize(e,i,o,s),this.left=t-this.width/2,this.top=r-this.height/2,e.save();const a=this.ctxRenderer({ctx:e,id:this.options.id,x:t,y:r,state:{selected:i,hover:o},style:EIe({},s),label:this.options.label});if(a.drawNode!=null&&a.drawNode(),e.restore(),a.drawExternalLabel){const g=a.drawExternalLabel;a.drawExternalLabel=()=>{e.save(),g(),e.restore()}}return a.nodeDimensions&&(this.customSizeWidth=a.nodeDimensions.width,this.customSizeHeight=a.nodeDimensions.height),a}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},_Ie=class extends po{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e,t,r){if(this.needsRefresh(t,r)){const o=this.getDimensionsFromLabel(e,t,r).width+this.margin.right+this.margin.left;this.width=o,this.height=o,this.radius=this.width/2}}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width/2,this.top=r-this.height/2,this.initContextForDraw(e,s),jX(e,t-this.width/2,r-this.height/2,this.width,this.height),this.performFill(e,s),this.updateBoundingBox(t,r,e,i,o),this.labelModule.draw(e,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,i,o)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},OIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"diamond",4,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},TIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"circle",2,t,r,i,o,s)}distanceToBorder(e){return e&&this.resize(e),this.options.size}},wk=class extends po{constructor(e,t,r){super(e,t,r)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.needsRefresh(t,r)){const i=this.getDimensionsFromLabel(e,t,r);this.height=i.height*2,this.width=i.width+i.height,this.radius=.5*this.width}}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width*.5,this.top=r-this.height*.5,this.initContextForDraw(e,s),sO(e,this.left,this.top,this.width,this.height),this.performFill(e,s),this.updateBoundingBox(t,r,e,i,o),this.labelModule.draw(e,t,r,i,o)}distanceToBorder(e,t){e&&this.resize(e);const r=this.width*.5,i=this.height*.5,o=Math.sin(t)*r,s=Math.cos(t)*i;return r*i/Math.sqrt(o*o+s*s)}},RIe=class extends po{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e,t,r){this.needsRefresh(t,r)&&(this.iconSize={width:Number(this.options.icon.size),height:Number(this.options.icon.size)},this.width=this.iconSize.width+this.margin.right+this.margin.left,this.height=this.iconSize.height+this.margin.top+this.margin.bottom,this.radius=.5*this.width)}draw(e,t,r,i,o,s){return this.resize(e,i,o),this.options.icon.size=this.options.icon.size||50,this.left=t-this.width/2,this.top=r-this.height/2,this._icon(e,t,r,i,o,s),{drawExternalLabel:()=>{this.options.label!==void 0&&this.labelModule.draw(e,this.left+this.iconSize.width/2+this.margin.left,r+this.height/2+5,i),this.updateBoundingBox(t,r)}}}updateBoundingBox(e,t){this.boundingBox.top=t-this.options.icon.size*.5,this.boundingBox.left=e-this.options.icon.size*.5,this.boundingBox.right=e+this.options.icon.size*.5,this.boundingBox.bottom=t+this.options.icon.size*.5,this.options.label!==void 0&&this.labelModule.size.width>0&&(this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left),this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width),this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelModule.size.height+5))}_icon(e,t,r,i,o,s){const a=Number(this.options.icon.size);this.options.icon.code!==void 0?(e.font=[this.options.icon.weight!=null?this.options.icon.weight:i?"bold":"",(this.options.icon.weight!=null&&i?5:0)+a+"px",this.options.icon.face].join(" "),e.fillStyle=this.options.icon.color||"black",e.textAlign="center",e.textBaseline="middle",this.enableShadow(e,s),e.fillText(this.options.icon.code,t,r),this.disableShadow(e,s)):console.error("When using the icon shape, you need to define the code in the icon options object. This can be done per node or globally.")}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},PIe=class extends vT{constructor(e,t,r,i,o){super(e,t,r),this.setImages(i,o)}resize(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.selected,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.hover;if(this.imageObj.src===void 0||this.imageObj.width===void 0||this.imageObj.height===void 0){const o=this.options.size*2;this.width=o,this.height=o;return}this.needsRefresh(t,r)&&this._resizeImage()}draw(e,t,r,i,o,s){e.save(),this.switchImages(i),this.resize();let a=t,g=r;if(this.options.shapeProperties.coordinateOrigin==="top-left"?(this.left=t,this.top=r,a+=this.width/2,g+=this.height/2):(this.left=t-this.width/2,this.top=r-this.height/2),this.options.shapeProperties.useBorderWithImage===!0){const A=this.options.borderWidth,I=this.options.borderWidthSelected||2*this.options.borderWidth,C=(i?I:A)/this.body.view.scale;e.lineWidth=Math.min(this.width,C),e.beginPath();let l=i?this.options.color.highlight.border:o?this.options.color.hover.border:this.options.color.border,d=i?this.options.color.highlight.background:o?this.options.color.hover.background:this.options.color.background;s.opacity!==void 0&&(l=hr(l,s.opacity),d=hr(d,s.opacity)),e.strokeStyle=l,e.fillStyle=d,e.rect(this.left-.5*e.lineWidth,this.top-.5*e.lineWidth,this.width+e.lineWidth,this.height+e.lineWidth),cg(e).call(e),this.performStroke(e,s),e.closePath()}this._drawImageAtPosition(e,s),this._drawImageLabel(e,a,g,i,o),this.updateBoundingBox(t,r),e.restore()}updateBoundingBox(e,t){this.resize(),this.options.shapeProperties.coordinateOrigin==="top-left"?(this.left=e,this.top=t):(this.left=e-this.width/2,this.top=t-this.height/2),this.boundingBox.left=this.left,this.boundingBox.top=this.top,this.boundingBox.bottom=this.top+this.height,this.boundingBox.right=this.left+this.width,this.options.label!==void 0&&this.labelModule.size.width>0&&(this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left),this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width),this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelOffset))}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},xIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"square",2,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},$Ie=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"hexagon",4,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},DIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"star",4,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},NIe=class extends po{constructor(e,t,r){super(e,t,r),this._setMargins(r)}resize(e,t,r){this.needsRefresh(t,r)&&(this.textSize=this.labelModule.getTextSize(e,t,r),this.width=this.textSize.width+this.margin.right+this.margin.left,this.height=this.textSize.height+this.margin.top+this.margin.bottom,this.radius=.5*this.width)}draw(e,t,r,i,o,s){this.resize(e,i,o),this.left=t-this.width/2,this.top=r-this.height/2,this.enableShadow(e,s),this.labelModule.draw(e,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,i,o),this.disableShadow(e,s),this.updateBoundingBox(t,r,e,i,o)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},MIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"triangle",3,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}},qIe=class extends vn{constructor(e,t,r){super(e,t,r)}draw(e,t,r,i,o,s){return this._drawShape(e,"triangleDown",3,t,r,i,o,s)}distanceToBorder(e,t){return this._distanceToBorder(e,t)}};function Ek(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function Sk(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=Ek(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=Ek(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}let sr=class qr{constructor(e,t,r,i,o,s){this.options=sn(o),this.globalOptions=o,this.defaultOptions=s,this.body=t,this.edges=[],this.id=void 0,this.imagelist=r,this.grouplist=i,this.x=void 0,this.y=void 0,this.baseSize=this.options.size,this.baseFontSize=this.options.font.size,this.predefinedPosition=!1,this.selected=!1,this.hover=!1,this.labelModule=new d7(this.body,this.options,!1),this.setOptions(e)}attachEdge(e){var t;_e(t=this.edges).call(t,e)===-1&&this.edges.push(e)}detachEdge(e){var t;const r=_e(t=this.edges).call(t,e);if(r!=-1){var i;ti(i=this.edges).call(i,r,1)}}setOptions(e){const t=this.options.shape;if(!e)return;if(typeof e.color<"u"&&(this._localColor=e.color),e.id!==void 0&&(this.id=e.id),this.id===void 0)throw new Error("Node must have an id");qr.checkMass(e,this.id),e.x!==void 0&&(e.x===null?(this.x=void 0,this.predefinedPosition=!1):(this.x=Fr(e.x),this.predefinedPosition=!0)),e.y!==void 0&&(e.y===null?(this.y=void 0,this.predefinedPosition=!1):(this.y=Fr(e.y),this.predefinedPosition=!0)),e.size!==void 0&&(this.baseSize=e.size),e.value!==void 0&&(e.value=C7(e.value)),qr.parseOptions(this.options,e,!0,this.globalOptions,this.grouplist);const r=[e,this.options,this.defaultOptions];return this.chooser=pT("node",r),this._load_images(),this.updateLabelModule(e),e.opacity!==void 0&&qr.checkOpacity(e.opacity)&&(this.options.opacity=e.opacity),this.updateShape(t),e.hidden!==void 0||e.physics!==void 0}_load_images(){if((this.options.shape==="circularImage"||this.options.shape==="image")&&this.options.image===void 0)throw new Error("Option image must be defined for node type '"+this.options.shape+"'");if(this.options.image!==void 0){if(this.imagelist===void 0)throw new Error("Internal Error: No images provided");if(typeof this.options.image=="string")this.imageObj=this.imagelist.load(this.options.image,this.options.brokenImage,this.id);else{if(this.options.image.unselected===void 0)throw new Error("No unselected image provided");this.imageObj=this.imagelist.load(this.options.image.unselected,this.options.brokenImage,this.id),this.options.image.selected!==void 0?this.imageObjAlt=this.imagelist.load(this.options.image.selected,this.options.brokenImage,this.id):this.imageObjAlt=void 0}}}static checkOpacity(e){return 0<=e&&e<=1}static checkCoordinateOrigin(e){return e===void 0||e==="center"||e==="top-left"}static updateGroupOptions(e,t,r){var i;if(r===void 0)return;const o=e.group;if(t!==void 0&&t.group!==void 0&&o!==t.group)throw new Error("updateGroupOptions: group values in options don't match.");if(!(typeof o=="number"||typeof o=="string"&&o!=""))return;const a=r.get(o);a.opacity!==void 0&&t.opacity===void 0&&(qr.checkOpacity(a.opacity)||(console.error("Invalid option for node opacity. Value must be between 0 and 1, found: "+a.opacity),a.opacity=void 0));const g=st(i=fIe(t)).call(i,A=>t[A]!=null);g.push("font"),zA(g,e,a),e.color=CO(e.color)}static parseOptions(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1,i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:{},o=arguments.length>4?arguments[4]:void 0;if(zA(["color","fixed","shadow"],e,t,r),qr.checkMass(t),e.opacity!==void 0&&(qr.checkOpacity(e.opacity)||(console.error("Invalid option for node opacity. Value must be between 0 and 1, found: "+e.opacity),e.opacity=void 0)),t.opacity!==void 0&&(qr.checkOpacity(t.opacity)||(console.error("Invalid option for node opacity. Value must be between 0 and 1, found: "+t.opacity),t.opacity=void 0)),t.shapeProperties&&!qr.checkCoordinateOrigin(t.shapeProperties.coordinateOrigin)&&console.error("Invalid option for node coordinateOrigin, found: "+t.shapeProperties.coordinateOrigin),dr(e,t,"shadow",i),t.color!==void 0&&t.color!==null){const a=CO(t.color);zQ(e.color,a)}else r===!0&&t.color===null&&(e.color=sn(i.color));t.fixed!==void 0&&t.fixed!==null&&(typeof t.fixed=="boolean"?(e.fixed.x=t.fixed,e.fixed.y=t.fixed):(t.fixed.x!==void 0&&typeof t.fixed.x=="boolean"&&(e.fixed.x=t.fixed.x),t.fixed.y!==void 0&&typeof t.fixed.y=="boolean"&&(e.fixed.y=t.fixed.y))),r===!0&&t.font===null&&(e.font=sn(i.font)),qr.updateGroupOptions(e,t,o),t.scaling!==void 0&&dr(e.scaling,t.scaling,"label",i.scaling)}getFormattingValues(){const e={color:this.options.color.background,opacity:this.options.opacity,borderWidth:this.options.borderWidth,borderColor:this.options.color.border,size:this.options.size,borderDashes:this.options.shapeProperties.borderDashes,borderRadius:this.options.shapeProperties.borderRadius,shadow:this.options.shadow.enabled,shadowColor:this.options.shadow.color,shadowSize:this.options.shadow.size,shadowX:this.options.shadow.x,shadowY:this.options.shadow.y};if(this.selected||this.hover?this.chooser===!0?this.selected?(this.options.borderWidthSelected!=null?e.borderWidth=this.options.borderWidthSelected:e.borderWidth*=2,e.color=this.options.color.highlight.background,e.borderColor=this.options.color.highlight.border,e.shadow=this.options.shadow.enabled):this.hover&&(e.color=this.options.color.hover.background,e.borderColor=this.options.color.hover.border,e.shadow=this.options.shadow.enabled):typeof this.chooser=="function"&&(this.chooser(e,this.options.id,this.selected,this.hover),e.shadow===!1&&(e.shadowColor!==this.options.shadow.color||e.shadowSize!==this.options.shadow.size||e.shadowX!==this.options.shadow.x||e.shadowY!==this.options.shadow.y)&&(e.shadow=!0)):e.shadow=this.options.shadow.enabled,this.options.opacity!==void 0){const t=this.options.opacity;e.borderColor=hr(e.borderColor,t),e.color=hr(e.color,t),e.shadowColor=hr(e.shadowColor,t)}return e}updateLabelModule(e){(this.options.label===void 0||this.options.label===null)&&(this.options.label=""),qr.updateGroupOptions(this.options,Sk(Sk({},e),{},{color:e&&e.color||this._localColor||void 0}),this.grouplist);const t=this.grouplist.get(this.options.group,!1),r=[e,this.options,t,this.globalOptions,this.defaultOptions];this.labelModule.update(this.options,r),this.labelModule.baseSize!==void 0&&(this.baseFontSize=this.labelModule.baseSize)}updateShape(e){if(e===this.options.shape&&this.shape)this.shape.setOptions(this.options,this.imageObj,this.imageObjAlt);else switch(this.options.shape){case"box":this.shape=new yIe(this.options,this.body,this.labelModule);break;case"circle":this.shape=new bIe(this.options,this.body,this.labelModule);break;case"circularImage":this.shape=new wIe(this.options,this.body,this.labelModule,this.imageObj,this.imageObjAlt);break;case"custom":this.shape=new SIe(this.options,this.body,this.labelModule,this.options.ctxRenderer);break;case"database":this.shape=new _Ie(this.options,this.body,this.labelModule);break;case"diamond":this.shape=new OIe(this.options,this.body,this.labelModule);break;case"dot":this.shape=new TIe(this.options,this.body,this.labelModule);break;case"ellipse":this.shape=new wk(this.options,this.body,this.labelModule);break;case"icon":this.shape=new RIe(this.options,this.body,this.labelModule);break;case"image":this.shape=new PIe(this.options,this.body,this.labelModule,this.imageObj,this.imageObjAlt);break;case"square":this.shape=new xIe(this.options,this.body,this.labelModule);break;case"hexagon":this.shape=new $Ie(this.options,this.body,this.labelModule);break;case"star":this.shape=new DIe(this.options,this.body,this.labelModule);break;case"text":this.shape=new NIe(this.options,this.body,this.labelModule);break;case"triangle":this.shape=new MIe(this.options,this.body,this.labelModule);break;case"triangleDown":this.shape=new qIe(this.options,this.body,this.labelModule);break;default:this.shape=new wk(this.options,this.body,this.labelModule);break}this.needsRefresh()}select(){this.selected=!0,this.needsRefresh()}unselect(){this.selected=!1,this.needsRefresh()}needsRefresh(){this.shape.refreshNeeded=!0}getTitle(){return this.options.title}distanceToBorder(e,t){return this.shape.distanceToBorder(e,t)}isFixed(){return this.options.fixed.x&&this.options.fixed.y}isSelected(){return this.selected}getValue(){return this.options.value}getLabelSize(){return this.labelModule.size()}setValueRange(e,t,r){if(this.options.value!==void 0){const i=this.options.scaling.customScalingFunction(e,t,r,this.options.value),o=this.options.scaling.max-this.options.scaling.min;if(this.options.scaling.label.enabled===!0){const s=this.options.scaling.label.max-this.options.scaling.label.min;this.options.font.size=this.options.scaling.label.min+i*s}this.options.size=this.options.scaling.min+i*o}else this.options.size=this.baseSize,this.options.font.size=this.baseFontSize;this.updateLabelModule()}draw(e){const t=this.getFormattingValues();return this.shape.draw(e,this.x,this.y,this.selected,this.hover,t)||{}}updateBoundingBox(e){this.shape.updateBoundingBox(this.x,this.y,e)}resize(e){const t=this.getFormattingValues();this.shape.resize(e,this.selected,this.hover,t)}getItemsOnPoint(e){const t=[];return this.labelModule.visible()&&fO(this.labelModule.getSize(),e)&&t.push({nodeId:this.id,labelId:0}),fO(this.shape.boundingBox,e)&&t.push({nodeId:this.id}),t}isOverlappingWith(e){return this.shape.left<e.right&&this.shape.left+this.shape.width>e.left&&this.shape.top<e.bottom&&this.shape.top+this.shape.height>e.top}isBoundingBoxOverlappingWith(e){return this.shape.boundingBox.left<e.right&&this.shape.boundingBox.right>e.left&&this.shape.boundingBox.top<e.bottom&&this.shape.boundingBox.bottom>e.top}static checkMass(e,t){if(e.mass!==void 0&&e.mass<=0){let r="";t!==void 0&&(r=" in node id: "+t),console.error("%cNegative or zero mass disallowed"+r+", setting mass to 1.",WQ),e.mass=1}}},FIe=class{constructor(e,t,r,i){var o;if(this.body=e,this.images=t,this.groups=r,this.layoutEngine=i,this.body.functions.createNode=z(o=this.create).call(o,this),this.nodesListeners={add:(s,a)=>{this.add(a.items)},update:(s,a)=>{this.update(a.items,a.data,a.oldData)},remove:(s,a)=>{this.remove(a.items)}},this.defaultOptions={borderWidth:1,borderWidthSelected:void 0,brokenImage:void 0,color:{border:"#2B7CE9",background:"#97C2FC",highlight:{border:"#2B7CE9",background:"#D2E5FF"},hover:{border:"#2B7CE9",background:"#D2E5FF"}},opacity:void 0,fixed:{x:!1,y:!1},font:{color:"#343434",size:14,face:"arial",background:"none",strokeWidth:0,strokeColor:"#ffffff",align:"center",vadjust:0,multi:!1,bold:{mod:"bold"},boldital:{mod:"bold italic"},ital:{mod:"italic"},mono:{mod:"",size:15,face:"monospace",vadjust:2}},group:void 0,hidden:!1,icon:{face:"FontAwesome",code:void 0,size:50,color:"#2B7CE9"},image:void 0,imagePadding:{top:0,right:0,bottom:0,left:0},label:void 0,labelHighlightBold:!0,level:void 0,margin:{top:5,right:5,bottom:5,left:5},mass:1,physics:!0,scaling:{min:10,max:30,label:{enabled:!1,min:14,max:30,maxVisible:30,drawThreshold:5},customScalingFunction:function(s,a,g,A){if(a===s)return .5;{const I=1/(a-s);return Math.max(0,(A-s)*I)}}},shadow:{enabled:!1,color:"rgba(0,0,0,0.5)",size:10,x:5,y:5},shape:"ellipse",shapeProperties:{borderDashes:!1,borderRadius:6,interpolation:!0,useImageSize:!1,useBorderWithImage:!1,coordinateOrigin:"center"},size:25,title:void 0,value:void 0,x:void 0,y:void 0},this.defaultOptions.mass<=0)throw"Internal error: mass in defaultOptions of NodesHandler may not be zero or negative";this.options=sn(this.defaultOptions),this.bindEventListeners()}bindEventListeners(){var e,t;this.body.emitter.on("refreshNodes",z(e=this.refresh).call(e,this)),this.body.emitter.on("refresh",z(t=this.refresh).call(t,this)),this.body.emitter.on("destroy",()=>{de(this.nodesListeners,(r,i)=>{this.body.data.nodes&&this.body.data.nodes.off(i,r)}),delete this.body.functions.createNode,delete this.nodesListeners.add,delete this.nodesListeners.update,delete this.nodesListeners.remove,delete this.nodesListeners})}setOptions(e){if(e!==void 0){if(sr.parseOptions(this.options,e),e.opacity!==void 0&&(hO(e.opacity)||!Nn(e.opacity)||e.opacity<0||e.opacity>1?console.error("Invalid option for node opacity. Value must be between 0 and 1, found: "+e.opacity):this.options.opacity=e.opacity),e.shape!==void 0)for(const t in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,t)&&this.body.nodes[t].updateShape();if(typeof e.font<"u"||typeof e.widthConstraint<"u"||typeof e.heightConstraint<"u")for(const t of Be(this.body.nodes))this.body.nodes[t].updateLabelModule(),this.body.nodes[t].needsRefresh();if(e.size!==void 0)for(const t in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,t)&&this.body.nodes[t].needsRefresh();(e.hidden!==void 0||e.physics!==void 0)&&this.body.emitter.emit("_dataChanged")}}setData(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;const r=this.body.data.nodes;if(I7("id",e))this.body.data.nodes=e;else if(we(e))this.body.data.nodes=new us,this.body.data.nodes.add(e);else if(!e)this.body.data.nodes=new us;else throw new TypeError("Array or DataSet expected");if(r&&de(this.nodesListeners,function(i,o){r.off(o,i)}),this.body.nodes={},this.body.data.nodes){const i=this;de(this.nodesListeners,function(s,a){i.body.data.nodes.on(a,s)});const o=this.body.data.nodes.getIds();this.add(o,!0)}t===!1&&this.body.emitter.emit("_dataChanged")}add(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,r;const i=[];for(let o=0;o<e.length;o++){r=e[o];const s=this.body.data.nodes.get(r),a=this.create(s);i.push(a),this.body.nodes[r]=a}this.layoutEngine.positionInitially(i),t===!1&&this.body.emitter.emit("_dataChanged")}update(e,t,r){const i=this.body.nodes;let o=!1;for(let s=0;s<e.length;s++){const a=e[s];let g=i[a];const A=t[s];g!==void 0?g.setOptions(A)&&(o=!0):(o=!0,g=this.create(A),i[a]=g)}!o&&r!==void 0&&(o=i7(t).call(t,function(s,a){const g=r[a];return g&&g.level!==s.level})),o===!0?this.body.emitter.emit("_dataChanged"):this.body.emitter.emit("_dataUpdated")}remove(e){const t=this.body.nodes;for(let r=0;r<e.length;r++){const i=e[r];delete t[i]}this.body.emitter.emit("_dataChanged")}create(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:sr;return new t(e,this.body,this.images,this.groups,this.options,this.defaultOptions)}refresh(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;de(this.body.nodes,(t,r)=>{const i=this.body.data.nodes.get(r);i!==void 0&&(e===!0&&t.setOptions({x:null,y:null}),t.setOptions({fixed:!1}),t.setOptions(i))})}getPositions(e){const t={};if(e!==void 0){if(we(e)===!0){for(let r=0;r<e.length;r++)if(this.body.nodes[e[r]]!==void 0){const i=this.body.nodes[e[r]];t[e[r]]={x:Math.round(i.x),y:Math.round(i.y)}}}else if(this.body.nodes[e]!==void 0){const r=this.body.nodes[e];t[e]={x:Math.round(r.x),y:Math.round(r.y)}}}else for(let r=0;r<this.body.nodeIndices.length;r++){const i=this.body.nodes[this.body.nodeIndices[r]];t[this.body.nodeIndices[r]]={x:Math.round(i.x),y:Math.round(i.y)}}return t}getPosition(e){if(e==null)throw new TypeError("No id was specified for getPosition method.");if(this.body.nodes[e]==null)throw new ReferenceError("NodeId provided for getPosition does not exist. Provided: ".concat(e));return{x:Math.round(this.body.nodes[e].x),y:Math.round(this.body.nodes[e].y)}}storePositions(){const e=[],t=this.body.data.nodes.getDataSet();for(const r of t.get()){const i=r.id,o=this.body.nodes[i],s=Math.round(o.x),a=Math.round(o.y);(r.x!==s||r.y!==a)&&e.push({id:i,x:s,y:a})}t.update(e)}getBoundingBox(e){if(this.body.nodes[e]!==void 0)return this.body.nodes[e].shape.boundingBox}getConnectedNodes(e,t){const r=[];if(this.body.nodes[e]!==void 0){const i=this.body.nodes[e],o={};for(let s=0;s<i.edges.length;s++){const a=i.edges[s];t!=="to"&&a.toId==i.id?o[a.fromId]===void 0&&(r.push(a.fromId),o[a.fromId]=!0):t!=="from"&&a.fromId==i.id&&o[a.toId]===void 0&&(r.push(a.toId),o[a.toId]=!0)}}return r}getConnectedEdges(e){const t=[];if(this.body.nodes[e]!==void 0){const r=this.body.nodes[e];for(let i=0;i<r.edges.length;i++)t.push(r.edges[i].id)}else console.error("NodeId provided for getConnectedEdges does not exist. Provided: ",e);return t}moveNode(e,t,r){this.body.nodes[e]!==void 0?(this.body.nodes[e].x=Number(t),this.body.nodes[e].y=Number(r),ri(()=>{this.body.emitter.emit("startSimulation")},0)):console.error("Node id supplied to moveNode does not exist. Provided: ",e)}};var _k={},Ok;function kIe(){if(Ok)return _k;Ok=1;var n=ee(),e=Math.hypot,t=Math.abs,r=Math.sqrt,i=!!e&&e(1/0,NaN)!==1/0;return n({target:"Math",stat:!0,arity:2,forced:i},{hypot:function(s,a){for(var g=0,A=0,I=arguments.length,C=0,l,d;A<I;)l=t(arguments[A++]),C<l?(d=C/l,g=g*d*d+1,C=l):l>0?(d=l/C,g+=d*d):g+=l;return C===1/0?1/0:C*r(g)}}),_k}var ff,Tk;function BIe(){if(Tk)return ff;Tk=1,kIe();var n=Ee();return ff=n.Math.hypot,ff}var pf,Rk;function zIe(){if(Rk)return pf;Rk=1;var n=BIe();return pf=n,pf}var vf,Pk;function jIe(){return Pk||(Pk=1,vf=zIe()),vf}var LIe=jIe(),GIe=ne(LIe);let rt=class{static transform(e,t){we(e)||(e=[e]);const r=t.point.x,i=t.point.y,o=t.angle,s=t.length;for(let a=0;a<e.length;++a){const g=e[a],A=g.x*Math.cos(o)-g.y*Math.sin(o),I=g.x*Math.sin(o)+g.y*Math.cos(o);g.x=r+s*A,g.y=i+s*I}}static drawPath(e,t){e.beginPath(),e.moveTo(t[0].x,t[0].y);for(let r=1;r<t.length;++r)e.lineTo(t[r].x,t[r].y);e.closePath()}},WIe=class extends rt{static draw(e,t){if(t.image){e.save(),e.translate(t.point.x,t.point.y),e.rotate(Math.PI/2+t.angle);const r=t.imageWidth!=null?t.imageWidth:t.image.width,i=t.imageHeight!=null?t.imageHeight:t.image.height;t.image.drawImageAtPosition(e,1,-r/2,0,r,i),e.restore()}return!1}},VIe=class extends rt{static draw(e,t){const r=[{x:0,y:0},{x:-1,y:.3},{x:-.9,y:0},{x:-1,y:-.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},ZIe=class{static draw(e,t){const r=[{x:-1,y:0},{x:0,y:.3},{x:-.4,y:0},{x:0,y:-.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},HIe=class{static draw(e,t){const r={x:-.4,y:0};rt.transform(r,t),e.strokeStyle=e.fillStyle,e.fillStyle="rgba(0, 0, 0, 0)";const i=Math.PI,o=t.angle-i/2,s=t.angle+i/2;return e.beginPath(),e.arc(r.x,r.y,t.length*.4,o,s,!1),e.stroke(),!0}},UIe=class{static draw(e,t){const r={x:-.3,y:0};rt.transform(r,t),e.strokeStyle=e.fillStyle,e.fillStyle="rgba(0, 0, 0, 0)";const i=Math.PI,o=t.angle+i/2,s=t.angle+3*i/2;return e.beginPath(),e.arc(r.x,r.y,t.length*.4,o,s,!1),e.stroke(),!0}},KIe=class{static draw(e,t){const r=[{x:.02,y:0},{x:-1,y:.3},{x:-1,y:-.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},YIe=class{static draw(e,t){const r=[{x:0,y:.3},{x:0,y:-.3},{x:-1,y:0}];return rt.transform(r,t),rt.drawPath(e,r),!0}},XIe=class{static draw(e,t){const r={x:-.4,y:0};return rt.transform(r,t),ZO(e,r.x,r.y,t.length*.4),!0}},QIe=class{static draw(e,t){const r=[{x:0,y:.5},{x:0,y:-.5},{x:-.15,y:-.5},{x:-.15,y:.5}];return rt.transform(r,t),rt.drawPath(e,r),!0}},JIe=class{static draw(e,t){const r=[{x:0,y:.3},{x:0,y:-.3},{x:-.6,y:-.3},{x:-.6,y:.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},eCe=class{static draw(e,t){const r=[{x:0,y:0},{x:-.5,y:-.3},{x:-1,y:0},{x:-.5,y:.3}];return rt.transform(r,t),rt.drawPath(e,r),!0}},tCe=class{static draw(e,t){const r=[{x:-1,y:.3},{x:-.5,y:0},{x:-1,y:-.3},{x:0,y:0}];return rt.transform(r,t),rt.drawPath(e,r),!0}},u7=class{static draw(e,t){let r;switch(t.type&&(r=t.type.toLowerCase()),r){case"image":return WIe.draw(e,t);case"circle":return XIe.draw(e,t);case"box":return JIe.draw(e,t);case"crow":return ZIe.draw(e,t);case"curve":return HIe.draw(e,t);case"diamond":return eCe.draw(e,t);case"inv_curve":return UIe.draw(e,t);case"triangle":return KIe.draw(e,t);case"inv_triangle":return YIe.draw(e,t);case"bar":return QIe.draw(e,t);case"vee":return tCe.draw(e,t);case"arrow":default:return VIe.draw(e,t)}}};function xk(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function $k(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=xk(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=xk(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}let h7=class{constructor(e,t,r){ze(this,"color",{}),ze(this,"colorDirty",!0),ze(this,"hoverWidth",1.5),ze(this,"selectionWidth",2),this._body=t,this._labelModule=r,this.setOptions(e),this.fromPoint=this.from,this.toPoint=this.to}connect(){this.from=this._body.nodes[this.options.from],this.to=this._body.nodes[this.options.to]}cleanup(){return!1}setOptions(e){this.options=e,this.from=this._body.nodes[this.options.from],this.to=this._body.nodes[this.options.to],this.id=this.options.id}drawLine(e,t,r,i){let o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:this.getViaNode();e.strokeStyle=this.getColor(e,t),e.lineWidth=t.width,t.dashes!==!1?this._drawDashedLine(e,t,o):this._drawLine(e,t,o)}_drawLine(e,t,r,i,o){if(this.from!=this.to)this._line(e,t,r,i,o);else{const[s,a,g]=this._getCircleData(e);this._circle(e,t,s,a,g)}}_drawDashedLine(e,t,r,i,o){e.lineCap="round";const s=we(t.dashes)?t.dashes:[5,5];if(e.setLineDash!==void 0){if(e.save(),e.setLineDash(s),e.lineDashOffset=0,this.from!=this.to)this._line(e,t,r);else{const[a,g,A]=this._getCircleData(e);this._circle(e,t,a,g,A)}e.setLineDash([0]),e.lineDashOffset=0,e.restore()}else{if(this.from!=this.to)LX(e,this.from.x,this.from.y,this.to.x,this.to.y,s);else{const[a,g,A]=this._getCircleData(e);this._circle(e,t,a,g,A)}this.enableShadow(e,t),e.stroke(),this.disableShadow(e,t)}}findBorderPosition(e,t,r){return this.from!=this.to?this._findBorderPosition(e,t,r):this._findBorderPositionCircle(e,t,r)}findBorderPositions(e){if(this.from!=this.to)return{from:this._findBorderPosition(this.from,e),to:this._findBorderPosition(this.to,e)};{var t;const[r,i]=zr(t=this._getCircleData(e)).call(t,0,2);return{from:this._findBorderPositionCircle(this.from,e,{x:r,y:i,low:.25,high:.6,direction:-1}),to:this._findBorderPositionCircle(this.from,e,{x:r,y:i,low:.6,high:.8,direction:1})}}}_getCircleData(e){const t=this.options.selfReference.size;e!==void 0&&this.from.shape.width===void 0&&this.from.shape.resize(e);const r=l7(e,this.options.selfReference.angle,t,this.from);return[r.x,r.y,t]}_pointOnCircle(e,t,r,i){const o=i*2*Math.PI;return{x:e+r*Math.cos(o),y:t-r*Math.sin(o)}}_findBorderPositionCircle(e,t,r){const i=r.x,o=r.y;let s=r.low,a=r.high;const g=r.direction,A=10,I=this.options.selfReference.size,C=.05;let l,d=(s+a)*.5,u=0;this.options.arrowStrikethrough===!0&&(g===-1?u=this.options.endPointOffset.from:g===1&&(u=this.options.endPointOffset.to));let h=0;do{d=(s+a)*.5,l=this._pointOnCircle(i,o,I,d);const v=Math.atan2(e.y-l.y,e.x-l.x),f=e.distanceToBorder(t,v)+u,c=Math.sqrt(Math.pow(l.x-e.x,2)+Math.pow(l.y-e.y,2)),b=f-c;if(Math.abs(b)<C)break;b>0?g>0?s=d:a=d:g>0?a=d:s=d,++h}while(s<=a&&h<A);return $k($k({},l),{},{t:d})}getLineWidth(e,t){return e===!0?Math.max(this.selectionWidth,.3/this._body.view.scale):t===!0?Math.max(this.hoverWidth,.3/this._body.view.scale):Math.max(this.options.width,.3/this._body.view.scale)}getColor(e,t){if(t.inheritsColor!==!1){if(t.inheritsColor==="both"&&this.from.id!==this.to.id){const r=e.createLinearGradient(this.from.x,this.from.y,this.to.x,this.to.y);let i=this.from.options.color.highlight.border,o=this.to.options.color.highlight.border;return this.from.selected===!1&&this.to.selected===!1?(i=hr(this.from.options.color.border,t.opacity),o=hr(this.to.options.color.border,t.opacity)):this.from.selected===!0&&this.to.selected===!1?o=this.to.options.color.border:this.from.selected===!1&&this.to.selected===!0&&(i=this.from.options.color.border),r.addColorStop(0,i),r.addColorStop(1,o),r}return t.inheritsColor==="to"?hr(this.to.options.color.border,t.opacity):hr(this.from.options.color.border,t.opacity)}else return hr(t.color,t.opacity)}_circle(e,t,r,i,o){this.enableShadow(e,t);let s=0,a=Math.PI*2;if(!this.options.selfReference.renderBehindTheNode){const g=this.options.selfReference.angle,A=this.options.selfReference.angle+Math.PI,I=this._findBorderPositionCircle(this.from,e,{x:r,y:i,low:g,high:A,direction:-1}),C=this._findBorderPositionCircle(this.from,e,{x:r,y:i,low:g,high:A,direction:1});s=Math.atan2(I.y-i,I.x-r),a=Math.atan2(C.y-i,C.x-r)}e.beginPath(),e.arc(r,i,o,s,a,!1),e.stroke(),this.disableShadow(e,t)}getDistanceToEdge(e,t,r,i,o,s){if(this.from!=this.to)return this._getDistanceToEdge(e,t,r,i,o,s);{const[a,g,A]=this._getCircleData(void 0),I=a-o,C=g-s;return Math.abs(Math.sqrt(I*I+C*C)-A)}}_getDistanceToLine(e,t,r,i,o,s){const a=r-e,g=i-t,A=a*a+g*g;let I=((o-e)*a+(s-t)*g)/A;I>1?I=1:I<0&&(I=0);const C=e+I*a,l=t+I*g,d=C-o,u=l-s;return Math.sqrt(d*d+u*u)}getArrowData(e,t,r,i,o,s){let a,g,A,I,C,l,d;const u=s.width;t==="from"?(A=this.from,I=this.to,C=s.fromArrowScale<0,l=Math.abs(s.fromArrowScale),d=s.fromArrowType):t==="to"?(A=this.to,I=this.from,C=s.toArrowScale<0,l=Math.abs(s.toArrowScale),d=s.toArrowType):(A=this.to,I=this.from,C=s.middleArrowScale<0,l=Math.abs(s.middleArrowScale),d=s.middleArrowType);const h=15*l+3*u;if(A!=I){const b=GIe(A.x-I.x,A.y-I.y),p=h/b;if(t!=="middle")if(this.options.smooth.enabled===!0){const y=this._findBorderPosition(A,e,{via:r}),E=this.getPoint(y.t+p*(t==="from"?1:-1),r);a=Math.atan2(y.y-E.y,y.x-E.x),g=y}else a=Math.atan2(A.y-I.y,A.x-I.x),g=this._findBorderPosition(A,e);else{const y=(C?-p:p)/2,E=this.getPoint(.5+y,r),S=this.getPoint(.5-y,r);a=Math.atan2(E.y-S.y,E.x-S.x),g=this.getPoint(.5,r)}}else{const[b,p,y]=this._getCircleData(e);if(t==="from"){const E=this.options.selfReference.angle,S=this.options.selfReference.angle+Math.PI,m=this._findBorderPositionCircle(this.from,e,{x:b,y:p,low:E,high:S,direction:-1});a=m.t*-2*Math.PI+1.5*Math.PI+.1*Math.PI,g=m}else if(t==="to"){const E=this.options.selfReference.angle,S=this.options.selfReference.angle+Math.PI,m=this._findBorderPositionCircle(this.from,e,{x:b,y:p,low:E,high:S,direction:1});a=m.t*-2*Math.PI+1.5*Math.PI-1.1*Math.PI,g=m}else{const E=this.options.selfReference.angle/(2*Math.PI);g=this._pointOnCircle(b,p,y,E),a=E*-2*Math.PI+1.5*Math.PI+.1*Math.PI}}const v=g.x-h*.9*Math.cos(a),f=g.y-h*.9*Math.sin(a);return{point:g,core:{x:v,y:f},angle:a,length:h,type:d}}drawArrowHead(e,t,r,i,o){e.strokeStyle=this.getColor(e,t),e.fillStyle=e.strokeStyle,e.lineWidth=t.width,u7.draw(e,o)&&(this.enableShadow(e,t),cg(e).call(e),this.disableShadow(e,t))}enableShadow(e,t){t.shadow===!0&&(e.shadowColor=t.shadowColor,e.shadowBlur=t.shadowSize,e.shadowOffsetX=t.shadowX,e.shadowOffsetY=t.shadowY)}disableShadow(e,t){t.shadow===!0&&(e.shadowColor="rgba(0,0,0,0)",e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0)}drawBackground(e,t){if(t.background!==!1){const r={strokeStyle:e.strokeStyle,lineWidth:e.lineWidth,dashes:e.dashes};e.strokeStyle=t.backgroundColor,e.lineWidth=t.backgroundSize,this.setStrokeDashed(e,t.backgroundDashes),e.stroke(),e.strokeStyle=r.strokeStyle,e.lineWidth=r.lineWidth,e.dashes=r.dashes,this.setStrokeDashed(e,t.dashes)}}setStrokeDashed(e,t){if(t!==!1)if(e.setLineDash!==void 0){const r=we(t)?t:[5,5];e.setLineDash(r)}else console.warn("setLineDash is not supported in this browser. The dashed stroke cannot be used.");else e.setLineDash!==void 0?e.setLineDash([]):console.warn("setLineDash is not supported in this browser. The dashed stroke cannot be used.")}};function Dk(n,e){var t=Be(n);if(ai){var r=ai(n);e&&(r=st(r).call(r,function(i){return Ci(n,i).enumerable})),t.push.apply(t,r)}return t}function Nk(n){for(var e=1;e<arguments.length;e++){var t,r,i=arguments[e]!=null?arguments[e]:{};e%2?be(t=Dk(Object(i),!0)).call(t,function(o){ze(n,o,i[o])}):gi?wg(n,gi(i)):be(r=Dk(Object(i))).call(r,function(o){_g(n,o,Ci(i,o))})}return n}let mT=class extends h7{constructor(e,t,r){super(e,t,r)}_findBorderPositionBezier(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this._getViaCoordinates();const i=10,o=.2;let s=!1,a=1,g=0,A=this.to,I,C,l=this.options.endPointOffset?this.options.endPointOffset.to:0;e.id===this.from.id&&(A=this.from,s=!0,l=this.options.endPointOffset?this.options.endPointOffset.from:0),this.options.arrowStrikethrough===!1&&(l=0);let d=0;do{C=(g+a)*.5,I=this.getPoint(C,r);const u=Math.atan2(A.y-I.y,A.x-I.x),h=A.distanceToBorder(t,u)+l,v=Math.sqrt(Math.pow(I.x-A.x,2)+Math.pow(I.y-A.y,2)),f=h-v;if(Math.abs(f)<o)break;f<0?s===!1?g=C:a=C:s===!1?a=C:g=C,++d}while(g<=a&&d<i);return Nk(Nk({},I),{},{t:C})}_getDistanceToBezierEdge(e,t,r,i,o,s,a){let g=1e9,A,I,C,l,d,u=e,h=t;for(I=1;I<10;I++)C=.1*I,l=Math.pow(1-C,2)*e+2*C*(1-C)*a.x+Math.pow(C,2)*r,d=Math.pow(1-C,2)*t+2*C*(1-C)*a.y+Math.pow(C,2)*i,I>0&&(A=this._getDistanceToLine(u,h,l,d,o,s),g=A<g?A:g),u=l,h=d;return g}_bezierCurve(e,t,r,i){e.beginPath(),e.moveTo(this.fromPoint.x,this.fromPoint.y),r!=null&&r.x!=null?i!=null&&i.x!=null?e.bezierCurveTo(r.x,r.y,i.x,i.y,this.toPoint.x,this.toPoint.y):e.quadraticCurveTo(r.x,r.y,this.toPoint.x,this.toPoint.y):e.lineTo(this.toPoint.x,this.toPoint.y),this.drawBackground(e,t),this.enableShadow(e,t),e.stroke(),this.disableShadow(e,t)}getViaNode(){return this._getViaCoordinates()}},Mk=class extends mT{constructor(e,t,r){super(e,t,r),ze(this,"via",this.via),this._boundFunction=()=>{this.positionBezierNode()},this._body.emitter.on("_repositionBezierNodes",this._boundFunction)}setOptions(e){super.setOptions(e);let t=!1;this.options.physics!==e.physics&&(t=!0),this.options=e,this.id=this.options.id,this.from=this._body.nodes[this.options.from],this.to=this._body.nodes[this.options.to],this.setupSupportNode(),this.connect(),t===!0&&(this.via.setOptions({physics:this.options.physics}),this.positionBezierNode())}connect(){this.from=this._body.nodes[this.options.from],this.to=this._body.nodes[this.options.to],this.from===void 0||this.to===void 0||this.options.physics===!1?this.via.setOptions({physics:!1}):this.from.id===this.to.id?this.via.setOptions({physics:!1}):this.via.setOptions({physics:!0})}cleanup(){return this._body.emitter.off("_repositionBezierNodes",this._boundFunction),this.via!==void 0?(delete this._body.nodes[this.via.id],this.via=void 0,!0):!1}setupSupportNode(){if(this.via===void 0){const e="edgeId:"+this.id,t=this._body.functions.createNode({id:e,shape:"circle",physics:!0,hidden:!0});this._body.nodes[e]=t,this.via=t,this.via.parentEdgeId=this.id,this.positionBezierNode()}}positionBezierNode(){this.via!==void 0&&this.from!==void 0&&this.to!==void 0?(this.via.x=.5*(this.from.x+this.to.x),this.via.y=.5*(this.from.y+this.to.y)):this.via!==void 0&&(this.via.x=0,this.via.y=0)}_line(e,t,r){this._bezierCurve(e,t,r)}_getViaCoordinates(){return this.via}getViaNode(){return this.via}getPoint(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.via;if(this.from===this.to){const[r,i,o]=this._getCircleData(),s=2*Math.PI*(1-e);return{x:r+o*Math.sin(s),y:i+o-o*(1-Math.cos(s))}}else return{x:Math.pow(1-e,2)*this.fromPoint.x+2*e*(1-e)*t.x+Math.pow(e,2)*this.toPoint.x,y:Math.pow(1-e,2)*this.fromPoint.y+2*e*(1-e)*t.y+Math.pow(e,2)*this.toPoint.y}}_findBorderPosition(e,t){return this._findBorderPositionBezier(e,t,this.via)}_getDistanceToEdge(e,t,r,i,o,s){return this._getDistanceToBezierEdge(e,t,r,i,o,s,this.via)}},qk=class extends mT{constructor(e,t,r){super(e,t,r)}_line(e,t,r){this._bezierCurve(e,t,r)}getViaNode(){return this._getViaCoordinates()}_getViaCoordinates(){const e=this.options.smooth.roundness,t=this.options.smooth.type;let r=Math.abs(this.from.x-this.to.x),i=Math.abs(this.from.y-this.to.y);if(t==="discrete"||t==="diagonalCross"){let o,s;r<=i?o=s=e*i:o=s=e*r,this.from.x>this.to.x&&(o=-o),this.from.y>=this.to.y&&(s=-s);let a=this.from.x+o,g=this.from.y+s;return t==="discrete"&&(r<=i?a=r<e*i?this.from.x:a:g=i<e*r?this.from.y:g),{x:a,y:g}}else if(t==="straightCross"){let o=(1-e)*r,s=(1-e)*i;return r<=i?(o=0,this.from.y<this.to.y&&(s=-s)):(this.from.x<this.to.x&&(o=-o),s=0),{x:this.to.x+o,y:this.to.y+s}}else if(t==="horizontal"){let o=(1-e)*r;return this.from.x<this.to.x&&(o=-o),{x:this.to.x+o,y:this.from.y}}else if(t==="vertical"){let o=(1-e)*i;return this.from.y<this.to.y&&(o=-o),{x:this.from.x,y:this.to.y+o}}else if(t==="curvedCW"){r=this.to.x-this.from.x,i=this.from.y-this.to.y;const o=Math.sqrt(r*r+i*i),s=Math.PI,g=(Math.atan2(i,r)+(e*.5+.5)*s)%(2*s);return{x:this.from.x+(e*.5+.5)*o*Math.sin(g),y:this.from.y+(e*.5+.5)*o*Math.cos(g)}}else if(t==="curvedCCW"){r=this.to.x-this.from.x,i=this.from.y-this.to.y;const o=Math.sqrt(r*r+i*i),s=Math.PI,g=(Math.atan2(i,r)+(-e*.5+.5)*s)%(2*s);return{x:this.from.x+(e*.5+.5)*o*Math.sin(g),y:this.from.y+(e*.5+.5)*o*Math.cos(g)}}else{let o,s;r<=i?o=s=e*i:o=s=e*r,this.from.x>this.to.x&&(o=-o),this.from.y>=this.to.y&&(s=-s);let a=this.from.x+o,g=this.from.y+s;return r<=i?this.from.x<=this.to.x?a=this.to.x<a?this.to.x:a:a=this.to.x>a?this.to.x:a:this.from.y>=this.to.y?g=this.to.y>g?this.to.y:g:g=this.to.y<g?this.to.y:g,{x:a,y:g}}}_findBorderPosition(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};return this._findBorderPositionBezier(e,t,r.via)}_getDistanceToEdge(e,t,r,i,o,s){let a=arguments.length>6&&arguments[6]!==void 0?arguments[6]:this._getViaCoordinates();return this._getDistanceToBezierEdge(e,t,r,i,o,s,a)}getPoint(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this._getViaCoordinates();const r=e,i=Math.pow(1-r,2)*this.fromPoint.x+2*r*(1-r)*t.x+Math.pow(r,2)*this.toPoint.x,o=Math.pow(1-r,2)*this.fromPoint.y+2*r*(1-r)*t.y+Math.pow(r,2)*this.toPoint.y;return{x:i,y:o}}},rCe=class extends mT{constructor(e,t,r){super(e,t,r)}_getDistanceToBezierEdge2(e,t,r,i,o,s,a,g){let A=1e9,I=e,C=t;const l=[0,0,0,0];for(let d=1;d<10;d++){const u=.1*d;l[0]=Math.pow(1-u,3),l[1]=3*u*Math.pow(1-u,2),l[2]=3*Math.pow(u,2)*(1-u),l[3]=Math.pow(u,3);const h=l[0]*e+l[1]*a.x+l[2]*g.x+l[3]*r,v=l[0]*t+l[1]*a.y+l[2]*g.y+l[3]*i;if(d>0){const f=this._getDistanceToLine(I,C,h,v,o,s);A=f<A?f:A}I=h,C=v}return A}},Fk=class extends rCe{constructor(e,t,r){super(e,t,r)}_line(e,t,r){const i=r[0],o=r[1];this._bezierCurve(e,t,i,o)}_getViaCoordinates(){const e=this.from.x-this.to.x,t=this.from.y-this.to.y;let r,i,o,s;const a=this.options.smooth.roundness;return(Math.abs(e)>Math.abs(t)||this.options.smooth.forceDirection===!0||this.options.smooth.forceDirection==="horizontal")&&this.options.smooth.forceDirection!=="vertical"?(i=this.from.y,s=this.to.y,r=this.from.x-a*e,o=this.to.x+a*e):(i=this.from.y-a*t,s=this.to.y+a*t,r=this.from.x,o=this.to.x),[{x:r,y:i},{x:o,y:s}]}getViaNode(){return this._getViaCoordinates()}_findBorderPosition(e,t){return this._findBorderPositionBezier(e,t)}_getDistanceToEdge(e,t,r,i,o,s){let[a,g]=arguments.length>6&&arguments[6]!==void 0?arguments[6]:this._getViaCoordinates();return this._getDistanceToBezierEdge2(e,t,r,i,o,s,a,g)}getPoint(e){let[t,r]=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this._getViaCoordinates();const i=e,o=[Math.pow(1-i,3),3*i*Math.pow(1-i,2),3*Math.pow(i,2)*(1-i),Math.pow(i,3)],s=o[0]*this.fromPoint.x+o[1]*t.x+o[2]*r.x+o[3]*this.toPoint.x,a=o[0]*this.fromPoint.y+o[1]*t.y+o[2]*r.y+o[3]*this.toPoint.y;return{x:s,y:a}}},kk=class extends h7{constructor(e,t,r){super(e,t,r)}_line(e,t){e.beginPath(),e.moveTo(this.fromPoint.x,this.fromPoint.y),e.lineTo(this.toPoint.x,this.toPoint.y),this.enableShadow(e,t),e.stroke(),this.disableShadow(e,t)}getViaNode(){}getPoint(e){return{x:(1-e)*this.fromPoint.x+e*this.toPoint.x,y:(1-e)*this.fromPoint.y+e*this.toPoint.y}}_findBorderPosition(e,t){let r=this.to,i=this.from;e.id===this.from.id&&(r=this.from,i=this.to);const o=Math.atan2(r.y-i.y,r.x-i.x),s=r.x-i.x,a=r.y-i.y,g=Math.sqrt(s*s+a*a),A=e.distanceToBorder(t,o),I=(g-A)/g;return{x:(1-I)*i.x+I*r.x,y:(1-I)*i.y+I*r.y,t:0}}_getDistanceToEdge(e,t,r,i,o,s){return this._getDistanceToLine(e,t,r,i,o,s)}},ns=class c7{constructor(e,t,r,i,o){if(t===void 0)throw new Error("No body provided");this.options=sn(i),this.globalOptions=i,this.defaultOptions=o,this.body=t,this.imagelist=r,this.id=void 0,this.fromId=void 0,this.toId=void 0,this.selected=!1,this.hover=!1,this.labelDirty=!0,this.baseWidth=this.options.width,this.baseFontSize=this.options.font.size,this.from=void 0,this.to=void 0,this.edgeType=void 0,this.connected=!1,this.labelModule=new d7(this.body,this.options,!0),this.setOptions(e)}setOptions(e){if(!e)return;let t=typeof e.physics<"u"&&this.options.physics!==e.physics||typeof e.hidden<"u"&&(this.options.hidden||!1)!==(e.hidden||!1)||typeof e.from<"u"&&this.options.from!==e.from||typeof e.to<"u"&&this.options.to!==e.to;c7.parseOptions(this.options,e,!0,this.globalOptions),e.id!==void 0&&(this.id=e.id),e.from!==void 0&&(this.fromId=e.from),e.to!==void 0&&(this.toId=e.to),e.title!==void 0&&(this.title=e.title),e.value!==void 0&&(e.value=C7(e.value));const r=[e,this.options,this.defaultOptions];return this.chooser=pT("edge",r),this.updateLabelModule(e),t=this.updateEdgeType()||t,this._setInteractionWidths(),this.connect(),t}static parseOptions(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1,i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:{},o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!1;if(zs(["endPointOffset","arrowStrikethrough","id","from","hidden","hoverWidth","labelHighlightBold","length","line","opacity","physics","scaling","selectionWidth","selfReferenceSize","selfReference","to","title","value","width","font","chosen","widthConstraint"],e,t,r),t.endPointOffset!==void 0&&t.endPointOffset.from!==void 0&&(Nn(t.endPointOffset.from)?e.endPointOffset.from=t.endPointOffset.from:(e.endPointOffset.from=i.endPointOffset.from!==void 0?i.endPointOffset.from:0,console.error("endPointOffset.from is not a valid number"))),t.endPointOffset!==void 0&&t.endPointOffset.to!==void 0&&(Nn(t.endPointOffset.to)?e.endPointOffset.to=t.endPointOffset.to:(e.endPointOffset.to=i.endPointOffset.to!==void 0?i.endPointOffset.to:0,console.error("endPointOffset.to is not a valid number"))),GA(t.label)?e.label=t.label:GA(e.label)||(e.label=void 0),dr(e,t,"smooth",i),dr(e,t,"shadow",i),dr(e,t,"background",i),t.dashes!==void 0&&t.dashes!==null?e.dashes=t.dashes:r===!0&&t.dashes===null&&(e.dashes=nn(i.dashes)),t.scaling!==void 0&&t.scaling!==null?(t.scaling.min!==void 0&&(e.scaling.min=t.scaling.min),t.scaling.max!==void 0&&(e.scaling.max=t.scaling.max),dr(e.scaling,t.scaling,"label",i.scaling)):r===!0&&t.scaling===null&&(e.scaling=nn(i.scaling)),t.arrows!==void 0&&t.arrows!==null)if(typeof t.arrows=="string"){const a=t.arrows.toLowerCase();e.arrows.to.enabled=_e(a).call(a,"to")!=-1,e.arrows.middle.enabled=_e(a).call(a,"middle")!=-1,e.arrows.from.enabled=_e(a).call(a,"from")!=-1}else if(typeof t.arrows=="object")dr(e.arrows,t.arrows,"to",i.arrows),dr(e.arrows,t.arrows,"middle",i.arrows),dr(e.arrows,t.arrows,"from",i.arrows);else throw new Error("The arrow newOptions can only be an object or a string. Refer to the documentation. You used:"+ks(t.arrows));else r===!0&&t.arrows===null&&(e.arrows=nn(i.arrows));if(t.color!==void 0&&t.color!==null){const a=ts(t.color)?{color:t.color,highlight:t.color,hover:t.color,inherit:!1,opacity:1}:t.color,g=e.color;if(o)Me(g,i.color,!1,r);else for(const A in g)Object.prototype.hasOwnProperty.call(g,A)&&delete g[A];if(ts(g))g.color=g,g.highlight=g,g.hover=g,g.inherit=!1,a.opacity===void 0&&(g.opacity=1);else{let A=!1;a.color!==void 0&&(g.color=a.color,A=!0),a.highlight!==void 0&&(g.highlight=a.highlight,A=!0),a.hover!==void 0&&(g.hover=a.hover,A=!0),a.inherit!==void 0&&(g.inherit=a.inherit),a.opacity!==void 0&&(g.opacity=Math.min(1,Math.max(0,a.opacity))),A===!0?g.inherit=!1:g.inherit===void 0&&(g.inherit="from")}}else r===!0&&t.color===null&&(e.color=sn(i.color));r===!0&&t.font===null&&(e.font=sn(i.font)),Object.prototype.hasOwnProperty.call(t,"selfReferenceSize")&&(console.warn("The selfReferenceSize property has been deprecated. Please use selfReference property instead. The selfReference can be set like thise selfReference:{size:30, angle:Math.PI / 4}"),e.selfReference.size=t.selfReferenceSize)}getFormattingValues(){const e=this.options.arrows.to===!0||this.options.arrows.to.enabled===!0,t=this.options.arrows.from===!0||this.options.arrows.from.enabled===!0,r=this.options.arrows.middle===!0||this.options.arrows.middle.enabled===!0,i=this.options.color.inherit,o={toArrow:e,toArrowScale:this.options.arrows.to.scaleFactor,toArrowType:this.options.arrows.to.type,toArrowSrc:this.options.arrows.to.src,toArrowImageWidth:this.options.arrows.to.imageWidth,toArrowImageHeight:this.options.arrows.to.imageHeight,middleArrow:r,middleArrowScale:this.options.arrows.middle.scaleFactor,middleArrowType:this.options.arrows.middle.type,middleArrowSrc:this.options.arrows.middle.src,middleArrowImageWidth:this.options.arrows.middle.imageWidth,middleArrowImageHeight:this.options.arrows.middle.imageHeight,fromArrow:t,fromArrowScale:this.options.arrows.from.scaleFactor,fromArrowType:this.options.arrows.from.type,fromArrowSrc:this.options.arrows.from.src,fromArrowImageWidth:this.options.arrows.from.imageWidth,fromArrowImageHeight:this.options.arrows.from.imageHeight,arrowStrikethrough:this.options.arrowStrikethrough,color:i?void 0:this.options.color.color,inheritsColor:i,opacity:this.options.color.opacity,hidden:this.options.hidden,length:this.options.length,shadow:this.options.shadow.enabled,shadowColor:this.options.shadow.color,shadowSize:this.options.shadow.size,shadowX:this.options.shadow.x,shadowY:this.options.shadow.y,dashes:this.options.dashes,width:this.options.width,background:this.options.background.enabled,backgroundColor:this.options.background.color,backgroundSize:this.options.background.size,backgroundDashes:this.options.background.dashes};if(this.selected||this.hover)if(this.chooser===!0){if(this.selected){const s=this.options.selectionWidth;typeof s=="function"?o.width=s(o.width):typeof s=="number"&&(o.width+=s),o.width=Math.max(o.width,.3/this.body.view.scale),o.color=this.options.color.highlight,o.shadow=this.options.shadow.enabled}else if(this.hover){const s=this.options.hoverWidth;typeof s=="function"?o.width=s(o.width):typeof s=="number"&&(o.width+=s),o.width=Math.max(o.width,.3/this.body.view.scale),o.color=this.options.color.hover,o.shadow=this.options.shadow.enabled}}else typeof this.chooser=="function"&&(this.chooser(o,this.options.id,this.selected,this.hover),o.color!==void 0&&(o.inheritsColor=!1),o.shadow===!1&&(o.shadowColor!==this.options.shadow.color||o.shadowSize!==this.options.shadow.size||o.shadowX!==this.options.shadow.x||o.shadowY!==this.options.shadow.y)&&(o.shadow=!0));else o.shadow=this.options.shadow.enabled,o.width=Math.max(o.width,.3/this.body.view.scale);return o}updateLabelModule(e){const t=[e,this.options,this.globalOptions,this.defaultOptions];this.labelModule.update(this.options,t),this.labelModule.baseSize!==void 0&&(this.baseFontSize=this.labelModule.baseSize)}updateEdgeType(){const e=this.options.smooth;let t=!1,r=!0;return this.edgeType!==void 0&&((this.edgeType instanceof Mk&&e.enabled===!0&&e.type==="dynamic"||this.edgeType instanceof Fk&&e.enabled===!0&&e.type==="cubicBezier"||this.edgeType instanceof qk&&e.enabled===!0&&e.type!=="dynamic"&&e.type!=="cubicBezier"||this.edgeType instanceof kk&&e.type.enabled===!1)&&(r=!1),r===!0&&(t=this.cleanup())),r===!0?e.enabled===!0?e.type==="dynamic"?(t=!0,this.edgeType=new Mk(this.options,this.body,this.labelModule)):e.type==="cubicBezier"?this.edgeType=new Fk(this.options,this.body,this.labelModule):this.edgeType=new qk(this.options,this.body,this.labelModule):this.edgeType=new kk(this.options,this.body,this.labelModule):this.edgeType.setOptions(this.options),t}connect(){this.disconnect(),this.from=this.body.nodes[this.fromId]||void 0,this.to=this.body.nodes[this.toId]||void 0,this.connected=this.from!==void 0&&this.to!==void 0,this.connected===!0?(this.from.attachEdge(this),this.to.attachEdge(this)):(this.from&&this.from.detachEdge(this),this.to&&this.to.detachEdge(this)),this.edgeType.connect()}disconnect(){this.from&&(this.from.detachEdge(this),this.from=void 0),this.to&&(this.to.detachEdge(this),this.to=void 0),this.connected=!1}getTitle(){return this.title}isSelected(){return this.selected}getValue(){return this.options.value}setValueRange(e,t,r){if(this.options.value!==void 0){const i=this.options.scaling.customScalingFunction(e,t,r,this.options.value),o=this.options.scaling.max-this.options.scaling.min;if(this.options.scaling.label.enabled===!0){const s=this.options.scaling.label.max-this.options.scaling.label.min;this.options.font.size=this.options.scaling.label.min+i*s}this.options.width=this.options.scaling.min+i*o}else this.options.width=this.baseWidth,this.options.font.size=this.baseFontSize;this._setInteractionWidths(),this.updateLabelModule()}_setInteractionWidths(){typeof this.options.hoverWidth=="function"?this.edgeType.hoverWidth=this.options.hoverWidth(this.options.width):this.edgeType.hoverWidth=this.options.hoverWidth+this.options.width,typeof this.options.selectionWidth=="function"?this.edgeType.selectionWidth=this.options.selectionWidth(this.options.width):this.edgeType.selectionWidth=this.options.selectionWidth+this.options.width}draw(e){const t=this.getFormattingValues();if(t.hidden)return;const r=this.edgeType.getViaNode();this.edgeType.drawLine(e,t,this.selected,this.hover,r),this.drawLabel(e,r)}drawArrows(e){const t=this.getFormattingValues();if(t.hidden)return;const r=this.edgeType.getViaNode(),i={};this.edgeType.fromPoint=this.edgeType.from,this.edgeType.toPoint=this.edgeType.to,t.fromArrow&&(i.from=this.edgeType.getArrowData(e,"from",r,this.selected,this.hover,t),t.arrowStrikethrough===!1&&(this.edgeType.fromPoint=i.from.core),t.fromArrowSrc&&(i.from.image=this.imagelist.load(t.fromArrowSrc)),t.fromArrowImageWidth&&(i.from.imageWidth=t.fromArrowImageWidth),t.fromArrowImageHeight&&(i.from.imageHeight=t.fromArrowImageHeight)),t.toArrow&&(i.to=this.edgeType.getArrowData(e,"to",r,this.selected,this.hover,t),t.arrowStrikethrough===!1&&(this.edgeType.toPoint=i.to.core),t.toArrowSrc&&(i.to.image=this.imagelist.load(t.toArrowSrc)),t.toArrowImageWidth&&(i.to.imageWidth=t.toArrowImageWidth),t.toArrowImageHeight&&(i.to.imageHeight=t.toArrowImageHeight)),t.middleArrow&&(i.middle=this.edgeType.getArrowData(e,"middle",r,this.selected,this.hover,t),t.middleArrowSrc&&(i.middle.image=this.imagelist.load(t.middleArrowSrc)),t.middleArrowImageWidth&&(i.middle.imageWidth=t.middleArrowImageWidth),t.middleArrowImageHeight&&(i.middle.imageHeight=t.middleArrowImageHeight)),t.fromArrow&&this.edgeType.drawArrowHead(e,t,this.selected,this.hover,i.from),t.middleArrow&&this.edgeType.drawArrowHead(e,t,this.selected,this.hover,i.middle),t.toArrow&&this.edgeType.drawArrowHead(e,t,this.selected,this.hover,i.to)}drawLabel(e,t){if(this.options.label!==void 0){const r=this.from,i=this.to;this.labelModule.differentState(this.selected,this.hover)&&this.labelModule.getTextSize(e,this.selected,this.hover);let o;if(r.id!=i.id){this.labelModule.pointToSelf=!1,o=this.edgeType.getPoint(.5,t),e.save();const s=this._getRotation(e);s.angle!=0&&(e.translate(s.x,s.y),e.rotate(s.angle)),this.labelModule.draw(e,o.x,o.y,this.selected,this.hover),e.restore()}else{this.labelModule.pointToSelf=!0;const s=l7(e,this.options.selfReference.angle,this.options.selfReference.size,r);o=this._pointOnCircle(s.x,s.y,this.options.selfReference.size,this.options.selfReference.angle),this.labelModule.draw(e,o.x,o.y,this.selected,this.hover)}}}getItemsOnPoint(e){const t=[];if(this.labelModule.visible()){const i=this._getRotation();fO(this.labelModule.getSize(),e,i)&&t.push({edgeId:this.id,labelId:0})}const r={left:e.x,top:e.y};return this.isOverlappingWith(r)&&t.push({edgeId:this.id}),t}isOverlappingWith(e){if(this.connected){const r=this.from.x,i=this.from.y,o=this.to.x,s=this.to.y,a=e.left,g=e.top;return this.edgeType.getDistanceToEdge(r,i,o,s,a,g)<10}else return!1}_getRotation(e){const t=this.edgeType.getViaNode(),r=this.edgeType.getPoint(.5,t);e!==void 0&&this.labelModule.calculateLabelSize(e,this.selected,this.hover,r.x,r.y);const i={x:r.x,y:this.labelModule.size.yLine,angle:0};if(!this.labelModule.visible()||this.options.font.align==="horizontal")return i;const o=this.from.y-this.to.y,s=this.from.x-this.to.x;let a=Math.atan2(o,s);return(a<-1&&s<0||a>0&&s<0)&&(a+=Math.PI),i.angle=a,i}_pointOnCircle(e,t,r,i){return{x:e+r*Math.cos(i),y:t-r*Math.sin(i)}}select(){this.selected=!0}unselect(){this.selected=!1}cleanup(){return this.edgeType.cleanup()}remove(){this.cleanup(),this.disconnect(),delete this.body.edges[this.id]}endPointsValid(){return this.body.nodes[this.fromId]!==void 0&&this.body.nodes[this.toId]!==void 0}},iCe=class{constructor(e,t,r){var i;this.body=e,this.images=t,this.groups=r,this.body.functions.createEdge=z(i=this.create).call(i,this),this.edgesListeners={add:(o,s)=>{this.add(s.items)},update:(o,s)=>{this.update(s.items)},remove:(o,s)=>{this.remove(s.items)}},this.options={},this.defaultOptions={arrows:{to:{enabled:!1,scaleFactor:1,type:"arrow"},middle:{enabled:!1,scaleFactor:1,type:"arrow"},from:{enabled:!1,scaleFactor:1,type:"arrow"}},endPointOffset:{from:0,to:0},arrowStrikethrough:!0,color:{color:"#848484",highlight:"#848484",hover:"#848484",inherit:"from",opacity:1},dashes:!1,font:{color:"#343434",size:14,face:"arial",background:"none",strokeWidth:2,strokeColor:"#ffffff",align:"horizontal",multi:!1,vadjust:0,bold:{mod:"bold"},boldital:{mod:"bold italic"},ital:{mod:"italic"},mono:{mod:"",size:15,face:"courier new",vadjust:2}},hidden:!1,hoverWidth:1.5,label:void 0,labelHighlightBold:!0,length:void 0,physics:!0,scaling:{min:1,max:15,label:{enabled:!0,min:14,max:30,maxVisible:30,drawThreshold:5},customScalingFunction:function(o,s,a,g){if(s===o)return .5;{const A=1/(s-o);return Math.max(0,(g-o)*A)}}},selectionWidth:1.5,selfReference:{size:20,angle:Math.PI/4,renderBehindTheNode:!0},shadow:{enabled:!1,color:"rgba(0,0,0,0.5)",size:10,x:5,y:5},background:{enabled:!1,color:"rgba(111,111,111,1)",size:10,dashes:!1},smooth:{enabled:!0,type:"dynamic",forceDirection:"none",roundness:.5},title:void 0,width:1,value:void 0},Me(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){var e=this,t,r;this.body.emitter.on("_forceDisableDynamicCurves",function(i){let o=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;i==="dynamic"&&(i="continuous");let s=!1;for(const a in e.body.edges)if(Object.prototype.hasOwnProperty.call(e.body.edges,a)){const g=e.body.edges[a],A=e.body.data.edges.get(a);if(A!=null){const I=A.smooth;I!==void 0&&I.enabled===!0&&I.type==="dynamic"&&(i===void 0?g.setOptions({smooth:!1}):g.setOptions({smooth:{type:i}}),s=!0)}}o===!0&&s===!0&&e.body.emitter.emit("_dataChanged")}),this.body.emitter.on("_dataUpdated",()=>{this.reconnectEdges()}),this.body.emitter.on("refreshEdges",z(t=this.refresh).call(t,this)),this.body.emitter.on("refresh",z(r=this.refresh).call(r,this)),this.body.emitter.on("destroy",()=>{de(this.edgesListeners,(i,o)=>{this.body.data.edges&&this.body.data.edges.off(o,i)}),delete this.body.functions.createEdge,delete this.edgesListeners.add,delete this.edgesListeners.update,delete this.edgesListeners.remove,delete this.edgesListeners})}setOptions(e){if(e!==void 0){ns.parseOptions(this.options,e,!0,this.defaultOptions,!0);let t=!1;if(e.smooth!==void 0)for(const r in this.body.edges)Object.prototype.hasOwnProperty.call(this.body.edges,r)&&(t=this.body.edges[r].updateEdgeType()||t);if(e.font!==void 0)for(const r in this.body.edges)Object.prototype.hasOwnProperty.call(this.body.edges,r)&&this.body.edges[r].updateLabelModule();(e.hidden!==void 0||e.physics!==void 0||t===!0)&&this.body.emitter.emit("_dataChanged")}}setData(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;const r=this.body.data.edges;if(I7("id",e))this.body.data.edges=e;else if(we(e))this.body.data.edges=new us,this.body.data.edges.add(e);else if(!e)this.body.data.edges=new us;else throw new TypeError("Array or DataSet expected");if(r&&de(this.edgesListeners,(i,o)=>{r.off(o,i)}),this.body.edges={},this.body.data.edges){de(this.edgesListeners,(o,s)=>{this.body.data.edges.on(s,o)});const i=this.body.data.edges.getIds();this.add(i,!0)}this.body.emitter.emit("_adjustEdgesForHierarchicalLayout"),t===!1&&this.body.emitter.emit("_dataChanged")}add(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;const r=this.body.edges,i=this.body.data.edges;for(let o=0;o<e.length;o++){const s=e[o],a=r[s];a&&a.disconnect();const g=i.get(s,{showInternalIds:!0});r[s]=this.create(g)}this.body.emitter.emit("_adjustEdgesForHierarchicalLayout"),t===!1&&this.body.emitter.emit("_dataChanged")}update(e){const t=this.body.edges,r=this.body.data.edges;let i=!1;for(let o=0;o<e.length;o++){const s=e[o],a=r.get(s),g=t[s];g!==void 0?(g.disconnect(),i=g.setOptions(a)||i,g.connect()):(this.body.edges[s]=this.create(a),i=!0)}i===!0?(this.body.emitter.emit("_adjustEdgesForHierarchicalLayout"),this.body.emitter.emit("_dataChanged")):this.body.emitter.emit("_dataUpdated")}remove(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;if(e.length===0)return;const r=this.body.edges;de(e,i=>{const o=r[i];o!==void 0&&o.remove()}),t&&this.body.emitter.emit("_dataChanged")}refresh(){de(this.body.edges,(e,t)=>{const r=this.body.data.edges.get(t);r!==void 0&&e.setOptions(r)})}create(e){return new ns(e,this.body,this.images,this.options,this.defaultOptions)}reconnectEdges(){let e;const t=this.body.nodes,r=this.body.edges;for(e in t)Object.prototype.hasOwnProperty.call(t,e)&&(t[e].edges=[]);for(e in r)if(Object.prototype.hasOwnProperty.call(r,e)){const i=r[e];i.from=null,i.to=null,i.connect()}}getConnectedNodes(e){const t=[];if(this.body.edges[e]!==void 0){const r=this.body.edges[e];r.fromId!==void 0&&t.push(r.fromId),r.toId!==void 0&&t.push(r.toId)}return t}_updateState(){this._addMissingEdges(),this._removeInvalidEdges()}_removeInvalidEdges(){const e=[];de(this.body.edges,(t,r)=>{const i=this.body.nodes[t.toId],o=this.body.nodes[t.fromId];i!==void 0&&i.isCluster===!0||o!==void 0&&o.isCluster===!0||(i===void 0||o===void 0)&&e.push(r)}),this.remove(e,!1)}_addMissingEdges(){const e=this.body.data.edges;if(e==null)return;const t=this.body.edges,r=[];be(e).call(e,(i,o)=>{t[o]===void 0&&r.push(o)}),this.add(r,!0)}},f7=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.barnesHutTree,this.setOptions(r),this._rng=yI("BARNES HUT SOLVER")}setOptions(e){this.options=e,this.thetaInversed=1/this.options.theta,this.overlapAvoidanceFactor=1-Math.max(0,Math.min(1,this.options.avoidOverlap))}solve(){if(this.options.gravitationalConstant!==0&&this.physicsBody.physicsNodeIndices.length>0){let e;const t=this.body.nodes,r=this.physicsBody.physicsNodeIndices,i=r.length,o=this._formBarnesHutTree(t,r);this.barnesHutTree=o;for(let s=0;s<i;s++)e=t[r[s]],e.options.mass>0&&this._getForceContributions(o.root,e)}}_getForceContributions(e,t){this._getForceContribution(e.children.NW,t),this._getForceContribution(e.children.NE,t),this._getForceContribution(e.children.SW,t),this._getForceContribution(e.children.SE,t)}_getForceContribution(e,t){if(e.childrenCount>0){const r=e.centerOfMass.x-t.x,i=e.centerOfMass.y-t.y,o=Math.sqrt(r*r+i*i);o*e.calcSize>this.thetaInversed?this._calculateForces(o,r,i,t,e):e.childrenCount===4?this._getForceContributions(e,t):e.children.data.id!=t.id&&this._calculateForces(o,r,i,t,e)}}_calculateForces(e,t,r,i,o){e===0&&(e=.1,t=e),this.overlapAvoidanceFactor<1&&i.shape.radius&&(e=Math.max(.1+this.overlapAvoidanceFactor*i.shape.radius,e-i.shape.radius));const s=this.options.gravitationalConstant*o.mass*i.options.mass/Math.pow(e,3),a=t*s,g=r*s;this.physicsBody.forces[i.id].x+=a,this.physicsBody.forces[i.id].y+=g}_formBarnesHutTree(e,t){let r;const i=t.length;let o=e[t[0]].x,s=e[t[0]].y,a=e[t[0]].x,g=e[t[0]].y;for(let v=1;v<i;v++){const f=e[t[v]],c=f.x,b=f.y;f.options.mass>0&&(c<o&&(o=c),c>a&&(a=c),b<s&&(s=b),b>g&&(g=b))}const A=Math.abs(a-o)-Math.abs(g-s);A>0?(s-=.5*A,g+=.5*A):(o+=.5*A,a-=.5*A);const C=Math.max(1e-5,Math.abs(a-o)),l=.5*C,d=.5*(o+a),u=.5*(s+g),h={root:{centerOfMass:{x:0,y:0},mass:0,range:{minX:d-l,maxX:d+l,minY:u-l,maxY:u+l},size:C,calcSize:1/C,children:{data:null},maxWidth:0,level:0,childrenCount:4}};this._splitBranch(h.root);for(let v=0;v<i;v++)r=e[t[v]],r.options.mass>0&&this._placeInTree(h.root,r);return h}_updateBranchMass(e,t){const r=e.centerOfMass,i=e.mass+t.options.mass,o=1/i;r.x=r.x*e.mass+t.x*t.options.mass,r.x*=o,r.y=r.y*e.mass+t.y*t.options.mass,r.y*=o,e.mass=i;const s=Math.max(Math.max(t.height,t.radius),t.width);e.maxWidth=e.maxWidth<s?s:e.maxWidth}_placeInTree(e,t,r){(r!=!0||r===void 0)&&this._updateBranchMass(e,t);const i=e.children.NW.range;let o;i.maxX>t.x?i.maxY>t.y?o="NW":o="SW":i.maxY>t.y?o="NE":o="SE",this._placeInRegion(e,t,o)}_placeInRegion(e,t,r){const i=e.children[r];switch(i.childrenCount){case 0:i.children.data=t,i.childrenCount=1,this._updateBranchMass(i,t);break;case 1:i.children.data.x===t.x&&i.children.data.y===t.y?(t.x+=this._rng(),t.y+=this._rng()):(this._splitBranch(i),this._placeInTree(i,t));break;case 4:this._placeInTree(i,t);break}}_splitBranch(e){let t=null;e.childrenCount===1&&(t=e.children.data,e.mass=0,e.centerOfMass.x=0,e.centerOfMass.y=0),e.childrenCount=4,e.children.data=null,this._insertRegion(e,"NW"),this._insertRegion(e,"NE"),this._insertRegion(e,"SW"),this._insertRegion(e,"SE"),t!=null&&this._placeInTree(e,t)}_insertRegion(e,t){let r,i,o,s;const a=.5*e.size;switch(t){case"NW":r=e.range.minX,i=e.range.minX+a,o=e.range.minY,s=e.range.minY+a;break;case"NE":r=e.range.minX+a,i=e.range.maxX,o=e.range.minY,s=e.range.minY+a;break;case"SW":r=e.range.minX,i=e.range.minX+a,o=e.range.minY+a,s=e.range.maxY;break;case"SE":r=e.range.minX+a,i=e.range.maxX,o=e.range.minY+a,s=e.range.maxY;break}e.children[t]={centerOfMass:{x:0,y:0},mass:0,range:{minX:r,maxX:i,minY:o,maxY:s},size:.5*e.size,calcSize:2*e.calcSize,children:{data:null},maxWidth:0,level:e.level+1,childrenCount:0}}_debug(e,t){this.barnesHutTree!==void 0&&(e.lineWidth=1,this._drawBranch(this.barnesHutTree.root,e,t))}_drawBranch(e,t,r){r===void 0&&(r="#FF0000"),e.childrenCount===4&&(this._drawBranch(e.children.NW,t),this._drawBranch(e.children.NE,t),this._drawBranch(e.children.SE,t),this._drawBranch(e.children.SW,t)),t.strokeStyle=r,t.beginPath(),t.moveTo(e.range.minX,e.range.minY),t.lineTo(e.range.maxX,e.range.minY),t.stroke(),t.beginPath(),t.moveTo(e.range.maxX,e.range.minY),t.lineTo(e.range.maxX,e.range.maxY),t.stroke(),t.beginPath(),t.moveTo(e.range.maxX,e.range.maxY),t.lineTo(e.range.minX,e.range.maxY),t.stroke(),t.beginPath(),t.moveTo(e.range.minX,e.range.maxY),t.lineTo(e.range.minX,e.range.minY),t.stroke()}},nCe=class{constructor(e,t,r){this._rng=yI("REPULSION SOLVER"),this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e}solve(){let e,t,r,i,o,s,a,g;const A=this.body.nodes,I=this.physicsBody.physicsNodeIndices,C=this.physicsBody.forces,l=this.options.nodeDistance,d=-2/3/l,u=4/3;for(let h=0;h<I.length-1;h++){a=A[I[h]];for(let v=h+1;v<I.length;v++)g=A[I[v]],e=g.x-a.x,t=g.y-a.y,r=Math.sqrt(e*e+t*t),r===0&&(r=.1*this._rng(),e=r),r<2*l&&(r<.5*l?s=1:s=d*r+u,s=s/r,i=e*s,o=t*s,C[a.id].x-=i,C[a.id].y-=o,C[g.id].x+=i,C[g.id].y+=o)}}},oCe=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e,this.overlapAvoidanceFactor=Math.max(0,Math.min(1,this.options.avoidOverlap||0))}solve(){const e=this.body.nodes,t=this.physicsBody.physicsNodeIndices,r=this.physicsBody.forces,i=this.options.nodeDistance;for(let o=0;o<t.length-1;o++){const s=e[t[o]];for(let a=o+1;a<t.length;a++){const g=e[t[a]];if(s.level===g.level){const A=i+this.overlapAvoidanceFactor*((s.shape.radius||0)/2+(g.shape.radius||0)/2),I=g.x-s.x,C=g.y-s.y,l=Math.sqrt(I*I+C*C),d=.05;let u;l<A?u=-Math.pow(d*l,2)+Math.pow(d*A,2):u=0,l!==0&&(u=u/l);const h=I*u,v=C*u;r[s.id].x-=h,r[s.id].y-=v,r[g.id].x+=h,r[g.id].y+=v}}}}},mf=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e}solve(){let e,t;const r=this.physicsBody.physicsEdgeIndices,i=this.body.edges;let o,s,a;for(let g=0;g<r.length;g++)t=i[r[g]],t.connected===!0&&t.toId!==t.fromId&&this.body.nodes[t.toId]!==void 0&&this.body.nodes[t.fromId]!==void 0&&(t.edgeType.via!==void 0?(e=t.options.length===void 0?this.options.springLength:t.options.length,o=t.to,s=t.edgeType.via,a=t.from,this._calculateSpringForce(o,s,.5*e),this._calculateSpringForce(s,a,.5*e)):(e=t.options.length===void 0?this.options.springLength*1.5:t.options.length,this._calculateSpringForce(t.from,t.to,e)))}_calculateSpringForce(e,t,r){const i=e.x-t.x,o=e.y-t.y,s=Math.max(Math.sqrt(i*i+o*o),.01),a=this.options.springConstant*(r-s)/s,g=i*a,A=o*a;this.physicsBody.forces[e.id]!==void 0&&(this.physicsBody.forces[e.id].x+=g,this.physicsBody.forces[e.id].y+=A),this.physicsBody.forces[t.id]!==void 0&&(this.physicsBody.forces[t.id].x-=g,this.physicsBody.forces[t.id].y-=A)}},sCe=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e}solve(){let e,t,r,i,o,s,a,g;const A=this.body.edges,I=.5,C=this.physicsBody.physicsEdgeIndices,l=this.physicsBody.physicsNodeIndices,d=this.physicsBody.forces;for(let p=0;p<l.length;p++){const y=l[p];d[y].springFx=0,d[y].springFy=0}for(let p=0;p<C.length;p++)t=A[C[p]],t.connected===!0&&(e=t.options.length===void 0?this.options.springLength:t.options.length,r=t.from.x-t.to.x,i=t.from.y-t.to.y,g=Math.sqrt(r*r+i*i),g=g===0?.01:g,a=this.options.springConstant*(e-g)/g,o=r*a,s=i*a,t.to.level!=t.from.level?(d[t.toId]!==void 0&&(d[t.toId].springFx-=o,d[t.toId].springFy-=s),d[t.fromId]!==void 0&&(d[t.fromId].springFx+=o,d[t.fromId].springFy+=s)):(d[t.toId]!==void 0&&(d[t.toId].x-=I*o,d[t.toId].y-=I*s),d[t.fromId]!==void 0&&(d[t.fromId].x+=I*o,d[t.fromId].y+=I*s)));a=1;let u,h;for(let p=0;p<l.length;p++){const y=l[p];u=Math.min(a,Math.max(-a,d[y].springFx)),h=Math.min(a,Math.max(-a,d[y].springFy)),d[y].x+=u,d[y].y+=h}let v=0,f=0;for(let p=0;p<l.length;p++){const y=l[p];v+=d[y].x,f+=d[y].y}const c=v/l.length,b=f/l.length;for(let p=0;p<l.length;p++){const y=l[p];d[y].x-=c,d[y].y-=b}}},OA=class{constructor(e,t,r){this.body=e,this.physicsBody=t,this.setOptions(r)}setOptions(e){this.options=e}solve(){let e,t,r,i;const o=this.body.nodes,s=this.physicsBody.physicsNodeIndices,a=this.physicsBody.forces;for(let g=0;g<s.length;g++){const A=s[g];i=o[A],e=-i.x,t=-i.y,r=Math.sqrt(e*e+t*t),this._calculateForces(r,e,t,a,i)}}_calculateForces(e,t,r,i,o){const s=e===0?0:this.options.centralGravity/e;i[o.id].x=t*s,i[o.id].y=r*s}},aCe=class extends f7{constructor(e,t,r){super(e,t,r),this._rng=yI("FORCE ATLAS 2 BASED REPULSION SOLVER")}_calculateForces(e,t,r,i,o){e===0&&(e=.1*this._rng(),t=e),this.overlapAvoidanceFactor<1&&i.shape.radius&&(e=Math.max(.1+this.overlapAvoidanceFactor*i.shape.radius,e-i.shape.radius));const s=i.edges.length+1,a=this.options.gravitationalConstant*o.mass*i.options.mass*s/Math.pow(e,2),g=t*a,A=r*a;this.physicsBody.forces[i.id].x+=g,this.physicsBody.forces[i.id].y+=A}},gCe=class extends OA{constructor(e,t,r){super(e,t,r)}_calculateForces(e,t,r,i,o){if(e>0){const s=o.edges.length+1,a=this.options.centralGravity*s*o.options.mass;i[o.id].x=t*a,i[o.id].y=r*a}}},ACe=class{constructor(e){this.body=e,this.physicsBody={physicsNodeIndices:[],physicsEdgeIndices:[],forces:{},velocities:{}},this.physicsEnabled=!0,this.simulationInterval=1e3/60,this.requiresTimeout=!0,this.previousStates={},this.referenceState={},this.freezeCache={},this.renderTimer=void 0,this.adaptiveTimestep=!1,this.adaptiveTimestepEnabled=!1,this.adaptiveCounter=0,this.adaptiveInterval=3,this.stabilized=!1,this.startedStabilization=!1,this.stabilizationIterations=0,this.ready=!1,this.options={},this.defaultOptions={enabled:!0,barnesHut:{theta:.5,gravitationalConstant:-2e3,centralGravity:.3,springLength:95,springConstant:.04,damping:.09,avoidOverlap:0},forceAtlas2Based:{theta:.5,gravitationalConstant:-50,centralGravity:.01,springConstant:.08,springLength:100,damping:.4,avoidOverlap:0},repulsion:{centralGravity:.2,springLength:200,springConstant:.05,nodeDistance:100,damping:.09,avoidOverlap:0},hierarchicalRepulsion:{centralGravity:0,springLength:100,springConstant:.01,nodeDistance:120,damping:.09},maxVelocity:50,minVelocity:.75,solver:"barnesHut",stabilization:{enabled:!0,iterations:1e3,updateInterval:50,onlyDynamicEdges:!1,fit:!0},timestep:.5,adaptiveTimestep:!0,wind:{x:0,y:0}},tt(this.options,this.defaultOptions),this.timestep=.5,this.layoutFailed=!1,this.bindEventListeners()}bindEventListeners(){this.body.emitter.on("initPhysics",()=>{this.initPhysics()}),this.body.emitter.on("_layoutFailed",()=>{this.layoutFailed=!0}),this.body.emitter.on("resetPhysics",()=>{this.stopSimulation(),this.ready=!1}),this.body.emitter.on("disablePhysics",()=>{this.physicsEnabled=!1,this.stopSimulation()}),this.body.emitter.on("restorePhysics",()=>{this.setOptions(this.options),this.ready===!0&&this.startSimulation()}),this.body.emitter.on("startSimulation",()=>{this.ready===!0&&this.startSimulation()}),this.body.emitter.on("stopSimulation",()=>{this.stopSimulation()}),this.body.emitter.on("destroy",()=>{this.stopSimulation(!1),this.body.emitter.off()}),this.body.emitter.on("_dataChanged",()=>{this.updatePhysicsData()})}setOptions(e){if(e!==void 0)if(e===!1)this.options.enabled=!1,this.physicsEnabled=!1,this.stopSimulation();else if(e===!0)this.options.enabled=!0,this.physicsEnabled=!0,this.startSimulation();else{this.physicsEnabled=!0,zA(["stabilization"],this.options,e),dr(this.options,e,"stabilization"),e.enabled===void 0&&(this.options.enabled=!0),this.options.enabled===!1&&(this.physicsEnabled=!1,this.stopSimulation());const t=this.options.wind;t&&((typeof t.x!="number"||hO(t.x))&&(t.x=0),(typeof t.y!="number"||hO(t.y))&&(t.y=0)),this.timestep=this.options.timestep}this.init()}init(){let e;this.options.solver==="forceAtlas2Based"?(e=this.options.forceAtlas2Based,this.nodesSolver=new aCe(this.body,this.physicsBody,e),this.edgesSolver=new mf(this.body,this.physicsBody,e),this.gravitySolver=new gCe(this.body,this.physicsBody,e)):this.options.solver==="repulsion"?(e=this.options.repulsion,this.nodesSolver=new nCe(this.body,this.physicsBody,e),this.edgesSolver=new mf(this.body,this.physicsBody,e),this.gravitySolver=new OA(this.body,this.physicsBody,e)):this.options.solver==="hierarchicalRepulsion"?(e=this.options.hierarchicalRepulsion,this.nodesSolver=new oCe(this.body,this.physicsBody,e),this.edgesSolver=new sCe(this.body,this.physicsBody,e),this.gravitySolver=new OA(this.body,this.physicsBody,e)):(e=this.options.barnesHut,this.nodesSolver=new f7(this.body,this.physicsBody,e),this.edgesSolver=new mf(this.body,this.physicsBody,e),this.gravitySolver=new OA(this.body,this.physicsBody,e)),this.modelOptions=e}initPhysics(){this.physicsEnabled===!0&&this.options.enabled===!0?this.options.stabilization.enabled===!0?this.stabilize():(this.stabilized=!1,this.ready=!0,this.body.emitter.emit("fit",{},this.layoutFailed),this.startSimulation()):(this.ready=!0,this.body.emitter.emit("fit"))}startSimulation(){if(this.physicsEnabled===!0&&this.options.enabled===!0){if(this.stabilized=!1,this.adaptiveTimestep=!1,this.body.emitter.emit("_resizeNodes"),this.viewFunction===void 0){var e;this.viewFunction=z(e=this.simulationStep).call(e,this),this.body.emitter.on("initRedraw",this.viewFunction),this.body.emitter.emit("_startRendering")}}else this.body.emitter.emit("_redraw")}stopSimulation(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!0;this.stabilized=!0,e===!0&&this._emitStabilized(),this.viewFunction!==void 0&&(this.body.emitter.off("initRedraw",this.viewFunction),this.viewFunction=void 0,e===!0&&this.body.emitter.emit("_stopRendering"))}simulationStep(){const e=MA();this.physicsTick(),(MA()-e<.4*this.simulationInterval||this.runDoubleSpeed===!0)&&this.stabilized===!1&&(this.physicsTick(),this.runDoubleSpeed=!0),this.stabilized===!0&&this.stopSimulation()}_emitStabilized(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.stabilizationIterations;(this.stabilizationIterations>1||this.startedStabilization===!0)&&ri(()=>{this.body.emitter.emit("stabilized",{iterations:e}),this.startedStabilization=!1,this.stabilizationIterations=0},0)}physicsStep(){this.gravitySolver.solve(),this.nodesSolver.solve(),this.edgesSolver.solve(),this.moveNodes()}adjustTimeStep(){this._evaluateStepQuality()===!0?this.timestep=1.2*this.timestep:this.timestep/1.2<this.options.timestep?this.timestep=this.options.timestep:(this.adaptiveCounter=-1,this.timestep=Math.max(this.options.timestep,this.timestep/1.2))}physicsTick(){this._startStabilizing(),this.stabilized!==!0&&(this.adaptiveTimestep===!0&&this.adaptiveTimestepEnabled===!0?(this.adaptiveCounter%this.adaptiveInterval===0?(this.timestep=2*this.timestep,this.physicsStep(),this.revert(),this.timestep=.5*this.timestep,this.physicsStep(),this.physicsStep(),this.adjustTimeStep()):this.physicsStep(),this.adaptiveCounter+=1):(this.timestep=this.options.timestep,this.physicsStep()),this.stabilized===!0&&this.revert(),this.stabilizationIterations++)}updatePhysicsData(){this.physicsBody.forces={},this.physicsBody.physicsNodeIndices=[],this.physicsBody.physicsEdgeIndices=[];const e=this.body.nodes,t=this.body.edges;for(const r in e)Object.prototype.hasOwnProperty.call(e,r)&&e[r].options.physics===!0&&this.physicsBody.physicsNodeIndices.push(e[r].id);for(const r in t)Object.prototype.hasOwnProperty.call(t,r)&&t[r].options.physics===!0&&this.physicsBody.physicsEdgeIndices.push(t[r].id);for(let r=0;r<this.physicsBody.physicsNodeIndices.length;r++){const i=this.physicsBody.physicsNodeIndices[r];this.physicsBody.forces[i]={x:0,y:0},this.physicsBody.velocities[i]===void 0&&(this.physicsBody.velocities[i]={x:0,y:0})}for(const r in this.physicsBody.velocities)e[r]===void 0&&delete this.physicsBody.velocities[r]}revert(){const e=Be(this.previousStates),t=this.body.nodes,r=this.physicsBody.velocities;this.referenceState={};for(let i=0;i<e.length;i++){const o=e[i];t[o]!==void 0?t[o].options.physics===!0&&(this.referenceState[o]={positions:{x:t[o].x,y:t[o].y}},r[o].x=this.previousStates[o].vx,r[o].y=this.previousStates[o].vy,t[o].x=this.previousStates[o].x,t[o].y=this.previousStates[o].y):delete this.previousStates[o]}}_evaluateStepQuality(){let e,t,r;const i=this.body.nodes,o=this.referenceState,s=.3;for(const a in this.referenceState)if(Object.prototype.hasOwnProperty.call(this.referenceState,a)&&i[a]!==void 0&&(e=i[a].x-o[a].positions.x,t=i[a].y-o[a].positions.y,r=Math.sqrt(Math.pow(e,2)+Math.pow(t,2)),r>s))return!1;return!0}moveNodes(){const e=this.physicsBody.physicsNodeIndices;let t=0,r=0;const i=5;for(let o=0;o<e.length;o++){const s=e[o],a=this._performStep(s);t=Math.max(t,a),r+=a}this.adaptiveTimestepEnabled=r/e.length<i,this.stabilized=t<this.options.minVelocity}calculateComponentVelocity(e,t,r){const i=this.modelOptions.damping*e,o=(t-i)/r;e+=o*this.timestep;const s=this.options.maxVelocity||1e9;return Math.abs(e)>s&&(e=e>0?s:-s),e}_performStep(e){const t=this.body.nodes[e],r=this.physicsBody.forces[e];this.options.wind&&(r.x+=this.options.wind.x,r.y+=this.options.wind.y);const i=this.physicsBody.velocities[e];return this.previousStates[e]={x:t.x,y:t.y,vx:i.x,vy:i.y},t.options.fixed.x===!1?(i.x=this.calculateComponentVelocity(i.x,r.x,t.options.mass),t.x+=i.x*this.timestep):(r.x=0,i.x=0),t.options.fixed.y===!1?(i.y=this.calculateComponentVelocity(i.y,r.y,t.options.mass),t.y+=i.y*this.timestep):(r.y=0,i.y=0),Math.sqrt(Math.pow(i.x,2)+Math.pow(i.y,2))}_freezeNodes(){const e=this.body.nodes;for(const t in e)if(Object.prototype.hasOwnProperty.call(e,t)&&e[t].x&&e[t].y){const r=e[t].options.fixed;this.freezeCache[t]={x:r.x,y:r.y},r.x=!0,r.y=!0}}_restoreFrozenNodes(){const e=this.body.nodes;for(const t in e)Object.prototype.hasOwnProperty.call(e,t)&&this.freezeCache[t]!==void 0&&(e[t].options.fixed.x=this.freezeCache[t].x,e[t].options.fixed.y=this.freezeCache[t].y);this.freezeCache={}}stabilize(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.options.stabilization.iterations;if(typeof e!="number"&&(e=this.options.stabilization.iterations,console.error("The stabilize method needs a numeric amount of iterations. Switching to default: ",e)),this.physicsBody.physicsNodeIndices.length===0){this.ready=!0;return}this.adaptiveTimestep=this.options.adaptiveTimestep,this.body.emitter.emit("_resizeNodes"),this.stopSimulation(),this.stabilized=!1,this.body.emitter.emit("_blockRedraw"),this.targetIterations=e,this.options.stabilization.onlyDynamicEdges===!0&&this._freezeNodes(),this.stabilizationIterations=0,ri(()=>this._stabilizationBatch(),0)}_startStabilizing(){return this.startedStabilization===!0?!1:(this.body.emitter.emit("startStabilizing"),this.startedStabilization=!0,!0)}_stabilizationBatch(){const e=()=>this.stabilized===!1&&this.stabilizationIterations<this.targetIterations,t=()=>{this.body.emitter.emit("stabilizationProgress",{iterations:this.stabilizationIterations,total:this.targetIterations})};this._startStabilizing()&&t();let r=0;for(;e()&&r<this.options.stabilization.updateInterval;)this.physicsTick(),r++;if(t(),e()){var i;ri(z(i=this._stabilizationBatch).call(i,this),0)}else this._finalizeStabilization()}_finalizeStabilization(){this.body.emitter.emit("_allowRedraw"),this.options.stabilization.fit===!0&&this.body.emitter.emit("fit"),this.options.stabilization.onlyDynamicEdges===!0&&this._restoreFrozenNodes(),this.body.emitter.emit("stabilizationIterationsDone"),this.body.emitter.emit("_requestRedraw"),this.stabilized===!0?this._emitStabilized():this.startSimulation(),this.ready=!0}_drawForces(e){for(let t=0;t<this.physicsBody.physicsNodeIndices.length;t++){const r=this.physicsBody.physicsNodeIndices[t],i=this.body.nodes[r],o=this.physicsBody.forces[r],s=20,a=.03,g=Math.sqrt(Math.pow(o.x,2)+Math.pow(o.x,2)),A=Math.min(Math.max(5,g),15),I=3*A,C=lO((180-Math.min(1,Math.max(0,a*g))*180)/360,1,1),l={x:i.x+s*o.x,y:i.y+s*o.y};e.lineWidth=A,e.strokeStyle=C,e.beginPath(),e.moveTo(i.x,i.y),e.lineTo(l.x,l.y),e.stroke();const d=Math.atan2(o.y,o.x);e.fillStyle=C,u7.draw(e,{type:"arrow",point:l,angle:d,length:I}),cg(e).call(e)}}},Lt=class{constructor(){}static getRange(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],r=1e9,i=-1e9,o=1e9,s=-1e9,a;if(t.length>0)for(let g=0;g<t.length;g++)a=e[t[g]],o>a.shape.boundingBox.left&&(o=a.shape.boundingBox.left),s<a.shape.boundingBox.right&&(s=a.shape.boundingBox.right),r>a.shape.boundingBox.top&&(r=a.shape.boundingBox.top),i<a.shape.boundingBox.bottom&&(i=a.shape.boundingBox.bottom);return o===1e9&&s===-1e9&&r===1e9&&i===-1e9&&(r=0,i=0,o=0,s=0),{minX:o,maxX:s,minY:r,maxY:i}}static getRangeCore(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],r=1e9,i=-1e9,o=1e9,s=-1e9,a;if(t.length>0)for(let g=0;g<t.length;g++)a=e[t[g]],o>a.x&&(o=a.x),s<a.x&&(s=a.x),r>a.y&&(r=a.y),i<a.y&&(i=a.y);return o===1e9&&s===-1e9&&r===1e9&&i===-1e9&&(r=0,i=0,o=0,s=0),{minX:o,maxX:s,minY:r,maxY:i}}static findCenter(e){return{x:.5*(e.maxX+e.minX),y:.5*(e.maxY+e.minY)}}static cloneOptions(e,t){const r={};return t===void 0||t==="node"?(Me(r,e.options,!0),r.x=e.x,r.y=e.y,r.amountOfConnections=e.edges.length):Me(r,e.options,!0),r}},ICe=class extends sr{constructor(e,t,r,i,o,s){super(e,t,r,i,o,s),this.isCluster=!0,this.containedNodes={},this.containedEdges={}}_openChildCluster(e){const t=this.body.nodes[e];if(this.containedNodes[e]===void 0)throw new Error("node with id: "+e+" not in current cluster");if(!t.isCluster)throw new Error("node with id: "+e+" is not a cluster");delete this.containedNodes[e],de(t.edges,r=>{delete this.containedEdges[r.id]}),de(t.containedNodes,(r,i)=>{this.containedNodes[i]=r}),t.containedNodes={},de(t.containedEdges,(r,i)=>{this.containedEdges[i]=r}),t.containedEdges={},de(t.edges,r=>{de(this.edges,i=>{var o,s;const a=_e(o=i.clusteringEdgeReplacingIds).call(o,r.id);a!==-1&&(de(r.clusteringEdgeReplacingIds,g=>{i.clusteringEdgeReplacingIds.push(g),this.body.edges[g].edgeReplacedById=i.id}),ti(s=i.clusteringEdgeReplacingIds).call(s,a,1))})}),t.edges=[]}},CCe=class{constructor(e){this.body=e,this.clusteredNodes={},this.clusteredEdges={},this.options={},this.defaultOptions={},tt(this.options,this.defaultOptions),this.body.emitter.on("_resetData",()=>{this.clusteredNodes={},this.clusteredEdges={}})}clusterByHubsize(e,t){e===void 0?e=this._getHubSize():typeof e=="object"&&(t=this._checkOptions(e),e=this._getHubSize());const r=[];for(let i=0;i<this.body.nodeIndices.length;i++){const o=this.body.nodes[this.body.nodeIndices[i]];o.edges.length>=e&&r.push(o.id)}for(let i=0;i<r.length;i++)this.clusterByConnection(r[i],t,!0);this.body.emitter.emit("_dataChanged")}cluster(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;if(e.joinCondition===void 0)throw new Error("Cannot call clusterByNodeData without a joinCondition function in the options.");e=this._checkOptions(e);const r={},i={};de(this.body.nodes,(o,s)=>{o.options&&e.joinCondition(o.options)===!0&&(r[s]=o,de(o.edges,a=>{this.clusteredEdges[a.id]===void 0&&(i[a.id]=a)}))}),this._cluster(r,i,e,t)}clusterByEdgeCount(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0;t=this._checkOptions(t);const i=[],o={};let s,a,g;for(let A=0;A<this.body.nodeIndices.length;A++){const I={},C={},l=this.body.nodeIndices[A],d=this.body.nodes[l];if(o[l]===void 0){g=0,a=[];for(let u=0;u<d.edges.length;u++)s=d.edges[u],this.clusteredEdges[s.id]===void 0&&(s.toId!==s.fromId&&g++,a.push(s));if(g===e){const u=function(v){if(t.joinCondition===void 0||t.joinCondition===null)return!0;const f=Lt.cloneOptions(v);return t.joinCondition(f)};let h=!0;for(let v=0;v<a.length;v++){s=a[v];const f=this._getConnectedId(s,l);if(u(d))C[s.id]=s,I[l]=d,I[f]=this.body.nodes[f],o[l]=!0;else{h=!1;break}}if(Be(I).length>0&&Be(C).length>0&&h===!0){const f=function(){for(let c=0;c<i.length;++c)for(const b in I)if(i[c].nodes[b]!==void 0)return i[c]}();if(f!==void 0){for(const c in I)f.nodes[c]===void 0&&(f.nodes[c]=I[c]);for(const c in C)f.edges[c]===void 0&&(f.edges[c]=C[c])}else i.push({nodes:I,edges:C})}}}}for(let A=0;A<i.length;A++)this._cluster(i[A].nodes,i[A].edges,t,!1);r===!0&&this.body.emitter.emit("_dataChanged")}clusterOutliers(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;this.clusterByEdgeCount(1,e,t)}clusterBridges(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;this.clusterByEdgeCount(2,e,t)}clusterByConnection(e,t){var r;let i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0;if(e===void 0)throw new Error("No nodeId supplied to clusterByConnection!");if(this.body.nodes[e]===void 0)throw new Error("The nodeId given to clusterByConnection does not exist!");const o=this.body.nodes[e];t=this._checkOptions(t,o),t.clusterNodeProperties.x===void 0&&(t.clusterNodeProperties.x=o.x),t.clusterNodeProperties.y===void 0&&(t.clusterNodeProperties.y=o.y),t.clusterNodeProperties.fixed===void 0&&(t.clusterNodeProperties.fixed={},t.clusterNodeProperties.fixed.x=o.options.fixed.x,t.clusterNodeProperties.fixed.y=o.options.fixed.y);const s={},a={},g=o.id,A=Lt.cloneOptions(o);s[g]=o;for(let C=0;C<o.edges.length;C++){const l=o.edges[C];if(this.clusteredEdges[l.id]===void 0){const d=this._getConnectedId(l,g);if(this.clusteredNodes[d]===void 0)if(d!==g)if(t.joinCondition===void 0)a[l.id]=l,s[d]=this.body.nodes[d];else{const u=Lt.cloneOptions(this.body.nodes[d]);t.joinCondition(A,u)===!0&&(a[l.id]=l,s[d]=this.body.nodes[d])}else a[l.id]=l}}const I=Mt(r=Be(s)).call(r,function(C){return s[C].id});for(const C in s){if(!Object.prototype.hasOwnProperty.call(s,C))continue;const l=s[C];for(let d=0;d<l.edges.length;d++){const u=l.edges[d];_e(I).call(I,this._getConnectedId(u,l.id))>-1&&(a[u.id]=u)}}this._cluster(s,a,t,i)}_createClusterEdges(e,t,r,i){let o,s,a,g,A,I;const C=Be(e),l=[];for(let h=0;h<C.length;h++){s=C[h],a=e[s];for(let v=0;v<a.edges.length;v++)o=a.edges[v],this.clusteredEdges[o.id]===void 0&&(o.toId==o.fromId?t[o.id]=o:o.toId==s?(g=r.id,A=o.fromId,I=A):(g=o.toId,A=r.id,I=g),e[I]===void 0&&l.push({edge:o,fromId:A,toId:g}))}const d=[],u=function(h){for(let v=0;v<d.length;v++){const f=d[v],c=h.fromId===f.fromId&&h.toId===f.toId,b=h.fromId===f.toId&&h.toId===f.fromId;if(c||b)return f}return null};for(let h=0;h<l.length;h++){const v=l[h],f=v.edge;let c=u(v);c===null?(c=this._createClusteredEdge(v.fromId,v.toId,f,i),d.push(c)):c.clusteringEdgeReplacingIds.push(f.id),this.body.edges[f.id].edgeReplacedById=c.id,this._backupEdgeOptions(f),f.setOptions({physics:!1})}}_checkOptions(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return e.clusterEdgeProperties===void 0&&(e.clusterEdgeProperties={}),e.clusterNodeProperties===void 0&&(e.clusterNodeProperties={}),e}_cluster(e,t,r){let i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!0;const o=[];for(const I in e)Object.prototype.hasOwnProperty.call(e,I)&&this.clusteredNodes[I]!==void 0&&o.push(I);for(let I=0;I<o.length;++I)delete e[o[I]];if(Be(e).length==0||Be(e).length==1&&r.clusterNodeProperties.allowSingleNodeCluster!=!0)return;let s=Me({},r.clusterNodeProperties);if(r.processProperties!==void 0){const I=[];for(const l in e)if(Object.prototype.hasOwnProperty.call(e,l)){const d=Lt.cloneOptions(e[l]);I.push(d)}const C=[];for(const l in t)if(Object.prototype.hasOwnProperty.call(t,l)&&l.substr(0,12)!=="clusterEdge:"){const d=Lt.cloneOptions(t[l],"edge");C.push(d)}if(s=r.processProperties(s,I,C),!s)throw new Error("The processProperties function does not return properties!")}s.id===void 0&&(s.id="cluster:"+is());const a=s.id;s.label===void 0&&(s.label="cluster");let g;s.x===void 0&&(g=this._getClusterPosition(e),s.x=g.x),s.y===void 0&&(g===void 0&&(g=this._getClusterPosition(e)),s.y=g.y),s.id=a;const A=this.body.functions.createNode(s,ICe);A.containedNodes=e,A.containedEdges=t,A.clusterEdgeProperties=r.clusterEdgeProperties,this.body.nodes[s.id]=A,this._clusterEdges(e,t,s,r.clusterEdgeProperties),s.id=void 0,i===!0&&this.body.emitter.emit("_dataChanged")}_backupEdgeOptions(e){this.clusteredEdges[e.id]===void 0&&(this.clusteredEdges[e.id]={physics:e.options.physics})}_restoreEdge(e){const t=this.clusteredEdges[e.id];t!==void 0&&(e.setOptions({physics:t.physics}),delete this.clusteredEdges[e.id])}isCluster(e){return this.body.nodes[e]!==void 0?this.body.nodes[e].isCluster===!0:(console.error("Node does not exist."),!1)}_getClusterPosition(e){const t=Be(e);let r=e[t[0]].x,i=e[t[0]].x,o=e[t[0]].y,s=e[t[0]].y,a;for(let g=1;g<t.length;g++)a=e[t[g]],r=a.x<r?a.x:r,i=a.x>i?a.x:i,o=a.y<o?a.y:o,s=a.y>s?a.y:s;return{x:.5*(r+i),y:.5*(o+s)}}openCluster(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0;if(e===void 0)throw new Error("No clusterNodeId supplied to openCluster.");const i=this.body.nodes[e];if(i===void 0)throw new Error("The clusterNodeId supplied to openCluster does not exist.");if(i.isCluster!==!0||i.containedNodes===void 0||i.containedEdges===void 0)throw new Error("The node:"+e+" is not a valid cluster.");const o=this.findNode(e),s=_e(o).call(o,e)-1;if(s>=0){const I=o[s];this.body.nodes[I]._openChildCluster(e),delete this.body.nodes[e],r===!0&&this.body.emitter.emit("_dataChanged");return}const a=i.containedNodes,g=i.containedEdges;if(t!==void 0&&t.releaseFunction!==void 0&&typeof t.releaseFunction=="function"){const I={},C={x:i.x,y:i.y};for(const d in a)if(Object.prototype.hasOwnProperty.call(a,d)){const u=this.body.nodes[d];I[d]={x:u.x,y:u.y}}const l=t.releaseFunction(C,I);for(const d in a)if(Object.prototype.hasOwnProperty.call(a,d)){const u=this.body.nodes[d];l[d]!==void 0&&(u.x=l[d].x===void 0?i.x:l[d].x,u.y=l[d].y===void 0?i.y:l[d].y)}}else de(a,function(I){I.options.fixed.x===!1&&(I.x=i.x),I.options.fixed.y===!1&&(I.y=i.y)});for(const I in a)if(Object.prototype.hasOwnProperty.call(a,I)){const C=this.body.nodes[I];C.vx=i.vx,C.vy=i.vy,C.setOptions({physics:!0}),delete this.clusteredNodes[I]}const A=[];for(let I=0;I<i.edges.length;I++)A.push(i.edges[I]);for(let I=0;I<A.length;I++){const C=A[I],l=this._getConnectedId(C,e),d=this.clusteredNodes[l];for(let u=0;u<C.clusteringEdgeReplacingIds.length;u++){const h=C.clusteringEdgeReplacingIds[u],v=this.body.edges[h];if(v!==void 0)if(d!==void 0){const f=this.body.nodes[d.clusterId];f.containedEdges[v.id]=v,delete g[v.id];let c=v.fromId,b=v.toId;v.toId==l?b=d.clusterId:c=d.clusterId,this._createClusteredEdge(c,b,v,f.clusterEdgeProperties,{hidden:!1,physics:!0})}else this._restoreEdge(v)}C.remove()}for(const I in g)Object.prototype.hasOwnProperty.call(g,I)&&this._restoreEdge(g[I]);delete this.body.nodes[e],r===!0&&this.body.emitter.emit("_dataChanged")}getNodesInCluster(e){const t=[];if(this.isCluster(e)===!0){const r=this.body.nodes[e].containedNodes;for(const i in r)Object.prototype.hasOwnProperty.call(r,i)&&t.push(this.body.nodes[i].id)}return t}findNode(e){const t=[];let i=0,o;for(;this.clusteredNodes[e]!==void 0&&i<100;){if(o=this.body.nodes[e],o===void 0)return[];t.push(o.id),e=this.clusteredNodes[e].clusterId,i++}return o=this.body.nodes[e],o===void 0?[]:(t.push(o.id),zn(t).call(t),t)}updateClusteredNode(e,t){if(e===void 0)throw new Error("No clusteredNodeId supplied to updateClusteredNode.");if(t===void 0)throw new Error("No newOptions supplied to updateClusteredNode.");if(this.body.nodes[e]===void 0)throw new Error("The clusteredNodeId supplied to updateClusteredNode does not exist.");this.body.nodes[e].setOptions(t),this.body.emitter.emit("_dataChanged")}updateEdge(e,t){if(e===void 0)throw new Error("No startEdgeId supplied to updateEdge.");if(t===void 0)throw new Error("No newOptions supplied to updateEdge.");if(this.body.edges[e]===void 0)throw new Error("The startEdgeId supplied to updateEdge does not exist.");const r=this.getClusteredEdges(e);for(let i=0;i<r.length;i++)this.body.edges[r[i]].setOptions(t);this.body.emitter.emit("_dataChanged")}getClusteredEdges(e){const t=[];let i=0;for(;e!==void 0&&this.body.edges[e]!==void 0&&i<100;)t.push(this.body.edges[e].id),e=this.body.edges[e].edgeReplacedById,i++;return zn(t).call(t),t}getBaseEdge(e){return this.getBaseEdges(e)[0]}getBaseEdges(e){const t=[e],r=[],i=[],o=100;let s=0;for(;t.length>0&&s<o;){const a=t.pop();if(a===void 0)continue;const g=this.body.edges[a];if(g===void 0)continue;s++;const A=g.clusteringEdgeReplacingIds;if(A===void 0)i.push(a);else for(let I=0;I<A.length;++I){const C=A[I];_e(t).call(t,A)!==-1||_e(r).call(r,A)!==-1||t.push(C)}r.push(a)}return i}_getConnectedId(e,t){return e.toId!=t?e.toId:(e.fromId!=t,e.fromId)}_getHubSize(){let e=0,t=0,r=0,i=0;for(let g=0;g<this.body.nodeIndices.length;g++){const A=this.body.nodes[this.body.nodeIndices[g]];A.edges.length>i&&(i=A.edges.length),e+=A.edges.length,t+=Math.pow(A.edges.length,2),r+=1}e=e/r,t=t/r;const o=t-Math.pow(e,2),s=Math.sqrt(o);let a=Math.floor(e+2*s);return a>i&&(a=i),a}_createClusteredEdge(e,t,r,i,o){const s=Lt.cloneOptions(r,"edge");Me(s,i),s.from=e,s.to=t,s.id="clusterEdge:"+is(),o!==void 0&&Me(s,o);const a=this.body.functions.createEdge(s);return a.clusteringEdgeReplacingIds=[r.id],a.connect(),this.body.edges[a.id]=a,a}_clusterEdges(e,t,r,i){if(t instanceof ns){const o=t,s={};s[o.id]=o,t=s}if(e instanceof sr){const o=e,s={};s[o.id]=o,e=s}if(r==null)throw new Error("_clusterEdges: parameter clusterNode required");i===void 0&&(i=r.clusterEdgeProperties),this._createClusterEdges(e,t,r,i);for(const o in t)if(Object.prototype.hasOwnProperty.call(t,o)&&this.body.edges[o]!==void 0){const s=this.body.edges[o];this._backupEdgeOptions(s),s.setOptions({physics:!1})}for(const o in e)Object.prototype.hasOwnProperty.call(e,o)&&(this.clusteredNodes[o]={clusterId:r.id,node:this.body.nodes[o]},this.body.nodes[o].setOptions({physics:!1}))}_getClusterNodeForNode(e){if(e===void 0)return;const t=this.clusteredNodes[e];if(t===void 0)return;const r=t.clusterId;if(r!==void 0)return this.body.nodes[r]}_filter(e,t){const r=[];return de(e,i=>{t(i)&&r.push(i)}),r}_updateState(){let e;const t=[],r={},i=g=>{de(this.body.nodes,A=>{A.isCluster===!0&&g(A)})};for(e in this.clusteredNodes){if(!Object.prototype.hasOwnProperty.call(this.clusteredNodes,e))continue;this.body.nodes[e]===void 0&&t.push(e)}i(function(g){for(let A=0;A<t.length;A++)delete g.containedNodes[t[A]]});for(let g=0;g<t.length;g++)delete this.clusteredNodes[t[g]];de(this.clusteredEdges,g=>{const A=this.body.edges[g];(A===void 0||!A.endPointsValid())&&(r[g]=g)}),i(function(g){de(g.containedEdges,(A,I)=>{!A.endPointsValid()&&!r[I]&&(r[I]=I)})}),de(this.body.edges,(g,A)=>{let I=!0;const C=g.clusteringEdgeReplacingIds;if(C!==void 0){let l=0;de(C,d=>{const u=this.body.edges[d];u!==void 0&&u.endPointsValid()&&(l+=1)}),I=l>0}(!g.endPointsValid()||!I)&&(r[A]=A)}),i(g=>{de(r,A=>{delete g.containedEdges[A],de(g.edges,(I,C)=>{if(I.id===A){g.edges[C]=null;return}I.clusteringEdgeReplacingIds=this._filter(I.clusteringEdgeReplacingIds,function(l){return!r[l]})}),g.edges=this._filter(g.edges,function(I){return I!==null})})}),de(r,g=>{delete this.clusteredEdges[g]}),de(r,g=>{delete this.body.edges[g]});const o=Be(this.body.edges);de(o,g=>{const A=this.body.edges[g],I=this._isClusteredNode(A.fromId)||this._isClusteredNode(A.toId);if(I!==this._isClusteredEdge(A.id))if(I){const C=this._getClusterNodeForNode(A.fromId);C!==void 0&&this._clusterEdges(this.body.nodes[A.fromId],A,C);const l=this._getClusterNodeForNode(A.toId);l!==void 0&&this._clusterEdges(this.body.nodes[A.toId],A,l)}else delete this._clusterEdges[g],this._restoreEdge(A)});let s=!1,a=!0;for(;a;){const g=[];i(function(A){const I=Be(A.containedNodes).length,C=A.options.allowSingleNodeCluster===!0;(C&&I<1||!C&&I<2)&&g.push(A.id)});for(let A=0;A<g.length;++A)this.openCluster(g[A],{},!1);a=g.length>0,s=s||a}s&&this._updateState()}_isClusteredNode(e){return this.clusteredNodes[e]!==void 0}_isClusteredEdge(e){return this.clusteredEdges[e]!==void 0}},lCe=class{constructor(e,t){this.body=e,this.canvas=t,this.redrawRequested=!1,this.requestAnimationFrameRequestId=void 0,this.renderingActive=!1,this.renderRequests=0,this.allowRedraw=!0,this.dragging=!1,this.zooming=!1,this.options={},this.defaultOptions={hideEdgesOnDrag:!1,hideEdgesOnZoom:!1,hideNodesOnDrag:!1},tt(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){var e;this.body.emitter.on("dragStart",()=>{this.dragging=!0}),this.body.emitter.on("dragEnd",()=>{this.dragging=!1}),this.body.emitter.on("zoom",()=>{this.zooming=!0,window.clearTimeout(this.zoomTimeoutId),this.zoomTimeoutId=ri(()=>{var t;this.zooming=!1,z(t=this._requestRedraw).call(t,this)()},250)}),this.body.emitter.on("_resizeNodes",()=>{this._resizeNodes()}),this.body.emitter.on("_redraw",()=>{this.renderingActive===!1&&this._redraw()}),this.body.emitter.on("_blockRedraw",()=>{this.allowRedraw=!1}),this.body.emitter.on("_allowRedraw",()=>{this.allowRedraw=!0,this.redrawRequested=!1}),this.body.emitter.on("_requestRedraw",z(e=this._requestRedraw).call(e,this)),this.body.emitter.on("_startRendering",()=>{this.renderRequests+=1,this.renderingActive=!0,this._startRendering()}),this.body.emitter.on("_stopRendering",()=>{this.renderRequests-=1,this.renderingActive=this.renderRequests>0,this.requestAnimationFrameRequestId=void 0}),this.body.emitter.on("destroy",()=>{this.renderRequests=0,this.allowRedraw=!1,this.renderingActive=!1,window.cancelAnimationFrame(this.requestAnimationFrameRequestId),this.body.emitter.off()})}setOptions(e){e!==void 0&&zs(["hideEdgesOnDrag","hideEdgesOnZoom","hideNodesOnDrag"],this.options,e)}_startRendering(){if(this.renderingActive===!0&&this.requestAnimationFrameRequestId===void 0){var e;this.requestAnimationFrameRequestId=window.requestAnimationFrame(z(e=this._renderStep).call(e,this),this.simulationInterval)}}_renderStep(){this.renderingActive===!0&&(this.requestAnimationFrameRequestId=void 0,this._startRendering(),this._redraw())}redraw(){this.body.emitter.emit("setSize"),this._redraw()}_requestRedraw(){this.redrawRequested!==!0&&this.renderingActive===!1&&this.allowRedraw===!0&&(this.redrawRequested=!0,window.requestAnimationFrame(()=>{this._redraw(!1)}))}_redraw(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;if(this.allowRedraw===!0){this.body.emitter.emit("initRedraw"),this.redrawRequested=!1;const t={drawExternalLabels:null};(this.canvas.frame.canvas.width===0||this.canvas.frame.canvas.height===0)&&this.canvas.setSize(),this.canvas.setTransform();const r=this.canvas.getContext(),i=this.canvas.frame.canvas.clientWidth,o=this.canvas.frame.canvas.clientHeight;if(r.clearRect(0,0,i,o),this.canvas.frame.clientWidth===0)return;if(r.save(),r.translate(this.body.view.translation.x,this.body.view.translation.y),r.scale(this.body.view.scale,this.body.view.scale),r.beginPath(),this.body.emitter.emit("beforeDrawing",r),r.closePath(),e===!1&&(this.dragging===!1||this.dragging===!0&&this.options.hideEdgesOnDrag===!1)&&(this.zooming===!1||this.zooming===!0&&this.options.hideEdgesOnZoom===!1)&&this._drawEdges(r),this.dragging===!1||this.dragging===!0&&this.options.hideNodesOnDrag===!1){const{drawExternalLabels:s}=this._drawNodes(r,e);t.drawExternalLabels=s}e===!1&&(this.dragging===!1||this.dragging===!0&&this.options.hideEdgesOnDrag===!1)&&(this.zooming===!1||this.zooming===!0&&this.options.hideEdgesOnZoom===!1)&&this._drawArrows(r),t.drawExternalLabels!=null&&t.drawExternalLabels(),e===!1&&this._drawSelectionBox(r),r.beginPath(),this.body.emitter.emit("afterDrawing",r),r.closePath(),r.restore(),e===!0&&r.clearRect(0,0,i,o)}}_resizeNodes(){this.canvas.setTransform();const e=this.canvas.getContext();e.save(),e.translate(this.body.view.translation.x,this.body.view.translation.y),e.scale(this.body.view.scale,this.body.view.scale);const t=this.body.nodes;let r;for(const i in t)Object.prototype.hasOwnProperty.call(t,i)&&(r=t[i],r.resize(e),r.updateBoundingBox(e,r.selected));e.restore()}_drawNodes(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;const r=this.body.nodes,i=this.body.nodeIndices;let o;const s=[],a=[],g=20,A=this.canvas.DOMtoCanvas({x:-g,y:-g}),I=this.canvas.DOMtoCanvas({x:this.canvas.frame.canvas.clientWidth+g,y:this.canvas.frame.canvas.clientHeight+g}),C={top:A.y,left:A.x,bottom:I.y,right:I.x},l=[];for(let v=0;v<i.length;v++)if(o=r[i[v]],o.hover)a.push(i[v]);else if(o.isSelected())s.push(i[v]);else if(t===!0){const f=o.draw(e);f.drawExternalLabel!=null&&l.push(f.drawExternalLabel)}else if(o.isBoundingBoxOverlappingWith(C)===!0){const f=o.draw(e);f.drawExternalLabel!=null&&l.push(f.drawExternalLabel)}else o.updateBoundingBox(e,o.selected);let d;const u=s.length,h=a.length;for(d=0;d<u;d++){o=r[s[d]];const v=o.draw(e);v.drawExternalLabel!=null&&l.push(v.drawExternalLabel)}for(d=0;d<h;d++){o=r[a[d]];const v=o.draw(e);v.drawExternalLabel!=null&&l.push(v.drawExternalLabel)}return{drawExternalLabels:()=>{for(const v of l)v()}}}_drawEdges(e){const t=this.body.edges,r=this.body.edgeIndices;for(let i=0;i<r.length;i++){const o=t[r[i]];o.connected===!0&&o.draw(e)}}_drawArrows(e){const t=this.body.edges,r=this.body.edgeIndices;for(let i=0;i<r.length;i++){const o=t[r[i]];o.connected===!0&&o.drawArrows(e)}}_drawSelectionBox(e){if(this.body.selectionBox.show){e.beginPath();const t=this.body.selectionBox.position.end.x-this.body.selectionBox.position.start.x,r=this.body.selectionBox.position.end.y-this.body.selectionBox.position.start.y;e.rect(this.body.selectionBox.position.start.x,this.body.selectionBox.position.start.y,t,r),e.fillStyle="rgba(151, 194, 252, 0.2)",e.fillRect(this.body.selectionBox.position.start.x,this.body.selectionBox.position.start.y,t,r),e.strokeStyle="rgba(151, 194, 252, 1)",e.stroke()}else e.closePath()}};var yf,Bk;function dCe(){if(Bk)return yf;Bk=1,CQ();var n=Ee();return yf=n.setInterval,yf}var bf,zk;function uCe(){return zk||(zk=1,bf=dCe()),bf}var hCe=uCe(),cCe=ne(hCe);function WA(n,e){e.inputHandler=function(t){t.isFirst&&e(t)},n.on("hammer.input",e.inputHandler)}function p7(n,e){return e.inputHandler=function(t){t.isFinal&&e(t)},n.on("hammer.input",e.inputHandler)}let fCe=class{constructor(e){this.body=e,this.pixelRatio=1,this.cameraState={},this.initialized=!1,this.canvasViewCenter={},this._cleanupCallbacks=[],this.options={},this.defaultOptions={autoResize:!0,height:"100%",width:"100%"},tt(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){var e;this.body.emitter.once("resize",t=>{t.width!==0&&(this.body.view.translation.x=t.width*.5),t.height!==0&&(this.body.view.translation.y=t.height*.5)}),this.body.emitter.on("setSize",z(e=this.setSize).call(e,this)),this.body.emitter.on("destroy",()=>{this.hammerFrame.destroy(),this.hammer.destroy(),this._cleanUp()})}setOptions(e){if(e!==void 0&&zs(["width","height","autoResize"],this.options,e),this._cleanUp(),this.options.autoResize===!0){var t;if(window.ResizeObserver){const i=new ResizeObserver(()=>{this.setSize()===!0&&this.body.emitter.emit("_requestRedraw")}),{frame:o}=this;i.observe(o),this._cleanupCallbacks.push(()=>{i.unobserve(o)})}else{const i=cCe(()=>{this.setSize()===!0&&this.body.emitter.emit("_requestRedraw")},1e3);this._cleanupCallbacks.push(()=>{clearInterval(i)})}const r=z(t=this._onResize).call(t,this);window.addEventListener("resize",r),this._cleanupCallbacks.push(()=>{window.removeEventListener("resize",r)})}}_cleanUp(){var e,t,r;be(e=zn(t=ti(r=this._cleanupCallbacks).call(r,0)).call(t)).call(e,i=>{try{i()}catch(o){console.error(o)}})}_onResize(){this.setSize(),this.body.emitter.emit("_redraw")}_getCameraState(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.pixelRatio;this.initialized===!0&&(this.cameraState.previousWidth=this.frame.canvas.width/e,this.cameraState.previousHeight=this.frame.canvas.height/e,this.cameraState.scale=this.body.view.scale,this.cameraState.position=this.DOMtoCanvas({x:.5*this.frame.canvas.width/e,y:.5*this.frame.canvas.height/e}))}_setCameraState(){if(this.cameraState.scale!==void 0&&this.frame.canvas.clientWidth!==0&&this.frame.canvas.clientHeight!==0&&this.pixelRatio!==0&&this.cameraState.previousWidth>0&&this.cameraState.previousHeight>0){const e=this.frame.canvas.width/this.pixelRatio/this.cameraState.previousWidth,t=this.frame.canvas.height/this.pixelRatio/this.cameraState.previousHeight;let r=this.cameraState.scale;e!=1&&t!=1?r=this.cameraState.scale*.5*(e+t):e!=1?r=this.cameraState.scale*e:t!=1&&(r=this.cameraState.scale*t),this.body.view.scale=r;const i=this.DOMtoCanvas({x:.5*this.frame.canvas.clientWidth,y:.5*this.frame.canvas.clientHeight}),o={x:i.x-this.cameraState.position.x,y:i.y-this.cameraState.position.y};this.body.view.translation.x+=o.x*this.body.view.scale,this.body.view.translation.y+=o.y*this.body.view.scale}}_prepareValue(e){if(typeof e=="number")return e+"px";if(typeof e=="string"){if(_e(e).call(e,"%")!==-1||_e(e).call(e,"px")!==-1)return e;if(_e(e).call(e,"%")===-1)return e+"px"}throw new Error("Could not use the value supplied for width or height:"+e)}_create(){for(;this.body.container.hasChildNodes();)this.body.container.removeChild(this.body.container.firstChild);if(this.frame=document.createElement("div"),this.frame.className="vis-network",this.frame.style.position="relative",this.frame.style.overflow="hidden",this.frame.tabIndex=0,this.frame.canvas=document.createElement("canvas"),this.frame.canvas.style.position="relative",this.frame.appendChild(this.frame.canvas),this.frame.canvas.getContext)this._setPixelRatio(),this.setTransform();else{const e=document.createElement("DIV");e.style.color="red",e.style.fontWeight="bold",e.style.padding="10px",e.innerText="Error: your browser does not support HTML canvas",this.frame.canvas.appendChild(e)}this.body.container.appendChild(this.frame),this.body.view.scale=1,this.body.view.translation={x:.5*this.frame.canvas.clientWidth,y:.5*this.frame.canvas.clientHeight},this._bindHammer()}_bindHammer(){this.hammer!==void 0&&this.hammer.destroy(),this.drag={},this.pinch={},this.hammer=new rs(this.frame.canvas),this.hammer.get("pinch").set({enable:!0}),this.hammer.get("pan").set({threshold:5,direction:rs.DIRECTION_ALL}),WA(this.hammer,e=>{this.body.eventListeners.onTouch(e)}),this.hammer.on("tap",e=>{this.body.eventListeners.onTap(e)}),this.hammer.on("doubletap",e=>{this.body.eventListeners.onDoubleTap(e)}),this.hammer.on("press",e=>{this.body.eventListeners.onHold(e)}),this.hammer.on("panstart",e=>{this.body.eventListeners.onDragStart(e)}),this.hammer.on("panmove",e=>{this.body.eventListeners.onDrag(e)}),this.hammer.on("panend",e=>{this.body.eventListeners.onDragEnd(e)}),this.hammer.on("pinch",e=>{this.body.eventListeners.onPinch(e)}),this.frame.canvas.addEventListener("wheel",e=>{this.body.eventListeners.onMouseWheel(e)}),this.frame.canvas.addEventListener("mousemove",e=>{this.body.eventListeners.onMouseMove(e)}),this.frame.canvas.addEventListener("contextmenu",e=>{this.body.eventListeners.onContext(e)}),this.hammerFrame=new rs(this.frame),p7(this.hammerFrame,e=>{this.body.eventListeners.onRelease(e)})}setSize(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.options.width,t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.options.height;e=this._prepareValue(e),t=this._prepareValue(t);let r=!1;const i=this.frame.canvas.width,o=this.frame.canvas.height,s=this.pixelRatio;if(this._setPixelRatio(),e!=this.options.width||t!=this.options.height||this.frame.style.width!=e||this.frame.style.height!=t)this._getCameraState(s),this.frame.style.width=e,this.frame.style.height=t,this.frame.canvas.style.width="100%",this.frame.canvas.style.height="100%",this.frame.canvas.width=Math.round(this.frame.canvas.clientWidth*this.pixelRatio),this.frame.canvas.height=Math.round(this.frame.canvas.clientHeight*this.pixelRatio),this.options.width=e,this.options.height=t,this.canvasViewCenter={x:.5*this.frame.clientWidth,y:.5*this.frame.clientHeight},r=!0;else{const a=Math.round(this.frame.canvas.clientWidth*this.pixelRatio),g=Math.round(this.frame.canvas.clientHeight*this.pixelRatio);(this.frame.canvas.width!==a||this.frame.canvas.height!==g)&&this._getCameraState(s),this.frame.canvas.width!==a&&(this.frame.canvas.width=a,r=!0),this.frame.canvas.height!==g&&(this.frame.canvas.height=g,r=!0)}return r===!0&&(this.body.emitter.emit("resize",{width:Math.round(this.frame.canvas.width/this.pixelRatio),height:Math.round(this.frame.canvas.height/this.pixelRatio),oldWidth:Math.round(i/this.pixelRatio),oldHeight:Math.round(o/this.pixelRatio)}),this._setCameraState()),this.initialized=!0,r}getContext(){return this.frame.canvas.getContext("2d")}_determinePixelRatio(){const e=this.getContext();if(e===void 0)throw new Error("Could not get canvax context");let t=1;typeof window<"u"&&(t=window.devicePixelRatio||1);const r=e.webkitBackingStorePixelRatio||e.mozBackingStorePixelRatio||e.msBackingStorePixelRatio||e.oBackingStorePixelRatio||e.backingStorePixelRatio||1;return t/r}_setPixelRatio(){this.pixelRatio=this._determinePixelRatio()}setTransform(){const e=this.getContext();if(e===void 0)throw new Error("Could not get canvax context");e.setTransform(this.pixelRatio,0,0,this.pixelRatio,0,0)}_XconvertDOMtoCanvas(e){return(e-this.body.view.translation.x)/this.body.view.scale}_XconvertCanvasToDOM(e){return e*this.body.view.scale+this.body.view.translation.x}_YconvertDOMtoCanvas(e){return(e-this.body.view.translation.y)/this.body.view.scale}_YconvertCanvasToDOM(e){return e*this.body.view.scale+this.body.view.translation.y}canvasToDOM(e){return{x:this._XconvertCanvasToDOM(e.x),y:this._YconvertCanvasToDOM(e.y)}}DOMtoCanvas(e){return{x:this._XconvertDOMtoCanvas(e.x),y:this._YconvertDOMtoCanvas(e.y)}}};function pCe(n,e){const t=tt({nodes:e,minZoomLevel:Number.MIN_VALUE,maxZoomLevel:1},n??{});if(!we(t.nodes))throw new TypeError("Nodes has to be an array of ids.");if(t.nodes.length===0&&(t.nodes=e),!(typeof t.minZoomLevel=="number"&&t.minZoomLevel>0))throw new TypeError("Min zoom level has to be a number higher than zero.");if(!(typeof t.maxZoomLevel=="number"&&t.minZoomLevel<=t.maxZoomLevel))throw new TypeError("Max zoom level has to be a number higher than min zoom level.");return t}let vCe=class{constructor(e,t){var r,i;this.body=e,this.canvas=t,this.animationSpeed=1/this.renderRefreshRate,this.animationEasingFunction="easeInOutQuint",this.easingTime=0,this.sourceScale=0,this.targetScale=0,this.sourceTranslation=0,this.targetTranslation=0,this.lockedOnNodeId=void 0,this.lockedOnNodeOffset=void 0,this.touchTime=0,this.viewFunction=void 0,this.body.emitter.on("fit",z(r=this.fit).call(r,this)),this.body.emitter.on("animationFinished",()=>{this.body.emitter.emit("_stopRendering")}),this.body.emitter.on("unlockNode",z(i=this.releaseNode).call(i,this))}setOptions(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};this.options=e}fit(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;e=pCe(e,this.body.nodeIndices);const r=this.canvas.frame.canvas.clientWidth,i=this.canvas.frame.canvas.clientHeight;let o,s;if(r===0||i===0)s=1,o=Lt.getRange(this.body.nodes,e.nodes);else if(t===!0){let A=0;for(const l in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,l)&&this.body.nodes[l].predefinedPosition===!0&&(A+=1);if(A>.5*this.body.nodeIndices.length){this.fit(e,!1);return}o=Lt.getRange(this.body.nodes,e.nodes),s=12.662/(this.body.nodeIndices.length+7.4147)+.0964822;const C=Math.min(r/600,i/600);s*=C}else{this.body.emitter.emit("_resizeNodes"),o=Lt.getRange(this.body.nodes,e.nodes);const A=Math.abs(o.maxX-o.minX)*1.1,I=Math.abs(o.maxY-o.minY)*1.1,C=r/A,l=i/I;s=C<=l?C:l}s>e.maxZoomLevel?s=e.maxZoomLevel:s<e.minZoomLevel&&(s=e.minZoomLevel);const g={position:Lt.findCenter(o),scale:s,animation:e.animation};this.moveTo(g)}focus(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};if(this.body.nodes[e]!==void 0){const r={x:this.body.nodes[e].x,y:this.body.nodes[e].y};t.position=r,t.lockedOnNode=e,this.moveTo(t)}else console.error("Node: "+e+" cannot be found.")}moveTo(e){if(e===void 0){e={};return}if(e.offset!=null){if(e.offset.x!=null){if(e.offset.x=+e.offset.x,!Nn(e.offset.x))throw new TypeError('The option "offset.x" has to be a finite number.')}else e.offset.x=0;if(e.offset.y!=null){if(e.offset.y=+e.offset.y,!Nn(e.offset.y))throw new TypeError('The option "offset.y" has to be a finite number.')}else e.offset.x=0}else e.offset={x:0,y:0};if(e.position!=null){if(e.position.x!=null){if(e.position.x=+e.position.x,!Nn(e.position.x))throw new TypeError('The option "position.x" has to be a finite number.')}else e.position.x=0;if(e.position.y!=null){if(e.position.y=+e.position.y,!Nn(e.position.y))throw new TypeError('The option "position.y" has to be a finite number.')}else e.position.x=0}else e.position=this.getViewPosition();if(e.scale!=null){if(e.scale=+e.scale,!(e.scale>0))throw new TypeError('The option "scale" has to be a number greater than zero.')}else e.scale=this.body.view.scale;e.animation===void 0&&(e.animation={duration:0}),e.animation===!1&&(e.animation={duration:0}),e.animation===!0&&(e.animation={}),e.animation.duration===void 0&&(e.animation.duration=1e3),e.animation.easingFunction===void 0&&(e.animation.easingFunction="easeInOutQuad"),this.animateView(e)}animateView(e){if(e===void 0)return;this.animationEasingFunction=e.animation.easingFunction,this.releaseNode(),e.locked===!0&&(this.lockedOnNodeId=e.lockedOnNode,this.lockedOnNodeOffset=e.offset),this.easingTime!=0&&this._transitionRedraw(!0),this.sourceScale=this.body.view.scale,this.sourceTranslation=this.body.view.translation,this.targetScale=e.scale,this.body.view.scale=this.targetScale;const t=this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight}),r={x:t.x-e.position.x,y:t.y-e.position.y};if(this.targetTranslation={x:this.sourceTranslation.x+r.x*this.targetScale+e.offset.x,y:this.sourceTranslation.y+r.y*this.targetScale+e.offset.y},e.animation.duration===0)if(this.lockedOnNodeId!=null){var i;this.viewFunction=z(i=this._lockedRedraw).call(i,this),this.body.emitter.on("initRedraw",this.viewFunction)}else this.body.view.scale=this.targetScale,this.body.view.translation=this.targetTranslation,this.body.emitter.emit("_requestRedraw");else{var o;this.animationSpeed=1/(60*e.animation.duration*.001)||1/60,this.animationEasingFunction=e.animation.easingFunction,this.viewFunction=z(o=this._transitionRedraw).call(o,this),this.body.emitter.on("initRedraw",this.viewFunction),this.body.emitter.emit("_startRendering")}}_lockedRedraw(){const e={x:this.body.nodes[this.lockedOnNodeId].x,y:this.body.nodes[this.lockedOnNodeId].y},t=this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight}),r={x:t.x-e.x,y:t.y-e.y},i=this.body.view.translation,o={x:i.x+r.x*this.body.view.scale+this.lockedOnNodeOffset.x,y:i.y+r.y*this.body.view.scale+this.lockedOnNodeOffset.y};this.body.view.translation=o}releaseNode(){this.lockedOnNodeId!==void 0&&this.viewFunction!==void 0&&(this.body.emitter.off("initRedraw",this.viewFunction),this.lockedOnNodeId=void 0,this.lockedOnNodeOffset=void 0)}_transitionRedraw(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;this.easingTime+=this.animationSpeed,this.easingTime=e===!0?1:this.easingTime;const t=yse[this.animationEasingFunction](this.easingTime);if(this.body.view.scale=this.sourceScale+(this.targetScale-this.sourceScale)*t,this.body.view.translation={x:this.sourceTranslation.x+(this.targetTranslation.x-this.sourceTranslation.x)*t,y:this.sourceTranslation.y+(this.targetTranslation.y-this.sourceTranslation.y)*t},this.easingTime>=1){if(this.body.emitter.off("initRedraw",this.viewFunction),this.easingTime=0,this.lockedOnNodeId!=null){var r;this.viewFunction=z(r=this._lockedRedraw).call(r,this),this.body.emitter.on("initRedraw",this.viewFunction)}this.body.emitter.emit("animationFinished")}}getScale(){return this.body.view.scale}getViewPosition(){return this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight})}};function jk(n){var e=n&&n.preventDefault||!1,t=n&&n.container||window,r={},i={keydown:{},keyup:{}},o={},s;for(s=97;s<=122;s++)o[String.fromCharCode(s)]={code:65+(s-97),shift:!1};for(s=65;s<=90;s++)o[String.fromCharCode(s)]={code:s,shift:!0};for(s=0;s<=9;s++)o[""+s]={code:48+s,shift:!1};for(s=1;s<=12;s++)o["F"+s]={code:111+s,shift:!1};for(s=0;s<=9;s++)o["num"+s]={code:96+s,shift:!1};o["num*"]={code:106,shift:!1},o["num+"]={code:107,shift:!1},o["num-"]={code:109,shift:!1},o["num/"]={code:111,shift:!1},o["num."]={code:110,shift:!1},o.left={code:37,shift:!1},o.up={code:38,shift:!1},o.right={code:39,shift:!1},o.down={code:40,shift:!1},o.space={code:32,shift:!1},o.enter={code:13,shift:!1},o.shift={code:16,shift:void 0},o.esc={code:27,shift:!1},o.backspace={code:8,shift:!1},o.tab={code:9,shift:!1},o.ctrl={code:17,shift:!1},o.alt={code:18,shift:!1},o.delete={code:46,shift:!1},o.pageup={code:33,shift:!1},o.pagedown={code:34,shift:!1},o["="]={code:187,shift:!1},o["-"]={code:189,shift:!1},o["]"]={code:221,shift:!1},o["["]={code:219,shift:!1};var a=function(I){A(I,"keydown")},g=function(I){A(I,"keyup")},A=function(I,C){if(i[C][I.keyCode]!==void 0){for(var l=i[C][I.keyCode],d=0;d<l.length;d++)(l[d].shift===void 0||l[d].shift==!0&&I.shiftKey==!0||l[d].shift==!1&&I.shiftKey==!1)&&l[d].fn(I);e==!0&&I.preventDefault()}};return r.bind=function(I,C,l){if(l===void 0&&(l="keydown"),o[I]===void 0)throw new Error("unsupported key: "+I);i[l][o[I].code]===void 0&&(i[l][o[I].code]=[]),i[l][o[I].code].push({fn:C,shift:o[I].shift})},r.bindAll=function(I,C){C===void 0&&(C="keydown");for(var l in o)o.hasOwnProperty(l)&&r.bind(l,I,C)},r.getKey=function(I){for(var C in o)if(o.hasOwnProperty(C)){if(I.shiftKey==!0&&o[C].shift==!0&&I.keyCode==o[C].code)return C;if(I.shiftKey==!1&&o[C].shift==!1&&I.keyCode==o[C].code)return C;if(I.keyCode==o[C].code&&C=="shift")return C}return"unknown key, currently not supported"},r.unbind=function(I,C,l){if(l===void 0&&(l="keydown"),o[I]===void 0)throw new Error("unsupported key: "+I);if(C!==void 0){var d=[],u=i[l][o[I].code];if(u!==void 0)for(var h=0;h<u.length;h++)u[h].fn==C&&u[h].shift==o[I].shift||d.push(i[l][o[I].code][h]);i[l][o[I].code]=d}else i[l][o[I].code]=[]},r.reset=function(){i={keydown:{},keyup:{}}},r.destroy=function(){i={keydown:{},keyup:{}},t.removeEventListener("keydown",a,!0),t.removeEventListener("keyup",g,!0)},t.addEventListener("keydown",a,!0),t.addEventListener("keyup",g,!0),r}let mCe=class{constructor(e,t){this.body=e,this.canvas=t,this.iconsCreated=!1,this.navigationHammers=[],this.boundFunctions={},this.touchTime=0,this.activated=!1,this.body.emitter.on("activate",()=>{this.activated=!0,this.configureKeyboardBindings()}),this.body.emitter.on("deactivate",()=>{this.activated=!1,this.configureKeyboardBindings()}),this.body.emitter.on("destroy",()=>{this.keycharm!==void 0&&this.keycharm.destroy()}),this.options={}}setOptions(e){e!==void 0&&(this.options=e,this.create())}create(){this.options.navigationButtons===!0?this.iconsCreated===!1&&this.loadNavigationElements():this.iconsCreated===!0&&this.cleanNavigation(),this.configureKeyboardBindings()}cleanNavigation(){if(this.navigationHammers.length!=0){for(let e=0;e<this.navigationHammers.length;e++)this.navigationHammers[e].destroy();this.navigationHammers=[]}this.navigationDOM&&this.navigationDOM.wrapper&&this.navigationDOM.wrapper.parentNode&&this.navigationDOM.wrapper.parentNode.removeChild(this.navigationDOM.wrapper),this.iconsCreated=!1}loadNavigationElements(){this.cleanNavigation(),this.navigationDOM={};const e=["up","down","left","right","zoomIn","zoomOut","zoomExtends"],t=["_moveUp","_moveDown","_moveLeft","_moveRight","_zoomIn","_zoomOut","_fit"];this.navigationDOM.wrapper=document.createElement("div"),this.navigationDOM.wrapper.className="vis-navigation",this.canvas.frame.appendChild(this.navigationDOM.wrapper);for(let s=0;s<e.length;s++){this.navigationDOM[e[s]]=document.createElement("div"),this.navigationDOM[e[s]].className="vis-button vis-"+e[s],this.navigationDOM.wrapper.appendChild(this.navigationDOM[e[s]]);const a=new rs(this.navigationDOM[e[s]]);if(t[s]==="_fit"){var r;WA(a,z(r=this._fit).call(r,this))}else{var i;WA(a,z(i=this.bindToRedraw).call(i,this,t[s]))}this.navigationHammers.push(a)}const o=new rs(this.canvas.frame);p7(o,()=>{this._stopMovement()}),this.navigationHammers.push(o),this.iconsCreated=!0}bindToRedraw(e){if(this.boundFunctions[e]===void 0){var t;this.boundFunctions[e]=z(t=this[e]).call(t,this),this.body.emitter.on("initRedraw",this.boundFunctions[e]),this.body.emitter.emit("_startRendering")}}unbindFromRedraw(e){this.boundFunctions[e]!==void 0&&(this.body.emitter.off("initRedraw",this.boundFunctions[e]),this.body.emitter.emit("_stopRendering"),delete this.boundFunctions[e])}_fit(){new Date().valueOf()-this.touchTime>700&&(this.body.emitter.emit("fit",{duration:700}),this.touchTime=new Date().valueOf())}_stopMovement(){for(const e in this.boundFunctions)Object.prototype.hasOwnProperty.call(this.boundFunctions,e)&&(this.body.emitter.off("initRedraw",this.boundFunctions[e]),this.body.emitter.emit("_stopRendering"));this.boundFunctions={}}_moveUp(){this.body.view.translation.y+=this.options.keyboard.speed.y}_moveDown(){this.body.view.translation.y-=this.options.keyboard.speed.y}_moveLeft(){this.body.view.translation.x+=this.options.keyboard.speed.x}_moveRight(){this.body.view.translation.x-=this.options.keyboard.speed.x}_zoomIn(){const e=this.body.view.scale,t=this.body.view.scale*(1+this.options.keyboard.speed.zoom),r=this.body.view.translation,i=t/e,o=(1-i)*this.canvas.canvasViewCenter.x+r.x*i,s=(1-i)*this.canvas.canvasViewCenter.y+r.y*i;this.body.view.scale=t,this.body.view.translation={x:o,y:s},this.body.emitter.emit("zoom",{direction:"+",scale:this.body.view.scale,pointer:null})}_zoomOut(){const e=this.body.view.scale,t=this.body.view.scale/(1+this.options.keyboard.speed.zoom),r=this.body.view.translation,i=t/e,o=(1-i)*this.canvas.canvasViewCenter.x+r.x*i,s=(1-i)*this.canvas.canvasViewCenter.y+r.y*i;this.body.view.scale=t,this.body.view.translation={x:o,y:s},this.body.emitter.emit("zoom",{direction:"-",scale:this.body.view.scale,pointer:null})}configureKeyboardBindings(){if(this.keycharm!==void 0&&this.keycharm.destroy(),this.options.keyboard.enabled===!0&&(this.options.keyboard.bindToWindow===!0?this.keycharm=jk({container:window,preventDefault:!0}):this.keycharm=jk({container:this.canvas.frame,preventDefault:!0}),this.keycharm.reset(),this.activated===!0)){var e,t,r,i,o,s,a,g,A,I,C,l,d,u,h,v,f,c,b,p,y,E,S,m;z(e=this.keycharm).call(e,"up",()=>{this.bindToRedraw("_moveUp")},"keydown"),z(t=this.keycharm).call(t,"down",()=>{this.bindToRedraw("_moveDown")},"keydown"),z(r=this.keycharm).call(r,"left",()=>{this.bindToRedraw("_moveLeft")},"keydown"),z(i=this.keycharm).call(i,"right",()=>{this.bindToRedraw("_moveRight")},"keydown"),z(o=this.keycharm).call(o,"=",()=>{this.bindToRedraw("_zoomIn")},"keydown"),z(s=this.keycharm).call(s,"num+",()=>{this.bindToRedraw("_zoomIn")},"keydown"),z(a=this.keycharm).call(a,"num-",()=>{this.bindToRedraw("_zoomOut")},"keydown"),z(g=this.keycharm).call(g,"-",()=>{this.bindToRedraw("_zoomOut")},"keydown"),z(A=this.keycharm).call(A,"[",()=>{this.bindToRedraw("_zoomOut")},"keydown"),z(I=this.keycharm).call(I,"]",()=>{this.bindToRedraw("_zoomIn")},"keydown"),z(C=this.keycharm).call(C,"pageup",()=>{this.bindToRedraw("_zoomIn")},"keydown"),z(l=this.keycharm).call(l,"pagedown",()=>{this.bindToRedraw("_zoomOut")},"keydown"),z(d=this.keycharm).call(d,"up",()=>{this.unbindFromRedraw("_moveUp")},"keyup"),z(u=this.keycharm).call(u,"down",()=>{this.unbindFromRedraw("_moveDown")},"keyup"),z(h=this.keycharm).call(h,"left",()=>{this.unbindFromRedraw("_moveLeft")},"keyup"),z(v=this.keycharm).call(v,"right",()=>{this.unbindFromRedraw("_moveRight")},"keyup"),z(f=this.keycharm).call(f,"=",()=>{this.unbindFromRedraw("_zoomIn")},"keyup"),z(c=this.keycharm).call(c,"num+",()=>{this.unbindFromRedraw("_zoomIn")},"keyup"),z(b=this.keycharm).call(b,"num-",()=>{this.unbindFromRedraw("_zoomOut")},"keyup"),z(p=this.keycharm).call(p,"-",()=>{this.unbindFromRedraw("_zoomOut")},"keyup"),z(y=this.keycharm).call(y,"[",()=>{this.unbindFromRedraw("_zoomOut")},"keyup"),z(E=this.keycharm).call(E,"]",()=>{this.unbindFromRedraw("_zoomIn")},"keyup"),z(S=this.keycharm).call(S,"pageup",()=>{this.unbindFromRedraw("_zoomIn")},"keyup"),z(m=this.keycharm).call(m,"pagedown",()=>{this.unbindFromRedraw("_zoomOut")},"keyup")}}},yCe=class{constructor(e,t,r){var i,o,s,a,g,A,I,C,l,d,u,h,v;this.body=e,this.canvas=t,this.selectionHandler=r,this.navigationHandler=new mCe(e,t),this.body.eventListeners.onTap=z(i=this.onTap).call(i,this),this.body.eventListeners.onTouch=z(o=this.onTouch).call(o,this),this.body.eventListeners.onDoubleTap=z(s=this.onDoubleTap).call(s,this),this.body.eventListeners.onHold=z(a=this.onHold).call(a,this),this.body.eventListeners.onDragStart=z(g=this.onDragStart).call(g,this),this.body.eventListeners.onDrag=z(A=this.onDrag).call(A,this),this.body.eventListeners.onDragEnd=z(I=this.onDragEnd).call(I,this),this.body.eventListeners.onMouseWheel=z(C=this.onMouseWheel).call(C,this),this.body.eventListeners.onPinch=z(l=this.onPinch).call(l,this),this.body.eventListeners.onMouseMove=z(d=this.onMouseMove).call(d,this),this.body.eventListeners.onRelease=z(u=this.onRelease).call(u,this),this.body.eventListeners.onContext=z(h=this.onContext).call(h,this),this.touchTime=0,this.drag={},this.pinch={},this.popup=void 0,this.popupObj=void 0,this.popupTimer=void 0,this.body.functions.getPointer=z(v=this.getPointer).call(v,this),this.options={},this.defaultOptions={dragNodes:!0,dragView:!0,hover:!1,keyboard:{enabled:!1,speed:{x:10,y:10,zoom:.02},bindToWindow:!0,autoFocus:!0},navigationButtons:!1,tooltipDelay:300,zoomView:!0,zoomSpeed:1},tt(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){this.body.emitter.on("destroy",()=>{clearTimeout(this.popupTimer),delete this.body.functions.getPointer})}setOptions(e){e!==void 0&&(zA(["hideEdgesOnDrag","hideEdgesOnZoom","hideNodesOnDrag","keyboard","multiselect","selectable","selectConnectedEdges"],this.options,e),dr(this.options,e,"keyboard"),e.tooltip&&(tt(this.options.tooltip,e.tooltip),e.tooltip.color&&(this.options.tooltip.color=CO(e.tooltip.color)))),this.navigationHandler.setOptions(this.options)}getPointer(e){return{x:e.x-fse(this.canvas.frame.canvas),y:e.y-pse(this.canvas.frame.canvas)}}onTouch(e){new Date().valueOf()-this.touchTime>50&&(this.drag.pointer=this.getPointer(e.center),this.drag.pinched=!1,this.pinch.scale=this.body.view.scale,this.touchTime=new Date().valueOf())}onTap(e){const t=this.getPointer(e.center),r=this.selectionHandler.options.multiselect&&(e.changedPointers[0].ctrlKey||e.changedPointers[0].metaKey);this.checkSelectionChanges(t,r),this.selectionHandler.commitAndEmit(t,e),this.selectionHandler.generateClickEvent("click",e,t)}onDoubleTap(e){const t=this.getPointer(e.center);this.selectionHandler.generateClickEvent("doubleClick",e,t)}onHold(e){const t=this.getPointer(e.center),r=this.selectionHandler.options.multiselect;this.checkSelectionChanges(t,r),this.selectionHandler.commitAndEmit(t,e),this.selectionHandler.generateClickEvent("click",e,t),this.selectionHandler.generateClickEvent("hold",e,t)}onRelease(e){if(new Date().valueOf()-this.touchTime>10){const t=this.getPointer(e.center);this.selectionHandler.generateClickEvent("release",e,t),this.touchTime=new Date().valueOf()}}onContext(e){const t=this.getPointer({x:e.clientX,y:e.clientY});this.selectionHandler.generateClickEvent("oncontext",e,t)}checkSelectionChanges(e){(arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1)===!0?this.selectionHandler.selectAdditionalOnPoint(e):this.selectionHandler.selectOnPoint(e)}_determineDifference(e,t){const r=function(i,o){const s=[];for(let a=0;a<i.length;a++){const g=i[a];_e(o).call(o,g)===-1&&s.push(g)}return s};return{nodes:r(e.nodes,t.nodes),edges:r(e.edges,t.edges)}}onDragStart(e){if(this.drag.dragging)return;this.drag.pointer===void 0&&this.onTouch(e);const t=this.selectionHandler.getNodeAt(this.drag.pointer);if(this.drag.dragging=!0,this.drag.selection=[],this.drag.translation=tt({},this.body.view.translation),this.drag.nodeId=void 0,e.srcEvent.shiftKey){this.body.selectionBox.show=!0;const r=this.getPointer(e.center);this.body.selectionBox.position.start={x:this.canvas._XconvertDOMtoCanvas(r.x),y:this.canvas._YconvertDOMtoCanvas(r.y)},this.body.selectionBox.position.end={x:this.canvas._XconvertDOMtoCanvas(r.x),y:this.canvas._YconvertDOMtoCanvas(r.y)}}else if(t!==void 0&&this.options.dragNodes===!0){this.drag.nodeId=t.id,t.isSelected()===!1&&this.selectionHandler.setSelection({nodes:[t.id]}),this.selectionHandler.generateClickEvent("dragStart",e,this.drag.pointer);for(const r of this.selectionHandler.getSelectedNodes()){const i={id:r.id,node:r,x:r.x,y:r.y,xFixed:r.options.fixed.x,yFixed:r.options.fixed.y};r.options.fixed.x=!0,r.options.fixed.y=!0,this.drag.selection.push(i)}}else this.selectionHandler.generateClickEvent("dragStart",e,this.drag.pointer,void 0,!0)}onDrag(e){if(this.drag.pinched===!0)return;this.body.emitter.emit("unlockNode");const t=this.getPointer(e.center),r=this.drag.selection;if(r&&r.length&&this.options.dragNodes===!0){this.selectionHandler.generateClickEvent("dragging",e,t);const i=t.x-this.drag.pointer.x,o=t.y-this.drag.pointer.y;be(r).call(r,s=>{const a=s.node;s.xFixed===!1&&(a.x=this.canvas._XconvertDOMtoCanvas(this.canvas._XconvertCanvasToDOM(s.x)+i)),s.yFixed===!1&&(a.y=this.canvas._YconvertDOMtoCanvas(this.canvas._YconvertCanvasToDOM(s.y)+o))}),this.body.emitter.emit("startSimulation")}else{if(e.srcEvent.shiftKey){if(this.selectionHandler.generateClickEvent("dragging",e,t,void 0,!0),this.drag.pointer===void 0){this.onDragStart(e);return}this.body.selectionBox.position.end={x:this.canvas._XconvertDOMtoCanvas(t.x),y:this.canvas._YconvertDOMtoCanvas(t.y)},this.body.emitter.emit("_requestRedraw")}if(this.options.dragView===!0&&!e.srcEvent.shiftKey){if(this.selectionHandler.generateClickEvent("dragging",e,t,void 0,!0),this.drag.pointer===void 0){this.onDragStart(e);return}const i=t.x-this.drag.pointer.x,o=t.y-this.drag.pointer.y;this.body.view.translation={x:this.drag.translation.x+i,y:this.drag.translation.y+o},this.body.emitter.emit("_requestRedraw")}}}onDragEnd(e){if(this.drag.dragging=!1,this.body.selectionBox.show){var t;this.body.selectionBox.show=!1;const r=this.body.selectionBox.position,i={minX:Math.min(r.start.x,r.end.x),minY:Math.min(r.start.y,r.end.y),maxX:Math.max(r.start.x,r.end.x),maxY:Math.max(r.start.y,r.end.y)},o=st(t=this.body.nodeIndices).call(t,a=>{const g=this.body.nodes[a];return g.x>=i.minX&&g.x<=i.maxX&&g.y>=i.minY&&g.y<=i.maxY});be(o).call(o,a=>this.selectionHandler.selectObject(this.body.nodes[a]));const s=this.getPointer(e.center);this.selectionHandler.commitAndEmit(s,e),this.selectionHandler.generateClickEvent("dragEnd",e,this.getPointer(e.center),void 0,!0),this.body.emitter.emit("_requestRedraw")}else{const r=this.drag.selection;r&&r.length?(be(r).call(r,function(i){i.node.options.fixed.x=i.xFixed,i.node.options.fixed.y=i.yFixed}),this.selectionHandler.generateClickEvent("dragEnd",e,this.getPointer(e.center)),this.body.emitter.emit("startSimulation")):(this.selectionHandler.generateClickEvent("dragEnd",e,this.getPointer(e.center),void 0,!0),this.body.emitter.emit("_requestRedraw"))}}onPinch(e){const t=this.getPointer(e.center);this.drag.pinched=!0,this.pinch.scale===void 0&&(this.pinch.scale=1);const r=this.pinch.scale*e.scale;this.zoom(r,t)}zoom(e,t){if(this.options.zoomView===!0){const r=this.body.view.scale;e<1e-5&&(e=1e-5),e>10&&(e=10);let i;this.drag!==void 0&&this.drag.dragging===!0&&(i=this.canvas.DOMtoCanvas(this.drag.pointer));const o=this.body.view.translation,s=e/r,a=(1-s)*t.x+o.x*s,g=(1-s)*t.y+o.y*s;if(this.body.view.scale=e,this.body.view.translation={x:a,y:g},i!=null){const A=this.canvas.canvasToDOM(i);this.drag.pointer.x=A.x,this.drag.pointer.y=A.y}this.body.emitter.emit("_requestRedraw"),r<e?this.body.emitter.emit("zoom",{direction:"+",scale:this.body.view.scale,pointer:t}):this.body.emitter.emit("zoom",{direction:"-",scale:this.body.view.scale,pointer:t})}}onMouseWheel(e){if(this.options.zoomView===!0){if(e.deltaY!==0){let t=this.body.view.scale;t*=1+(e.deltaY<0?1:-1)*(this.options.zoomSpeed*.1);const r=this.getPointer({x:e.clientX,y:e.clientY});this.zoom(t,r)}e.preventDefault()}}onMouseMove(e){const t=this.getPointer({x:e.clientX,y:e.clientY});let r=!1;this.popup!==void 0&&(this.popup.hidden===!1&&this._checkHidePopup(t),this.popup.hidden===!1&&(r=!0,this.popup.setPosition(t.x+3,t.y-5),this.popup.show())),this.options.keyboard.autoFocus&&this.options.keyboard.bindToWindow===!1&&this.options.keyboard.enabled===!0&&this.canvas.frame.focus(),r===!1&&(this.popupTimer!==void 0&&(clearInterval(this.popupTimer),this.popupTimer=void 0),this.drag.dragging||(this.popupTimer=ri(()=>this._checkShowPopup(t),this.options.tooltipDelay))),this.options.hover===!0&&this.selectionHandler.hoverObject(e,t)}_checkShowPopup(e){const t=this.canvas._XconvertDOMtoCanvas(e.x),r=this.canvas._YconvertDOMtoCanvas(e.y),i={left:t,top:r,right:t,bottom:r},o=this.popupObj===void 0?void 0:this.popupObj.id;let s=!1,a="node";if(this.popupObj===void 0){const g=this.body.nodeIndices,A=this.body.nodes;let I;const C=[];for(let l=0;l<g.length;l++)I=A[g[l]],I.isOverlappingWith(i)===!0&&(s=!0,I.getTitle()!==void 0&&C.push(g[l]));C.length>0&&(this.popupObj=A[C[C.length-1]],s=!0)}if(this.popupObj===void 0&&s===!1){const g=this.body.edgeIndices,A=this.body.edges;let I;const C=[];for(let l=0;l<g.length;l++)I=A[g[l]],I.isOverlappingWith(i)===!0&&I.connected===!0&&I.getTitle()!==void 0&&C.push(g[l]);C.length>0&&(this.popupObj=A[C[C.length-1]],a="edge")}this.popupObj!==void 0?this.popupObj.id!==o&&(this.popup===void 0&&(this.popup=new Rse(this.canvas.frame)),this.popup.popupTargetType=a,this.popup.popupTargetId=this.popupObj.id,this.popup.setPosition(e.x+3,e.y-5),this.popup.setText(this.popupObj.getTitle()),this.popup.show(),this.body.emitter.emit("showPopup",this.popupObj.id)):this.popup!==void 0&&(this.popup.hide(),this.body.emitter.emit("hidePopup"))}_checkHidePopup(e){const t=this.selectionHandler._pointerToPositionObject(e);let r=!1;if(this.popup.popupTargetType==="node"){if(this.body.nodes[this.popup.popupTargetId]!==void 0&&(r=this.body.nodes[this.popup.popupTargetId].isOverlappingWith(t),r===!0)){const i=this.selectionHandler.getNodeAt(e);r=i===void 0?!1:i.id===this.popup.popupTargetId}}else this.selectionHandler.getNodeAt(e)===void 0&&this.body.edges[this.popup.popupTargetId]!==void 0&&(r=this.body.edges[this.popup.popupTargetId].isOverlappingWith(t));r===!1&&(this.popupObj=void 0,this.popup.hide(),this.body.emitter.emit("hidePopup"))}};var Lk={},Gk={},wf,Wk;function bCe(){if(Wk)return wf;Wk=1;var n=me(),e=hT(),t=bI().getWeakData,r=dT(),i=Ii(),o=Os(),s=bt(),a=wI(),g=pn(),A=ct(),I=Io(),C=I.set,l=I.getterFor,d=g.find,u=g.findIndex,h=n([].splice),v=0,f=function(p){return p.frozen||(p.frozen=new c)},c=function(){this.entries=[]},b=function(p,y){return d(p.entries,function(E){return E[0]===y})};return c.prototype={get:function(p){var y=b(this,p);if(y)return y[1]},has:function(p){return!!b(this,p)},set:function(p,y){var E=b(this,p);E?E[1]=y:this.entries.push([p,y])},delete:function(p){var y=u(this.entries,function(E){return E[0]===p});return~y&&h(this.entries,y,1),!!~y}},wf={getConstructor:function(p,y,E,S){var m=p(function(R,O){r(R,w),C(R,{type:y,id:v++,frozen:null}),o(O)||a(O,R[S],{that:R,AS_ENTRIES:E})}),w=m.prototype,_=l(y),T=function(R,O,P){var x=_(R),V=t(i(O),!0);return V===!0?f(x).set(O,P):V[x.id]=P,R};return e(w,{delete:function(R){var O=_(this);if(!s(R))return!1;var P=t(R);return P===!0?f(O).delete(R):P&&A(P,O.id)&&delete P[O.id]},has:function(O){var P=_(this);if(!s(O))return!1;var x=t(O);return x===!0?f(P).has(O):x&&A(x,P.id)}}),e(w,E?{get:function(O){var P=_(this);if(s(O)){var x=t(O);if(x===!0)return f(P).get(O);if(x)return x[P.id]}},set:function(O,P){return T(this,O,P)}}:{add:function(O){return T(this,O,!0)}}),m}},wf}var Vk;function wCe(){if(Vk)return Gk;Vk=1;var n=QQ(),e=Le(),t=me(),r=hT(),i=bI(),o=uT(),s=bCe(),a=bt(),g=Io().enforce,A=ce(),I=UX(),C=Object,l=Array.isArray,d=C.isExtensible,u=C.isFrozen,h=C.isSealed,v=C.freeze,f=C.seal,c=!e.ActiveXObject&&"ActiveXObject"in e,b,p=function(R){return function(){return R(this,arguments.length?arguments[0]:void 0)}},y=o("WeakMap",p,s),E=y.prototype,S=t(E.set),m=function(){return n&&A(function(){var R=v([]);return S(new y,R,1),!u(R)})};if(I)if(c){b=s.getConstructor(p,"WeakMap",!0),i.enable();var w=t(E.delete),_=t(E.has),T=t(E.get);r(E,{delete:function(R){if(a(R)&&!d(R)){var O=g(this);return O.frozen||(O.frozen=new b),w(this,R)||O.frozen.delete(R)}return w(this,R)},has:function(O){if(a(O)&&!d(O)){var P=g(this);return P.frozen||(P.frozen=new b),_(this,O)||P.frozen.has(O)}return _(this,O)},get:function(O){if(a(O)&&!d(O)){var P=g(this);return P.frozen||(P.frozen=new b),_(this,O)?T(this,O):P.frozen.get(O)}return T(this,O)},set:function(O,P){if(a(O)&&!d(O)){var x=g(this);x.frozen||(x.frozen=new b),_(this,O)?S(this,O,P):x.frozen.set(O,P)}else S(this,O,P);return this}})}else m()&&r(E,{set:function(O,P){var x;return l(O)&&(u(O)?x=v:h(O)&&(x=f)),S(this,O,P),x&&x(O),this}});return Gk}var Zk;function ECe(){return Zk||(Zk=1,wCe()),Lk}var Ef,Hk;function SCe(){if(Hk)return Ef;Hk=1,$i(),ECe();var n=Ee();return Ef=n.WeakMap,Ef}var Sf,Uk;function _Ce(){if(Uk)return Sf;Uk=1;var n=SCe();return Di(),Sf=n,Sf}var _f,Kk;function OCe(){return Kk||(Kk=1,_f=_Ce()),_f}var TCe=OCe(),Og=ne(TCe);function Na(n,e,t){RCe(n,e),e.set(n,t)}function RCe(n,e){if(e.has(n))throw new TypeError("Cannot initialize the same private elements twice on an object")}function pO(n,e,t){return n.set(v7(n,e),t),t}function De(n,e){return n.get(v7(n,e))}function v7(n,e,t){if(typeof n=="function"?n===e:n.has(e))return arguments.length<3?e:t;throw new TypeError("Private element is not present on this object")}function Yk(n,e){const t=new jr;for(const r of e)n.has(r)||t.add(r);return t}var zo=new Og,Nr=new Og;let Xk=class{constructor(){Na(this,zo,new jr),Na(this,Nr,new jr)}get size(){return De(Nr,this).size}add(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];for(const i of t)De(Nr,this).add(i)}delete(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];for(const i of t)De(Nr,this).delete(i)}clear(){De(Nr,this).clear()}getSelection(){return[...De(Nr,this)]}getChanges(){return{added:[...Yk(De(zo,this),De(Nr,this))],deleted:[...Yk(De(Nr,this),De(zo,this))],previous:[...new jr(De(zo,this))],current:[...new jr(De(Nr,this))]}}commit(){const e=this.getChanges();pO(zo,this,De(Nr,this)),pO(Nr,this,new jr(De(zo,this)));for(const t of e.added)t.select();for(const t of e.deleted)t.unselect();return e}};var Tn=new Og,Rn=new Og,Of=new Og;let PCe=class{constructor(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:()=>{};Na(this,Tn,new Xk),Na(this,Rn,new Xk),Na(this,Of,void 0),pO(Of,this,e)}get sizeNodes(){return De(Tn,this).size}get sizeEdges(){return De(Rn,this).size}getNodes(){return De(Tn,this).getSelection()}getEdges(){return De(Rn,this).getSelection()}addNodes(){De(Tn,this).add(...arguments)}addEdges(){De(Rn,this).add(...arguments)}deleteNodes(e){De(Tn,this).delete(e)}deleteEdges(e){De(Rn,this).delete(e)}clear(){De(Tn,this).clear(),De(Rn,this).clear()}commit(){const e={nodes:De(Tn,this).commit(),edges:De(Rn,this).commit()};for(var t=arguments.length,r=new Array(t),i=0;i<t;i++)r[i]=arguments[i];return De(Of,this).call(this,e,...r),e}},xCe=class{constructor(e,t){this.body=e,this.canvas=t,this._selectionAccumulator=new PCe,this.hoverObj={nodes:{},edges:{}},this.options={},this.defaultOptions={multiselect:!1,selectable:!0,selectConnectedEdges:!0,hoverConnectedEdges:!0},tt(this.options,this.defaultOptions),this.body.emitter.on("_dataChanged",()=>{this.updateSelection()})}setOptions(e){e!==void 0&&zs(["multiselect","hoverConnectedEdges","selectable","selectConnectedEdges"],this.options,e)}selectOnPoint(e){let t=!1;if(this.options.selectable===!0){const r=this.getNodeAt(e)||this.getEdgeAt(e);this.unselectAll(),r!==void 0&&(t=this.selectObject(r)),this.body.emitter.emit("_requestRedraw")}return t}selectAdditionalOnPoint(e){let t=!1;if(this.options.selectable===!0){const r=this.getNodeAt(e)||this.getEdgeAt(e);r!==void 0&&(t=!0,r.isSelected()===!0?this.deselectObject(r):this.selectObject(r),this.body.emitter.emit("_requestRedraw"))}return t}_initBaseEvent(e,t){const r={};return r.pointer={DOM:{x:t.x,y:t.y},canvas:this.canvas.DOMtoCanvas(t)},r.event=e,r}generateClickEvent(e,t,r,i){let o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!1;const s=this._initBaseEvent(t,r);if(o===!0)s.nodes=[],s.edges=[];else{const a=this.getSelection();s.nodes=a.nodes,s.edges=a.edges}i!==void 0&&(s.previousSelection=i),e=="click"&&(s.items=this.getClickedItems(r)),t.controlEdge!==void 0&&(s.controlEdge=t.controlEdge),this.body.emitter.emit(e,s)}selectObject(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.options.selectConnectedEdges;return e!==void 0?(e instanceof sr?(t===!0&&this._selectionAccumulator.addEdges(...e.edges),this._selectionAccumulator.addNodes(e)):this._selectionAccumulator.addEdges(e),!0):!1}deselectObject(e){e.isSelected()===!0&&(e.selected=!1,this._removeFromSelection(e))}_getAllNodesOverlappingWith(e){const t=[],r=this.body.nodes;for(let i=0;i<this.body.nodeIndices.length;i++){const o=this.body.nodeIndices[i];r[o].isOverlappingWith(e)&&t.push(o)}return t}_pointerToPositionObject(e){const t=this.canvas.DOMtoCanvas(e);return{left:t.x-1,top:t.y+1,right:t.x+1,bottom:t.y-1}}getNodeAt(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;const r=this._pointerToPositionObject(e),i=this._getAllNodesOverlappingWith(r);if(i.length>0)return t===!0?this.body.nodes[i[i.length-1]]:i[i.length-1]}_getEdgesOverlappingWith(e,t){const r=this.body.edges;for(let i=0;i<this.body.edgeIndices.length;i++){const o=this.body.edgeIndices[i];r[o].isOverlappingWith(e)&&t.push(o)}}_getAllEdgesOverlappingWith(e){const t=[];return this._getEdgesOverlappingWith(e,t),t}getEdgeAt(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;const r=this.canvas.DOMtoCanvas(e);let i=10,o=null;const s=this.body.edges;for(let a=0;a<this.body.edgeIndices.length;a++){const g=this.body.edgeIndices[a],A=s[g];if(A.connected){const I=A.from.x,C=A.from.y,l=A.to.x,d=A.to.y,u=A.edgeType.getDistanceToEdge(I,C,l,d,r.x,r.y);u<i&&(o=g,i=u)}}if(o!==null)return t===!0?this.body.edges[o]:o}_addToHover(e){e instanceof sr?this.hoverObj.nodes[e.id]=e:this.hoverObj.edges[e.id]=e}_removeFromSelection(e){e instanceof sr?(this._selectionAccumulator.deleteNodes(e),this._selectionAccumulator.deleteEdges(...e.edges)):this._selectionAccumulator.deleteEdges(e)}unselectAll(){this._selectionAccumulator.clear()}getSelectedNodeCount(){return this._selectionAccumulator.sizeNodes}getSelectedEdgeCount(){return this._selectionAccumulator.sizeEdges}_hoverConnectedEdges(e){for(let t=0;t<e.edges.length;t++){const r=e.edges[t];r.hover=!0,this._addToHover(r)}}emitBlurEvent(e,t,r){const i=this._initBaseEvent(e,t);r.hover===!0&&(r.hover=!1,r instanceof sr?(i.node=r.id,this.body.emitter.emit("blurNode",i)):(i.edge=r.id,this.body.emitter.emit("blurEdge",i)))}emitHoverEvent(e,t,r){const i=this._initBaseEvent(e,t);let o=!1;return r.hover===!1&&(r.hover=!0,this._addToHover(r),o=!0,r instanceof sr?(i.node=r.id,this.body.emitter.emit("hoverNode",i)):(i.edge=r.id,this.body.emitter.emit("hoverEdge",i))),o}hoverObject(e,t){let r=this.getNodeAt(t);r===void 0&&(r=this.getEdgeAt(t));let i=!1;for(const o in this.hoverObj.nodes)Object.prototype.hasOwnProperty.call(this.hoverObj.nodes,o)&&(r===void 0||r instanceof sr&&r.id!=o||r instanceof ns)&&(this.emitBlurEvent(e,t,this.hoverObj.nodes[o]),delete this.hoverObj.nodes[o],i=!0);for(const o in this.hoverObj.edges)Object.prototype.hasOwnProperty.call(this.hoverObj.edges,o)&&(i===!0?(this.hoverObj.edges[o].hover=!1,delete this.hoverObj.edges[o]):(r===void 0||r instanceof ns&&r.id!=o||r instanceof sr&&!r.hover)&&(this.emitBlurEvent(e,t,this.hoverObj.edges[o]),delete this.hoverObj.edges[o],i=!0));if(r!==void 0){const o=Be(this.hoverObj.edges).length,s=Be(this.hoverObj.nodes).length,a=r instanceof ns&&o===0&&s===0,g=r instanceof sr&&o===0&&s===0;(i||a||g)&&(i=this.emitHoverEvent(e,t,r)),r instanceof sr&&this.options.hoverConnectedEdges===!0&&this._hoverConnectedEdges(r)}i===!0&&this.body.emitter.emit("_requestRedraw")}commitWithoutEmitting(){this._selectionAccumulator.commit()}commitAndEmit(e,t){let r=!1;const i=this._selectionAccumulator.commit(),o={nodes:i.nodes.previous,edges:i.edges.previous};i.edges.deleted.length>0&&(this.generateClickEvent("deselectEdge",t,e,o),r=!0),i.nodes.deleted.length>0&&(this.generateClickEvent("deselectNode",t,e,o),r=!0),i.nodes.added.length>0&&(this.generateClickEvent("selectNode",t,e),r=!0),i.edges.added.length>0&&(this.generateClickEvent("selectEdge",t,e),r=!0),r===!0&&this.generateClickEvent("select",t,e)}getSelection(){return{nodes:this.getSelectedNodeIds(),edges:this.getSelectedEdgeIds()}}getSelectedNodes(){return this._selectionAccumulator.getNodes()}getSelectedEdges(){return this._selectionAccumulator.getEdges()}getSelectedNodeIds(){var e;return Mt(e=this._selectionAccumulator.getNodes()).call(e,t=>t.id)}getSelectedEdgeIds(){var e;return Mt(e=this._selectionAccumulator.getEdges()).call(e,t=>t.id)}setSelection(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};if(!e||!e.nodes&&!e.edges)throw new TypeError("Selection must be an object with nodes and/or edges properties");if((t.unselectAll||t.unselectAll===void 0)&&this.unselectAll(),e.nodes)for(const r of e.nodes){const i=this.body.nodes[r];if(!i)throw new RangeError('Node with id "'+r+'" not found');this.selectObject(i,t.highlightEdges)}if(e.edges)for(const r of e.edges){const i=this.body.edges[r];if(!i)throw new RangeError('Edge with id "'+r+'" not found');this.selectObject(i)}this.body.emitter.emit("_requestRedraw"),this._selectionAccumulator.commit()}selectNodes(e){let t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!0;if(!e||e.length===void 0)throw"Selection must be an array with ids";this.setSelection({nodes:e},{highlightEdges:t})}selectEdges(e){if(!e||e.length===void 0)throw"Selection must be an array with ids";this.setSelection({edges:e})}updateSelection(){for(const e in this._selectionAccumulator.getNodes())Object.prototype.hasOwnProperty.call(this.body.nodes,e.id)||this._selectionAccumulator.deleteNodes(e);for(const e in this._selectionAccumulator.getEdges())Object.prototype.hasOwnProperty.call(this.body.edges,e.id)||this._selectionAccumulator.deleteEdges(e)}getClickedItems(e){const t=this.canvas.DOMtoCanvas(e),r=[],i=this.body.nodeIndices,o=this.body.nodes;for(let g=i.length-1;g>=0;g--){const I=o[i[g]].getItemsOnPoint(t);r.push.apply(r,I)}const s=this.body.edgeIndices,a=this.body.edges;for(let g=s.length-1;g>=0;g--){const I=a[s[g]].getItemsOnPoint(t);r.push.apply(r,I)}return r}},m7=class{abstract(){throw new Error("Can't instantiate abstract class!")}fake_use(){}curveType(){return this.abstract()}getPosition(e){return this.fake_use(e),this.abstract()}setPosition(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:void 0;this.fake_use(e,t,r),this.abstract()}getTreeSize(e){return this.fake_use(e),this.abstract()}sort(e){this.fake_use(e),this.abstract()}fix(e,t){this.fake_use(e,t),this.abstract()}shift(e,t){this.fake_use(e,t),this.abstract()}},$Ce=class extends m7{constructor(e){super(),this.layout=e}curveType(){return"horizontal"}getPosition(e){return e.x}setPosition(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:void 0;r!==void 0&&this.layout.hierarchical.addToOrdering(e,r),e.x=t}getTreeSize(e){const t=this.layout.hierarchical.getTreeSize(this.layout.body.nodes,e);return{min:t.min_x,max:t.max_x}}sort(e){mi(e).call(e,function(t,r){return t.x-r.x})}fix(e,t){e.y=this.layout.options.hierarchical.levelSeparation*t,e.options.fixed.y=!0}shift(e,t){this.layout.body.nodes[e].x+=t}},DCe=class extends m7{constructor(e){super(),this.layout=e}curveType(){return"vertical"}getPosition(e){return e.y}setPosition(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:void 0;r!==void 0&&this.layout.hierarchical.addToOrdering(e,r),e.y=t}getTreeSize(e){const t=this.layout.hierarchical.getTreeSize(this.layout.body.nodes,e);return{min:t.min_y,max:t.max_y}}sort(e){mi(e).call(e,function(t,r){return t.y-r.y})}fix(e,t){e.x=this.layout.options.hierarchical.levelSeparation*t,e.options.fixed.x=!0}shift(e,t){this.layout.body.nodes[e].y+=t}};var Qk={},Jk;function NCe(){if(Jk)return Qk;Jk=1;var n=ee(),e=pn().every,t=Fs(),r=t("every");return n({target:"Array",proto:!0,forced:!r},{every:function(o){return e(this,o,arguments.length>1?arguments[1]:void 0)}}),Qk}var Tf,eB;function MCe(){if(eB)return Tf;eB=1,NCe();var n=ft();return Tf=n("Array","every"),Tf}var Rf,tB;function qCe(){if(tB)return Rf;tB=1;var n=Je(),e=MCe(),t=Array.prototype;return Rf=function(r){var i=r.every;return r===t||n(t,r)&&i===t.every?e:i},Rf}var Pf,rB;function FCe(){if(rB)return Pf;rB=1;var n=qCe();return Pf=n,Pf}var xf,iB;function kCe(){return iB||(iB=1,xf=FCe()),xf}var BCe=kCe(),y7=ne(BCe);function zCe(n,e){const t=new jr;return be(n).call(n,r=>{var i;be(i=r.edges).call(i,o=>{o.connected&&t.add(o)})}),be(t).call(t,r=>{const i=r.from.id,o=r.to.id;e[i]==null&&(e[i]=0),(e[o]==null||e[i]>=e[o])&&(e[o]=e[i]+1)}),e}function jCe(n){return b7(e=>{var t,r;return y7(t=st(r=e.edges).call(r,i=>n.has(i.toId))).call(t,i=>i.to===e)},(e,t)=>t>e,"from",n)}function LCe(n){return b7(e=>{var t,r;return y7(t=st(r=e.edges).call(r,i=>n.has(i.toId))).call(t,i=>i.from===e)},(e,t)=>t<e,"to",n)}function b7(n,e,t,r){var i;const o=nn(null),s=cT(i=[...LA(r).call(r)]).call(i,(C,l)=>C+1+l.edges.length,0),a=t+"Id",g=t==="to"?1:-1;for(const[C,l]of r){if(!r.has(C)||!n(l))continue;o[C]=0;const d=[l];let u=0,h;for(;h=d.pop();){var A,I;if(!r.has(C))continue;const v=o[h.id]+g;if(be(A=st(I=h.edges).call(I,f=>f.connected&&f.to!==f.from&&f[t]!==h&&r.has(f.toId)&&r.has(f.fromId))).call(A,f=>{const c=f[a],b=o[c];(b==null||e(v,b))&&(o[c]=v,d.push(f[t]))}),u>s)return zCe(r,o);++u}}return o}let GCe=class{constructor(){this.childrenReference={},this.parentReference={},this.trees={},this.distributionOrdering={},this.levels={},this.distributionIndex={},this.isTree=!1,this.treeIndex=-1}addRelation(e,t){this.childrenReference[e]===void 0&&(this.childrenReference[e]=[]),this.childrenReference[e].push(t),this.parentReference[t]===void 0&&(this.parentReference[t]=[]),this.parentReference[t].push(e)}checkIfTree(){for(const e in this.parentReference)if(this.parentReference[e].length>1){this.isTree=!1;return}this.isTree=!0}numTrees(){return this.treeIndex+1}setTreeIndex(e,t){t!==void 0&&this.trees[e.id]===void 0&&(this.trees[e.id]=t,this.treeIndex=Math.max(t,this.treeIndex))}ensureLevel(e){this.levels[e]===void 0&&(this.levels[e]=0)}getMaxLevel(e){const t={},r=i=>{if(t[i]!==void 0)return t[i];let o=this.levels[i];if(this.childrenReference[i]){const s=this.childrenReference[i];if(s.length>0)for(let a=0;a<s.length;a++)o=Math.max(o,r(s[a]))}return t[i]=o,o};return r(e)}levelDownstream(e,t){this.levels[t.id]===void 0&&(this.levels[e.id]===void 0&&(this.levels[e.id]=0),this.levels[t.id]=this.levels[e.id]+1)}setMinLevelToZero(){var e;const t=new bg;let r=0;const i=mi(e=[...new jr(qne(this.levels))]).call(e,(o,s)=>o-s);for(const o of i)t.set(o,r++);for(const o in this.levels)Object.prototype.hasOwnProperty.call(this.levels,o)&&(this.levels[o]=t.get(this.levels[o]))}getTreeSize(e,t){let r=1e9,i=-1e9,o=1e9,s=-1e9;for(const a in this.trees)if(Object.prototype.hasOwnProperty.call(this.trees,a)&&this.trees[a]===t){const g=e[a];r=Math.min(g.x,r),i=Math.max(g.x,i),o=Math.min(g.y,o),s=Math.max(g.y,s)}return{min_x:r,max_x:i,min_y:o,max_y:s}}hasSameParent(e,t){const r=this.parentReference[e.id],i=this.parentReference[t.id];if(r===void 0||i===void 0)return!1;for(let o=0;o<r.length;o++)for(let s=0;s<i.length;s++)if(r[o]==i[s])return!0;return!1}inSameSubNetwork(e,t){return this.trees[e.id]===this.trees[t.id]}getLevels(){return Be(this.distributionOrdering)}addToOrdering(e,t){this.distributionOrdering[t]===void 0&&(this.distributionOrdering[t]=[]);let r=!1;const i=this.distributionOrdering[t];for(const o in i)if(i[o]===e){r=!0;break}r||(this.distributionOrdering[t].push(e),this.distributionIndex[e.id]=this.distributionOrdering[t].length-1)}},WCe=class{constructor(e){this.body=e,this._resetRNG(Math.random()+":"+MA()),this.setPhysics=!1,this.options={},this.optionsBackup={physics:{}},this.defaultOptions={randomSeed:void 0,improvedLayout:!0,clusterThreshold:150,hierarchical:{enabled:!1,levelSeparation:150,nodeSpacing:100,treeSpacing:200,blockShifting:!0,edgeMinimization:!0,parentCentralization:!0,direction:"UD",sortMethod:"hubsize"}},tt(this.options,this.defaultOptions),this.bindEventListeners()}bindEventListeners(){this.body.emitter.on("_dataChanged",()=>{this.setupHierarchicalLayout()}),this.body.emitter.on("_dataLoaded",()=>{this.layoutNetwork()}),this.body.emitter.on("_resetHierarchicalLayout",()=>{this.setupHierarchicalLayout()}),this.body.emitter.on("_adjustEdgesForHierarchicalLayout",()=>{if(this.options.hierarchical.enabled!==!0)return;const e=this.direction.curveType();this.body.emitter.emit("_forceDisableDynamicCurves",e,!1)})}setOptions(e,t){if(e!==void 0){const r=this.options.hierarchical,i=r.enabled;if(zs(["randomSeed","improvedLayout","clusterThreshold"],this.options,e),dr(this.options,e,"hierarchical"),e.randomSeed!==void 0&&this._resetRNG(e.randomSeed),r.enabled===!0)return i===!0&&this.body.emitter.emit("refresh",!0),r.direction==="RL"||r.direction==="DU"?r.levelSeparation>0&&(r.levelSeparation*=-1):r.levelSeparation<0&&(r.levelSeparation*=-1),this.setDirectionStrategy(),this.body.emitter.emit("_resetHierarchicalLayout"),this.adaptAllOptionsForHierarchicalLayout(t);if(i===!0)return this.body.emitter.emit("refresh"),Me(t,this.optionsBackup)}return t}_resetRNG(e){this.initialRandomSeed=e,this._rng=yI(this.initialRandomSeed)}adaptAllOptionsForHierarchicalLayout(e){if(this.options.hierarchical.enabled===!0){const t=this.optionsBackup.physics;e.physics===void 0||e.physics===!0?(e.physics={enabled:t.enabled===void 0?!0:t.enabled,solver:"hierarchicalRepulsion"},t.enabled=t.enabled===void 0?!0:t.enabled,t.solver=t.solver||"barnesHut"):typeof e.physics=="object"?(t.enabled=e.physics.enabled===void 0?!0:e.physics.enabled,t.solver=e.physics.solver||"barnesHut",e.physics.solver="hierarchicalRepulsion"):e.physics!==!1&&(t.solver="barnesHut",e.physics={solver:"hierarchicalRepulsion"});let r=this.direction.curveType();if(e.edges===void 0)this.optionsBackup.edges={smooth:{enabled:!0,type:"dynamic"}},e.edges={smooth:!1};else if(e.edges.smooth===void 0)this.optionsBackup.edges={smooth:{enabled:!0,type:"dynamic"}},e.edges.smooth=!1;else if(typeof e.edges.smooth=="boolean")this.optionsBackup.edges={smooth:e.edges.smooth},e.edges.smooth={enabled:e.edges.smooth,type:r};else{const i=e.edges.smooth;i.type!==void 0&&i.type!=="dynamic"&&(r=i.type),this.optionsBackup.edges={smooth:{enabled:i.enabled===void 0?!0:i.enabled,type:i.type===void 0?"dynamic":i.type,roundness:i.roundness===void 0?.5:i.roundness,forceDirection:i.forceDirection===void 0?!1:i.forceDirection}},e.edges.smooth={enabled:i.enabled===void 0?!0:i.enabled,type:r,roundness:i.roundness===void 0?.5:i.roundness,forceDirection:i.forceDirection===void 0?!1:i.forceDirection}}this.body.emitter.emit("_forceDisableDynamicCurves",r)}return e}positionInitially(e){if(this.options.hierarchical.enabled!==!0){this._resetRNG(this.initialRandomSeed);const t=e.length+50;for(let r=0;r<e.length;r++){const i=e[r],o=2*Math.PI*this._rng();i.x===void 0&&(i.x=t*Math.cos(o)),i.y===void 0&&(i.y=t*Math.sin(o))}}}layoutNetwork(){if(this.options.hierarchical.enabled!==!0&&this.options.improvedLayout===!0){const e=this.body.nodeIndices;let t=0;for(let r=0;r<e.length;r++)this.body.nodes[e[r]].predefinedPosition===!0&&(t+=1);if(t<.5*e.length){let i=0;const o=this.options.clusterThreshold,s={clusterNodeProperties:{shape:"ellipse",label:"",group:"",font:{multi:!1}},clusterEdgeProperties:{label:"",font:{multi:!1},smooth:{enabled:!1}}};if(e.length>o){const g=e.length;for(;e.length>o&&i<=10;){i+=1;const A=e.length;i%3===0?this.body.modules.clustering.clusterBridges(s):this.body.modules.clustering.clusterOutliers(s);const I=e.length;if(A==I&&i%3!==0){this._declusterAll(),this.body.emitter.emit("_layoutFailed"),console.info("This network could not be positioned by this version of the improved layout algorithm. Please disable improvedLayout for better performance.");return}}this.body.modules.kamadaKawai.setOptions({springLength:Math.max(150,2*g)})}i>10&&console.info("The clustering didn't succeed within the amount of interations allowed, progressing with partial result."),this.body.modules.kamadaKawai.solve(e,this.body.edgeIndices,!0),this._shiftToCenter();const a=70;for(let g=0;g<e.length;g++){const A=this.body.nodes[e[g]];A.predefinedPosition===!1&&(A.x+=(.5-this._rng())*a,A.y+=(.5-this._rng())*a)}this._declusterAll(),this.body.emitter.emit("_repositionBezierNodes")}}}_shiftToCenter(){const e=Lt.getRangeCore(this.body.nodes,this.body.nodeIndices),t=Lt.findCenter(e);for(let r=0;r<this.body.nodeIndices.length;r++){const i=this.body.nodes[this.body.nodeIndices[r]];i.x-=t.x,i.y-=t.y}}_declusterAll(){let e=!0;for(;e===!0;){e=!1;for(let t=0;t<this.body.nodeIndices.length;t++)this.body.nodes[this.body.nodeIndices[t]].isCluster===!0&&(e=!0,this.body.modules.clustering.openCluster(this.body.nodeIndices[t],{},!1));e===!0&&this.body.emitter.emit("_dataChanged")}}getSeed(){return this.initialRandomSeed}setupHierarchicalLayout(){if(this.options.hierarchical.enabled===!0&&this.body.nodeIndices.length>0){let e,t,r=!1,i=!1;this.lastNodeOnLevel={},this.hierarchical=new GCe;for(t in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,t)&&(e=this.body.nodes[t],e.options.level!==void 0?(r=!0,this.hierarchical.levels[t]=e.options.level):i=!0);if(i===!0&&r===!0)throw new Error("To use the hierarchical layout, nodes require either no predefined levels or levels have to be defined for all nodes.");{if(i===!0){const s=this.options.hierarchical.sortMethod;s==="hubsize"?this._determineLevelsByHubsize():s==="directed"?this._determineLevelsDirected():s==="custom"&&this._determineLevelsCustomCallback()}for(const s in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,s)&&this.hierarchical.ensureLevel(s);const o=this._getDistribution();this._generateMap(),this._placeNodesByHierarchy(o),this._condenseHierarchy(),this._shiftToCenter()}}}_condenseHierarchy(){var e=this;let t=!1;const r={},i=()=>{const f=s();let c=0;for(let b=0;b<f.length-1;b++){const p=f[b].max-f[b+1].min;c+=p+this.options.hierarchical.treeSpacing,o(b+1,c)}},o=(f,c)=>{const b=this.hierarchical.trees;for(const p in b)Object.prototype.hasOwnProperty.call(b,p)&&b[p]===f&&this.direction.shift(p,c)},s=()=>{const f=[];for(let c=0;c<this.hierarchical.numTrees();c++)f.push(this.direction.getTreeSize(c));return f},a=(f,c)=>{if(!c[f.id]&&(c[f.id]=!0,this.hierarchical.childrenReference[f.id])){const b=this.hierarchical.childrenReference[f.id];if(b.length>0)for(let p=0;p<b.length;p++)a(this.body.nodes[b[p]],c)}},g=function(f){let c=arguments.length>1&&arguments[1]!==void 0?arguments[1]:1e9,b=1e9,p=1e9,y=1e9,E=-1e9;for(const S in f)if(Object.prototype.hasOwnProperty.call(f,S)){const m=e.body.nodes[S],w=e.hierarchical.levels[m.id],_=e.direction.getPosition(m),[T,R]=e._getSpaceAroundNode(m,f);b=Math.min(T,b),p=Math.min(R,p),w<=c&&(y=Math.min(_,y),E=Math.max(_,E))}return[y,E,b,p]},A=(f,c)=>{const b=this.hierarchical.getMaxLevel(f.id),p=this.hierarchical.getMaxLevel(c.id);return Math.min(b,p)},I=(f,c,b)=>{const p=this.hierarchical;for(let y=0;y<c.length;y++){const E=c[y],S=p.distributionOrdering[E];if(S.length>1)for(let m=0;m<S.length-1;m++){const w=S[m],_=S[m+1];p.hasSameParent(w,_)&&p.inSameSubNetwork(w,_)&&f(w,_,b)}}},C=function(f,c){let b=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;const p=e.direction.getPosition(f),y=e.direction.getPosition(c),E=Math.abs(y-p),S=e.options.hierarchical.nodeSpacing;if(E>S){const m={},w={};a(f,m),a(c,w);const _=A(f,c),T=g(m,_),R=g(w,_),O=T[1],P=R[0],x=R[2];if(Math.abs(O-P)>S){let M=O-P+S;M<-x+S&&(M=-x+S),M<0&&(e._shiftBlock(c.id,M),t=!0,b===!0&&e._centerParent(c))}}},l=(f,c)=>{const b=c.id,p=c.edges,y=this.hierarchical.levels[c.id],E=this.options.hierarchical.levelSeparation*this.options.hierarchical.levelSeparation,S={},m=[];for(let x=0;x<p.length;x++){const V=p[x];if(V.toId!=V.fromId){const M=V.toId==b?V.from:V.to;S[p[x].id]=M,this.hierarchical.levels[M.id]<y&&m.push(V)}}const w=(x,V)=>{let M=0;for(let U=0;U<V.length;U++)if(S[V[U].id]!==void 0){const K=this.direction.getPosition(S[V[U].id])-x;M+=K/Math.sqrt(K*K+E)}return M},_=(x,V)=>{let M=0;for(let U=0;U<V.length;U++)if(S[V[U].id]!==void 0){const K=this.direction.getPosition(S[V[U].id])-x;M-=E*Math.pow(K*K+E,-1.5)}return M},T=(x,V)=>{let M=this.direction.getPosition(c);const U={};for(let K=0;K<x;K++){const oe=w(M,V),L=_(M,V),ae=40,he=Math.max(-ae,Math.min(ae,Math.round(oe/L)));if(M=M-he,U[M]!==void 0)break;U[M]=K}return M},R=x=>{const V=this.direction.getPosition(c);if(r[c.id]===void 0){const ae={};a(c,ae),r[c.id]=ae}const M=g(r[c.id]),U=M[2],K=M[3],oe=x-V;let L=0;oe>0?L=Math.min(oe,K-this.options.hierarchical.nodeSpacing):oe<0&&(L=-Math.min(-oe,U-this.options.hierarchical.nodeSpacing)),L!=0&&(this._shiftBlock(c.id,L),t=!0)},O=x=>{const V=this.direction.getPosition(c),[M,U]=this._getSpaceAroundNode(c),K=x-V;let oe=V;K>0?oe=Math.min(V+(U-this.options.hierarchical.nodeSpacing),x):K<0&&(oe=Math.max(V-(M-this.options.hierarchical.nodeSpacing),x)),oe!==V&&(this.direction.setPosition(c,oe),t=!0)};let P=T(f,m);R(P),P=T(f,p),O(P)},d=f=>{let c=this.hierarchical.getLevels();c=zn(c).call(c);for(let b=0;b<f;b++){t=!1;for(let p=0;p<c.length;p++){const y=c[p],E=this.hierarchical.distributionOrdering[y];for(let S=0;S<E.length;S++)l(1e3,E[S])}if(t!==!0)break}},u=f=>{let c=this.hierarchical.getLevels();c=zn(c).call(c);for(let b=0;b<f&&(t=!1,I(C,c,!0),t===!0);b++);},h=()=>{for(const f in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,f)&&this._centerParent(this.body.nodes[f])},v=()=>{let f=this.hierarchical.getLevels();f=zn(f).call(f);for(let c=0;c<f.length;c++){const b=f[c],p=this.hierarchical.distributionOrdering[b];for(let y=0;y<p.length;y++)this._centerParent(p[y])}};this.options.hierarchical.blockShifting===!0&&(u(5),h()),this.options.hierarchical.edgeMinimization===!0&&d(20),this.options.hierarchical.parentCentralization===!0&&v(),i()}_getSpaceAroundNode(e,t){let r=!0;t===void 0&&(r=!1);const i=this.hierarchical.levels[e.id];if(i!==void 0){const o=this.hierarchical.distributionIndex[e.id],s=this.direction.getPosition(e),a=this.hierarchical.distributionOrdering[i];let g=1e9,A=1e9;if(o!==0){const I=a[o-1];if(r===!0&&t[I.id]===void 0||r===!1){const C=this.direction.getPosition(I);g=s-C}}if(o!=a.length-1){const I=a[o+1];if(r===!0&&t[I.id]===void 0||r===!1){const C=this.direction.getPosition(I);A=Math.min(A,C-s)}}return[g,A]}else return[0,0]}_centerParent(e){if(this.hierarchical.parentReference[e.id]){const t=this.hierarchical.parentReference[e.id];for(let r=0;r<t.length;r++){const i=t[r],o=this.body.nodes[i],s=this.hierarchical.childrenReference[i];if(s!==void 0){const a=this._getCenterPosition(s),g=this.direction.getPosition(o),[A,I]=this._getSpaceAroundNode(o),C=g-a;(C<0&&Math.abs(C)<I-this.options.hierarchical.nodeSpacing||C>0&&Math.abs(C)<A-this.options.hierarchical.nodeSpacing)&&this.direction.setPosition(o,a)}}}}_placeNodesByHierarchy(e){this.positionedNodes={};for(const r in e)if(Object.prototype.hasOwnProperty.call(e,r)){var t;let i=Be(e[r]);i=this._indexArrayToNodes(i),mi(t=this.direction).call(t,i);let o=0;for(let s=0;s<i.length;s++){const a=i[s];if(this.positionedNodes[a.id]===void 0){const g=this.options.hierarchical.nodeSpacing;let A=g*o;o>0&&(A=this.direction.getPosition(i[s-1])+g),this.direction.setPosition(a,A,r),this._validatePositionAndContinue(a,r,A),o++}}}}_placeBranchNodes(e,t){var r;const i=this.hierarchical.childrenReference[e];if(i===void 0)return;const o=[];for(let a=0;a<i.length;a++)o.push(this.body.nodes[i[a]]);mi(r=this.direction).call(r,o);for(let a=0;a<o.length;a++){const g=o[a],A=this.hierarchical.levels[g.id];if(A>t&&this.positionedNodes[g.id]===void 0){const I=this.options.hierarchical.nodeSpacing;let C;a===0?C=this.direction.getPosition(this.body.nodes[e]):C=this.direction.getPosition(o[a-1])+I,this.direction.setPosition(g,C,A),this._validatePositionAndContinue(g,A,C)}else return}const s=this._getCenterPosition(o);this.direction.setPosition(this.body.nodes[e],s,t)}_validatePositionAndContinue(e,t,r){if(this.hierarchical.isTree){if(this.lastNodeOnLevel[t]!==void 0){const i=this.direction.getPosition(this.body.nodes[this.lastNodeOnLevel[t]]);if(r-i<this.options.hierarchical.nodeSpacing){const o=i+this.options.hierarchical.nodeSpacing-r,s=this._findCommonParent(this.lastNodeOnLevel[t],e.id);this._shiftBlock(s.withChild,o)}}this.lastNodeOnLevel[t]=e.id,this.positionedNodes[e.id]=!0,this._placeBranchNodes(e.id,t)}}_indexArrayToNodes(e){const t=[];for(let r=0;r<e.length;r++)t.push(this.body.nodes[e[r]]);return t}_getDistribution(){const e={};let t,r;for(t in this.body.nodes)if(Object.prototype.hasOwnProperty.call(this.body.nodes,t)){r=this.body.nodes[t];const i=this.hierarchical.levels[t]===void 0?0:this.hierarchical.levels[t];this.direction.fix(r,i),e[i]===void 0&&(e[i]={}),e[i][t]=r}return e}_getActiveEdges(e){const t=[];return de(e.edges,r=>{var i;_e(i=this.body.edgeIndices).call(i,r.id)!==-1&&t.push(r)}),t}_getHubSizes(){const e={},t=this.body.nodeIndices;de(t,i=>{const o=this.body.nodes[i],s=this._getActiveEdges(o).length;e[s]=!0});const r=[];return de(e,i=>{r.push(Number(i))}),mi(r).call(r,function(i,o){return o-i}),r}_determineLevelsByHubsize(){const e=(r,i)=>{this.hierarchical.levelDownstream(r,i)},t=this._getHubSizes();for(let r=0;r<t.length;++r){const i=t[r];if(i===0)break;de(this.body.nodeIndices,o=>{const s=this.body.nodes[o];i===this._getActiveEdges(s).length&&this._crawlNetwork(e,o)})}}_determineLevelsCustomCallback(){const t=function(i,o,s){},r=(i,o,s)=>{let a=this.hierarchical.levels[i.id];a===void 0&&(a=this.hierarchical.levels[i.id]=1e5);const g=t(Lt.cloneOptions(i,"node"),Lt.cloneOptions(o,"node"),Lt.cloneOptions(s,"edge"));this.hierarchical.levels[o.id]=a+g};this._crawlNetwork(r),this.hierarchical.setMinLevelToZero()}_determineLevelsDirected(){var e;const t=cT(e=this.body.nodeIndices).call(e,(r,i)=>(r.set(i,this.body.nodes[i]),r),new bg);this.options.hierarchical.shakeTowards==="roots"?this.hierarchical.levels=LCe(t):this.hierarchical.levels=jCe(t),this.hierarchical.setMinLevelToZero()}_generateMap(){const e=(t,r)=>{this.hierarchical.levels[r.id]>this.hierarchical.levels[t.id]&&this.hierarchical.addRelation(t.id,r.id)};this._crawlNetwork(e),this.hierarchical.checkIfTree()}_crawlNetwork(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:function(){},t=arguments.length>1?arguments[1]:void 0;const r={},i=(o,s)=>{if(r[o.id]===void 0){this.hierarchical.setTreeIndex(o,s),r[o.id]=!0;let a;const g=this._getActiveEdges(o);for(let A=0;A<g.length;A++){const I=g[A];I.connected===!0&&(I.toId==o.id?a=I.from:a=I.to,o.id!=a.id&&(e(o,a,I),i(a,s)))}}};if(t===void 0){let o=0;for(let s=0;s<this.body.nodeIndices.length;s++){const a=this.body.nodeIndices[s];if(r[a]===void 0){const g=this.body.nodes[a];i(g,o),o+=1}}}else{const o=this.body.nodes[t];if(o===void 0){console.error("Node not found:",t);return}i(o)}}_shiftBlock(e,t){const r={},i=o=>{if(r[o])return;r[o]=!0,this.direction.shift(o,t);const s=this.hierarchical.childrenReference[o];if(s!==void 0)for(let a=0;a<s.length;a++)i(s[a])};i(e)}_findCommonParent(e,t){const r={},i=(s,a)=>{const g=this.hierarchical.parentReference[a];if(g!==void 0)for(let A=0;A<g.length;A++){const I=g[A];s[I]=!0,i(s,I)}},o=(s,a)=>{const g=this.hierarchical.parentReference[a];if(g!==void 0)for(let A=0;A<g.length;A++){const I=g[A];if(s[I]!==void 0)return{foundParent:I,withChild:a};const C=o(s,I);if(C.foundParent!==null)return C}return{foundParent:null,withChild:a}};return i(r,e),o(r,t)}setDirectionStrategy(){this.options.hierarchical.direction==="UD"||this.options.hierarchical.direction==="DU"?this.direction=new $Ce(this):this.direction=new DCe(this)}_getCenterPosition(e){let t=1e9,r=-1e9;for(let i=0;i<e.length;i++){let o;if(e[i].id!==void 0)o=e[i];else{const a=e[i];o=this.body.nodes[a]}const s=this.direction.getPosition(o);t=Math.min(t,s),r=Math.max(r,s)}return .5*(t+r)}},VCe=class{constructor(e,t,r,i){var o,s;this.body=e,this.canvas=t,this.selectionHandler=r,this.interactionHandler=i,this.editMode=!1,this.manipulationDiv=void 0,this.editModeDiv=void 0,this.closeDiv=void 0,this._domEventListenerCleanupQueue=[],this.temporaryUIFunctions={},this.temporaryEventFunctions=[],this.touchTime=0,this.temporaryIds={nodes:[],edges:[]},this.guiEnabled=!1,this.inMode=!1,this.selectedControlNode=void 0,this.options={},this.defaultOptions={enabled:!1,initiallyActive:!1,addNode:!0,addEdge:!0,editNode:void 0,editEdge:!0,deleteNode:!0,deleteEdge:!0,controlNodeStyle:{shape:"dot",size:6,color:{background:"#ff0000",border:"#3c3c3c",highlight:{background:"#07f968",border:"#3c3c3c"}},borderWidth:2,borderWidthSelected:2}},tt(this.options,this.defaultOptions),this.body.emitter.on("destroy",()=>{this._clean()}),this.body.emitter.on("_dataChanged",z(o=this._restore).call(o,this)),this.body.emitter.on("_resetData",z(s=this._restore).call(s,this))}_restore(){this.inMode!==!1&&(this.options.initiallyActive===!0?this.enableEditMode():this.disableEditMode())}setOptions(e,t,r){t!==void 0&&(t.locale!==void 0?this.options.locale=t.locale:this.options.locale=r.locale,t.locales!==void 0?this.options.locales=t.locales:this.options.locales=r.locales),e!==void 0&&(typeof e=="boolean"?this.options.enabled=e:(this.options.enabled=!0,Me(this.options,e)),this.options.initiallyActive===!0&&(this.editMode=!0),this._setup())}toggleEditMode(){this.editMode===!0?this.disableEditMode():this.enableEditMode()}enableEditMode(){this.editMode=!0,this._clean(),this.guiEnabled===!0&&(this.manipulationDiv.style.display="block",this.closeDiv.style.display="block",this.editModeDiv.style.display="none",this.showManipulatorToolbar())}disableEditMode(){this.editMode=!1,this._clean(),this.guiEnabled===!0&&(this.manipulationDiv.style.display="none",this.closeDiv.style.display="none",this.editModeDiv.style.display="block",this._createEditButton())}showManipulatorToolbar(){if(this._clean(),this.manipulationDOM={},this.guiEnabled===!0){var e,t;this.editMode=!0,this.manipulationDiv.style.display="block",this.closeDiv.style.display="block";const r=this.selectionHandler.getSelectedNodeCount(),i=this.selectionHandler.getSelectedEdgeCount(),o=r+i,s=this.options.locales[this.options.locale];let a=!1;this.options.addNode!==!1&&(this._createAddNodeButton(s),a=!0),this.options.addEdge!==!1&&(a===!0?this._createSeperator(1):a=!0,this._createAddEdgeButton(s)),r===1&&typeof this.options.editNode=="function"?(a===!0?this._createSeperator(2):a=!0,this._createEditNodeButton(s)):i===1&&r===0&&this.options.editEdge!==!1&&(a===!0?this._createSeperator(3):a=!0,this._createEditEdgeButton(s)),o!==0&&(r>0&&this.options.deleteNode!==!1?(a===!0&&this._createSeperator(4),this._createDeleteButton(s)):r===0&&this.options.deleteEdge!==!1&&(a===!0&&this._createSeperator(4),this._createDeleteButton(s))),this._bindElementEvents(this.closeDiv,z(e=this.toggleEditMode).call(e,this)),this._temporaryBindEvent("select",z(t=this.showManipulatorToolbar).call(t,this))}this.body.emitter.emit("_redraw")}addNodeMode(){var e;if(this.editMode!==!0&&this.enableEditMode(),this._clean(),this.inMode="addNode",this.guiEnabled===!0){var t;const r=this.options.locales[this.options.locale];this.manipulationDOM={},this._createBackButton(r),this._createSeperator(),this._createDescription(r.addDescription||this.options.locales.en.addDescription),this._bindElementEvents(this.closeDiv,z(t=this.toggleEditMode).call(t,this))}this._temporaryBindEvent("click",z(e=this._performAddNode).call(e,this))}editNode(){this.editMode!==!0&&this.enableEditMode(),this._clean();const e=this.selectionHandler.getSelectedNodes()[0];if(e!==void 0)if(this.inMode="editNode",typeof this.options.editNode=="function")if(e.isCluster!==!0){const t=Me({},e.options,!1);if(t.x=e.x,t.y=e.y,this.options.editNode.length===2)this.options.editNode(t,r=>{r!=null&&this.inMode==="editNode"&&this.body.data.nodes.getDataSet().update(r),this.showManipulatorToolbar()});else throw new Error("The function for edit does not support two arguments (data, callback)")}else alert(this.options.locales[this.options.locale].editClusterError||this.options.locales.en.editClusterError);else throw new Error("No function has been configured to handle the editing of nodes.");else this.showManipulatorToolbar()}addEdgeMode(){var e,t,r,i,o;if(this.editMode!==!0&&this.enableEditMode(),this._clean(),this.inMode="addEdge",this.guiEnabled===!0){var s;const a=this.options.locales[this.options.locale];this.manipulationDOM={},this._createBackButton(a),this._createSeperator(),this._createDescription(a.edgeDescription||this.options.locales.en.edgeDescription),this._bindElementEvents(this.closeDiv,z(s=this.toggleEditMode).call(s,this))}this._temporaryBindUI("onTouch",z(e=this._handleConnect).call(e,this)),this._temporaryBindUI("onDragEnd",z(t=this._finishConnect).call(t,this)),this._temporaryBindUI("onDrag",z(r=this._dragControlNode).call(r,this)),this._temporaryBindUI("onRelease",z(i=this._finishConnect).call(i,this)),this._temporaryBindUI("onDragStart",z(o=this._dragStartEdge).call(o,this)),this._temporaryBindUI("onHold",()=>{})}editEdgeMode(){if(this.editMode!==!0&&this.enableEditMode(),this._clean(),this.inMode="editEdge",typeof this.options.editEdge=="object"&&typeof this.options.editEdge.editWithoutDrag=="function"&&(this.edgeBeingEditedId=this.selectionHandler.getSelectedEdgeIds()[0],this.edgeBeingEditedId!==void 0)){const s=this.body.edges[this.edgeBeingEditedId];this._performEditEdge(s.from.id,s.to.id);return}if(this.guiEnabled===!0){var e;const s=this.options.locales[this.options.locale];this.manipulationDOM={},this._createBackButton(s),this._createSeperator(),this._createDescription(s.editEdgeDescription||this.options.locales.en.editEdgeDescription),this._bindElementEvents(this.closeDiv,z(e=this.toggleEditMode).call(e,this))}if(this.edgeBeingEditedId=this.selectionHandler.getSelectedEdgeIds()[0],this.edgeBeingEditedId!==void 0){var t,r,i,o;const s=this.body.edges[this.edgeBeingEditedId],a=this._getNewTargetNode(s.from.x,s.from.y),g=this._getNewTargetNode(s.to.x,s.to.y);this.temporaryIds.nodes.push(a.id),this.temporaryIds.nodes.push(g.id),this.body.nodes[a.id]=a,this.body.nodeIndices.push(a.id),this.body.nodes[g.id]=g,this.body.nodeIndices.push(g.id),this._temporaryBindUI("onTouch",z(t=this._controlNodeTouch).call(t,this)),this._temporaryBindUI("onTap",()=>{}),this._temporaryBindUI("onHold",()=>{}),this._temporaryBindUI("onDragStart",z(r=this._controlNodeDragStart).call(r,this)),this._temporaryBindUI("onDrag",z(i=this._controlNodeDrag).call(i,this)),this._temporaryBindUI("onDragEnd",z(o=this._controlNodeDragEnd).call(o,this)),this._temporaryBindUI("onMouseMove",()=>{}),this._temporaryBindEvent("beforeDrawing",A=>{const I=s.edgeType.findBorderPositions(A);a.selected===!1&&(a.x=I.from.x,a.y=I.from.y),g.selected===!1&&(g.x=I.to.x,g.y=I.to.y)}),this.body.emitter.emit("_redraw")}else this.showManipulatorToolbar()}deleteSelected(){this.editMode!==!0&&this.enableEditMode(),this._clean(),this.inMode="delete";const e=this.selectionHandler.getSelectedNodeIds(),t=this.selectionHandler.getSelectedEdgeIds();let r;if(e.length>0){for(let i=0;i<e.length;i++)if(this.body.nodes[e[i]].isCluster===!0){alert(this.options.locales[this.options.locale].deleteClusterError||this.options.locales.en.deleteClusterError);return}typeof this.options.deleteNode=="function"&&(r=this.options.deleteNode)}else t.length>0&&typeof this.options.deleteEdge=="function"&&(r=this.options.deleteEdge);if(typeof r=="function"){const i={nodes:e,edges:t};if(r.length===2)r(i,o=>{o!=null&&this.inMode==="delete"?(this.body.data.edges.getDataSet().remove(o.edges),this.body.data.nodes.getDataSet().remove(o.nodes),this.body.emitter.emit("startSimulation"),this.showManipulatorToolbar()):(this.body.emitter.emit("startSimulation"),this.showManipulatorToolbar())});else throw new Error("The function for delete does not support two arguments (data, callback)")}else this.body.data.edges.getDataSet().remove(t),this.body.data.nodes.getDataSet().remove(e),this.body.emitter.emit("startSimulation"),this.showManipulatorToolbar()}_setup(){this.options.enabled===!0?(this.guiEnabled=!0,this._createWrappers(),this.editMode===!1?this._createEditButton():this.showManipulatorToolbar()):(this._removeManipulationDOM(),this.guiEnabled=!1)}_createWrappers(){if(this.manipulationDiv===void 0&&(this.manipulationDiv=document.createElement("div"),this.manipulationDiv.className="vis-manipulation",this.editMode===!0?this.manipulationDiv.style.display="block":this.manipulationDiv.style.display="none",this.canvas.frame.appendChild(this.manipulationDiv)),this.editModeDiv===void 0&&(this.editModeDiv=document.createElement("div"),this.editModeDiv.className="vis-edit-mode",this.editMode===!0?this.editModeDiv.style.display="none":this.editModeDiv.style.display="block",this.canvas.frame.appendChild(this.editModeDiv)),this.closeDiv===void 0){var e,t;this.closeDiv=document.createElement("button"),this.closeDiv.className="vis-close",this.closeDiv.setAttribute("aria-label",(e=(t=this.options.locales[this.options.locale])===null||t===void 0?void 0:t.close)!==null&&e!==void 0?e:this.options.locales.en.close),this.closeDiv.style.display=this.manipulationDiv.style.display,this.canvas.frame.appendChild(this.closeDiv)}}_getNewTargetNode(e,t){const r=Me({},this.options.controlNodeStyle);r.id="targetNode"+is(),r.hidden=!1,r.physics=!1,r.x=e,r.y=t;const i=this.body.functions.createNode(r);return i.shape.boundingBox={left:e,right:e,top:t,bottom:t},i}_createEditButton(){var e;this._clean(),this.manipulationDOM={},Ki(this.editModeDiv);const t=this.options.locales[this.options.locale],r=this._createButton("editMode","vis-edit vis-edit-mode",t.edit||this.options.locales.en.edit);this.editModeDiv.appendChild(r),this._bindElementEvents(r,z(e=this.toggleEditMode).call(e,this))}_clean(){this.inMode=!1,this.guiEnabled===!0&&(Ki(this.editModeDiv),Ki(this.manipulationDiv),this._cleanupDOMEventListeners()),this._cleanupTemporaryNodesAndEdges(),this._unbindTemporaryUIs(),this._unbindTemporaryEvents(),this.body.emitter.emit("restorePhysics")}_cleanupDOMEventListeners(){for(const t of ti(e=this._domEventListenerCleanupQueue).call(e,0)){var e;t()}}_removeManipulationDOM(){this._clean(),Ki(this.manipulationDiv),Ki(this.editModeDiv),Ki(this.closeDiv),this.manipulationDiv&&this.canvas.frame.removeChild(this.manipulationDiv),this.editModeDiv&&this.canvas.frame.removeChild(this.editModeDiv),this.closeDiv&&this.canvas.frame.removeChild(this.closeDiv),this.manipulationDiv=void 0,this.editModeDiv=void 0,this.closeDiv=void 0}_createSeperator(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:1;this.manipulationDOM["seperatorLineDiv"+e]=document.createElement("div"),this.manipulationDOM["seperatorLineDiv"+e].className="vis-separator-line",this.manipulationDiv.appendChild(this.manipulationDOM["seperatorLineDiv"+e])}_createAddNodeButton(e){var t;const r=this._createButton("addNode","vis-add",e.addNode||this.options.locales.en.addNode);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.addNodeMode).call(t,this))}_createAddEdgeButton(e){var t;const r=this._createButton("addEdge","vis-connect",e.addEdge||this.options.locales.en.addEdge);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.addEdgeMode).call(t,this))}_createEditNodeButton(e){var t;const r=this._createButton("editNode","vis-edit",e.editNode||this.options.locales.en.editNode);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.editNode).call(t,this))}_createEditEdgeButton(e){var t;const r=this._createButton("editEdge","vis-edit",e.editEdge||this.options.locales.en.editEdge);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.editEdgeMode).call(t,this))}_createDeleteButton(e){var t;let r;this.options.rtl?r="vis-delete-rtl":r="vis-delete";const i=this._createButton("delete",r,e.del||this.options.locales.en.del);this.manipulationDiv.appendChild(i),this._bindElementEvents(i,z(t=this.deleteSelected).call(t,this))}_createBackButton(e){var t;const r=this._createButton("back","vis-back",e.back||this.options.locales.en.back);this.manipulationDiv.appendChild(r),this._bindElementEvents(r,z(t=this.showManipulatorToolbar).call(t,this))}_createButton(e,t,r){let i=arguments.length>3&&arguments[3]!==void 0?arguments[3]:"vis-label";return this.manipulationDOM[e+"Div"]=document.createElement("button"),this.manipulationDOM[e+"Div"].className="vis-button "+t,this.manipulationDOM[e+"Label"]=document.createElement("div"),this.manipulationDOM[e+"Label"].className=i,this.manipulationDOM[e+"Label"].innerText=r,this.manipulationDOM[e+"Div"].appendChild(this.manipulationDOM[e+"Label"]),this.manipulationDOM[e+"Div"]}_createDescription(e){this.manipulationDOM.descriptionLabel=document.createElement("div"),this.manipulationDOM.descriptionLabel.className="vis-none",this.manipulationDOM.descriptionLabel.innerText=e,this.manipulationDiv.appendChild(this.manipulationDOM.descriptionLabel)}_temporaryBindEvent(e,t){this.temporaryEventFunctions.push({event:e,boundFunction:t}),this.body.emitter.on(e,t)}_temporaryBindUI(e,t){if(this.body.eventListeners[e]!==void 0)this.temporaryUIFunctions[e]=this.body.eventListeners[e],this.body.eventListeners[e]=t;else throw new Error("This UI function does not exist. Typo? You tried: "+e+" possible are: "+ks(Be(this.body.eventListeners)))}_unbindTemporaryUIs(){for(const e in this.temporaryUIFunctions)Object.prototype.hasOwnProperty.call(this.temporaryUIFunctions,e)&&(this.body.eventListeners[e]=this.temporaryUIFunctions[e],delete this.temporaryUIFunctions[e]);this.temporaryUIFunctions={}}_unbindTemporaryEvents(){for(let e=0;e<this.temporaryEventFunctions.length;e++){const t=this.temporaryEventFunctions[e].event,r=this.temporaryEventFunctions[e].boundFunction;this.body.emitter.off(t,r)}this.temporaryEventFunctions=[]}_bindElementEvents(e,t){const r=new rs(e,{});WA(r,t),this._domEventListenerCleanupQueue.push(()=>{r.destroy()});const i=o=>{let{keyCode:s,key:a}=o;(a==="Enter"||a===" "||s===13||s===32)&&t()};e.addEventListener("keyup",i,!1),this._domEventListenerCleanupQueue.push(()=>{e.removeEventListener("keyup",i,!1)})}_cleanupTemporaryNodesAndEdges(){for(let o=0;o<this.temporaryIds.edges.length;o++){var e;this.body.edges[this.temporaryIds.edges[o]].disconnect(),delete this.body.edges[this.temporaryIds.edges[o]];const s=_e(e=this.body.edgeIndices).call(e,this.temporaryIds.edges[o]);if(s!==-1){var t;ti(t=this.body.edgeIndices).call(t,s,1)}}for(let o=0;o<this.temporaryIds.nodes.length;o++){var r;delete this.body.nodes[this.temporaryIds.nodes[o]];const s=_e(r=this.body.nodeIndices).call(r,this.temporaryIds.nodes[o]);if(s!==-1){var i;ti(i=this.body.nodeIndices).call(i,s,1)}}this.temporaryIds={nodes:[],edges:[]}}_controlNodeTouch(e){this.selectionHandler.unselectAll(),this.lastTouch=this.body.functions.getPointer(e.center),this.lastTouch.translation=tt({},this.body.view.translation)}_controlNodeDragStart(){const e=this.lastTouch,t=this.selectionHandler._pointerToPositionObject(e),r=this.body.nodes[this.temporaryIds.nodes[0]],i=this.body.nodes[this.temporaryIds.nodes[1]],o=this.body.edges[this.edgeBeingEditedId];this.selectedControlNode=void 0;const s=r.isOverlappingWith(t),a=i.isOverlappingWith(t);s===!0?(this.selectedControlNode=r,o.edgeType.from=r):a===!0&&(this.selectedControlNode=i,o.edgeType.to=i),this.selectedControlNode!==void 0&&this.selectionHandler.selectObject(this.selectedControlNode),this.body.emitter.emit("_redraw")}_controlNodeDrag(e){this.body.emitter.emit("disablePhysics");const t=this.body.functions.getPointer(e.center),r=this.canvas.DOMtoCanvas(t);this.selectedControlNode!==void 0?(this.selectedControlNode.x=r.x,this.selectedControlNode.y=r.y):this.interactionHandler.onDrag(e),this.body.emitter.emit("_redraw")}_controlNodeDragEnd(e){const t=this.body.functions.getPointer(e.center),r=this.selectionHandler._pointerToPositionObject(t),i=this.body.edges[this.edgeBeingEditedId];if(this.selectedControlNode===void 0)return;this.selectionHandler.unselectAll();const o=this.selectionHandler._getAllNodesOverlappingWith(r);let s;for(let a=o.length-1;a>=0;a--)if(o[a]!==this.selectedControlNode.id){s=this.body.nodes[o[a]];break}if(s!==void 0&&this.selectedControlNode!==void 0)if(s.isCluster===!0)alert(this.options.locales[this.options.locale].createEdgeError||this.options.locales.en.createEdgeError);else{const a=this.body.nodes[this.temporaryIds.nodes[0]];this.selectedControlNode.id===a.id?this._performEditEdge(s.id,i.to.id):this._performEditEdge(i.from.id,s.id)}else i.updateEdgeType(),this.body.emitter.emit("restorePhysics");this.body.emitter.emit("_redraw")}_handleConnect(e){if(new Date().valueOf()-this.touchTime>100){this.lastTouch=this.body.functions.getPointer(e.center),this.lastTouch.translation=tt({},this.body.view.translation),this.interactionHandler.drag.pointer=this.lastTouch,this.interactionHandler.drag.translation=this.lastTouch.translation;const t=this.lastTouch,r=this.selectionHandler.getNodeAt(t);if(r!==void 0)if(r.isCluster===!0)alert(this.options.locales[this.options.locale].createEdgeError||this.options.locales.en.createEdgeError);else{const i=this._getNewTargetNode(r.x,r.y);this.body.nodes[i.id]=i,this.body.nodeIndices.push(i.id);const o=this.body.functions.createEdge({id:"connectionEdge"+is(),from:r.id,to:i.id,physics:!1,smooth:{enabled:!0,type:"continuous",roundness:.5}});this.body.edges[o.id]=o,this.body.edgeIndices.push(o.id),this.temporaryIds.nodes.push(i.id),this.temporaryIds.edges.push(o.id)}this.touchTime=new Date().valueOf()}}_dragControlNode(e){const t=this.body.functions.getPointer(e.center),r=this.selectionHandler._pointerToPositionObject(t);let i;this.temporaryIds.edges[0]!==void 0&&(i=this.body.edges[this.temporaryIds.edges[0]].fromId);const o=this.selectionHandler._getAllNodesOverlappingWith(r);let s;for(let g=o.length-1;g>=0;g--){var a;if(_e(a=this.temporaryIds.nodes).call(a,o[g])===-1){s=this.body.nodes[o[g]];break}}if(e.controlEdge={from:i,to:s?s.id:void 0},this.selectionHandler.generateClickEvent("controlNodeDragging",e,t),this.temporaryIds.nodes[0]!==void 0){const g=this.body.nodes[this.temporaryIds.nodes[0]];g.x=this.canvas._XconvertDOMtoCanvas(t.x),g.y=this.canvas._YconvertDOMtoCanvas(t.y),this.body.emitter.emit("_redraw")}else this.interactionHandler.onDrag(e)}_finishConnect(e){const t=this.body.functions.getPointer(e.center),r=this.selectionHandler._pointerToPositionObject(t);let i;this.temporaryIds.edges[0]!==void 0&&(i=this.body.edges[this.temporaryIds.edges[0]].fromId);const o=this.selectionHandler._getAllNodesOverlappingWith(r);let s;for(let g=o.length-1;g>=0;g--){var a;if(_e(a=this.temporaryIds.nodes).call(a,o[g])===-1){s=this.body.nodes[o[g]];break}}this._cleanupTemporaryNodesAndEdges(),s!==void 0&&(s.isCluster===!0?alert(this.options.locales[this.options.locale].createEdgeError||this.options.locales.en.createEdgeError):this.body.nodes[i]!==void 0&&this.body.nodes[s.id]!==void 0&&this._performAddEdge(i,s.id)),e.controlEdge={from:i,to:s?s.id:void 0},this.selectionHandler.generateClickEvent("controlNodeDragEnd",e,t),this.body.emitter.emit("_redraw")}_dragStartEdge(e){const t=this.lastTouch;this.selectionHandler.generateClickEvent("dragStart",e,t,void 0,!0)}_performAddNode(e){const t={id:is(),x:e.pointer.canvas.x,y:e.pointer.canvas.y,label:"new"};if(typeof this.options.addNode=="function")if(this.options.addNode.length===2)this.options.addNode(t,r=>{r!=null&&this.inMode==="addNode"&&this.body.data.nodes.getDataSet().add(r),this.showManipulatorToolbar()});else throw this.showManipulatorToolbar(),new Error("The function for add does not support two arguments (data,callback)");else this.body.data.nodes.getDataSet().add(t),this.showManipulatorToolbar()}_performAddEdge(e,t){const r={from:e,to:t};if(typeof this.options.addEdge=="function")if(this.options.addEdge.length===2)this.options.addEdge(r,i=>{i!=null&&this.inMode==="addEdge"&&(this.body.data.edges.getDataSet().add(i),this.selectionHandler.unselectAll(),this.showManipulatorToolbar())});else throw new Error("The function for connect does not support two arguments (data,callback)");else this.body.data.edges.getDataSet().add(r),this.selectionHandler.unselectAll(),this.showManipulatorToolbar()}_performEditEdge(e,t){const r={id:this.edgeBeingEditedId,from:e,to:t,label:this.body.data.edges.get(this.edgeBeingEditedId).label};let i=this.options.editEdge;if(typeof i=="object"&&(i=i.editWithoutDrag),typeof i=="function")if(i.length===2)i(r,o=>{o==null||this.inMode!=="editEdge"?(this.body.edges[r.id].updateEdgeType(),this.body.emitter.emit("_redraw"),this.showManipulatorToolbar()):(this.body.data.edges.getDataSet().update(o),this.selectionHandler.unselectAll(),this.showManipulatorToolbar())});else throw new Error("The function for edit does not support two arguments (data, callback)");else this.body.data.edges.getDataSet().update(r),this.selectionHandler.unselectAll(),this.showManipulatorToolbar()}};const G="string",k="boolean",$="number",Ta="array",Q="object",w7="dom",ZCe="any",$f=["arrow","bar","box","circle","crow","curve","diamond","image","inv_curve","inv_triangle","triangle","vee"],Df={borderWidth:{number:$},borderWidthSelected:{number:$,undefined:"undefined"},brokenImage:{string:G,undefined:"undefined"},chosen:{label:{boolean:k,function:"function"},node:{boolean:k,function:"function"},__type__:{object:Q,boolean:k}},color:{border:{string:G},background:{string:G},highlight:{border:{string:G},background:{string:G},__type__:{object:Q,string:G}},hover:{border:{string:G},background:{string:G},__type__:{object:Q,string:G}},__type__:{object:Q,string:G}},opacity:{number:$,undefined:"undefined"},fixed:{x:{boolean:k},y:{boolean:k},__type__:{object:Q,boolean:k}},font:{align:{string:G},color:{string:G},size:{number:$},face:{string:G},background:{string:G},strokeWidth:{number:$},strokeColor:{string:G},vadjust:{number:$},multi:{boolean:k,string:G},bold:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},boldital:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},ital:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},mono:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},__type__:{object:Q,string:G}},group:{string:G,number:$,undefined:"undefined"},heightConstraint:{minimum:{number:$},valign:{string:G},__type__:{object:Q,boolean:k,number:$}},hidden:{boolean:k},icon:{face:{string:G},code:{string:G},size:{number:$},color:{string:G},weight:{string:G,number:$},__type__:{object:Q}},id:{string:G,number:$},image:{selected:{string:G,undefined:"undefined"},unselected:{string:G,undefined:"undefined"},__type__:{object:Q,string:G}},imagePadding:{top:{number:$},right:{number:$},bottom:{number:$},left:{number:$},__type__:{object:Q,number:$}},label:{string:G,undefined:"undefined"},labelHighlightBold:{boolean:k},level:{number:$,undefined:"undefined"},margin:{top:{number:$},right:{number:$},bottom:{number:$},left:{number:$},__type__:{object:Q,number:$}},mass:{number:$},physics:{boolean:k},scaling:{min:{number:$},max:{number:$},label:{enabled:{boolean:k},min:{number:$},max:{number:$},maxVisible:{number:$},drawThreshold:{number:$},__type__:{object:Q,boolean:k}},customScalingFunction:{function:"function"},__type__:{object:Q}},shadow:{enabled:{boolean:k},color:{string:G},size:{number:$},x:{number:$},y:{number:$},__type__:{object:Q,boolean:k}},shape:{string:["custom","ellipse","circle","database","box","text","image","circularImage","diamond","dot","star","triangle","triangleDown","square","icon","hexagon"]},ctxRenderer:{function:"function"},shapeProperties:{borderDashes:{boolean:k,array:Ta},borderRadius:{number:$},interpolation:{boolean:k},useImageSize:{boolean:k},useBorderWithImage:{boolean:k},coordinateOrigin:{string:["center","top-left"]},__type__:{object:Q}},size:{number:$},title:{string:G,dom:w7,undefined:"undefined"},value:{number:$,undefined:"undefined"},widthConstraint:{minimum:{number:$},maximum:{number:$},__type__:{object:Q,boolean:k,number:$}},x:{number:$},y:{number:$},__type__:{object:Q}},HCe={configure:{enabled:{boolean:k},filter:{boolean:k,string:G,array:Ta,function:"function"},container:{dom:w7},showButton:{boolean:k},__type__:{object:Q,boolean:k,string:G,array:Ta,function:"function"}},edges:{arrows:{to:{enabled:{boolean:k},scaleFactor:{number:$},type:{string:$f},imageHeight:{number:$},imageWidth:{number:$},src:{string:G},__type__:{object:Q,boolean:k}},middle:{enabled:{boolean:k},scaleFactor:{number:$},type:{string:$f},imageWidth:{number:$},imageHeight:{number:$},src:{string:G},__type__:{object:Q,boolean:k}},from:{enabled:{boolean:k},scaleFactor:{number:$},type:{string:$f},imageWidth:{number:$},imageHeight:{number:$},src:{string:G},__type__:{object:Q,boolean:k}},__type__:{string:["from","to","middle"],object:Q}},endPointOffset:{from:{number:$},to:{number:$},__type__:{object:Q,number:$}},arrowStrikethrough:{boolean:k},background:{enabled:{boolean:k},color:{string:G},size:{number:$},dashes:{boolean:k,array:Ta},__type__:{object:Q,boolean:k}},chosen:{label:{boolean:k,function:"function"},edge:{boolean:k,function:"function"},__type__:{object:Q,boolean:k}},color:{color:{string:G},highlight:{string:G},hover:{string:G},inherit:{string:["from","to","both"],boolean:k},opacity:{number:$},__type__:{object:Q,string:G}},dashes:{boolean:k,array:Ta},font:{color:{string:G},size:{number:$},face:{string:G},background:{string:G},strokeWidth:{number:$},strokeColor:{string:G},align:{string:["horizontal","top","middle","bottom"]},vadjust:{number:$},multi:{boolean:k,string:G},bold:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},boldital:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},ital:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},mono:{color:{string:G},size:{number:$},face:{string:G},mod:{string:G},vadjust:{number:$},__type__:{object:Q,string:G}},__type__:{object:Q,string:G}},hidden:{boolean:k},hoverWidth:{function:"function",number:$},label:{string:G,undefined:"undefined"},labelHighlightBold:{boolean:k},length:{number:$,undefined:"undefined"},physics:{boolean:k},scaling:{min:{number:$},max:{number:$},label:{enabled:{boolean:k},min:{number:$},max:{number:$},maxVisible:{number:$},drawThreshold:{number:$},__type__:{object:Q,boolean:k}},customScalingFunction:{function:"function"},__type__:{object:Q}},selectionWidth:{function:"function",number:$},selfReferenceSize:{number:$},selfReference:{size:{number:$},angle:{number:$},renderBehindTheNode:{boolean:k},__type__:{object:Q}},shadow:{enabled:{boolean:k},color:{string:G},size:{number:$},x:{number:$},y:{number:$},__type__:{object:Q,boolean:k}},smooth:{enabled:{boolean:k},type:{string:["dynamic","continuous","discrete","diagonalCross","straightCross","horizontal","vertical","curvedCW","curvedCCW","cubicBezier"]},roundness:{number:$},forceDirection:{string:["horizontal","vertical","none"],boolean:k},__type__:{object:Q,boolean:k}},title:{string:G,undefined:"undefined"},width:{number:$},widthConstraint:{maximum:{number:$},__type__:{object:Q,boolean:k,number:$}},value:{number:$,undefined:"undefined"},__type__:{object:Q}},groups:{useDefaultGroups:{boolean:k},__any__:Df,__type__:{object:Q}},interaction:{dragNodes:{boolean:k},dragView:{boolean:k},hideEdgesOnDrag:{boolean:k},hideEdgesOnZoom:{boolean:k},hideNodesOnDrag:{boolean:k},hover:{boolean:k},keyboard:{enabled:{boolean:k},speed:{x:{number:$},y:{number:$},zoom:{number:$},__type__:{object:Q}},bindToWindow:{boolean:k},autoFocus:{boolean:k},__type__:{object:Q,boolean:k}},multiselect:{boolean:k},navigationButtons:{boolean:k},selectable:{boolean:k},selectConnectedEdges:{boolean:k},hoverConnectedEdges:{boolean:k},tooltipDelay:{number:$},zoomView:{boolean:k},zoomSpeed:{number:$},__type__:{object:Q}},layout:{randomSeed:{undefined:"undefined",number:$,string:G},improvedLayout:{boolean:k},clusterThreshold:{number:$},hierarchical:{enabled:{boolean:k},levelSeparation:{number:$},nodeSpacing:{number:$},treeSpacing:{number:$},blockShifting:{boolean:k},edgeMinimization:{boolean:k},parentCentralization:{boolean:k},direction:{string:["UD","DU","LR","RL"]},sortMethod:{string:["hubsize","directed"]},shakeTowards:{string:["leaves","roots"]},__type__:{object:Q,boolean:k}},__type__:{object:Q}},manipulation:{enabled:{boolean:k},initiallyActive:{boolean:k},addNode:{boolean:k,function:"function"},addEdge:{boolean:k,function:"function"},editNode:{function:"function"},editEdge:{editWithoutDrag:{function:"function"},__type__:{object:Q,boolean:k,function:"function"}},deleteNode:{boolean:k,function:"function"},deleteEdge:{boolean:k,function:"function"},controlNodeStyle:Df,__type__:{object:Q,boolean:k}},nodes:Df,physics:{enabled:{boolean:k},barnesHut:{theta:{number:$},gravitationalConstant:{number:$},centralGravity:{number:$},springLength:{number:$},springConstant:{number:$},damping:{number:$},avoidOverlap:{number:$},__type__:{object:Q}},forceAtlas2Based:{theta:{number:$},gravitationalConstant:{number:$},centralGravity:{number:$},springLength:{number:$},springConstant:{number:$},damping:{number:$},avoidOverlap:{number:$},__type__:{object:Q}},repulsion:{centralGravity:{number:$},springLength:{number:$},springConstant:{number:$},nodeDistance:{number:$},damping:{number:$},__type__:{object:Q}},hierarchicalRepulsion:{centralGravity:{number:$},springLength:{number:$},springConstant:{number:$},nodeDistance:{number:$},damping:{number:$},avoidOverlap:{number:$},__type__:{object:Q}},maxVelocity:{number:$},minVelocity:{number:$},solver:{string:["barnesHut","repulsion","hierarchicalRepulsion","forceAtlas2Based"]},stabilization:{enabled:{boolean:k},iterations:{number:$},updateInterval:{number:$},onlyDynamicEdges:{boolean:k},fit:{boolean:k},__type__:{object:Q,boolean:k}},timestep:{number:$},adaptiveTimestep:{boolean:k},wind:{x:{number:$},y:{number:$},__type__:{object:Q}},__type__:{object:Q,boolean:k}},autoResize:{boolean:k},clickToUse:{boolean:k},locale:{string:G},locales:{__any__:{any:ZCe},__type__:{object:Q}},height:{string:G},width:{string:G},__type__:{object:Q}},E7={nodes:{borderWidth:[1,0,10,1],borderWidthSelected:[2,0,10,1],color:{border:["color","#2B7CE9"],background:["color","#97C2FC"],highlight:{border:["color","#2B7CE9"],background:["color","#D2E5FF"]},hover:{border:["color","#2B7CE9"],background:["color","#D2E5FF"]}},opacity:[0,0,1,.1],fixed:{x:!1,y:!1},font:{color:["color","#343434"],size:[14,0,100,1],face:["arial","verdana","tahoma"],background:["color","none"],strokeWidth:[0,0,50,1],strokeColor:["color","#ffffff"]},hidden:!1,labelHighlightBold:!0,physics:!0,scaling:{min:[10,0,200,1],max:[30,0,200,1],label:{enabled:!1,min:[14,0,200,1],max:[30,0,200,1],maxVisible:[30,0,200,1],drawThreshold:[5,0,20,1]}},shadow:{enabled:!1,color:"rgba(0,0,0,0.5)",size:[10,0,20,1],x:[5,-30,30,1],y:[5,-30,30,1]},shape:["ellipse","box","circle","database","diamond","dot","square","star","text","triangle","triangleDown","hexagon"],shapeProperties:{borderDashes:!1,borderRadius:[6,0,20,1],interpolation:!0,useImageSize:!1},size:[25,0,200,1]},edges:{arrows:{to:{enabled:!1,scaleFactor:[1,0,3,.05],type:"arrow"},middle:{enabled:!1,scaleFactor:[1,0,3,.05],type:"arrow"},from:{enabled:!1,scaleFactor:[1,0,3,.05],type:"arrow"}},endPointOffset:{from:[0,-10,10,1],to:[0,-10,10,1]},arrowStrikethrough:!0,color:{color:["color","#848484"],highlight:["color","#848484"],hover:["color","#848484"],inherit:["from","to","both",!0,!1],opacity:[1,0,1,.05]},dashes:!1,font:{color:["color","#343434"],size:[14,0,100,1],face:["arial","verdana","tahoma"],background:["color","none"],strokeWidth:[2,0,50,1],strokeColor:["color","#ffffff"],align:["horizontal","top","middle","bottom"]},hidden:!1,hoverWidth:[1.5,0,5,.1],labelHighlightBold:!0,physics:!0,scaling:{min:[1,0,100,1],max:[15,0,100,1],label:{enabled:!0,min:[14,0,200,1],max:[30,0,200,1],maxVisible:[30,0,200,1],drawThreshold:[5,0,20,1]}},selectionWidth:[1.5,0,5,.1],selfReferenceSize:[20,0,200,1],selfReference:{size:[20,0,200,1],angle:[Math.PI/2,-6*Math.PI,6*Math.PI,Math.PI/8],renderBehindTheNode:!0},shadow:{enabled:!1,color:"rgba(0,0,0,0.5)",size:[10,0,20,1],x:[5,-30,30,1],y:[5,-30,30,1]},smooth:{enabled:!0,type:["dynamic","continuous","discrete","diagonalCross","straightCross","horizontal","vertical","curvedCW","curvedCCW","cubicBezier"],forceDirection:["horizontal","vertical","none"],roundness:[.5,0,1,.05]},width:[1,0,30,1]},layout:{hierarchical:{enabled:!1,levelSeparation:[150,20,500,5],nodeSpacing:[100,20,500,5],treeSpacing:[200,20,500,5],blockShifting:!0,edgeMinimization:!0,parentCentralization:!0,direction:["UD","DU","LR","RL"],sortMethod:["hubsize","directed"],shakeTowards:["leaves","roots"]}},interaction:{dragNodes:!0,dragView:!0,hideEdgesOnDrag:!1,hideEdgesOnZoom:!1,hideNodesOnDrag:!1,hover:!1,keyboard:{enabled:!1,speed:{x:[10,0,40,1],y:[10,0,40,1],zoom:[.02,0,.1,.005]},bindToWindow:!0,autoFocus:!0},multiselect:!1,navigationButtons:!1,selectable:!0,selectConnectedEdges:!0,hoverConnectedEdges:!0,tooltipDelay:[300,0,1e3,25],zoomView:!0,zoomSpeed:[1,.1,2,.1]},manipulation:{enabled:!1,initiallyActive:!1},physics:{enabled:!0,barnesHut:{theta:[.5,.1,1,.05],gravitationalConstant:[-2e3,-3e4,0,50],centralGravity:[.3,0,10,.05],springLength:[95,0,500,5],springConstant:[.04,0,1.2,.005],damping:[.09,0,1,.01],avoidOverlap:[0,0,1,.01]},forceAtlas2Based:{theta:[.5,.1,1,.05],gravitationalConstant:[-50,-500,0,1],centralGravity:[.01,0,1,.005],springLength:[95,0,500,5],springConstant:[.08,0,1.2,.005],damping:[.4,0,1,.01],avoidOverlap:[0,0,1,.01]},repulsion:{centralGravity:[.2,0,10,.05],springLength:[200,0,500,5],springConstant:[.05,0,1.2,.005],nodeDistance:[100,0,500,5],damping:[.09,0,1,.01]},hierarchicalRepulsion:{centralGravity:[.2,0,10,.05],springLength:[100,0,500,5],springConstant:[.01,0,1.2,.005],nodeDistance:[120,0,500,5],damping:[.09,0,1,.01],avoidOverlap:[0,0,1,.01]},maxVelocity:[50,0,150,1],minVelocity:[.1,.01,.5,.01],solver:["barnesHut","forceAtlas2Based","repulsion","hierarchicalRepulsion"],timestep:[.5,.01,1,.01],wind:{x:[0,-10,10,.1],y:[0,-10,10,.1]}}},UCe=(n,e,t)=>{var r;return!!(rn(n).call(n,"physics")&&rn(r=E7.physics.solver).call(r,e)&&t.physics.solver!==e&&e!=="wind")};let KCe=class{constructor(){}getDistances(e,t,r){const i={},o=e.edges;for(let a=0;a<t.length;a++){const g=t[a],A={};i[g]=A;for(let I=0;I<t.length;I++)A[t[I]]=a==I?0:1e9}for(let a=0;a<r.length;a++){const g=o[r[a]];g.connected===!0&&i[g.fromId]!==void 0&&i[g.toId]!==void 0&&(i[g.fromId][g.toId]=1,i[g.toId][g.fromId]=1)}const s=t.length;for(let a=0;a<s;a++){const g=t[a],A=i[g];for(let I=0;I<s-1;I++){const C=t[I],l=i[C];for(let d=I+1;d<s;d++){const u=t[d],h=i[u],v=Math.min(l[u],l[g]+A[u]);l[u]=v,h[C]=v}}}return i}},YCe=class{constructor(e,t,r){this.body=e,this.springLength=t,this.springConstant=r,this.distanceSolver=new KCe}setOptions(e){e&&(e.springLength&&(this.springLength=e.springLength),e.springConstant&&(this.springConstant=e.springConstant))}solve(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;const i=this.distanceSolver.getDistances(this.body,e,t);this._createL_matrix(i),this._createK_matrix(i),this._createE_matrix();const o=.01,s=1;let a=0;const g=Math.max(1e3,Math.min(10*this.body.nodeIndices.length,6e3)),A=5;let I=1e9,C=0,l=0,d=0,u=0,h=0;for(;I>o&&a<g;)for(a+=1,[C,I,l,d]=this._getHighestEnergyNode(r),u=I,h=0;u>s&&h<A;)h+=1,this._moveNode(C,l,d),[u,l,d]=this._getEnergy(C)}_getHighestEnergyNode(e){const t=this.body.nodeIndices,r=this.body.nodes;let i=0,o=t[0],s=0,a=0;for(let g=0;g<t.length;g++){const A=t[g];if(r[A].predefinedPosition!==!0||r[A].isCluster===!0&&e===!0||r[A].options.fixed.x!==!0||r[A].options.fixed.y!==!0){const[I,C,l]=this._getEnergy(A);i<I&&(i=I,o=A,s=C,a=l)}}return[o,i,s,a]}_getEnergy(e){const[t,r]=this.E_sums[e];return[Math.sqrt(t**2+r**2),t,r]}_moveNode(e,t,r){const i=this.body.nodeIndices,o=this.body.nodes;let s=0,a=0,g=0;const A=o[e].x,I=o[e].y,C=this.K_matrix[e],l=this.L_matrix[e];for(let p=0;p<i.length;p++){const y=i[p];if(y!==e){const E=o[y].x,S=o[y].y,m=C[y],w=l[y],_=1/((A-E)**2+(I-S)**2)**1.5;s+=m*(1-w*(I-S)**2*_),a+=m*(w*(A-E)*(I-S)*_),g+=m*(1-w*(A-E)**2*_)}}const d=s,u=a,h=t,v=g,f=r,c=(h/d+f/u)/(u/d-v/u),b=-(u*c+h)/d;o[e].x+=b,o[e].y+=c,this._updateE_matrix(e)}_createL_matrix(e){const t=this.body.nodeIndices,r=this.springLength;this.L_matrix=[];for(let i=0;i<t.length;i++){this.L_matrix[t[i]]={};for(let o=0;o<t.length;o++)this.L_matrix[t[i]][t[o]]=r*e[t[i]][t[o]]}}_createK_matrix(e){const t=this.body.nodeIndices,r=this.springConstant;this.K_matrix=[];for(let i=0;i<t.length;i++){this.K_matrix[t[i]]={};for(let o=0;o<t.length;o++)this.K_matrix[t[i]][t[o]]=r*e[t[i]][t[o]]**-2}}_createE_matrix(){const e=this.body.nodeIndices,t=this.body.nodes;this.E_matrix={},this.E_sums={};for(let r=0;r<e.length;r++)this.E_matrix[e[r]]=[];for(let r=0;r<e.length;r++){const i=e[r],o=t[i].x,s=t[i].y;let a=0,g=0;for(let A=r;A<e.length;A++){const I=e[A];if(I!==i){const C=t[I].x,l=t[I].y,d=1/Math.sqrt((o-C)**2+(s-l)**2);this.E_matrix[i][A]=[this.K_matrix[i][I]*(o-C-this.L_matrix[i][I]*(o-C)*d),this.K_matrix[i][I]*(s-l-this.L_matrix[i][I]*(s-l)*d)],this.E_matrix[I][r]=this.E_matrix[i][A],a+=this.E_matrix[i][A][0],g+=this.E_matrix[i][A][1]}}this.E_sums[i]=[a,g]}}_updateE_matrix(e){const t=this.body.nodeIndices,r=this.body.nodes,i=this.E_matrix[e],o=this.K_matrix[e],s=this.L_matrix[e],a=r[e].x,g=r[e].y;let A=0,I=0;for(let C=0;C<t.length;C++){const l=t[C];if(l!==e){const d=i[C],u=d[0],h=d[1],v=r[l].x,f=r[l].y,c=1/Math.sqrt((a-v)**2+(g-f)**2),b=o[l]*(a-v-s[l]*(a-v)*c),p=o[l]*(g-f-s[l]*(g-f)*c);i[C]=[b,p],A+=b,I+=p;const y=this.E_sums[l];y[0]+=b-u,y[1]+=p-h}}this.E_sums[e]=[A,I]}};function X(n,e,t){var r,i,o,s;if(!(this instanceof X))throw new SyntaxError("Constructor must be called with the new operator");this.options={},this.defaultOptions={locale:"en",locales:Jse,clickToUse:!1},tt(this.options,this.defaultOptions),this.body={container:n,nodes:{},nodeIndices:[],edges:{},edgeIndices:[],emitter:{on:z(r=this.on).call(r,this),off:z(i=this.off).call(i,this),emit:z(o=this.emit).call(o,this),once:z(s=this.once).call(s,this)},eventListeners:{onTap:function(){},onTouch:function(){},onDoubleTap:function(){},onHold:function(){},onDragStart:function(){},onDrag:function(){},onDragEnd:function(){},onMouseWheel:function(){},onPinch:function(){},onMouseMove:function(){},onRelease:function(){},onContext:function(){}},data:{nodes:null,edges:null},functions:{createNode:function(){},createEdge:function(){},getPointer:function(){}},modules:{},view:{scale:1,translation:{x:0,y:0}},selectionBox:{show:!1,position:{start:{x:0,y:0},end:{x:0,y:0}}}},this.bindEventListeners(),this.images=new rae(()=>this.body.emitter.emit("_requestRedraw")),this.groups=new cae,this.canvas=new fCe(this.body),this.selectionHandler=new xCe(this.body,this.canvas),this.interactionHandler=new yCe(this.body,this.canvas,this.selectionHandler),this.view=new vCe(this.body,this.canvas),this.renderer=new lCe(this.body,this.canvas),this.physics=new ACe(this.body),this.layoutEngine=new WCe(this.body),this.clustering=new CCe(this.body),this.manipulation=new VCe(this.body,this.canvas,this.selectionHandler,this.interactionHandler),this.nodesHandler=new FIe(this.body,this.images,this.groups,this.layoutEngine),this.edgesHandler=new iCe(this.body,this.images,this.groups),this.body.modules.kamadaKawai=new YCe(this.body,150,.05),this.body.modules.clustering=this.clustering,this.canvas._create(),this.setOptions(t),this.setData(e)}GX(X.prototype);X.prototype.setOptions=function(n){if(n===null&&(n=void 0),n!==void 0){if(Pse.validate(n,HCe)===!0&&console.error("%cErrors have been found in the supplied options object.",WQ),zs(["locale","locales","clickToUse"],this.options,n),n.locale!==void 0&&(n.locale=eae(n.locales||this.options.locales,n.locale)),n=this.layoutEngine.setOptions(n.layout,n),this.canvas.setOptions(n),this.groups.setOptions(n.groups),this.nodesHandler.setOptions(n.nodes),this.edgesHandler.setOptions(n.edges),this.physics.setOptions(n.physics),this.manipulation.setOptions(n.manipulation,n,this.options),this.interactionHandler.setOptions(n.interaction),this.renderer.setOptions(n.interaction),this.selectionHandler.setOptions(n.interaction),n.groups!==void 0&&this.body.emitter.emit("refreshNodes"),"configure"in n&&(this.configurator||(this.configurator=new Tse(this,this.body.container,E7,this.canvas.pixelRatio,UCe)),this.configurator.setOptions(n.configure)),this.configurator&&this.configurator.options.enabled===!0){const r={nodes:{},edges:{},layout:{},interaction:{},manipulation:{},physics:{},global:{}};Me(r.nodes,this.nodesHandler.options),Me(r.edges,this.edgesHandler.options),Me(r.layout,this.layoutEngine.options),Me(r.interaction,this.selectionHandler.options),Me(r.interaction,this.renderer.options),Me(r.interaction,this.interactionHandler.options),Me(r.manipulation,this.manipulation.options),Me(r.physics,this.physics.options),Me(r.global,this.canvas.options),Me(r.global,this.options),this.configurator.setModuleOptions(r)}n.clickToUse!==void 0?n.clickToUse===!0?this.activator===void 0&&(this.activator=new Ose(this.canvas.frame),this.activator.on("change",()=>{this.body.emitter.emit("activate")})):(this.activator!==void 0&&(this.activator.destroy(),delete this.activator),this.body.emitter.emit("activate")):this.body.emitter.emit("activate"),this.canvas.setSize(),this.body.emitter.emit("startSimulation")}};X.prototype._updateVisibleIndices=function(){const n=this.body.nodes,e=this.body.edges;this.body.nodeIndices=[],this.body.edgeIndices=[];for(const t in n)Object.prototype.hasOwnProperty.call(n,t)&&!this.clustering._isClusteredNode(t)&&n[t].options.hidden===!1&&this.body.nodeIndices.push(n[t].id);for(const t in e)if(Object.prototype.hasOwnProperty.call(e,t)){const r=e[t],i=n[r.fromId],o=n[r.toId],s=i!==void 0&&o!==void 0;!this.clustering._isClusteredEdge(t)&&r.options.hidden===!1&&s&&i.options.hidden===!1&&o.options.hidden===!1&&this.body.edgeIndices.push(r.id)}};X.prototype.bindEventListeners=function(){this.body.emitter.on("_dataChanged",()=>{this.edgesHandler._updateState(),this.body.emitter.emit("_dataUpdated")}),this.body.emitter.on("_dataUpdated",()=>{this.clustering._updateState(),this._updateVisibleIndices(),this._updateValueRange(this.body.nodes),this._updateValueRange(this.body.edges),this.body.emitter.emit("startSimulation"),this.body.emitter.emit("_requestRedraw")})};X.prototype.setData=function(n){if(this.body.emitter.emit("resetPhysics"),this.body.emitter.emit("_resetData"),this.selectionHandler.unselectAll(),n&&n.dot&&(n.nodes||n.edges))throw new SyntaxError('Data must contain either parameter "dot" or parameter pair "nodes" and "edges", but not both.');if(this.setOptions(n&&n.options),n&&n.dot){console.warn("The dot property has been deprecated. Please use the static convertDot method to convert DOT into vis.network format and use the normal data format with nodes and edges. This converter is used like this: var data = vis.network.convertDot(dotString);");const e=zse(n.dot);this.setData(e);return}else if(n&&n.gephi){console.warn("The gephi property has been deprecated. Please use the static convertGephi method to convert gephi into vis.network format and use the normal data format with nodes and edges. This converter is used like this: var data = vis.network.convertGephi(gephiJson);");const e=jse(n.gephi);this.setData(e);return}else this.nodesHandler.setData(n&&n.nodes,!0),this.edgesHandler.setData(n&&n.edges,!0);this.body.emitter.emit("_dataChanged"),this.body.emitter.emit("_dataLoaded"),this.body.emitter.emit("initPhysics")};X.prototype.destroy=function(){this.body.emitter.emit("destroy"),this.body.emitter.off(),this.off(),delete this.groups,delete this.canvas,delete this.selectionHandler,delete this.interactionHandler,delete this.view,delete this.renderer,delete this.physics,delete this.layoutEngine,delete this.clustering,delete this.manipulation,delete this.nodesHandler,delete this.edgesHandler,delete this.configurator,delete this.images;for(const n in this.body.nodes)Object.prototype.hasOwnProperty.call(this.body.nodes,n)&&delete this.body.nodes[n];for(const n in this.body.edges)Object.prototype.hasOwnProperty.call(this.body.edges,n)&&delete this.body.edges[n];Ki(this.body.container)};X.prototype._updateValueRange=function(n){let e,t,r,i=0;for(e in n)if(Object.prototype.hasOwnProperty.call(n,e)){const o=n[e].getValue();o!==void 0&&(t=t===void 0?o:Math.min(o,t),r=r===void 0?o:Math.max(o,r),i+=o)}if(t!==void 0&&r!==void 0)for(e in n)Object.prototype.hasOwnProperty.call(n,e)&&n[e].setValueRange(t,r,i)};X.prototype.isActive=function(){return!this.activator||this.activator.active};X.prototype.setSize=function(){return this.canvas.setSize.apply(this.canvas,arguments)};X.prototype.canvasToDOM=function(){return this.canvas.canvasToDOM.apply(this.canvas,arguments)};X.prototype.DOMtoCanvas=function(){return this.canvas.DOMtoCanvas.apply(this.canvas,arguments)};X.prototype.findNode=function(){return this.clustering.findNode.apply(this.clustering,arguments)};X.prototype.isCluster=function(){return this.clustering.isCluster.apply(this.clustering,arguments)};X.prototype.openCluster=function(){return this.clustering.openCluster.apply(this.clustering,arguments)};X.prototype.cluster=function(){return this.clustering.cluster.apply(this.clustering,arguments)};X.prototype.getNodesInCluster=function(){return this.clustering.getNodesInCluster.apply(this.clustering,arguments)};X.prototype.clusterByConnection=function(){return this.clustering.clusterByConnection.apply(this.clustering,arguments)};X.prototype.clusterByHubsize=function(){return this.clustering.clusterByHubsize.apply(this.clustering,arguments)};X.prototype.updateClusteredNode=function(){return this.clustering.updateClusteredNode.apply(this.clustering,arguments)};X.prototype.getClusteredEdges=function(){return this.clustering.getClusteredEdges.apply(this.clustering,arguments)};X.prototype.getBaseEdge=function(){return this.clustering.getBaseEdge.apply(this.clustering,arguments)};X.prototype.getBaseEdges=function(){return this.clustering.getBaseEdges.apply(this.clustering,arguments)};X.prototype.updateEdge=function(){return this.clustering.updateEdge.apply(this.clustering,arguments)};X.prototype.clusterOutliers=function(){return this.clustering.clusterOutliers.apply(this.clustering,arguments)};X.prototype.getSeed=function(){return this.layoutEngine.getSeed.apply(this.layoutEngine,arguments)};X.prototype.enableEditMode=function(){return this.manipulation.enableEditMode.apply(this.manipulation,arguments)};X.prototype.disableEditMode=function(){return this.manipulation.disableEditMode.apply(this.manipulation,arguments)};X.prototype.addNodeMode=function(){return this.manipulation.addNodeMode.apply(this.manipulation,arguments)};X.prototype.editNode=function(){return this.manipulation.editNode.apply(this.manipulation,arguments)};X.prototype.editNodeMode=function(){return console.warn("Deprecated: Please use editNode instead of editNodeMode."),this.manipulation.editNode.apply(this.manipulation,arguments)};X.prototype.addEdgeMode=function(){return this.manipulation.addEdgeMode.apply(this.manipulation,arguments)};X.prototype.editEdgeMode=function(){return this.manipulation.editEdgeMode.apply(this.manipulation,arguments)};X.prototype.deleteSelected=function(){return this.manipulation.deleteSelected.apply(this.manipulation,arguments)};X.prototype.getPositions=function(){return this.nodesHandler.getPositions.apply(this.nodesHandler,arguments)};X.prototype.getPosition=function(){return this.nodesHandler.getPosition.apply(this.nodesHandler,arguments)};X.prototype.storePositions=function(){return this.nodesHandler.storePositions.apply(this.nodesHandler,arguments)};X.prototype.moveNode=function(){return this.nodesHandler.moveNode.apply(this.nodesHandler,arguments)};X.prototype.getBoundingBox=function(){return this.nodesHandler.getBoundingBox.apply(this.nodesHandler,arguments)};X.prototype.getConnectedNodes=function(n){return this.body.nodes[n]!==void 0?this.nodesHandler.getConnectedNodes.apply(this.nodesHandler,arguments):this.edgesHandler.getConnectedNodes.apply(this.edgesHandler,arguments)};X.prototype.getConnectedEdges=function(){return this.nodesHandler.getConnectedEdges.apply(this.nodesHandler,arguments)};X.prototype.startSimulation=function(){return this.physics.startSimulation.apply(this.physics,arguments)};X.prototype.stopSimulation=function(){return this.physics.stopSimulation.apply(this.physics,arguments)};X.prototype.stabilize=function(){return this.physics.stabilize.apply(this.physics,arguments)};X.prototype.getSelection=function(){return this.selectionHandler.getSelection.apply(this.selectionHandler,arguments)};X.prototype.setSelection=function(){return this.selectionHandler.setSelection.apply(this.selectionHandler,arguments)};X.prototype.getSelectedNodes=function(){return this.selectionHandler.getSelectedNodeIds.apply(this.selectionHandler,arguments)};X.prototype.getSelectedEdges=function(){return this.selectionHandler.getSelectedEdgeIds.apply(this.selectionHandler,arguments)};X.prototype.getNodeAt=function(){const n=this.selectionHandler.getNodeAt.apply(this.selectionHandler,arguments);return n!==void 0&&n.id!==void 0?n.id:n};X.prototype.getEdgeAt=function(){const n=this.selectionHandler.getEdgeAt.apply(this.selectionHandler,arguments);return n!==void 0&&n.id!==void 0?n.id:n};X.prototype.selectNodes=function(){return this.selectionHandler.selectNodes.apply(this.selectionHandler,arguments)};X.prototype.selectEdges=function(){return this.selectionHandler.selectEdges.apply(this.selectionHandler,arguments)};X.prototype.unselectAll=function(){this.selectionHandler.unselectAll.apply(this.selectionHandler,arguments),this.selectionHandler.commitWithoutEmitting.apply(this.selectionHandler),this.redraw()};X.prototype.redraw=function(){return this.renderer.redraw.apply(this.renderer,arguments)};X.prototype.getScale=function(){return this.view.getScale.apply(this.view,arguments)};X.prototype.getViewPosition=function(){return this.view.getViewPosition.apply(this.view,arguments)};X.prototype.fit=function(){return this.view.fit.apply(this.view,arguments)};X.prototype.moveTo=function(){return this.view.moveTo.apply(this.view,arguments)};X.prototype.focus=function(){return this.view.focus.apply(this.view,arguments)};X.prototype.releaseNode=function(){return this.view.releaseNode.apply(this.view,arguments)};X.prototype.getOptionsFromConfigurator=function(){let n={};return this.configurator&&(n=this.configurator.getOptions.apply(this.configurator)),n};const S7={vue:{color:"#42b883"},ts:{color:"#3B86CB"},js:{color:"#d6cb2d"},json:{color:"#cf8f30"},css:{color:"#e6659a"},html:{color:"#e34c26"},jsx:{color:"#54B9D1"},tsx:{color:"#4FC7FF"},other:{color:"#B86542"}},XCe=["vue","other"];function QCe(){const[n,e]=RX(!0);return{fileTypeData:Object.entries(S7).map(([t,r])=>({key:t,color:r.color,capitalize:XCe.includes(t)})),fileTypeShow:n,toggleFileType:e}}const{isDark:JCe}=Pte(),nB=PX(()=>({nodes:{shape:"dot",size:16,font:{color:JCe.value?"#fff":"#000",multi:"html"}},interaction:{hover:!0},physics:{maxVelocity:146,solver:"forceAtlas2Based",timestep:.35,stabilization:{enabled:!0,iterations:200}},groups:S7})),Ma=PX({get:()=>oO.value.graphSettings,set:n=>{oO.value.graphSettings=n}});$A(Ma,()=>{ET()},{deep:!0});const yT=Bn("");xte(yT,()=>{ET()},{debounce:350});const bT=Bn(""),hs=new us([]),cs=new us([]),wT=xX([]),_7=new Map,ni=new Map,os=new Map,ele=n=>n.reduce((e,t)=>(e.some(r=>r.id===t.id)||e.push(t),e),[]),O7=n=>n.reduce((e,t)=>(e.some(r=>r.from===t.from&&r.to===t.to)||e.push(t),e),[]);function tle(){wT.value=[],_7.clear(),hs.clear(),cs.clear(),ni.clear(),os.clear()}function fs(n){const e=n.id.includes("node_modules");return!(!Ma.value.node_modules&&e||!Ma.value.virtual&&n.virtual&&!e||!Ma.value.lib&&!n.id.includes(bT.value)&&!n.virtual)}function T7(n){const e=os.get(n);return e?e.some(t=>fs(t.mod)):!0}const rle=/(?:.*\/){3}([^/]+$)/;function ET(){hs.clear(),cs.clear(),sle();const n=[],e=[],t=[],r=gle();(r?r.slice():wT.value.slice()).forEach(({node:s,edges:a,mod:g})=>{fs(g)&&T7(g.id)&&(n.push(s),e.push({id:g.id.match(rle)?.[0]??g.id,fullId:g.id,node:s,edges:a,deps:g.deps}),t.push(...a))});const o=yT.value;if(o.trim().length){const s=e.filter(({id:a})=>a.includes(o));if(t.length=0,n.length=0,s.length){const{node:a,edges:g}=ile(s);n.push(...a),t.push(...g)}}hs.add(ele(n)),cs.add(O7(t))}function ile(n){const e=new Map,t=new Map;return n.forEach(r=>{r=$te(r),r.node.font||(r.node.font={color:"#F19B4A"}),r.node.label=`<b>${r.node.label}</b>`,e.set(r.fullId,r.node),r.deps.forEach(i=>{const o=ni.get(i);o&&fs(o.mod)&&(e.set(o.mod.id,o.node),t.set(`${r.fullId}-${o.mod.id}`,vO(o.mod.id,r.fullId)),o.edges.forEach(s=>t.set(`${s.from}-${s.to}`,s)))})}),{node:Array.from(e.values()),edges:Array.from(t.values())}}function vO(n,e){return{from:n,to:e,arrows:{to:{enabled:!0,scaleFactor:.8},from:{enabled:!0,type:"circle",scaleFactor:.8}}}}function ST(n){return n.replace(/\?.*$/,"").replace(/#.*$/,"").replace(/\/{2,}/g,"/")}function R7(n){return n.includes("vue&type=style")}function mO(n){return n.replace(bT.value,"")}function oB(n){return 15+Math.min(n/2,8)}function sB(n,e){const t=[];return n.forEach(r=>{R7(r)||(r=ST(r),!t.includes(r)&&(t.push(r),e?.(r)))}),t}function nle(n,e){if(!n)return;bT.value=e,hs.clear(),cs.clear();const t=[],r=[];n.forEach(i=>{if(R7(i.id))return;if(i.id=ST(i.id),r.some(C=>C.id===i.id)){const C=ni.get(i.id);C.node.size=oB(C.edges.length+i.deps.length);const l=[],u=sB(i.deps,h=>{l.push(vO(i.id,h))}).filter(h=>!C.mod.deps.includes(h));if(!u.length)return;C.mod.deps.push(...u),t.push(...l);return}const o=i.id,a=o.split("/").at(-1)??"",g=mO(o),A={mod:i,info:{displayName:a,displayPath:g},node:{id:i.id,label:a,group:o.match(/\.(\w+)$/)?.[1]||"unknown",size:oB(i.deps.length),shape:i.id.includes("/node_modules/")?"hexagon":i.virtual?"diamond":"dot"},edges:[]},I=sB(i.deps,C=>{A.edges.push(vO(i.id,C)),os.has(C)||os.set(C,[]);const l=os.get(C),d=mO(o);l.find(h=>h.path===o&&h.displayPath===d&&h.mod.id===i.id)||l.push({path:o,displayPath:d,mod:i})});i.deps=I,wT.value.push(A),_7.set(i.id,A),ni.set(i.id,A),fs(i)&&T7(i.id)&&(r.push(A.node),t.push(...A.edges))}),hs.add(r.slice()),cs.add(O7(t))}const P7=Bn(),[ole,yO]=RX(!1);function sle(){yO(!1)}function ale(n){const e=ni.get(n);if(!e)return;const t=e.mod.deps.reduce((o,s)=>{const a=ni.get(s);return a&&fs(a.mod)&&o.push({path:s,displayPath:mO(ST(s))}),o},[]),i=(os.get(e.mod.id)||[]).reduce((o,s)=>{const a=ni.get(s.path);return a&&fs(a.mod)&&o.push({path:s.path,displayPath:s.displayPath}),o},[]);P7.value={name:e.info.displayName,displayPath:e.info.displayPath,path:e.mod.id,deps:t,refs:i}}const ps=Bn("");$A(ps,()=>{ET()});function gle(){const n=ps.value;return ps.value=n,!n||!ni.get(n)?null:x7(n,new Set,0)}function x7(n,e,t){if(e.has(n))return[];const r=ni.get(n);if(t+=1,!r||t>20)return[];const i=[r];return e.add(n),r.mod.deps.forEach(o=>{const s=ni.get(o);s&&i.push(...x7(s.mod.id,e,t))}),i.reduce((o,s)=>(o.some(a=>a.mod.id===s.mod.id)||o.push(s),o),[])}const Ale={class:"w-300px","h-full":"","of-auto":""},Ile={"text-md":"","h-80px":"","border-b":"","border-base":"",p3:"",flex:"~ col gap1"},Cle={"text-lg":"",flex:"~ gap2 items-center"},lle={key:0,"i-material-symbols-check-small":"","text-primary-500":""},dle=["title"],ule={pb2:"","text-gray-500":""},hle={"text-primary-500":""},cle={flex:"~ col gap2 items-start"},fle=["onClick"],ple={p3:""},aB=1500,vle=oI({__name:"GraphDrawer",props:{top:{}},setup(n){const e=P7,t=ole,r=ps,i=Fte(),o=C=>{if(i.vitePluginDetected.value&&kte.value){Bte(C);return}A(C)},{copy:s,isSupported:a,copied:g}=Dte({copiedDuring:aB});function A(C){s(C),zte({message:"Copied to clipboard",type:"success",duration:aB})}const I=[["refs","references"],["deps","dependencies"]];return(C,l)=>(Xt(),Nte(Pe(qte),{modelValue:Pe(t),"onUpdate:modelValue":l[3]||(l[3]=d=>$X(t)?t.value=d:null),top:n.top,"close-outside":!1,permanent:!0,"content-blur":!0,position:"absolute","mount-to":".graph-body"},{default:$R(()=>[et("div",Ale,[et("div",Ile,[et("span",Cle,[wA($n(Pe(e)?.name)+" ",1),Pe(g)?(Xt(),ar("span",lle)):Pe(e)?(Xt(),ar("span",{key:1,hover:"op-100","i-carbon-copy":"","cursor-pointer":"","text-sm":"","op-50":"",class:Wo({"text-gray-200":!Pe(a)}),onClick:l[0]||(l[0]=d=>A(Pe(e).name))},null,2)):BO("",!0)]),et("button",{hover:"underline",truncate:"","text-left":"","text-gray-500":"",title:Pe(e)?.displayPath,onClick:l[1]||(l[1]=d=>o(Pe(e).path))},$n(Pe(e)?.displayPath),9,dle)]),(Xt(),ar(DA,null,NA(I,([d,u])=>et("div",{key:d,"max-h-60":"","of-auto":"","border-b":"","border-base":"",p3:"","text-sm":""},[et("div",ule,[et("span",hle,$n(Pe(e)?.[d].length),1),wA(" "+$n(u),1)]),et("div",cle,[(Xt(!0),ar(DA,null,NA(Pe(e)?.[d],h=>(Xt(),ar("button",{key:h.path,dark:"text-gray-200","of-hidden":"",truncate:"","ws-nowrap":"","pr-3":"","text-gray-800":"",hover:"underline",onClick:v=>o(h.path)},$n(h.displayPath),9,fle))),128))])])),64)),et("div",ple,[es(Pe(Mte),{type:"primary",onClick:l[2]||(l[2]=d=>r.value=Pe(e).path)},{default:$R(()=>[...l[4]||(l[4]=[wA(" Filter to this module ",-1)])]),_:1})])])]),_:1},8,["modelValue","top"]))}}),mle=oI({__name:"GraphFileType",setup(n){const{fileTypeData:e,fileTypeShow:t,toggleFileType:r}=QCe();return(i,o)=>(Xt(),ar("div",{absolute:"","bottom-0":"",grid:"","grid-cols-3":"","w-260px":"","gap-2":"","b-1":"","b-l-0":"","border-base":"","rounded-tr-lg":"","glass-effect":"",px4:"",py2:"","text-sm":"","transition-transform":"","duration-300":"",class:Wo(["group",{"translate-x-[calc(-100%+30px)] translate-y-[calc(100%-30px)]":!Pe(t)}])},[et("div",{class:Wo(["group",{"rounded-bl-lg opacity-0 group-hover:opacity-100":Pe(t)}]),absolute:"","right-0":"",h30px:"",w30px:"","cursor-pointer":"","rounded-tr-lg":"","bg-primary-500":"","text-white":"","transition-opacity":"",flex:"~ justify-center items-center",onClick:o[0]||(o[0]=()=>Pe(r)())},[et("div",{"transition-transform":"",class:Wo([Pe(t)?"i-material-symbols-arrow-downward-alt rotate-45 hover:translate-x--10% hover:translate-y-10%":"i-mdi-file-outline"])},null,2)],2),(Xt(!0),ar(DA,null,NA(Pe(e),s=>(Xt(),ar("div",{key:s.key,flex:"","items-center":"","gap-2":""},[et("div",{h12px:"",w12px:"","rounded-full":"",style:jte({backgroundColor:s.color})},null,4),et("span",{class:Wo([s.capitalize?"capitalize":"uppercase"])},$n(s.key),3)]))),128))],2))}}),yle={flex:"~ items-center gap-4 nowrap",class:"[&_>*]:flex-[0_0_auto]",absolute:"","left-0":"","top-0":"","z-10":"","navbar-base":"","w-full":"","overflow-x-auto":"","glass-effect":"",px4:"","text-sm":""},ble=oI({__name:"GraphNavbar",setup(n){const e=yT,t=Ma,r=[["node_modules"],["virtual","virtual module"],["lib","library module"]],i=ps;return(o,s)=>(Xt(),ar("div",yle,[es(Pe(Lte),{modelValue:Pe(e),"onUpdate:modelValue":s[0]||(s[0]=a=>$X(e)?e.value=a:null),placeholder:"Search modules..."},null,8,["modelValue"]),(Xt(),ar(DA,null,NA(r,a=>et("div",{key:a[0],flex:"~ gap-2 items-center"},[es(Pe(Gte),{modelValue:Pe(t)[a[0]],"onUpdate:modelValue":g=>Pe(t)[a[0]]=g},null,8,["modelValue","onUpdate:modelValue"]),et("span",{class:Wo({"text-gray-400 dark:text-gray-600":!Pe(t)[a[0]]})},"Show "+$n(a[1]??a[0]),3)])),64)),s[3]||(s[3]=et("div",{"flex-auto":""},null,-1)),Pe(i)?(Xt(),ar("button",{key:0,"rounded-full":"","bg-gray:20":"",py1:"",pl3:"",pr2:"","text-xs":"",op50:"","hover:op100":"",onClick:s[1]||(s[1]=a=>i.value="")},[...s[2]||(s[2]=[wA(" Clear filter ",-1),et("div",{"i-carbon-close":"",mb2px:""},null,-1)])])):BO("",!0)]))}});/**
938
938
  * vis-data
939
939
  * http://visjs.org/
940
940
  *