@antv/layout 1.0.0-alpha.0 → 1.0.0-alpha.10

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.
@@ -1,2 +0,0 @@
1
- (()=>{"use strict";var e={d:(t,r)=>{for(var a in r)e.o(r,a)&&!e.o(t,a)&&Object.defineProperty(t,a,{enumerable:!0,get:r[a]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t)},t={};e.d(t,{calculateLayout:()=>f});class r{nodeMap=new Map;edgeMap=new Map;inEdgesMap=new Map;outEdgesMap=new Map;treeIndices=new Map;changes=[];batchCount=0;onChanged=()=>{};constructor(e){e&&(e.nodes&&this.addNodes(e.nodes),e.edges&&this.addEdges(e.edges),e.tree&&this.addTree(e.tree),e.onChanged&&(this.onChanged=e.onChanged))}batch=e=>{this.batchCount+=1,e(),this.batchCount-=1,this.batchCount||this.commit()};commit(){const e=this.changes;this.changes=[],this.onChanged({graph:this,changes:e})}reduceChanges(e){let t=[];return e.forEach((e=>{switch(e.type){case"NodeRemoved":{let r=!1;t=t.filter((t=>{if("NodeAdded"===t.type){const a=t.value.id===e.value.id;return a&&(r=!0),!a}return"NodeDataUpdated"===t.type?t.id!==e.value.id:"TreeStructureChanged"!==t.type||t.nodeId!==e.value.id})),r||t.push(e);break}case"EdgeRemoved":{let r=!1;t=t.filter((t=>{if("EdgeAdded"===t.type){const a=t.value.id===e.value.id;return a&&(r=!0),!a}return"EdgeDataUpdated"!==t.type&&"EdgeUpdated"!==t.type||t.id!==e.value.id})),r||t.push(e);break}case"NodeDataUpdated":case"EdgeDataUpdated":case"EdgeUpdated":{const r=t.find((t=>t.type===e.type&&t.id===e.id&&t.propertyName===e.propertyName));r?r.newValue=e.newValue:t.push(e);break}case"TreeStructureDetached":t=t.filter((t=>"TreeStructureAttached"===t.type?t.treeKey!==e.treeKey:"TreeStructureChanged"!==t.type||t.treeKey!==e.treeKey)),t.push(e);break;case"TreeStructureChanged":{const r=t.find((t=>"TreeStructureChanged"===t.type&&t.treeKey===e.treeKey&&t.nodeId===e.nodeId));r?r.newParentId=e.newParentId:t.push(e);break}default:t.push(e)}})),t}checkNodeExistence(e){if(!this.hasNode(e))throw new Error("Node not found for id: "+e)}hasNode(e){return this.nodeMap.has(e)}areNeighbors(e,t){return this.checkNodeExistence(e),this.getNeighbors(t).some((t=>t.id===e))}getNode(e){return this.checkNodeExistence(e),this.nodeMap.get(e)}getRelatedEdges(e,t){this.checkNodeExistence(e);const r=this.inEdgesMap.get(e),a=this.outEdgesMap.get(e);if("in"===t)return Array.from(r);if("out"===t)return Array.from(a);const d=new Set([...r,...a]);return Array.from(d)}getDegree(e,t){return this.getRelatedEdges(e,t).length}getSuccessors(e){const t=this.getRelatedEdges(e,"out").map((e=>e.target));return Array.from(new Set(t)).map((e=>this.getNode(e)))}getPredecessors(e){const t=this.getRelatedEdges(e,"in").map((e=>e.source));return Array.from(new Set(t)).map((e=>this.getNode(e)))}getNeighbors(e){const t=this.getPredecessors(e),r=this.getSuccessors(e);return Array.from(new Set([...t,...r]))}doAddNode(e){if(this.hasNode(e.id))throw new Error("Node already exists: "+e.id);this.nodeMap.set(e.id,e),this.inEdgesMap.set(e.id,new Set),this.outEdgesMap.set(e.id,new Set),this.treeIndices.forEach((t=>{t.childrenMap.set(e.id,new Set)})),this.changes.push({type:"NodeAdded",value:e})}addNodes(e){this.batch((()=>{for(const t of e)this.doAddNode(t)}))}addNode(e){this.addNodes([e])}doRemoveNode(e){const t=this.getNode(e),r=this.inEdgesMap.get(e),a=this.outEdgesMap.get(e);r?.forEach((e=>this.doRemoveEdge(e.id))),a?.forEach((e=>this.doRemoveEdge(e.id))),this.nodeMap.delete(e),this.treeIndices.forEach((t=>{t.childrenMap.get(e)?.forEach((e=>{t.parentMap.delete(e.id)})),t.parentMap.delete(e),t.childrenMap.delete(e)})),this.changes.push({type:"NodeRemoved",value:t})}removeNodes(e){this.batch((()=>{e.forEach((e=>this.doRemoveNode(e)))}))}removeNode(e){this.removeNodes([e])}updateNodeData(e,t,r){const a=this.getNode(e);this.batch((()=>{const d=a.data[t],s=r;a.data[t]=s,this.changes.push({type:"NodeDataUpdated",id:e,propertyName:t,oldValue:d,newValue:s})}))}mergeNodeData(e,t){this.batch((()=>{Object.entries(t).forEach((([t,r])=>{this.updateNodeData(e,t,r)}))}))}checkEdgeExistence(e){if(!this.hasEdge(e))throw new Error("Edge not found for id: "+e)}hasEdge(e){return this.edgeMap.has(e)}getEdge(e){return this.checkEdgeExistence(e),this.edgeMap.get(e)}getEdgeDetail(e){const t=this.getEdge(e);return{edge:t,source:this.getNode(t.source),target:this.getNode(t.target)}}doAddEdge(e){if(this.hasEdge(e.id))throw new Error("Edge already exists: "+e.id);this.checkNodeExistence(e.source),this.checkNodeExistence(e.target),this.edgeMap.set(e.id,e);const t=this.inEdgesMap.get(e.target),r=this.outEdgesMap.get(e.source);t.add(e),r.add(e),this.changes.push({type:"EdgeAdded",value:e})}addEdges(e){this.batch((()=>{for(const t of e)this.doAddEdge(t)}))}addEdge(e){this.addEdges([e])}doRemoveEdge(e){const t=this.getEdge(e),r=this.outEdgesMap.get(t.source),a=this.inEdgesMap.get(t.target);r.delete(t),a.delete(t),this.edgeMap.delete(e),this.changes.push({type:"EdgeRemoved",value:t})}removeEdges(e){this.batch((()=>{e.forEach((e=>this.doRemoveEdge(e)))}))}removeEdge(e){this.removeEdges([e])}updateEdgeSource(e,t){const r=this.getEdge(e);this.checkNodeExistence(t);const a=r.source,d=t;this.outEdgesMap.get(a).delete(r),this.outEdgesMap.get(d).add(r),r.source=t,this.batch((()=>{this.changes.push({type:"EdgeUpdated",id:e,propertyName:"source",oldValue:a,newValue:d})}))}updateEdgeTarget(e,t){const r=this.getEdge(e);this.checkNodeExistence(t);const a=r.target,d=t;this.inEdgesMap.get(a).delete(r),this.inEdgesMap.get(d).add(r),r.target=t,this.batch((()=>{this.changes.push({type:"EdgeUpdated",id:e,propertyName:"target",oldValue:a,newValue:d})}))}updateEdgeData(e,t,r){const a=this.getEdge(e);this.batch((()=>{const d=a.data[t],s=r;a.data[t]=s,this.changes.push({type:"EdgeDataUpdated",id:e,propertyName:t,oldValue:d,newValue:s})}))}mergeEdgeData(e,t){this.batch((()=>{Object.entries(t).forEach((([t,r])=>{this.updateEdgeData(e,t,r)}))}))}checkTreeExistence(e){if(!this.treeIndices.has(e))throw new Error("Tree structure not found for treeKey: "+e)}attachTreeStructure(e){this.treeIndices.has(e)||(this.treeIndices.set(e,{parentMap:new Map,childrenMap:new Map}),this.batch((()=>{this.changes.push({type:"TreeStructureAttached",treeKey:e})})))}detachTreeStructure(e){this.checkTreeExistence(e),this.treeIndices.delete(e),this.batch((()=>{this.changes.push({type:"TreeStructureDetached",treeKey:e})}))}addTree(e,t){this.batch((()=>{this.attachTreeStructure(t);const r=[],a=Array.isArray(e)?e:[e];for(;a.length;){const e=a.shift();r.push(e),e.children&&a.push(...e.children)}this.addNodes(r),r.forEach((e=>{e.children?.forEach((r=>{this.setParent(r.id,e.id,t)}))}))}))}getRoots(e){return this.checkTreeExistence(e),this.getAllNodes().filter((t=>!this.getParent(t.id,e)))}getChildren(e,t){this.checkNodeExistence(e),this.checkTreeExistence(t);const r=this.treeIndices.get(t).childrenMap.get(e);return Array.from(r||[])}getParent(e,t){return this.checkNodeExistence(e),this.checkTreeExistence(t),this.treeIndices.get(t).parentMap.get(e)||null}setParent(e,t,r){this.checkTreeExistence(r);const a=this.treeIndices.get(r),d=this.getNode(e),s=a.parentMap.get(e),n=this.getNode(t);a.parentMap.set(e,n),s&&a.childrenMap.get(s.id)?.delete(d);let i=a.childrenMap.get(n.id);i||(i=new Set,a.childrenMap.set(n.id,i)),i.add(d),this.batch((()=>{this.changes.push({type:"TreeStructureChanged",treeKey:r,nodeId:e,oldParentId:s?.id,newParentId:n.id})}))}getAllNodes(){return Array.from(this.nodeMap.values())}getAllEdges(){return Array.from(this.edgeMap.values())}doBFS(e,t,r){for(;e.length;){const a=e.shift();r(a),t.add(a.id),this.getSuccessors(a.id).forEach((r=>{t.has(r.id)||(t.add(r.id),e.push(r))}))}}bfs(e,t){this.doBFS([this.getNode(e)],new Set,t)}doDFS(e,t,r){r(e),t.add(e.id),this.getSuccessors(e.id).forEach((e=>{t.has(e.id)||this.doDFS(e,t,r)}))}dfs(e,t){this.doDFS(this.getNode(e),new Set,t)}clone(){const e=this.getAllNodes().map((e=>({...e,data:{...e.data}}))),t=this.getAllEdges().map((e=>({...e,data:{...e.data}}))),a=new r({nodes:e,edges:t});return this.treeIndices.forEach((({parentMap:e,childrenMap:t},r)=>{const d=new Map;e.forEach(((e,t)=>{d.set(t,a.getNode(e.id))}));const s=new Map;t.forEach(((e,t)=>{s.set(t,new Set(Array.from(e).map((e=>a.getNode(e.id)))))})),a.treeIndices.set(r,{parentMap:d,childrenMap:s})})),a}toJSON(){return JSON.stringify({nodes:this.getAllNodes(),edges:this.getAllEdges()})}}var a=function(){return a=Object.assign||function(e){for(var t,r=1,a=arguments.length;r<a;r++)for(var d in t=arguments[r])Object.prototype.hasOwnProperty.call(t,d)&&(e[d]=t[d]);return e},a.apply(this,arguments)};function d(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var a,d,s=r.call(e),n=[];try{for(;(void 0===t||t-- >0)&&!(a=s.next()).done;)n.push(a.value)}catch(e){d={error:e}}finally{try{a&&!a.done&&(r=s.return)&&r.call(s)}finally{if(d)throw d.error}}return n}Object.create,Object.create;var s=/-(\w)/g,n=(function(e){return e.replace(s,(function(e,t){return t?t.toUpperCase():""}))},Object.create(null),Array.isArray),i=function(e){return null!==e&&"object"==typeof e},o=function(e){if(null===e)return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Array){var t=[];return e.forEach((function(e){t.push(e)})),t.map((function(e){return o(e)}))}if("object"==typeof e&&Object.keys(e).length){var r=a({},e);return Object.keys(r).forEach((function(e){r[e]=o(r[e])})),r}return e},h=function(e,t){var r=e[t];return i(r)?r.cell:r},c=function(e,t,r){return void 0===r&&(r=!0),t||0===t?"function"==typeof t?t:"number"==typeof t?function(){return t}:n(t)?function(){if(r){var a=Math.max.apply(Math,function(e,t,r){if(r||2===arguments.length)for(var a,d=0,s=t.length;d<s;d++)!a&&d in t||(a||(a=Array.prototype.slice.call(t,0,d)),a[d]=t[d]);return e.concat(a||Array.prototype.slice.call(t))}([],d(t),!1));return isNaN(a)?e:a}return t}:i(t)?function(){if(r){var a=Math.max(t.width,t.height);return isNaN(a)?e:a}return[t.width,t.height]}:function(){return e}:function(t){return t.size?n(t.size)?t.size[0]>t.size[1]?t.size[0]:t.size[1]:i(t.size)?t.size.width>t.size.height?t.size.width:t.size.height:t.size:e}},u={radius:null,startRadius:null,endRadius:null,startAngle:0,endAngle:2*Math.PI,clockwise:!0,divisions:1,ordering:null,angleRatio:1};function g(e,t){var r=e.degree,a=t.degree;return r<a?-1:r>a?1:0}function p(e,t,r,a,d){void 0===d&&(d=!1);var s=o(t),n=[s[0]],i=[t[0]],c=[],u=t.length;c[0]=!0,function(e,t,r,a){e.forEach((function(t,r){e[r].children=[],e[r].parent=[]})),a?t.forEach((function(t){var a=h(t,"source"),d=h(t,"target"),s=0;a&&(s=r[a]);var n=0;d&&(n=r[d]);var i=e[s].children,o=e[n].parent;i.push(e[n].id),o.push(e[s].id)})):t.forEach((function(t){var a=h(t,"source"),d=h(t,"target"),s=0;a&&(s=r[a]);var n=0;d&&(n=r[d]);var i=e[s].children,o=e[n].children;i.push(e[n].id),o.push(e[s].id)}))}(s,r,a,d);var g=0;return s.forEach((function(d,o){if(0!==o)if(o!==u-1&&e[o].all===e[o+1].all&&!function(e,t,r){for(var a=r.length,d=0;d<a;d++){var s=h(r[d],"source"),n=h(r[d],"target");if(e.id===s&&t.id===n||t.id===s&&e.id===n)return!0}return!1}(n[g],d,r)||c[o]){for(var p=n[g].children,l=!1,f=0;f<p.length;f++){var E=a[p[f]];if(e[E].all===e[o].all&&!c[E]){n.push(s[E]),i.push(t[a[s[E].id]]),c[E]=!0,l=!0;break}}for(var y=0;!l&&(c[y]||(n.push(s[y]),i.push(t[a[s[y].id]]),c[y]=!0,l=!0),++y!==u););}else n.push(d),i.push(t[a[d.id]]),c[o]=!0,g++})),i}var l={circular:function(){function e(e){void 0===e&&(e={}),this.options=e,this.id="circular",Object.assign(this.options,u,e)}return e.prototype.execute=function(e,t){return this.genericCircularLayout(!1,e,t)},e.prototype.assign=function(e,t){var r=this;e.batch((function(){r.genericCircularLayout(!0,e,t)}))},e.prototype.genericCircularLayout=function(e,t,r){var s=a(a({},this.options),r),n=s.width,i=s.height,o=s.center,u=s.divisions,l=s.startAngle,f=void 0===l?0:l,E=s.endAngle,y=void 0===E?2*Math.PI:E,v=s.angleRatio,N=s.ordering,M=s.clockwise,w=s.nodeSpacing,m=s.nodeSize,b=s.onLayoutEnd,A=t.getAllNodes(),S=t.getAllEdges(),k=A.length;if(0===k)return b&&b(),{nodes:[],edges:[]};var x=d(function(e,t,r){var a=e,d=t,s=r;return a||"undefined"==typeof window||(a=window.innerWidth),d||"undefined"==typeof window||(d=window.innerHeight),s||(s=[a/2,d/2]),[a,d,s]}(n,i,o),3),I=x[0],R=x[1],C=x[2];if(1===k)return e&&(t.updateNodeData(A[0].id,"x",C[0]),t.updateNodeData(A[0].id,"y",C[1])),b&&b(),{nodes:[{id:"".concat(A[0].id),x:C[0],y:C[1]}],edges:[]};var D=(y-f)/k,P={};A.forEach((function(e,t){P[e.id]=t}));var T=function(e,t,r){for(var a=[],d=0;d<e;d++)a[d]={in:0,out:0,all:0};return r?(r.forEach((function(e){var r=h(e,"source"),d=h(e,"target");r&&a[t[r]]&&(a[t[r]].out+=1,a[t[r]].all+=1),d&&a[t[d]]&&(a[t[d]].in+=1,a[t[d]].all+=1)})),a):a}(A.length,P,S),O=s.radius,j=s.startRadius,z=s.endRadius;if(w){var U=c(10,w),K=c(10,m),V=-1/0;A.forEach((function(e){var t=K(e);V<t&&(V=t)}));var L=0;A.forEach((function(e,t){L+=0===t?V||10:(U(e)||0)+(V||10)})),O=L/(2*Math.PI)}else O||j||z?!j&&z?j=z:j&&!z&&(z=j):O=R>I?I/2:R/2;var F=D*v,B=[],J=A.map((function(e){return e.data}));B="topology"===N?p(T,J,S,P):"topology-directed"===N?p(T,J,S,P,!0):"degree"===N?function(e,t){var r=[];return t.forEach((function(t,a){t.degree=e[a].all,r.push(t)})),r.sort(g),r}(T,J):A;for(var H=Math.ceil(k/u),W=0;W<k;++W){var q=O;q||null===j||null===z||(q=j+W*(z-j)/(k-1)),q||(q=10+100*W/(k-1));var G=f+W%H*F+2*Math.PI/u*Math.floor(W/H);M||(G=y-W%H*F-2*Math.PI/u*Math.floor(W/H)),B[W].x=C[0]+Math.cos(G)*q,B[W].y=C[1]+Math.sin(G)*q,B[W].weight=T[W].all}return e&&B.forEach((function(e){t.mergeNodeData(e.id,{x:e.x,y:e.y,weight:e.weight})})),b&&b(),{nodes:B,edges:S}},e}()};function f(e,t){var a=e.layout,d=a.id,s=a.options,n=e.nodes,i=e.edges,o=new r({nodes:n,edges:i}),h=l[d];if(!h)throw new Error("Unknown layout id: "+d);return[new h(s).execute(o),t]}addEventListener("message",(function(e){var r,a=e.data,d=a.type,s=a.method,n=a.id,i=a.params;"RPC"===d&&s&&((r=t[s])?Promise.resolve().then((function(){return r.apply(t,i)})):Promise.reject("No such method")).then((function(e){postMessage({type:"RPC",id:n,result:e})})).catch((function(e){var t={message:e};e.stack&&(t.message=e.message,t.stack=e.stack,t.name=e.name),postMessage({type:"RPC",id:n,error:t})}))})),postMessage({type:"RPC",method:"ready"})})();
2
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"3a54d760230d1933f953.worker.js","mappings":"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","sources":["webpack://Layout/webpack/bootstrap","webpack://Layout/webpack/runtime/define property getters","webpack://Layout/webpack/runtime/hasOwnProperty shorthand","webpack://Layout/../../node_modules/@antv/graphlib/esm/Graph.js","webpack://Layout/../../node_modules/tslib/tslib.es6.js","webpack://Layout/./src/util/string.ts","webpack://Layout/./src/util/array.ts","webpack://Layout/./src/util/object.ts","webpack://Layout/./src/util/math.ts","webpack://Layout/./src/util/function.ts","webpack://Layout/./src/util/number.ts","webpack://Layout/./src/circular.ts","webpack://Layout/./src/registry.ts","webpack://Layout/./src/worker.ts"],"sourcesContent":["// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","export class Graph {\n    nodeMap = new Map();\n    edgeMap = new Map();\n    inEdgesMap = new Map();\n    outEdgesMap = new Map();\n    treeIndices = new Map();\n    changes = [];\n    batchCount = 0;\n    /**\n     * This function is called with a {@link GraphChangedEvent} each time a graph change happened.\n     *\n     * `event.changes` contains all the graph changes in order since last `onChanged`.\n     */\n    onChanged = () => {\n        // Do nothing.\n    };\n    /**\n     * Create a new Graph instance.\n     * @param options - The options to initialize a graph. See {@link GraphOptions}.\n     *\n     * ```ts\n     * const graph = new Graph({\n     *   // Optional, initial nodes.\n     *   nodes: [\n     *     // Each node has a unique ID.\n     *     { id: 'A', foo: 1 },\n     *     { id: 'B', foo: 1 },\n     *   ],\n     *   // Optional, initial edges.\n     *   edges: [\n     *     { id: 'C', source: 'B', target: 'B', weight: 1 },\n     *   ],\n     *   // Optional, called with a GraphChangedEvent.\n     *   onChanged: (event) => {\n     *     console.log(event);\n     *   }\n     * });\n     * ```\n     */\n    constructor(options) {\n        if (!options)\n            return;\n        if (options.nodes)\n            this.addNodes(options.nodes);\n        if (options.edges)\n            this.addEdges(options.edges);\n        if (options.tree)\n            this.addTree(options.tree);\n        if (options.onChanged)\n            this.onChanged = options.onChanged;\n    }\n    /**\n     * Batch several graph changes into one.\n     *\n     * Make several changes, but dispatch only one ChangedEvent at the end of batch:\n     * ```ts\n     * graph.batch(() => {\n     *   graph.addNodes([]);\n     *   graph.addEdges([]);\n     * });\n     * ```\n     *\n     * Batches can be nested. Only the outermost batch will dispatch a ChangedEvent:\n     * ```ts\n     * graph.batch(() => {\n     *   graph.addNodes([]);\n     *   graph.batch(() => {\n     *     graph.addEdges([]);\n     *   });\n     * });\n     * ```\n     */\n    batch = (fn) => {\n        this.batchCount += 1;\n        fn();\n        this.batchCount -= 1;\n        if (!this.batchCount) {\n            this.commit();\n        }\n    };\n    /**\n     * Reset changes and dispatch a ChangedEvent.\n     */\n    commit() {\n        const changes = this.changes;\n        this.changes = [];\n        this.onChanged({\n            graph: this,\n            changes,\n        });\n    }\n    /**\n     * Reduce the number of ordered graph changes by dropping or merging unnecessary changes.\n     *\n     * For example, if we update a node and remove it in a batch:\n     *\n     * ```ts\n     * graph.batch(() => {\n     *   graph.updateNodeData('A', 'foo', 2);\n     *   graph.removeNode('A');\n     * });\n     * ```\n     *\n     * We get 2 atomic graph changes like\n     *\n     * ```ts\n     * [\n     *   { type: 'NodeDataUpdated', id: 'A', propertyName: 'foo', oldValue: 1, newValue: 2 },\n     *   { type: 'NodeRemoved', value: { id: 'A', data: { foo: 2 } },\n     * ]\n     * ```\n     *\n     * Since node 'A' has been removed, we actually have no need to handle with NodeDataUpdated change.\n     *\n     * `reduceChanges()` here helps us remove such changes.\n     */\n    reduceChanges(changes) {\n        let mergedChanges = [];\n        changes.forEach((change) => {\n            switch (change.type) {\n                case 'NodeRemoved': {\n                    // NodeAdded: A added.\n                    // NodeDataUpdated: A changed.\n                    // TreeStructureChanged: A's parent changed.\n                    // NodeRemoved: A removed. 👈🏻 Since A was removed, above three changes may be ignored.\n                    let isNewlyAdded = false;\n                    mergedChanges = mergedChanges.filter((pastChange) => {\n                        if (pastChange.type === 'NodeAdded') {\n                            const sameId = pastChange.value.id === change.value.id;\n                            if (sameId) {\n                                isNewlyAdded = true;\n                            }\n                            return !sameId;\n                        }\n                        else if (pastChange.type === 'NodeDataUpdated') {\n                            return pastChange.id !== change.value.id;\n                        }\n                        else if (pastChange.type === 'TreeStructureChanged') {\n                            return pastChange.nodeId !== change.value.id;\n                        }\n                        return true;\n                    });\n                    if (!isNewlyAdded) {\n                        mergedChanges.push(change);\n                    }\n                    break;\n                }\n                case 'EdgeRemoved': {\n                    // EdgeAdded: A added.\n                    // EdgeDataUpdated: A changed.\n                    // EdgeDataUpdated: A's source/target changed.\n                    // EdgeRemoved: A removed. 👈🏻 Since A was removed, above three changes may be ignored.\n                    let isNewlyAdded = false;\n                    mergedChanges = mergedChanges.filter((pastChange) => {\n                        if (pastChange.type === 'EdgeAdded') {\n                            const sameId = pastChange.value.id === change.value.id;\n                            if (sameId) {\n                                isNewlyAdded = true;\n                            }\n                            return !sameId;\n                        }\n                        else if (pastChange.type === 'EdgeDataUpdated' ||\n                            pastChange.type === 'EdgeUpdated') {\n                            return pastChange.id !== change.value.id;\n                        }\n                        return true;\n                    });\n                    if (!isNewlyAdded) {\n                        mergedChanges.push(change);\n                    }\n                    break;\n                }\n                case 'NodeDataUpdated':\n                case 'EdgeDataUpdated':\n                case 'EdgeUpdated': {\n                    // NodeDataUpdated: { id: A, propertyName: 'foo', oldValue: 1, newValue: 2 }.\n                    // NodeDataUpdated: { id: A, propertyName: 'foo', oldValue: 2, newValue: 3 }.\n                    // 👆 Could be merged as { id: A, propertyName: 'foo', oldValue: 1, newValue: 3 }.\n                    const existingChange = mergedChanges.find((pastChange) => {\n                        return (pastChange.type === change.type &&\n                            pastChange.id === change.id &&\n                            pastChange.propertyName === change.propertyName);\n                    });\n                    if (existingChange) {\n                        existingChange.newValue = change.newValue;\n                    }\n                    else {\n                        mergedChanges.push(change);\n                    }\n                    break;\n                }\n                case 'TreeStructureDetached': {\n                    // TreeStructureAttached\n                    // TreeStructureChanged\n                    // TreeStructureDetached 👈🏻 Since the tree struct was detached, above 2 changes may be ignored.\n                    mergedChanges = mergedChanges.filter((pastChange) => {\n                        if (pastChange.type === 'TreeStructureAttached') {\n                            return pastChange.treeKey !== change.treeKey;\n                        }\n                        else if (pastChange.type === 'TreeStructureChanged') {\n                            return pastChange.treeKey !== change.treeKey;\n                        }\n                        return true;\n                    });\n                    mergedChanges.push(change);\n                    break;\n                }\n                case 'TreeStructureChanged': {\n                    const existingChange = mergedChanges.find((pastChange) => {\n                        return (pastChange.type === 'TreeStructureChanged' &&\n                            pastChange.treeKey === change.treeKey &&\n                            pastChange.nodeId === change.nodeId);\n                    });\n                    if (existingChange) {\n                        existingChange.newParentId =\n                            change.newParentId;\n                    }\n                    else {\n                        mergedChanges.push(change);\n                    }\n                    break;\n                }\n                default:\n                    mergedChanges.push(change);\n                    break;\n            }\n        });\n        return mergedChanges;\n    }\n    // ================= Node =================\n    checkNodeExistence(id) {\n        if (!this.hasNode(id)) {\n            throw new Error('Node not found for id: ' + id);\n        }\n    }\n    /**\n     * Check if a node exists in the graph.\n     * @group NodeMethods\n     */\n    hasNode(id) {\n        return this.nodeMap.has(id);\n    }\n    /**\n     * Tell if two nodes are neighbors.\n     * @group NodeMethods\n     */\n    areNeighbors(firstNodeId, secondNodeId) {\n        this.checkNodeExistence(firstNodeId);\n        return this.getNeighbors(secondNodeId).some((neighbor) => neighbor.id === firstNodeId);\n    }\n    /**\n     * Get the node data with given ID.\n     * @group NodeMethods\n     */\n    getNode(id) {\n        this.checkNodeExistence(id);\n        return this.nodeMap.get(id);\n    }\n    /**\n     * Given a node ID, find all edges of the node.\n     * @param id - ID of the node\n     * @param direction - Edge direction, defaults to 'both'.\n     * @group NodeMethods\n     */\n    getRelatedEdges(id, direction) {\n        this.checkNodeExistence(id);\n        const inEdges = this.inEdgesMap.get(id);\n        const outEdges = this.outEdgesMap.get(id);\n        if (direction === 'in') {\n            return Array.from(inEdges);\n        }\n        else if (direction === 'out') {\n            return Array.from(outEdges);\n        }\n        const bothEdges = new Set([...inEdges, ...outEdges]);\n        return Array.from(bothEdges);\n    }\n    /**\n     * Get the degree of the given node.\n     * @group NodeMethods\n     */\n    getDegree(id, direction) {\n        return this.getRelatedEdges(id, direction).length;\n    }\n    /**\n     * Get all successors of the given node.\n     */\n    getSuccessors(id) {\n        const outEdges = this.getRelatedEdges(id, 'out');\n        const targets = outEdges.map((edge) => edge.target);\n        return Array.from(new Set(targets)).map((id) => this.getNode(id));\n    }\n    /**\n     * Get all predecessors of the given node.\n     */\n    getPredecessors(id) {\n        const inEdges = this.getRelatedEdges(id, 'in');\n        const sources = inEdges.map((edge) => edge.source);\n        return Array.from(new Set(sources)).map((id) => this.getNode(id));\n    }\n    /**\n     * Given a node ID, find its neighbors.\n     * @param id - ID of the node\n     * @group NodeMethods\n     */\n    getNeighbors(id) {\n        const predecessors = this.getPredecessors(id);\n        const successors = this.getSuccessors(id);\n        return Array.from(new Set([...predecessors, ...successors]));\n    }\n    doAddNode(node) {\n        if (this.hasNode(node.id)) {\n            throw new Error('Node already exists: ' + node.id);\n        }\n        this.nodeMap.set(node.id, node);\n        this.inEdgesMap.set(node.id, new Set());\n        this.outEdgesMap.set(node.id, new Set());\n        this.treeIndices.forEach((tree) => {\n            tree.childrenMap.set(node.id, new Set());\n        });\n        this.changes.push({ type: 'NodeAdded', value: node });\n    }\n    /**\n     * Add all nodes of the given array, or iterable, into the graph.\n     * @group NodeMethods\n     */\n    addNodes(nodes) {\n        this.batch(() => {\n            for (const node of nodes) {\n                this.doAddNode(node);\n            }\n        });\n    }\n    /**\n     * Add a single node into the graph.\n     * @group NodeMethods\n     */\n    addNode(node) {\n        this.addNodes([node]);\n    }\n    doRemoveNode(id) {\n        const node = this.getNode(id);\n        const inEdges = this.inEdgesMap.get(id);\n        const outEdges = this.outEdgesMap.get(id);\n        inEdges?.forEach((edge) => this.doRemoveEdge(edge.id));\n        outEdges?.forEach((edge) => this.doRemoveEdge(edge.id));\n        this.nodeMap.delete(id);\n        this.treeIndices.forEach((tree) => {\n            tree.childrenMap.get(id)?.forEach((child) => {\n                tree.parentMap.delete(child.id);\n            });\n            tree.parentMap.delete(id);\n            tree.childrenMap.delete(id);\n        });\n        this.changes.push({ type: 'NodeRemoved', value: node });\n    }\n    /**\n     * Remove nodes and their attached edges from the graph.\n     * @group NodeMethods\n     */\n    removeNodes(idList) {\n        this.batch(() => {\n            idList.forEach((id) => this.doRemoveNode(id));\n        });\n    }\n    /**\n     * Remove a single node and its attached edges from the graph.\n     * @group NodeMethods\n     */\n    removeNode(id) {\n        this.removeNodes([id]);\n    }\n    /**\n     * Update node data.\n     * @group NodeMethods\n     */\n    updateNodeData(id, propertyName, value) {\n        const node = this.getNode(id);\n        this.batch(() => {\n            const oldValue = node.data[propertyName];\n            const newValue = value;\n            node.data[propertyName] = newValue;\n            this.changes.push({\n                type: 'NodeDataUpdated',\n                id,\n                propertyName,\n                oldValue,\n                newValue,\n            });\n        });\n    }\n    /**\n     * Like Object.assign, merge all properties of `path` to the node data.\n     * @param id Node ID.\n     * @param patch A data object to merge.\n     */\n    mergeNodeData(id, patch) {\n        this.batch(() => {\n            Object.entries(patch).forEach(([propertyName, value]) => {\n                this.updateNodeData(id, propertyName, value);\n            });\n        });\n    }\n    // ================= Edge =================\n    checkEdgeExistence(id) {\n        if (!this.hasEdge(id)) {\n            throw new Error('Edge not found for id: ' + id);\n        }\n    }\n    /**\n     * Check if an edge exists in the graph.\n     * @group NodeMethods\n     */\n    hasEdge(id) {\n        return this.edgeMap.has(id);\n    }\n    /**\n     * Get the edge data with given ID.\n     * @group EdgeMethods\n     */\n    getEdge(id) {\n        this.checkEdgeExistence(id);\n        return this.edgeMap.get(id);\n    }\n    /**\n     * Get the edge, the source node, and the target node by an edge ID.\n     * @group EdgeMethods\n     */\n    getEdgeDetail(id) {\n        const edge = this.getEdge(id);\n        return {\n            edge,\n            source: this.getNode(edge.source),\n            target: this.getNode(edge.target),\n        };\n    }\n    doAddEdge(edge) {\n        if (this.hasEdge(edge.id)) {\n            throw new Error('Edge already exists: ' + edge.id);\n        }\n        this.checkNodeExistence(edge.source);\n        this.checkNodeExistence(edge.target);\n        this.edgeMap.set(edge.id, edge);\n        const inEdges = this.inEdgesMap.get(edge.target);\n        const outEdges = this.outEdgesMap.get(edge.source);\n        inEdges.add(edge);\n        outEdges.add(edge);\n        this.changes.push({ type: 'EdgeAdded', value: edge });\n    }\n    /**\n     * Add all edges of the given iterable(an array, a set, etc.) into the graph.\n     * @group EdgeMethods\n     */\n    addEdges(edges) {\n        this.batch(() => {\n            for (const edge of edges) {\n                this.doAddEdge(edge);\n            }\n        });\n    }\n    /**\n     * Add a single edge pointing from `source` to `target` into the graph.\n     *\n     * ```ts\n     * graph.addNode({ id: 'NodeA' });\n     * graph.addNode({ id: 'NodeB' });\n     * graph.addEdge({ id: 'EdgeA', source: 'NodeA', target: 'NodeB' });\n     * ```\n     *\n     * If `source` or `target` were not found in the current graph, it throws an Error.\n     * @group EdgeMethods\n     */\n    addEdge(edge) {\n        this.addEdges([edge]);\n    }\n    doRemoveEdge(id) {\n        const edge = this.getEdge(id);\n        const outEdges = this.outEdgesMap.get(edge.source);\n        const inEdges = this.inEdgesMap.get(edge.target);\n        outEdges.delete(edge);\n        inEdges.delete(edge);\n        this.edgeMap.delete(id);\n        this.changes.push({ type: 'EdgeRemoved', value: edge });\n    }\n    /**\n     * Remove edges whose id was included in the given id list.\n     * @group EdgeMethods\n     */\n    removeEdges(idList) {\n        this.batch(() => {\n            idList.forEach((id) => this.doRemoveEdge(id));\n        });\n    }\n    /**\n     * Remove a single edge of the given id.\n     * @group EdgeMethods\n     */\n    removeEdge(id) {\n        this.removeEdges([id]);\n    }\n    /**\n     * Change the source of an edge. The source must be found in current graph.\n     * @group EdgeMethods\n     */\n    updateEdgeSource(id, source) {\n        const edge = this.getEdge(id);\n        this.checkNodeExistence(source);\n        const oldSource = edge.source;\n        const newSource = source;\n        this.outEdgesMap.get(oldSource).delete(edge);\n        this.outEdgesMap.get(newSource).add(edge);\n        edge.source = source;\n        this.batch(() => {\n            this.changes.push({\n                type: 'EdgeUpdated',\n                id,\n                propertyName: 'source',\n                oldValue: oldSource,\n                newValue: newSource,\n            });\n        });\n    }\n    /**\n     * Change the target of an edge. The target must be found in current graph.\n     * @group EdgeMethods\n     */\n    updateEdgeTarget(id, target) {\n        const edge = this.getEdge(id);\n        this.checkNodeExistence(target);\n        const oldTarget = edge.target;\n        const newTarget = target;\n        this.inEdgesMap.get(oldTarget).delete(edge);\n        this.inEdgesMap.get(newTarget).add(edge);\n        edge.target = target;\n        this.batch(() => {\n            this.changes.push({\n                type: 'EdgeUpdated',\n                id,\n                propertyName: 'target',\n                oldValue: oldTarget,\n                newValue: newTarget,\n            });\n        });\n    }\n    /**\n     * Update edge data.\n     * @group EdgeMethods\n     */\n    updateEdgeData(id, propertyName, value) {\n        const edge = this.getEdge(id);\n        this.batch(() => {\n            const oldValue = edge.data[propertyName];\n            const newValue = value;\n            edge.data[propertyName] = newValue;\n            this.changes.push({\n                type: 'EdgeDataUpdated',\n                id,\n                propertyName,\n                oldValue,\n                newValue,\n            });\n        });\n    }\n    /**\n     * @group EdgeMethods\n     */\n    mergeEdgeData(id, patch) {\n        this.batch(() => {\n            Object.entries(patch).forEach(([propertyName, value]) => {\n                this.updateEdgeData(id, propertyName, value);\n            });\n        });\n    }\n    // ================= Tree =================\n    checkTreeExistence(treeKey) {\n        if (!this.treeIndices.has(treeKey)) {\n            throw new Error('Tree structure not found for treeKey: ' + treeKey);\n        }\n    }\n    /**\n     * Attach a new tree structure representing the hierarchy of all nodes in the graph.\n     * @param treeKey A unique key of the tree structure. You can attach multiple tree structures with different keys.\n     *\n     * ```ts\n     * const graph = new Graph({\n     *   nodes: [{ id: 1 }, { id: 2 }, { id: 3 }],\n     * });\n     * graph.attachTreeStructure('Inheritance');\n     * graph.setParent(2, 1, 'Inheritance');\n     * graph.setParent(3, 1, 'Inheritance');\n     * graph.getRoots('Inheritance'); // [1]\n     * graph.getChildren(1, 'Inheritance'); // [2,3]\n     * ```\n     * @group TreeMethods\n     */\n    attachTreeStructure(treeKey) {\n        if (this.treeIndices.has(treeKey)) {\n            // Already attached.\n            return;\n        }\n        this.treeIndices.set(treeKey, {\n            parentMap: new Map(),\n            childrenMap: new Map(),\n        });\n        this.batch(() => {\n            this.changes.push({\n                type: 'TreeStructureAttached',\n                treeKey,\n            });\n        });\n    }\n    /**\n     * Detach the tree structure of the given tree key from the graph.\n     *\n     * ```ts\n     * graph.detachTreeStructure('Inheritance');\n     * graph.getRoots('Inheritance'); // Error!\n     * ```\n     * @group TreeMethods\n     */\n    detachTreeStructure(treeKey) {\n        this.checkTreeExistence(treeKey);\n        this.treeIndices.delete(treeKey);\n        this.batch(() => {\n            this.changes.push({\n                type: 'TreeStructureDetached',\n                treeKey,\n            });\n        });\n    }\n    /**\n     * Traverse the given tree data, add each node into the graph, then attach the tree structure.\n     *\n     * ```ts\n     * graph.addTree({\n     *   id: 1,\n     *   children: [\n     *     { id: 2 },\n     *     { id: 3 },\n     *   ],\n     * }, 'Inheritance');\n     * graph.getRoots('Inheritance'); // [1]\n     * graph.getChildren(1, 'Inheritance'); // [2, 3]\n     * graph.getAllNodes(); // [1, 2, 3]\n     * graph.getAllEdges(); // []\n     * ```\n     * @group TreeMethods\n     */\n    addTree(tree, treeKey) {\n        this.batch(() => {\n            this.attachTreeStructure(treeKey);\n            // Add Nodes\n            const nodes = [];\n            const stack = Array.isArray(tree) ? tree : [tree];\n            while (stack.length) {\n                const node = stack.shift();\n                nodes.push(node);\n                if (node.children) {\n                    stack.push(...node.children);\n                }\n            }\n            this.addNodes(nodes);\n            // Set parent for each child node.\n            nodes.forEach((parent) => {\n                parent.children?.forEach((child) => {\n                    this.setParent(child.id, parent.id, treeKey);\n                });\n            });\n        });\n    }\n    /**\n     * Get the root nodes of an attached tree structure.\n     *\n     * Consider a graph with the following tree structure attached:\n     * ```\n     * Tree structure:\n     *    O     3\n     *   / \\    |\n     *  1   2   4\n     * ```\n     * `graph.getRoots()` takes all nodes without a parent, therefore [0, 3] was returned.\n     *\n     * Newly added nodes are also unparented. So they are counted as roots.\n     * ```ts\n     * graph.addNode({ id: 5 });\n     * graph.getRoots(); // [0, 3, 5]\n     * ```\n     *\n     * Here is how the tree structure looks like:\n     * ```\n     * Tree structure:\n     *    O     3  5\n     *   / \\    |\n     *  1   2   4\n     * ```\n     *\n     * By setting a parent, a root node no more be a root.\n     * ```ts\n     * graph.setParent(5, 2);\n     * graph.getRoots(); // [0, 3]\n     * ```\n     *\n     * The tree structure now becomes:\n     * ```\n     * Tree structure:\n     *    O     3\n     *   / \\    |\n     *  1   2   4\n     *      |\n     *      5\n     * ```\n     *\n     * Removing a node forces its children to be unparented, or roots.\n     * ```ts\n     * graph.removeNode(0);\n     * graph.getRoots(); // [1, 2, 3]\n     * ```\n     *\n     * You might draw the the structure as follow:\n     * ```\n     * Tree structure:\n     *  1   2  3\n     *      |  |\n     *      5  4\n     * ```\n     * @group TreeMethods\n     */\n    getRoots(treeKey) {\n        this.checkTreeExistence(treeKey);\n        return this.getAllNodes().filter((node) => !this.getParent(node.id, treeKey));\n    }\n    /**\n     * Given a node ID and an optional tree key, get the children of the node in the specified tree structure.\n     * @group TreeMethods\n     */\n    getChildren(id, treeKey) {\n        this.checkNodeExistence(id);\n        this.checkTreeExistence(treeKey);\n        const tree = this.treeIndices.get(treeKey);\n        const children = tree.childrenMap.get(id);\n        return Array.from(children || []);\n    }\n    /**\n     * Given a node ID and an optional tree key, get the parent of the node in the specified tree structure.\n     * If the given node is one of the tree roots, this returns null.\n     * @group TreeMethods\n     */\n    getParent(id, treeKey) {\n        this.checkNodeExistence(id);\n        this.checkTreeExistence(treeKey);\n        const tree = this.treeIndices.get(treeKey);\n        return tree.parentMap.get(id) || null;\n    }\n    /**\n     * Set node parent. If this operation causes a circle, it fails with an error.\n     * @param id - ID of the child node.\n     * @param parent - ID of the parent node.\n     * @param treeKey - Which tree structure the relation is applied to.\n     * @group TreeMethods\n     */\n    setParent(id, parent, treeKey) {\n        this.checkTreeExistence(treeKey);\n        const tree = this.treeIndices.get(treeKey);\n        const node = this.getNode(id);\n        const oldParent = tree.parentMap.get(id);\n        const newParent = this.getNode(parent);\n        // Set parent\n        tree.parentMap.set(id, newParent);\n        // Set children\n        if (oldParent) {\n            tree.childrenMap.get(oldParent.id)?.delete(node);\n        }\n        let children = tree.childrenMap.get(newParent.id);\n        if (!children) {\n            children = new Set();\n            tree.childrenMap.set(newParent.id, children);\n        }\n        children.add(node);\n        this.batch(() => {\n            this.changes.push({\n                type: 'TreeStructureChanged',\n                treeKey,\n                nodeId: id,\n                oldParentId: oldParent?.id,\n                newParentId: newParent.id,\n            });\n        });\n    }\n    // ================= Graph =================\n    /**\n     * Get all nodes in the graph as an array.\n     */\n    getAllNodes() {\n        return Array.from(this.nodeMap.values());\n    }\n    /**\n     * Get all edges in the graph as an array.\n     */\n    getAllEdges() {\n        return Array.from(this.edgeMap.values());\n    }\n    doBFS(queue, visited, fn) {\n        while (queue.length) {\n            const node = queue.shift();\n            fn(node);\n            visited.add(node.id);\n            this.getSuccessors(node.id).forEach((n) => {\n                if (!visited.has(n.id)) {\n                    visited.add(n.id);\n                    queue.push(n);\n                }\n            });\n        }\n    }\n    bfs(id, fn) {\n        this.doBFS([this.getNode(id)], new Set(), fn);\n    }\n    doDFS(node, visited, fn) {\n        fn(node);\n        visited.add(node.id);\n        this.getSuccessors(node.id).forEach((n) => {\n            if (!visited.has(n.id)) {\n                this.doDFS(n, visited, fn);\n            }\n        });\n    }\n    dfs(id, fn) {\n        this.doDFS(this.getNode(id), new Set(), fn);\n    }\n    clone() {\n        // Make a shallow copy of nodes and edges.\n        const newNodes = this.getAllNodes().map((oldNode) => {\n            return { ...oldNode, data: { ...oldNode.data } };\n        });\n        const newEdges = this.getAllEdges().map((oldEdge) => {\n            return { ...oldEdge, data: { ...oldEdge.data } };\n        });\n        // Create a new graph with shallow copied nodes and edges.\n        const newGraph = new Graph({\n            nodes: newNodes,\n            edges: newEdges,\n        });\n        // Add tree indices.\n        this.treeIndices.forEach(({ parentMap: oldParentMap, childrenMap: oldChildrenMap }, treeKey) => {\n            const parentMap = new Map();\n            oldParentMap.forEach((parent, key) => {\n                parentMap.set(key, newGraph.getNode(parent.id));\n            });\n            const childrenMap = new Map();\n            oldChildrenMap.forEach((children, key) => {\n                childrenMap.set(key, new Set(Array.from(children).map((n) => newGraph.getNode(n.id))));\n            });\n            newGraph.treeIndices.set(treeKey, {\n                parentMap: parentMap,\n                childrenMap: childrenMap,\n            });\n        });\n        return newGraph;\n    }\n    toJSON() {\n        return JSON.stringify({\n            nodes: this.getAllNodes(),\n            edges: this.getAllEdges(),\n            // FIXME: And tree structures?\n        });\n    }\n}\n//# sourceMappingURL=Graph.js.map","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    if (typeof b !== \"function\" && b !== null)\r\n        throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    var desc = Object.getOwnPropertyDescriptor(m, k);\r\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n        desc = { enumerable: true, get: function() { return m[k]; } };\r\n    }\r\n    Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n        if (ar || !(i in from)) {\r\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n            ar[i] = from[i];\r\n        }\r\n    }\r\n    return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n    o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n    __setModuleDefault(result, mod);\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n    return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n    if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n    return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n    if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n    return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","export const isString = (val: unknown): val is string =>\n  typeof val === \"string\";\n\nconst cacheStringFunction = <T extends (str: string) => string>(fn: T): T => {\n  const cache: Record<string, string> = Object.create(null);\n  return ((str: string) => {\n    const hit = cache[str];\n    return hit || (cache[str] = fn(str));\n  }) as any;\n};\n\nconst camelizeRE = /-(\\w)/g;\nexport const camelize = cacheStringFunction((str: string): string => {\n  return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : \"\"));\n});\n\n// export const capitalize = cacheStringFunction(\n//   (str: string) => str.charAt(0).toUpperCase() + str.slice(1),\n// )\n","export const isArray = Array.isArray;\n","export const isObject = (val: unknown): val is Record<any, any> =>\n  val !== null && typeof val === \"object\";\n\nexport const clone = <T>(target: T): T => {\n  if (target === null) {\n    return target;\n  }\n  if (target instanceof Date) {\n    return new Date(target.getTime()) as any;\n  }\n  if (target instanceof Array) {\n    const cp = [] as any[];\n    (target as any[]).forEach((v) => {\n      cp.push(v);\n    });\n    return cp.map((n: any) => clone<any>(n)) as any;\n  }\n  if (typeof target === \"object\" && Object.keys(target).length) {\n    const cp = { ...(target as { [key: string]: any }) } as {\n      [key: string]: any;\n    };\n    Object.keys(cp).forEach((k) => {\n      cp[k] = clone<any>(cp[k]);\n    });\n    return cp as T;\n  }\n  return target;\n};\n","import {\n  Matrix,\n  Model,\n  IndexMap,\n  Edge,\n  Node,\n  OutNode,\n  Degree,\n  NodeMap,\n} from \"../types\";\nimport { isArray } from \"./array\";\nimport { isNumber } from \"./number\";\nimport { isObject } from \"./object\";\n\nexport const getEdgeTerminal = (edge: Edge, type: \"source\" | \"target\") => {\n  const terminal = edge[type];\n  if (isObject(terminal)) {\n    return terminal.cell;\n  }\n  return terminal;\n};\n\nexport const getDegree = (\n  n: number,\n  nodeIdxMap: IndexMap,\n  edges: Edge[] | null\n) => {\n  const degrees: Degree[] = [];\n  for (let i = 0; i < n; i++) {\n    degrees[i] = {\n      in: 0,\n      out: 0,\n      all: 0,\n    };\n  }\n  if (!edges) return degrees;\n  edges.forEach((e) => {\n    const source = getEdgeTerminal(e, \"source\");\n    const target = getEdgeTerminal(e, \"target\");\n    if (source && degrees[nodeIdxMap[source]]) {\n      degrees[nodeIdxMap[source]].out += 1;\n      degrees[nodeIdxMap[source]].all += 1;\n    }\n    if (target && degrees[nodeIdxMap[target]]) {\n      degrees[nodeIdxMap[target]].in += 1;\n      degrees[nodeIdxMap[target]].all += 1;\n    }\n  });\n  return degrees;\n};\n\nexport const getDegreeMap = (nodes: Node[], edges: Edge[] | null) => {\n  const degreesMap: { [id: string]: Degree } = {};\n  nodes.forEach((node) => {\n    degreesMap[node.id] = {\n      in: 0,\n      out: 0,\n      all: 0,\n    };\n  });\n\n  if (!edges) return degreesMap;\n  edges.forEach((e) => {\n    const source = getEdgeTerminal(e, \"source\");\n    const target = getEdgeTerminal(e, \"target\");\n    if (source) {\n      degreesMap[source].out += 1;\n      degreesMap[source].all += 1;\n    }\n    if (target) {\n      degreesMap[target].in += 1;\n      degreesMap[target].all += 1;\n    }\n  });\n  return degreesMap;\n};\n\nexport const floydWarshall = (adjMatrix: Matrix[]): Matrix[] => {\n  // initialize\n  const dist: Matrix[] = [];\n  const size = adjMatrix.length;\n  for (let i = 0; i < size; i += 1) {\n    dist[i] = [];\n    for (let j = 0; j < size; j += 1) {\n      if (i === j) {\n        dist[i][j] = 0;\n      } else if (adjMatrix[i][j] === 0 || !adjMatrix[i][j]) {\n        dist[i][j] = Infinity;\n      } else {\n        dist[i][j] = adjMatrix[i][j];\n      }\n    }\n  }\n  // floyd\n  for (let k = 0; k < size; k += 1) {\n    for (let i = 0; i < size; i += 1) {\n      for (let j = 0; j < size; j += 1) {\n        if (dist[i][j] > dist[i][k] + dist[k][j]) {\n          dist[i][j] = dist[i][k] + dist[k][j];\n        }\n      }\n    }\n  }\n  return dist;\n};\n\nexport const getAdjMatrix = (data: Model, directed: boolean): Matrix[] => {\n  const { nodes, edges } = data;\n  const matrix: Matrix[] = [];\n  // map node with index in data.nodes\n  const nodeMap: {\n    [key: string]: number;\n  } = {};\n\n  if (!nodes) {\n    throw new Error(\"invalid nodes data!\");\n  }\n  if (nodes) {\n    nodes.forEach((node, i) => {\n      nodeMap[node.id] = i;\n      const row: number[] = [];\n      matrix.push(row);\n    });\n  }\n\n  edges?.forEach((e) => {\n    const source = getEdgeTerminal(e, \"source\");\n    const target = getEdgeTerminal(e, \"target\");\n    const sIndex = nodeMap[source as string];\n    const tIndex = nodeMap[target as string];\n    if (sIndex === undefined || tIndex === undefined) return;\n    matrix[sIndex][tIndex] = 1;\n    if (!directed) {\n      matrix[tIndex][sIndex] = 1;\n    }\n  });\n  return matrix;\n};\n\n/**\n * scale matrix\n * @param matrix [ [], [], [] ]\n * @param ratio\n */\nexport const scaleMatrix = (matrix: Matrix[], ratio: number) => {\n  const result: Matrix[] = [];\n  matrix.forEach((row) => {\n    const newRow: number[] = [];\n    row.forEach((v) => {\n      newRow.push(v * ratio);\n    });\n    result.push(newRow);\n  });\n  return result;\n};\n\n/**\n * depth first traverse, from leaves to root, children in inverse order\n *  if the fn returns false, terminate the traverse\n */\nconst traverseUp = <T extends { children?: T[] }>(\n  data: T,\n  fn: (param: T) => boolean\n) => {\n  if (data && data.children) {\n    for (let i = data.children.length - 1; i >= 0; i--) {\n      if (!traverseUp(data.children[i], fn)) return;\n    }\n  }\n\n  if (!fn(data)) {\n    return false;\n  }\n  return true;\n};\n\n/**\n * depth first traverse, from leaves to root, children in inverse order\n * if the fn returns false, terminate the traverse\n */\nexport const traverseTreeUp = <T extends { children?: T[] }>(\n  data: T,\n  fn: (param: T) => boolean\n) => {\n  if (typeof fn !== \"function\") {\n    return;\n  }\n  traverseUp(data, fn);\n};\n\n/**\n * calculate the bounding box for the nodes according to their x, y, and size\n * @param nodes nodes in the layout\n * @returns\n */\nexport const getLayoutBBox = (nodes: OutNode[]) => {\n  let minX = Infinity;\n  let minY = Infinity;\n  let maxX = -Infinity;\n  let maxY = -Infinity;\n  nodes.forEach((node) => {\n    let size = node.size;\n    if (isArray(size)) {\n      if (size.length === 1) size = [size[0], size[0]];\n    } else if (isNumber(size)) {\n      size = [size, size];\n    } else if (size === undefined || isNaN(size as any)) {\n      size = [30, 30];\n    }\n\n    const halfSize = [size[0] / 2, size[1] / 2];\n    const left = node.x - halfSize[0];\n    const right = node.x + halfSize[0];\n    const top = node.y - halfSize[1];\n    const bottom = node.y + halfSize[1];\n\n    if (minX > left) minX = left;\n    if (minY > top) minY = top;\n    if (maxX < right) maxX = right;\n    if (maxY < bottom) maxY = bottom;\n  });\n  return { minX, minY, maxX, maxY };\n};\n\n/**\n * 获取节点集合的平均位置信息\n * @param nodes 节点集合\n * @returns 平局内置\n */\nexport const getAvgNodePosition = (nodes: OutNode[]) => {\n  const totalNodes = { x: 0, y: 0 };\n  nodes.forEach((node) => {\n    totalNodes.x += node.x || 0;\n    totalNodes.y += node.y || 0;\n  });\n  // 获取均值向量\n  const length = nodes.length || 1;\n  return {\n    x: totalNodes.x / length,\n    y: totalNodes.y / length,\n  };\n};\n\n// 找出指定节点关联的边的起点或终点\nconst getCoreNode = (type: \"source\" | \"target\", node: Node, edges: Edge[]) => {\n  if (type === \"source\") {\n    return (edges?.find((edge) => edge.target === node.id)?.source ||\n      {}) as Node;\n  }\n  return (edges?.find((edge) => edge.source === node.id)?.target || {}) as Node;\n};\n\n// 找出指定节点为起点或终点的所有一度叶子节点\nconst getRelativeNodeIds = (\n  type: \"source\" | \"target\" | \"both\",\n  coreNode: Node,\n  edges: Edge[]\n) => {\n  let relativeNodes: string[] = [];\n  switch (type) {\n    case \"source\":\n      relativeNodes = edges\n        ?.filter((edge) => edge.source === coreNode.id)\n        .map((edge) => edge.target);\n      break;\n    case \"target\":\n      relativeNodes = edges\n        ?.filter((edge) => edge.target === coreNode.id)\n        .map((edge) => edge.source);\n      break;\n    case \"both\":\n      relativeNodes = edges\n        ?.filter((edge) => edge.source === coreNode.id)\n        .map((edge) => edge.target)\n        .concat(\n          edges\n            ?.filter((edge) => edge.target === coreNode.id)\n            .map((edge) => edge.source)\n        );\n      break;\n    default:\n      break;\n  }\n  // 去重\n  const set = new Set(relativeNodes);\n  return Array.from(set);\n};\n// 找出同类型的节点\nconst getSameTypeNodes = (\n  type: \"leaf\" | \"all\",\n  nodeClusterBy: string,\n  node: Node,\n  relativeNodes: Node[],\n  degreesMap: { [id: string]: Degree }\n) => {\n  // @ts-ignore\n  const typeName = node[nodeClusterBy] || \"\";\n  // @ts-ignore\n  let sameTypeNodes =\n    relativeNodes?.filter((item) => item[nodeClusterBy] === typeName) || [];\n  if (type === \"leaf\") {\n    sameTypeNodes = sameTypeNodes.filter(\n      (node) => degreesMap[node.id]?.in === 0 || degreesMap[node.id]?.out === 0\n    );\n  }\n  return sameTypeNodes;\n};\n\n// 找出与指定节点关联的边的起点或终点出发的所有一度叶子节点\nexport const getCoreNodeAndRelativeLeafNodes = (\n  type: \"leaf\" | \"all\",\n  node: Node,\n  edges: Edge[],\n  nodeClusterBy: string,\n  degreesMap: { [id: string]: Degree },\n  nodeMap: NodeMap\n) => {\n  const { in: inDegree, out: outDegree } = degreesMap[node.id];\n  let coreNode: Node = node;\n  let relativeLeafNodes: Node[] = [];\n  if (inDegree === 0) {\n    // 如果为没有出边的叶子节点，则找出与它关联的边的起点出发的所有一度节点\n    coreNode = getCoreNode(\"source\", node, edges);\n    relativeLeafNodes = getRelativeNodeIds(\"both\", coreNode, edges).map(\n      (nodeId) => nodeMap[nodeId]\n    );\n  } else if (outDegree === 0) {\n    // 如果为没有入边边的叶子节点，则找出与它关联的边的起点出发的所有一度节点\n    coreNode = getCoreNode(\"target\", node, edges);\n    relativeLeafNodes = getRelativeNodeIds(\"both\", coreNode, edges).map(\n      (nodeId) => nodeMap[nodeId]\n    );\n  }\n  relativeLeafNodes = relativeLeafNodes.filter(\n    (node) =>\n      degreesMap[node.id] &&\n      (degreesMap[node.id].in === 0 || degreesMap[node.id].out === 0)\n  );\n  const sameTypeLeafNodes = getSameTypeNodes(\n    type,\n    nodeClusterBy,\n    node,\n    relativeLeafNodes,\n    degreesMap\n  );\n  return { coreNode, relativeLeafNodes, sameTypeLeafNodes };\n};\n","import { isArray, isObject } from \".\";\nimport { isNumber } from \"./number\";\n\nexport const isFunction = (val: unknown): val is Function =>\n  typeof val === \"function\";\n\nexport const getFunc = (\n  value: number,\n  defaultValue: number,\n  func?: ((d?: any) => number) | undefined\n): Function => {\n  let resultFunc;\n  if (func) {\n    resultFunc = func;\n  } else if (isNumber(value)) {\n    resultFunc = () => value;\n  } else {\n    resultFunc = () => defaultValue;\n  }\n  return resultFunc;\n};\n\nexport const getFuncByUnknownType = (\n  defaultValue: number,\n  value?:\n    | number\n    | number[]\n    | { width: number; height: number }\n    | ((d?: any) => number)\n    | undefined,\n  resultIsNumber: boolean = true\n): ((d?: any) => number | number[]) => {\n  if (!value && value !== 0) {\n    return (d) => {\n      if (d.size) {\n        if (isArray(d.size))\n          return d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n        if (isObject(d.size))\n          return d.size.width > d.size.height ? d.size.width : d.size.height;\n        return d.size;\n      }\n      return defaultValue;\n    };\n  }\n  if (isFunction(value)) {\n    return value;\n  }\n  if (isNumber(value)) {\n    return () => value;\n  }\n  if (isArray(value)) {\n    return () => {\n      if (resultIsNumber) {\n        const max = Math.max(...(value as number[]));\n        return isNaN(max) ? defaultValue : max;\n      }\n      return value;\n    };\n  }\n  if (isObject(value)) {\n    return () => {\n      if (resultIsNumber) {\n        const max = Math.max(value.width, value.height);\n        return isNaN(max) ? defaultValue : max;\n      }\n      return [value.width, value.height];\n    };\n  }\n  return () => defaultValue;\n};\n","export const isNumber = (val: unknown): val is Number =>\n  typeof val === \"number\";\n\nexport const isNaN = (num: unknown) => Number.isNaN(Number(num));\n\nexport const toNumber = (val: any): any => {\n  const n = parseFloat(val);\n  return isNaN(n) ? val : n;\n};\n","import type { Graph } from \"@antv/graphlib\";\nimport type { CircularLayoutOptions, SyncLayout, LayoutMapping, PointTuple, IndexMap, OutNode, Edge, Degree } from \"./types\";\nimport { getDegree, getEdgeTerminal, getFuncByUnknownType, clone } from \"./util\";\n\ntype INodeData = OutNode & {\n  degree: number;\n  size: number | PointTuple;\n  weight: number;\n  children: string[];\n  parent: string[];\n};\n\ntype IEdgeData = {};\n\nconst DEFAULTS_LAYOUT_OPTIONS: Partial<CircularLayoutOptions> = {\n  radius: null,\n  startRadius: null,\n  endRadius: null,\n  startAngle: 0,\n  endAngle: 2 * Math.PI,\n  clockwise: true,\n  divisions: 1,\n  ordering: null,\n  angleRatio: 1\n}\n\n/**\n * Layout arranging the nodes in a circle.\n * \n * @example\n * // Assign layout options when initialization.\n * const layout = new CircularLayout({ radius: 10 });\n * const positions = layout.execute(graph); // { nodes: [], edges: [] }\n * \n * // Or use different options later.\n * const layout = new CircularLayout({ radius: 10 });\n * const positions = layout.execute(graph, { radius: 20 }); // { nodes: [], edges: [] }\n * \n * // If you want to assign the positions directly to the nodes, use assign method.\n * layout.assign(graph, { radius: 20 });\n */\nexport class CircularLayout implements SyncLayout<CircularLayoutOptions> {\n  id = 'circular';\n\n  constructor(public options: CircularLayoutOptions = {} as CircularLayoutOptions) {\n    Object.assign(this.options, DEFAULTS_LAYOUT_OPTIONS, options);\n  }\n\n  /**\n   * Return the positions of nodes and edges(if needed).\n   */\n  execute(graph: Graph<INodeData, IEdgeData>, options?: CircularLayoutOptions): LayoutMapping {\n    return this.genericCircularLayout(false, graph, options) as LayoutMapping;\n  }\n\n  /**\n   * To directly assign the positions to the nodes.\n   */\n  assign(graph: Graph<INodeData, IEdgeData>, options?: CircularLayoutOptions) {\n    graph.batch(() => {\n      this.genericCircularLayout(true, graph, options);\n    });\n  }\n\n  private genericCircularLayout(assign: boolean, graph: Graph<INodeData, IEdgeData>, options?: CircularLayoutOptions): LayoutMapping | void {\n    const mergedOptions = { ...this.options, ...options };\n    const { width, height, center, divisions, startAngle = 0, endAngle = 2 * Math.PI, angleRatio, ordering, clockwise, nodeSpacing: paramNodeSpacing, nodeSize: paramNodeSize, onLayoutEnd } = mergedOptions;\n\n    const nodes = graph.getAllNodes();\n    const edges = graph.getAllEdges() as Edge[];\n    const n = nodes.length;\n\n    // Need no layout if there is no node.\n    if (n === 0) {\n      if (onLayoutEnd) {\n        onLayoutEnd();\n      }\n      return {\n        nodes: [],\n        edges: [],\n      };\n    }\n\n    // Calculate center according to `window` if not provided.\n    const [calculatedWidth, calculatedHeight, calculatedCenter] = calculateCenter(width, height, center);\n\n    // Layout easily if there is only one node.\n    if (n === 1) {\n      if (assign) {\n        graph.updateNodeData(nodes[0].id, \"x\", calculatedCenter[0]);\n        graph.updateNodeData(nodes[0].id, \"y\", calculatedCenter[1]);\n      }\n      \n      if (onLayoutEnd) {\n        onLayoutEnd();\n      }\n      return {\n        nodes: [\n          {\n            id: `${nodes[0].id}`,\n            x: calculatedCenter[0],\n            y: calculatedCenter[1],\n          }\n        ],\n        edges: [],\n      };\n    }\n\n    const angleStep = (endAngle - startAngle) / n;\n    const nodeMap: IndexMap = {};\n    nodes.forEach((node, i) => {\n      nodeMap[node.id] = i;\n    });\n    const degrees = getDegree(nodes.length, nodeMap, edges as Edge[]);\n\n    let { radius, startRadius, endRadius } = mergedOptions;\n    if (paramNodeSpacing) {\n      const nodeSpacing: Function = getFuncByUnknownType(10, paramNodeSpacing);\n      const nodeSize: Function = getFuncByUnknownType(10, paramNodeSize);\n      let maxNodeSize = -Infinity;\n      nodes.forEach((node) => {\n        const nSize = nodeSize(node);\n        if (maxNodeSize < nSize) maxNodeSize = nSize;\n      });\n      let length = 0;\n      nodes.forEach((node, i) => {\n        if (i === 0) length += (maxNodeSize || 10);\n        else length += (nodeSpacing(node) || 0) + (maxNodeSize || 10);\n      });\n      radius = length / (2 * Math.PI);\n    } else if (!radius && !startRadius && !endRadius) {\n      radius = calculatedHeight > calculatedWidth ? calculatedWidth / 2 : calculatedHeight / 2;\n    } else if (!startRadius && endRadius) {\n      startRadius = endRadius;\n    } else if (startRadius && !endRadius) {\n      endRadius = startRadius;\n    }\n    const astep = angleStep * angleRatio!;\n\n    let layoutNodes: any[] = [];\n    let nodesData = nodes.map((node) => node.data);\n    if (ordering === \"topology\") {\n      // layout according to the topology\n      layoutNodes = topologyOrdering(degrees, nodesData, edges, nodeMap);\n    } else if (ordering === \"topology-directed\") {\n      // layout according to the topology\n      layoutNodes = topologyOrdering(degrees, nodesData, edges, nodeMap, true);\n    } else if (ordering === \"degree\") {\n      // layout according to the descent order of degrees\n      layoutNodes = degreeOrdering(degrees, nodesData);\n    } else {\n      // layout according to the original order in the data.nodes\n      layoutNodes = nodes;\n    }\n\n    const divN = Math.ceil(n / divisions!); // node number in each division\n    for (let i = 0; i < n; ++i) {\n      let r = radius;\n      if (!r && startRadius !== null && endRadius !== null) {\n        r = startRadius! + (i * (endRadius! - startRadius!)) / (n - 1);\n      }\n      if (!r) {\n        r = 10 + (i * 100) / (n - 1);\n      }\n      let angle =\n        startAngle +\n        (i % divN) * astep +\n        ((2 * Math.PI) / divisions!) * Math.floor(i / divN);\n      if (!clockwise) {\n        angle =\n          endAngle -\n          (i % divN) * astep -\n          ((2 * Math.PI) / divisions!) * Math.floor(i / divN);\n      }\n      layoutNodes[i].x = calculatedCenter[0] + Math.cos(angle) * r;\n      layoutNodes[i].y = calculatedCenter[1] + Math.sin(angle) * r;\n      layoutNodes[i].weight = degrees[i].all;\n    }\n\n    if (assign) {\n      layoutNodes.forEach((node) => {\n        graph.mergeNodeData(node.id, {\n          x: node.x,\n          y: node.y,\n          weight: node.weight,\n        });\n      });\n    }\n\n    if (onLayoutEnd) {\n      onLayoutEnd();\n    };\n\n    return {\n      nodes: layoutNodes,\n      edges\n    };\n  }\n}\n\nfunction initHierarchy(\n  nodes: INodeData[],\n  edges: Edge[],\n  nodeMap: IndexMap,\n  directed: boolean\n) {\n  nodes.forEach((_, i: number) => {\n    nodes[i].children = [];\n    nodes[i].parent = [];\n  });\n  if (directed) {\n    edges.forEach((e) => {\n      const source = getEdgeTerminal(e, 'source');\n      const target = getEdgeTerminal(e, 'target');\n      let sourceIdx = 0;\n      if (source) {\n        sourceIdx = nodeMap[source];\n      }\n      let targetIdx = 0;\n      if (target) {\n        targetIdx = nodeMap[target];\n      }\n      const child = nodes[sourceIdx].children!;\n      const parent = nodes[targetIdx].parent!;\n      child.push(nodes[targetIdx].id);\n      parent.push(nodes[sourceIdx].id);\n    });\n  } else {\n    edges.forEach((e) => {\n      const source = getEdgeTerminal(e, 'source');\n      const target = getEdgeTerminal(e, 'target');\n      let sourceIdx = 0;\n      if (source) {\n        sourceIdx = nodeMap[source];\n      }\n      let targetIdx = 0;\n      if (target) {\n        targetIdx = nodeMap[target];\n      }\n      const sourceChildren = nodes[sourceIdx].children!;\n      const targetChildren = nodes[targetIdx].children!;\n      sourceChildren.push(nodes[targetIdx].id);\n      targetChildren.push(nodes[sourceIdx].id);\n    });\n  }\n}\n\nfunction connect(a: INodeData, b: INodeData, edges: Edge[]) {\n  const m = edges.length;\n  for (let i = 0; i < m; i++) {\n    const source = getEdgeTerminal(edges[i], 'source');\n    const target = getEdgeTerminal(edges[i], 'target');\n    if (\n      (a.id === source && b.id === target) ||\n      (b.id === source && a.id === target)\n    ) {\n      return true;\n    }\n  }\n  return false;\n}\n\nfunction compareDegree(a: INodeData, b: INodeData) {\n  const aDegree = a.degree!;\n  const bDegree = b.degree!;\n  if (aDegree < bDegree) {\n    return -1;\n  }\n  if (aDegree > bDegree) {\n    return 1;\n  }\n  return 0;\n}\n\nfunction topologyOrdering(\n  degrees: Degree[],\n  nodes: INodeData[],\n  edges: Edge[],\n  nodeMap: IndexMap, \n  directed: boolean = false\n) {\n  const cnodes = clone(nodes);\n  const orderedCNodes = [cnodes[0]];\n  const resNodes = [nodes[0]];\n  const pickFlags: boolean[] = [];\n  const n = nodes.length;\n  pickFlags[0] = true;\n  initHierarchy(cnodes, edges, nodeMap, directed);\n  let k = 0;\n  cnodes.forEach((cnode, i) => {\n    if (i !== 0) {\n      if (\n        (i === n - 1 ||\n          degrees[i].all !== degrees[i + 1].all ||\n          connect(\n            orderedCNodes[k],\n            cnode,\n            edges\n          )) &&\n        !pickFlags[i]\n      ) {\n        orderedCNodes.push(cnode);\n        resNodes.push(nodes[nodeMap[cnode.id]]);\n        pickFlags[i] = true;\n        k++;\n      } else {\n        const children = orderedCNodes[k].children!;\n        let foundChild = false;\n        for (let j = 0; j < children.length; j++) {\n          const childIdx = nodeMap[children[j]];\n          if (degrees[childIdx].all === degrees[i].all && !pickFlags[childIdx]) {\n            orderedCNodes.push(cnodes[childIdx]);\n            resNodes.push(nodes[nodeMap[cnodes[childIdx].id]]);\n            pickFlags[childIdx] = true;\n            foundChild = true;\n            break;\n          }\n        }\n        let ii = 0;\n        while (!foundChild) {\n          if (!pickFlags[ii]) {\n            orderedCNodes.push(cnodes[ii]);\n            resNodes.push(nodes[nodeMap[cnodes[ii].id]]);\n            pickFlags[ii] = true;\n            foundChild = true;\n          }\n          ii++;\n          if (ii === n) {\n            break;\n          }\n        }\n      }\n    }\n  });\n  return resNodes;\n}\n\nfunction degreeOrdering(\n  degrees: Degree[],\n  nodes: INodeData[],\n): INodeData[] {\n  const orderedNodes: INodeData[] = [];\n  nodes.forEach((node, i) => {\n    node.degree = degrees[i].all;\n    orderedNodes.push(node);\n  });\n  orderedNodes.sort(compareDegree);\n  return orderedNodes;\n}\n\nfunction calculateCenter(width: number | undefined, height: number | undefined, center: PointTuple | undefined): [number, number, PointTuple] {\n  let calculatedWidth = width;\n  let calculatedHeight = height;\n  let calculatedCenter = center;\n  if (!calculatedWidth && typeof window !== \"undefined\") {\n    calculatedWidth = window.innerWidth;\n  }\n  if (!calculatedHeight && typeof window !== \"undefined\") {\n    calculatedHeight = window.innerHeight;\n  }\n  if (!calculatedCenter) {\n    calculatedCenter = [calculatedWidth! / 2, calculatedHeight! / 2];\n  }\n  return [calculatedWidth!, calculatedHeight!, calculatedCenter];\n}","import { CircularLayout } from \"./circular\";\nimport type { SyncLayoutConstructor } from \"./types\";\n\nexport const registry: Record<string, SyncLayoutConstructor<any>> = {\n  circular: CircularLayout,\n};\nexport function registerLayout(id: string, layout: SyncLayoutConstructor<any>) {\n  registry[id] = layout;\n}\n","import { Graph } from \"@antv/graphlib\";\n// import { setupTransferableMethodsOnWorker } from \"@naoak/workerize-transferable\";\nimport { registry } from \"./registry\";\nimport type { Payload } from \"./supervisor\";\nimport type { LayoutMapping, SyncLayout } from \"./types\";\n\n// @see https://www.npmjs.com/package/@naoak/workerize-transferable\n// setupTransferableMethodsOnWorker({\n//   // The name of function which use some transferables.\n//   calculateLayout: {\n//     // Specify an instance of the function\n//     fn: calculateLayout,\n//     // Pick a transferable object from the result which is an instance of Float32Array\n//     pickTransferablesFromResult: (result) => [result[1].buffer],\n//   },\n// });\n\nexport function calculateLayout(payload: Payload, transferables: Float32Array[]) {\n  const { layout: { id, options }, nodes, edges } = payload;\n\n  // Sync graph on the worker side.\n  // TODO: Use transferable objects like ArrayBuffer for nodes & edges, \n  // in which case we don't need the whole graph.\n  // @see https://github.com/graphology/graphology/blob/master/src/layout-noverlap/webworker.tpl.js#L32\n  const graph = new Graph({\n    nodes: nodes,\n    edges: edges,\n  });\n\n  /**\n   * Create layout instance on the worker side.\n   */\n  let layout: SyncLayout<any>;\n  let positions: LayoutMapping;\n  const layoutCtor = registry[id];\n  if (layoutCtor) {\n    layout = new layoutCtor(options);\n  } else {\n    throw new Error('Unknown layout id: ' + id);\n  }\n\n  // Do calculation.\n  positions = layout.execute(graph);\n  \n  return [positions, transferables];\n}\n"],"names":["__webpack_require__","exports","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","Graph","nodeMap","Map","edgeMap","inEdgesMap","outEdgesMap","treeIndices","changes","batchCount","onChanged","constructor","options","nodes","this","addNodes","edges","addEdges","tree","addTree","batch","fn","commit","graph","reduceChanges","mergedChanges","forEach","change","type","isNewlyAdded","filter","pastChange","sameId","value","id","nodeId","push","existingChange","find","propertyName","newValue","treeKey","newParentId","checkNodeExistence","hasNode","Error","has","areNeighbors","firstNodeId","secondNodeId","getNeighbors","some","neighbor","getNode","getRelatedEdges","direction","inEdges","outEdges","Array","from","bothEdges","Set","getDegree","length","getSuccessors","targets","map","edge","target","getPredecessors","sources","source","predecessors","successors","doAddNode","node","set","childrenMap","addNode","doRemoveNode","doRemoveEdge","delete","child","parentMap","removeNodes","idList","removeNode","updateNodeData","oldValue","data","mergeNodeData","patch","entries","checkEdgeExistence","hasEdge","getEdge","getEdgeDetail","doAddEdge","add","addEdge","removeEdges","removeEdge","updateEdgeSource","oldSource","newSource","updateEdgeTarget","oldTarget","newTarget","updateEdgeData","mergeEdgeData","checkTreeExistence","attachTreeStructure","detachTreeStructure","stack","isArray","shift","children","parent","setParent","getRoots","getAllNodes","getParent","getChildren","oldParent","newParent","oldParentId","values","getAllEdges","doBFS","queue","visited","n","bfs","doDFS","dfs","clone","newNodes","oldNode","newEdges","oldEdge","newGraph","oldParentMap","oldChildrenMap","toJSON","JSON","stringify","__assign","assign","t","s","i","arguments","p","apply","__read","m","Symbol","iterator","r","e","ar","next","done","error","create","camelizeRE","str","replace","_","c","toUpperCase","isObject","val","Date","getTime","v","keys","k","getEdgeTerminal","terminal","cell","getFuncByUnknownType","defaultValue","resultIsNumber","max","Math","to","pack","l","slice","concat","isNaN","width","height","d","size","DEFAULTS_LAYOUT_OPTIONS","radius","startRadius","endRadius","startAngle","endAngle","PI","clockwise","divisions","ordering","angleRatio","compareDegree","a","b","aDegree","degree","bDegree","topologyOrdering","degrees","directed","cnodes","orderedCNodes","resNodes","pickFlags","sourceIdx","targetIdx","sourceChildren","targetChildren","initHierarchy","cnode","all","connect","foundChild","j","childIdx","ii","registry","circular","execute","genericCircularLayout","mergedOptions","center","paramNodeSpacing","paramNodeSize","onLayoutEnd","calculatedWidth","calculatedHeight","calculatedCenter","window","innerWidth","innerHeight","calculateCenter","x","y","angleStep","nodeIdxMap","in","out","nSize","astep","layoutNodes","nodesData","orderedNodes","sort","degreeOrdering","divN","ceil","angle","floor","cos","sin","weight","calculateLayout","payload","transferables","layoutCtor"],"sourceRoot":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"3a54d760230d1933f953.worker.js","mappings":"mBACA,IAAIA,EAAsB,CCA1BA,EAAwB,CAACC,EAASC,KACjC,IAAI,IAAIC,KAAOD,EACXF,EAAoBI,EAAEF,EAAYC,KAASH,EAAoBI,EAAEH,EAASE,IAC5EE,OAAOC,eAAeL,EAASE,EAAK,CAAEI,YAAY,EAAMC,IAAKN,EAAWC,IAE1E,ECNDH,EAAwB,CAACS,EAAKC,IAAUL,OAAOM,UAAUC,eAAeC,KAAKJ,EAAKC,I,oCCA3E,MAAMI,EACTC,QAAU,IAAIC,IACdC,QAAU,IAAID,IACdE,WAAa,IAAIF,IACjBG,YAAc,IAAIH,IAClBI,YAAc,IAAIJ,IAClBK,QAAU,GACVC,WAAa,EAMbC,UAAY,OA0BZC,YAAYC,GACHA,IAEDA,EAAQC,OACRC,KAAKC,SAASH,EAAQC,OACtBD,EAAQI,OACRF,KAAKG,SAASL,EAAQI,OACtBJ,EAAQM,MACRJ,KAAKK,QAAQP,EAAQM,MACrBN,EAAQF,YACRI,KAAKJ,UAAYE,EAAQF,WACjC,CAsBAU,MAASC,IACLP,KAAKL,YAAc,EACnBY,IACAP,KAAKL,YAAc,EACdK,KAAKL,YACNK,KAAKQ,QACT,EAKJA,SACI,MAAMd,EAAUM,KAAKN,QACrBM,KAAKN,QAAU,GACfM,KAAKJ,UAAU,CACXa,MAAOT,KACPN,WAER,CA0BAgB,cAAchB,GACV,IAAIiB,EAAgB,GA8GpB,OA7GAjB,EAAQkB,SAASC,IACb,OAAQA,EAAOC,MACX,IAAK,cAAe,CAKhB,IAAIC,GAAe,EACnBJ,EAAgBA,EAAcK,QAAQC,IAClC,GAAwB,cAApBA,EAAWH,KAAsB,CACjC,MAAMI,EAASD,EAAWE,MAAMC,KAAOP,EAAOM,MAAMC,GAIpD,OAHIF,IACAH,GAAe,IAEXG,CACZ,CACK,MAAwB,oBAApBD,EAAWH,KACTG,EAAWG,KAAOP,EAAOM,MAAMC,GAEb,yBAApBH,EAAWH,MACTG,EAAWI,SAAWR,EAAOM,MAAMC,EAEnC,IAEVL,GACDJ,EAAcW,KAAKT,GAEvB,KACJ,CACA,IAAK,cAAe,CAKhB,IAAIE,GAAe,EACnBJ,EAAgBA,EAAcK,QAAQC,IAClC,GAAwB,cAApBA,EAAWH,KAAsB,CACjC,MAAMI,EAASD,EAAWE,MAAMC,KAAOP,EAAOM,MAAMC,GAIpD,OAHIF,IACAH,GAAe,IAEXG,CACZ,CACK,MAAwB,oBAApBD,EAAWH,MACI,gBAApBG,EAAWH,MACJG,EAAWG,KAAOP,EAAOM,MAAMC,EAE/B,IAEVL,GACDJ,EAAcW,KAAKT,GAEvB,KACJ,CACA,IAAK,kBACL,IAAK,kBACL,IAAK,cAAe,CAIhB,MAAMU,EAAiBZ,EAAca,MAAMP,GAC/BA,EAAWH,OAASD,EAAOC,MAC/BG,EAAWG,KAAOP,EAAOO,IACzBH,EAAWQ,eAAiBZ,EAAOY,eAEvCF,EACAA,EAAeG,SAAWb,EAAOa,SAGjCf,EAAcW,KAAKT,GAEvB,KACJ,CACA,IAAK,wBAIDF,EAAgBA,EAAcK,QAAQC,GACV,0BAApBA,EAAWH,KACJG,EAAWU,UAAYd,EAAOc,QAEZ,yBAApBV,EAAWH,MACTG,EAAWU,UAAYd,EAAOc,UAI7ChB,EAAcW,KAAKT,GACnB,MAEJ,IAAK,uBAAwB,CACzB,MAAMU,EAAiBZ,EAAca,MAAMP,GACX,yBAApBA,EAAWH,MACfG,EAAWU,UAAYd,EAAOc,SAC9BV,EAAWI,SAAWR,EAAOQ,SAEjCE,EACAA,EAAeK,YACXf,EAAOe,YAGXjB,EAAcW,KAAKT,GAEvB,KACJ,CACA,QACIF,EAAcW,KAAKT,GAE3B,IAEGF,CACX,CAEAkB,mBAAmBT,GACf,IAAKpB,KAAK8B,QAAQV,GACd,MAAM,IAAIW,MAAM,0BAA4BX,EAEpD,CAKAU,QAAQV,GACJ,OAAOpB,KAAKZ,QAAQ4C,IAAIZ,EAC5B,CAKAa,aAAaC,EAAaC,GAEtB,OADAnC,KAAK6B,mBAAmBK,GACjBlC,KAAKoC,aAAaD,GAAcE,MAAMC,GAAaA,EAASlB,KAAOc,GAC9E,CAKAK,QAAQnB,GAEJ,OADApB,KAAK6B,mBAAmBT,GACjBpB,KAAKZ,QAAQP,IAAIuC,EAC5B,CAOAoB,gBAAgBpB,EAAIqB,GAChBzC,KAAK6B,mBAAmBT,GACxB,MAAMsB,EAAU1C,KAAKT,WAAWV,IAAIuC,GAC9BuB,EAAW3C,KAAKR,YAAYX,IAAIuC,GACtC,GAAkB,OAAdqB,EACA,OAAOG,MAAMC,KAAKH,GAEjB,GAAkB,QAAdD,EACL,OAAOG,MAAMC,KAAKF,GAEtB,MAAMG,EAAY,IAAIC,IAAI,IAAIL,KAAYC,IAC1C,OAAOC,MAAMC,KAAKC,EACtB,CAKAE,UAAU5B,EAAIqB,GACV,OAAOzC,KAAKwC,gBAAgBpB,EAAIqB,GAAWQ,MAC/C,CAIAC,cAAc9B,GACV,MACM+B,EADWnD,KAAKwC,gBAAgBpB,EAAI,OACjBgC,KAAKC,GAASA,EAAKC,SAC5C,OAAOV,MAAMC,KAAK,IAAIE,IAAII,IAAUC,KAAKhC,GAAOpB,KAAKuC,QAAQnB,IACjE,CAIAmC,gBAAgBnC,GACZ,MACMoC,EADUxD,KAAKwC,gBAAgBpB,EAAI,MACjBgC,KAAKC,GAASA,EAAKI,SAC3C,OAAOb,MAAMC,KAAK,IAAIE,IAAIS,IAAUJ,KAAKhC,GAAOpB,KAAKuC,QAAQnB,IACjE,CAMAgB,aAAahB,GACT,MAAMsC,EAAe1D,KAAKuD,gBAAgBnC,GACpCuC,EAAa3D,KAAKkD,cAAc9B,GACtC,OAAOwB,MAAMC,KAAK,IAAIE,IAAI,IAAIW,KAAiBC,IACnD,CACAC,UAAUC,GACN,GAAI7D,KAAK8B,QAAQ+B,EAAKzC,IAClB,MAAM,IAAIW,MAAM,wBAA0B8B,EAAKzC,IAEnDpB,KAAKZ,QAAQ0E,IAAID,EAAKzC,GAAIyC,GAC1B7D,KAAKT,WAAWuE,IAAID,EAAKzC,GAAI,IAAI2B,KACjC/C,KAAKR,YAAYsE,IAAID,EAAKzC,GAAI,IAAI2B,KAClC/C,KAAKP,YAAYmB,SAASR,IACtBA,EAAK2D,YAAYD,IAAID,EAAKzC,GAAI,IAAI2B,IAAM,IAE5C/C,KAAKN,QAAQ4B,KAAK,CAAER,KAAM,YAAaK,MAAO0C,GAClD,CAKA5D,SAASF,GACLC,KAAKM,OAAM,KACP,IAAK,MAAMuD,KAAQ9D,EACfC,KAAK4D,UAAUC,EACnB,GAER,CAKAG,QAAQH,GACJ7D,KAAKC,SAAS,CAAC4D,GACnB,CACAI,aAAa7C,GACT,MAAMyC,EAAO7D,KAAKuC,QAAQnB,GACpBsB,EAAU1C,KAAKT,WAAWV,IAAIuC,GAC9BuB,EAAW3C,KAAKR,YAAYX,IAAIuC,GACtCsB,GAAS9B,SAASyC,GAASrD,KAAKkE,aAAab,EAAKjC,MAClDuB,GAAU/B,SAASyC,GAASrD,KAAKkE,aAAab,EAAKjC,MACnDpB,KAAKZ,QAAQ+E,OAAO/C,GACpBpB,KAAKP,YAAYmB,SAASR,IACtBA,EAAK2D,YAAYlF,IAAIuC,IAAKR,SAASwD,IAC/BhE,EAAKiE,UAAUF,OAAOC,EAAMhD,GAAG,IAEnChB,EAAKiE,UAAUF,OAAO/C,GACtBhB,EAAK2D,YAAYI,OAAO/C,EAAG,IAE/BpB,KAAKN,QAAQ4B,KAAK,CAAER,KAAM,cAAeK,MAAO0C,GACpD,CAKAS,YAAYC,GACRvE,KAAKM,OAAM,KACPiE,EAAO3D,SAASQ,GAAOpB,KAAKiE,aAAa7C,IAAI,GAErD,CAKAoD,WAAWpD,GACPpB,KAAKsE,YAAY,CAAClD,GACtB,CAKAqD,eAAerD,EAAIK,EAAcN,GAC7B,MAAM0C,EAAO7D,KAAKuC,QAAQnB,GAC1BpB,KAAKM,OAAM,KACP,MAAMoE,EAAWb,EAAKc,KAAKlD,GACrBC,EAAWP,EACjB0C,EAAKc,KAAKlD,GAAgBC,EAC1B1B,KAAKN,QAAQ4B,KAAK,CACdR,KAAM,kBACNM,KACAK,eACAiD,WACAhD,YACF,GAEV,CAMAkD,cAAcxD,EAAIyD,GACd7E,KAAKM,OAAM,KACP5B,OAAOoG,QAAQD,GAAOjE,SAAQ,EAAEa,EAAcN,MAC1CnB,KAAKyE,eAAerD,EAAIK,EAAcN,EAAM,GAC9C,GAEV,CAEA4D,mBAAmB3D,GACf,IAAKpB,KAAKgF,QAAQ5D,GACd,MAAM,IAAIW,MAAM,0BAA4BX,EAEpD,CAKA4D,QAAQ5D,GACJ,OAAOpB,KAAKV,QAAQ0C,IAAIZ,EAC5B,CAKA6D,QAAQ7D,GAEJ,OADApB,KAAK+E,mBAAmB3D,GACjBpB,KAAKV,QAAQT,IAAIuC,EAC5B,CAKA8D,cAAc9D,GACV,MAAMiC,EAAOrD,KAAKiF,QAAQ7D,GAC1B,MAAO,CACHiC,OACAI,OAAQzD,KAAKuC,QAAQc,EAAKI,QAC1BH,OAAQtD,KAAKuC,QAAQc,EAAKC,QAElC,CACA6B,UAAU9B,GACN,GAAIrD,KAAKgF,QAAQ3B,EAAKjC,IAClB,MAAM,IAAIW,MAAM,wBAA0BsB,EAAKjC,IAEnDpB,KAAK6B,mBAAmBwB,EAAKI,QAC7BzD,KAAK6B,mBAAmBwB,EAAKC,QAC7BtD,KAAKV,QAAQwE,IAAIT,EAAKjC,GAAIiC,GAC1B,MAAMX,EAAU1C,KAAKT,WAAWV,IAAIwE,EAAKC,QACnCX,EAAW3C,KAAKR,YAAYX,IAAIwE,EAAKI,QAC3Cf,EAAQ0C,IAAI/B,GACZV,EAASyC,IAAI/B,GACbrD,KAAKN,QAAQ4B,KAAK,CAAER,KAAM,YAAaK,MAAOkC,GAClD,CAKAlD,SAASD,GACLF,KAAKM,OAAM,KACP,IAAK,MAAM+C,KAAQnD,EACfF,KAAKmF,UAAU9B,EACnB,GAER,CAaAgC,QAAQhC,GACJrD,KAAKG,SAAS,CAACkD,GACnB,CACAa,aAAa9C,GACT,MAAMiC,EAAOrD,KAAKiF,QAAQ7D,GACpBuB,EAAW3C,KAAKR,YAAYX,IAAIwE,EAAKI,QACrCf,EAAU1C,KAAKT,WAAWV,IAAIwE,EAAKC,QACzCX,EAASwB,OAAOd,GAChBX,EAAQyB,OAAOd,GACfrD,KAAKV,QAAQ6E,OAAO/C,GACpBpB,KAAKN,QAAQ4B,KAAK,CAAER,KAAM,cAAeK,MAAOkC,GACpD,CAKAiC,YAAYf,GACRvE,KAAKM,OAAM,KACPiE,EAAO3D,SAASQ,GAAOpB,KAAKkE,aAAa9C,IAAI,GAErD,CAKAmE,WAAWnE,GACPpB,KAAKsF,YAAY,CAAClE,GACtB,CAKAoE,iBAAiBpE,EAAIqC,GACjB,MAAMJ,EAAOrD,KAAKiF,QAAQ7D,GAC1BpB,KAAK6B,mBAAmB4B,GACxB,MAAMgC,EAAYpC,EAAKI,OACjBiC,EAAYjC,EAClBzD,KAAKR,YAAYX,IAAI4G,GAAWtB,OAAOd,GACvCrD,KAAKR,YAAYX,IAAI6G,GAAWN,IAAI/B,GACpCA,EAAKI,OAASA,EACdzD,KAAKM,OAAM,KACPN,KAAKN,QAAQ4B,KAAK,CACdR,KAAM,cACNM,KACAK,aAAc,SACdiD,SAAUe,EACV/D,SAAUgE,GACZ,GAEV,CAKAC,iBAAiBvE,EAAIkC,GACjB,MAAMD,EAAOrD,KAAKiF,QAAQ7D,GAC1BpB,KAAK6B,mBAAmByB,GACxB,MAAMsC,EAAYvC,EAAKC,OACjBuC,EAAYvC,EAClBtD,KAAKT,WAAWV,IAAI+G,GAAWzB,OAAOd,GACtCrD,KAAKT,WAAWV,IAAIgH,GAAWT,IAAI/B,GACnCA,EAAKC,OAASA,EACdtD,KAAKM,OAAM,KACPN,KAAKN,QAAQ4B,KAAK,CACdR,KAAM,cACNM,KACAK,aAAc,SACdiD,SAAUkB,EACVlE,SAAUmE,GACZ,GAEV,CAKAC,eAAe1E,EAAIK,EAAcN,GAC7B,MAAMkC,EAAOrD,KAAKiF,QAAQ7D,GAC1BpB,KAAKM,OAAM,KACP,MAAMoE,EAAWrB,EAAKsB,KAAKlD,GACrBC,EAAWP,EACjBkC,EAAKsB,KAAKlD,GAAgBC,EAC1B1B,KAAKN,QAAQ4B,KAAK,CACdR,KAAM,kBACNM,KACAK,eACAiD,WACAhD,YACF,GAEV,CAIAqE,cAAc3E,EAAIyD,GACd7E,KAAKM,OAAM,KACP5B,OAAOoG,QAAQD,GAAOjE,SAAQ,EAAEa,EAAcN,MAC1CnB,KAAK8F,eAAe1E,EAAIK,EAAcN,EAAM,GAC9C,GAEV,CAEA6E,mBAAmBrE,GACf,IAAK3B,KAAKP,YAAYuC,IAAIL,GACtB,MAAM,IAAII,MAAM,yCAA2CJ,EAEnE,CAiBAsE,oBAAoBtE,GACZ3B,KAAKP,YAAYuC,IAAIL,KAIzB3B,KAAKP,YAAYqE,IAAInC,EAAS,CAC1B0C,UAAW,IAAIhF,IACf0E,YAAa,IAAI1E,MAErBW,KAAKM,OAAM,KACPN,KAAKN,QAAQ4B,KAAK,CACdR,KAAM,wBACNa,WACF,IAEV,CAUAuE,oBAAoBvE,GAChB3B,KAAKgG,mBAAmBrE,GACxB3B,KAAKP,YAAY0E,OAAOxC,GACxB3B,KAAKM,OAAM,KACPN,KAAKN,QAAQ4B,KAAK,CACdR,KAAM,wBACNa,WACF,GAEV,CAmBAtB,QAAQD,EAAMuB,GACV3B,KAAKM,OAAM,KACPN,KAAKiG,oBAAoBtE,GAEzB,MAAM5B,EAAQ,GACRoG,EAAQvD,MAAMwD,QAAQhG,GAAQA,EAAO,CAACA,GAC5C,KAAO+F,EAAMlD,QAAQ,CACjB,MAAMY,EAAOsC,EAAME,QACnBtG,EAAMuB,KAAKuC,GACPA,EAAKyC,UACLH,EAAM7E,QAAQuC,EAAKyC,SAE3B,CACAtG,KAAKC,SAASF,GAEdA,EAAMa,SAAS2F,IACXA,EAAOD,UAAU1F,SAASwD,IACtBpE,KAAKwG,UAAUpC,EAAMhD,GAAImF,EAAOnF,GAAIO,EAAQ,GAC9C,GACJ,GAEV,CA0DA8E,SAAS9E,GAEL,OADA3B,KAAKgG,mBAAmBrE,GACjB3B,KAAK0G,cAAc1F,QAAQ6C,IAAU7D,KAAK2G,UAAU9C,EAAKzC,GAAIO,IACxE,CAKAiF,YAAYxF,EAAIO,GACZ3B,KAAK6B,mBAAmBT,GACxBpB,KAAKgG,mBAAmBrE,GACxB,MACM2E,EADOtG,KAAKP,YAAYZ,IAAI8C,GACZoC,YAAYlF,IAAIuC,GACtC,OAAOwB,MAAMC,KAAKyD,GAAY,GAClC,CAMAK,UAAUvF,EAAIO,GAIV,OAHA3B,KAAK6B,mBAAmBT,GACxBpB,KAAKgG,mBAAmBrE,GACX3B,KAAKP,YAAYZ,IAAI8C,GACtB0C,UAAUxF,IAAIuC,IAAO,IACrC,CAQAoF,UAAUpF,EAAImF,EAAQ5E,GAClB3B,KAAKgG,mBAAmBrE,GACxB,MAAMvB,EAAOJ,KAAKP,YAAYZ,IAAI8C,GAC5BkC,EAAO7D,KAAKuC,QAAQnB,GACpByF,EAAYzG,EAAKiE,UAAUxF,IAAIuC,GAC/B0F,EAAY9G,KAAKuC,QAAQgE,GAE/BnG,EAAKiE,UAAUP,IAAI1C,EAAI0F,GAEnBD,GACAzG,EAAK2D,YAAYlF,IAAIgI,EAAUzF,KAAK+C,OAAON,GAE/C,IAAIyC,EAAWlG,EAAK2D,YAAYlF,IAAIiI,EAAU1F,IACzCkF,IACDA,EAAW,IAAIvD,IACf3C,EAAK2D,YAAYD,IAAIgD,EAAU1F,GAAIkF,IAEvCA,EAASlB,IAAIvB,GACb7D,KAAKM,OAAM,KACPN,KAAKN,QAAQ4B,KAAK,CACdR,KAAM,uBACNa,UACAN,OAAQD,EACR2F,YAAaF,GAAWzF,GACxBQ,YAAakF,EAAU1F,IACzB,GAEV,CAKAsF,cACI,OAAO9D,MAAMC,KAAK7C,KAAKZ,QAAQ4H,SACnC,CAIAC,cACI,OAAOrE,MAAMC,KAAK7C,KAAKV,QAAQ0H,SACnC,CACAE,MAAMC,EAAOC,EAAS7G,GAClB,KAAO4G,EAAMlE,QAAQ,CACjB,MAAMY,EAAOsD,EAAMd,QACnB9F,EAAGsD,GACHuD,EAAQhC,IAAIvB,EAAKzC,IACjBpB,KAAKkD,cAAcW,EAAKzC,IAAIR,SAASyG,IAC5BD,EAAQpF,IAAIqF,EAAEjG,MACfgG,EAAQhC,IAAIiC,EAAEjG,IACd+F,EAAM7F,KAAK+F,GACf,GAER,CACJ,CACAC,IAAIlG,EAAIb,GACJP,KAAKkH,MAAM,CAAClH,KAAKuC,QAAQnB,IAAM,IAAI2B,IAAOxC,EAC9C,CACAgH,MAAM1D,EAAMuD,EAAS7G,GACjBA,EAAGsD,GACHuD,EAAQhC,IAAIvB,EAAKzC,IACjBpB,KAAKkD,cAAcW,EAAKzC,IAAIR,SAASyG,IAC5BD,EAAQpF,IAAIqF,EAAEjG,KACfpB,KAAKuH,MAAMF,EAAGD,EAAS7G,EAC3B,GAER,CACAiH,IAAIpG,EAAIb,GACJP,KAAKuH,MAAMvH,KAAKuC,QAAQnB,GAAK,IAAI2B,IAAOxC,EAC5C,CACAkH,QAEI,MAAMC,EAAW1H,KAAK0G,cAActD,KAAKuE,IAC9B,IAAKA,EAAShD,KAAM,IAAKgD,EAAQhD,UAEtCiD,EAAW5H,KAAKiH,cAAc7D,KAAKyE,IAC9B,IAAKA,EAASlD,KAAM,IAAKkD,EAAQlD,UAGtCmD,EAAW,IAAI3I,EAAM,CACvBY,MAAO2H,EACPxH,MAAO0H,IAiBX,OAdA5H,KAAKP,YAAYmB,SAAQ,EAAGyD,UAAW0D,EAAchE,YAAaiE,GAAkBrG,KAChF,MAAM0C,EAAY,IAAIhF,IACtB0I,EAAanH,SAAQ,CAAC2F,EAAQ/H,KAC1B6F,EAAUP,IAAItF,EAAKsJ,EAASvF,QAAQgE,EAAOnF,IAAI,IAEnD,MAAM2C,EAAc,IAAI1E,IACxB2I,EAAepH,SAAQ,CAAC0F,EAAU9H,KAC9BuF,EAAYD,IAAItF,EAAK,IAAIuE,IAAIH,MAAMC,KAAKyD,GAAUlD,KAAKiE,GAAMS,EAASvF,QAAQ8E,EAAEjG,OAAM,IAE1F0G,EAASrI,YAAYqE,IAAInC,EAAS,CAC9B0C,UAAWA,EACXN,YAAaA,GACf,IAEC+D,CACX,CACAG,SACI,OAAOC,KAAKC,UAAU,CAClBpI,MAAOC,KAAK0G,cACZxG,MAAOF,KAAKiH,eAGpB,ECl0BG,IAAImB,EAAW,WAQlB,OAPAA,EAAW1J,OAAO2J,QAAU,SAAkBC,GAC1C,IAAK,IAAIC,EAAGC,EAAI,EAAGnB,EAAIoB,UAAUxF,OAAQuF,EAAInB,EAAGmB,IAE5C,IAAK,IAAIE,KADTH,EAAIE,UAAUD,GACO9J,OAAOM,UAAUC,eAAeC,KAAKqJ,EAAGG,KAAIJ,EAAEI,GAAKH,EAAEG,IAE9E,OAAOJ,CACX,EACOF,EAASO,MAAM3I,KAAMyI,UAChC,EA+FO,SAASG,EAAOnK,EAAG4I,GACtB,IAAIwB,EAAsB,mBAAXC,QAAyBrK,EAAEqK,OAAOC,UACjD,IAAKF,EAAG,OAAOpK,EACf,IAAmBuK,EAAYC,EAA3BT,EAAIK,EAAE3J,KAAKT,GAAOyK,EAAK,GAC3B,IACI,WAAc,IAAN7B,GAAgBA,KAAM,MAAQ2B,EAAIR,EAAEW,QAAQC,MAAMF,EAAG5H,KAAK0H,EAAE7H,MAQxE,CANA,MAAOkI,GAASJ,EAAI,CAAEI,MAAOA,EAAS,CACtC,QACI,IACQL,IAAMA,EAAEI,OAASP,EAAIL,EAAU,SAAIK,EAAE3J,KAAKsJ,EAElB,CAAhC,QAAU,GAAIS,EAAG,MAAMA,EAAEI,KAAO,CACpC,CACA,OAAOH,CACX,CA3C6BxK,OAAO4K,OA0GX5K,OAAO4K,OCrNzB,IAWDC,EAAa,SCXN,GDY+B,SAACC,GAC3C,OAAOA,EAAIC,QAAQF,GAAY,SAACG,EAAGC,GAAM,OAACA,EAAIA,EAAEC,cAAgB,EAAvB,GAC3C,EAVwClL,OAAO4K,OAAO,MCJ/B1G,MAAMwD,SCAhByD,EAAW,SAACC,GACvB,OAAQ,OAARA,GAA+B,iBAARA,CAAvB,EAEWrC,EAAQ,SAAInE,GACvB,GAAe,OAAXA,EACF,OAAOA,EAET,GAAIA,aAAkByG,KACpB,OAAO,IAAIA,KAAKzG,EAAO0G,WAEzB,GAAI1G,aAAkBV,MAAO,CAC3B,IAAM,EAAK,GAIX,OAHCU,EAAiB1C,SAAQ,SAACqJ,GACzB,EAAG3I,KAAK2I,EACV,IACO,EAAG7G,KAAI,SAACiE,GAAW,OAAAI,EAAWJ,EAAX,G,CAE5B,GAAsB,iBAAX/D,GAAuB5E,OAAOwL,KAAK5G,GAAQL,OAAQ,CAC5D,IAAM,EAAK,KAAMK,GAMjB,OAHA5E,OAAOwL,KAAK,GAAItJ,SAAQ,SAACuJ,GACvB,EAAGA,GAAK1C,EAAW,EAAG0C,GACxB,IACO,C,CAET,OAAO7G,CACT,ECba8G,EAAkB,SAAC/G,EAAYvC,GAC1C,IAAMuJ,EAAWhH,EAAKvC,GACtB,OAAI+I,EAASQ,GACJA,EAASC,KAEXD,CACT,ECEaE,EAAuB,SAClCC,EACArJ,EAMAsJ,GAEA,YAFA,IAAAA,IAAAA,GAAA,GAEKtJ,GAAmB,IAAVA,EA5BC,mBAwCAA,EACNA,EC5CM,iBD8CFA,EACJ,WAAM,OAAAA,CAAA,EAEX,EAAQA,GACH,WACL,GAAIsJ,EAAgB,CAClB,IAAMC,EAAMC,KAAKD,IAAG,MAARC,KLmHb,SAAuBC,EAAI/H,EAAMgI,GACpC,GAAIA,GAA6B,IAArBpC,UAAUxF,OAAc,IAAK,IAA4BiG,EAAxBV,EAAI,EAAGsC,EAAIjI,EAAKI,OAAYuF,EAAIsC,EAAGtC,KACxEU,GAAQV,KAAK3F,IACRqG,IAAIA,EAAKtG,MAAM5D,UAAU+L,MAAM7L,KAAK2D,EAAM,EAAG2F,IAClDU,EAAGV,GAAK3F,EAAK2F,IAGrB,OAAOoC,EAAGI,OAAO9B,GAAMtG,MAAM5D,UAAU+L,MAAM7L,KAAK2D,GACtD,CK3HwB,MAAS1B,IAAkB,IAC3C,OAAO8J,MAAMP,GAAOF,EAAeE,C,CAErC,OAAOvJ,CACT,EAEE0I,EAAS1I,GACJ,WACL,GAAIsJ,EAAgB,CAClB,IAAMC,EAAMC,KAAKD,IAAIvJ,EAAM+J,MAAO/J,EAAMgK,QACxC,OAAOF,MAAMP,GAAOF,EAAeE,C,CAErC,MAAO,CAACvJ,EAAM+J,MAAO/J,EAAMgK,OAC7B,EAEK,WAAM,OAAAX,CAAA,EAnCJ,SAACY,GACN,OAAIA,EAAEC,KACA,EAAQD,EAAEC,MACLD,EAAEC,KAAK,GAAKD,EAAEC,KAAK,GAAKD,EAAEC,KAAK,GAAKD,EAAEC,KAAK,GAChDxB,EAASuB,EAAEC,MACND,EAAEC,KAAKH,MAAQE,EAAEC,KAAKF,OAASC,EAAEC,KAAKH,MAAQE,EAAEC,KAAKF,OACvDC,EAAEC,KAEJb,CACT,CA2BJ,EEvDMc,EAA0D,CAC9DC,OAAQ,KACRC,YAAa,KACbC,UAAW,KACXC,WAAY,EACZC,SAAU,EAAIhB,KAAKiB,GACnBC,WAAW,EACXC,UAAW,EACXC,SAAU,KACVC,WAAY,GA+Od,SAASC,EAAcC,EAAcC,GACnC,IAAMC,EAAUF,EAAEG,OACZC,EAAUH,EAAEE,OAClB,OAAID,EAAUE,GACJ,EAENF,EAAUE,EACL,EAEF,CACT,CAEA,SAASC,EACPC,EACAzM,EACAG,EACAd,EACAqN,QAAA,IAAAA,IAAAA,GAAA,GAEA,IAAMC,EAASjF,EAAM1H,GACf4M,EAAgB,CAACD,EAAO,IACxBE,EAAW,CAAC7M,EAAM,IAClB8M,EAAuB,GACvBxF,EAAItH,EAAMkD,OAChB4J,EAAU,IAAK,EAtFjB,SACE9M,EACAG,EACAd,EACAqN,GAEA1M,EAAMa,SAAQ,SAAC8I,EAAGlB,GAChBzI,EAAMyI,GAAGlC,SAAW,GACpBvG,EAAMyI,GAAGjC,OAAS,EACpB,IACIkG,EACFvM,EAAMU,SAAQ,SAACqI,GACb,IAAMxF,EAAS2G,EAAgBnB,EAAG,UAC5B3F,EAAS8G,EAAgBnB,EAAG,UAC9B6D,EAAY,EACZrJ,IACFqJ,EAAY1N,EAAQqE,IAEtB,IAAIsJ,EAAY,EACZzJ,IACFyJ,EAAY3N,EAAQkE,IAEtB,IAAMc,EAAQrE,EAAM+M,GAAWxG,SACzBC,EAASxG,EAAMgN,GAAWxG,OAChCnC,EAAM9C,KAAKvB,EAAMgN,GAAW3L,IAC5BmF,EAAOjF,KAAKvB,EAAM+M,GAAW1L,GAC/B,IAEAlB,EAAMU,SAAQ,SAACqI,GACb,IAAMxF,EAAS2G,EAAgBnB,EAAG,UAC5B3F,EAAS8G,EAAgBnB,EAAG,UAC9B6D,EAAY,EACZrJ,IACFqJ,EAAY1N,EAAQqE,IAEtB,IAAIsJ,EAAY,EACZzJ,IACFyJ,EAAY3N,EAAQkE,IAEtB,IAAM0J,EAAiBjN,EAAM+M,GAAWxG,SAClC2G,EAAiBlN,EAAMgN,GAAWzG,SACxC0G,EAAe1L,KAAKvB,EAAMgN,GAAW3L,IACrC6L,EAAe3L,KAAKvB,EAAM+M,GAAW1L,GACvC,GAEJ,CA0CE8L,CAAcR,EAAQxM,EAAOd,EAASqN,GACtC,IAAItC,EAAI,EA8CR,OA7CAuC,EAAO9L,SAAQ,SAACuM,EAAO3E,GACrB,GAAU,IAANA,EACF,GACGA,IAAMnB,EAAI,GACTmF,EAAQhE,GAAG4E,MAAQZ,EAAQhE,EAAI,GAAG4E,MA9C5C,SAAiBlB,EAAcC,EAAcjM,GAE3C,IADA,IAAM2I,EAAI3I,EAAM+C,OACPuF,EAAI,EAAGA,EAAIK,EAAGL,IAAK,CAC1B,IAAM/E,EAAS2G,EAAgBlK,EAAMsI,GAAI,UACnClF,EAAS8G,EAAgBlK,EAAMsI,GAAI,UACzC,GACG0D,EAAE9K,KAAOqC,GAAU0I,EAAE/K,KAAOkC,GAC5B6I,EAAE/K,KAAOqC,GAAUyI,EAAE9K,KAAOkC,EAE7B,OAAO,C,CAGX,OAAO,CACT,CAkCU+J,CACEV,EAAcxC,GACdgD,EACAjN,IAEH2M,EAAUrE,GAMN,CAGL,IAFA,IAAMlC,EAAWqG,EAAcxC,GAAG7D,SAC9BgH,GAAa,EACRC,EAAI,EAAGA,EAAIjH,EAASrD,OAAQsK,IAAK,CACxC,IAAMC,EAAWpO,EAAQkH,EAASiH,IAClC,GAAIf,EAAQgB,GAAUJ,MAAQZ,EAAQhE,GAAG4E,MAAQP,EAAUW,GAAW,CACpEb,EAAcrL,KAAKoL,EAAOc,IAC1BZ,EAAStL,KAAKvB,EAAMX,EAAQsN,EAAOc,GAAUpM,MAC7CyL,EAAUW,IAAY,EACtBF,GAAa,EACb,K,EAIJ,IADA,IAAIG,EAAK,GACDH,IACDT,EAAUY,KACbd,EAAcrL,KAAKoL,EAAOe,IAC1Bb,EAAStL,KAAKvB,EAAMX,EAAQsN,EAAOe,GAAIrM,MACvCyL,EAAUY,IAAM,EAChBH,GAAa,KAEfG,IACWpG,K,MA1BbsF,EAAcrL,KAAK6L,GACnBP,EAAStL,KAAKvB,EAAMX,EAAQ+N,EAAM/L,MAClCyL,EAAUrE,IAAK,EACf2B,GA6BN,IACOyC,CACT,CC5UO,IAAMc,EAAuD,CAClEC,SDqCF,WAGE,WAAmB7N,QAAA,IAAAA,IAAAA,EAAiC,CAAC,GAAlC,KAAAA,QAAAA,EAFnB,KAAAsB,GAAK,WAGH1C,OAAO2J,OAAOrI,KAAKF,QAASwL,EAAyBxL,EACvD,CAwJF,OAnJE,YAAA8N,QAAA,SAAQnN,EAAoCX,GAC1C,OAAOE,KAAK6N,uBAAsB,EAAOpN,EAAOX,EAClD,EAKA,YAAAuI,OAAA,SAAO5H,EAAoCX,GAA3C,WACEW,EAAMH,OAAM,WACV,EAAKuN,uBAAsB,EAAMpN,EAAOX,EAC1C,GACF,EAEQ,YAAA+N,sBAAR,SAA8BxF,EAAiB5H,EAAoCX,GACjF,IAAMgO,EAAgB,OAAK9N,KAAKF,SAAYA,GACpCoL,EAAmL4C,EAAa,MAAzL3C,EAA4K2C,EAAa,OAAjLC,EAAoKD,EAAa,OAAzKhC,EAA4JgC,EAAa,UAA9J,EAAiJA,EAAa,WAA9JpC,OAAU,IAAG,IAAC,EAAE,EAAiIoC,EAAa,SAA9InC,OAAQ,IAAG,IAAIhB,KAAKiB,GAAE,EAAEI,EAAyG8B,EAAa,WAA1G/B,EAA6F+B,EAAa,SAAhGjC,EAAmFiC,EAAa,UAAxEE,EAA2DF,EAAa,YAA5CG,EAA+BH,EAAa,SAA7BI,EAAgBJ,EAAa,YAElM/N,EAAQU,EAAMiG,cACdxG,EAAQO,EAAMwG,cACdI,EAAItH,EAAMkD,OAGhB,GAAU,IAANoE,EAIF,OAHI6G,GACFA,IAEK,CACLnO,MAAO,GACPG,MAAO,IAKL,QA0QV,SAAyBgL,EAA2BC,EAA4B4C,GAC9E,IAAII,EAAkBjD,EAClBkD,EAAmBjD,EACnBkD,EAAmBN,EAUvB,OATKI,GAAqC,oBAAXG,SAC7BH,EAAkBG,OAAOC,YAEtBH,GAAsC,oBAAXE,SAC9BF,EAAmBE,OAAOE,aAEvBH,IACHA,EAAmB,CAACF,EAAmB,EAAGC,EAAoB,IAEzD,CAACD,EAAkBC,EAAmBC,EAC/C,CAxRkEI,CAAgBvD,EAAOC,EAAQ4C,GAAO,GAA7FI,EAAe,KAAEC,EAAgB,KAAEC,EAAgB,KAG1D,GAAU,IAANhH,EASF,OARIgB,IACF5H,EAAMgE,eAAe1E,EAAM,GAAGqB,GAAI,IAAKiN,EAAiB,IACxD5N,EAAMgE,eAAe1E,EAAM,GAAGqB,GAAI,IAAKiN,EAAiB,KAGtDH,GACFA,IAEK,CACLnO,MAAO,CACL,CACEqB,GAAI,UAAGrB,EAAM,GAAGqB,IAChBsN,EAAGL,EAAiB,GACpBM,EAAGN,EAAiB,KAGxBnO,MAAO,IAIX,IAAM0O,GAAajD,EAAWD,GAAcrE,EACtCjI,EAAoB,CAAC,EAC3BW,EAAMa,SAAQ,SAACiD,EAAM2E,GACnBpJ,EAAQyE,EAAKzC,IAAMoH,CACrB,IACA,IAAMgE,EH3Fe,SACvBnF,EACAwH,EACA3O,GAGA,IADA,IAAMsM,EAAoB,GACjBhE,EAAI,EAAGA,EAAInB,EAAGmB,IACrBgE,EAAQhE,GAAK,CACXsG,GAAI,EACJC,IAAK,EACL3B,IAAK,GAGT,OAAKlN,GACLA,EAAMU,SAAQ,SAACqI,GACb,IAAMxF,EAAS2G,EAAgBnB,EAAG,UAC5B3F,EAAS8G,EAAgBnB,EAAG,UAC9BxF,GAAU+I,EAAQqC,EAAWpL,MAC/B+I,EAAQqC,EAAWpL,IAASsL,KAAO,EACnCvC,EAAQqC,EAAWpL,IAAS2J,KAAO,GAEjC9J,GAAUkJ,EAAQqC,EAAWvL,MAC/BkJ,EAAQqC,EAAWvL,IAASwL,IAAM,EAClCtC,EAAQqC,EAAWvL,IAAS8J,KAAO,EAEvC,IACOZ,GAbYA,CAcrB,CGgEoBxJ,CAAUjD,EAAMkD,OAAQ7D,EAASc,GAE3CqL,EAAmCuC,EAAa,OAAxCtC,EAA2BsC,EAAa,YAA3BrC,EAAcqC,EAAa,UACtD,GAAIE,EAAkB,CACpB,IAAM,EAAwBzD,EAAqB,GAAIyD,GACjD,EAAqBzD,EAAqB,GAAI0D,GAChD,GAAc,IAClBlO,EAAMa,SAAQ,SAACiD,GACb,IAAMmL,EAAQ,EAASnL,GACnB,EAAcmL,IAAO,EAAcA,EACzC,IACA,IAAI,EAAS,EACbjP,EAAMa,SAAQ,SAACiD,EAAM2E,GACN,GAAH,IAANA,EAAoB,GAAe,IACvB,EAAY3E,IAAS,IAAM,GAAe,GAC5D,IACA0H,EAAS,GAAU,EAAIZ,KAAKiB,G,MAClBL,GAAWC,GAAgBC,GAE3BD,GAAeC,EACzBD,EAAcC,EACLD,IAAgBC,IACzBA,EAAYD,GAJZD,EAAS6C,EAAmBD,EAAkBA,EAAkB,EAAIC,EAAmB,EAMzF,IAAMa,EAAQL,EAAY5C,EAEtBkD,EAAqB,GACrBC,EAAYpP,EAAMqD,KAAI,SAACS,GAAS,OAAAA,EAAKc,IAAL,IAGlCuK,EAFe,aAAbnD,EAEYQ,EAAiBC,EAAS2C,EAAWjP,EAAOd,GACpC,sBAAb2M,EAEKQ,EAAiBC,EAAS2C,EAAWjP,EAAOd,GAAS,GAC7C,WAAb2M,EA8Lf,SACES,EACAzM,GAEA,IAAMqP,EAA4B,GAMlC,OALArP,EAAMa,SAAQ,SAACiD,EAAM2E,GACnB3E,EAAKwI,OAASG,EAAQhE,GAAG4E,IACzBgC,EAAa9N,KAAKuC,EACpB,IACAuL,EAAaC,KAAKpD,GACXmD,CACT,CAvMoBE,CAAe9C,EAAS2C,GAGxBpP,EAIhB,IADA,IAAMwP,EAAO5E,KAAK6E,KAAKnI,EAAIyE,GAClBtD,EAAI,EAAGA,EAAInB,IAAKmB,EAAG,CAC1B,IAAIQ,EAAIuC,EACHvC,GAAqB,OAAhBwC,GAAsC,OAAdC,IAChCzC,EAAIwC,EAAgBhD,GAAKiD,EAAaD,IAAkBnE,EAAI,IAEzD2B,IACHA,EAAI,GAAU,IAAJR,GAAYnB,EAAI,IAE5B,IAAIoI,EACF/D,EACClD,EAAI+G,EAAQN,EACX,EAAItE,KAAKiB,GAAME,EAAcnB,KAAK+E,MAAMlH,EAAI+G,GAC3C1D,IACH4D,EACE9D,EACCnD,EAAI+G,EAAQN,EACX,EAAItE,KAAKiB,GAAME,EAAcnB,KAAK+E,MAAMlH,EAAI+G,IAElDL,EAAY1G,GAAGkG,EAAIL,EAAiB,GAAK1D,KAAKgF,IAAIF,GAASzG,EAC3DkG,EAAY1G,GAAGmG,EAAIN,EAAiB,GAAK1D,KAAKiF,IAAIH,GAASzG,EAC3DkG,EAAY1G,GAAGqH,OAASrD,EAAQhE,GAAG4E,G,CAiBrC,OAdI/E,GACF6G,EAAYtO,SAAQ,SAACiD,GACnBpD,EAAMmE,cAAcf,EAAKzC,GAAI,CAC3BsN,EAAG7K,EAAK6K,EACRC,EAAG9K,EAAK8K,EACRkB,OAAQhM,EAAKgM,QAEjB,IAGE3B,GACFA,IAGK,CACLnO,MAAOmP,EACPhP,MAAK,EAET,EACF,EA7JA,IExBO,SAAS4P,EAAgBC,EAAkBC,GACxC,MAA0CD,EAAO,OAAvC3O,EAAE,KAAEtB,EAAO,UAAIC,EAAiBgQ,EAAO,MAAjB7P,EAAU6P,EAAO,MAMnDtP,EAAQ,IAAItB,EAAM,CACtBY,MAAOA,EACPG,MAAOA,IAQH+P,EAAavC,EAAStM,GAC5B,IAAI6O,EAGF,MAAM,IAAIlO,MAAM,sBAAwBX,GAM1C,MAAO,CARI,IAAI6O,EAAWnQ,GAMP8N,QAAQnN,GAERuP,EACrB,C","sources":["webpack://Layout/webpack/bootstrap","webpack://Layout/webpack/runtime/define property getters","webpack://Layout/webpack/runtime/hasOwnProperty shorthand","webpack://Layout/../../node_modules/@antv/graphlib/esm/Graph.js","webpack://Layout/../../node_modules/tslib/tslib.es6.js","webpack://Layout/./src/util/string.ts","webpack://Layout/./src/util/array.ts","webpack://Layout/./src/util/object.ts","webpack://Layout/./src/util/math.ts","webpack://Layout/./src/util/function.ts","webpack://Layout/./src/util/number.ts","webpack://Layout/./src/circular.ts","webpack://Layout/./src/registry.ts","webpack://Layout/./src/worker.ts"],"sourcesContent":["// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","export class Graph {\n nodeMap = new Map();\n edgeMap = new Map();\n inEdgesMap = new Map();\n outEdgesMap = new Map();\n treeIndices = new Map();\n changes = [];\n batchCount = 0;\n /**\n * This function is called with a {@link GraphChangedEvent} each time a graph change happened.\n *\n * `event.changes` contains all the graph changes in order since last `onChanged`.\n */\n onChanged = () => {\n // Do nothing.\n };\n /**\n * Create a new Graph instance.\n * @param options - The options to initialize a graph. See {@link GraphOptions}.\n *\n * ```ts\n * const graph = new Graph({\n * // Optional, initial nodes.\n * nodes: [\n * // Each node has a unique ID.\n * { id: 'A', foo: 1 },\n * { id: 'B', foo: 1 },\n * ],\n * // Optional, initial edges.\n * edges: [\n * { id: 'C', source: 'B', target: 'B', weight: 1 },\n * ],\n * // Optional, called with a GraphChangedEvent.\n * onChanged: (event) => {\n * console.log(event);\n * }\n * });\n * ```\n */\n constructor(options) {\n if (!options)\n return;\n if (options.nodes)\n this.addNodes(options.nodes);\n if (options.edges)\n this.addEdges(options.edges);\n if (options.tree)\n this.addTree(options.tree);\n if (options.onChanged)\n this.onChanged = options.onChanged;\n }\n /**\n * Batch several graph changes into one.\n *\n * Make several changes, but dispatch only one ChangedEvent at the end of batch:\n * ```ts\n * graph.batch(() => {\n * graph.addNodes([]);\n * graph.addEdges([]);\n * });\n * ```\n *\n * Batches can be nested. Only the outermost batch will dispatch a ChangedEvent:\n * ```ts\n * graph.batch(() => {\n * graph.addNodes([]);\n * graph.batch(() => {\n * graph.addEdges([]);\n * });\n * });\n * ```\n */\n batch = (fn) => {\n this.batchCount += 1;\n fn();\n this.batchCount -= 1;\n if (!this.batchCount) {\n this.commit();\n }\n };\n /**\n * Reset changes and dispatch a ChangedEvent.\n */\n commit() {\n const changes = this.changes;\n this.changes = [];\n this.onChanged({\n graph: this,\n changes,\n });\n }\n /**\n * Reduce the number of ordered graph changes by dropping or merging unnecessary changes.\n *\n * For example, if we update a node and remove it in a batch:\n *\n * ```ts\n * graph.batch(() => {\n * graph.updateNodeData('A', 'foo', 2);\n * graph.removeNode('A');\n * });\n * ```\n *\n * We get 2 atomic graph changes like\n *\n * ```ts\n * [\n * { type: 'NodeDataUpdated', id: 'A', propertyName: 'foo', oldValue: 1, newValue: 2 },\n * { type: 'NodeRemoved', value: { id: 'A', data: { foo: 2 } },\n * ]\n * ```\n *\n * Since node 'A' has been removed, we actually have no need to handle with NodeDataUpdated change.\n *\n * `reduceChanges()` here helps us remove such changes.\n */\n reduceChanges(changes) {\n let mergedChanges = [];\n changes.forEach((change) => {\n switch (change.type) {\n case 'NodeRemoved': {\n // NodeAdded: A added.\n // NodeDataUpdated: A changed.\n // TreeStructureChanged: A's parent changed.\n // NodeRemoved: A removed. 👈🏻 Since A was removed, above three changes may be ignored.\n let isNewlyAdded = false;\n mergedChanges = mergedChanges.filter((pastChange) => {\n if (pastChange.type === 'NodeAdded') {\n const sameId = pastChange.value.id === change.value.id;\n if (sameId) {\n isNewlyAdded = true;\n }\n return !sameId;\n }\n else if (pastChange.type === 'NodeDataUpdated') {\n return pastChange.id !== change.value.id;\n }\n else if (pastChange.type === 'TreeStructureChanged') {\n return pastChange.nodeId !== change.value.id;\n }\n return true;\n });\n if (!isNewlyAdded) {\n mergedChanges.push(change);\n }\n break;\n }\n case 'EdgeRemoved': {\n // EdgeAdded: A added.\n // EdgeDataUpdated: A changed.\n // EdgeDataUpdated: A's source/target changed.\n // EdgeRemoved: A removed. 👈🏻 Since A was removed, above three changes may be ignored.\n let isNewlyAdded = false;\n mergedChanges = mergedChanges.filter((pastChange) => {\n if (pastChange.type === 'EdgeAdded') {\n const sameId = pastChange.value.id === change.value.id;\n if (sameId) {\n isNewlyAdded = true;\n }\n return !sameId;\n }\n else if (pastChange.type === 'EdgeDataUpdated' ||\n pastChange.type === 'EdgeUpdated') {\n return pastChange.id !== change.value.id;\n }\n return true;\n });\n if (!isNewlyAdded) {\n mergedChanges.push(change);\n }\n break;\n }\n case 'NodeDataUpdated':\n case 'EdgeDataUpdated':\n case 'EdgeUpdated': {\n // NodeDataUpdated: { id: A, propertyName: 'foo', oldValue: 1, newValue: 2 }.\n // NodeDataUpdated: { id: A, propertyName: 'foo', oldValue: 2, newValue: 3 }.\n // 👆 Could be merged as { id: A, propertyName: 'foo', oldValue: 1, newValue: 3 }.\n const existingChange = mergedChanges.find((pastChange) => {\n return (pastChange.type === change.type &&\n pastChange.id === change.id &&\n pastChange.propertyName === change.propertyName);\n });\n if (existingChange) {\n existingChange.newValue = change.newValue;\n }\n else {\n mergedChanges.push(change);\n }\n break;\n }\n case 'TreeStructureDetached': {\n // TreeStructureAttached\n // TreeStructureChanged\n // TreeStructureDetached 👈🏻 Since the tree struct was detached, above 2 changes may be ignored.\n mergedChanges = mergedChanges.filter((pastChange) => {\n if (pastChange.type === 'TreeStructureAttached') {\n return pastChange.treeKey !== change.treeKey;\n }\n else if (pastChange.type === 'TreeStructureChanged') {\n return pastChange.treeKey !== change.treeKey;\n }\n return true;\n });\n mergedChanges.push(change);\n break;\n }\n case 'TreeStructureChanged': {\n const existingChange = mergedChanges.find((pastChange) => {\n return (pastChange.type === 'TreeStructureChanged' &&\n pastChange.treeKey === change.treeKey &&\n pastChange.nodeId === change.nodeId);\n });\n if (existingChange) {\n existingChange.newParentId =\n change.newParentId;\n }\n else {\n mergedChanges.push(change);\n }\n break;\n }\n default:\n mergedChanges.push(change);\n break;\n }\n });\n return mergedChanges;\n }\n // ================= Node =================\n checkNodeExistence(id) {\n if (!this.hasNode(id)) {\n throw new Error('Node not found for id: ' + id);\n }\n }\n /**\n * Check if a node exists in the graph.\n * @group NodeMethods\n */\n hasNode(id) {\n return this.nodeMap.has(id);\n }\n /**\n * Tell if two nodes are neighbors.\n * @group NodeMethods\n */\n areNeighbors(firstNodeId, secondNodeId) {\n this.checkNodeExistence(firstNodeId);\n return this.getNeighbors(secondNodeId).some((neighbor) => neighbor.id === firstNodeId);\n }\n /**\n * Get the node data with given ID.\n * @group NodeMethods\n */\n getNode(id) {\n this.checkNodeExistence(id);\n return this.nodeMap.get(id);\n }\n /**\n * Given a node ID, find all edges of the node.\n * @param id - ID of the node\n * @param direction - Edge direction, defaults to 'both'.\n * @group NodeMethods\n */\n getRelatedEdges(id, direction) {\n this.checkNodeExistence(id);\n const inEdges = this.inEdgesMap.get(id);\n const outEdges = this.outEdgesMap.get(id);\n if (direction === 'in') {\n return Array.from(inEdges);\n }\n else if (direction === 'out') {\n return Array.from(outEdges);\n }\n const bothEdges = new Set([...inEdges, ...outEdges]);\n return Array.from(bothEdges);\n }\n /**\n * Get the degree of the given node.\n * @group NodeMethods\n */\n getDegree(id, direction) {\n return this.getRelatedEdges(id, direction).length;\n }\n /**\n * Get all successors of the given node.\n */\n getSuccessors(id) {\n const outEdges = this.getRelatedEdges(id, 'out');\n const targets = outEdges.map((edge) => edge.target);\n return Array.from(new Set(targets)).map((id) => this.getNode(id));\n }\n /**\n * Get all predecessors of the given node.\n */\n getPredecessors(id) {\n const inEdges = this.getRelatedEdges(id, 'in');\n const sources = inEdges.map((edge) => edge.source);\n return Array.from(new Set(sources)).map((id) => this.getNode(id));\n }\n /**\n * Given a node ID, find its neighbors.\n * @param id - ID of the node\n * @group NodeMethods\n */\n getNeighbors(id) {\n const predecessors = this.getPredecessors(id);\n const successors = this.getSuccessors(id);\n return Array.from(new Set([...predecessors, ...successors]));\n }\n doAddNode(node) {\n if (this.hasNode(node.id)) {\n throw new Error('Node already exists: ' + node.id);\n }\n this.nodeMap.set(node.id, node);\n this.inEdgesMap.set(node.id, new Set());\n this.outEdgesMap.set(node.id, new Set());\n this.treeIndices.forEach((tree) => {\n tree.childrenMap.set(node.id, new Set());\n });\n this.changes.push({ type: 'NodeAdded', value: node });\n }\n /**\n * Add all nodes of the given array, or iterable, into the graph.\n * @group NodeMethods\n */\n addNodes(nodes) {\n this.batch(() => {\n for (const node of nodes) {\n this.doAddNode(node);\n }\n });\n }\n /**\n * Add a single node into the graph.\n * @group NodeMethods\n */\n addNode(node) {\n this.addNodes([node]);\n }\n doRemoveNode(id) {\n const node = this.getNode(id);\n const inEdges = this.inEdgesMap.get(id);\n const outEdges = this.outEdgesMap.get(id);\n inEdges?.forEach((edge) => this.doRemoveEdge(edge.id));\n outEdges?.forEach((edge) => this.doRemoveEdge(edge.id));\n this.nodeMap.delete(id);\n this.treeIndices.forEach((tree) => {\n tree.childrenMap.get(id)?.forEach((child) => {\n tree.parentMap.delete(child.id);\n });\n tree.parentMap.delete(id);\n tree.childrenMap.delete(id);\n });\n this.changes.push({ type: 'NodeRemoved', value: node });\n }\n /**\n * Remove nodes and their attached edges from the graph.\n * @group NodeMethods\n */\n removeNodes(idList) {\n this.batch(() => {\n idList.forEach((id) => this.doRemoveNode(id));\n });\n }\n /**\n * Remove a single node and its attached edges from the graph.\n * @group NodeMethods\n */\n removeNode(id) {\n this.removeNodes([id]);\n }\n /**\n * Update node data.\n * @group NodeMethods\n */\n updateNodeData(id, propertyName, value) {\n const node = this.getNode(id);\n this.batch(() => {\n const oldValue = node.data[propertyName];\n const newValue = value;\n node.data[propertyName] = newValue;\n this.changes.push({\n type: 'NodeDataUpdated',\n id,\n propertyName,\n oldValue,\n newValue,\n });\n });\n }\n /**\n * Like Object.assign, merge all properties of `path` to the node data.\n * @param id Node ID.\n * @param patch A data object to merge.\n */\n mergeNodeData(id, patch) {\n this.batch(() => {\n Object.entries(patch).forEach(([propertyName, value]) => {\n this.updateNodeData(id, propertyName, value);\n });\n });\n }\n // ================= Edge =================\n checkEdgeExistence(id) {\n if (!this.hasEdge(id)) {\n throw new Error('Edge not found for id: ' + id);\n }\n }\n /**\n * Check if an edge exists in the graph.\n * @group NodeMethods\n */\n hasEdge(id) {\n return this.edgeMap.has(id);\n }\n /**\n * Get the edge data with given ID.\n * @group EdgeMethods\n */\n getEdge(id) {\n this.checkEdgeExistence(id);\n return this.edgeMap.get(id);\n }\n /**\n * Get the edge, the source node, and the target node by an edge ID.\n * @group EdgeMethods\n */\n getEdgeDetail(id) {\n const edge = this.getEdge(id);\n return {\n edge,\n source: this.getNode(edge.source),\n target: this.getNode(edge.target),\n };\n }\n doAddEdge(edge) {\n if (this.hasEdge(edge.id)) {\n throw new Error('Edge already exists: ' + edge.id);\n }\n this.checkNodeExistence(edge.source);\n this.checkNodeExistence(edge.target);\n this.edgeMap.set(edge.id, edge);\n const inEdges = this.inEdgesMap.get(edge.target);\n const outEdges = this.outEdgesMap.get(edge.source);\n inEdges.add(edge);\n outEdges.add(edge);\n this.changes.push({ type: 'EdgeAdded', value: edge });\n }\n /**\n * Add all edges of the given iterable(an array, a set, etc.) into the graph.\n * @group EdgeMethods\n */\n addEdges(edges) {\n this.batch(() => {\n for (const edge of edges) {\n this.doAddEdge(edge);\n }\n });\n }\n /**\n * Add a single edge pointing from `source` to `target` into the graph.\n *\n * ```ts\n * graph.addNode({ id: 'NodeA' });\n * graph.addNode({ id: 'NodeB' });\n * graph.addEdge({ id: 'EdgeA', source: 'NodeA', target: 'NodeB' });\n * ```\n *\n * If `source` or `target` were not found in the current graph, it throws an Error.\n * @group EdgeMethods\n */\n addEdge(edge) {\n this.addEdges([edge]);\n }\n doRemoveEdge(id) {\n const edge = this.getEdge(id);\n const outEdges = this.outEdgesMap.get(edge.source);\n const inEdges = this.inEdgesMap.get(edge.target);\n outEdges.delete(edge);\n inEdges.delete(edge);\n this.edgeMap.delete(id);\n this.changes.push({ type: 'EdgeRemoved', value: edge });\n }\n /**\n * Remove edges whose id was included in the given id list.\n * @group EdgeMethods\n */\n removeEdges(idList) {\n this.batch(() => {\n idList.forEach((id) => this.doRemoveEdge(id));\n });\n }\n /**\n * Remove a single edge of the given id.\n * @group EdgeMethods\n */\n removeEdge(id) {\n this.removeEdges([id]);\n }\n /**\n * Change the source of an edge. The source must be found in current graph.\n * @group EdgeMethods\n */\n updateEdgeSource(id, source) {\n const edge = this.getEdge(id);\n this.checkNodeExistence(source);\n const oldSource = edge.source;\n const newSource = source;\n this.outEdgesMap.get(oldSource).delete(edge);\n this.outEdgesMap.get(newSource).add(edge);\n edge.source = source;\n this.batch(() => {\n this.changes.push({\n type: 'EdgeUpdated',\n id,\n propertyName: 'source',\n oldValue: oldSource,\n newValue: newSource,\n });\n });\n }\n /**\n * Change the target of an edge. The target must be found in current graph.\n * @group EdgeMethods\n */\n updateEdgeTarget(id, target) {\n const edge = this.getEdge(id);\n this.checkNodeExistence(target);\n const oldTarget = edge.target;\n const newTarget = target;\n this.inEdgesMap.get(oldTarget).delete(edge);\n this.inEdgesMap.get(newTarget).add(edge);\n edge.target = target;\n this.batch(() => {\n this.changes.push({\n type: 'EdgeUpdated',\n id,\n propertyName: 'target',\n oldValue: oldTarget,\n newValue: newTarget,\n });\n });\n }\n /**\n * Update edge data.\n * @group EdgeMethods\n */\n updateEdgeData(id, propertyName, value) {\n const edge = this.getEdge(id);\n this.batch(() => {\n const oldValue = edge.data[propertyName];\n const newValue = value;\n edge.data[propertyName] = newValue;\n this.changes.push({\n type: 'EdgeDataUpdated',\n id,\n propertyName,\n oldValue,\n newValue,\n });\n });\n }\n /**\n * @group EdgeMethods\n */\n mergeEdgeData(id, patch) {\n this.batch(() => {\n Object.entries(patch).forEach(([propertyName, value]) => {\n this.updateEdgeData(id, propertyName, value);\n });\n });\n }\n // ================= Tree =================\n checkTreeExistence(treeKey) {\n if (!this.treeIndices.has(treeKey)) {\n throw new Error('Tree structure not found for treeKey: ' + treeKey);\n }\n }\n /**\n * Attach a new tree structure representing the hierarchy of all nodes in the graph.\n * @param treeKey A unique key of the tree structure. You can attach multiple tree structures with different keys.\n *\n * ```ts\n * const graph = new Graph({\n * nodes: [{ id: 1 }, { id: 2 }, { id: 3 }],\n * });\n * graph.attachTreeStructure('Inheritance');\n * graph.setParent(2, 1, 'Inheritance');\n * graph.setParent(3, 1, 'Inheritance');\n * graph.getRoots('Inheritance'); // [1]\n * graph.getChildren(1, 'Inheritance'); // [2,3]\n * ```\n * @group TreeMethods\n */\n attachTreeStructure(treeKey) {\n if (this.treeIndices.has(treeKey)) {\n // Already attached.\n return;\n }\n this.treeIndices.set(treeKey, {\n parentMap: new Map(),\n childrenMap: new Map(),\n });\n this.batch(() => {\n this.changes.push({\n type: 'TreeStructureAttached',\n treeKey,\n });\n });\n }\n /**\n * Detach the tree structure of the given tree key from the graph.\n *\n * ```ts\n * graph.detachTreeStructure('Inheritance');\n * graph.getRoots('Inheritance'); // Error!\n * ```\n * @group TreeMethods\n */\n detachTreeStructure(treeKey) {\n this.checkTreeExistence(treeKey);\n this.treeIndices.delete(treeKey);\n this.batch(() => {\n this.changes.push({\n type: 'TreeStructureDetached',\n treeKey,\n });\n });\n }\n /**\n * Traverse the given tree data, add each node into the graph, then attach the tree structure.\n *\n * ```ts\n * graph.addTree({\n * id: 1,\n * children: [\n * { id: 2 },\n * { id: 3 },\n * ],\n * }, 'Inheritance');\n * graph.getRoots('Inheritance'); // [1]\n * graph.getChildren(1, 'Inheritance'); // [2, 3]\n * graph.getAllNodes(); // [1, 2, 3]\n * graph.getAllEdges(); // []\n * ```\n * @group TreeMethods\n */\n addTree(tree, treeKey) {\n this.batch(() => {\n this.attachTreeStructure(treeKey);\n // Add Nodes\n const nodes = [];\n const stack = Array.isArray(tree) ? tree : [tree];\n while (stack.length) {\n const node = stack.shift();\n nodes.push(node);\n if (node.children) {\n stack.push(...node.children);\n }\n }\n this.addNodes(nodes);\n // Set parent for each child node.\n nodes.forEach((parent) => {\n parent.children?.forEach((child) => {\n this.setParent(child.id, parent.id, treeKey);\n });\n });\n });\n }\n /**\n * Get the root nodes of an attached tree structure.\n *\n * Consider a graph with the following tree structure attached:\n * ```\n * Tree structure:\n * O 3\n * / \\ |\n * 1 2 4\n * ```\n * `graph.getRoots()` takes all nodes without a parent, therefore [0, 3] was returned.\n *\n * Newly added nodes are also unparented. So they are counted as roots.\n * ```ts\n * graph.addNode({ id: 5 });\n * graph.getRoots(); // [0, 3, 5]\n * ```\n *\n * Here is how the tree structure looks like:\n * ```\n * Tree structure:\n * O 3 5\n * / \\ |\n * 1 2 4\n * ```\n *\n * By setting a parent, a root node no more be a root.\n * ```ts\n * graph.setParent(5, 2);\n * graph.getRoots(); // [0, 3]\n * ```\n *\n * The tree structure now becomes:\n * ```\n * Tree structure:\n * O 3\n * / \\ |\n * 1 2 4\n * |\n * 5\n * ```\n *\n * Removing a node forces its children to be unparented, or roots.\n * ```ts\n * graph.removeNode(0);\n * graph.getRoots(); // [1, 2, 3]\n * ```\n *\n * You might draw the the structure as follow:\n * ```\n * Tree structure:\n * 1 2 3\n * | |\n * 5 4\n * ```\n * @group TreeMethods\n */\n getRoots(treeKey) {\n this.checkTreeExistence(treeKey);\n return this.getAllNodes().filter((node) => !this.getParent(node.id, treeKey));\n }\n /**\n * Given a node ID and an optional tree key, get the children of the node in the specified tree structure.\n * @group TreeMethods\n */\n getChildren(id, treeKey) {\n this.checkNodeExistence(id);\n this.checkTreeExistence(treeKey);\n const tree = this.treeIndices.get(treeKey);\n const children = tree.childrenMap.get(id);\n return Array.from(children || []);\n }\n /**\n * Given a node ID and an optional tree key, get the parent of the node in the specified tree structure.\n * If the given node is one of the tree roots, this returns null.\n * @group TreeMethods\n */\n getParent(id, treeKey) {\n this.checkNodeExistence(id);\n this.checkTreeExistence(treeKey);\n const tree = this.treeIndices.get(treeKey);\n return tree.parentMap.get(id) || null;\n }\n /**\n * Set node parent. If this operation causes a circle, it fails with an error.\n * @param id - ID of the child node.\n * @param parent - ID of the parent node.\n * @param treeKey - Which tree structure the relation is applied to.\n * @group TreeMethods\n */\n setParent(id, parent, treeKey) {\n this.checkTreeExistence(treeKey);\n const tree = this.treeIndices.get(treeKey);\n const node = this.getNode(id);\n const oldParent = tree.parentMap.get(id);\n const newParent = this.getNode(parent);\n // Set parent\n tree.parentMap.set(id, newParent);\n // Set children\n if (oldParent) {\n tree.childrenMap.get(oldParent.id)?.delete(node);\n }\n let children = tree.childrenMap.get(newParent.id);\n if (!children) {\n children = new Set();\n tree.childrenMap.set(newParent.id, children);\n }\n children.add(node);\n this.batch(() => {\n this.changes.push({\n type: 'TreeStructureChanged',\n treeKey,\n nodeId: id,\n oldParentId: oldParent?.id,\n newParentId: newParent.id,\n });\n });\n }\n // ================= Graph =================\n /**\n * Get all nodes in the graph as an array.\n */\n getAllNodes() {\n return Array.from(this.nodeMap.values());\n }\n /**\n * Get all edges in the graph as an array.\n */\n getAllEdges() {\n return Array.from(this.edgeMap.values());\n }\n doBFS(queue, visited, fn) {\n while (queue.length) {\n const node = queue.shift();\n fn(node);\n visited.add(node.id);\n this.getSuccessors(node.id).forEach((n) => {\n if (!visited.has(n.id)) {\n visited.add(n.id);\n queue.push(n);\n }\n });\n }\n }\n bfs(id, fn) {\n this.doBFS([this.getNode(id)], new Set(), fn);\n }\n doDFS(node, visited, fn) {\n fn(node);\n visited.add(node.id);\n this.getSuccessors(node.id).forEach((n) => {\n if (!visited.has(n.id)) {\n this.doDFS(n, visited, fn);\n }\n });\n }\n dfs(id, fn) {\n this.doDFS(this.getNode(id), new Set(), fn);\n }\n clone() {\n // Make a shallow copy of nodes and edges.\n const newNodes = this.getAllNodes().map((oldNode) => {\n return { ...oldNode, data: { ...oldNode.data } };\n });\n const newEdges = this.getAllEdges().map((oldEdge) => {\n return { ...oldEdge, data: { ...oldEdge.data } };\n });\n // Create a new graph with shallow copied nodes and edges.\n const newGraph = new Graph({\n nodes: newNodes,\n edges: newEdges,\n });\n // Add tree indices.\n this.treeIndices.forEach(({ parentMap: oldParentMap, childrenMap: oldChildrenMap }, treeKey) => {\n const parentMap = new Map();\n oldParentMap.forEach((parent, key) => {\n parentMap.set(key, newGraph.getNode(parent.id));\n });\n const childrenMap = new Map();\n oldChildrenMap.forEach((children, key) => {\n childrenMap.set(key, new Set(Array.from(children).map((n) => newGraph.getNode(n.id))));\n });\n newGraph.treeIndices.set(treeKey, {\n parentMap: parentMap,\n childrenMap: childrenMap,\n });\n });\n return newGraph;\n }\n toJSON() {\n return JSON.stringify({\n nodes: this.getAllNodes(),\n edges: this.getAllEdges(),\n // FIXME: And tree structures?\n });\n }\n}\n//# sourceMappingURL=Graph.js.map","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","export const isString = (val: unknown): val is string =>\n typeof val === \"string\";\n\nconst cacheStringFunction = <T extends (str: string) => string>(fn: T): T => {\n const cache: Record<string, string> = Object.create(null);\n return ((str: string) => {\n const hit = cache[str];\n return hit || (cache[str] = fn(str));\n }) as any;\n};\n\nconst camelizeRE = /-(\\w)/g;\nexport const camelize = cacheStringFunction((str: string): string => {\n return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : \"\"));\n});\n\n// export const capitalize = cacheStringFunction(\n// (str: string) => str.charAt(0).toUpperCase() + str.slice(1),\n// )\n","export const isArray = Array.isArray;\n","export const isObject = (val: unknown): val is Record<any, any> =>\n val !== null && typeof val === \"object\";\n\nexport const clone = <T>(target: T): T => {\n if (target === null) {\n return target;\n }\n if (target instanceof Date) {\n return new Date(target.getTime()) as any;\n }\n if (target instanceof Array) {\n const cp = [] as any[];\n (target as any[]).forEach((v) => {\n cp.push(v);\n });\n return cp.map((n: any) => clone<any>(n)) as any;\n }\n if (typeof target === \"object\" && Object.keys(target).length) {\n const cp = { ...(target as { [key: string]: any }) } as {\n [key: string]: any;\n };\n Object.keys(cp).forEach((k) => {\n cp[k] = clone<any>(cp[k]);\n });\n return cp as T;\n }\n return target;\n};\n","import {\n Matrix,\n Model,\n IndexMap,\n Edge,\n Node,\n OutNode,\n Degree,\n NodeMap,\n} from \"../types\";\nimport { isArray } from \"./array\";\nimport { isNumber } from \"./number\";\nimport { isObject } from \"./object\";\n\nexport const getEdgeTerminal = (edge: Edge, type: \"source\" | \"target\") => {\n const terminal = edge[type];\n if (isObject(terminal)) {\n return terminal.cell;\n }\n return terminal;\n};\n\nexport const getDegree = (\n n: number,\n nodeIdxMap: IndexMap,\n edges: Edge[] | null\n) => {\n const degrees: Degree[] = [];\n for (let i = 0; i < n; i++) {\n degrees[i] = {\n in: 0,\n out: 0,\n all: 0,\n };\n }\n if (!edges) return degrees;\n edges.forEach((e) => {\n const source = getEdgeTerminal(e, \"source\");\n const target = getEdgeTerminal(e, \"target\");\n if (source && degrees[nodeIdxMap[source]]) {\n degrees[nodeIdxMap[source]].out += 1;\n degrees[nodeIdxMap[source]].all += 1;\n }\n if (target && degrees[nodeIdxMap[target]]) {\n degrees[nodeIdxMap[target]].in += 1;\n degrees[nodeIdxMap[target]].all += 1;\n }\n });\n return degrees;\n};\n\nexport const getDegreeMap = (nodes: Node[], edges: Edge[] | null) => {\n const degreesMap: { [id: string]: Degree } = {};\n nodes.forEach((node) => {\n degreesMap[node.id] = {\n in: 0,\n out: 0,\n all: 0,\n };\n });\n\n if (!edges) return degreesMap;\n edges.forEach((e) => {\n const source = getEdgeTerminal(e, \"source\");\n const target = getEdgeTerminal(e, \"target\");\n if (source) {\n degreesMap[source].out += 1;\n degreesMap[source].all += 1;\n }\n if (target) {\n degreesMap[target].in += 1;\n degreesMap[target].all += 1;\n }\n });\n return degreesMap;\n};\n\nexport const floydWarshall = (adjMatrix: Matrix[]): Matrix[] => {\n // initialize\n const dist: Matrix[] = [];\n const size = adjMatrix.length;\n for (let i = 0; i < size; i += 1) {\n dist[i] = [];\n for (let j = 0; j < size; j += 1) {\n if (i === j) {\n dist[i][j] = 0;\n } else if (adjMatrix[i][j] === 0 || !adjMatrix[i][j]) {\n dist[i][j] = Infinity;\n } else {\n dist[i][j] = adjMatrix[i][j];\n }\n }\n }\n // floyd\n for (let k = 0; k < size; k += 1) {\n for (let i = 0; i < size; i += 1) {\n for (let j = 0; j < size; j += 1) {\n if (dist[i][j] > dist[i][k] + dist[k][j]) {\n dist[i][j] = dist[i][k] + dist[k][j];\n }\n }\n }\n }\n return dist;\n};\n\nexport const getAdjMatrix = (data: Model, directed: boolean): Matrix[] => {\n const { nodes, edges } = data;\n const matrix: Matrix[] = [];\n // map node with index in data.nodes\n const nodeMap: {\n [key: string]: number;\n } = {};\n\n if (!nodes) {\n throw new Error(\"invalid nodes data!\");\n }\n if (nodes) {\n nodes.forEach((node, i) => {\n nodeMap[node.id] = i;\n const row: number[] = [];\n matrix.push(row);\n });\n }\n\n edges?.forEach((e) => {\n const source = getEdgeTerminal(e, \"source\");\n const target = getEdgeTerminal(e, \"target\");\n const sIndex = nodeMap[source as string];\n const tIndex = nodeMap[target as string];\n if (sIndex === undefined || tIndex === undefined) return;\n matrix[sIndex][tIndex] = 1;\n if (!directed) {\n matrix[tIndex][sIndex] = 1;\n }\n });\n return matrix;\n};\n\n/**\n * scale matrix\n * @param matrix [ [], [], [] ]\n * @param ratio\n */\nexport const scaleMatrix = (matrix: Matrix[], ratio: number) => {\n const result: Matrix[] = [];\n matrix.forEach((row) => {\n const newRow: number[] = [];\n row.forEach((v) => {\n newRow.push(v * ratio);\n });\n result.push(newRow);\n });\n return result;\n};\n\n/**\n * depth first traverse, from leaves to root, children in inverse order\n * if the fn returns false, terminate the traverse\n */\nconst traverseUp = <T extends { children?: T[] }>(\n data: T,\n fn: (param: T) => boolean\n) => {\n if (data && data.children) {\n for (let i = data.children.length - 1; i >= 0; i--) {\n if (!traverseUp(data.children[i], fn)) return;\n }\n }\n\n if (!fn(data)) {\n return false;\n }\n return true;\n};\n\n/**\n * depth first traverse, from leaves to root, children in inverse order\n * if the fn returns false, terminate the traverse\n */\nexport const traverseTreeUp = <T extends { children?: T[] }>(\n data: T,\n fn: (param: T) => boolean\n) => {\n if (typeof fn !== \"function\") {\n return;\n }\n traverseUp(data, fn);\n};\n\n/**\n * calculate the bounding box for the nodes according to their x, y, and size\n * @param nodes nodes in the layout\n * @returns\n */\nexport const getLayoutBBox = (nodes: OutNode[]) => {\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n nodes.forEach((node) => {\n let size = node.size;\n if (isArray(size)) {\n if (size.length === 1) size = [size[0], size[0]];\n } else if (isNumber(size)) {\n size = [size, size];\n } else if (size === undefined || isNaN(size as any)) {\n size = [30, 30];\n }\n\n const halfSize = [size[0] / 2, size[1] / 2];\n const left = node.x - halfSize[0];\n const right = node.x + halfSize[0];\n const top = node.y - halfSize[1];\n const bottom = node.y + halfSize[1];\n\n if (minX > left) minX = left;\n if (minY > top) minY = top;\n if (maxX < right) maxX = right;\n if (maxY < bottom) maxY = bottom;\n });\n return { minX, minY, maxX, maxY };\n};\n\n/**\n * 获取节点集合的平均位置信息\n * @param nodes 节点集合\n * @returns 平局内置\n */\nexport const getAvgNodePosition = (nodes: OutNode[]) => {\n const totalNodes = { x: 0, y: 0 };\n nodes.forEach((node) => {\n totalNodes.x += node.x || 0;\n totalNodes.y += node.y || 0;\n });\n // 获取均值向量\n const length = nodes.length || 1;\n return {\n x: totalNodes.x / length,\n y: totalNodes.y / length,\n };\n};\n\n// 找出指定节点关联的边的起点或终点\nconst getCoreNode = (type: \"source\" | \"target\", node: Node, edges: Edge[]) => {\n if (type === \"source\") {\n return (edges?.find((edge) => edge.target === node.id)?.source ||\n {}) as Node;\n }\n return (edges?.find((edge) => edge.source === node.id)?.target || {}) as Node;\n};\n\n// 找出指定节点为起点或终点的所有一度叶子节点\nconst getRelativeNodeIds = (\n type: \"source\" | \"target\" | \"both\",\n coreNode: Node,\n edges: Edge[]\n) => {\n let relativeNodes: string[] = [];\n switch (type) {\n case \"source\":\n relativeNodes = edges\n ?.filter((edge) => edge.source === coreNode.id)\n .map((edge) => edge.target);\n break;\n case \"target\":\n relativeNodes = edges\n ?.filter((edge) => edge.target === coreNode.id)\n .map((edge) => edge.source);\n break;\n case \"both\":\n relativeNodes = edges\n ?.filter((edge) => edge.source === coreNode.id)\n .map((edge) => edge.target)\n .concat(\n edges\n ?.filter((edge) => edge.target === coreNode.id)\n .map((edge) => edge.source)\n );\n break;\n default:\n break;\n }\n // 去重\n const set = new Set(relativeNodes);\n return Array.from(set);\n};\n// 找出同类型的节点\nconst getSameTypeNodes = (\n type: \"leaf\" | \"all\",\n nodeClusterBy: string,\n node: Node,\n relativeNodes: Node[],\n degreesMap: { [id: string]: Degree }\n) => {\n // @ts-ignore\n const typeName = node[nodeClusterBy] || \"\";\n // @ts-ignore\n let sameTypeNodes =\n relativeNodes?.filter((item) => item[nodeClusterBy] === typeName) || [];\n if (type === \"leaf\") {\n sameTypeNodes = sameTypeNodes.filter(\n (node) => degreesMap[node.id]?.in === 0 || degreesMap[node.id]?.out === 0\n );\n }\n return sameTypeNodes;\n};\n\n// 找出与指定节点关联的边的起点或终点出发的所有一度叶子节点\nexport const getCoreNodeAndRelativeLeafNodes = (\n type: \"leaf\" | \"all\",\n node: Node,\n edges: Edge[],\n nodeClusterBy: string,\n degreesMap: { [id: string]: Degree },\n nodeMap: NodeMap\n) => {\n const { in: inDegree, out: outDegree } = degreesMap[node.id];\n let coreNode: Node = node;\n let relativeLeafNodes: Node[] = [];\n if (inDegree === 0) {\n // 如果为没有出边的叶子节点,则找出与它关联的边的起点出发的所有一度节点\n coreNode = getCoreNode(\"source\", node, edges);\n relativeLeafNodes = getRelativeNodeIds(\"both\", coreNode, edges).map(\n (nodeId) => nodeMap[nodeId]\n );\n } else if (outDegree === 0) {\n // 如果为没有入边边的叶子节点,则找出与它关联的边的起点出发的所有一度节点\n coreNode = getCoreNode(\"target\", node, edges);\n relativeLeafNodes = getRelativeNodeIds(\"both\", coreNode, edges).map(\n (nodeId) => nodeMap[nodeId]\n );\n }\n relativeLeafNodes = relativeLeafNodes.filter(\n (node) =>\n degreesMap[node.id] &&\n (degreesMap[node.id].in === 0 || degreesMap[node.id].out === 0)\n );\n const sameTypeLeafNodes = getSameTypeNodes(\n type,\n nodeClusterBy,\n node,\n relativeLeafNodes,\n degreesMap\n );\n return { coreNode, relativeLeafNodes, sameTypeLeafNodes };\n};\n","import { isArray, isObject } from \".\";\nimport { isNumber } from \"./number\";\n\nexport const isFunction = (val: unknown): val is Function =>\n typeof val === \"function\";\n\nexport const getFunc = (\n value: number,\n defaultValue: number,\n func?: ((d?: any) => number) | undefined\n): Function => {\n let resultFunc;\n if (func) {\n resultFunc = func;\n } else if (isNumber(value)) {\n resultFunc = () => value;\n } else {\n resultFunc = () => defaultValue;\n }\n return resultFunc;\n};\n\nexport const getFuncByUnknownType = (\n defaultValue: number,\n value?:\n | number\n | number[]\n | { width: number; height: number }\n | ((d?: any) => number)\n | undefined,\n resultIsNumber: boolean = true\n): ((d?: any) => number | number[]) => {\n if (!value && value !== 0) {\n return (d) => {\n if (d.size) {\n if (isArray(d.size))\n return d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n if (isObject(d.size))\n return d.size.width > d.size.height ? d.size.width : d.size.height;\n return d.size;\n }\n return defaultValue;\n };\n }\n if (isFunction(value)) {\n return value;\n }\n if (isNumber(value)) {\n return () => value;\n }\n if (isArray(value)) {\n return () => {\n if (resultIsNumber) {\n const max = Math.max(...(value as number[]));\n return isNaN(max) ? defaultValue : max;\n }\n return value;\n };\n }\n if (isObject(value)) {\n return () => {\n if (resultIsNumber) {\n const max = Math.max(value.width, value.height);\n return isNaN(max) ? defaultValue : max;\n }\n return [value.width, value.height];\n };\n }\n return () => defaultValue;\n};\n","export const isNumber = (val: unknown): val is Number =>\n typeof val === \"number\";\n\nexport const isNaN = (num: unknown) => Number.isNaN(Number(num));\n\nexport const toNumber = (val: any): any => {\n const n = parseFloat(val);\n return isNaN(n) ? val : n;\n};\n","import type { Graph } from \"@antv/graphlib\";\nimport type { CircularLayoutOptions, SyncLayout, LayoutMapping, PointTuple, IndexMap, OutNode, Edge, Degree } from \"./types\";\nimport { getDegree, getEdgeTerminal, getFuncByUnknownType, clone } from \"./util\";\n\ntype INodeData = OutNode & {\n degree: number;\n size: number | PointTuple;\n weight: number;\n children: string[];\n parent: string[];\n};\n\ntype IEdgeData = {};\n\nconst DEFAULTS_LAYOUT_OPTIONS: Partial<CircularLayoutOptions> = {\n radius: null,\n startRadius: null,\n endRadius: null,\n startAngle: 0,\n endAngle: 2 * Math.PI,\n clockwise: true,\n divisions: 1,\n ordering: null,\n angleRatio: 1\n}\n\n/**\n * Layout arranging the nodes in a circle.\n * \n * @example\n * // Assign layout options when initialization.\n * const layout = new CircularLayout({ radius: 10 });\n * const positions = layout.execute(graph); // { nodes: [], edges: [] }\n * \n * // Or use different options later.\n * const layout = new CircularLayout({ radius: 10 });\n * const positions = layout.execute(graph, { radius: 20 }); // { nodes: [], edges: [] }\n * \n * // If you want to assign the positions directly to the nodes, use assign method.\n * layout.assign(graph, { radius: 20 });\n */\nexport class CircularLayout implements SyncLayout<CircularLayoutOptions> {\n id = 'circular';\n\n constructor(public options: CircularLayoutOptions = {} as CircularLayoutOptions) {\n Object.assign(this.options, DEFAULTS_LAYOUT_OPTIONS, options);\n }\n\n /**\n * Return the positions of nodes and edges(if needed).\n */\n execute(graph: Graph<INodeData, IEdgeData>, options?: CircularLayoutOptions): LayoutMapping {\n return this.genericCircularLayout(false, graph, options) as LayoutMapping;\n }\n\n /**\n * To directly assign the positions to the nodes.\n */\n assign(graph: Graph<INodeData, IEdgeData>, options?: CircularLayoutOptions) {\n graph.batch(() => {\n this.genericCircularLayout(true, graph, options);\n });\n }\n\n private genericCircularLayout(assign: boolean, graph: Graph<INodeData, IEdgeData>, options?: CircularLayoutOptions): LayoutMapping | void {\n const mergedOptions = { ...this.options, ...options };\n const { width, height, center, divisions, startAngle = 0, endAngle = 2 * Math.PI, angleRatio, ordering, clockwise, nodeSpacing: paramNodeSpacing, nodeSize: paramNodeSize, onLayoutEnd } = mergedOptions;\n\n const nodes = graph.getAllNodes();\n const edges = graph.getAllEdges() as Edge[];\n const n = nodes.length;\n\n // Need no layout if there is no node.\n if (n === 0) {\n if (onLayoutEnd) {\n onLayoutEnd();\n }\n return {\n nodes: [],\n edges: [],\n };\n }\n\n // Calculate center according to `window` if not provided.\n const [calculatedWidth, calculatedHeight, calculatedCenter] = calculateCenter(width, height, center);\n\n // Layout easily if there is only one node.\n if (n === 1) {\n if (assign) {\n graph.updateNodeData(nodes[0].id, \"x\", calculatedCenter[0]);\n graph.updateNodeData(nodes[0].id, \"y\", calculatedCenter[1]);\n }\n \n if (onLayoutEnd) {\n onLayoutEnd();\n }\n return {\n nodes: [\n {\n id: `${nodes[0].id}`,\n x: calculatedCenter[0],\n y: calculatedCenter[1],\n }\n ],\n edges: [],\n };\n }\n\n const angleStep = (endAngle - startAngle) / n;\n const nodeMap: IndexMap = {};\n nodes.forEach((node, i) => {\n nodeMap[node.id] = i;\n });\n const degrees = getDegree(nodes.length, nodeMap, edges as Edge[]);\n\n let { radius, startRadius, endRadius } = mergedOptions;\n if (paramNodeSpacing) {\n const nodeSpacing: Function = getFuncByUnknownType(10, paramNodeSpacing);\n const nodeSize: Function = getFuncByUnknownType(10, paramNodeSize);\n let maxNodeSize = -Infinity;\n nodes.forEach((node) => {\n const nSize = nodeSize(node);\n if (maxNodeSize < nSize) maxNodeSize = nSize;\n });\n let length = 0;\n nodes.forEach((node, i) => {\n if (i === 0) length += (maxNodeSize || 10);\n else length += (nodeSpacing(node) || 0) + (maxNodeSize || 10);\n });\n radius = length / (2 * Math.PI);\n } else if (!radius && !startRadius && !endRadius) {\n radius = calculatedHeight > calculatedWidth ? calculatedWidth / 2 : calculatedHeight / 2;\n } else if (!startRadius && endRadius) {\n startRadius = endRadius;\n } else if (startRadius && !endRadius) {\n endRadius = startRadius;\n }\n const astep = angleStep * angleRatio!;\n\n let layoutNodes: any[] = [];\n let nodesData = nodes.map((node) => node.data);\n if (ordering === \"topology\") {\n // layout according to the topology\n layoutNodes = topologyOrdering(degrees, nodesData, edges, nodeMap);\n } else if (ordering === \"topology-directed\") {\n // layout according to the topology\n layoutNodes = topologyOrdering(degrees, nodesData, edges, nodeMap, true);\n } else if (ordering === \"degree\") {\n // layout according to the descent order of degrees\n layoutNodes = degreeOrdering(degrees, nodesData);\n } else {\n // layout according to the original order in the data.nodes\n layoutNodes = nodes;\n }\n\n const divN = Math.ceil(n / divisions!); // node number in each division\n for (let i = 0; i < n; ++i) {\n let r = radius;\n if (!r && startRadius !== null && endRadius !== null) {\n r = startRadius! + (i * (endRadius! - startRadius!)) / (n - 1);\n }\n if (!r) {\n r = 10 + (i * 100) / (n - 1);\n }\n let angle =\n startAngle +\n (i % divN) * astep +\n ((2 * Math.PI) / divisions!) * Math.floor(i / divN);\n if (!clockwise) {\n angle =\n endAngle -\n (i % divN) * astep -\n ((2 * Math.PI) / divisions!) * Math.floor(i / divN);\n }\n layoutNodes[i].x = calculatedCenter[0] + Math.cos(angle) * r;\n layoutNodes[i].y = calculatedCenter[1] + Math.sin(angle) * r;\n layoutNodes[i].weight = degrees[i].all;\n }\n\n if (assign) {\n layoutNodes.forEach((node) => {\n graph.mergeNodeData(node.id, {\n x: node.x,\n y: node.y,\n weight: node.weight,\n });\n });\n }\n\n if (onLayoutEnd) {\n onLayoutEnd();\n };\n\n return {\n nodes: layoutNodes,\n edges\n };\n }\n}\n\nfunction initHierarchy(\n nodes: INodeData[],\n edges: Edge[],\n nodeMap: IndexMap,\n directed: boolean\n) {\n nodes.forEach((_, i: number) => {\n nodes[i].children = [];\n nodes[i].parent = [];\n });\n if (directed) {\n edges.forEach((e) => {\n const source = getEdgeTerminal(e, 'source');\n const target = getEdgeTerminal(e, 'target');\n let sourceIdx = 0;\n if (source) {\n sourceIdx = nodeMap[source];\n }\n let targetIdx = 0;\n if (target) {\n targetIdx = nodeMap[target];\n }\n const child = nodes[sourceIdx].children!;\n const parent = nodes[targetIdx].parent!;\n child.push(nodes[targetIdx].id);\n parent.push(nodes[sourceIdx].id);\n });\n } else {\n edges.forEach((e) => {\n const source = getEdgeTerminal(e, 'source');\n const target = getEdgeTerminal(e, 'target');\n let sourceIdx = 0;\n if (source) {\n sourceIdx = nodeMap[source];\n }\n let targetIdx = 0;\n if (target) {\n targetIdx = nodeMap[target];\n }\n const sourceChildren = nodes[sourceIdx].children!;\n const targetChildren = nodes[targetIdx].children!;\n sourceChildren.push(nodes[targetIdx].id);\n targetChildren.push(nodes[sourceIdx].id);\n });\n }\n}\n\nfunction connect(a: INodeData, b: INodeData, edges: Edge[]) {\n const m = edges.length;\n for (let i = 0; i < m; i++) {\n const source = getEdgeTerminal(edges[i], 'source');\n const target = getEdgeTerminal(edges[i], 'target');\n if (\n (a.id === source && b.id === target) ||\n (b.id === source && a.id === target)\n ) {\n return true;\n }\n }\n return false;\n}\n\nfunction compareDegree(a: INodeData, b: INodeData) {\n const aDegree = a.degree!;\n const bDegree = b.degree!;\n if (aDegree < bDegree) {\n return -1;\n }\n if (aDegree > bDegree) {\n return 1;\n }\n return 0;\n}\n\nfunction topologyOrdering(\n degrees: Degree[],\n nodes: INodeData[],\n edges: Edge[],\n nodeMap: IndexMap, \n directed: boolean = false\n) {\n const cnodes = clone(nodes);\n const orderedCNodes = [cnodes[0]];\n const resNodes = [nodes[0]];\n const pickFlags: boolean[] = [];\n const n = nodes.length;\n pickFlags[0] = true;\n initHierarchy(cnodes, edges, nodeMap, directed);\n let k = 0;\n cnodes.forEach((cnode, i) => {\n if (i !== 0) {\n if (\n (i === n - 1 ||\n degrees[i].all !== degrees[i + 1].all ||\n connect(\n orderedCNodes[k],\n cnode,\n edges\n )) &&\n !pickFlags[i]\n ) {\n orderedCNodes.push(cnode);\n resNodes.push(nodes[nodeMap[cnode.id]]);\n pickFlags[i] = true;\n k++;\n } else {\n const children = orderedCNodes[k].children!;\n let foundChild = false;\n for (let j = 0; j < children.length; j++) {\n const childIdx = nodeMap[children[j]];\n if (degrees[childIdx].all === degrees[i].all && !pickFlags[childIdx]) {\n orderedCNodes.push(cnodes[childIdx]);\n resNodes.push(nodes[nodeMap[cnodes[childIdx].id]]);\n pickFlags[childIdx] = true;\n foundChild = true;\n break;\n }\n }\n let ii = 0;\n while (!foundChild) {\n if (!pickFlags[ii]) {\n orderedCNodes.push(cnodes[ii]);\n resNodes.push(nodes[nodeMap[cnodes[ii].id]]);\n pickFlags[ii] = true;\n foundChild = true;\n }\n ii++;\n if (ii === n) {\n break;\n }\n }\n }\n }\n });\n return resNodes;\n}\n\nfunction degreeOrdering(\n degrees: Degree[],\n nodes: INodeData[],\n): INodeData[] {\n const orderedNodes: INodeData[] = [];\n nodes.forEach((node, i) => {\n node.degree = degrees[i].all;\n orderedNodes.push(node);\n });\n orderedNodes.sort(compareDegree);\n return orderedNodes;\n}\n\nfunction calculateCenter(width: number | undefined, height: number | undefined, center: PointTuple | undefined): [number, number, PointTuple] {\n let calculatedWidth = width;\n let calculatedHeight = height;\n let calculatedCenter = center;\n if (!calculatedWidth && typeof window !== \"undefined\") {\n calculatedWidth = window.innerWidth;\n }\n if (!calculatedHeight && typeof window !== \"undefined\") {\n calculatedHeight = window.innerHeight;\n }\n if (!calculatedCenter) {\n calculatedCenter = [calculatedWidth! / 2, calculatedHeight! / 2];\n }\n return [calculatedWidth!, calculatedHeight!, calculatedCenter];\n}","import { CircularLayout } from \"./circular\";\nimport type { SyncLayoutConstructor } from \"./types\";\n\nexport const registry: Record<string, SyncLayoutConstructor<any>> = {\n circular: CircularLayout,\n};\nexport function registerLayout(id: string, layout: SyncLayoutConstructor<any>) {\n registry[id] = layout;\n}\n","import { Graph } from \"@antv/graphlib\";\n// import { setupTransferableMethodsOnWorker } from \"@naoak/workerize-transferable\";\nimport { registry } from \"./registry\";\nimport type { Payload } from \"./supervisor\";\nimport type { LayoutMapping, SyncLayout } from \"./types\";\n\n// @see https://www.npmjs.com/package/@naoak/workerize-transferable\n// setupTransferableMethodsOnWorker({\n// // The name of function which use some transferables.\n// calculateLayout: {\n// // Specify an instance of the function\n// fn: calculateLayout,\n// // Pick a transferable object from the result which is an instance of Float32Array\n// pickTransferablesFromResult: (result) => [result[1].buffer],\n// },\n// });\n\nexport function calculateLayout(payload: Payload, transferables: Float32Array[]) {\n const { layout: { id, options }, nodes, edges } = payload;\n\n // Sync graph on the worker side.\n // TODO: Use transferable objects like ArrayBuffer for nodes & edges, \n // in which case we don't need the whole graph.\n // @see https://github.com/graphology/graphology/blob/master/src/layout-noverlap/webworker.tpl.js#L32\n const graph = new Graph({\n nodes: nodes,\n edges: edges,\n });\n\n /**\n * Create layout instance on the worker side.\n */\n let layout: SyncLayout<any>;\n let positions: LayoutMapping;\n const layoutCtor = registry[id];\n if (layoutCtor) {\n layout = new layoutCtor(options);\n } else {\n throw new Error('Unknown layout id: ' + id);\n }\n\n // Do calculation.\n positions = layout.execute(graph);\n \n return [positions, transferables];\n}\n"],"names":["__webpack_require__","exports","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","Graph","nodeMap","Map","edgeMap","inEdgesMap","outEdgesMap","treeIndices","changes","batchCount","onChanged","constructor","options","nodes","this","addNodes","edges","addEdges","tree","addTree","batch","fn","commit","graph","reduceChanges","mergedChanges","forEach","change","type","isNewlyAdded","filter","pastChange","sameId","value","id","nodeId","push","existingChange","find","propertyName","newValue","treeKey","newParentId","checkNodeExistence","hasNode","Error","has","areNeighbors","firstNodeId","secondNodeId","getNeighbors","some","neighbor","getNode","getRelatedEdges","direction","inEdges","outEdges","Array","from","bothEdges","Set","getDegree","length","getSuccessors","targets","map","edge","target","getPredecessors","sources","source","predecessors","successors","doAddNode","node","set","childrenMap","addNode","doRemoveNode","doRemoveEdge","delete","child","parentMap","removeNodes","idList","removeNode","updateNodeData","oldValue","data","mergeNodeData","patch","entries","checkEdgeExistence","hasEdge","getEdge","getEdgeDetail","doAddEdge","add","addEdge","removeEdges","removeEdge","updateEdgeSource","oldSource","newSource","updateEdgeTarget","oldTarget","newTarget","updateEdgeData","mergeEdgeData","checkTreeExistence","attachTreeStructure","detachTreeStructure","stack","isArray","shift","children","parent","setParent","getRoots","getAllNodes","getParent","getChildren","oldParent","newParent","oldParentId","values","getAllEdges","doBFS","queue","visited","n","bfs","doDFS","dfs","clone","newNodes","oldNode","newEdges","oldEdge","newGraph","oldParentMap","oldChildrenMap","toJSON","JSON","stringify","__assign","assign","t","s","i","arguments","p","apply","__read","m","Symbol","iterator","r","e","ar","next","done","error","create","camelizeRE","str","replace","_","c","toUpperCase","isObject","val","Date","getTime","v","keys","k","getEdgeTerminal","terminal","cell","getFuncByUnknownType","defaultValue","resultIsNumber","max","Math","to","pack","l","slice","concat","isNaN","width","height","d","size","DEFAULTS_LAYOUT_OPTIONS","radius","startRadius","endRadius","startAngle","endAngle","PI","clockwise","divisions","ordering","angleRatio","compareDegree","a","b","aDegree","degree","bDegree","topologyOrdering","degrees","directed","cnodes","orderedCNodes","resNodes","pickFlags","sourceIdx","targetIdx","sourceChildren","targetChildren","initHierarchy","cnode","all","connect","foundChild","j","childIdx","ii","registry","circular","execute","genericCircularLayout","mergedOptions","center","paramNodeSpacing","paramNodeSize","onLayoutEnd","calculatedWidth","calculatedHeight","calculatedCenter","window","innerWidth","innerHeight","calculateCenter","x","y","angleStep","nodeIdxMap","in","out","nSize","astep","layoutNodes","nodesData","orderedNodes","sort","degreeOrdering","divN","ceil","angle","floor","cos","sin","weight","calculateLayout","payload","transferables","layoutCtor"],"sourceRoot":""}