/**
 * @license GoJS
 * GoJS v3.1.0 JavaScript Library for Interactive Diagrams, https://gojs.net
 * GoJS and Northwoods Software are registered trademarks of Northwoods Software Corporation, https://nwoods.com.
 * Copyright 1998-2025 by Northwoods Software Corporation.  All Rights Reserved.
 * THIS SOFTWARE IS LICENSED.  THE LICENSE AGREEMENT IS AT: https://gojs.net/3.1.0/license.html.
 * DO NOT MODIFY THIS FILE.  DO NOT DISTRIBUTE A MODIFIED COPY OF THE CONTENTS OF THIS FILE.
 */
(function() {const root=typeof globalThis=="object"&&globalThis||typeof global=="object"&&global.global===global&&global||typeof self=="object"&&self.self===self&&self||{};root.requestAnimationFrame===void 0&&(root.setImmediate===void 0?root.requestAnimationFrame=w=>root.setTimeout(w,0):root.requestAnimationFrame=root.setImmediate);class U{static ur=root.navigator!==void 0&&root.navigator.platform!==void 0&&root.navigator.platform.match(/(iPhone|iPod|iPad|Mac)/i)!==null;static NP(t,e,i){let s=-1;return function(){const n=this,o=arguments;s!==-1&&U.yc(s),s=U.dn(()=>{s=-1,i||t.apply(n,o)},e),i&&!s&&t.apply(n,o)}}static dn(t,e){return root.setTimeout(t,e)}static yc(t){root.clearTimeout(t)}static Ni(t){return root.document.createElement(t)}static o(t){throw new Error(t)}static L(t,e){let i="The object is frozen, so its properties cannot be set: "+t.toString();e!==void 0&&(i+="  to value: "+e),U.o(i)}static se(t,e,i,s){}static s(t,e,i,s){}static CU(t,e,i){}static wc(t,e,i){if(t===null||typeof t!="object"){let s=U.LL(e);i!==void 0&&(s+="."+i),U.si(t,"object",s)}}static S(t,e,i){U.s(t,"function",e,i)}static LU(t,e,i){}static si(t,e,i,s){}static J(t,e,i,s){let n=U.LL(i);s!==void 0&&(n+="."+s),U.o(n+" is not in the range "+e+": "+t)}static Gi(t){}static dr(t,e){}static ne(t){root.console&&root.console.log(t)}static $(t){return t!==null&&typeof t=="object"}static nt(t){return typeof t=="function"}static CP=[];static ot(){const t=U.CP.pop();return t===void 0?[]:t}static Z(t){t.length=0,U.CP.push(t)}static AU=Object.freeze([]);static LL(t){return t===null?"*":typeof t=="string"?t:U.nt(t)?t.name:""}static Hn(t){return U.nt(t)?t.className?t.className:t.name:U.$(t)&&t.constructor?U.Hn(t.constructor):typeof t}static Wa(t,e){return e==null||e===""?null:U.$(t)&&e in t||t[e]?t[e]:null}static toString(t){let e=t;return U.$(t)&&(t.text?e=t.text:t.name?e=t.name:t.key!==void 0?e=t.key:t.id!==void 0?e=t.id:t.constructor===Object&&(t.Text?e=t.Text:t.Name?e=t.Name:t.Key!==void 0?e=t.Key:t.Id!==void 0?e=t.Id:t.ID!==void 0&&(e=t.ID))),e===void 0?"undefined":e===null?"null":e.toString()}static Hw(t,e){if(t.hasOwnProperty(e))return!0;let i=Object.getPrototypeOf(t);for(;i&&i!==Function;){if(i.hasOwnProperty(e))return!0;const s=i.TU;if(s&&s[e])return!0;i=Object.getPrototypeOf(i)}return!1}static zF(t){const e=[];let i=0;for(i=0;i<256;i++)e[i]=i;let s=0,n=0;for(i=0;i<256;i++)s=(s+e[i]+119)%256,n=e[i],e[i]=e[s],e[s]=n;i=0,s=0;let o="";for(let r=0;r<t.length;r++)i=(i+1)%256,s=(s+e[i])%256,n=e[i],e[i]=e[s],e[s]=n,o+=String.fromCharCode(t.charCodeAt(r)^e[(e[i]+e[s])%256]);return o}static XF(t){const e="0123456789abcdef",i=[];for(let r=0;r<256;r++)i[e.charAt(r>>4)+e.charAt(r&15)]=String.fromCharCode(r);t.length%2&&(t="0"+t);const s=[];let n=0;for(let r=0;r<t.length;r+=2)s[n++]=i[t.substring(r,r+2)];const o=s.join("");return o===""?"0":o}static We(t){return U.zF(U.XF(t))}static color1="@COLOR1";static color2="@COLOR2";static jw="32ab5ff3b26f42dc0ed90f21412913b5"}U.vfo="29e647fdb3";class StringBuilder{LP;constructor(){this.LP=[]}toString(){return this.LP.join("")}add(t){t!==""&&this.LP.push(t)}}class PropertyCollection{}class EmptyIterator{g;constructor(){this.g=[]}[Symbol.iterator](){return this.g.values()}key;value;get iterator(){return this}reset(){}next(){return!1}hasNext(){return!1}first(){return null}any(){return!1}all(){return!0}each(){return this}map(t){return this}filter(){return this}get count(){return 0}Ml(){}toString(){return"EmptyIterator"}static instance=new EmptyIterator}class SingletonIterator{constructor(t){this.key=-1,this.value=t}[Symbol.iterator](){return[this.value].values()}key;value;get iterator(){return this}reset(){this.key=-1}next(){return this.key===-1?(this.key=0,!0):!1}hasNext(){return this.next()}first(){return this.key=0,this.value}any(t){return this.key=-1,t(this.value)}all(t){return this.key=-1,t(this.value)}each(t){return this.key=-1,t(this.value),this}map(t){return new SingletonIterator(t(this.value))}filter(t){return t(this.value)?new SingletonIterator(this.value):EmptyIterator.instance}get count(){return 1}Ml(){this.value=null}toString(){return"SingletonIterator("+this.value+")"}}class ListIterator{jt;Xs;Gt;Tt;constructor(t){this.jt=t,this.Xs=null,t.gr=null,this.Gt=t.lt,this.Tt=-1}[Symbol.iterator](){return this.Xs===null?this.jt.r.values():this.jt.r.filter(this.Xs).values()}key;value;get iterator(){return this}get predicate(){return this.Xs}set predicate(t){this.Xs=t}reset(){const t=this.jt;t.gr=null,this.Gt=t.lt,this.Tt=-1}next(){const t=this.jt;if(t.lt!==this.Gt){if(this.key<0)return!1;U.Gi(t)}const e=t.r,i=e.length;let s=++this.Tt;const n=this.Xs;if(n!==null)for(;s<i;){const o=e[s];if(n(o))return this.Tt=s,this.key=s,this.value=o,!0;s++}else{if(s<i)return this.key=s,this.value=e[s],!0;this.Ml()}return!1}hasNext(){return this.next()}first(){const t=this.jt;this.Gt=t.lt,this.Tt=0;const e=t.r,i=e.length,s=this.Xs;if(s!==null){let n=0;for(;n<i;){const o=e[n];if(s(o))return this.Tt=n,this.key=n,this.value=o,o;n++}return null}else if(i>0){const n=e[0];return this.key=0,this.value=n,n}else return null}any(t){const e=this.jt;e.gr=null;const i=e.lt;this.Tt=-1;const s=e.r,n=s.length,o=this.Xs;for(let r=0;r<n;r++){const l=s[r];if(!(o!==null&&!o(l))){if(t(l))return!0;e.lt!==i&&U.Gi(e)}}return!1}all(t){const e=this.jt;e.gr=null;const i=e.lt;this.Tt=-1;const s=e.r,n=s.length,o=this.Xs;for(let r=0;r<n;r++){const l=s[r];if(!(o!==null&&!o(l))){if(!t(l))return!1;e.lt!==i&&U.Gi(e)}}return!0}each(t){const e=this.jt;e.gr=null;const i=e.lt;this.Tt=-1;const s=e.r,n=s.length,o=this.Xs;for(let r=0;r<n;r++){const l=s[r];o!==null&&!o(l)||(t(l),e.lt!==i&&U.Gi(e))}return this}map(t){const e=this.jt;e.gr=null;const i=e.lt;this.Tt=-1;const s=[],n=e.r,o=n.length,r=this.Xs;for(let a=0;a<o;a++){const h=n[a];r!==null&&!r(h)||(s.push(t(h)),e.lt!==i&&U.Gi(e))}const l=new List;return l.r=s,l.Yi(),l.iterator}filter(t){const e=this.jt;e.gr=null;const i=e.lt;this.Tt=-1;const s=[],n=e.r,o=n.length,r=this.Xs;for(let a=0;a<o;a++){const h=n[a];r!==null&&!r(h)||(t(h)&&s.push(h),e.lt!==i&&U.Gi(e))}const l=new List;return l.r=s,l.Yi(),l.iterator}get count(){const t=this.Xs;if(t!==null){let e=0;const i=this.jt.r,s=i.length;for(let n=0;n<s;n++)t(i[n])&&e++;return e}else return this.jt.r.length}Ml(){this.key=-1,this.value=null,this.Gt=-1,this.Xs=null,this.jt.gr=this}toString(){return"ListIterator@"+this.Tt+"/"+this.jt.count}}class ListIteratorBackwards{jt;Gt;Tt;constructor(t){this.jt=t,t.pr=null,this.Gt=t.lt,this.Tt=t.r.length}[Symbol.iterator](){return this.jt.r.reverse().values()}key;value;get iterator(){return this}reset(){const t=this.jt;t.pr=null,this.Gt=t.lt,this.Tt=t.r.length}next(){const t=this.jt;if(t.lt!==this.Gt){if(this.key<0)return!1;U.Gi(t)}const e=--this.Tt;return e>=0?(this.key=e,this.value=t.r[e],!0):(this.Ml(),!1)}hasNext(){return this.next()}first(){const t=this.jt;this.Gt=t.lt;const e=t.r,i=e.length-1;if(this.Tt=i,i>=0){const s=e[i];return this.key=i,this.value=s,s}else return null}any(t){const e=this.jt;e.pr=null;const i=e.lt,s=e.r,n=s.length;this.Tt=n;for(let o=n-1;o>=0;o--){const r=s[o];if(t(r))return!0;e.lt!==i&&U.Gi(e)}return!1}all(t){const e=this.jt;e.pr=null;const i=e.lt,s=e.r,n=s.length;this.Tt=n;for(let o=n-1;o>=0;o--){const r=s[o];if(!t(r))return!1;e.lt!==i&&U.Gi(e)}return!0}each(t){const e=this.jt;e.pr=null;const i=e.lt,s=e.r,n=s.length;this.Tt=n;for(let o=n-1;o>=0;o--){const r=s[o];t(r),e.lt!==i&&U.Gi(e)}return this}map(t){const e=this.jt;e.pr=null;const i=e.lt,s=[],n=e.r,o=n.length;this.Tt=o;for(let l=o-1;l>=0;l--){const a=n[l];s.push(t(a)),e.lt!==i&&U.Gi(e)}const r=new List;return r.r=s,r.Yi(),r.iterator}filter(t){const e=this.jt;e.pr=null;const i=e.lt,s=[],n=e.r,o=n.length;this.Tt=o;for(let l=o-1;l>=0;l--){const a=n[l];t(a)&&s.push(a),e.lt!==i&&U.Gi(e)}const r=new List;return r.r=s,r.Yi(),r.iterator}get count(){return this.jt.r.length}Ml(){this.key=-1,this.value=null,this.Gt=-1,this.jt.pr=this}toString(){return"ListIteratorBackwards("+this.Tt+"/"+this.jt.count+")"}}class List{f;r;lt;gr;pr;constructor(t){GSet.Je(this),this.f=!1,this.r=[],this.lt=0,this.gr=null,this.pr=null,t!==void 0&&this.addAll(t)}[Symbol.iterator](){return this.r.values()}Yi(){let t=this.lt;t++,t>999999999&&(t=0),this.lt=t}b(){return this.f=!0,this}ce(){return this.f=!1,this}toString(){return"List()#"+GSet.xs(this)}add(t){return this.f&&U.L(this,t),this.r.push(t),this.Yi(),this}push(t){this.add(t)}addAll(t){if(t===null)return this;this.f&&U.L(this);const e=this.r;if(t.first){const i=t.iterator;for(;i.next();)e.push(i.value)}else for(const i of t)e.push(i);return this.Yi(),this}clear(){this.f&&U.L(this),this.r.length=0,this.Yi()}contains(t){return this.has(t)}has(t){return t===null?!1:this.r.indexOf(t)!==-1}indexOf(t){return t===null?-1:this.r.indexOf(t)}elt(t){const e=this.r;return(t<0||t>=e.length)&&U.J(t,"0 <= i < length",List,"elt:i"),e[t]}get(t){return this.elt(t)}setElt(t,e){const i=this.r;(t<0||t>=i.length)&&U.J(t,"0 <= i < length",List,"setElt:i"),this.f&&U.L(this,t),i[t]=e}set(t,e){this.setElt(t,e)}first(){const t=this.r;return t.length===0?null:t[0]}last(){const t=this.r,e=t.length;return e>0?t[e-1]:null}pop(){this.f&&U.L(this);const t=this.r;if(t.length>0){const e=t.pop();return e===void 0?null:e}return null}any(t){const e=this.r,i=this.lt,s=e.length;for(let n=0;n<s;n++){if(t(e[n]))return!0;this.lt!==i&&U.Gi(this)}return!1}all(t){const e=this.r,i=this.lt,s=e.length;for(let n=0;n<s;n++){if(!t(e[n]))return!1;this.lt!==i&&U.Gi(this)}return!0}each(t){const e=this.r,i=this.lt,s=e.length;for(let n=0;n<s;n++)t(e[n]),this.lt!==i&&U.Gi(this);return this}map(t){const e=new List,i=[],s=this.r,n=this.lt,o=s.length;for(let r=0;r<o;r++)i.push(t(s[r])),this.lt!==n&&U.Gi(this);return e.r=i,e.Yi(),e}filter(t){const e=new List,i=[],s=this.r,n=this.lt,o=s.length;for(let r=0;r<o;r++){const l=s[r];t(l)&&i.push(l),this.lt!==n&&U.Gi(this)}return e.r=i,e.Yi(),e}insertAt(t,e){t<0&&U.J(t,">= 0",List,"insertAt:i"),this.f&&U.L(this,t);const i=this.r;t>=i.length?i.push(e):i.splice(t,0,e),this.Yi()}remove(t){return this.delete(t)}delete(t){if(t===null)return!1;this.f&&U.L(this,t);const e=this.r,i=e.indexOf(t);return i===-1?!1:(i===e.length-1?e.pop():e.splice(i,1),this.Yi(),!0)}removeAt(t){const e=this.r;(t<0||t>=e.length)&&U.J(t,"0 <= i < length",List,"removeAt:i"),this.f&&U.L(this,t),t===e.length-1?e.pop():e.splice(t,1),this.Yi()}removeRange(t,e){const i=this.r,s=i.length;if(t<0)t=0;else if(t>=s)return this;if(e<0)return this;if(e>=s&&(e=s-1),t>e)return this;this.f&&U.L(this);let n=t,o=e+1;for(;o<s;)i[n++]=i[o++];return i.length=s-(e-t+1),this.Yi(),this}copy(){const t=new List,e=this.r;return e.length>0&&(t.r=Array.prototype.slice.call(e)),t}toArray(){const t=this.r,e=this.count,i=new Array(e);for(let s=0;s<e;s++)i[s]=t[s];return i}get AL(){return this.r}toSet(){const t=new GSet,e=this.r,i=this.count;for(let s=0;s<i;s++)t.add(e[s]);return t}sort(t){return this.f&&U.L(this),this.r.sort(t),this.Yi(),this}sortRange(t,e,i){const s=this.r,n=s.length;e===void 0&&(e=0),i===void 0&&(i=n),this.f&&U.L(this);const o=i-e;if(o<=1)return this;if((e<0||e>=n-1)&&U.J(e,"0 <= from < length",List,"sortRange:from"),o===2){const r=s[e],l=s[e+1];return t(r,l)>0&&(s[e]=l,s[e+1]=r,this.Yi()),this}if(e===0)if(i>=n)s.sort(t);else{const r=s.slice(0,i);r.sort(t);for(let l=0;l<i;l++)s[l]=r[l]}else if(i>=n){const r=s.slice(e);r.sort(t);for(let l=e;l<n;l++)s[l]=r[l-e]}else{const r=s.slice(e,i);r.sort(t);for(let l=e;l<i;l++)s[l]=r[l-e]}return this.Yi(),this}reverse(){return this.f&&U.L(this),this.r.reverse(),this.Yi(),this}get count(){return this.r.length}get size(){return this.r.length}get length(){return this.r.length}get iterator(){if(this.r.length<=0)return EmptyIterator.instance;const t=this.gr;return t!==null?(t.reset(),t):new ListIterator(this)}get iteratorBackwards(){if(this.r.length<=0)return EmptyIterator.instance;const t=this.pr;return t!==null?(t.reset(),t):new ListIteratorBackwards(this)}}class SetIterator{Do;oe;constructor(t){this.Do=t,this.oe=t.g.values()}[Symbol.iterator](){return this.Do.g.values()}key;value;get iterator(){return this}reset(){const t=this.Do;this.oe=t.g.values()}next(){const t=this.oe.next();return this.value=t.value,this.key=t.value,!t.done}hasNext(){return this.next()}first(){return this.Do.g.size===0?null:(this.oe=this.Do.g.values(),this.oe.next().value)}any(t){return this.Do.any(t)}all(t){return this.Do.all(t)}each(t){return this.Do.each(t),this}map(t){const e=new List;return this.Do.g.forEach(i=>e.add(t(i))),e.iterator}filter(t){const e=new List;return this.Do.g.forEach(i=>{t(i)&&e.add(i)}),e.iterator}get count(){return this.Do.count}Ml(){this.key=null,this.value=null,this.oe=null}toString(){return"SetIterator"}}class GSet{f;g;constructor(t){this.f=!1,this.g=new Set,t!==void 0&&this.addAll(t)}[Symbol.iterator](){return this.g.values()}values(){return this.g.values()}b(){return this.f=!0,this}ce(){return this.f=!1,this}toString(){return"Set()#"+GSet.xs(this)}add(t){return t===null?this:(this.g.add(t),this)}addAll(t){if(t===null)return this;if(this.f&&U.L(this),t.first){const e=t.iterator;for(;e.next();)this.g.add(e.value)}else for(const e of t)this.g.add(e);return this}has(t){return this.g.has(t)}contains(t){return this.has(t)}containsAll(t){if(t===null)return!0;if(t.first){const e=t.iterator;for(;e.next();)if(!this.has(e.value))return!1}else for(const e of t)if(!this.has(e))return!1;return!0}containsAny(t){if(t===null)return!0;if(t.first){const e=t.iterator;for(;e.next();)if(this.has(e.value))return!0}else for(const e of t)if(this.has(e))return!0;return!1}first(){return this.g.size===0?null:this.g.values().next().value}any(t){for(const e of this.g)if(t(e))return!0;return!1}all(t){for(const e of this.g)if(!t(e))return!1;return!0}each(t){for(const e of this.g)t(e);return this}map(t){const e=new GSet;for(const i of this.g)e.add(t(i));return e}filter(t){const e=new GSet;for(const i of this.g)t(i)&&e.add(i);return e}delete(t){return this.f&&U.L(this),this.g.delete(t)}remove(t){return this.delete(t)}removeAll(t){if(t===null)return this;if(this.f&&U.L(this),t.first){const e=t.iterator;for(;e.next();)this.delete(e.value)}else for(const e of t)this.delete(e);return this}retainAll(t){if(t===null)return this;if(this.count===0)return this;this.f&&U.L(this);const e=new GSet;e.addAll(t);const i=[];if(t.first){const s=t.iterator;for(;s.next();){const n=s.value;e.has(n)||i.push(n)}}else for(const s of t)e.has(s)||i.push(s);return this.removeAll(i),this}clear(){this.f&&U.L(this),this.g.clear()}copy(){const t=new GSet;return this.g.forEach(e=>t.add(e)),t}toArray(){return Array.from(this.g)}toList(){const t=new List;return this.g.forEach(e=>t.add(e)),t}get count(){return this.g.size}get size(){return this.g.size}get iterator(){return this.g.size<=0?EmptyIterator.instance:new SetIterator(this)}entries(){return this.g.entries()}keys(){return this.g.keys()}forEach(t,e){return this.g.forEach(t,e)}static qw=1;static Je(t){t.__gohashid=GSet.qw++}static xs(t){return t.__gohashid}}class MapKeySetIterator{q;oe;constructor(t){this.q=t,this.oe=t.g.keys()}[Symbol.iterator](){return this.q.g.keys()}key;value;get iterator(){return this}reset(){const t=this.q;this.oe=t.g.keys()}next(){const t=this.oe.next();return this.value=t.value,this.key=t.value,!t.done}hasNext(){return this.next()}first(){return this.q.g.size===0?null:(this.oe=this.q.g.keys(),this.oe.next().value)}any(t){for(const e of this.q.g)if(t(e[0]))return!0;return!1}all(t){for(const e of this.q.g)if(!t(e[0]))return!1;return!0}each(t){for(const e of this.q.g)t(e[0]);return this}map(t){const e=this.q,i=new List;for(const s of e.g)i.add(t(s[0]));return i.iterator}filter(t){const e=this.q,i=new List;for(const s of e.g){const n=s[0];t(n)&&i.add(n)}return i.iterator}get count(){return this.q.size}Ml(){this.key=null,this.value=null,this.oe=null}toString(){return"MapKeySetIterator"}}class MapKeySet extends GSet{q;constructor(t){super(),GSet.Je(this),this.f=!0,this.q=t}[Symbol.iterator](){return this.g.keys()}values(){return this.g.keys()}b(){return this}ce(){return this}toString(){return"MapKeySet("+this.q.toString()+")"}add(t){U.o("This Set is read-only: "+this.toString())}has(t){return this.q.has(t)}contains(t){return this.has(t)}delete(t){U.o("This Set is read-only: "+this.toString())}remove(t){return this.delete(t)}clear(){U.o("This Set is read-only: "+this.toString())}first(){return this.q.g.size===0?null:this.q.g.keys().next().value}any(t){for(const e of this.q.g)if(t(e[0]))return!0;return!1}all(t){for(const e of this.q.g)if(!t(e[0]))return!1;return!0}each(t){for(const e of this.q.g)t(e[0]);return this}map(t){const e=new GSet;for(const i of this.q.g)e.add(t(i[0]));return e}filter(t){const e=new GSet;for(const i of this.q.g){const s=i[0];t(s)&&e.add(s)}return e}copy(){return new MapKeySet(this.q)}toSet(){const t=new GSet,e=this.q.g;for(const i of e)t.add(i[0]);return t}toArray(){const t=this.q.g,e=new Array(t.size);let i=0;for(const s of t)e[i]=s[0],i++;return e}toList(){const t=new List,e=this.q.g;for(const i of e)t.add(i[0]);return t}get count(){return this.q.size}get size(){return this.q.size}get iterator(){return this.q.size<=0?EmptyIterator.instance:new MapKeySetIterator(this.q)}}class MapValueSetIterator{q;oe;constructor(t){this.q=t,this.oe=t.g.values()}[Symbol.iterator](){return this.q.g.values()}key;value;get iterator(){return this}reset(){const t=this.q;this.oe=t.g.values()}next(){const t=this.oe.next();return this.value=t.value,this.key=t.value,!t.done}hasNext(){return this.next()}first(){return this.q.g.size===0?null:(this.oe=this.q.g.values(),this.oe.next().value)}any(t){for(const e of this.q.g)if(t(e[1]))return!0;return!1}all(t){for(const e of this.q.g)if(!t(e[1]))return!1;return!0}each(t){for(const e of this.q.g)t(e[1]);return this}map(t){const e=this.q,i=new List;for(const s of e.g)i.add(t(s[1]));return i.iterator}filter(t){const e=this.q,i=new List;for(const s of e.g){const n=s[1];t(n)&&i.add(n)}return i.iterator}get count(){return this.q.size}Ml(){this.key=null,this.value=null,this.oe=null}toString(){return"MapValueSetIterator"}}class KeyValuePair{constructor(t,e){this.key=t,this.value=e}toString(){return"{"+this.key+":"+this.value+"}"}key;value}class MapIterator{q;oe;constructor(t){this.q=t,this.oe=t.g.entries()}[Symbol.iterator](){return this.q.g.entries()}key;value;get iterator(){return this}reset(){const t=this.q;this.oe=t.g.entries()}next(){const t=this.oe.next();return t.done?(this.key=null,this.value=null,!1):(this.key=t.value[0],this.value=t.value[1],!0)}hasNext(){return this.next()}first(){if(this.q.g.size===0)return null;this.oe=this.q.g.entries();const t=this.oe.next().value;return this.key=t[0],this.value=t[1],new KeyValuePair(t[0],t[1])}any(t){return this.q.any(t)}all(t){return this.q.all(t)}each(t){return this.q.each(t),this}map(t){const e=new List;let i=null;return this.q.g.forEach((s,n)=>{i===null?i=new KeyValuePair(n,s):(i.key=n,i.value=s),e.add(t(i))}),e.iterator}filter(t){const e=new List;let i=null;return this.q.g.forEach((s,n)=>{i===null?i=new KeyValuePair(n,s):(i.key=n,i.value=s),t(i)&&(e.add(i),i=null)}),e.iterator}get count(){return this.q.size}Ml(){this.key=null,this.value=null,this.oe=null}toString(){return"MapIterator"}}class GMap{f;g;constructor(t){GSet.Je(this),this.f=!1,this.g=new Map,t!==void 0&&this.addAll(t)}[Symbol.iterator](){return this.g.entries()}entries(){return this.g.entries()}b(){return this.f=!0,this}ce(){return this.f=!1,this}toString(){return"Map()#"+GSet.xs(this)}set(t,e){return this.f&&U.L(this,t),this.g.set(t,e),this}add(t,e){return this.set(t,e)}addAll(t){if(t===null)return this;if(this.f&&U.L(this),t instanceof GMap){const e=t.iterator;for(;e.next();)this.g.set(e.key,e.value)}else if(t.first){const e=t.iterator;for(;e.next();){const i=e.value;this.g.set(i.key,i.value)}}else for(const e of t){const i=e;Array.isArray(i)?this.g.set(i[0],i[1]):this.g.set(i.key,i.value)}return this}first(){if(this.g.size===0)return null;const t=this.g.entries().next().value;return t?new KeyValuePair(t[0],t[1]):null}any(t){let e=null;for(const[i,s]of this.g)if(e===null?e=new KeyValuePair(i,s):(e.key=i,e.value=s),t(e))return!0;return!1}all(t){let e=null;for(const[i,s]of this.g)if(e===null?e=new KeyValuePair(i,s):(e.key=i,e.value=s),!t(e))return!1;return!0}each(t){let e=null;for(const[i,s]of this.g)e===null?e=new KeyValuePair(i,s):(e.key=i,e.value=s),t(e);return this}map(t){const e=new GMap;let i=null;for(const[s,n]of this.g)i===null?i=new KeyValuePair(s,n):(i.key=s,i.value=n),e.set(s,t(i));return e}filter(t){const e=new GMap;let i=null;for(const[s,n]of this.g)i===null?i=new KeyValuePair(s,n):(i.key=s,i.value=n),t(i)&&e.set(s,n);return e}has(t){return this.g.has(t)}contains(t){return this.has(t)}get(t){const e=this.g.get(t);return e===void 0?null:e}getValue(t){return this.get(t)}delete(t){return t===null?!1:(this.f&&U.L(this,t),this.g.delete(t))}remove(t){return this.delete(t)}clear(){this.f&&U.L(this),this.g.clear()}copy(){const t=new GMap;return t.g=new Map(this.g),t}toArray(){const t=this.g,e=new Array(t.size);let i=0;for(const s of t)e[i]=new KeyValuePair(s[0],s[1]),i++;return e}toKeySet(){return new MapKeySet(this)}get count(){return this.g.size}get size(){return this.g.size}get iterator(){return this.g.size<=0?EmptyIterator.instance:new MapIterator(this)}get iteratorKeys(){return this.count<=0?EmptyIterator.instance:new MapKeySetIterator(this)}keys(){return this.g.keys()}get iteratorValues(){return this.count<=0?EmptyIterator.instance:new MapValueSetIterator(this)}values(){return this.g.values()}forEach(t,e){return this.g.forEach(t,e)}}class Point{px;py;f;constructor(t,e){t===void 0?(this.px=0,this.py=0):typeof t=="number"&&typeof e=="number"?(this.px=t,this.py=e):U.o("Invalid arguments to Point constructor: "+t+", "+e),this.f=!1}h(t){return this.px=t.px,this.py=t.py,this}e(t,e){return this.px=t,this.py=e,this}setTo(t,e){return this.px=t,this.py=e,this}set(t){return this.px=t.px,this.py=t.py,this}copy(){const t=new Point;return t.px=this.px,t.py=this.py,t}kt(){return this.f=!0,Object.freeze(this),this}N(){return this.f||Object.isFrozen(this)?this:this.copy().b()}b(){return this.f||(this.f=!0),this}Ww(t){}static parse(t){if(typeof t=="string"){const e=t.split(" ");let i=0,s=0;for(;e[i]==="";)i++;let n=e[i++];n&&(s=parseFloat(n));let o=0;for(;e[i]==="";)i++;return n=e[i++],n&&(o=parseFloat(n)),new Point(s,o)}else return new Point}static stringify(t){return t.x.toString()+" "+t.y.toString()}static stringifyFixed(t){return U.s(t,"number",Point,"stringifyFixed:digits"),e=>e.x.toFixed(t)+" "+e.y.toFixed(t)}toString(){return"Point("+this.x+","+this.y+")"}equals(t){return t instanceof Point?this.px===t.x&&this.py===t.y:!1}equalTo(t,e){return this.px===t&&this.py===e}equalsApprox(t){return G.u(this.px,t.x)&&G.u(this.py,t.y)}add(t){return this.px+=t.x,this.py+=t.y,this}subtract(t){return this.px-=t.x,this.py-=t.y,this}offset(t,e){return this.px+=t,this.py+=e,this}rotate(t){if(t===0)return this;const e=this.px,i=this.py;if(e===0&&i===0)return this;let s=0,n=0;if(t=G.Ee(t),t===90)s=0,n=1;else if(t===180)s=-1,n=0;else if(t===270)s=0,n=-1;else{const o=t*Math.PI/180;s=Math.cos(o),n=Math.sin(o)}return this.px=s*e-n*i,this.py=n*e+s*i,this}scale(t,e){return this.px*=t,this.py*=e,this}distanceSquaredPoint(t){const e=t.x-this.px,i=t.y-this.py;return e*e+i*i}distanceSquared(t,e){const i=t-this.px,s=e-this.py;return i*i+s*s}normalize(){const t=this.px,e=this.py,i=Math.sqrt(t*t+e*e);return i>0&&(this.px=t/i,this.py=e/i),this}directionPoint(t){return this.TL(t.x-this.px,t.y-this.py)}direction(t,e){return this.TL(t-this.px,e-this.py)}TL(t,e){if(t===0)return e>0?90:e<0?270:0;if(e===0)return t>0?0:180;{if(isNaN(t)||isNaN(e))return 0;let i=Math.atan(Math.abs(e/t))*180/Math.PI;return t<0?e<0?i+=180:i=180-i:e<0&&(i=360-i),i}}static compareWithLineSegment(t,e,i,s,n,o){return G.ku(t,e,i,s,n,o)}compareWithLineSegmentPoint(t,e){return G.ku(t.x,t.y,e.x,e.y,this.x,this.y)}static intersectingLineSegments(t,e,i,s,n,o,r,l){return G.Pu(t,e,i,s,n,o,r,l)}projectOntoLineSegment(t,e,i,s){return G.Nl(t,e,i,s,this.px,this.py,this),this}projectOntoLineSegmentPoint(t,e){return G.Nl(t.x,t.y,e.x,e.y,this.px,this.py,this),this}snapToGrid(t,e,i,s){return G._g(this.px,this.py,t,e,i,s,this),this}snapToGridPoint(t,e){return G._g(this.px,this.py,t.x,t.y,e.width,e.height,this),this}setRectSpot(t,e){return this.px=t.x+e.x*t.width+e.offsetX,this.py=t.y+e.y*t.height+e.offsetY,this}setSpot(t,e,i,s,n){return this.px=t+n.x*i+n.offsetX,this.py=e+n.y*s+n.offsetY,this}v(t){return t.gt(this),this}Ki(t){return t.Ci(this),this}static distanceLineSegmentSquared(t,e,i,s,n,o){let r=n-i,l=o-s;const a=r*r+l*l,h=i-t,c=s-e,f=-h*r-c*l;if(f<=0||f>=a)return r=n-t,l=o-e,Math.min(h*h+c*c,r*r+l*l);{const u=r*c-l*h;return u*u/a}}static distanceSquared(t,e,i,s){const n=i-t,o=s-e;return n*n+o*o}static direction(t,e,i,s){const n=i-t,o=s-e;if(n===0)return o>0?90:o<0?270:0;if(o===0)return n>0?0:180;{if(isNaN(n)||isNaN(o))return 0;let r=Math.atan(Math.abs(o/n))*180/Math.PI;return n<0?o<0?r+=180:r=180-r:o<0&&(r=360-r),r}}get x(){return this.px}set x(t){this.px=t}get y(){return this.py}set y(t){this.py=t}isReal(){return isFinite(this.x)&&isFinite(this.y)}static gn=new Point(0,0).kt();static DL=new Point(-1/0,-1/0).kt();static vL=new Point(1/0,1/0).kt();static FL=new Point(6,6).kt();static mn=new Point(NaN,NaN).kt();static Jw=[];static l(){const t=Point.Jw.pop();return t===void 0?new Point:t}static bs(t){const e=Point.Jw.pop();return e===void 0?t.copy():e.h(t)}static z(t,e){const i=Point.Jw.pop();return i===void 0?new Point(t,e):(i.x=t,i.y=e,i)}static i(t){Point.Jw.push(t)}}class Size{sw;sh;f;constructor(t,e){t===void 0?(this.sw=0,this.sh=0):typeof t=="number"&&(t>=0||isNaN(t))&&typeof e=="number"&&(e>=0||isNaN(e))?(this.sw=t,this.sh=e):U.o("Invalid arguments to Size constructor: "+t+", "+e),this.f=!1}h(t){return this.sw=t.sw,this.sh=t.sh,this}e(t,e){return this.sw=t,this.sh=e,this}setTo(t,e){return this.sw=t,this.sh=e,this}set(t){return this.sw=t.sw,this.sh=t.sh,this}copy(){const t=new Size;return t.sw=this.sw,t.sh=this.sh,t}kt(){return this.f=!0,Object.freeze(this),this}N(){return this.f||Object.isFrozen(this)?this:this.copy().b()}b(){return this.f||(this.f=!0),this}Ww(t){}static parse(t){if(typeof t=="string"){const e=t.split(" ");let i=0,s=0;for(;e[i]==="";)i++;let n=e[i++];n&&(s=parseFloat(n));let o=0;for(;e[i]==="";)i++;return n=e[i++],n&&(o=parseFloat(n)),new Size(s,o)}else return new Size}static stringify(t){return t.width.toString()+" "+t.height.toString()}static stringifyFixed(t){return U.s(t,"number",Size,"stringifyFixed:digits"),e=>e.width.toFixed(t)+" "+e.height.toFixed(t)}toString(){return"Size("+this.width+","+this.height+")"}equals(t){return t instanceof Size?this.sw===t.width&&this.sh===t.height:!1}equalTo(t,e){return this.sw===t&&this.sh===e}equalsApprox(t){return G.u(this.sw,t.width)&&G.u(this.sh,t.height)}inflate(t,e){const i=this.width+t;this.sw=i>=0?i:0;const s=this.height+e;return this.sh=s>=0?s:0,this}get width(){return this.sw}set width(t){t<0&&U.J(t,">= 0",Size,"width"),this.sw=t}get height(){return this.sh}set height(t){t<0&&U.J(t,">= 0",Size,"height"),this.sh=t}isReal(){return isFinite(this.width)&&isFinite(this.height)}static xc=new Size(0,0).kt();static AP=new Size(1,1).kt();static RL=new Size(6,6).kt();static Su=new Size(8,8).kt();static OL=new Size(10,10).kt();static TP=new Size(1/0,1/0).kt();static $w=new Size(NaN,NaN).kt();static IL=[];static l(){const t=Size.IL.pop();return t===void 0?new Size:t}static i(t){Size.IL.push(t)}}class Rect{rx;ry;rw;rh;f;constructor(t,e,i,s){if(t===void 0)this.rx=0,this.ry=0,this.rw=0,this.rh=0;else if(typeof t=="number"&&typeof e=="number"&&typeof i=="number"&&(i>=0||isNaN(i))&&typeof s=="number"&&(s>=0||isNaN(s)))this.rx=t,this.ry=e,this.rw=i,this.rh=s;else if(t instanceof Point){const n=t.x,o=t.y;if(e instanceof Point){const r=e.x,l=e.y;this.rx=Math.min(n,r),this.ry=Math.min(o,l),this.rw=Math.abs(n-r),this.rh=Math.abs(o-l)}else e instanceof Size?(this.rx=n,this.ry=o,this.rw=e.width,this.rh=e.height):U.o("Incorrect second argument supplied to Rect constructor "+e)}else U.o("Invalid arguments to Rect constructor: "+t+", "+e+", "+i+", "+s);this.f=!1}h(t){return this.rx=t.rx,this.ry=t.ry,this.rw=t.rw,this.rh=t.rh,this}e(t,e,i,s){return this.rx=t,this.ry=e,this.rw=i,this.rh=s,this}jn(t,e){return this.rw=t,this.rh=e,this}setTo(t,e,i,s){return this.rx=t,this.ry=e,this.rw=i,this.rh=s,this}set(t){return this.rx=t.rx,this.ry=t.ry,this.rw=t.rw,this.rh=t.rh,this}setPoint(t){return this.rx=t.x,this.ry=t.y,this}setSize(t){return this.rw=t.width,this.rh=t.height,this}copy(){const t=new Rect;return t.rx=this.rx,t.ry=this.ry,t.rw=this.rw,t.rh=this.rh,t}kt(){return this.f=!0,Object.freeze(this),this}N(){return this.f||Object.isFrozen(this)?this:this.copy().b()}b(){return this.f||(this.f=!0),this}ce(){return this.f&&(Object.isFrozen(this)&&U.o("cannot thaw constant: "+this),this.f=!1),this}Ww(t){}static parse(t){if(typeof t=="string"){const e=t.split(" ");let i=0,s=0;for(;e[i]==="";)i++;let n=e[i++];n&&(s=parseFloat(n));let o=0;for(;e[i]==="";)i++;n=e[i++],n&&(o=parseFloat(n));let r=0;for(;e[i]==="";)i++;n=e[i++],n&&(r=parseFloat(n));let l=0;for(;e[i]==="";)i++;return n=e[i++],n&&(l=parseFloat(n)),new Rect(s,o,r,l)}else return new Rect}static stringify(t){return t.x.toString()+" "+t.y.toString()+" "+t.width.toString()+" "+t.height.toString()}static stringifyFixed(t){return U.s(t,"number",Rect,"stringifyFixed:digits"),e=>e.x.toFixed(t)+" "+e.y.toFixed(t)+" "+e.width.toFixed(t)+" "+e.height.toFixed(t)}toString(){return"Rect("+this.x+","+this.y+","+this.width+","+this.height+")"}equals(t){return t instanceof Rect?this.rx===t.x&&this.ry===t.y&&this.rw===t.width&&this.rh===t.height:!1}equalTo(t,e,i,s){return this.rx===t&&this.ry===e&&this.rw===i&&this.rh===s}equalsApprox(t){return G.u(this.rx,t.x)&&G.u(this.ry,t.y)&&G.u(this.rw,t.width)&&G.u(this.rh,t.height)}equalsApproxTo(t,e,i,s){return G.u(this.rx,t)&&G.u(this.ry,e)&&G.u(this.rw,i)&&G.u(this.rh,s)}equalsApproxClose(t){return G.X(this.rx,t.x)&&G.X(this.ry,t.y)&&G.X(this.rw,t.width)&&G.X(this.rh,t.height)}containsPoint(t){return this.rx<=t.x&&this.rx+this.rw>=t.x&&this.ry<=t.y&&this.ry+this.rh>=t.y}containsRect(t){return this.rx<=t.x&&t.x+t.width<=this.rx+this.rw&&this.ry<=t.y&&t.y+t.height<=this.ry+this.rh}contains(t,e,i,s){return i===void 0&&(i=0),s===void 0&&(s=0),this.rx<=t&&t+i<=this.rx+this.rw&&this.ry<=e&&e+s<=this.ry+this.rh}offset(t,e){return this.rx+=t,this.ry+=e,this}inflate(t,e){return this.Zw(e,t,e,t)}addMargin(t){return this.Zw(t.top,t.right,t.bottom,t.left)}subtractMargin(t){return this.Zw(-t.top,-t.right,-t.bottom,-t.left)}grow(t,e,i,s){return this.Zw(t,e,i,s)}Zw(t,e,i,s){const n=this.rw;e+s<=-n?(this.rx+=n/2,this.rw=0):(this.rx-=s,this.rw+=e+s);const o=this.rh;return t+i<=-o?(this.ry+=o/2,this.rh=0):(this.ry-=t,this.rh+=t+i),this}intersectRect(t){return this.EL(t.x,t.y,t.width,t.height)}intersect(t,e,i,s){return this.EL(t,e,i,s)}EL(t,e,i,s){const n=Math.max(this.rx,t),o=Math.max(this.ry,e),r=Math.min(this.rx+this.rw,t+i),l=Math.min(this.ry+this.rh,e+s);return this.rx=n,this.ry=o,this.rw=Math.max(0,r-n),this.rh=Math.max(0,l-o),this}intersectsRect(t){return this.intersects(t.x,t.y,t.width,t.height)}intersects(t,e,i,s){let n=this.rw;const o=this.rx;if(n!==1/0&&i!==1/0&&(n+=o,i+=t,isNaN(i)||isNaN(n)||o>i||t>n))return!1;let r=this.rh;const l=this.ry;return!(r!==1/0&&s!==1/0&&(r+=l,s+=e,isNaN(s)||isNaN(r)||l>s||e>r))}UL(t,e){let i=this.rw,s=t.width+e+e;const n=this.rx,o=t.x-e;if(i+=n,s+=o,n>s||o>i)return!1;let r=this.rh,l=t.height+e+e;const a=this.ry,h=t.y-e;return r+=a,l+=h,!(a>l||h>r)}unionPoint(t){return this.re(t.x,t.y,0,0)}unionRect(t){return this.re(t.rx,t.ry,t.rw,t.rh)}union(t,e,i,s){return i===void 0&&(i=0),s===void 0&&(s=0),this.re(t,e,i,s)}re(t,e,i,s){const n=Math.min(this.rx,t),o=Math.min(this.ry,e),r=Math.max(this.rx+this.rw,t+i),l=Math.max(this.ry+this.rh,e+s);return this.rx=n,this.ry=o,this.rw=r-n,this.rh=l-o,this}setSpot(t,e,i){return this.rx=t-i.offsetX-i.x*this.rw,this.ry=e-i.offsetY-i.y*this.rh,this}nearestSideDirection(t,e){return G.Qw(this,t,e,!0)}nearestSideDirectionPoint(t){return G.Qw(this,t.x,t.y,!0)}static contains(t,e,i,s,n,o,r,l){return r===void 0&&(r=0),l===void 0&&(l=0),t<=n&&n+r<=t+i&&e<=o&&o+l<=e+s}static intersects(t,e,i,s,n,o,r,l){let a=i,h=r;const c=t,f=n;if(a+=c,h+=f,c>h||f>a)return!1;let u=s,d=l;const m=e,g=o;return u+=m,d+=g,!(m>d||g>u)}static intersectsLineSegment(t,e,i,s,n,o,r,l){return G.VL(t,e,i,s,n,o,r,l)}get x(){return this.rx}set x(t){this.rx=t}get y(){return this.ry}set y(t){this.ry=t}get width(){return this.rw}set width(t){t<0&&U.J(t,">= 0",Rect,"width"),this.rw=t}get height(){return this.rh}set height(t){t<0&&U.J(t,">= 0",Rect,"height"),this.rh=t}get left(){return this.rx}set left(t){this.rx=t}get top(){return this.ry}set top(t){this.ry=t}get right(){return this.rx+this.rw}set right(t){this.rx+=t-(this.rx+this.rw)}get bottom(){return this.ry+this.rh}set bottom(t){this.ry+=t-(this.ry+this.rh)}get position(){return new Point(this.rx,this.ry)}set position(t){this.rx=t.x,this.ry=t.y}get size(){return new Size(this.rw,this.rh)}set size(t){this.rw=t.width,this.rh=t.height}get center(){return new Point(this.rx+this.rw/2,this.ry+this.rh/2)}set center(t){this.rx=t.x-this.rw/2,this.ry=t.y-this.rh/2}get centerX(){return this.rx+this.rw/2}set centerX(t){this.rx=t-this.rw/2}get centerY(){return this.ry+this.rh/2}set centerY(t){this.ry=t-this.rh/2}isReal(){return isFinite(this.x)&&isFinite(this.y)&&isFinite(this.width)&&isFinite(this.height)}isEmpty(){return this.width===0&&this.height===0}static tm=new Rect(0,0,0,0).kt();static GF=new Rect(NaN,NaN,NaN,NaN).kt();static _w=[];static l(){const t=Rect._w.pop();return t===void 0?new Rect:t}static bs(t){const e=Rect._w.pop();return e===void 0?t.copy():e.h(t)}static z(t,e,i,s){const n=Rect._w.pop();return n===void 0?new Rect(t,e,i,s):n.e(t,e,i,s)}static i(t){Rect._w.push(t)}}class Margin{mt;mr;mb;ml;constructor(t,e,i,s){t===void 0?(this.mt=0,this.mr=0,this.mb=0,this.ml=0):e===void 0?(e=t,i=t,s=t,this.mt=t,this.mr=e,this.mb=i,this.ml=s):i===void 0?(i=t,s=e,this.mt=t,this.mr=e,this.mb=i,this.ml=s):s!==void 0?(this.mt=t,this.mr=e,this.mb=i,this.ml=s):U.o("Invalid arguments to Margin constructor: "+t+", "+e+", "+i+", "+s)}setTo(t,e,i,s){return this.mt=t,this.mr=e,this.mb=i,this.ml=s,this}set(t){return this.mt=t.mt,this.mr=t.mr,this.mb=t.mb,this.ml=t.ml,this}copy(){const t=new Margin;return t.mt=this.mt,t.mr=this.mr,t.mb=this.mb,t.ml=this.ml,t}kt(){return Object.freeze(this),this}N(){return Object.isFrozen(this)?this:this.copy().kt()}Ww(t){}static parse(t){if(typeof t=="string"){const e=t.split(" ");let i=0,s=NaN;for(;e[i]==="";)i++;let n=e[i++];if(n&&(s=parseFloat(n)),isNaN(s))return new Margin;let o=NaN;for(;e[i]==="";)i++;if(n=e[i++],n&&(o=parseFloat(n)),isNaN(o))return new Margin(s);let r=NaN;for(;e[i]==="";)i++;if(n=e[i++],n&&(r=parseFloat(n)),isNaN(r))return new Margin(s,o);let l=NaN;for(;e[i]==="";)i++;return n=e[i++],n&&(l=parseFloat(n)),isNaN(l)?new Margin(s,o):new Margin(s,o,r,l)}else return new Margin}static stringify(t){return t.top.toString()+" "+t.right.toString()+" "+t.bottom.toString()+" "+t.left.toString()}static stringifyFixed(t){return U.s(t,"number",Margin,"stringifyFixed:digits"),e=>e.top.toFixed(t)+" "+e.right.toFixed(t)+" "+e.bottom.toFixed(t)+" "+e.left.toFixed(t)}toString(){return"Margin("+this.top+","+this.right+","+this.bottom+","+this.left+")"}equals(t){return t instanceof Margin?this.mt===t.top&&this.mr===t.right&&this.mb===t.bottom&&this.ml===t.left:!1}equalTo(t,e,i,s){return this.mt===t&&this.mr===e&&this.mb===i&&this.ml===s}equalsApprox(t){return G.u(this.mt,t.top)&&G.u(this.mr,t.right)&&G.u(this.mb,t.bottom)&&G.u(this.ml,t.left)}get top(){return this.mt}set top(t){this.mt=t}get right(){return this.mr}set right(t){this.mr=t}get bottom(){return this.mb}set bottom(t){this.mb=t}get left(){return this.ml}set left(t){this.ml=t}isReal(){return isFinite(this.top)&&isFinite(this.right)&&isFinite(this.bottom)&&isFinite(this.left)}static em=new Margin(0,0,0,0).kt();static BL=new Margin(2,2,2,2).kt()}class Spot{sx;sy;ox;oy;constructor(t,e,i,s){t===void 0?(this.sx=0,this.sy=0,this.ox=0,this.oy=0):(e===void 0&&(e=0),i===void 0&&(i=0),s===void 0&&(s=0),this.sx=t,this.sy=e,this.ox=i,this.oy=s)}setTo(t,e,i,s){return this.sx=t,this.sy=e,this.ox=i,this.oy=s,this}set(t){return this.sx=t.sx,this.sy=t.sy,this.ox=t.ox,this.oy=t.oy,this}copy(){const t=new Spot;return t.sx=this.sx,t.sy=this.sy,t.ox=this.ox,t.oy=this.oy,t}kt(){return Object.freeze(this),this}N(){return Object.isFrozen(this)?this:this.copy().kt()}Ww(t){}Hi(t){return this.sx=NaN,this.sy=NaN,this.ox=t,this.kt()}DU(t,e){(isNaN(t)||t>1||t<0)&&U.J(t,"0 <= "+e+" <= 1",Spot,e)}vU(t,e){(isNaN(t)||t===1/0||t===-1/0)&&U.J(t,"real number, not NaN or Infinity",Spot,e)}static parse(t){if(typeof t=="string"){if(t=t.trim(),t==="None")return Spot.None;if(t==="TopLeft")return Spot.TopLeft;if(t==="Top"||t==="TopCenter"||t==="MiddleTop")return Spot.TopCenter;if(t==="TopRight")return Spot.TopRight;if(t==="Left"||t==="LeftCenter"||t==="MiddleLeft")return Spot.LeftCenter;if(t==="Center")return Spot.Center;if(t==="Right"||t==="RightCenter"||t==="MiddleRight")return Spot.RightCenter;if(t==="BottomLeft")return Spot.BottomLeft;if(t==="Bottom"||t==="BottomCenter"||t==="MiddleBottom")return Spot.BottomCenter;if(t==="BottomRight")return Spot.BottomRight;if(t==="TopSide")return Spot.TopSide;if(t==="LeftSide")return Spot.LeftSide;if(t==="RightSide")return Spot.RightSide;if(t==="BottomSide")return Spot.BottomSide;if(t==="TopBottomSides")return Spot.TopBottomSides;if(t==="LeftRightSides")return Spot.LeftRightSides;if(t==="TopLeftSides")return Spot.TopLeftSides;if(t==="TopRightSides")return Spot.TopRightSides;if(t==="BottomLeftSides")return Spot.BottomLeftSides;if(t==="BottomRightSides")return Spot.BottomRightSides;if(t==="NotTopSide")return Spot.NotTopSide;if(t==="NotLeftSide")return Spot.NotLeftSide;if(t==="NotRightSide")return Spot.NotRightSide;if(t==="NotBottomSide")return Spot.NotBottomSide;if(t==="AllSides")return Spot.AllSides;if(t==="Default")return Spot.Default;const e=t.split(" ");let i=0,s=0;for(;e[i]==="";)i++;let n=e[i++];n!==void 0&&n.length>0&&(s=parseFloat(n));let o=0;for(;e[i]==="";)i++;n=e[i++],n!==void 0&&n.length>0&&(o=parseFloat(n));let r=0;for(;e[i]==="";)i++;n=e[i++],n!==void 0&&n.length>0&&(r=parseFloat(n));let l=0;for(;e[i]==="";)i++;return n=e[i++],n!==void 0&&n.length>0&&(l=parseFloat(n)),new Spot(s,o,r,l)}else return new Spot}static stringify(t){return t.isSpot()?t.x.toString()+" "+t.y.toString()+" "+t.offsetX.toString()+" "+t.offsetY.toString():t.toString()}static stringifyFixed(t){return U.s(t,"number",Spot,"stringifyFixed:digits"),e=>e.x.toFixed(t)+" "+e.y.toFixed(t)+" "+e.offsetX.toFixed(t)+" "+e.offsetY.toFixed(t)}toString(){return this.isSpot()?this.ox===0&&this.oy===0?"Spot("+this.x+","+this.y+")":"Spot("+this.x+","+this.y+","+this.offsetX+","+this.offsetY+")":this.equals(Spot.None)?"None":this.equals(Spot.TopLeft)?"TopLeft":this.equals(Spot.TopCenter)?"Top":this.equals(Spot.TopRight)?"TopRight":this.equals(Spot.LeftCenter)?"Left":this.equals(Spot.Center)?"Center":this.equals(Spot.RightCenter)?"Right":this.equals(Spot.BottomLeft)?"BottomLeft":this.equals(Spot.BottomCenter)?"Bottom":this.equals(Spot.BottomRight)?"BottomRight":this.equals(Spot.TopSide)?"TopSide":this.equals(Spot.LeftSide)?"LeftSide":this.equals(Spot.RightSide)?"RightSide":this.equals(Spot.BottomSide)?"BottomSide":this.equals(Spot.TopBottomSides)?"TopBottomSides":this.equals(Spot.LeftRightSides)?"LeftRightSides":this.equals(Spot.TopLeftSides)?"TopLeftSides":this.equals(Spot.TopRightSides)?"TopRightSides":this.equals(Spot.BottomLeftSides)?"BottomLeftSides":this.equals(Spot.BottomRightSides)?"BottomRightSides":this.equals(Spot.NotTopSide)?"NotTopSide":this.equals(Spot.NotLeftSide)?"NotLeftSide":this.equals(Spot.NotRightSide)?"NotRightSide":this.equals(Spot.NotBottomSide)?"NotBottomSide":this.equals(Spot.AllSides)?"AllSides":this.equals(Spot.Default)?"Default":"None"}equals(t){return t instanceof Spot?(this.sx===t.x||isNaN(this.sx)&&isNaN(t.x))&&(this.sy===t.y||isNaN(this.sy)&&isNaN(t.y))&&this.ox===t.offsetX&&this.oy===t.offsetY:!1}opposite(){return new Spot(.5-(this.sx-.5),.5-(this.sy-.5),-this.ox,-this.oy)}includesSide(t){if(!this.isSide())return!1;if(!t.isSide())if(t.equals(Spot.Left))t=Spot.LeftSide;else if(t.equals(Spot.Right))t=Spot.RightSide;else if(t.equals(Spot.Top))t=Spot.TopSide;else if(t.equals(Spot.Bottom))t=Spot.BottomSide;else return!1;const e=this.oy,i=t.offsetY;return(e&i)===i}get x(){return this.sx}set x(t){this.sx=t}get y(){return this.sy}set y(t){this.sy=t}get offsetX(){return this.ox}set offsetX(t){this.ox=t}get offsetY(){return this.oy}set offsetY(t){this.oy=t}isSpot(){return!isNaN(this.x)&&!isNaN(this.y)}isNoSpot(){return isNaN(this.x)||isNaN(this.y)}isSide(){return isNaN(this.x)&&isNaN(this.y)&&this.offsetX===1&&this.offsetY!==0}isNone(){return isNaN(this.x)&&isNaN(this.y)&&this.offsetX===0&&this.offsetY===0}isDefault(){return isNaN(this.x)&&isNaN(this.y)&&this.offsetX===-1&&this.offsetY===0}static None=new Spot(0,0,0,0).Hi(0);static Default=new Spot(0,0,-1,0).Hi(-1);static TopLeft=new Spot(0,0,0,0).kt();static TopCenter=new Spot(.5,0,0,0).kt();static TopRight=new Spot(1,0,0,0).kt();static LeftCenter=new Spot(0,.5,0,0).kt();static Center=new Spot(.5,.5,0,0).kt();static RightCenter=new Spot(1,.5,0,0).kt();static BottomLeft=new Spot(0,1,0,0).kt();static BottomCenter=new Spot(.5,1,0,0).kt();static BottomRight=new Spot(1,1,0,0).kt();static MiddleTop=Spot.TopCenter;static MiddleLeft=Spot.LeftCenter;static MiddleRight=Spot.RightCenter;static MiddleBottom=Spot.BottomCenter;static Top=Spot.TopCenter;static Left=Spot.LeftCenter;static Right=Spot.RightCenter;static Bottom=Spot.BottomCenter;static TopSide=new Spot(0,0,1,1).Hi(1);static LeftSide=new Spot(0,0,1,2).Hi(1);static RightSide=new Spot(0,0,1,4).Hi(1);static BottomSide=new Spot(0,0,1,8).Hi(1);static TopBottomSides=new Spot(0,0,1,9).Hi(1);static LeftRightSides=new Spot(0,0,1,6).Hi(1);static TopLeftSides=new Spot(0,0,1,3).Hi(1);static TopRightSides=new Spot(0,0,1,5).Hi(1);static BottomLeftSides=new Spot(0,0,1,10).Hi(1);static BottomRightSides=new Spot(0,0,1,12).Hi(1);static NotTopSide=new Spot(0,0,1,14).Hi(1);static NotLeftSide=new Spot(0,0,1,13).Hi(1);static NotRightSide=new Spot(0,0,1,11).Hi(1);static NotBottomSide=new Spot(0,0,1,7).Hi(1);static AllSides=new Spot(0,0,1,15).Hi(1);static DP=new Spot(.156,.156).kt();static vP=new Spot(.844,.844).kt()}class Transform{m11;m12;m21;m22;dx;dy;constructor(){this.m11=1,this.m12=0,this.m21=0,this.m22=1,this.dx=0,this.dy=0}set(t){return this.m11=t.m11,this.m12=t.m12,this.m21=t.m21,this.m22=t.m22,this.dx=t.dx,this.dy=t.dy,this}setTo(t,e,i,s,n,o){return this.m11=t,this.m12=e,this.m21=i,this.m22=s,this.dx=n,this.dy=o,this}copy(){const t=new Transform;return t.m11=this.m11,t.m12=this.m12,t.m21=this.m21,t.m22=this.m22,t.dx=this.dx,t.dy=this.dy,t}toString(){return"Transform("+this.m11+","+this.m12+","+this.m21+","+this.m22+","+this.dx+","+this.dy+")"}equals(t){return this.m11===t.m11&&this.m12===t.m12&&this.m21===t.m21&&this.m22===t.m22&&this.dx===t.dx&&this.dy===t.dy}FP(){return this.dx===0&&this.dy===0&&this.m11===1&&this.m12===0&&this.m21===0&&this.m22===1}Ue(){return this.m11=1,this.m12=0,this.m21=0,this.m22=1,this.dx=0,this.dy=0,this}bc(t){const e=this.m11*t.m11+this.m21*t.m12,i=this.m12*t.m11+this.m22*t.m12,s=this.m11*t.m21+this.m21*t.m22,n=this.m12*t.m21+this.m22*t.m22;return this.dx=this.m11*t.dx+this.m21*t.dy+this.dx,this.dy=this.m12*t.dx+this.m22*t.dy+this.dy,this.m11=e,this.m12=i,this.m21=s,this.m22=n,this}zL(t){const e=1/(t.m11*t.m22-t.m12*t.m21),i=t.m22*e,s=-t.m12*e,n=-t.m21*e,o=t.m11*e,r=e*(t.m21*t.dy-t.m22*t.dx),l=e*(t.m12*t.dx-t.m11*t.dy),a=this.m11*i+this.m21*s,h=this.m12*i+this.m22*s,c=this.m11*n+this.m21*o,f=this.m12*n+this.m22*o;return this.dx=this.m11*r+this.m21*l+this.dx,this.dy=this.m12*r+this.m22*l+this.dy,this.m11=a,this.m12=h,this.m21=c,this.m22=f,this}tx(){const t=1/(this.m11*this.m22-this.m12*this.m21),e=this.m22*t,i=-this.m12*t,s=-this.m21*t,n=this.m11*t,o=t*(this.m21*this.dy-this.m22*this.dx),r=t*(this.m12*this.dx-this.m11*this.dy);return this.m11=e,this.m12=i,this.m21=s,this.m22=n,this.dx=o,this.dy=r,this}ks(t,e,i){if(t=G.Ee(t),t===0)return this;this.Gs(e,i);let s=0,n=0;if(t===90)s=0,n=1;else if(t===180)s=-1,n=0;else if(t===270)s=0,n=-1;else{const h=t*Math.PI/180;s=Math.cos(h),n=Math.sin(h)}const o=this.m11*s+this.m21*n,r=this.m12*s+this.m22*n,l=this.m11*-n+this.m21*s,a=this.m12*-n+this.m22*s;return this.m11=o,this.m12=r,this.m21=l,this.m22=a,this.Gs(-e,-i),this}Gs(t,e){return this.dx+=this.m11*t+this.m21*e,this.dy+=this.m12*t+this.m22*e,this}it(t,e){return e===void 0&&(e=t),this.m11*=t,this.m12*=t,this.m21*=e,this.m22*=e,this}YF(){if(this.m11===1&&this.m12===0)return 0;let t=Math.atan2(this.m12,this.m11)*180/Math.PI;return t<0&&(t+=360),t}gt(t){const e=t.x,i=t.y;return t.e(e*this.m11+i*this.m21+this.dx,e*this.m12+i*this.m22+this.dy)}Ci(t){const e=1/(this.m11*this.m22-this.m12*this.m21),i=this.m22*e,s=-this.m12*e,n=-this.m21*e,o=this.m11*e,r=t.x-this.dx,l=t.y-this.dy;return t.e(r*i+l*n,r*s+l*o)}Mu(t){const e=1/(this.m11*this.m22-this.m12*this.m21),i=this.m22*e,s=-this.m12*e,n=-this.m21*e,o=this.m11*e,r=e*(this.m21*this.dy-this.m22*this.dx),l=e*(this.m12*this.dx-this.m11*this.dy),a=t.x*1.25,h=t.y*1.2;return t.e(a*i+h*n+r,a*s+h*o+l)}im(t){const e=t.x,i=t.y,s=e+t.width,n=i+t.height,o=this.m11,r=this.m12,l=this.m21,a=this.m22,h=this.dx,c=this.dy,f=e*o+i*l+h,u=e*r+i*a+c,d=s*o+i*l+h,m=s*r+i*a+c,g=e*o+n*l+h,p=e*r+n*a+c,y=s*o+n*l+h,x=s*r+n*a+c;let k=f,b=f,P=u,S=u;return k=Math.min(k,d),b=Math.max(b,d),P=Math.min(P,m),S=Math.max(S,m),k=Math.min(k,g),b=Math.max(b,g),P=Math.min(P,p),S=Math.max(S,p),k=Math.min(k,y),b=Math.max(b,y),P=Math.min(P,x),S=Math.max(S,x),t.e(k,P,b-k,S-P),t}static XL=[];static l(){const t=Transform.XL.pop();return t===void 0?new Transform:t}static i(t){Transform.XL.push(t)}static RP="54a702f3e53909c447824c6706603faf4c"}const G={KF:"7da71ca0ad381e90",qn:4*((Math.sqrt(2)-1)/3),GL:[],ex:w=>{if(w<=0)return 0;let t=G.GL;if(t===null){t=[];for(let e=0;e<=2e3;e++)t[e]=Math.sqrt(e);G.GL=t}if(w<1){const e=1/w;return e<=2e3?1/t[e|0]:Math.sqrt(w)}else return w<=2e3?t[w|0]:Math.sqrt(w)},u:(w,t)=>{const e=w-t;return e<.5&&e>-.5},X:(w,t)=>{const e=w-t;return e<5e-8&&e>-5e-8},Ve:(w,t,e,i,s,n,o)=>{s<=0&&(s=1e-6);let r=0,l=0,a=0,h=0;if(w<e?(l=w,r=e):(l=e,r=w),t<i?(h=t,a=i):(h=i,a=t),w===e)return h<=o&&o<=a&&w-s<=n&&n<=w+s;if(t===i)return l<=n&&n<=r&&t-s<=o&&o<=t+s;const c=r+s,f=l-s;if(f<=n&&n<=c){const u=a+s,d=h-s;if(d<=o&&o<=u)if(c-f>u-d)if(w-e>s||e-w>s){const g=(i-t)/(e-w)*(n-w)+t;if(g-s<=o&&o<=g+s)return!0}else return!0;else if(t-i>s||i-t>s){const g=(e-w)/(i-t)*(o-t)+w;if(g-s<=n&&n<=g+s)return!0}else return!0}return!1},ix:(w,t,e,i,s,n,o,r,l,a,h,c)=>{if(!G.Ve(w,t,o,r,c,e,i)||!G.Ve(w,t,o,r,c,s,n)){const f=(w+e)/2,u=(t+i)/2,d=(e+s)/2,m=(i+n)/2,g=(s+o)/2,p=(n+r)/2,y=(f+d)/2,x=(u+m)/2,k=(d+g)/2,b=(m+p)/2,P=(y+k)/2,S=(x+b)/2;return G.ix(w,t,f,u,y,x,P,S,l,a,h,c)||G.ix(P,S,k,b,g,p,o,r,l,a,h,c)}else return G.Ve(w,t,o,r,c,a,h)},YL:(w,t,e,i,s,n,o,r,l)=>{const a=(w+e)/2,h=(t+i)/2,c=(e+s)/2,f=(i+n)/2,u=(s+o)/2,d=(n+r)/2,m=(a+c)/2,g=(h+f)/2,p=(c+u)/2,y=(f+d)/2;return l.e((m+p)/2,(g+y)/2),l},HF:(w,t,e,i,s,n,o,r)=>{const l=(w+e)/2,a=(t+i)/2,h=(e+s)/2,c=(i+n)/2,f=(s+o)/2,u=(n+r)/2,d=(l+h)/2,m=(a+c)/2,g=(h+f)/2,p=(c+u)/2;return Point.direction(d,m,g,p)},Nu:(w,t,e,i,s,n,o,r,l,a)=>{if(!G.Ve(w,t,o,r,l,e,i)||!G.Ve(w,t,o,r,l,s,n)){const h=(w+e)/2,c=(t+i)/2,f=(e+s)/2,u=(i+n)/2,d=(s+o)/2,m=(n+r)/2,g=(h+f)/2,p=(c+u)/2,y=(f+d)/2,x=(u+m)/2,k=(g+y)/2,b=(p+x)/2;G.Nu(w,t,h,c,g,p,k,b,l,a),G.Nu(k,b,y,x,d,m,o,r,l,a)}else a.re(w,t,0,0),a.re(o,r,0,0);return a},Wn:(w,t,e,i,s,n,o,r,l,a)=>{if(!G.Ve(w,t,o,r,l,e,i)||!G.Ve(w,t,o,r,l,s,n)){const h=(w+e)/2,c=(t+i)/2,f=(e+s)/2,u=(i+n)/2,d=(s+o)/2,m=(n+r)/2,g=(h+f)/2,p=(c+u)/2,y=(f+d)/2,x=(u+m)/2,k=(g+y)/2,b=(p+x)/2;G.Wn(w,t,h,c,g,p,k,b,l,a),G.Wn(k,b,y,x,d,m,o,r,l,a)}else a.length===0&&(a.push(w),a.push(t)),a.push(o),a.push(r);return a},OP:(w,t,e,i,s,n,o,r,l,a)=>{if(G.Ve(w,t,s,n,a,e,i))return G.Ve(w,t,s,n,a,r,l);{const h=(w+e)/2,c=(t+i)/2,f=(e+s)/2,u=(i+n)/2,d=(h+f)/2,m=(c+u)/2;return G.OP(w,t,h,c,d,m,o,r,l,a)||G.OP(d,m,f,u,s,n,o,r,l,a)}},IP:(w,t,e,i,s,n,o,r)=>{if(G.Ve(w,t,s,n,o,e,i))r.re(w,t,0,0),r.re(s,n,0,0);else{const l=(w+e)/2,a=(t+i)/2,h=(e+s)/2,c=(i+n)/2,f=(l+h)/2,u=(a+c)/2;G.IP(w,t,l,a,f,u,o,r),G.IP(f,u,h,c,s,n,o,r)}return r},sm:(w,t,e,i,s,n,o,r)=>{if(G.Ve(w,t,s,n,o,e,i))r.length===0&&(r.push(w),r.push(t)),r.push(s),r.push(n);else{const l=(w+e)/2,a=(t+i)/2,h=(e+s)/2,c=(i+n)/2,f=(l+h)/2,u=(a+c)/2;G.sm(w,t,l,a,f,u,o,r),G.sm(f,u,h,c,s,n,o,r)}return r},nm:(w,t,e,i,s,n,o,r,l,a,h,c,f,u)=>{if(!G.Ve(w,t,o,r,f,e,i)||!G.Ve(w,t,o,r,f,s,n)){const d=(w+e)/2,m=(t+i)/2,g=(e+s)/2,p=(i+n)/2,y=(s+o)/2,x=(n+r)/2,k=(d+g)/2,b=(m+p)/2,P=(g+y)/2,S=(p+x)/2,L=(k+P)/2,C=(b+S)/2;let M=1/0,N=!1,T=0,A=0;if(G.nm(w,t,d,m,k,b,L,C,l,a,h,c,f,u)){const D=(u.x-l)**2+(u.y-a)**2;D<M&&(M=D,N=!0,T=u.x,A=u.y)}if(G.nm(L,C,P,S,y,x,o,r,l,a,h,c,f,u)){const D=(u.x-l)**2+(u.y-a)**2;D<M&&(M=D,N=!0,T=u.x,A=u.y)}return N&&(u.x=T,u.y=A),N}else{if(!G.Pu(w,t,o,r,l,a,h,c))return!1;const d=(w-o)*(a-c)-(t-r)*(l-h);if(d===0)return!1;const m=((w*r-t*o)*(l-h)-(w-o)*(l*c-a*h))/d,g=((w*r-t*o)*(a-c)-(t-r)*(l*c-a*h))/d;return u.e(m,g),!0}},om:(w,t,e,i,s,n,o,r,l,a,h,c,f)=>{let u=0;if(!G.Ve(w,t,o,r,f,e,i)||!G.Ve(w,t,o,r,f,s,n)){const d=(w+e)/2,m=(t+i)/2,g=(e+s)/2,p=(i+n)/2,y=(s+o)/2,x=(n+r)/2,k=(d+g)/2,b=(m+p)/2,P=(g+y)/2,S=(p+x)/2,L=(k+P)/2,C=(b+S)/2;u+=G.om(w,t,d,m,k,b,L,C,l,a,h,c,f),u+=G.om(L,C,P,S,y,x,o,r,l,a,h,c,f)}else{const d=(w-o)*(a-c)-(t-r)*(l-h);if(d===0)return u;const m=((w*r-t*o)*(l-h)-(w-o)*(l*c-a*h))/d,g=((w*r-t*o)*(a-c)-(t-r)*(l*c-a*h))/d;if(m>=h)return u;let p=0,y=0;if((l>h?l-h:h-l)<(a>c?a-c:c-a)){if(t<r?(p=t,y=r):(p=r,y=t),g<p||g>y)return u}else if(w<o?(p=w,y=o):(p=o,y=w),m<p||m>y)return u;d>0?u++:d<0&&u--}return u},Nl:(w,t,e,i,s,n,o)=>{if(G.X(w,e)){let r=0,l=0;t<i?(r=t,l=i):(r=i,l=t);const a=n;return a<r?(o.e(w,r),!1):a>l?(o.e(w,l),!1):(o.e(w,a),!0)}else if(G.X(t,i)){let r=0,l=0;w<e?(r=w,l=e):(r=e,l=w);const a=s;return a<r?(o.e(r,t),!1):a>l?(o.e(l,t),!1):(o.e(a,t),!0)}else{const r=(e-w)**2+(i-t)**2,l=((w-s)*(w-e)+(t-n)*(t-i))/r;if(l<-5e-6)return o.e(w,t),!1;if(l>1.000005)return o.e(e,i),!1;{const a=w+l*(e-w),h=t+l*(i-t);return o.e(a,h),!0}}},vo:(w,t,e,i,s,n,o,r,l)=>{if(G.u(w,e)&&G.u(t,i))return l.e(w,t),!1;if(G.X(s,o)){if(G.X(w,e))return G.Nl(w,t,e,i,s,n,l),!1;{const h=(i-t)/(e-w)*(s-w)+t;return G.Nl(w,t,e,i,s,h,l)}}else{const a=(r-n)/(o-s);if(G.X(w,e)){const h=a*(w-s)+n;let c=0,f=0;return t<i?(c=t,f=i):(c=i,f=t),h<c?(l.e(w,c),!1):h>f?(l.e(w,f),!1):(l.e(w,h),!0)}else{const h=(i-t)/(e-w);if(G.X(a,h))return G.Nl(w,t,e,i,s,n,l),!1;{const c=(h*w-a*s+n-t)/(h-a);if(G.X(h,0)){let f=0,u=0;return w<e?(f=w,u=e):(f=e,u=w),c<f?(l.e(f,t),!1):c>u?(l.e(u,t),!1):(l.e(c,t),!0)}else{const f=h*(c-w)+t;return G.Nl(w,t,e,i,c,f,l)}}}}},Cl:(w,t,e,i,s,n,o,r,l)=>{let a=1e21,h=w,c=t;if(G.vo(w,t,w,i,s,n,o,r,l)){const f=(l.x-s)**2+(l.y-n)**2;f<a&&(a=f,h=l.x,c=l.y)}if(G.vo(e,t,e,i,s,n,o,r,l)){const f=(l.x-s)**2+(l.y-n)**2;f<a&&(a=f,h=l.x,c=l.y)}if(G.vo(w,t,e,t,s,n,o,r,l)){const f=(l.x-s)**2+(l.y-n)**2;f<a&&(a=f,h=l.x,c=l.y)}if(G.vo(w,i,e,i,s,n,o,r,l)){const f=(l.x-s)**2+(l.y-n)**2;f<a&&(a=f,h=l.x,c=l.y)}return l.e(h,c),a<1e21},nx:(w,t,e)=>G.VL(w.x,w.y,w.width,w.height,t.x,t.y,e.x,e.y),VL:(w,t,e,i,s,n,o,r)=>{const l=w,a=w+e,h=t,c=t+i;if(s===o){let f=0,u=0;return n<r?(f=n,u=r):(f=r,u=n),l<=s&&s<=a&&f<=c&&u>=h}if(n===r){let f=0,u=0;return s<o?(f=s,u=o):(f=o,u=s),h<=n&&n<=c&&f<=a&&u>=l}return!!(Rect.contains(w,t,e,i,s,n)||Rect.contains(w,t,e,i,o,r)||G.Pu(l,h,a,h,s,n,o,r)||G.Pu(a,h,a,c,s,n,o,r)||G.Pu(a,c,l,c,s,n,o,r)||G.Pu(l,c,l,h,s,n,o,r))},Pu:(w,t,e,i,s,n,o,r)=>w===e&&t===i&&s===o&&n===r?w===s&&t===n:G.ku(w,t,e,i,s,n)*G.ku(w,t,e,i,o,r)<=0&&G.ku(s,n,o,r,w,t)*G.ku(s,n,o,r,e,i)<=0,ku:(w,t,e,i,s,n)=>{const o=e-w,r=i-t;let l=s-w,a=n-t,h=l*r-a*o;return h===0&&(h=l*o+a*r,h>0&&(l-=o,a-=r,h=l*o+a*r,h<0&&(h=0))),h},Qw(w,t,e,i){i===void 0&&(i=!1);let s=0;const n=w===null?t:(t-w.x)/(w.width>0?w.width:1),o=w===null?e:(e-w.y)/(w.height>0?w.height:1);return n>o?n>1-o||(i||n<1-o?s=270:s=315):i||n<o?n>1-o?s=90:i||n<1-o?s=180:s=135:n<.5?s=225:n>.5&&(s=45),s},Ee:w=>(w>=360?w-=360:w<0&&(w+=360),w),jF:(w,t)=>w>t?Math.min(w-t,Math.abs(w-360-t)):t>w?Math.min(t-w,Math.abs(w-(t-360))):0,KL:(w,t,e,i,s,n)=>{const o=Math.PI;n||(i=i*(o/180),s=s*(o/180));const r=i>s?-1:1,l=1e-5,a=o*2,h=[],c=o/2;let f=i,u=Math.min(a,Math.abs(s-i));if(u<l){const d=f+r*Math.min(u,c),m=w+e*Math.cos(f),g=t+e*Math.sin(f),p=w+e*Math.cos(d),y=t+e*Math.sin(d),x=(m+p)/2,k=(g+y)/2;return h.push([m,g,x,k,x,k,p,y]),h}for(;u>l;){const d=f+r*Math.min(u,c);h.push(G.qF(e,f,d,w,t)),u-=Math.abs(d-f),f=d}return h},qF:(w,t,e,i,s)=>{const n=(e-t)/2,o=w*Math.cos(n),r=w*Math.sin(n),l=o,a=-r,h=l*l+a*a,c=h+l*o+a*r,f=4/3*(Math.sqrt(2*h*c)-c)/(l*r-a*o),u=l-f*a,d=a+f*l,m=u,g=-d,p=n+t,y=Math.cos(p),x=Math.sin(p);return[i+w*Math.cos(t),s+w*Math.sin(t),i+u*y-d*x,s+u*x+d*y,i+m*y-g*x,s+m*x+g*y,i+w*Math.cos(e),s+w*Math.sin(e)]},_g:(w,t,e,i,s,n,o)=>{const r=s,l=n,a=Math.floor((w-e)/r)*r+e,h=Math.floor((t-i)/l)*l+i;let c=a;a+r-w<r/2&&(c=a+r);let f=h;return h+l-t<l/2&&(f=h+l),o.e(c,f),o},HL:(w,t)=>{let e=Math.max(w,t),i=Math.min(w,t),s=1,n=1;do s=e%i,n=i,e=i,i=s;while(s>0);return n},WF:(w,t,e,i)=>{const s=e<0,n=i<0;let o=0,r=0,l=0;w<t?(r=1,l=0):(r=0,l=1);let a=0,h=0,c=0,f=0;return o=r,a=o===0?w:t,c=o===0?e:i,(o===0?s:n)&&(c=-c),o=l,h=o===0?w:t,f=o===0?e:i,(o===0?s:n)&&(f=-f),G.JF(a,h,c,f,0,0)},JF:(w,t,e,i,s,n)=>{let o=0;if(i>0)if(e>0){const r=w*w,l=t*t,a=w*e,h=t*i;let c=-l+h,f=-l+Math.sqrt(a*a+h*h),u=c;const d=9999999999;for(let p=0;p<d&&(u=.5*(c+f),!(u===c||u===f));++p){const y=a/(u+r),x=h/(u+l),k=y*y+x*x-1;if(k>0)c=u;else if(k<0)f=u;else break}s=r*e/(u+r),n=l*i/(u+l);const m=s-e,g=n-i;o=Math.sqrt(m*m+g*g)}else s=0,n=t,o=Math.abs(i-t);else{const r=w*w-t*t,l=w*e;if(l<r){const a=l/r,h=a*a;s=w*a,n=t*Math.sqrt(Math.abs(1-h));const c=s-e;o=Math.sqrt(c*c+n*n)}else s=w,n=0,o=Math.abs(e-w)}return o},Jn:{},rm:new PropertyCollection,yr:new PropertyCollection,wr:0,lm:100};G.za=G.KF;var GeometryType=(w=>(w[w.Line=1]="Line",w[w.Rectangle=2]="Rectangle",w[w.Ellipse=3]="Ellipse",w[w.Path=4]="Path",w))(GeometryType||{}),GeometryStretch=(w=>(w[w.None=0]="None",w[w.Default=1]="Default",w[w.Fill=2]="Fill",w[w.Uniform=6]="Uniform",w))(GeometryStretch||{});class Geometry{n;am;hm;kc;Cu;Lu;$n;Zn;Qn;W;Li;Ai;ni;oi;Ys;Pc;Sc;constructor(t,e){GSet.Je(this),this.n=2,t===void 0&&(t=4),this.W=t,this.Li=0,this.Ai=0,this.ni=0,this.oi=0,t===4?this.Ys=new List:this.Ys=Geometry.lx,this.am=this.Ys.lt,this.hm=new Rect,this.kc=null,this.Cu=null,this.Lu=NaN,this.$n=Spot.TopLeft,this.Zn=Spot.BottomRight,this.Pc=NaN,this.Sc=NaN,this.Qn=2,e&&Object.assign(this,e)}copy(){const t=new Geometry;if(t.n=this.n&-2,t.W=this.W,t.Li=this.Li,t.Ai=this.Ai,t.ni=this.ni,t.oi=this.oi,this.W===4){const e=this.Ys.r,i=t.Ys;for(let s=0;s<e.length;s++){const n=e[s];i.add(n.copy())}t.Ys=i}else t.Ys=this.Ys;return t.am=this.am,t.hm.h(this.hm),t.kc=this.kc,t.Cu=this.Cu,t.Lu=this.Lu,t.$n=this.$n.N(),t.Zn=this.Zn.N(),t.Pc=this.Pc,t.Sc=this.Sc,t.Qn=this.Qn,t}static Line=1;static Rectangle=2;static Ellipse=3;static Path=4;static lx=new List().b();get f(){return(this.n&1)!==0}set f(t){t?this.n|=1:this.n&=-2}get yt(){return(this.n&2)!==0}set yt(t){t?this.n|=2:this.n&=-3}b(){if(this.f=!0,this.type!==4)return this;const t=this.figures;t.b();for(const e of t)e.b();return this}equalsApprox(t){if(!(t instanceof Geometry))return!1;if(this.type!==t.type)return this.type===1&&t.type===4?this.jL(t):t.type===1&&this.type===4?t.jL(this):!1;if(this.type===4){const e=this.figures.r,i=t.figures.r,s=e.length;if(s!==i.length)return!1;for(let n=0;n<s;n++){const o=e[n],r=i[n];if(!o.equalsApprox(r))return!1}return!0}else return G.u(this.startX,t.startX)&&G.u(this.startY,t.startY)&&G.u(this.endX,t.endX)&&G.u(this.endY,t.endY)}jL(t){if(this.type!==1||t.type!==4)return!1;if(t.figures.count===1){const e=t.figures.elt(0);if(e.segments.count===1&&G.u(this.startX,e.startX)&&G.u(this.startY,e.startY)){const i=e.segments.elt(0);if(i.type===2&&G.u(this.endX,i.endX)&&G.u(this.endY,i.endY))return!0}}return!1}static stringify(t){return t.toString()}static stringifyFixed(t){return U.s(t,"number",Geometry,"stringifyFixed:digits"),e=>e.toString(t)}fe(t){t in GeometryType?this.type=t:U.dr(this,t)}toString(t){t===void 0&&(t=-1);const e=s=>s===0?"0":s.toFixed(t);let i;switch(this.type){case 1:return t<0?"M"+this.startX.toString()+" "+this.startY.toString()+"L"+this.endX.toString()+" "+this.endY.toString():"M"+e(this.startX)+" "+e(this.startY)+"L"+e(this.endX)+" "+e(this.endY);case 2:return i=new Rect(this.startX,this.startY,0,0),i.union(this.endX,this.endY,0,0),t<0?"M"+i.x.toString()+" "+i.y.toString()+"H"+i.right.toString()+"V"+i.bottom.toString()+"H"+i.left.toString()+"z":"M"+e(i.x)+" "+e(i.y)+"H"+e(i.right)+"V"+e(i.bottom)+"H"+e(i.left)+"z";case 3:if(i=new Rect(this.startX,this.startY,0,0),i.union(this.endX,this.endY,0,0),t<0){const r=i.left.toString()+" "+(i.y+i.height/2).toString(),l=i.right.toString()+" "+(i.y+i.height/2).toString();return"M"+r+"A"+(i.width/2).toString()+" "+(i.height/2).toString()+" 0 0 1 "+l+"A"+(i.width/2).toString()+" "+(i.height/2).toString()+" 0 0 1 "+r}else{const r=e(i.left)+" "+e(i.y+i.height/2),l=e(i.right)+" "+e(i.y+i.height/2);return"M"+r+"A"+e(i.width/2)+" "+e(i.height/2)+" 0 0 1 "+l+"A"+e(i.width/2)+" "+e(i.height/2)+" 0 0 1 "+r}case 4:let s="";const n=this.figures.r,o=n.length;for(let r=0;r<o;r++){const l=n[r];r>0&&(s+=" x "),l.isFilled&&(s+="F "),s+=l.toString(t)}return s;default:return GeometryType[this.type]}}static fillPath(t){typeof t!="string"&&U.si(t,"string",Geometry,"fillPath:str");const e=t.split(/[Xx]/),i=e.length;let s="";for(let n=0;n<i;n++){const o=e[n];if(o.match(/[Ff]/)!==null){n===0?s+=o:s+="X"+(o[0]===" "?"":" ")+o;continue}s+=(n===0?"":"X ")+"F"+(o[0]===" "?"":" ")+o}return s}static cm="UuBbMmZzLlHhVvCcSsQqTtAaFfXx";static parse(t,e){e===void 0&&(e=!1),typeof t!="string"&&U.si(t,"string",Geometry,"parse:str");const i=new RegExp("(["+Geometry.cm+"])(["+Geometry.cm+"])","gm"),s=new RegExp("(["+Geometry.cm+"])([^s])","gm"),n=new RegExp("([^s])(["+Geometry.cm+"])","gm");t=t.replace(/,/gm," "),t=t.replace(i,"$1 $2"),t=t.replace(i,"$1 $2"),t=t.replace(s,"$1 $2"),t=t.replace(n,"$1 $2"),t=t.replace(/([0-9])([+\-])/gm,"$1 $2"),t=t.replace(/[\s\r\t\n]+/gm," "),t=t.replace(/^\s+|\s+$/g,"");const o=t.split(" ");for(let T=0;T<o.length;T++){const A=o[T];if(A.match(/(\.[0-9]*)(\.)/gm)!==null){const D=U.ot();let v="",R=!1;for(let F=0;F<A.length;F++){const O=A[F];O==="."&&!R?(R=!0,v+=O):O==="."?(D.push(v),v="."):v+=O}D.push(v),o.splice(T,1);for(let F=0;F<D.length;F++)o.splice(T+F,0,D[F]);T+=D.length-1,U.Z(D)}}let r=-1,l="",a="";const h=new Point(0,0),c=new Point(0,0),f=new Point(0,0);let u=!0;function d(){return r>=k-1||o[r+1].match(M)!==null?!0:(u=!1,!1)}function m(){return r++,o[r]}function g(T){let A=parseFloat(m()),D=parseFloat(m());l===l.toLowerCase()&&(A=f.x+A,D=f.y+D),T.e(A,D)}function p(){return g(f),f}function y(){return g(c),c}function x(){const T=a.toLowerCase();return T==="c"||T==="s"||T==="q"||T==="t"?new Point(2*f.x-c.x,2*f.y-c.y):new Point(f.x,f.y)}const k=o.length,b=GeoStream.qL(null);let P=!1,S=!1,L=!1,C=!0;const M=new RegExp("["+Geometry.cm+"]");for(;!(r>=k-1);){if(a=l,l=m(),l==="")continue;u=!0;let T=!1;switch(l.toUpperCase()){case"X":C=!0,P=!1,S=!1;break;case"M":const A=p();for(b.Ne===null||C===!0?(b.Au(A.x,A.y,P,!1,!S,L),C=!1):b.$F(A.x,A.y),h.h(f);!d();){const D=p();b.Ks(D.x,D.y)}break;case"L":for(;!d();){const D=p();b.Ks(D.x,D.y)}u&&(T=!0);break;case"H":for(;!d();)f.e((l===l.toLowerCase()?f.x:0)+parseFloat(m()),f.y),b.Ks(f.x,f.y);break;case"V":for(;!d();)f.e(f.x,(l===l.toLowerCase()?f.y:0)+parseFloat(m())),b.Ks(f.x,f.y);u&&(T=!0);break;case"C":for(;!d();){const D=new Point;g(D);const v=y(),R=p();b.xr(D.x,D.y,v.x,v.y,R.x,R.y)}u&&(T=!0);break;case"S":for(;!d();){const D=x(),v=y(),R=p();b.xr(D.x,D.y,v.x,v.y,R.x,R.y)}u&&(T=!0);break;case"Q":for(;!d();){const D=y(),v=p();b.Tu(D.x,D.y,v.x,v.y)}u&&(T=!0);break;case"T":for(;!d();){const D=x();c.h(D);const v=p();b.Tu(D.x,D.y,v.x,v.y),c.h(v)}u&&(T=!0);break;case"B":for(;!d();){const D=parseFloat(m()),v=parseFloat(m());let R=parseFloat(m()),F=parseFloat(m());const O=parseFloat(m());let z=O,Y=!1;d()||(z=parseFloat(m()),d()||(Y=parseFloat(m())!==0)),l===l.toLowerCase()&&(R+=f.x,F+=f.y),b.ZF(D,v,R,F,O,z,Y)}u&&(T=!0);break;case"A":for(;!d();){const D=Math.abs(parseFloat(m())),v=Math.abs(parseFloat(m())),R=parseFloat(m());let F=!1,O=!1,z=0,Y=0;const E=m();E.length===1?(F=!!parseFloat(E),O=!!parseFloat(m()),z=parseFloat(m()),Y=parseFloat(m())):E.length===2?(F=!!parseFloat(E[0]),O=!!parseFloat(E[1]),z=parseFloat(m()),Y=parseFloat(m())):(F=!!parseFloat(E[0]),O=!!parseFloat(E[1]),z=parseFloat(E.slice(2)),Y=parseFloat(m())),l===l.toLowerCase()&&(z=f.x+z,Y=f.y+Y),f.e(z,Y),b.QF(D,v,R,F,O,z,Y)}u&&(T=!0);break;case"Z":b._F(),f.h(h);break;case"F":{let D="",v=1;for(;o[r+v];){if(o[r+v]==="0"){L=!0,v++;continue}if(o[r+v].match(/[Uu]/)!==null){v++;continue}if(o[r+v].match(M)===null){v++;continue}D=o[r+v];break}D.match(/[Mm]/)?P=!0:b.tR();break}case"U":{let D="",v=1;for(;o[r+v];){if(o[r+v].match(/[Ff]/)!==null){v++;continue}if(o[r+v].match(M)===null){v++;continue}D=o[r+v];break}D.match(/[Mm]/)?S=!0:b.eR(!1);break}default:if(l==="0"||l==="1")break;U.ne("Unknown geometry command: "+l);break}if(T){U.ne(`Bad geometry command: ${l}, next token: ${m()},
string: ${t}`);break}}const N=b.fm;if(GeoStream.WL(b),e){const T=N.figures.iterator;for(;T.next();){const A=T.value;A.isFilled=!0}}return N}static JL(t,e){const i=t.length,s=Point.l();for(let n=0;n<i;n++){const o=t[n];s.x=o[0],s.y=o[1],e.gt(s),o[0]=s.x,o[1]=s.y,s.x=o[2],s.y=o[3],e.gt(s),o[2]=s.x,o[3]=s.y,s.x=o[4],s.y=o[5],e.gt(s),o[4]=s.x,o[5]=s.y,s.x=o[6],s.y=o[7],e.gt(s),o[6]=s.x,o[7]=s.y}Point.i(s)}EP(){if(this.yt)return!0;if(this.type===4){const t=this.figures;if(this.am!==t.lt)return!0;const e=this.figures.r,i=e.length;for(let s=0;s<i;s++)if(e[s].EP())return!0}return!1}hx(){if(this.yt=!1,this.kc=null,this.Cu=null,this.Lu=NaN,this.type===4){const e=this.figures;this.am=e.lt;const i=this.figures.r,s=i.length;for(let n=0;n<s;n++)i[n].iR()}const t=this.hm;isNaN(this.Pc)||isNaN(this.Sc)?t.e(0,0,0,0):t.e(0,0,this.Pc,this.Sc),this.$L(t,!1),t.re(0,0,0,0)}computeBoundsWithoutOrigin(){const t=new Rect;return this.$L(t,!0),t}$L(t,e){switch(this.type){case 1:case 2:case 3:e?t.e(this.Li,this.Ai,0,0):t.re(this.Li,this.Ai,0,0),t.re(this.ni,this.oi,0,0);break;case 4:const i=this.figures,s=i.r,n=i.length;for(let o=0;o<n;o++){const r=s[o];e&&o===0?t.e(r.startX,r.startY,0,0):t.re(r.startX,r.startY,0,0);const a=r.segments.r,h=a.length;let c=r.startX,f=r.startY;for(let u=0;u<h;u++){const d=a[u];switch(d.type){case 2:case 1:c=d.endX,f=d.endY,t.re(c,f,0,0);break;case 3:G.Nu(c,f,d.point1X,d.point1Y,d.point2X,d.point2Y,d.endX,d.endY,.5,t),c=d.endX,f=d.endY;break;case 4:G.IP(c,f,d.point1X,d.point1Y,d.endX,d.endY,.5,t),c=d.endX,f=d.endY;break;case 5:case 6:const m=d.type===5?d.Fo(r):d.Ja(r,c,f),g=m.length;if(g===0){c=d.type===5?d.centerX:d.endX,f=d.type===5?d.centerY:d.endY,t.re(c,f,0,0);break}let p=null;for(let y=0;y<g;y++)p=m[y],G.Nu(p[0],p[1],p[2],p[3],p[4],p[5],p[6],p[7],.5,t);p!==null&&(c=p[6],f=p[7]);break;default:U.o("Unknown Segment type: "+d.type)}}}break;default:U.o("Unknown Geometry type: "+this.type)}}sR(t,e){const i=this.bounds;let s=t/i.width,n=e/i.height;return isFinite(s)||(s=1),isFinite(n)||(n=1),s===1&&n===1?this:this.copy().scale(s,n)}normalize(){this.f&&U.L(this);const t=this.computeBoundsWithoutOrigin();return this.offset(-t.x,-t.y),new Point(-t.x,-t.y)}offset(t,e){return this.f&&U.L(this),this.v(1,0,0,1,t,e),this}scale(t,e){return this.f&&U.L(this),this.v(t,0,0,e,0,0),this}rotate(t,e,i){this.f&&U.L(this),e===void 0&&(e=0),i===void 0&&(i=0);const s=Transform.l();return s.Ue(),s.ks(t,e,i),this.v(s.m11,s.m12,s.m21,s.m22,s.dx,s.dy),Transform.i(s),this}v(t,e,i,s,n,o){let r=0,l=0;switch(this.type){case 1:case 2:case 3:r=this.Li,l=this.Ai,this.Li=r*t+l*i+n,this.Ai=r*e+l*s+o,r=this.ni,l=this.oi,this.ni=r*t+l*i+n,this.oi=r*e+l*s+o;break;case 4:const h=this.figures.r,c=h.length;for(let f=0;f<c;f++){const u=h[f];r=u.startX,l=u.startY,u.startX=r*t+l*i+n,u.startY=r*e+l*s+o;const m=u.segments.r,g=m.length;for(let p=0;p<g;p++){const y=m[p];switch(y.type){case 2:case 1:r=y.endX,l=y.endY,y.endX=r*t+l*i+n,y.endY=r*e+l*s+o;break;case 3:r=y.point1X,l=y.point1Y,y.point1X=r*t+l*i+n,y.point1Y=r*e+l*s+o,r=y.point2X,l=y.point2Y,y.point2X=r*t+l*i+n,y.point2Y=r*e+l*s+o,r=y.endX,l=y.endY,y.endX=r*t+l*i+n,y.endY=r*e+l*s+o;break;case 4:r=y.point1X,l=y.point1Y,y.point1X=r*t+l*i+n,y.point1Y=r*e+l*s+o,r=y.endX,l=y.endY,y.endX=r*t+l*i+n,y.endY=r*e+l*s+o;break;case 5:if(r=y.centerX,l=y.centerY,y.centerX=r*t+l*i+n,y.centerY=r*e+l*s+o,e!==0){let x=Math.atan2(e,t)*180/Math.PI;x<0&&(x+=360),y.startAngle+=x}t<0&&(y.startAngle=180-y.startAngle,y.sweepAngle=-y.sweepAngle),s<0&&(y.startAngle=-y.startAngle,y.sweepAngle=-y.sweepAngle),y.radiusX*=Math.sqrt(t*t+i*i),y.radiusY!==void 0&&(y.radiusY*=Math.sqrt(e*e+s*s));break;case 6:if(r=y.endX,l=y.endY,y.endX=r*t+l*i+n,y.endY=r*e+l*s+o,y.radiusX===0||y.radiusY===0)break;if(e!==0){let x=Math.atan2(e,t)*180/Math.PI;x<0&&(x+=360),y.xAxisRotation+=x}t<0&&(y.xAxisRotation=180-y.xAxisRotation,y.isClockwiseArc=!y.isClockwiseArc),s<0&&(y.xAxisRotation=-y.xAxisRotation,y.isClockwiseArc=!y.isClockwiseArc),y.radiusX*=Math.sqrt(t*t+i*i),y.radiusY*=Math.sqrt(e*e+s*s);break;default:U.o("Unknown Segment type: "+y.type)}}}break}return this.yt=!0,this}containsPoint(t,e){e===void 0&&(e=0);const i=this.Li,s=this.Ai,n=this.ni,o=this.oi;switch(this.type){case 1:return G.Ve(i,s,n,o,e,t.x,t.y);case 2:{const r=Math.min(i,n)-e,l=Math.min(s,o)-e,a=Math.abs(n-i)+e*2,h=Math.abs(o-s)+e*2,c=Rect.z(r,l,a,h),f=c.containsPoint(t);return Rect.i(c),f}case 3:{let r=Math.min(i,n)-e,l=Math.min(s,o)-e;const a=Math.abs(n-i)+e*2,h=Math.abs(o-s)+e*2,c=a/2,f=h/2;return c<=0||f<=0?!1:(r=t.x-(r+c),l=t.y-(l+f),r*r/(c*c)+l*l/(f*f)<=1)}case 4:return this.UP(t,e,!0,!1);default:return!1}}UP(t,e,i,s){const n=t.x,o=t.y,r=this.bounds.x-20,l=o;let a=0,h=0,c=0,f=0,u=0,d=0;const m=this.figures.r,g=m.length;for(let p=0;p<g;p++){const y=m[p],x=!y.isEvenOdd;if(y.isFilled){if(i&&y.VP(n,o,e))return!0}else{if(y.VP(n,o,s?e:e+2))return!0;continue}const k=y.segments;h=y.startX,c=y.startY;let b=h,P=c;const S=k.r;let L=S[0];for(let C=0;C<=k.length;C++){let M;switch(C!==k.length?(L=S[C],M=L.type,u=L.endX,d=L.endY):(M=2,u=b,d=P),M){case 1:{const N=this.cx(n,o,r,l,h,c,b,P);if(isNaN(N))return!0;a+=N,b=u,P=d;break}case 2:{const N=this.cx(n,o,r,l,h,c,u,d);if(isNaN(N))return!0;a+=N;break}case 3:f=G.om(h,c,L.point1X,L.point1Y,L.point2X,L.point2Y,u,d,r,l,n,o,.5),a+=f;break;case 4:{const N=(h+2*L.point1X)/3,T=(c+2*L.point1Y)/3,A=(L.point1X*2+u)/3,D=(L.point1Y*2+d)/3;f=G.om(h,c,N,T,A,D,u,d,r,l,n,o,.5),a+=f;break}case 5:case 6:{const N=L.type===5?L.Fo(y):L.Ja(y,h,c),T=N.length;if(T===0){const D=this.cx(n,o,r,l,h,c,L.type===5?L.centerX:L.endX,L.type===5?L.centerY:L.endY);if(isNaN(D))return!0;a+=D;break}let A=null;for(let D=0;D<T;D++){if(A=N[D],D===0){const v=this.cx(n,o,r,l,h,c,A[0],A[1]);if(isNaN(v))return!0;a+=v}f=G.om(A[0],A[1],A[2],A[3],A[4],A[5],A[6],A[7],r,l,n,o,.5),a+=f}A!==null&&(u=A[6],d=A[7]);break}default:U.o("Unknown Segment type: "+L.type)}h=u,c=d}if(x){if(a!==0)return!0}else if(a%2!==0)return!0;a=0}return!1}cx(t,e,i,s,n,o,r,l){if(G.Ve(n,o,r,l,.05,t,e))return NaN;const a=(t-i)*(o-l);if(a===0)return 0;const h=((t*s-e*i)*(n-r)-(t-i)*(n*l-o*r))/a,c=(t*s-e*i)*(o-l)/a;if(h>=t)return 0;if((n>r?n-r:r-n)<(o>l?o-l:l-o)){if(o<l){if(c<o||c>l)return 0}else if(c<l||c>o)return 0}else if(n<r){if(h<n||h>r)return 0}else if(h<r||h>n)return 0;return a>0?1:-1}ZL(t,e,i){const s=this.figures.r,n=s.length;for(let o=0;o<n;o++)if(s[o].VP(t,e,i))return!0;return!1}getPointAlongPath(t,e){if(t<0?t=0:t>1&&(t=1),e===void 0&&(e=new Point),this.type===1)return e.e(this.startX+t*(this.endX-this.startX),this.startY+t*(this.endY-this.startY)),e;const i=this.flattenedSegments,s=this.flattenedLengths,n=this.flattenedTotalLength,o=i.length,r=n*t;let l=0;for(let a=0;a<o;a++){const h=s[a],c=h.length;for(let f=0;f<c;f++){const u=h[f];if(l+u>=r){const d=r-l,m=u===0?0:d/u,g=i[a],p=g[f*2],y=g[f*2+1],x=g[f*2+2],k=g[f*2+3];return e.e(p+(x-p)*m,y+(k-y)*m),e}l+=u}}return e}getAngleAlongPath(t){if(t<0?t=0:t>1&&(t=1),this.type===1)return Math.atan2(this.endY-this.startY,this.endX-this.startX)*180/Math.PI;const e=this.flattenedSegments,i=this.flattenedLengths,s=this.flattenedTotalLength,n=e.length,o=s*t;let r=0;for(let l=0;l<n;l++){const a=i[l],h=a.length;for(let c=0;c<h;c++){const f=a[c];if(r+f>=o){const u=e[l],d=u[c*2],m=u[c*2+1],g=u[c*2+2],p=u[c*2+3];return Math.abs(g-d)<1&&Math.abs(p-m)<1?0:Math.abs(g-d)<1?p-m>=0?90:270:Math.abs(p-m)<1?g-d>=0?0:180:Math.atan2(p-m,g-d)*180/Math.PI}r+=f}}return NaN}getPointAndAngleAlongPath(t,e){if(t<0?t=0:t>1&&(t=1),e===void 0&&(e=[]),e.length=3,this.type===1)return e[0]=this.startX+t*(this.endX-this.startX),e[1]=this.startY+t*(this.endY-this.startY),e[2]=Math.atan2(this.endY-this.startY,this.endX-this.startX)*180/Math.PI,e;const i=this.flattenedSegments,s=this.flattenedLengths,n=this.flattenedTotalLength,o=i.length,r=n*t;let l=0;for(let a=0;a<o;a++){const h=s[a],c=h.length;for(let f=0;f<c;f++){const u=h[f];if(l+u>=r){const d=r-l,m=u===0?0:d/u,g=i[a],p=g[f*2],y=g[f*2+1],x=g[f*2+2],k=g[f*2+3];e[0]=p+(x-p)*m,e[1]=y+(k-y)*m;let b;return Math.abs(x-p)<1&&Math.abs(k-y)<1?b=0:Math.abs(x-p)<1?b=k-y>=0?90:270:Math.abs(k-y)<1?b=x-p>=0?0:180:b=Math.atan2(k-y,x-p)*180/Math.PI,e[2]=b,e}l+=u}}return e}getFractionForPoint(t){if(this.type===1){const e=this.startX,i=this.startY,s=this.endX,n=this.endY;if(e===s&&i===n)return 0;{const o=t.x,r=t.y;let l=0,a=0;if(e===s)return i<n?(l=i,a=n):(l=n,a=i),r<=l?l===i?0:1:r>=a?a===i?0:1:Math.abs(r-i)/(a-l);if(i===n)return e<s?(l=e,a=s):(l=s,a=e),o<=l?l===e?0:1:o>=a?a===e?0:1:Math.abs(o-e)/(a-l);{const h=(s-e)**2+(n-i)**2,c=Point.l();G.Nl(e,i,s,n,o,r,c);const f=c.x,u=c.y;return Point.i(c),Math.sqrt(((f-e)**2+(u-i)**2)/h)}}}else if(this.type===2){const e=this.startX,i=this.startY,s=this.endX,n=this.endY;if(e===s&&i===n)return 0;{const o=s-e,r=n-i,l=o*2+r*2;let a=t.x,h=t.y;a=Math.min(Math.max(a,e),s),h=Math.min(Math.max(h,i),n);const c=Math.abs(a-e),f=Math.abs(a-s),u=Math.abs(h-i),d=Math.abs(h-n),m=Math.min(c,f,u,d);if(m===u)return a/l;if(m===f)return(o+h)/l;if(m===d)return(o*2+r-a)/l;if(m===c)return(o*2+r*2-h)/l}}else{const e=this.flattenedSegments,i=this.flattenedLengths,s=this.flattenedTotalLength,n=Point.l();let o=1/0,r=0,l=0;const a=e.length;let h=0,c=0;for(let u=0;u<a;u++){const d=e[u],m=i[u],g=d.length;for(let p=0;p<g;p+=2){const y=d[p],x=d[p+1];if(p===0){h=y,c=x;continue}G.Nl(h,c,y,x,t.x,t.y,n);const k=(n.x-t.x)**2+(n.y-t.y)**2;k<o&&(o=k,r=l,r+=Math.sqrt((n.x-h)**2+(n.y-c)**2)),l+=m[(p-2)/2],h=y,c=x}}Point.i(n);const f=r/s;return f<0?0:f>1?1:f}return 0}get flattenedSegments(){return this.QL(),this.kc}QL(){if(this.kc===null){const t=this.kc=[],e=this.Cu=[];this.nR(t,e)}}get flattenedLengths(){return this.QL(),this.Cu}get flattenedTotalLength(){let t=this.Lu;if(isNaN(t)){if(this.type===1){const e=Math.abs(this.endX-this.startX),i=Math.abs(this.endY-this.startY);t=Math.sqrt(e*e+i*i)}else if(this.type===2){const e=Math.abs(this.endX-this.startX),i=Math.abs(this.endY-this.startY);t=e*2+i*2}else{const e=this.flattenedLengths,i=e.length;t=0;for(let s=0;s<i;s++){const n=e[s],o=n.length;for(let r=0;r<o;r++)t+=n[r]}}this.Lu=t}return t}BP(t){const e=[];let i=0,s=0;const n=t.length;for(let o=0;o<n;o+=2){const r=t[o],l=t[o+1];if(o===0){i=r,s=l;continue}const a=Math.sqrt(Point.distanceSquared(i,s,r,l));e.push(a),i=r,s=l}return e}nR(t,e){let i=[];const s=[];if(this.type===1)i.push(this.startX),i.push(this.startY),i.push(this.endX),i.push(this.endY),t.push(i),s.push(Math.sqrt((this.startX-this.endX)**2+(this.startY-this.endY)**2)),e.push(s);else if(this.type===2)i.push(this.startX),i.push(this.startY),i.push(this.endX),i.push(this.startY),i.push(this.endX),i.push(this.endY),i.push(this.startX),i.push(this.endY),i.push(this.startX),i.push(this.startY),t.push(i),s.push(Math.abs(this.startX-this.endX)),s.push(Math.abs(this.startY-this.endY)),s.push(Math.abs(this.startX-this.endX)),s.push(Math.abs(this.startY-this.endY)),e.push(s);else if(this.type===3){const n=new PathFigure;n.startX=this.endX,n.startY=(this.startY+this.endY)/2;const o=new PathSegment(5);o.startAngle=0,o.sweepAngle=360,o.centerX=(this.startX+this.endX)/2,o.centerY=(this.startY+this.endY)/2,o.radiusX=Math.abs(this.startX-this.endX)/2,o.radiusY=Math.abs(this.startY-this.endY)/2,n.add(o);const r=o.Fo(n),l=r.length;if(l===0)i.push(o.centerX),i.push(o.centerY);else{let a=n.startX,h=n.startY;for(let c=0;c<l;c++){const f=r[c];G.Wn(a,h,f[2],f[3],f[4],f[5],f[6],f[7],.5,i),a=f[6],h=f[7]}}t.push(i),e.push(this.BP(i))}else{const n=this.figures.iterator;for(;n.next();){const o=n.value;i=[],i.push(o.startX),i.push(o.startY);let r=o.startX,l=o.startY,a=r,h=l;const c=o.segments.r,f=c.length;for(let u=0;u<f;u++){const d=c[u];switch(d.type){case 1:i.length>=4&&(t.push(i),e.push(this.BP(i))),i=[],i.push(d.endX),i.push(d.endY),r=d.endX,l=d.endY,a=r,h=l;break;case 2:i.push(d.endX),i.push(d.endY),r=d.endX,l=d.endY;break;case 3:G.Wn(r,l,d.point1X,d.point1Y,d.point2X,d.point2Y,d.endX,d.endY,.5,i),r=d.endX,l=d.endY;break;case 4:G.sm(r,l,d.point1X,d.point1Y,d.endX,d.endY,.5,i),r=d.endX,l=d.endY;break;case 5:{const m=d.Fo(o),g=m.length;if(g===0){i.push(d.centerX),i.push(d.centerY),r=d.centerX,l=d.centerY;break}for(let p=0;p<g;p++){const y=m[p];G.Wn(r,l,y[2],y[3],y[4],y[5],y[6],y[7],.5,i),r=y[6],l=y[7]}break}case 6:{const m=d.Ja(o,r,l),g=m.length,p=d.endX,y=d.endY;if(g===0){i.push(p),i.push(y),r=p,l=y;break}for(let x=0;x<g;x++){const k=m[x];G.Wn(r,l,k[2],k[3],k[4],k[5],k[6],k[7],.5,i),r=k[6],l=k[7]}break}default:U.o("Segment not of valid type: "+d.type)}d.isClosed&&(i.push(a),i.push(h))}i.length>=4&&(t.push(i),e.push(this.BP(i)))}}}get type(){return this.W}set type(t){this.W!==t&&(this.f&&U.L(this,t),this.W=t,t===4?this.Ys=new List:(Geometry.lx===null&&(Geometry.lx=new List().b()),this.Ys=Geometry.lx),this.yt=!0)}get startX(){return this.Li}set startX(t){this.Li!==t&&(this.f&&U.L(this,t),this.Li=t,this.yt=!0)}get startY(){return this.Ai}set startY(t){this.Ai!==t&&(this.f&&U.L(this,t),this.Ai=t,this.yt=!0)}get endX(){return this.ni}set endX(t){this.ni!==t&&(this.f&&U.L(this,t),this.ni=t,this.yt=!0)}get endY(){return this.oi}set endY(t){this.oi!==t&&(this.f&&U.L(this,t),this.oi=t,this.yt=!0)}get figures(){return this.Ys}set figures(t){this.Ys!==t&&(this.f&&U.L(this,t),this.Ys=t,this.yt=!0)}add(t){return this.Ys.add(t),this}setSpots(t,e,i,s,n,o,r,l){return this.f&&U.L(this),this.$n=new Spot(t,e,n,o),this.Zn=new Spot(i,s,r,l),this}get spot1(){return this.$n}set spot1(t){this.f&&U.L(this,t),this.$n=t.N()}get spot2(){return this.Zn}set spot2(t){this.f&&U.L(this,t),this.Zn=t.N()}get defaultStretch(){return this.Qn}set defaultStretch(t){this.Qn=t}get bounds(){return this.EP()&&this.hx(),this.hm}polygonClosestSegment(t,e){if(e===void 0&&(e=10),this.type!==4)return null;const i=t.x,s=t.y;let n=1/0,o=0,r=0,l=0,a=0,h=0,c=0,f=0,u=0;return this.figures.each(d=>{let m=d.startX,g=d.startY;d.segments.each(p=>{let y=p.endX,x=p.endY,k=0;if(p.type===2)k=Point.distanceLineSegmentSquared(i,s,m,g,y,x);else{m=p.endX,g=p.endY;return}k<n&&(n=k,o=l,r=a,h=m,c=g,f=y,u=x),m=y,g=x,a++,p.isClosed&&(y=d.startX,x=d.startY,k=Point.distanceLineSegmentSquared(i,s,m,g,y,x),k<n&&(n=k,o=l,r=a,h=m,c=g,f=y,u=x),a++)}),l++,a=0}),n<e*e?{figi:o,segi:r,ax:h,ay:c,bx:f,by:u}:null}get polygonArea(){if(this.type===4){const t=this.figures.iterator;let e=0,i=0,s=0,n=0,o=0;for(;t.next();){const r=t.value;if(!r.isFilled)continue;e=r.startX,i=r.startY;const l=r.segments.iterator;for(;l.next();){const a=l.value;s=a.endX,n=a.endY,a.type===1||a.type!==5&&(o+=e*n-i*s),e=s,i=n}o+=e*r.startY-i*r.startX}return Math.abs(o)/2}else if(this.type===2){const t=Math.abs(this.startX-this.endX),e=Math.abs(this.startY-this.endY);return t*e}else if(this.type===3){const t=Math.abs(this.startX-this.endX),e=Math.abs(this.startY-this.endY);return Math.PI*t/2*e/2}else return 0}get polygonLength(){if(this.type===4){const t=this.figures.iterator;let e=0,i=0,s=0,n=0,o=0;for(;t.next();){const r=t.value;e=r.startX,i=r.startY;const l=r.segments.iterator;for(;l.next();){const h=l.value;s=h.endX,n=h.endY,h.type===1||h.type!==5&&(o+=Math.sqrt((s-e)*(s-e)+(n-i)*(n-i))),e=s,i=n}const a=r.segments.last();a&&a.isClosed&&(s=r.startX,n=r.startY,o+=Math.sqrt((s-e)*(s-e)+(n-i)*(n-i)))}return o}else if(this.type===2){const t=Math.abs(this.startX-this.endX),e=Math.abs(this.startY-this.endY);return t*2+e*2}else if(this.type===3){const t=Math.abs(this.startX-this.endX)/2,e=Math.abs(this.startY-this.endY)/2;if(t+e===0)return 0;const i=(t-e)*(t-e)/((t+e)*(t+e));let s=i,n=1+s/4;return s*=i,n+=s/64,s*=i,n+=s/256,s*=i,n+=s*25/16384,s*=i,n+=s*49/65536,s*=i,n+=s*441/1048576,Math.PI*(t+e)*n}else{const t=this.startX,e=this.startY,i=this.endX,s=this.endY;return Math.sqrt((i-t)*(i-t)+(s-e)*(s-e))}}static computeConvexHull(t){t.sort((s,n)=>s.x===n.x?n.y-s.y:n.x-s.x);const e=[];for(let s=0;s<t.length;s++){for(;e.length>=2&&t[s].compareWithLineSegmentPoint(e[e.length-2],e[e.length-1])>=0;)e.pop();e.push(t[s])}e.pop();const i=[];for(let s=t.length-1;s>=0;s--){for(;i.length>=2&&t[s].compareWithLineSegmentPoint(i[i.length-2],i[i.length-1])>=0;)i.pop();i.push(t[s])}return i.pop(),e.concat(i)}static generatePolygon(t,e,i){e===void 0&&(e=0),i===void 0&&(i=!0);const s=new Geometry;if(t.length>1)if(e>0)if(i){t.push(t[0]),t.push(t[1]);let n=!0;const o=new PathFigure(0,0,i,!1);for(let l=1;l<t.length;l++){const a=(t[l-1].x+t[l].x)/2,h=(t[l-1].y+t[l].y)/2,c=t[l-1].distanceSquaredPoint(t[l]),f=.5*e/Math.sqrt(c);if(f<.5){const u=t[l-1].x+(t[l].x-t[l-1].x)*f,d=t[l-1].y+(t[l].y-t[l-1].y)*f;if(n?(n=!1,o.startX=u,o.startY=d):o.add(new PathSegment(3,u,d,t[l-1].x,t[l-1].y,t[l-1].x,t[l-1].y)),l<t.length-1){const m=t[l].x+(t[l-1].x-t[l].x)*f,g=t[l].y+(t[l-1].y-t[l].y)*f;o.add(new PathSegment(2,m,g))}}else n?(n=!1,o.startX=a,o.startY=h):o.add(new PathSegment(3,a,h,t[l-1].x,t[l-1].y,t[l-1].x,t[l-1].y))}const r=o.segments.last();r&&r.close(),s.add(o)}else{const n=new PathFigure(t[0].x,t[0].y,!1,!1);for(let o=1;o<t.length;o++){const r=(t[o-1].x+t[o].x)/2,l=(t[o-1].y+t[o].y)/2,a=t[o-1].distanceSquaredPoint(t[o]),h=.5*e/Math.sqrt(a);if(h<.5){if(o>1){const u=t[o-1].x+(t[o].x-t[o-1].x)*h,d=t[o-1].y+(t[o].y-t[o-1].y)*h;n.add(new PathSegment(3,u,d,t[o-1].x,t[o-1].y,t[o-1].x,t[o-1].y))}const c=t[o].x+(t[o-1].x-t[o].x)*h,f=t[o].y+(t[o-1].y-t[o].y)*h;n.add(new PathSegment(2,c,f))}else o>1&&n.add(new PathSegment(3,r,l,t[o-1].x,t[o-1].y,t[o-1].x,t[o-1].y));o===t.length-1&&n.add(new PathSegment(2,t[o].x,t[o].y))}s.add(n)}else{const n=new PathFigure(t[0].x,t[0].y,i,!1);for(let o=1;o<t.length;o++)n.add(new PathSegment(2,t[o].x,t[o].y));if(i){const o=n.segments.last();o&&o.close()}s.add(n)}return s}}Geometry.stringify=Geometry.stringify;Geometry.stringifyFixed=Geometry.stringifyFixed;Geometry.fillPath=Geometry.fillPath;Geometry.parse=Geometry.parse;class PathFigure{n;Li;Ai;Mc;um;ji;constructor(t,e,i,s,n){i===void 0&&(i=!0),s===void 0&&(s=!0),n===void 0&&(n=!1),this.n=2|(i?4:0)|(s?8:0)|(n?16:0),t!==void 0?this.Li=t:this.Li=0,e!==void 0?this.Ai=e:this.Ai=0,this.Mc=new List,this.um=this.Mc.lt,this.ji=null}copy(){const t=new PathFigure;t.n=this.n&-2,t.Li=this.Li,t.Ai=this.Ai;const e=this.Mc.r,i=e.length,s=t.Mc;for(let n=0;n<i;n++){const r=e[n].copy();s.add(r)}return t.um=this.um,t.ji=this.ji,t}equalsApprox(t){if(!(t instanceof PathFigure)||!G.u(this.startX,t.startX)||!G.u(this.startY,t.startY))return!1;const e=this.segments.r,i=t.segments.r,s=e.length;if(s!==i.length)return!1;for(let n=0;n<s;n++){const o=e[n],r=i[n];if(!o.equalsApprox(r))return!1}return!0}toString(t){t===void 0&&(t=-1);let e="";if(t<0)e="M"+this.startX.toString()+" "+this.startY.toString();else{const n=o=>o===0?"0":o.toFixed(t);e="M"+n(this.startX)+" "+n(this.startY)}const i=this.segments.r,s=i.length;for(let n=0;n<s;n++){const o=i[n];e+=" "+o.toString(t)}return e}get f(){return(this.n&1)!==0}set f(t){t?this.n|=1:this.n&=-2}get yt(){return(this.n&2)!==0}set yt(t){t?this.n|=2:this.n&=-3}b(){this.f=!0;const t=this.segments;t.b();const e=t.r,i=t.length;for(let s=0;s<i;s++)e[s].b();return this}EP(){if(this.yt)return!0;const t=this.segments;if(this.um!==t.lt)return!0;for(const e of t)if(e.yt)return!0;return!1}iR(){this.yt=!1,this.ji=null;const t=this.segments;this.um=t.lt;for(const e of t)e.yt=!1,e.Hs=null}get isFilled(){return(this.n&4)!==0}set isFilled(t){this.f&&U.L(this,t),t?this.n|=4:this.n&=-5}get isShadowed(){return(this.n&8)!==0}set isShadowed(t){this.f&&U.L(this,t),t?this.n|=8:this.n&=-9}get isEvenOdd(){return(this.n&16)!==0}set isEvenOdd(t){this.f&&U.L(this,t),t?this.n|=16:this.n&=-17}get startX(){return this.Li}set startX(t){this.f&&U.L(this,t),this.Li=t,this.ji=null,this.yt=!0}get startY(){return this.Ai}set startY(t){this.f&&U.L(this,t),this.Ai=t,this.ji=null,this.yt=!0}get segments(){return this.Mc}set segments(t){this.f&&U.L(this,t),this.Mc=t,this.ji=null,this.yt=!0}add(t){return this.Mc.add(t),this.ji=null,this}VP(t,e,i){const s=this;let n=s.startX,o=s.startY,r=n,l=o;const a=s.segments.r,h=a.length;for(let c=0;c<h;c++){const f=a[c];switch(f.type){case 1:r=f.endX,l=f.endY,n=f.endX,o=f.endY;break;case 2:if(G.Ve(n,o,f.endX,f.endY,i,t,e))return!0;n=f.endX,o=f.endY;break;case 3:if(G.ix(n,o,f.point1X,f.point1Y,f.point2X,f.point2Y,f.endX,f.endY,.5,t,e,i))return!0;n=f.endX,o=f.endY;break;case 4:if(G.OP(n,o,f.point1X,f.point1Y,f.endX,f.endY,.5,t,e,i))return!0;n=f.endX,o=f.endY;break;case 5:case 6:const u=f.type===5?f.Fo(s):f.Ja(s,n,o),d=u.length,m=f.type===5?f.centerX:f.endX,g=f.type===5?f.centerY:f.endY;if(d===0){if(G.Ve(n,o,m,g,i,t,e))return!0;n=m,o=g;break}let p=null;for(let y=0;y<d;y++)if(p=u[y],y===0&&G.Ve(n,o,p[0],p[1],i,t,e)||G.ix(p[0],p[1],p[2],p[3],p[4],p[5],p[6],p[7],.5,t,e,i))return!0;p!==null&&(n=p[6],o=p[7]);break;default:U.o("Unknown Segment type: "+f.type)}if(f.isClosed&&(n!==r||o!==l)&&G.Ve(n,o,r,l,i,t,e))return!0}return!1}}var SegmentType=(w=>(w[w.Move=1]="Move",w[w.Line=2]="Line",w[w.Bezier=3]="Bezier",w[w.QuadraticBezier=4]="QuadraticBezier",w[w.Arc=5]="Arc",w[w.SvgArc=6]="SvgArc",w))(SegmentType||{});class PathSegment{W;n;ni;oi;pn;Ll;Al;br;Hs;constructor(t,e,i,s,n,o,r,l){if(GSet.Je(this),t===void 0&&(t=2),this.W=t,this.n=2,e!==void 0?this.ni=e:this.ni=0,i!==void 0?this.oi=i:this.oi=0,s===void 0&&(s=0),n===void 0&&(n=0),o===void 0&&(o=0),r===void 0&&(r=0),t===6){let a=o;a=a%360,a<0&&(a+=360),this.pn=a,this.Ll=0,this.Al=Math.max(s,0),this.br=Math.max(n,0),typeof r=="boolean"?r&&(this.isLargeArc=!0):typeof r=="number"&&r&&(this.isLargeArc=!0),l&&(this.isClockwiseArc=!0)}else this.pn=s,this.Ll=n,t===5&&(o=Math.max(o,0)),this.Al=o,typeof r=="number"?(t===5&&(r=Math.max(r,0)),this.br=r):this.br=0;this.Hs=null}copy(){const t=new PathSegment;return t.W=this.W,t.n=this.n&-2,t.ni=this.ni,t.oi=this.oi,t.pn=this.pn,t.Ll=this.Ll,t.Al=this.Al,t.br=this.br,t}equalsApprox(t){if(!(t instanceof PathSegment)||this.type!==t.type||this.isClosed!==t.isClosed)return!1;switch(this.type){case 1:case 2:return G.u(this.endX,t.endX)&&G.u(this.endY,t.endY);case 3:return G.u(this.endX,t.endX)&&G.u(this.endY,t.endY)&&G.u(this.point1X,t.point1X)&&G.u(this.point1Y,t.point1Y)&&G.u(this.point2X,t.point2X)&&G.u(this.point2Y,t.point2Y);case 4:return G.u(this.endX,t.endX)&&G.u(this.endY,t.endY)&&G.u(this.point1X,t.point1X)&&G.u(this.point1Y,t.point1Y);case 5:return G.u(this.startAngle,t.startAngle)&&G.u(this.sweepAngle,t.sweepAngle)&&G.u(this.centerX,t.centerX)&&G.u(this.centerY,t.centerY)&&G.u(this.radiusX,t.radiusX)&&G.u(this.radiusY,t.radiusY);case 6:return this.isClockwiseArc===t.isClockwiseArc&&this.isLargeArc===t.isLargeArc&&G.u(this.xAxisRotation,t.xAxisRotation)&&G.u(this.endX,t.endX)&&G.u(this.endY,t.endY)&&G.u(this.radiusX,t.radiusX)&&G.u(this.radiusY,t.radiusY);default:return!1}}fe(t){t in SegmentType?this.type=t:U.dr(this,t)}toString(t){t===void 0&&(t=-1);const e=s=>s===0?"0":s.toFixed(t);let i="";switch(this.type){case 1:t<0?i="M"+this.endX.toString()+" "+this.endY.toString():i="M"+e(this.endX)+" "+e(this.endY);break;case 2:t<0?i="L"+this.endX.toString()+" "+this.endY.toString():i="L"+e(this.endX)+" "+e(this.endY);break;case 3:t<0?i="C"+this.point1X.toString()+" "+this.point1Y.toString()+" "+this.point2X.toString()+" "+this.point2Y.toString()+" "+this.endX.toString()+" "+this.endY.toString():i="C"+e(this.point1X)+" "+e(this.point1Y)+" "+e(this.point2X)+" "+e(this.point2Y)+" "+e(this.endX)+" "+e(this.endY);break;case 4:t<0?i="Q"+this.point1X.toString()+" "+this.point1Y.toString()+" "+this.endX.toString()+" "+this.endY.toString():i="Q"+e(this.point1X)+" "+e(this.point1Y)+" "+e(this.endX)+" "+e(this.endY);break;case 5:t<0?i="B"+this.startAngle.toString()+" "+this.sweepAngle.toString()+" "+this.centerX.toString()+" "+this.centerY.toString()+" "+this.radiusX.toString()+" "+this.radiusY.toString():i="B"+e(this.startAngle)+" "+e(this.sweepAngle)+" "+e(this.centerX)+" "+e(this.centerY)+" "+e(this.radiusX)+" "+e(this.radiusY);break;case 6:t<0?i="A"+this.radiusX.toString()+" "+this.radiusY.toString()+" "+this.xAxisRotation.toString()+" "+(this.isLargeArc?1:0)+" "+(this.isClockwiseArc?1:0)+" "+this.endX.toString()+" "+this.endY.toString():i="A"+e(this.radiusX)+" "+e(this.radiusY)+" "+e(this.xAxisRotation)+" "+(this.isLargeArc?1:0)+" "+(this.isClockwiseArc?1:0)+" "+e(this.endX)+" "+e(this.endY);break;default:i=SegmentType[this.type]}return i+(this.isClosed?"z":"")}static Move=1;static Line=2;static Bezier=3;static QuadraticBezier=4;static Arc=5;static SvgArc=6;get f(){return(this.n&1)!==0}set f(t){t?this.n|=1:this.n&=-2}get yt(){return(this.n&2)!==0}set yt(t){t?this.n|=2:this.n&=-3}b(){return this.f=!0,this}close(){return this.isClosed=!0,this}Fo(t){if(this.Hs!==null&&t.yt===!1)return this.Hs;const e=this.radiusX;let i=this.radiusY;if(i===void 0&&(i=e),e===0||i===0)return this.Hs=[],this.Hs;const s=this.pn,n=this.Ll,o=G.KL(0,0,e<i?e:i,this.startAngle,this.startAngle+this.sweepAngle,!1);if(e!==i){const l=Transform.l();l.Ue(),e<i?l.it(1,i/e):l.it(e/i,1),Geometry.JL(o,l),Transform.i(l)}const r=o.length;for(let l=0;l<r;l++){const a=o[l];a[0]+=s,a[1]+=n,a[2]+=s,a[3]+=n,a[4]+=s,a[5]+=n,a[6]+=s,a[7]+=n}return this.Hs=o,this.Hs}Ja(t,e,i){if(this.Hs!==null&&t.yt===!1)return this.Hs;if(this.radiusX===0||this.radiusY===0)return this.Hs=[],this.Hs;const s=e,n=i;let o=this.Al,r=this.br;o===0&&(o=1e-4),r===0&&(r=1e-4);const l=this.pn*(Math.PI/180),a=this.isLargeArc,h=this.isClockwiseArc,c=this.ni,f=this.oi,u=Math.cos(l),d=Math.sin(l),m=u*(s-c)/2+d*(n-f)/2,g=-d*(s-c)/2+u*(n-f)/2,p=m*m/(o*o)+g*g/(r*r);p>1&&(o*=Math.sqrt(p),r*=Math.sqrt(p));let y=(a===h?-1:1)*Math.sqrt((o*o*r*r-o*o*g*g-r*r*m*m)/(o*o*g*g+r*r*m*m));isNaN(y)&&(y=0);let x=y*o*g/r,k=y*-r*m/o;isNaN(x)&&(x=0),isNaN(k)&&(k=0);const b=(s+c)/2+u*x-d*k,P=(n+f)/2+d*x+u*k,S=(X,B)=>Math.sqrt(X*X+B*B),L=(X,B,H,j)=>(X*H+B*j)/(S(X,B)*S(H,j)),C=(X,B,H,j)=>(X*j<B*H?-1:1)*Math.acos(L(X,B,H,j)),M=C(1,0,(m-x)/o,(g-k)/r),N=(m-x)/o,T=(g-k)/r,A=(-m-x)/o,D=(-g-k)/r;let v=C(N,T,A,D);const R=L(N,T,A,D);R<=-1?v=Math.PI:R>=1&&(v=0),!h&&v>0&&(v=v-2*Math.PI),h&&v<0&&(v=v+2*Math.PI);const F=o>r?o:r,O=o>r?1:o/r,z=o>r?r/o:1,Y=G.KL(0,0,F,M,M+v,!0),E=Transform.l();return E.Ue(),E.Gs(b,P),E.ks(this.pn,0,0),E.it(O,z),Geometry.JL(Y,E),Transform.i(E),this.Hs=Y,this.Hs}get isClosed(){return(this.n&8)!==0}set isClosed(t){this.isClosed!==t&&(t?this.n|=8:this.n&=-9,this.yt=!0)}get type(){return this.W}set type(t){this.f&&U.L(this,t),this.W=t,this.yt=!0}get endX(){return this.ni}set endX(t){this.f&&U.L(this,t),this.ni=t,this.yt=!0}get endY(){return this.oi}set endY(t){this.f&&U.L(this,t),this.oi=t,this.yt=!0}get point1X(){return this.pn}set point1X(t){this.f&&U.L(this,t),this.pn=t,this.yt=!0}get point1Y(){return this.Ll}set point1Y(t){this.f&&U.L(this,t),this.Ll=t,this.yt=!0}get point2X(){return this.Al}set point2X(t){this.f&&U.L(this,t),this.Al=t,this.yt=!0}get point2Y(){return this.br}set point2Y(t){this.f&&U.L(this,t),this.br=t,this.yt=!0}get centerX(){return this.pn}set centerX(t){this.f&&U.L(this,t),this.pn=t,this.yt=!0}get centerY(){return this.Ll}set centerY(t){this.f&&U.L(this,t),this.Ll=t,this.yt=!0}get radiusX(){return this.Al}set radiusX(t){t<0&&U.J(t,">= zero",PathSegment,"radiusX"),this.f&&U.L(this,t),this.Al=t,this.yt=!0}get radiusY(){return this.br}set radiusY(t){t<0&&U.J(t,">= zero",PathSegment,"radiusY"),this.f&&U.L(this,t),this.br=t,this.yt=!0}get startAngle(){return this.ni}set startAngle(t){this.f&&U.L(this,t),t=t%360,t<0&&(t+=360),this.ni=t,this.yt=!0}get sweepAngle(){return this.oi}set sweepAngle(t){this.f&&U.L(this,t),t>360&&(t=360),t<-360&&(t=-360),this.oi=t,this.yt=!0}get isClockwiseArc(){return(this.n&4)!==0}set isClockwiseArc(t){this.f&&U.L(this,t),t?this.n|=4:this.n&=-5,this.yt=!0}get isLargeArc(){return(this.n&16)!==0}set isLargeArc(t){this.f&&U.L(this,t),t?this.n|=16:this.n&=-17,this.yt=!0}get xAxisRotation(){return this.pn}set xAxisRotation(t){this.f&&U.L(this,t),t=t%360,t<0&&(t+=360),this.pn=t,this.yt=!0}}class InputEvent{a;fx;ux;dm;gm;mm;pm;ym;wm;xm;bm;km;Pm;Sm;Ro;Mm;Nm;Ps;Ti;constructor(){this.a=null,this.fx=new Point(0,0).b(),this.ux=new Point(0,0).b(),this.dm=0,this.gm=0,this.mm=1,this.pm="",this.ym="",this.wm=!1,this.xm=!1,this.bm=0,this.km=0,this.Pm=!1,this.Sm=!1,this.Ro=!1,this.Mm=null,this.Nm=0,this.Ps=null,this.Ti=null}copy(){const t=new InputEvent;return this.clone(t)}clone(t){return t.a=this.a,t.fx.h(this.viewPoint),t.ux.h(this.documentPoint),t.dm=this.dm,t.gm=this.gm,t.mm=this.mm,t.pm=this.pm,t.ym=this.ym,t.wm=this.wm,t.xm=this.xm,t.bm=this.bm,t.km=this.km,t.Pm=this.Pm,t.Sm=this.Sm,t.Ro=this.Ro,t.Mm=this.Mm,t.Nm=this.Nm,t.Ps=this.Ps,t.Ti=this.Ti,t}toString(){let t="^";return this.modifiers!==0&&(t+="M:"+this.modifiers),this.button!==0&&(t+="B:"+this.button),this.key!==""&&(t+="K:"+this.key),this.clickCount!==0&&(t+="C:"+this.clickCount),this.delta!==0&&(t+="D:"+this.delta),this.handled&&(t+="h"),this.bubbles&&(t+="b"),this.documentPoint!==null&&(t+="@"+this.documentPoint.toString()),t}get diagram(){return this.a}set diagram(t){this.a=t}get viewPoint(){return this.fx}set viewPoint(t){this.fx.h(t)}get documentPoint(){return this.ux}set documentPoint(t){this.ux.h(t)}getMultiTouchViewPoint(t,e){const i=this.diagram;return i===null||i._L(this.event,t,e),e}getMultiTouchDocumentPoint(t,e){const i=this.diagram;return i===null||(i._L(this.event,t,e),e.h(i.transformViewToDoc(e))),e}get modifiers(){return this.dm}set modifiers(t){this.dm=t}get button(){return this.gm}set button(t){if(this.gm=t,this.event===null)switch(t){case 0:this.buttons=1;return;case 1:this.buttons=4;return;case 2:this.buttons=2;return}}get buttons(){return this.mm}set buttons(t){this.mm=t}get key(){return this.pm}set key(t){this.pm=t}get code(){return this.ym}set code(t){this.ym=t}get down(){return this.wm}set down(t){this.wm=t}get up(){return this.xm}set up(t){this.xm=t}get clickCount(){return this.bm}set clickCount(t){this.bm=t}get delta(){return this.km}set delta(t){this.km=t}get isMultiTouch(){return this.Pm}set isMultiTouch(t){this.Pm=t}get handled(){return this.Sm}set handled(t){this.Sm=t}get bubbles(){return this.Ro}set bubbles(t){this.Ro=t}get event(){return this.Mm}set event(t){this.Mm=t}get isTouchEvent(){const t=this.event;return t===null?!1:t.pointerType==="touch"||t.pointerType==="pen"}get timestamp(){return this.Nm}set timestamp(t){this.Nm=t}get targetDiagram(){return this.Ps}set targetDiagram(t){this.Ps=t}get targetObject(){return this.Ti}set targetObject(t){this.Ti=t}get control(){return(this.modifiers&1)!==0}set control(t){this.modifiers=t?this.modifiers|1:this.modifiers&-2}get shift(){return(this.modifiers&4)!==0}set shift(t){this.modifiers=t?this.modifiers|4:this.modifiers&-5}get alt(){return(this.modifiers&2)!==0}set alt(t){this.modifiers=t?this.modifiers|2:this.modifiers&-3}get meta(){return(this.modifiers&8)!==0}set meta(t){this.modifiers=t?this.modifiers|8:this.modifiers&-9}get left(){const t=this.event;return t!==null&&(t.type==="mousedown"||t.type==="mouseup"||t.type==="pointerdown"||t.type==="pointerup")?this.button===0:(this.buttons&1)!==0}set left(t){t?this.buttons|=1:this.buttons&=-2}get right(){const t=this.event;return t!==null&&(t.type==="mousedown"||t.type==="mouseup"||t.type==="pointerdown"||t.type==="pointerup")?this.button===2:(this.buttons&2)!==0}set right(t){t?this.buttons|=2:this.buttons&=-3}get middle(){const t=this.event;return t!==null&&(t.type==="mousedown"||t.type==="mouseup"||t.type==="pointerdown"||t.type==="pointerup")?this.button===1:(this.buttons&4)!==0}set middle(t){t?this.buttons|=4:this.buttons&=-5}get commandKey(){const t=this.code,e=this.key;return"cxvyzagCXVYZAG".includes(e)?e.toLowerCase():t==="KeyC"?"c":t==="KeyX"?"x":t==="KeyV"?"v":t==="KeyY"?"y":t==="KeyZ"?"z":t==="KeyA"?"a":t==="KeyG"?"g":t!==""?t:e}}class DiagramEvent{a;Pt;Cm;Lm;constructor(){this.a=null,this.Pt="",this.Cm=null,this.Lm=null}copy(){const t=new DiagramEvent;return t.a=this.a,t.Pt=this.Pt,t.Cm=this.Cm,t.Lm=this.Lm,t}toString(){let t="*"+this.name;return this.subject!==null&&(t+=":"+this.subject.toString()),this.parameter!==null&&(t+="("+this.parameter.toString()+")"),t}get diagram(){return this.a}set diagram(t){this.a=t}get name(){return this.Pt}set name(t){this.Pt=t}get subject(){return this.Cm}set subject(t){this.Cm=t}get parameter(){return this.Lm}set parameter(t){this.Lm=t}}var ChangeType=(w=>(w[w.Transaction=1]="Transaction",w[w.Property=2]="Property",w[w.Insert=3]="Insert",w[w.Remove=4]="Remove",w))(ChangeType||{});class ChangedEvent{Du;Am;yn;Ce;a;vu;Nc;Cc;Lc;Ac;constructor(){this.Du=2,this.Am="",this.yn="",this.Ce=null,this.a=null,this.vu=null,this.Nc=null,this.Cc=null,this.Lc=null,this.Ac=null}static Transaction=1;static Property=2;static Insert=3;static Remove=4;clear(){this.Ce=null,this.a=null,this.vu=null,this.Nc=null,this.Cc=null,this.Lc=null,this.Ac=null}copy(){const t=new ChangedEvent;t.Du=this.Du,t.Am=this.Am,t.yn=this.yn,t.Ce=this.Ce,t.a=this.a,t.vu=this.vu;let e=this.Nc;return U.$(e)&&U.nt(e.copyFrozen)?t.Nc=e.copyFrozen():t.Nc=e,e=this.Cc,U.$(e)&&U.nt(e.copyFrozen)?t.Cc=e.copyFrozen():t.Cc=e,e=this.Lc,U.$(e)&&U.nt(e.copyFrozen)?t.Lc=e.copyFrozen():t.Lc=e,e=this.Ac,U.$(e)&&U.nt(e.copyFrozen)?t.Ac=e.copyFrozen():t.Ac=e,t}fe(t){t in ChangeType?this.change=t:U.dr(this,t)}toString(){let t="";return this.change===1?t+="* ":this.change===2?t+=this.model!==null?"!m":"!d":t+=(this.model!==null?"!m":"!d")+this.change,this.propertyName&&typeof this.propertyName=="string"&&(t+=" "+this.propertyName),this.modelChange&&this.modelChange!==this.propertyName&&(t+=" "+this.modelChange),t+=": ",this.change===1?this.oldValue!==null&&(t+=" "+this.oldValue):(this.object!==null&&(t+=U.toString(this.object)),this.oldValue!==null&&(t+="  old: "+U.toString(this.oldValue)),this.oldParam!==null&&(t+=" "+this.oldParam),this.newValue!==null&&(t+="  new: "+U.toString(this.newValue)),this.newParam!==null&&(t+=" "+this.newParam)),t}getValue(t){return t?this.oldValue:this.newValue}getParam(t){return t?this.oldParam:this.newParam}canUndo(){return this.model!==null||this.diagram!==null}undo(){this.canUndo()&&(this.model!==null?this.model.changeState(this,!0):this.diagram!==null&&this.diagram.tA(this,!0))}canRedo(){return this.model!==null||this.diagram!==null}redo(){this.canRedo()&&(this.model!==null?this.model.changeState(this,!1):this.diagram!==null&&this.diagram.tA(this,!1))}get model(){return this.Ce}set model(t){this.Ce=t}get diagram(){return this.a}set diagram(t){this.a=t}get change(){return this.Du}set change(t){this.Du=t}get modelChange(){return this.Am}set modelChange(t){this.Am=t}get propertyName(){return this.yn}set propertyName(t){this.yn=t}get isTransactionFinished(){return this.Du===1&&(this.yn==="CommittedTransaction"||this.yn==="FinishedUndo"||this.yn==="FinishedRedo")}get object(){return this.vu}set object(t){this.vu=t}get oldValue(){return this.Nc}set oldValue(t){this.Nc=t}get oldParam(){return this.Cc}set oldParam(t){this.Cc=t}get newValue(){return this.Lc}set newValue(t){this.Lc=t}get newParam(){return this.Ac}set newParam(t){this.Ac=t}}class Transaction{eA;Pt;zP;constructor(){this.eA=new List().b(),this.Pt="",this.zP=!1}toString(t){let e="Transaction: "+this.name+" "+this.changes.count.toString()+(this.isComplete?"":", incomplete");if(t!==void 0&&t>0){const i=this.changes.count;for(let s=0;s<i;s++){const n=this.changes.elt(s);n!==null&&(e+=`
  `+n.toString())}}return e}clear(){const t=this.changes;t.ce();for(let e=t.count-1;e>=0;e--){const i=t.elt(e);i!==null&&i.clear()}t.clear(),t.b()}canUndo(){return this.isComplete}undo(){if(this.canUndo())for(let t=this.changes.count-1;t>=0;t--){const e=this.changes.elt(t);e!==null&&e.undo()}}canRedo(){return this.isComplete}redo(){if(!this.canRedo())return;const t=this.changes.count;for(let e=0;e<t;e++){const i=this.changes.elt(e);i!==null&&i.redo()}}oR(t){const e=this.changes;for(let i=e.count-1;i>=t;i--){const s=e.elt(i);s!==null&&s.undo(),e.ce(),e.removeAt(i)}e.b()}thaw(){this.changes.ce()}optimize(){if(!this.isComplete)return;const t=this.changes;t.ce();const e=new Map;for(let s=0;s<t.count;s++){const n=t.elt(s);if(n===null||n.change!==2||!n.object)continue;let o=e.get(n.object);o||(o=new Map,e.set(n.object,o));const r=o.get(n.propertyName);r===void 0?o.set(n.propertyName,-1):(r>0&&t.setElt(r,null),o.set(n.propertyName,s))}let i=0;for(let s=0;s<t.count;s++){const n=t.elt(s);n!==null&&(s>i&&t.setElt(i,n),i++)}for(;t.length>i;)t.pop();t.b()}get changes(){return this.eA}get name(){return this.Pt}set name(t){this.Pt=t}get isComplete(){return this.zP}set isComplete(t){this.zP=t}}class UndoManager{gx;Be;iA;js;XP;Tm;Tl;GP;YP;wn;Tc;mx;qs;yx;wx;Dm;xx;constructor(t){this.gx=new GSet,this.Be=!1,this.iA=new List().b(),this.js=-1,this.XP=999,this.qs=!1,this.Tm=null,this.Tl=0,this.GP=!1,this.YP=23,this.wn=new List().b(),this.Tc=new List,this.mx=!0,this.yx=!1,this.wx=!1,this.Dm=!1,this.xx=!1,t&&Object.assign(this,t)}toString(t){let e="UndoManager "+this.historyIndex+"<"+this.history.count+"<="+this.maxHistoryLength;e+="[";let i=this.nestedTransactionNames.count;for(let s=0;s<i;s++)s>0&&(e+=" "),e+=this.nestedTransactionNames.elt(s);if(e+="]",t!==void 0&&t>0){i=this.history.count;for(let s=0;s<i;s++)e+=`
 `+this.history.elt(s).toString(t-1)}return e}clear(){const t=this.history;t.ce();for(let e=t.count-1;e>=0;e--){const i=t.elt(e);i!==null&&i.clear()}t.clear(),this.js=-1,t.b(),this.qs=!1,this.Tm=null,this.Tl=0,this.wn.ce(),this.wn.clear(),this.wn.b(),this.Tc.clear(),this.yx=!1,this.wx=!1,this.Dm=!1,this.xx=!1}copyProperties(t){this.isEnabled=t.isEnabled,this.maxHistoryLength=t.maxHistoryLength,this.vm=t.vm}addModel(t){this.gx.add(t)}removeModel(t){this.gx.delete(t)}startTransaction(t){if(t===void 0&&(t=""),t===null&&(t=""),this.isUndoingRedoing)return!1;this.mx===!0&&(this.mx=!1,this.Tl++,this.Dl||this.vl("StartingFirstTransaction",t,this.currentTransaction),this.Tl>0&&this.Tl--),this.isEnabled&&(this.wn.ce(),this.wn.add(t),this.wn.b(),this.currentTransaction===null?this.Tc.add(0):this.Tc.add(this.currentTransaction.changes.count)),this.Tl++;const e=this.transactionLevel===1;return e&&(this.Dl||this.vl("StartedTransaction",t,this.currentTransaction)),e}commitTransaction(t){return t===void 0&&(t=""),this.sA(!0,t)}rollbackTransaction(){return this.sA(!1,"")}sA(t,e){if(this.isUndoingRedoing)return!1;this.vm&&this.transactionLevel<1&&U.ne("Ending transaction without having started a transaction: "+e);const i=this.transactionLevel===1;let s=this.currentTransaction;i&&t&&(this.Dl||this.vl("CommittingTransaction",e,s));let n=0;if(this.transactionLevel>0&&(this.Tl--,this.isEnabled)){const o=this.wn.count;o>0&&(e===""&&(e=this.wn.elt(0)),this.wn.ce(),this.wn.removeAt(o-1),this.wn.b());const r=this.Tc.count;r>0&&(n=this.Tc.elt(r-1),this.Tc.removeAt(r-1))}if(i){if(t){if(this.Dm=!1,s===null&&e!==""&&(s=this.currentTransaction),this.isEnabled&&s!==null){const o=s;o.isComplete||(o.isComplete=!0,o.name=e),this.discardHistoryAfterIndex();const r=this.history;r.ce();const l=this.maxHistoryLength;if(l>=0){if(l===0)r.clear();else if(r.count>=l){const a=r.elt(0);a!==null&&a.clear(),r.removeAt(0),this.js--}}l!==0&&(r.count===0||r.get(r.count-1)!==o)&&(r.add(o),this.js++),r.b(),s=o}this.Dl||this.vl("CommittedTransaction",e,s)}else{this.qs=!0;try{this.isEnabled&&s!==null&&(s.isComplete=!0,s.undo())}finally{this.Dl||this.vl("RolledBackTransaction",e,s),this.qs=!1}s!==null&&s.clear()}return this.Tm=null,this.kx&&this.clear(),this.kx=!1,this.Px=!1,!0}else return this.isEnabled&&!t&&s!==null&&s.oR(n),!1}discardHistoryAfterIndex(){if(this.isUndoingRedoing||!this.canRedo())return;const t=this.history;t.ce();for(let e=t.count-1;e>this.historyIndex;e--){const i=t.elt(e);i!==null&&i.clear(),t.removeAt(e),this.Dm=!0}t.b()}thaw(){this.history.ce()}canUndo(){if(!this.isEnabled||this.transactionLevel>0)return!1;const t=this.transactionToUndo;return!!(t!==null&&t.canUndo())}undo(){if(!this.canUndo())return;const t=this.transactionToUndo;if(t!==null)try{this.qs=!0,this.vl("StartingUndo","Undo",t),this.js--,t.undo()}catch(e){U.ne("undo error: "+e.toString())}finally{this.vl("FinishedUndo","Undo",t),this.qs=!1}}canRedo(){if(!this.isEnabled||this.transactionLevel>0)return!1;const t=this.transactionToRedo;return!!(t!==null&&t.canRedo())}redo(){if(!this.canRedo())return;const t=this.transactionToRedo;if(t!==null)try{this.qs=!0,this.vl("StartingRedo","Redo",t),this.js++,t.redo()}catch(e){U.ne("redo error: "+e.toString())}finally{this.vl("FinishedRedo","Redo",t),this.qs=!1}}vl(t,e,i){const s=new ChangedEvent;s.change=1,s.propertyName=t,s.object=i,s.oldValue=e;const n=this.models;for(;n.next();){const o=n.value;s.model=o,o.rR(s)}}handleChanged(t){if(this.isEnabled&&!this.isUndoingRedoing&&!this.skipsEvent(t)){let e=this.currentTransaction;e===null&&(e=new Transaction,this.Tm=e);const i=t.copy(),s=e.changes;if(s.ce(),s.add(i),s.b(),this.vm&&this.YP>0&&this.transactionLevel<=0&&!this.mx){const n=t.diagram;if(n!==null&&n.$a===!1)return;U.ne("Change not within a transaction: "+i.toString()),this.YP--}}}skipsEvent(t){if(t===null||t.change===1)return!0;const e=t.object;if(e===null)return!1;if(e.layer!==void 0){const i=e.layer;if(i!==null&&i.isTemporary)return!0}else if(e.isTemporary)return!0;return!1}get models(){return this.gx.iterator}get isEnabled(){return this.Be}set isEnabled(t){this.Be=t}get transactionToUndo(){return this.historyIndex>=0&&this.historyIndex<=this.history.count-1?this.history.elt(this.historyIndex):null}get transactionToRedo(){return this.historyIndex<this.history.count-1?this.history.elt(this.historyIndex+1):null}get isUndoingRedoing(){return this.qs}get history(){return this.iA}get maxHistoryLength(){return this.XP}set maxHistoryLength(t){this.XP=t}get historyIndex(){return this.js}get currentTransaction(){return this.Tm}get transactionLevel(){return this.Tl}get isInTransaction(){return this.Tl>0}get vm(){return this.GP}set vm(t){this.GP=t}get nestedTransactionNames(){return this.wn}get kx(){return this.yx}set kx(t){this.yx=t}get Px(){return this.wx}set Px(t){this.wx=t}get Dl(){return this.xx}set Dl(t){this.xx=t}get isJustDiscarded(){return this.Dm}}class Tool{a;Pt;Be;KP;HP;Fm;nA;constructor(){GSet.Je(this),this.a=Diagram.Rm(),this.Pt="",this.Be=!0,this.KP=!1,this.HP=null,this.nA=new InputEvent,this.Fm=-1}get diagram(){return this.a}set diagram(t){t instanceof Diagram&&(this.a=t)}toString(){return this.name!==""?this.name+" Tool":U.Hn(this.constructor)}updateAdornments(t){}canStart(){return this.isEnabled}doStart(){}doActivate(){this.isActive=!0}doDeactivate(){this.isActive=!1}doStop(){}doCancel(){this.transactionResult=null,this.stopTool()}stopTool(){const t=this.diagram;t.currentTool===this&&(t.currentTool=null,t.currentCursor="")}doMouseDown(){!this.isActive&&this.canStart()&&this.doActivate()}doMouseMove(){}doMouseUp(){this.stopTool()}doMouseWheel(){}canStartMultiTouch(){return!0}standardPinchZoomStart(){const t=this.diagram,e=t.lastInput,i=e.getMultiTouchViewPoint(0,Point.z(NaN,NaN)),s=e.getMultiTouchViewPoint(1,Point.z(NaN,NaN));if(!i.isReal()||!s.isReal()){Point.i(i),Point.i(s);return}if(this.doCancel(),t.getInputOption("hasGestureZoom")){t.jP=t.scale;const n=s.x-i.x,o=s.y-i.y,r=Math.sqrt(n*n+o*o);t.qP=r,e.bubbles=!1}Point.i(i),Point.i(s)}standardPinchZoomMove(){const t=this.diagram,e=t.lastInput,i=e.getMultiTouchViewPoint(0,Point.z(NaN,NaN)),s=e.getMultiTouchViewPoint(1,Point.z(NaN,NaN));if(!i.isReal()||!s.isReal()){Point.i(i),Point.i(s);return}if(this.doCancel(),t.getInputOption("hasGestureZoom")){const n=s.x-i.x,o=s.y-i.y,l=Math.sqrt(n*n+o*o)/t.qP,a=new Point((Math.min(s.x,i.x)+Math.max(s.x,i.x))/2,(Math.min(s.y,i.y)+Math.max(s.y,i.y))/2),h=t.jP*l,c=t.commandHandler;if(h!==t.scale&&c.canResetZoom(h)){const f=t.zoomPoint;t.zoomPoint=a,c.resetZoom(h),t.zoomPoint=f}e.bubbles=!1}Point.i(i),Point.i(s)}doKeyDown(){this.diagram.lastInput.code==="Escape"&&this.doCancel()}doKeyUp(){}startTransaction(t){return t===void 0&&(t=this.name),this.transactionResult=null,this.diagram.startTransaction(t)}stopTransaction(){const t=this.diagram;return this.transactionResult===null?t.rollbackTransaction():t.commitTransaction(this.transactionResult)}standardMouseSelect(){const t=this.diagram;if(!t.allowSelect)return;const e=t.lastInput,i=t.findPartAt(e.documentPoint,!1);if(i!==null){if(U.ur?e.meta:e.control){t.T("ChangingSelection",t.selection);let s=i;for(;s!==null&&!s.canSelect();)s=s.containingGroup;s!==null&&(s.isSelected=!s.isSelected),t.T("ChangedSelection",t.selection)}else if(e.shift){if(!i.isSelected){t.T("ChangingSelection",t.selection);let s=i;for(;s!==null&&!s.canSelect();)s=s.containingGroup;s!==null&&(s.isSelected=!0),t.T("ChangedSelection",t.selection)}}else if(!i.isSelected){let s=i;for(;s!==null&&!s.canSelect();)s=s.containingGroup;s!==null&&t.select(s)}}else e.left&&!(U.ur?e.meta:e.control)&&!e.shift&&t.clearSelection()}standardMouseClick(t,e){t===void 0&&(t=null),e===void 0&&(e=o=>!o.layer?.isTemporary);const i=this.diagram,s=i.lastInput,n=i.findObjectAt(s.documentPoint,t,e);return s.targetObject=n,this.oA(n,s,i)}oA(t,e,i){if(e.handled=!1,t!==null&&!t.isEnabledObject())return!1;let s=0;e.left?e.clickCount===1?s=1:e.clickCount===2?s=2:s=1:e.right&&e.clickCount===1&&(s=3);let n="ObjectSingleClicked";if(t!==null){switch(s){case 1:n="ObjectSingleClicked";break;case 2:n="ObjectDoubleClicked";break;case 3:n="ObjectContextClicked";break}s!==0&&i.T(n,t)}else{switch(s){case 1:n="BackgroundSingleClicked";break;case 2:n="BackgroundDoubleClicked";break;case 3:n="BackgroundContextClicked";break}s!==0&&i.T(n)}if(t!==null)for(;t!==null;){let o=null;switch(s){case 1:o=t.click;break;case 2:o=t.doubleClick?t.doubleClick:t.click;break;case 3:o=t.contextClick;break}if(o!==null&&(o(e,t),e.handled))break;t=t.panel}else{let o=null;switch(s){case 1:o=i.click;break;case 2:o=i.doubleClick?i.doubleClick:i.click;break;case 3:o=i.contextClick;break}o!==null&&o(e)}return e.handled}standardMouseOver(){const t=this.diagram,e=t.lastInput;if(t.animationManager.ke===!0)return;const i=t.skipsUndoManager;t.skipsUndoManager=!0;let s=t.viewportBounds.containsPoint(e.documentPoint)?t.findObjectAt(e.documentPoint,null,null):null;e.event&&(e.event.type==="pointercancel"||e.event.type==="pointerout")&&(s=null),e.targetObject=s;let n=!1;if(s!==t.Dc){let o=t.Dc;const r=o;for(t.Dc=s,this.rA(o,s),e.handled=!1;o!==null;){const l=o.mouseLeave;if(l!==null&&(s===o||s!==null&&s.isContainedBy(o)||(l(e,o,s),n=!0,e.handled)))break;o=o.panel}for(o=r,e.handled=!1;s!==null;){const l=s.mouseEnter;if(l!==null&&(o===s||o!==null&&o.isContainedBy(s)||(l(e,s,o),n=!0,e.handled)))break;s=s.panel}s=t.Dc}if(s!==null){let o=s,r="";for(;o!==null&&(r=o.cursor,r==="");)o=o.panel;for(t.currentCursor=r,e.handled=!1,o=s;o!==null;){const l=o.mouseOver;if(l!==null&&(l(e,o),n=!0,e.handled))break;o=o.panel}}else{this.doUpdateCursor(null);const o=t.mouseOver;o!==null&&(o(e),n=!0)}n&&t.requestUpdate(),t.skipsUndoManager=i}doUpdateCursor(t){const e=this.diagram;e&&(e.currentCursor="")}rA(t,e){}standardMouseWheel(){const t=this.diagram,e=t.lastInput;let i=e.delta;if(i===0||!t.documentBounds.isReal())return;const s=t.commandHandler,n=t.toolManager.mouseWheelBehavior;if(s!==null&&(n===2&&!e.shift||n===1&&e.control)){if(i>0?s.canIncreaseZoom():s.canDecreaseZoom()){const o=t.zoomPoint;t.zoomPoint=e.viewPoint,i>0?s.increaseZoom():s.decreaseZoom(),t.zoomPoint=o}e.bubbles=!1}else if(n===2&&e.shift||n===1&&!e.control){const o=t.position.copy(),r=e.event,l=r.deltaMode;let a=r.deltaX,h=r.deltaY,c="pixel";if((a!==0||h!==0)&&!e.shift){switch(l){case 0:c="pixel";break;case 1:c="line";break;case 2:c="page";break}if(a!==0&&t.allowHorizontalScroll){const f=t.scrollHorizontalLineChange;a=a*(f/16),t.scroll(c,a>0?"right":"left",Math.abs(a))}if(h!==0&&t.allowVerticalScroll){const f=t.scrollVerticalLineChange;h=h*(f/16),t.scroll(c,h>0?"down":"up",Math.abs(h))}}else!e.shift&&t.allowVerticalScroll?(i=i*3*t.scrollVerticalLineChange,t.scroll(c,i>0?"up":"down",Math.abs(i))):e.shift&&t.allowHorizontalScroll&&(i=i*3*t.scrollHorizontalLineChange,t.scroll(c,i>0?"left":"right",Math.abs(i)));this.doWheelChange(t,o,e)}}doWheelChange(t,e,i){(!t.position.equals(e)||i.event.wheelDeltaX!==0)&&(i.bubbles=!1)}standardWaitAfter(t,e){e===void 0&&(e=this.diagram.lastInput),this.cancelWaitAfter();const i=this,s=e.clone(this.nA);this.Fm=U.dn(()=>i.doWaitAfter(s),t)}cancelWaitAfter(){this.Fm!==-1&&U.yc(this.Fm),this.Fm=-1}doWaitAfter(t){}findToolHandleAt(t,e){const s=this.diagram.findObjectAt(t,n=>{for(;n!==null&&!(n.panel instanceof Adornment);)n=n.panel;return n});return s===null?null:s.part.category===e?s:null}isBeyondDragSize(t,e){const i=this.diagram;t===void 0&&(t=i.firstInput.viewPoint),e===void 0&&(e=i.lastInput.viewPoint);const s=i.toolManager.dragSize;let n=s.width,o=s.height;return i.firstInput.isTouchEvent&&(n+=6,o+=6),Math.abs(e.x-t.x)>n||Math.abs(e.y-t.y)>o}get name(){return this.Pt}set name(t){U.s(t,"string",Tool,"name"),this.Pt=t}get isEnabled(){return this.Be}set isEnabled(t){U.s(t,"boolean",Tool,"isEnabled"),this.Be=t}get isActive(){return this.KP}set isActive(t){U.s(t,"boolean",Tool,"isActive"),this.KP=t}get transactionResult(){return this.HP}set transactionResult(t){t!==null&&U.s(t,"string",Tool,"transactionResult"),this.HP=t}}var WheelMode=(w=>(w[w.Scroll=1]="Scroll",w[w.Zoom=2]="Zoom",w[w.None=3]="None",w))(WheelMode||{}),GestureMode=(w=>(w[w.Zoom=1]="Zoom",w[w.Cancel=2]="Cancel",w[w.None=3]="None",w))(GestureMode||{});class ToolManager extends Tool{lA;aA;hA;WP;JP;$P;ZP;QP;_P;tS;Om;Za;constructor(t){super(),this.name="ToolManager",this.lA=new List,this.aA=new List,this.hA=new List,this.WP=850,this.JP=850,this.$P=new Size(2,2).kt(),this.ZP=5e3,this.QP=1,this._P=1,this.tS=null,this.Om=null,this.Za=-1,t&&Object.assign(this,t)}static WheelScroll=1;static WheelZoom=2;static WheelNone=3;static GestureZoom=1;static GestureCancel=2;static GestureNone=3;get mouseWheelBehavior(){return this.QP}set mouseWheelBehavior(t){this.QP=t}get gestureBehavior(){return this._P}set gestureBehavior(t){this._P=t}initializeStandardTools(){}updateAdornments(t){const e=this.currentToolTip;if(e instanceof Adornment&&this.Om===t){const i=e.adornedObject;(t!==null?i!==null&&i.part===t:i===null)?this.showToolTip(e,i):this.hideToolTip()}}doMouseDown(){const t=this.diagram,e=t.lastInput;if(e.isTouchEvent&&this.gestureBehavior===2&&(e.bubbles=!1),e.isMultiTouch){if(this.cancelWaitAfter(),this.gestureBehavior===3){e.bubbles=!0;return}if(this.gestureBehavior===2)return;if(t.currentTool.canStartMultiTouch()){t.currentTool.standardPinchZoomStart();return}}const i=t.undoManager,s=this.mouseDownTools.length;for(let n=0;n<s;n++){const o=this.mouseDownTools.elt(n);if(o.diagram=this.diagram,o.canStart()){t.doFocus(),t.currentTool=o,t.currentTool===o&&(o.isActive||o.doActivate(),o.doMouseDown());return}}t.lastInput.button===1&&(this.mouseWheelBehavior===1?this.mouseWheelBehavior=2:this.mouseWheelBehavior===2&&(this.mouseWheelBehavior=1)),this.doActivate(),this.standardWaitAfter(this.holdDelay,e)}doMouseMove(){const t=this.diagram,e=t.lastInput;if(e.isMultiTouch){if(this.gestureBehavior===3){e.bubbles=!0;return}if(this.gestureBehavior===2)return;if(t.currentTool.canStartMultiTouch()){t.currentTool.standardPinchZoomMove();return}}if(this.isActive){const s=this.mouseMoveTools.length;for(let n=0;n<s;n++){const o=this.mouseMoveTools.elt(n);if(o.diagram=this.diagram,o.canStart()){t.doFocus(),t.currentTool=o,t.currentTool===o&&(o.isActive||o.doActivate(),o.doMouseMove());return}}}this.cA(t);const i=e.event;i!==null&&(i.type==="pointermove"||!i.cancelable)&&(e.bubbles=!0)}cA(t){this.standardMouseOver(),this.isBeyondDragSize()&&this.standardWaitAfter(this.isActive?this.holdDelay:this.hoverDelay,t.lastInput)}rA(t,e){const i=this.currentToolTip;i!==null&&(e!==null&&i instanceof Adornment&&(e===i||e.isContainedBy(i))||this.hideToolTip())}doWaitAfter(t){const e=this.diagram;if(!e.lR())return;const i=e.lastInput;if(e.lastInput=t,this.doMouseHover(),this.isActive||this.doToolTip(),t.isTouchEvent&&!e.lastInput.handled){const s=t.copy();s.button=2,e.lastInput=s,e.Sx=!0,e.doMouseUp()}e.lastInput=i}doMouseHover(){const t=this.diagram,e=t.lastInput;e.targetObject===null&&(e.targetObject=t.findObjectAt(e.documentPoint,null,null));let i=e.targetObject;if(i!==null)for(e.handled=!1;i!==null;){const s=this.isActive?i.mouseHold:i.mouseHover;if(s!==null&&(s(e,i),e.handled))break;i=i.panel}else{const s=this.isActive?t.mouseHold:t.mouseHover;s!==null&&s(e)}}doToolTip(){const t=this.diagram,e=t.lastInput;e.targetObject===null&&(e.targetObject=t.findObjectAt(e.documentPoint,null,null));let i=e.targetObject;if(i!==null){const s=this.currentToolTip;if(s instanceof Adornment&&(i===s||i.isContainedBy(s)))return;for(;i!==null;){const n=i.toolTip;if(n!==null){this.showToolTip(n,i);return}i=i.panel}this.hideToolTip()}else{const s=t.toolTip;s!==null?this.showToolTip(s,null):this.hideToolTip()}}showToolTip(t,e){e!==null&&U.se(e,GraphObject,ToolManager,"showToolTip:obj");const i=this.diagram;if(t!==this.currentToolTip&&this.hideToolTip(),t instanceof Adornment){t.layerName="Tool",t.selectable=!1,t.scale=1/i.scale,t.category="ToolTip",t.hasPlaceholder()&&(t.placeholder.scale=i.scale);const s=t.diagram;s!==null&&s!==i&&s.remove(t),i.add(t),e!==null?t.adornedObject=e:t.data=i.model,t.ensureBounds(),this.positionToolTip(t,e)}else t instanceof HTMLInfo&&t!==this.currentToolTip&&t.show!==null&&t.show(e,i,this);this.currentToolTip=t,this.extendToolTip(this.toolTipDuration)}positionToolTip(t,e){if(t.hasPlaceholder())return;const i=t,s=this.diagram,n=s.lastInput.documentPoint.copy(),o=i.measuredBounds,r=s.viewportBounds;s.lastInput.isTouchEvent&&(n.x-=o.width),n.x+o.width>r.right&&(n.x-=o.width+5/s.scale),n.x<r.x&&(n.x=r.x),n.y+20/s.scale+o.height>r.bottom?n.y-=o.height+5/s.scale:n.y+=20/s.scale,n.y<r.y&&(n.y=r.y),i.position=n}extendToolTip(t){t===void 0&&(t=3e3),this.currentToolTip!==null&&(this.Za!==-1&&(U.yc(this.Za),this.Za=-1),t>0&&t!==1/0&&(this.Za=U.dn(()=>this.hideToolTip(),t)))}hideToolTip(){this.Za!==-1&&(U.yc(this.Za),this.Za=-1);const t=this.diagram,e=this.currentToolTip;e!==null&&(e instanceof Adornment?(t.remove(e),this.Om!==null&&this.Om.removeAdornment(e.category),e.data=null,e.adornedObject=null):e instanceof HTMLInfo&&e.hide!==null&&e.hide(t,this),this.currentToolTip=null)}get currentToolTip(){return this.tS}set currentToolTip(t){this.tS=t,this.Om=t!==null&&t instanceof Adornment?t.adornedPart:null}doMouseUp(){this.cancelWaitAfter();const t=this.diagram;if(this.isActive){const e=this.mouseUpTools.length;for(let i=0;i<e;i++){const s=this.mouseUpTools.elt(i);if(s.diagram=this.diagram,s.canStart()){t.doFocus(),t.currentTool=s,t.currentTool===s&&(s.isActive||s.doActivate(),s.doMouseUp());return}}}t.doFocus(),this.doDeactivate()}doMouseWheel(){this.standardMouseWheel()}doKeyDown(){const t=this.diagram;t.commandHandler!==null&&t.commandHandler.doKeyDown()}doKeyUp(){const t=this.diagram;t.commandHandler!==null&&t.commandHandler.doKeyUp()}findTool(t){U.s(t,"string",ToolManager,"findTool:name");let e=this.mouseDownTools.length;for(let i=0;i<e;i++){const s=this.mouseDownTools.elt(i);if(s.name===t)return s}e=this.mouseMoveTools.length;for(let i=0;i<e;i++){const s=this.mouseMoveTools.elt(i);if(s.name===t)return s}e=this.mouseUpTools.length;for(let i=0;i<e;i++){const s=this.mouseUpTools.elt(i);if(s.name===t)return s}return null}replaceTool(t,e){U.s(t,"string",ToolManager,"replaceTool:name"),e!==null&&(e.diagram=this.diagram);let i=this.mouseDownTools.length;for(let s=0;s<i;s++){const n=this.mouseDownTools.elt(s);if(n.name===t)return e!==null?this.mouseDownTools.setElt(s,e):this.mouseDownTools.removeAt(s),n}i=this.mouseMoveTools.length;for(let s=0;s<i;s++){const n=this.mouseMoveTools.elt(s);if(n.name===t)return e!==null?this.mouseMoveTools.setElt(s,e):this.mouseMoveTools.removeAt(s),n}i=this.mouseUpTools.length;for(let s=0;s<i;s++){const n=this.mouseUpTools.elt(s);if(n.name===t)return e!==null?this.mouseUpTools.setElt(s,e):this.mouseUpTools.removeAt(s),n}return null}replaceStandardTool(t,e,i){this.Jt(t,e,i)}Jt(t,e,i){U.s(t,"string",ToolManager,"replaceStandardTool:name"),e!==null&&(e.name=t,e.diagram=this.diagram),this.findTool(t)?this.replaceTool(t,e):e!==null&&i.add(e)}get mouseDownTools(){return this.lA}get mouseMoveTools(){return this.aA}get mouseUpTools(){return this.hA}get hoverDelay(){return this.WP}set hoverDelay(t){U.s(t,"number",ToolManager,"hoverDelay"),this.WP=t}get holdDelay(){return this.JP}set holdDelay(t){U.s(t,"number",ToolManager,"holdDelay"),this.JP=t}get dragSize(){return this.$P}set dragSize(t){this.$P=t.N()}get toolTipDuration(){return this.ZP}set toolTipDuration(t){U.s(t,"number",ToolManager,"toolTipDuration"),this.ZP=t}get actionTool(){return this.findTool("Action")}set actionTool(t){this.Jt("Action",t,this.mouseDownTools)}get relinkingTool(){return this.findTool("Relinking")}set relinkingTool(t){this.Jt("Relinking",t,this.mouseDownTools)}get linkReshapingTool(){return this.findTool("LinkReshaping")}set linkReshapingTool(t){this.Jt("LinkReshaping",t,this.mouseDownTools)}get resizingTool(){return this.findTool("Resizing")}set resizingTool(t){this.Jt("Resizing",t,this.mouseDownTools)}get rotatingTool(){return this.findTool("Rotating")}set rotatingTool(t){this.Jt("Rotating",t,this.mouseDownTools)}get linkingTool(){return this.findTool("Linking")}set linkingTool(t){this.Jt("Linking",t,this.mouseMoveTools)}get draggingTool(){return this.findTool("Dragging")}set draggingTool(t){this.Jt("Dragging",t,this.mouseMoveTools)}get dragSelectingTool(){return this.findTool("DragSelecting")}set dragSelectingTool(t){this.Jt("DragSelecting",t,this.mouseMoveTools)}get panningTool(){return this.findTool("Panning")}set panningTool(t){this.Jt("Panning",t,this.mouseMoveTools)}get contextMenuTool(){return this.findTool("ContextMenu")}set contextMenuTool(t){this.Jt("ContextMenu",t,this.mouseUpTools)}get textEditingTool(){return this.findTool("TextEditing")}set textEditingTool(t){this.Jt("TextEditing",t,this.mouseUpTools)}get clickCreatingTool(){return this.findTool("ClickCreating")}set clickCreatingTool(t){this.Jt("ClickCreating",t,this.mouseUpTools)}get clickSelectingTool(){return this.findTool("ClickSelecting")}set clickSelectingTool(t){this.Jt("ClickSelecting",t,this.mouseUpTools)}}class DraggingTool extends Tool{eS;iS;xn;sS;nS;oS;rS;vc;Im;lS;Qa;kr;fA;aS;Fu;Ru;hS;cS;fS;uS;static Mx=new List;static le=null;static _a=null;constructor(t){super(),this.name="Dragging",this.eS=!0,this.uS=!0,this.iS=!0,this.xn=null,this.sS=null,this.nS=null,this.oS=null,this.rS=!1,this.Fu=!1,this.vc=new Point(NaN,NaN),this.Im=new Point,this.lS=!0,this.Qa=100,this.kr=[],this.fA=new GSet().b(),this.aS=new DraggingOptions,this.Ru=null,this.hS="copy",this.cS="",this.fS="no-drop",t&&Object.assign(this,t)}get isCopyEnabled(){return this.eS}set isCopyEnabled(t){U.s(t,"boolean",DraggingTool,"isCopyEnabled"),this.eS=t}get copiesEffectiveCollection(){return this.iS}set copiesEffectiveCollection(t){U.s(t,"boolean",DraggingTool,"copiesEffectiveCollection"),this.iS=t}get dragOptions(){return this.aS}set dragOptions(t){this.aS=t}get isGridSnapEnabled(){return this.dragOptions.isGridSnapEnabled}set isGridSnapEnabled(t){U.s(t,"boolean",DraggingTool,"isGridSnapEnabled"),this.dragOptions.isGridSnapEnabled=t}get isComplexRoutingRealtime(){return this.lS}set isComplexRoutingRealtime(t){this.lS=t;const e=this.diagram.findRouter("AvoidsLinks");e!==null&&(e.isRealtime=t)}get isGridSnapRealtime(){return this.dragOptions.isGridSnapRealtime}set isGridSnapRealtime(t){U.s(t,"boolean",DraggingTool,"isGridSnapRealtime"),this.dragOptions.isGridSnapRealtime=t}get gridSnapCellSize(){return this.dragOptions.gridSnapCellSize}set gridSnapCellSize(t){this.dragOptions.gridSnapCellSize.equals(t)||(t=t.N(),this.dragOptions.gridSnapCellSize=t)}get gridSnapCellSpot(){return this.dragOptions.gridSnapCellSpot}set gridSnapCellSpot(t){this.dragOptions.gridSnapCellSpot.equals(t)||(t=t.N(),this.dragOptions.gridSnapCellSpot=t)}get gridSnapOrigin(){return this.dragOptions.gridSnapOrigin}set gridSnapOrigin(t){this.dragOptions.gridSnapOrigin.equals(t)||(t=t.N(),this.dragOptions.gridSnapOrigin=t)}get dragsLink(){return this.dragOptions.dragsLink}set dragsLink(t){U.s(t,"boolean",DraggingTool,"dragsLink"),this.dragOptions.dragsLink=t}get dragsTree(){return this.dragOptions.dragsTree}set dragsTree(t){U.s(t,"boolean",DraggingTool,"dragsTree"),this.dragOptions.dragsTree=t}get copyCursor(){return this.hS}set copyCursor(t){this.hS=t}get moveCursor(){return this.cS}set moveCursor(t){this.cS=t}get nodropCursor(){return this.fS}set nodropCursor(t){this.fS=t}get currentPart(){return this.sS}set currentPart(t){t!==null&&U.se(t,Part,DraggingTool,"currentPart"),this.sS=t}get copiedParts(){return this.oS}set copiedParts(t){this.oS=t}get draggedParts(){return this.nS}set draggedParts(t){this.nS=t}get draggingParts(){return this.copiedParts!==null?this.copiedParts.toKeySet():this.draggedParts!==null?this.draggedParts.toKeySet():this.fA}get draggedLink(){return this.diagram.draggedLink}set draggedLink(t){t!==null&&U.se(t,Link,DraggingTool,"draggedLink"),this.diagram.draggedLink=t}get isDragOutStarted(){return this.rS}set isDragOutStarted(t){this.rS=t}get startPoint(){return this.Im}set startPoint(t){this.Im.equals(t)||this.Im.h(t)}get delay(){return this.Qa}set delay(t){U.s(t,"number",DraggingTool,"delay"),this.Qa=t}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;if(t===null||t.isReadOnly&&!t.allowDragOut||!t.allowMove&&!t.allowCopy&&!t.allowDragOut||!t.allowSelect)return!1;const e=t.lastInput;return!e.left||t.currentTool!==this&&(!this.isBeyondDragSize()||e.isTouchEvent&&e.timestamp-t.firstInput.timestamp<this.Qa)?!1:this.findDraggablePart()!==null}findDraggablePart(){const t=this.diagram;let e=t.findPartAt(t.firstInput.documentPoint,!1);if(e===null)return null;for(;e!==null&&!e.canSelect();)e=e.containingGroup;return e!==null&&(e.canMove()||e.canCopy())?e:null}standardMouseSelect(){const t=this.diagram;if(!t.allowSelect)return;let e=t.findPartAt(t.firstInput.documentPoint,!1);if(e!==null){for(;e!==null&&!e.canSelect();)e=e.containingGroup;if(this.currentPart=e,this.currentPart!==null&&!this.currentPart.isSelected){t.T("ChangingSelection",t.selection);const i=t.lastInput;!(U.ur?i.meta:i.control)&&!i.shift&&t.clearSelection(!0),this.currentPart.isSelected=!0,t.T("ChangedSelection",t.selection)}}}doActivate(){const t=this.diagram;this.Ru=null,this.currentPart===null&&this.standardMouseSelect();const e=this.currentPart;if(e===null||!e.canMove()&&!e.canCopy())return;t.cacheGroupExternalLinks(!0),DraggingTool.le=null,this.isActive=!0,this.vc.set(t.position),this.dS(t.selection),this.kr.length=0,t.animationManager.stopAnimation();const i=this.computeEffectiveCollection(t.selection,this.dragOptions);this.draggedParts=i,this.uS=!!this.diagram.layout.isRealtime,this.diagram.layout.isRealtime=!1,t.Ou=!0,t.getRenderingHint("temporaryPixelRatio")===!0&&t.avgSpf>30&&t.Nx(),t.uA(this.draggedParts),t.Iu=!0,this.startTransaction("Drag"),this.startPoint=t.firstInput.documentPoint,t.isMouseCaptured=!0,t.allowDragOut&&this.aR()}dS(t){if(!this.dragsLink)return;const e=this.diagram,i=e.model.Em(),s=t.first();i&&t.count===1&&s instanceof Link&&this.mayDragLink(s)?(this.draggedLink=s,this.draggedLink.canRelinkFrom()&&this.draggedLink.canRelinkTo()&&this.draggedLink.clearAdornments(),this.xn=e.toolManager.findTool("Relinking"),this.xn===null&&(this.xn=new RelinkingTool,this.xn.diagram=e),this.xn.originalLink=this.draggedLink):(this.draggedLink=null,this.xn=null)}mayDragLink(t){const e=this.diagram;return e!==null&&e.allowRelink}computeEffectiveCollection(t,e){return this.diagram.commandHandler.computeEffectiveCollection(t,e)}Ws(t){return t===void 0?new DraggingInfo(Point.gn):this.isGridSnapEnabled?new DraggingInfo(new Point(Math.round(t.x*1e3)/1e3,Math.round(t.y*1e3)/1e3)):new DraggingInfo(t.copy())}doDeactivate(){this.isActive=!1;const t=this.diagram;this.diagram.layout.isRealtime=this.uS,t.Iu=!1,t.Fl=!0,t.cacheGroupExternalLinks(!1),t.stopAutoScroll(),this.gS(),t.mS(this.draggedParts),this.Ru=null,this.currentPart=null,this.draggedParts=null,this.isDragOutStarted=!1,this.Fu=!1,DraggingTool.hR(),this.dA(),this.vc.e(NaN,NaN),DraggingTool._a!==null&&(DraggingTool._a.currentCursor=""),DraggingTool._a=null,DraggingTool.le=null,this.Rl(),t.isMouseCaptured=!1,t.currentCursor="",t.Ou=!1,this.stopTransaction(),t.pS(!0)}stopTransaction(){const t=this.diagram,e=super.stopTransaction();return e&&t.undoManager.transactionToUndo!==null&&t.undoManager.transactionToUndo.optimize(),e}gS(){const t=this.diagram,e=t.skipsUndoManager;t.skipsUndoManager=!0;const i=t.lastInput;this.gA(i,null),t.skipsUndoManager=e,this.kr.length=0}mA(){this.Rl(),this.yS();const t=this.diagram;this.vc.isReal()&&(t.position=this.vc),t.stopAutoScroll()}doCancel(){this.Rl(),this.yS();const t=this.diagram;this.vc.isReal()&&(t.position=this.vc),this.stopTool()}doKeyDown(){const t=this.diagram;if(!this.isActive)return;const e=t.lastInput,i=t.previousInput;e.code==="Escape"?this.doCancel():(e.code!==i.code||e.modifiers!==i.modifiers)&&this.doMouseMove()}doKeyUp(){this.isActive&&this.doMouseMove()}cR(t,e){let i=1/0,s=1/0,n=-1/0,o=-1/0;const r=t.iterator;for(;r.next();){const l=r.value;if(!l.isVisible())continue;const a=l.location,h=a.x,c=a.y;isNaN(h)||isNaN(c)||(h<i&&(i=h),c<s&&(s=c),h>n&&(n=h),c>o&&(o=c))}return i===1/0?e.e(0,0,0,0):e.e(i,s,n-i,o-s),e}wS(t){if(this.copiedParts!==null)return;const e=this.diagram;if(t&&(e.isReadOnly||e.isModelReadOnly)||this.draggedParts===null)return;const i=e.undoManager;i.isEnabled&&i.isInTransaction?i.currentTransaction!==null&&i.currentTransaction.changes.count>0&&(e.undoManager.rollbackTransaction(),e.startTransaction("Drag")):this.yS(),e.skipsUndoManager=!t,e.partManager.addsToTemporaryLayer=!t,this.startPoint=e.firstInput.documentPoint;const s=this.copiesEffectiveCollection?this.draggedParts.toKeySet():e.selection,n=e.copyParts(s,e,!0),o=new GMap,r=this.draggedParts.iterator;for(;r.next();){const a=r.key;if(a.Di()&&a.canCopy()){const h=n.get(a);if(h===null)continue;h.location=a.location,h.ensureBounds(),o.set(h,this.Ws(h.location))}}const l=n.iterator;for(;l.next();){const a=l.value;a instanceof Link&&a.canCopy()&&o.set(a,this.Ws())}if(this.copiedParts=o,this.dS(o.toKeySet()),this.draggedLink!==null){const a=this.draggedLink,h=a.routeBounds;a.Pr(this.startPoint.x-(h.x+h.width/2),this.startPoint.y-(h.y+h.height/2))}this.doUpdateCursor(null)}Rl(){const t=this.diagram;if(this.copiedParts!==null){if(t.removeParts(this.copiedParts.toKeySet(),!1),this.copiedParts=null,this.draggedParts!==null){const e=this.draggedParts.iterator;for(;e.next();)if(e.key instanceof Link){const s=e.value;s.point=new Point(0,0)}}this.doUpdateCursor(null)}t.skipsUndoManager=!1,t.partManager.addsToTemporaryLayer=!1,this.startPoint=t.firstInput.documentPoint}dA(){this.draggedLink!==null&&(this.dragsLink&&this.xn!==null&&(this.xn.stopDraggingMouseMove(),this.xn.originalLink=null),this.draggedLink=null,this.xn=null)}Fc(t,e){if(t===null)return;const i=this.diagram,s=this.startPoint,n=Point.l();n.h(i.lastInput.documentPoint),this.moveParts(t,n.subtract(s),e),Point.i(n),i.getRenderingHint("temporaryPixelRatio")===!0&&i.Ol===null&&i.avgSpf>30&&(i.Nx(),i.Eu())}moveParts(t,e,i){i===void 0&&(i=!1);const s=this.diagram;s!==null&&s.Cx(t,e,this.dragOptions,i)}yS(){if(this.draggedParts===null)return;const t=this.diagram;let e=this.draggedParts.iterator;for(;e.next();){const i=e.key;i.Di()&&(i.location=e.value.point)}for(e=this.draggedParts.iterator;e.next();){const i=e.key;if(i instanceof Link&&i.suspendsRouting){const s=e.value.point;this.draggedParts.set(i,this.Ws()),i.Pr(-s.x,-s.y)}}t.maybeUpdate()}fR(t){if(t===null)return!0;const e=t.part;return!!(e===null||e instanceof Adornment||e.layer?.isTemporary||this.draggedParts&&this.draggedParts.has(e)||this.copiedParts&&this.copiedParts.has(e))}xS(t){const e=this.diagram;this.dragsLink&&(this.draggedLink!==null&&(this.draggedLink.fromNode=null,this.draggedLink.toNode=null),this.pA(!1));const i=this.findDragOverObject(t),s=e.lastInput;s.targetObject=i,this.doUpdateCursor(i);const n=e.skipsUndoManager;let o=!1;try{if(e.skipsUndoManager=!0,o=this.gA(s,i),!this.isActive&&DraggingTool.le===null)return;const r=i!==null?i.part:null;if(r===null||e.handlesDragDropForTopLevelParts&&r.isTopLevel&&!(r instanceof Group)){const l=e.mouseDragOver;l!==null&&(l(s),o=!0)}if(!this.isActive&&DraggingTool.le===null||(this.doDragOver(t,i),!this.isActive&&DraggingTool.le===null))return}finally{e.skipsUndoManager=n,o&&e.maybeUpdate()}this.Ru=i,!e.isReadOnly&&(e.allowMove||e.allowCopy)&&(e.allowHorizontalScroll||e.allowVerticalScroll)&&e.doAutoScroll(s.viewPoint)}findDragOverObject(t){return this.diagram.bS(t,null,e=>!this.fR(e))}doUpdateCursor(t){const e=this.diagram;(t===null||this.Ru!==t)&&(!this.diagram.currentTool.isActive||this.mayCopy()?e.currentCursor=this.copyCursor:this.mayMove()?e.currentCursor=this.moveCursor:this.mayDragOut()&&(e.currentCursor=this.nodropCursor))}gA(t,e){let i=!1,s=this.kr.length;const n=s>0?this.kr[0]:null;if(e===n)return!1;t.handled=!1;for(let r=0;r<s;r++){const l=this.kr[r],a=l.mouseDragLeave;if(a!==null&&(a(t,l,e),i=!0,t.handled))break}if(this.kr.length=0,!this.isActive&&DraggingTool.le===null||e===null)return i;t.handled=!1;let o=e;for(;o!==null;)this.kr.push(o),o=this.yA(o);s=this.kr.length;for(let r=0;r<s;r++){const l=this.kr[r],a=l.mouseDragEnter;if(a!==null&&(a(t,l,n),i=!0,t.handled))break}return i}FU(t,e){return t===null?!1:!!(t===e||t.isContainedBy(e)||e instanceof Group&&!(t instanceof Group)&&e.handlesDragDropForMembers&&t.part?.isMemberOf(e))}yA(t){const e=t.panel;if(e!==null)return e;if(t instanceof Part&&!(t instanceof Group)){const i=t.containingGroup;if(i!==null&&i.handlesDragDropForMembers)return i}return null}wA(t,e){const i=this.diagram,s=this.xn;if(s===null)return null;const n=s.portGravity,o=i.findObjectsNear(t,n,h=>s.findValidLinkablePort(h,e)),r=Point.l();let l=1/0,a=null;for(const h=o.iterator;h.next();){const c=h.value;if(c.part===null)continue;const u=c.getDocumentPoint(Spot.Center,r),d=t.distanceSquaredPoint(u);d<l&&(a=c,l=d)}return Point.i(r),a}pA(t){const e=this.draggedLink;if(e!==null){if(e.pointsCount<2)return;const i=this.diagram;if(i.isReadOnly)return;const s=this.xn;if(s===null)return;let n=null,o=null;e.fromNode===null&&(n=this.wA(e.getPoint(0),!1),n!==null&&(o=n.part));let r=null,l=null;e.toNode===null&&(r=this.wA(e.getPoint(e.pointsCount-1),!0),r!==null&&(l=r.part)),s.isValidLink(o,n,l,r)?t?(e.defaultFromPoint=e.getPoint(0),e.defaultToPoint=e.getPoint(e.pointsCount-1),e.suspendsRouting=!1,e.fromNode=o,n!==null&&(e.fromPortId=n.portId),e.toNode=l,r!==null&&(e.toPortId=r.portId),e.fromPort!==i.kS&&i.T("LinkRelinked",e,i.kS),e.toPort!==i.PS&&i.T("LinkRelinked",e,i.PS)):s.doDraggingMouseMove(o,n,l,r):s.doDraggingMouseMove(null,null,null,null)}}doDragOver(t,e){}xA(t){const e=this.diagram;this.dragsLink&&this.pA(!0),this.gS();const i=this.findDragOverObject(t),s=e.lastInput;if(s.targetObject=i,i!==null){s.handled=!1;let l=i;for(;l!==null;){const a=l.mouseDrop;if(a!==null&&(a(s,l),s.handled))break;this.uR(s,l),l=this.yA(l)}}else{const l=e.mouseDrop;l!==null&&l(s)}if(!this.isActive&&DraggingTool.le===null)return;const n=this.copiedParts||this.draggedParts;if(n!==null){const l=n.iterator;for(;l.next();){const a=l.key;a instanceof Node&&a.linksConnected.each(h=>h.suspendsRouting=!1)}}if(this.doDropOnto(t,i),!this.isActive&&DraggingTool.le===null)return;const o=Rect.l(),r=e.selection.iterator;for(;r.next();){const l=r.value;l instanceof Node&&this.dR(e,l,o)}Rect.i(o)}uR(t,e){const i=this.diagram,s=e.part;if(i.handlesDragDropForTopLevelParts&&s!==null&&s.isTopLevel&&!(s instanceof Group)){const n=i.mouseDrop;n!==null&&n(t)}}dR(t,e,i){if(!e.canAvoid())return;let s=!1;i=e.getAvoidableRect(i),t.viewportBounds.containsRect(i)&&(s=!0);const n=this.copiedParts||this.draggedParts;if(n===null)return;const o=t.SS(i,l=>l.part,l=>l instanceof Link,!0,l=>l instanceof Link,s);if(o.count===0)return;const r=o.iterator;for(;r.next();){const l=r.value;n.has(l)&&n.has(e)||!l.isMemberOf(e)&&l.isAvoiding&&l.$t()}}doDropOnto(t,e){}doMouseMove(){if(!this.isActive)return;const t=this.diagram,e=t.lastInput;if(this.simulatedMouseMove(e.event,e.documentPoint,e.targetDiagram))return;this.currentPart!==null&&this.draggedParts!==null&&(this.mayCopy()?(this.wS(!1),this.Fc(this.copiedParts,!1)):this.mayMove()?(this.Rl(),this.Fc(this.draggedParts,!0)):this.mayDragOut()?(this.wS(!1),this.Fc(this.copiedParts,!1)):this.Rl(),this.xS(t.lastInput.documentPoint))}doMouseUp(){if(!this.isActive)return;const t=this.diagram,e=t.lastInput;if(this.simulatedMouseUp(e.event,e.documentPoint,e.targetDiagram))return;let i=!1;const s=this.mayCopy();if(s&&this.copiedParts!==null?(this.Rl(),this.wS(!0),this.Fc(this.copiedParts,!1),this.copiedParts!==null&&(t.T("ChangingSelection",t.selection),t.clearSelection(!0),this.copiedParts.iteratorKeys.each(n=>{n.isSelected=!0}))):(i=!0,this.Rl(),this.mayMove()&&(this.Fc(this.draggedParts,!0),this.xS(t.lastInput.documentPoint))),this.Fu=!0,this.xA(t.lastInput.documentPoint),this.isActive){const n=s&&this.copiedParts,o=n?this.copiedParts?.toKeySet():this.draggedParts?this.draggedParts.toKeySet():null;this.copiedParts=null,i&&this.gR(),t.invalidateDocumentBounds(),t.mS(this.draggedParts),this.transactionResult=n?"Copy":"Move",t.T(n?"SelectionCopied":"SelectionMoved",o)}this.stopTool(),s&&t.T("ChangedSelection",t.selection)}simulatedMouseMove(t,e,i){if(DraggingTool.le===null)return!1;const s=DraggingTool.le.diagram;i instanceof Diagram||(i=null);const n=DraggingTool._a;if(i!==n){if(n!==null&&n!==s){n.stopAutoScroll(),DraggingTool.le.isDragOutStarted=!1;const r=n.toolManager.findTool("Dragging");r!==null&&r.doSimulatedDragLeave()}if(DraggingTool._a=i,i!==null&&i!==s){DraggingTool.le.mA();const r=i.toolManager.findTool("Dragging");r!==null&&(r.bA(),r.doSimulatedDragEnter())}this.doUpdateCursor(null)}if(i===null||i===s||!i.allowDrop||i.isReadOnly||!i.allowInsert)return!1;const o=i.toolManager.findTool("Dragging");if(o!==null){let r=e;t!==null&&(t.targetTouches!==void 0&&(t.targetTouches.length>0?t=t.targetTouches[0]:t.changedTouches.length>0&&(t=t.changedTouches[0])),r=i.getMouse(t)),i.lastInput.documentPoint=r,i.lastInput.viewPoint=i.transformDocToView(r),i.lastInput.down=!1,i.lastInput.up=!1,o.doSimulatedDragOver()}return!0}simulatedMouseUp(t,e,i){if(DraggingTool.le===null)return!1;const s=DraggingTool._a,n=DraggingTool.le.diagram;if(i===null)return DraggingTool.le.doCancel(),!0;if(i!==s){if(s!==null){const r=s.toolManager.findTool("Dragging");if(s!==null&&s!==n&&r!==null)return s.stopAutoScroll(),DraggingTool.le.isDragOutStarted=!1,r.doSimulatedDragLeave(),!1}DraggingTool._a=i;const o=i.toolManager.findTool("Dragging");o!==null&&(DraggingTool.le.mA(),o.bA(),o.doSimulatedDragEnter())}if(i!==this.diagram){let o=e;t!==null?(t.targetTouches!==void 0&&(t.targetTouches.length>0?t=t.targetTouches[0]:t.changedTouches.length>0&&(t=t.changedTouches[0])),o=i.getMouse(t)):o===null&&(o=new Point),i.lastInput.documentPoint=o,i.lastInput.viewPoint=i.transformDocToView(o),i.lastInput.down=!1,i.lastInput.up=!0;const r=i.toolManager.findTool("Dragging");r!==null&&r.doSimulatedDrop();const l=DraggingTool.le;if(l!==null){const a=l.mayCopy();l.transactionResult=a?"Copy":"Move",l.stopTool()}return!0}return!1}gR(){if(this.draggedParts===null)return;const t=this.draggedParts.iterator;for(;t.next();){const e=t.key;if(e instanceof Node){const i=e.containingGroup;i!==null&&i.hasPlaceholder()&&!this.draggedParts.has(i)&&i.placeholder.c()}}}mayCopy(){if(!this.isCopyEnabled)return!1;const t=this.diagram;if(t.isReadOnly||t.isModelReadOnly||!t.allowInsert||!t.allowCopy||!(U.ur?t.lastInput.alt:t.lastInput.control))return!1;const e=t.selection.iterator;for(;e.next();)if(e.value.canCopy())return!0;return!!(this.draggedLink!==null&&this.dragsLink&&this.draggedLink.canCopy())}mayDragOut(){if(!this.isCopyEnabled)return!1;const t=this.diagram;if(!t.allowDragOut||!t.allowCopy||t.allowMove)return!1;const e=t.selection.iterator;for(;e.next();)if(e.value.canCopy())return!0;return!!(this.draggedLink!==null&&this.dragsLink&&this.draggedLink.canCopy())}mayMove(){const t=this.diagram;if(t.isReadOnly||!t.allowMove)return!1;const e=t.selection.iterator;for(;e.next();)if(e.value.canMove())return!0;return!!(this.draggedLink!==null&&this.dragsLink&&this.draggedLink.canMove())}bA(){DraggingTool.Mx.has(this)||DraggingTool.Mx.add(this)}static hR(){if(DraggingTool.Mx.count>0){const t=DraggingTool.Mx,e=t.length;for(let i=0;i<e;i++){const s=t.elt(i);s.dA(),s.Rl(),s.gS(),s.diagram.stopAutoScroll()}t.clear()}}mR(t,e,i){return!this.Fu&&this.draggedParts!==null&&!this.draggedParts.has(t)?(i.h(e),!0):!1}get draggingSource(){return DraggingTool.le}mayDragIn(){const t=this.diagram;if(!t.allowDrop||t.isReadOnly||t.isModelReadOnly||!t.allowInsert)return!1;const e=DraggingTool.le;return!(e===null||e.diagram.model.dataFormat!==t.model.dataFormat)}doSimulatedDragEnter(){if(!this.mayDragIn())return;const t=this.diagram;t.animationManager.stopAnimation(),t.Sr(),t.animationManager.stopAnimation();const e=DraggingTool.le;e!==null&&(this.diagram.Ou=!0,t.lastInput.event===null&&(t.lastInput.event=e.diagram.lastInput.event)),this.doUpdateCursor(null)}doSimulatedDragLeave(){const t=DraggingTool.le;t!==null&&t.doSimulatedDragOut(),this.diagram.Ou=!1,this.doCancel()}doSimulatedDragOver(){const t=this.diagram;t.animationManager.Uu=!0;const e=DraggingTool.le;if(e!==null&&e.draggedParts!==null){if(!this.mayDragIn())return;this.kA(e.draggedParts.toKeySet(),!1,t.firstInput),this.Fc(this.copiedParts,!1),this.xS(t.lastInput.documentPoint)}t.animationManager.Uu=!1}doSimulatedDrop(){const t=this.diagram,e=DraggingTool.le;if(e!==null){const i=e.diagram;if(e.Fu=!0,this.Rl(),e.draggedParts===null||!this.mayDragIn())return;t.animationManager.Uu=!0,t.T("ChangingSelection",t.selection),this.startTransaction("Drop"),this.kA(e.draggedParts.toKeySet(),!0,t.lastInput),this.Fc(this.copiedParts,!1);const s=new GSet;this.copiedParts!==null&&(t.clearSelection(!0),this.copiedParts.iteratorKeys.each(n=>{n.isSelected=!0,s.add(n)})),this.xA(t.lastInput.documentPoint),t.invalidateDocumentBounds(),this.copiedParts!==null&&(this.transactionResult="ExternalCopy"),this.copiedParts=null,t.doFocus(),t.Ou=!1,t.T("ExternalObjectsDropped",s,i),this.stopTransaction(),t.T("ChangedSelection",t.selection)}t.animationManager.Uu=!1}kA(t,e,i){if(this.copiedParts!==null)return;const s=this.diagram;if(s.isReadOnly||s.isModelReadOnly)return;s.skipsUndoManager=!e,s.partManager.addsToTemporaryLayer=!e,this.startPoint=i.documentPoint;const n=s.copyParts(t,s,!0),o=Rect.l();this.cR(t,o);const r=o.x+o.width/2,l=o.y+o.height/2;Rect.i(o);const a=this.Im,h=new GMap,c=Point.l(),f=t.iterator;for(;f.next();){const d=f.value;if(d instanceof Link&&d.canCopy()){const m=n.get(d);if(m===null)continue;m.points=d.points,m.Pr(a.x-r,a.y-l),m.suspendsRouting=!0,h.set(m,this.Ws())}}const u=t.iterator;for(;u.next();){const d=u.value;if(d.Di()&&d.canCopy()){const m=n.get(d);if(m===null)continue;const g=d.location;c.e(a.x-(r-g.x),a.y-(l-g.y)),m.location=c,m.ensureBounds(),h.set(m,this.Ws(c))}}if(Point.i(c),this.copiedParts=h,this.dS(h.toKeySet()),this.draggedLink!==null){const d=this.draggedLink,m=d.routeBounds;d.Pr(this.startPoint.x-(m.x+m.width/2),this.startPoint.y-(m.y+m.height/2))}this.doUpdateCursor(null)}aR(){this.isDragOutStarted=!0,this.Fu=!1,DraggingTool.le=this,DraggingTool._a=this.diagram,this.doSimulatedDragOut()}doSimulatedDragOut(){const t=this.diagram;!this.mayCopy()&&!this.mayMove()?t.currentCursor=this.nodropCursor:t.currentCursor="",this.Ru=null}computeMove(t,e,i,s){const n=this.diagram;return n!==null?n.computeMove(t,e,this.dragOptions,s):new Point}}ToolManager.prototype.doCancel=function(){DraggingTool.le!==null&&DraggingTool.le.doCancel(),Tool.prototype.doCancel.call(this)};class LinkingBaseTool extends Tool{MS;NS;Il;CS;LS;th;AS;eh;TS;DS;vS;FS;RS;OS;PA;IS;El;ES;constructor(){super(),this.MS=100,this.NS=!1,this.Il="pointer",this.CS=new Link({layerName:"Tool"}).add(new Shape({isPanelMain:!0,stroke:"blue"}).theme("stroke","tempLink"),new Shape({toArrow:"Standard",fill:"blue",stroke:"blue"}).theme("fill","tempLink").theme("stroke","tempLink")).It(),this.th=new Shape("Rectangle",{portId:"",fill:null,stroke:"magenta",strokeWidth:2,desiredSize:Size.AP}).theme("stroke","tempPort"),this.LS=new Node({selectable:!1,layerName:"Tool"}).add(this.th).It(),this.eh=new Shape("Rectangle",{portId:"",fill:null,stroke:"magenta",strokeWidth:2,desiredSize:Size.AP}).theme("stroke","tempPort"),this.AS=new Node({selectable:!1,layerName:"Tool"}).add(this.eh).It(),this.TS=null,this.DS=null,this.vS=null,this.FS=null,this.RS=null,this.OS=!0,this.PA=new GMap,this.IS=null,this.El=null,this.ES=null}doStop(){this.diagram.stopAutoScroll(),this.originalLink=null,this.originalFromNode=null,this.originalFromPort=null,this.originalToNode=null,this.originalToPort=null,this.validPortsCache.clear(),this.targetPort=null}get portGravity(){return this.MS}set portGravity(t){U.s(t,"number",LinkingBaseTool,"portGravity"),t>=0&&(this.MS=t)}get isUnconnectedLinkValid(){return this.NS}set isUnconnectedLinkValid(t){U.s(t,"boolean",LinkingBaseTool,"isUnconnectedLinkValid"),this.NS=t}get linkingCursor(){return this.Il}set linkingCursor(t){this.Il=t}get temporaryLink(){return this.CS}set temporaryLink(t){t.It(),this.CS=t}get temporaryFromNode(){return this.LS}set temporaryFromNode(t){t.It(),this.LS=t,t&&(this.th=t.port)}get temporaryFromPort(){return this.th}set temporaryFromPort(t){if(this.th!==null){const e=this.th.panel;if(e!==null){const i=e.D.indexOf(this.th);e.removeAt(i),e.insertAt(i,t)}}this.th=t}get temporaryToNode(){return this.AS}set temporaryToNode(t){t.It(),this.AS=t,t&&(this.eh=t.port)}get temporaryToPort(){return this.eh}set temporaryToPort(t){if(this.eh!==null){const e=this.eh.panel;if(e!==null){const i=e.D.indexOf(this.eh);e.removeAt(i),e.insertAt(i,t)}}this.eh=t}get originalLink(){return this.TS}set originalLink(t){t!==null&&U.se(t,Link,LinkingBaseTool,"originalLink"),this.TS=t}get originalFromNode(){return this.DS}set originalFromNode(t){t!==null&&U.se(t,Node,LinkingBaseTool,"originalFromNode"),this.DS=t}get originalFromPort(){return this.vS}set originalFromPort(t){t!==null&&U.se(t,GraphObject,LinkingBaseTool,"originalFromPort"),this.vS=t}get originalToNode(){return this.FS}set originalToNode(t){t!==null&&U.se(t,Node,LinkingBaseTool,"originalToNode"),this.FS=t}get originalToPort(){return this.RS}set originalToPort(t){t!==null&&U.se(t,GraphObject,LinkingBaseTool,"originalToPort"),this.RS=t}get isForwards(){return this.OS}set isForwards(t){this.OS=t}get validPortsCache(){return this.PA}get targetPort(){return this.IS}set targetPort(t){t!==null&&U.se(t,GraphObject,LinkingBaseTool,"targetPort"),this.IS=t}copyPortProperties(t,e,i,s,n){if(t===null||e===null||i===null||s===null)return;const o=e.getDocumentScale(),r=Size.l();r.width=e.naturalBounds.width*o,r.height=e.naturalBounds.height*o,s.desiredSize=r,Size.i(r),n?(s.toSpot=e.toSpot,s.toEndSegmentLength=e.toEndSegmentLength):(s.fromSpot=e.fromSpot,s.fromEndSegmentLength=e.fromEndSegmentLength),i.locationSpot=Spot.Center;const l=Point.l();i.location=e.getDocumentPoint(Spot.Center,l),Point.i(l),s.angle=e.getDocumentAngle(),this.portTargeted!==null&&this.portTargeted(t,e,i,s,n)}setNoTargetPortProperties(t,e,i){e!==null&&(e.desiredSize=Size.AP,e.fromSpot=Spot.None,e.toSpot=Spot.None),t!==null&&(t.location=this.diagram.lastInput.documentPoint),this.portTargeted!==null&&this.portTargeted(null,null,t,e,i)}doMouseDown(){this.isActive&&this.doMouseMove()}doMouseMove(){if(this.isActive){const t=this.diagram;if(this.targetPort=this.findTargetPort(this.isForwards),this.targetPort!==null&&this.targetPort.part instanceof Node){const e=this.targetPort.part;this.isForwards?this.copyPortProperties(e,this.targetPort,this.temporaryToNode,this.temporaryToPort,!0):this.copyPortProperties(e,this.targetPort,this.temporaryFromNode,this.temporaryFromPort,!1)}else this.isForwards?this.setNoTargetPortProperties(this.temporaryToNode,this.temporaryToPort,!0):this.setNoTargetPortProperties(this.temporaryFromNode,this.temporaryFromPort,!1);(t.allowHorizontalScroll||t.allowVerticalScroll)&&t.doAutoScroll(t.lastInput.viewPoint)}}findValidLinkablePort(t,e){if(t===null)return null;const i=t.part;if(!(i instanceof Node))return null;for(;t!==null;){const s=e?t.toLinkable:t.fromLinkable;if(s===!0&&(t.portId!==null||t instanceof Node)&&(e?this.isValidTo(i,t):this.isValidFrom(i,t)))return t;if(s===!1)return null;t=t.panel}return null}findTargetPort(t){const e=this.diagram,i=e.lastInput.documentPoint;let s=this.portGravity;const n=e.findObjectsNear(i,s,a=>this.findValidLinkablePort(a,t),null,!0);let o=1/0,r=null;const l=n.iterator;for(;l.next();){const a=l.value,h=a.part;if(!(h instanceof Node))continue;const c=a.getDocumentPoint(Spot.Center,Point.l()),f=i.x-c.x,u=i.y-c.y;Point.i(c);const d=f*f+u*u;if(d<o){const m=this.validPortsCache.get(a);m!==null?m&&(r=a,o=d):t&&this.isValidLink(this.originalFromNode,this.originalFromPort,h,a)||!t&&this.isValidLink(h,a,this.originalToNode,this.originalToPort)?(this.validPortsCache.set(a,!0),r=a,o=d):this.validPortsCache.set(a,!1)}}if(r!==null){const a=r.part;if(a instanceof Node&&(a.layer===null||a.layer.allowLink))return r}return null}isValidFrom(t,e){if(t===null||e===null)return this.isUnconnectedLinkValid;if(this.diagram.currentTool===this&&(t.layer!==null&&!t.layer.allowLink||e.fromLinkable!==!0))return!1;const i=e.fromMaxLinks;if(i<1/0){if(this.originalLink!==null&&t===this.originalFromNode&&e===this.originalFromPort)return!0;let s=e.portId;if(s===null&&(s=""),t.findLinksOutOf(s).count>=i)return!1}return!0}isValidTo(t,e){if(t===null||e===null)return this.isUnconnectedLinkValid;if(this.diagram.currentTool===this&&(t.layer!==null&&!t.layer.allowLink||e.toLinkable!==!0))return!1;const i=e.toMaxLinks;if(i<1/0){if(this.originalLink!==null&&t===this.originalToNode&&e===this.originalToPort)return!0;let s=e.portId;if(s===null&&(s=""),t.findLinksInto(s).count>=i)return!1}return!0}isInSameNode(t,e){if(t===null||e===null)return!1;if(t===e)return!0;const i=t.part,s=e.part;return i!==null&&i===s}isLinked(t,e){if(t===null||e===null)return!1;const i=t.part;if(!(i instanceof Node))return!1;let s=t.portId;s===null&&(s="");const n=e.part;if(!(n instanceof Node))return!1;let o=e.portId;o===null&&(o="");const r=n.findLinksInto(o);for(;r.next();){const l=r.value;if(l.fromNode===i&&l.fromPortId===s)return!0}return!1}isValidLink(t,e,i,s){if(!this.isValidFrom(t,e)||!this.isValidTo(i,s)||e!==null&&s!==null&&(!(e.fromLinkableSelfNode&&s.toLinkableSelfNode)&&this.isInSameNode(e,s)||!(e.fromLinkableDuplicates&&s.toLinkableDuplicates)&&this.isLinked(e,s))||this.originalLink!==null&&(t!==null&&this.isLabelDependentOnLink(t,this.originalLink)||i!==null&&this.isLabelDependentOnLink(i,this.originalLink))||t!==null&&i!==null&&(t.data===null&&i.data!==null||t.data!==null&&i.data===null)||!this.isValidCycle(t,i,this.originalLink))return!1;let n;return t!==null&&e!==null&&(n=t.linkValidation,n!==null&&!n(t,e,i,s,this.originalLink))||i!==null&&s!==null&&(n=i.linkValidation,n!==null&&!n(t,e,i,s,this.originalLink))?!1:(n=this.linkValidation,n!==null?n(t,e,i,s,this.originalLink):!0)}isLabelDependentOnLink(t,e){if(t===null)return!1;const i=t.labeledLink;if(i===null)return!1;if(i===e)return!0;const s=new GSet;return s.add(t),this.US(i,e,s)}US(t,e,i){if(t===e)return!0;const s=t.fromNode;if(s!==null&&s.labeledLink&&(i.add(s),this.US(s.labeledLink,e,i)))return!0;const n=t.toNode;return!!(n!==null&&n.labeledLink&&(i.add(n),this.US(n.labeledLink,e,i)))}isValidCycle(t,e,i){if(i===void 0&&(i=null),t===null||e===null)return this.isUnconnectedLinkValid;const s=this.diagram;let n=1;if(s&&(s.model.Um()?n=s.isTreePathToChildren?5:6:n=s.validCycle),n===1)return!0;if(n===5){const o=i||this.temporaryLink;if(o!==null&&!o.isTreeLink)return!0;const r=e.linksConnected;for(;r.next();){const l=r.value;if(l!==i&&l.isTreeLink&&l.toNode===e)return!1}return!this.Vu(t,e,i,!0)}else if(n===6){const o=i||this.temporaryLink;if(o!==null&&!o.isTreeLink)return!0;const r=t.linksConnected;for(;r.next();){const l=r.value;if(l!==i&&l.isTreeLink&&l.fromNode===t)return!1}return!this.Vu(t,e,i,!0)}else{if(n===2)return!this.pR(t,e,i);if(n===3)return!this.Vu(t,e,i,!1);if(n===4)return!this.yR(t,e,i)}return!0}Vu(t,e,i,s){if(t===e)return!0;if(t===null||e===null)return!1;const n=t.linksConnected;for(;n.next();){const o=n.value;if(o===i||s&&!o.isTreeLink||o.toNode!==t)continue;const r=o.fromNode;if(!(r===t||r===null)&&this.Vu(r,e,i,s))return!0}return!1}pR(t,e,i){if(t===e)return!0;const s=new Set;return s.add(e),this.SA(s,t,e,i)}SA(t,e,i,s){if(e===i)return!0;if(e===null||i===null||t.has(e))return!1;t.add(e);const n=e.linksConnected;for(;n.next();){const o=n.value;if(o===s||o.toNode!==e)continue;const r=o.fromNode;if(!(r===e||r===null)&&this.SA(t,r,i,s))return!0}return!1}yR(t,e,i){if(t===e)return!0;const s=new Set;return s.add(e),this.MA(s,t,e,i)}MA(t,e,i,s){if(e===i)return!0;if(e===null||i===null||t.has(e))return!1;t.add(e);const n=e.linksConnected;for(;n.next();){const o=n.value;if(o===s)continue;const r=o.fromNode,l=o.toNode,a=r===e?l:r;if(!(a===e||a===null)&&this.MA(t,a,i,s))return!0}return!1}get linkValidation(){return this.El}set linkValidation(t){t!==null&&U.S(t,LinkingBaseTool,"linkValidation"),this.El=t}get portTargeted(){return this.ES}set portTargeted(t){t!==null&&U.S(t,LinkingBaseTool,"portTargeted"),this.ES=t}}var LinkingDirection=(w=>(w[w.Either=1]="Either",w[w.ForwardsOnly=2]="ForwardsOnly",w[w.BackwardsOnly=3]="BackwardsOnly",w))(LinkingDirection||{});class LinkingTool extends LinkingBaseTool{VS;BS;P;zS;constructor(t){super(),this.name="Linking",this.VS={},this.BS=null,this.P=1,this.zS=null,t&&Object.assign(this,t)}static Either=1;static ForwardsOnly=2;static BackwardsOnly=3;get archetypeLinkData(){return this.VS}set archetypeLinkData(t){t!==null&&U.wc(t,LinkingTool,"archetypeLinkData"),t instanceof GraphObject&&U.se(t,Link,LinkingTool,"archetypeLinkData"),this.VS=t}get archetypeLabelNodeData(){return this.BS}set archetypeLabelNodeData(t){t!==null&&U.wc(t,LinkingTool,"archetypeLabelNodeData"),t instanceof GraphObject&&U.se(t,Node,LinkingTool,"archetypeLabelNodeData"),this.BS=t}get direction(){return this.P}set direction(t){this.P=t}get startObject(){return this.zS}set startObject(t){t!==null&&U.se(t,GraphObject,LinkingTool,"startObject"),this.zS=t}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;return t.isReadOnly||t.isModelReadOnly||!t.allowLink||!t.model.Lx()||!t.lastInput.left||t.currentTool!==this&&!this.isBeyondDragSize()?!1:this.findLinkablePort()!==null}findLinkablePort(){const t=this.diagram;let e=this.startObject;if(e===null&&(e=t.findObjectAt(t.firstInput.documentPoint,null,null)),e===null)return null;const i=e.part;if(!(i instanceof Node))return null;const s=this.direction;if(s===1||s===2){const n=this.findValidLinkablePort(e,!1);if(n!==null)return this.isForwards=!0,n;if(this.startObject===i){const o=i.port;if(this.findValidLinkablePort(o,!1))return this.isForwards=!0,o}}if(s===1||s===3){const n=this.findValidLinkablePort(e,!0);if(n!==null)return this.isForwards=!1,n;if(this.startObject===i){const o=i.port;if(this.findValidLinkablePort(o,!0))return this.isForwards=!1,o}}return null}doActivate(){const t=this.diagram,e=this.findLinkablePort();if(e===null){this.stopTool();return}if(this.startTransaction(this.name),t.isMouseCaptured=!0,t.currentCursor=this.linkingCursor,this.isForwards){this.temporaryToNode!==null&&(this.temporaryToNode.location=t.lastInput.documentPoint),this.originalFromPort=e;const i=this.originalFromPort.part;i instanceof Node&&(this.originalFromNode=i),this.copyPortProperties(this.originalFromNode,this.originalFromPort,this.temporaryFromNode,this.temporaryFromPort,!1)}else{this.temporaryFromNode!==null&&(this.temporaryFromNode.location=t.lastInput.documentPoint),this.originalToPort=e;const i=this.originalToPort.part;i instanceof Node&&(this.originalToNode=i),this.copyPortProperties(this.originalToNode,this.originalToPort,this.temporaryToNode,this.temporaryToPort,!0)}t.add(this.temporaryFromNode),this.temporaryFromNode&&this.temporaryFromNode.ensureBounds(),t.add(this.temporaryToNode),this.temporaryToNode&&this.temporaryToNode.ensureBounds(),this.temporaryLink!==null&&(this.temporaryFromNode!==null&&(this.temporaryLink.fromNode=this.temporaryFromNode),this.temporaryToNode!==null&&(this.temporaryLink.toNode=this.temporaryToNode),this.temporaryLink.isTreeLink=this.isNewTreeLink(),this.temporaryLink.$t(),t.add(this.temporaryLink)),this.isActive=!0}doDeactivate(){this.isActive=!1;const t=this.diagram;t.remove(this.temporaryLink),t.remove(this.temporaryFromNode),t.remove(this.temporaryToNode),t.isMouseCaptured=!1,t.currentCursor="",this.stopTransaction()}doStop(){super.doStop(),this.startObject=null}doMouseUp(){if(this.isActive){const t=this.diagram;this.transactionResult=null;let e=null,i=null,s=null,n=null,o=null;try{this.targetPort=this.findTargetPort(this.isForwards);const r=this.targetPort;if(r!==null){const l=r.part;l instanceof Node&&(this.isForwards?(this.originalFromNode!==null&&(e=this.originalFromNode,i=this.originalFromPort),s=l,n=r):(e=l,i=r,this.originalToNode!==null&&(s=this.originalToNode,n=this.originalToPort)))}else this.isForwards?this.originalFromNode!==null&&this.isUnconnectedLinkValid&&(e=this.originalFromNode,i=this.originalFromPort):this.originalToNode!==null&&this.isUnconnectedLinkValid&&(s=this.originalToNode,n=this.originalToPort);e!==null||s!==null?(o=this.insertLink(e,i,s,n),o!==null?(r===null&&(this.isForwards?o.defaultToPoint=t.lastInput.documentPoint:o.defaultFromPoint=t.lastInput.documentPoint),t.allowSelect&&(t.T("ChangingSelection",t.selection),t.clearSelection(!0),o.isSelected=!0),this.transactionResult=this.name,t.T("LinkDrawn",o)):this.doNoLink(e,i,s,n)):this.isForwards?this.doNoLink(this.originalFromNode,this.originalFromPort,null,null):this.doNoLink(null,null,this.originalToNode,this.originalToPort)}finally{this.stopTool(),o&&t.allowSelect&&t.T("ChangedSelection",t.selection)}}}isNewTreeLink(){const t=this.archetypeLinkData;if(t===null)return!0;if(t instanceof Link)return t.isTreeLink;const e=this.diagram;if(e===null)return!0;const i=e.partManager.getLinkCategoryForData(t),s=e.partManager.findLinkTemplateForCategory(i);return s!==null?s.isTreeLink:!0}insertLink(t,e,i,s){return this.diagram.partManager.insertLink(t,e,i,s)}doNoLink(t,e,i,s){}}class RelinkingTool extends LinkingBaseTool{NA=null;CA=null;XS=null;GS=null;Ss;YS;constructor(t){super(),this.name="Relinking",this.fromHandleArchetype=new Shape("Diamond",{desiredSize:Size.Su,fill:"lightblue",stroke:"dodgerblue",cursor:this.linkingCursor,segmentIndex:0}).theme("fill","adornmentFill").theme("stroke","adornmentStroke"),this.toHandleArchetype=new Shape("Diamond",{desiredSize:Size.Su,fill:"lightblue",stroke:"dodgerblue",cursor:this.linkingCursor,segmentIndex:-1}).theme("fill","adornmentFill").theme("stroke","adornmentStroke"),this.Ss=null,this.YS=new Rect,t&&Object.assign(this,t)}updateAdornments(t){if(t===null||!(t instanceof Link))return;let e="RelinkFrom",i=null;if(t.isSelected&&!this.diagram.isReadOnly){const s=t.selectionObject;s!==null&&t.canRelinkFrom()&&t.actualBounds.isReal()&&t.isVisible()&&s.actualBounds.isReal()&&s.isVisibleObject()&&(i=t.findAdornment(e),i===null&&(i=this.makeAdornment(s,!1),t.addAdornment(e,i)))}if(i===null&&t.removeAdornment(e),e="RelinkTo",i=null,t.isSelected&&!this.diagram.isReadOnly){const s=t.selectionObject;s!==null&&t.canRelinkTo()&&t.actualBounds.isReal()&&t.isVisible()&&s.actualBounds.isReal()&&s.isVisibleObject()&&(i=t.findAdornment(e),i===null?(i=this.makeAdornment(s,!0),t.addAdornment(e,i)):i.c())}i===null&&t.removeAdornment(e)}makeAdornment(t,e){let i=e?this.GS:this.XS;return i&&(i=i.copy(),i.adornedObject=t),i}get fromHandleArchetype(){return this.NA}set fromHandleArchetype(t){t!==null&&U.se(t,GraphObject,RelinkingTool,"fromHandleArchetype"),this.NA=t,t!==null?this.XS=new Adornment(Panel.Link).add(t).It():this.XS=null}get toHandleArchetype(){return this.CA}set toHandleArchetype(t){t!==null&&U.se(t,GraphObject,RelinkingTool,"toHandleArchetype"),this.CA=t,t!==null?this.GS=new Adornment(Panel.Link).add(t).It():this.GS=null}get handle(){return this.Ss}set handle(t){t!==null&&(t.part instanceof Adornment||U.o("new handle is not in an Adornment: "+t)),this.Ss=t}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;if(t.isReadOnly||t.isModelReadOnly||!t.allowRelink||!t.model.Lx()||!t.lastInput.left)return!1;let i=this.findToolHandleAt(t.firstInput.documentPoint,"RelinkFrom");return i===null&&(i=this.findToolHandleAt(t.firstInput.documentPoint,"RelinkTo")),i!==null}doActivate(){const t=this.diagram;if(this.originalLink===null){let i=this.handle;if(i===null&&(i=this.findToolHandleAt(t.firstInput.documentPoint,"RelinkFrom"),i===null&&(i=this.findToolHandleAt(t.firstInput.documentPoint,"RelinkTo"))),i===null)return;const s=i.part;if(!(s instanceof Adornment)||!(s.adornedPart instanceof Link))return;this.handle=i,this.isForwards=s===null||s.category==="RelinkTo",this.originalLink=s.adornedPart}const e=this.originalLink;e!==null&&(this.startTransaction(this.name),t.isMouseCaptured=!0,t.currentCursor=this.linkingCursor,this.originalFromPort=e.fromPort,this.originalFromNode=e.fromNode,this.originalToPort=e.toPort,this.originalToNode=e.toNode,this.YS.set(e.actualBounds),e.pointsCount>0&&(e.fromNode===null&&(this.temporaryFromPort!==null&&(this.temporaryFromPort.desiredSize=Size.xc),this.temporaryFromNode!==null&&(this.temporaryFromNode.location=e.getPoint(0))),e.toNode===null&&(this.temporaryToPort!==null&&(this.temporaryToPort.desiredSize=Size.xc),this.temporaryToNode!==null&&(this.temporaryToNode.location=e.getPoint(e.pointsCount-1)))),this.copyPortProperties(this.originalFromNode,this.originalFromPort,this.temporaryFromNode,this.temporaryFromPort,!1),this.copyPortProperties(this.originalToNode,this.originalToPort,this.temporaryToNode,this.temporaryToPort,!0),t.add(this.temporaryFromNode),t.add(this.temporaryToNode),this.temporaryLink!==null&&(this.temporaryFromNode!==null&&(this.temporaryLink.fromNode=this.temporaryFromNode),this.temporaryToNode!==null&&(this.temporaryLink.toNode=this.temporaryToNode),this.copyLinkProperties(e,this.temporaryLink),this.temporaryLink.$t(),t.add(this.temporaryLink)),this.isActive=!0)}copyLinkProperties(t,e){if(t===null||e===null)return;e.adjusting=t.adjusting,e.corner=t.corner;let i=t.curve;(i===11||i===10)&&(i=0),e.curve=i,e.curviness=t.curviness,e.isTreeLink=t.isTreeLink,e.points=t.points,e.routing=t.routing,e.smoothness=t.smoothness,e.fromSpot=t.fromSpot,e.fromEndSegmentLength=t.fromEndSegmentLength,e.fromShortLength=t.fromShortLength,e.toSpot=t.toSpot,e.toEndSegmentLength=t.toEndSegmentLength,e.toShortLength=t.toShortLength}doDeactivate(){this.isActive=!1;const t=this.diagram;t.remove(this.temporaryLink),t.remove(this.temporaryFromNode),t.remove(this.temporaryToNode),t.isMouseCaptured=!1,t.currentCursor="",this.stopTransaction()}doStop(){super.doStop(),this.handle=null}doMouseUp(){if(this.isActive){const t=this.diagram;this.transactionResult=null;let e=this.originalFromNode,i=this.originalFromPort,s=this.originalToNode,n=this.originalToPort,o=this.originalLink;try{if(this.targetPort=this.findTargetPort(this.isForwards),this.targetPort!==null){const r=this.targetPort.part;r instanceof Node&&(this.isForwards?(s=r,n=this.targetPort):(e=r,i=this.targetPort))}else this.isUnconnectedLinkValid?this.isForwards?(s=null,n=null):(e=null,i=null):o=null;o!==null?(this.reconnectLink(o,this.isForwards?s:e,this.isForwards?n:i,this.isForwards),this.targetPort===null&&(this.isForwards?o.defaultToPoint=t.lastInput.documentPoint:o.defaultFromPoint=t.lastInput.documentPoint,o.$t()),this.transactionResult=this.name,t.T("LinkRelinked",o,this.isForwards?this.originalToPort:this.originalFromPort)):this.originalLink!==null&&this.doNoRelink(this.originalLink,this.isForwards),this.originalLink!==null&&this.originalLink.invalidateOtherJumpOvers(this.YS)}finally{this.stopTool()}}}reconnectLink(t,e,i,s){const n=i!==null&&i.portId!==null?i.portId:"";return s?(t.toNode=e,t.toPortId=n):(t.fromNode=e,t.fromPortId=n),!0}doNoRelink(t,e){}doDraggingMouseMove(t,e,i,s){t!==null?(this.copyPortProperties(t,e,this.temporaryFromNode,this.temporaryFromPort,!1),this.diagram.add(this.temporaryFromNode)):this.diagram.remove(this.temporaryFromNode),i!==null?(this.copyPortProperties(i,s,this.temporaryToNode,this.temporaryToPort,!0),this.diagram.add(this.temporaryToNode)):this.diagram.remove(this.temporaryToNode)}stopDraggingMouseMove(){this.diagram.remove(this.temporaryFromNode),this.diagram.remove(this.temporaryToNode)}}var ReshapingBehavior=(w=>(w[w.None=0]="None",w[w.Horizontal=1]="Horizontal",w[w.Vertical=2]="Vertical",w[w.All=3]="All",w))(ReshapingBehavior||{});class LinkReshapingTool extends Tool{Mr;KS;HS;Ss;Ax;jS;Vm;constructor(t){super(),this.name="LinkReshaping",this.Mr=new Shape("Rectangle",{desiredSize:Size.RL,fill:"lightblue",stroke:"dodgerblue"}).theme("fill","adornmentFill").theme("stroke","adornmentStroke"),this.KS=new Shape("Diamond",{desiredSize:Size.Su,fill:"lightblue",stroke:"dodgerblue",cursor:"move"}).theme("fill","adornmentFill").theme("stroke","adornmentStroke"),this.HS=3,this.Ss=null,this.Ax=null,this.jS=new Point,this.Vm=new List,t&&Object.assign(this,t)}static None=0;static Horizontal=1;static Vertical=2;static All=3;getReshapingBehavior(t){return t?t.Nr:0}setReshapingBehavior(t,e){t.Nr=e}updateAdornments(t){if(t===null||!(t instanceof Link))return;let e=null;if(t.isSelected&&!this.diagram.isReadOnly){const i=t.path;i!==null&&t.canReshape()&&t.actualBounds.isReal()&&t.isVisible()&&i.actualBounds.isReal()&&i.isVisibleObject()&&(e=t.findAdornment(this.name),(e===null||e.qS!==t.pointsCount||e.WS!==t.resegmentable)&&(e=this.makeAdornment(i),e!==null&&(e.qS=t.pointsCount,e.WS=t.resegmentable,t.addAdornment(this.name,e))))}e===null&&t.removeAdornment(this.name)}makeAdornment(t){const e=t.part,i=e.points,s=e.pointsCount,n=e.isOrthogonal;let o=null;if(i!==null&&s>1){o=new Adornment,o.type=Panel.Link;const r=e.firstPickIndex,l=e.lastPickIndex,a=n?1:0;if(e.resegmentable&&e.computeCurve()!==9)for(let h=r+a;h<l-a;h++){const c=this.makeResegmentHandle(t,h);c!==null&&(c.segmentIndex=h,c.segmentFraction=.5,c.fromMaxLinks=999,o.add(c))}for(let h=r+1;h<l;h++){const c=this.makeHandle(t,h);if(c!==null){if(c.segmentIndex=h,h!==r)if(h===r+1&&n){const f=e.getPoint(r);let u=e.getPoint(r+1);G.u(f.x,u.x)&&G.u(f.y,u.y)?(u=e.getPoint(r-1),G.u(f.x,u.x)?(this.setReshapingBehavior(c,2),c.cursor="n-resize"):G.u(f.y,u.y)&&(this.setReshapingBehavior(c,1),c.cursor="w-resize")):G.u(f.x,u.x)?(this.setReshapingBehavior(c,2),c.cursor="n-resize"):G.u(f.y,u.y)&&(this.setReshapingBehavior(c,1),c.cursor="w-resize")}else if(h===l-1&&n){let f=e.getPoint(l-1);const u=e.getPoint(l);G.u(f.x,u.x)&&G.u(f.y,u.y)?(f=e.getPoint(l+1),G.u(f.x,u.x)?(this.setReshapingBehavior(c,2),c.cursor="n-resize"):G.u(f.y,u.y)&&(this.setReshapingBehavior(c,1),c.cursor="w-resize")):G.u(f.x,u.x)?(this.setReshapingBehavior(c,2),c.cursor="n-resize"):G.u(f.y,u.y)&&(this.setReshapingBehavior(c,1),c.cursor="w-resize")}else h===l||(this.setReshapingBehavior(c,3),c.cursor="move");o.add(c)}}o.adornedObject=t}return o}makeHandle(t,e){const i=this.handleArchetype;return i===null?null:i.copy().JS()}get handleArchetype(){return this.Mr}set handleArchetype(t){t!==null&&U.se(t,GraphObject,LinkReshapingTool,"handleArchetype"),this.Mr=t}makeResegmentHandle(t,e){const i=this.midHandleArchetype;return i===null?null:i.copy().JS()}get midHandleArchetype(){return this.KS}set midHandleArchetype(t){t!==null&&U.se(t,GraphObject,LinkReshapingTool,"midHandleArchetype"),this.KS=t}get handle(){return this.Ss}set handle(t){t!==null&&(t.part instanceof Adornment||U.o("new handle is not in an Adornment: "+t)),this.Ss=t}get adornedLink(){return this.Ax}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;return t.isReadOnly||!t.allowReshape||!t.lastInput.left?!1:this.findToolHandleAt(t.firstInput.documentPoint,this.name)!==null}doActivate(){const t=this.diagram;if(this.handle===null&&(this.handle=this.findToolHandleAt(t.firstInput.documentPoint,this.name)),this.handle===null)return;const e=this.handle.part.adornedPart;if(e instanceof Link){if(this.Ax=e,t.isMouseCaptured=!0,this.startTransaction(this.name),e.resegmentable&&this.handle.fromMaxLinks===999){const i=e.points.copy(),s=this.getResegmentingPoint();if(i.insertAt(this.handle.segmentIndex+1,s),e.isOrthogonal&&i.insertAt(this.handle.segmentIndex+1,s),e.points=i,e.invalidateAdornments(),e.updateAdornments(),this.handle=this.findToolHandleAt(t.firstInput.documentPoint,this.name),this.handle===null){this.doDeactivate();return}}this.jS=e.getPoint(this.handle.segmentIndex),this.Vm=e.points.copy(),this.isActive=!0}}doDeactivate(){this.stopTransaction(),this.handle=null,this.Ax=null;const t=this.diagram;t.isMouseCaptured=!1,this.isActive=!1}stopTransaction(){const t=this.diagram,e=super.stopTransaction();return e&&t.undoManager.transactionToUndo!==null&&t.undoManager.transactionToUndo.optimize(),e}doCancel(){const t=this.adornedLink;t!==null&&(t.points=this.Vm),this.stopTool()}getResegmentingPoint(){return this.handle===null?this.diagram.lastInput.documentPoint:this.handle.getDocumentPoint(Spot.Center)}doMouseMove(){const t=this.diagram;if(this.isActive){const e=this.computeReshape(t.lastInput.documentPoint);this.reshape(e)}}doMouseUp(){const t=this.diagram;if(this.isActive){const e=this.computeReshape(t.lastInput.documentPoint);this.reshape(e);const i=this.adornedLink;if(i!==null&&i.resegmentable&&this.handle!==null){const s=this.handle.segmentIndex,n=i.getPoint(s-1),o=i.getPoint(s),r=i.getPoint(s+1);if(i.isOrthogonal){if(s>i.firstPickIndex+1&&s<i.lastPickIndex-1){let l=i.getPoint(s-2);if(this.isWithinResegmentingDistance(n,o)&&(this.isInLineOrtho(l,n,o,r,!0)||this.isInLineOrtho(l,n,o,r,!1))){const a=i.points.copy();this.isInLineOrtho(l,n,o,r,!0)?(a.setElt(s-2,new Point(l.x,(r.y+l.y)/2)),a.setElt(s+1,new Point(r.x,(r.y+l.y)/2))):(a.setElt(s-2,new Point((r.x+l.x)/2,l.y)),a.setElt(s+1,new Point((r.x+l.x)/2,r.y))),a.removeAt(s),a.removeAt(s-1),i.points=a,i.invalidateAdornments()}else if(l=i.getPoint(s+2),this.isWithinResegmentingDistance(o,r)&&(this.isInLineOrtho(n,o,r,l,!0)||this.isInLineOrtho(n,o,r,l,!1))){const a=i.points.copy();this.isInLineOrtho(n,o,r,l,!0)?(a.setElt(s-1,new Point(n.x,(n.y+l.y)/2)),a.setElt(s+2,new Point(l.x,(n.y+l.y)/2))):(a.setElt(s-1,new Point((n.x+l.x)/2,n.y)),a.setElt(s+2,new Point((n.x+l.x)/2,l.y))),a.removeAt(s+1),a.removeAt(s),i.points=a,i.invalidateAdornments()}}}else{const l=Point.l();if(G.Nl(n.x,n.y,r.x,r.y,o.x,o.y,l)&&l.distanceSquaredPoint(o)<this.resegmentingDistance*this.resegmentingDistance){const a=i.points.copy();a.removeAt(s),i.points=a,i.invalidateAdornments()}Point.i(l)}}t.invalidateDocumentBounds(),this.transactionResult=this.name,t.T("LinkReshaped",this.adornedLink,this.Vm)}this.stopTool()}isWithinResegmentingDistance(t,e){return Math.abs(t.x-e.x)<this.resegmentingDistance&&Math.abs(t.y-e.y)<this.resegmentingDistance}isInLineOrtho(t,e,i,s,n){return n?Math.abs(t.y-e.y)<this.resegmentingDistance&&Math.abs(e.y-i.y)<this.resegmentingDistance&&Math.abs(i.y-s.y)<this.resegmentingDistance:Math.abs(t.x-e.x)<this.resegmentingDistance&&Math.abs(e.x-i.x)<this.resegmentingDistance&&Math.abs(i.x-s.x)<this.resegmentingDistance}get resegmentingDistance(){return this.HS}set resegmentingDistance(t){U.s(t,"number",LinkReshapingTool,"resegmentingDistance"),this.HS=t}reshape(t){const e=this.adornedLink;if(e===null)return;const i=this.handle;if(i===null)return;e.startRoute();let s=i.segmentIndex;const n=this.getReshapingBehavior(i);if(e.isOrthogonal)if(s===e.firstPickIndex+1){const o=e.firstPickIndex+1;n===2?(e.setPointAt(o,e.getPoint(o-1).x,t.y),e.setPointAt(o+1,e.getPoint(o+2).x,t.y)):n===1&&(e.setPointAt(o,t.x,e.getPoint(o-1).y),e.setPointAt(o+1,t.x,e.getPoint(o+2).y))}else if(s===e.lastPickIndex-1){const o=e.lastPickIndex-1;n===2?(e.setPointAt(o-1,e.getPoint(o-2).x,t.y),e.setPointAt(o,e.getPoint(o+1).x,t.y)):n===1&&(e.setPointAt(o-1,t.x,e.getPoint(o-2).y),e.setPointAt(o,t.x,e.getPoint(o+1).y))}else{let o=s;const r=e.getPoint(o),l=e.getPoint(o-1),a=e.getPoint(o+1);G.u(l.x,r.x)&&G.u(r.y,a.y)?(G.u(l.x,e.getPoint(o-2).x)&&!G.u(l.y,e.getPoint(o-2).y)?(e.insertPointAt(o,t.x,l.y),s++,o++):e.setPointAt(o-1,t.x,l.y),G.u(a.y,e.getPoint(o+2).y)&&!G.u(a.x,e.getPoint(o+2).x)?e.insertPointAt(o+1,a.x,t.y):e.setPointAt(o+1,a.x,t.y)):G.u(l.y,r.y)&&G.u(r.x,a.x)?(G.u(l.y,e.getPoint(o-2).y)&&!G.u(l.x,e.getPoint(o-2).x)?(e.insertPointAt(o,l.x,t.y),s++,o++):e.setPointAt(o-1,l.x,t.y),G.u(a.x,e.getPoint(o+2).x)&&!G.u(a.y,e.getPoint(o+2).y)?e.insertPointAt(o+1,t.x,a.y):e.setPointAt(o+1,t.x,a.y)):G.u(l.x,r.x)&&G.u(r.x,a.x)?(G.u(l.x,e.getPoint(o-2).x)&&!G.u(l.y,e.getPoint(o-2).y)?(e.insertPointAt(o,t.x,l.y),s++,o++):e.setPointAt(o-1,t.x,l.y),G.u(a.x,e.getPoint(o+2).x)&&!G.u(a.y,e.getPoint(o+2).y)?e.insertPointAt(o+1,t.x,a.y):e.setPointAt(o+1,t.x,a.y)):G.u(l.y,r.y)&&G.u(r.y,a.y)&&(G.u(l.y,e.getPoint(o-2).y)&&!G.u(l.x,e.getPoint(o-2).x)?(e.insertPointAt(o,l.x,t.y),s++,o++):e.setPointAt(o-1,l.x,t.y),G.u(a.y,e.getPoint(o+2).y)&&!G.u(a.x,e.getPoint(o+2).x)?e.insertPointAt(o+1,a.x,t.y):e.setPointAt(o+1,a.x,t.y)),e.setPointAt(s,t.x,t.y)}else{e.setPointAt(s,t.x,t.y);let o=e.fromNode,r=e.fromPort;if(o!==null){const h=o.findVisibleNode();h!==null&&h!==o&&(o=h,r=o.port)}if(s===1&&r!==null&&e.computeSpot(!0,r).isNoSpot()){const h=r.getDocumentPoint(Spot.Center,Point.l()),c=e.getLinkPointFromPoint(o,r,h,t,!0,Point.l());e.setPointAt(0,c.x,c.y),Point.i(h),Point.i(c)}let l=e.toNode,a=e.toPort;if(l!==null){const h=l.findVisibleNode();h!==null&&h!==l&&(l=h,a=l.port)}if(s===e.pointsCount-2&&a!==null&&e.computeSpot(!1,a).isNoSpot()){const h=a.getDocumentPoint(Spot.Center,Point.l()),c=e.getLinkPointFromPoint(l,a,h,t,!1,Point.l());e.setPointAt(e.pointsCount-1,c.x,c.y),Point.i(h),Point.i(c)}}e.commitRoute()}computeReshape(t){const e=this.adornedLink;if(e===null)return t;const i=this.handle;if(i===null)return t;const s=i.segmentIndex;switch(this.getReshapingBehavior(i)){case 3:return t;case 2:{const n=e.getPoint(s);return new Point(n.x,t.y)}case 1:{const n=e.getPoint(s);return new Point(t.x,n.y)}default:case 0:return e.getPoint(s)}}get originalPoint(){return this.jS}get originalPoints(){return this.Vm}}class ResizingTool extends Tool{Cr;Lr;Oo;Rc;$S;Ms;Mr;Ss;Bm;ZS;Oc;Tx;Dx;vx;constructor(t){super(),this.name="Resizing",this.Cr=new Size(1,1).b(),this.Lr=new Size(9999,9999).b(),this.Oo=new Size(NaN,NaN).b(),this.Rc=!1,this.$S=!0,this.Ms=null,this.Mr=new Shape("Rectangle",{alignmentFocus:Spot.Center,desiredSize:Size.RL,fill:"lightblue",stroke:"dodgerblue",strokeWidth:1,cursor:"pointer"}).theme("fill","adornmentFill").theme("stroke","adornmentStroke"),this.Ss=null,this.Bm=new Point,this.ZS=new Size,this.Oc=new Point,this.Tx=new Size(0,0),this.Dx=new Size(1/0,1/0),this.vx=new Size(1,1),t&&Object.assign(this,t)}updateAdornments(t){if(t!==null){if(t.Ar()){const e=t.rotateObject;if(e===t||e===t.path||e.isPanelMain)return}if(t.isSelected&&!this.diagram.isReadOnly){const e=t.resizeObject;let i=t.findAdornment(this.name);if(e!==null&&t.canResize()&&t.actualBounds.isReal()&&t.isVisible()&&e.actualBounds.isReal()&&e.isVisibleObject()&&((i===null||i.adornedObject!==e)&&(i=this.makeAdornment(e)),i!==null)){const s=e.getDocumentAngle();t.Ul()&&this.updateResizeHandles(i,s),t.addAdornment(this.name,i);return}}t.removeAdornment(this.name)}}makeAdornment(t){let e=null;const i=t.part?.resizeAdornmentTemplate;if(i){if(e=i.copy(),e===null)return null}else{e=new Adornment,e.type=Panel.Spot,e.locationSpot=Spot.Center;const s=new Placeholder;s.isPanelMain=!0,e.add(s);let n=this.makeHandle(t,Spot.TopLeft);n!==null&&e.add(n),n=this.makeHandle(t,Spot.TopRight),n!==null&&e.add(n),n=this.makeHandle(t,Spot.BottomRight),n!==null&&e.add(n),n=this.makeHandle(t,Spot.BottomLeft),n!==null&&e.add(n),n=this.makeHandle(t,Spot.MiddleTop),n!==null&&e.add(n),n=this.makeHandle(t,Spot.MiddleRight),n!==null&&e.add(n),n=this.makeHandle(t,Spot.MiddleBottom),n!==null&&e.add(n),n=this.makeHandle(t,Spot.MiddleLeft),n!==null&&e.add(n)}return e.adornedObject=t,e}makeHandle(t,e){const i=this.handleArchetype;if(i===null)return null;const s=i.copy().JS();return s.alignment=e,s}updateResizeHandles(t,e){if(t!==null){if(!t.alignment.isDefault()&&(t.cursor==="pointer"||t.cursor.indexOf("resize")>0))this.wR(t,e);else if(t instanceof Panel){const i=t.elements;for(;i.next();){const s=i.value;this.updateResizeHandles(s,e)}}}}wR(t,e){let i=t.alignment;i.isNoSpot()&&(i=Spot.Center);let s=e;if(i.x<=0)i.y<=0?s+=225:i.y>=1?s+=135:s+=180;else if(i.x>=1)i.y<=0?s+=315:i.y>=1&&(s+=45);else if(i.y<=0)s+=270;else if(i.y>=1)s+=90;else return;s=G.Ee(s),s<22.5?t.cursor="e-resize":s<67.5?t.cursor="se-resize":s<112.5?t.cursor="s-resize":s<157.5?t.cursor="sw-resize":s<202.5?t.cursor="w-resize":s<247.5?t.cursor="nw-resize":s<292.5?t.cursor="n-resize":s<337.5?t.cursor="ne-resize":t.cursor="e-resize"}get handleArchetype(){return this.Mr}set handleArchetype(t){t!==null&&U.se(t,GraphObject,ResizingTool,"handleArchetype"),this.Mr=t}get handle(){return this.Ss}set handle(t){t!==null&&(t.part instanceof Adornment||U.o("new handle is not in an Adornment: "+t)),this.Ss=t}get adornedObject(){return this.Ms}set adornedObject(t){t!==null&&t.part instanceof Adornment&&U.o("new handle must not be in an Adornment: "+t),this.Ms=t}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;return t.isReadOnly||!t.allowResize||!t.lastInput.left?!1:this.findToolHandleAt(t.firstInput.documentPoint,this.name)!==null}doActivate(){const t=this.diagram;this.handle===null&&(this.handle=this.findToolHandleAt(t.firstInput.documentPoint,this.name)),this.handle!==null&&(this.adornedObject=this.handle.part.adornedObject,this.adornedObject!==null&&this.adornedObject.part!==null&&(t.isMouseCaptured=!0,t.animationManager.stopAnimation(),t.Iu=!0,this.startTransaction(this.name),this.Bm.set(this.adornedObject.getDocumentPoint(this.handle.alignment.opposite())),this.Oc.set(this.adornedObject.part.location),this.ZS.set(this.adornedObject.desiredSize),this.vx=this.computeCellSize(),this.Tx=this.computeMinSize(),this.Dx=this.computeMaxSize(),this.isActive=!0))}doDeactivate(){const t=this.diagram;t.Iu=!1,t.Fl=!0,this.stopTransaction(),this.handle=null,this.Ms=null,t.isMouseCaptured=!1,this.isActive=!1}stopTransaction(){const t=this.diagram,e=super.stopTransaction();return e&&t.undoManager.transactionToUndo!==null&&t.undoManager.transactionToUndo.optimize(),e}doCancel(){this.adornedObject!==null&&this.adornedObject.part!==null&&(this.adornedObject.desiredSize=this.originalDesiredSize,this.adornedObject.part.location=this.originalLocation),this.stopTool()}doMouseMove(){const t=this.diagram;if(!this.isActive||this.adornedObject===null||this.handle===null)return;const e=this.Tx,i=this.Dx,s=this.vx,n=t.lastInput.documentPoint,o=this.adornedObject.getLocalPoint(n,Point.l()),r=this.computeReshape(),l=this.computeResize(o,this.handle.alignment,e,i,s,r);this.resize(l),t.maybeUpdate(),Point.i(o)}doMouseUp(){const t=this.diagram;if(this.isActive&&this.adornedObject!==null&&this.handle!==null){const e=this.Tx,i=this.Dx,s=this.vx,n=this.adornedObject.getLocalPoint(t.lastInput.documentPoint,Point.l()),o=this.computeReshape(),r=this.computeResize(n,this.handle.alignment,e,i,s,o);this.resize(r),Point.i(n),t.invalidateDocumentBounds(),this.transactionResult=this.name,t.T("PartResized",this.adornedObject,this.originalDesiredSize)}this.stopTool()}resize(t){const e=this.diagram,i=this.adornedObject;if(i===null)return;i.desiredSize=t.size;const s=i.part;if(s===null||this.handle===null)return;s.ensureBounds();const n=i.getDocumentPoint(this.handle.alignment.opposite());if(s instanceof Group){const o=new List;o.add(s);let r;!this.dragsMembers&&!s.hasPlaceholder()&&(r=new DraggingOptions,r.dragsMembers=!1),e.moveParts(o,this.oppositePoint.copy().subtract(n),!0,r)}else s.location=s.location.copy().subtract(n).add(this.oppositePoint);e.maybeUpdate()}computeResize(t,e,i,s,n,o){if(this.adornedObject===null)return Rect.tm;e.isNoSpot()&&(e=Spot.Center);const r=this.adornedObject.naturalBounds,l=r.x,a=r.y,h=r.x+r.width,c=r.y+r.height;let f=1;if(!o){let m=r.width,g=r.height;m<=0&&(m=1),g<=0&&(g=1),f=g/m}const u=Point.l();G._g(t.x,t.y,l,a,n.width,n.height,u);const d=r.copy();return e.x<=0?e.y<=0?(d.x=Math.max(u.x,h-s.width),d.x=Math.min(d.x,h-i.width),d.width=Math.max(h-d.x,i.width),d.y=Math.max(u.y,c-s.height),d.y=Math.min(d.y,c-i.height),d.height=Math.max(c-d.y,i.height),o||(d.height/d.width>=1?(d.height=Math.max(Math.min(f*d.width,s.height),i.height),d.width=d.height/f):(d.width=Math.max(Math.min(d.height/f,s.width),i.width),d.height=f*d.width),d.x=h-d.width,d.y=c-d.height)):e.y>=1?(d.x=Math.max(u.x,h-s.width),d.x=Math.min(d.x,h-i.width),d.width=Math.max(h-d.x,i.width),d.height=Math.max(Math.min(u.y-a,s.height),i.height),o||(d.height/d.width>=1?(d.height=Math.max(Math.min(f*d.width,s.height),i.height),d.width=d.height/f):(d.width=Math.max(Math.min(d.height/f,s.width),i.width),d.height=f*d.width),d.x=h-d.width)):(d.x=Math.max(u.x,h-s.width),d.x=Math.min(d.x,h-i.width),d.width=h-d.x,o||(d.height=Math.max(Math.min(f*d.width,s.height),i.height),d.width=d.height/f,d.y=a+.5*(c-a-d.height))):e.x>=1?e.y<=0?(d.width=Math.max(Math.min(u.x-l,s.width),i.width),d.y=Math.max(u.y,c-s.height),d.y=Math.min(d.y,c-i.height),d.height=Math.max(c-d.y,i.height),o||(d.height/d.width>=1?(d.height=Math.max(Math.min(f*d.width,s.height),i.height),d.width=d.height/f):(d.width=Math.max(Math.min(d.height/f,s.width),i.width),d.height=f*d.width),d.y=c-d.height)):e.y>=1?(d.width=Math.max(Math.min(u.x-l,s.width),i.width),d.height=Math.max(Math.min(u.y-a,s.height),i.height),o||(d.height/d.width>=1?(d.height=Math.max(Math.min(f*d.width,s.height),i.height),d.width=d.height/f):(d.width=Math.max(Math.min(d.height/f,s.width),i.width),d.height=f*d.width))):(d.width=Math.max(Math.min(u.x-l,s.width),i.width),o||(d.height=Math.max(Math.min(f*d.width,s.height),i.height),d.width=d.height/f,d.y=a+.5*(c-a-d.height))):e.y<=0?(d.y=Math.max(u.y,c-s.height),d.y=Math.min(d.y,c-i.height),d.height=c-d.y,o||(d.width=Math.max(Math.min(d.height/f,s.width),i.width),d.height=f*d.width,d.x=l+.5*(h-l-d.width))):e.y>=1&&(d.height=Math.max(Math.min(u.y-a,s.height),i.height),o||(d.width=Math.max(Math.min(d.height/f,s.width),i.width),d.height=f*d.width,d.x=l+.5*(h-l-d.width))),Point.i(u),d}computeReshape(){let t=0;return this.adornedObject instanceof Shape&&(t=this.adornedObject.QS()),!(t===6||this.diagram.lastInput.shift)}computeMinSize(){if(this.adornedObject===null)return Size.xc;const t=this.adornedObject.minSize.copy(),e=this.minSize;return!isNaN(e.width)&&e.width>t.width&&(t.width=e.width),!isNaN(e.height)&&e.height>t.height&&(t.height=e.height),t}computeMaxSize(){if(this.adornedObject===null)return Size.TP;const t=this.adornedObject.maxSize.copy(),e=this.maxSize;return!isNaN(e.width)&&e.width<t.width&&(t.width=e.width),!isNaN(e.height)&&e.height<t.height&&(t.height=e.height),t}computeCellSize(){const t=new Size(NaN,NaN),e=this.adornedObject?.part;if(e){const n=e.resizeCellSize;!isNaN(n.width)&&n.width>0&&(t.width=n.width),!isNaN(n.height)&&n.height>0&&(t.height=n.height)}let i=this.cellSize;isNaN(t.width)&&!isNaN(i.width)&&i.width>0&&(t.width=i.width),isNaN(t.height)&&!isNaN(i.height)&&i.height>0&&(t.height=i.height);const s=this.diagram;if((isNaN(t.width)||isNaN(t.height))&&s){const n=s.grid;n!==null&&n.visible&&this.isGridSnapEnabled&&(i=n.gridCellSize,isNaN(t.width)&&!isNaN(i.width)&&i.width>0&&(t.width=i.width),isNaN(t.height)&&!isNaN(i.height)&&i.height>0&&(t.height=i.height))}return(isNaN(t.width)||t.width===0||t.width===1/0)&&(t.width=1),(isNaN(t.height)||t.height===0||t.height===1/0)&&(t.height=1),t}get minSize(){return this.Cr}set minSize(t){if(!this.Cr.equals(t)){let i=t.width;isNaN(i)&&(i=0);let s=t.height;isNaN(s)&&(s=0),this.Cr.e(i,s)}}get maxSize(){return this.Lr}set maxSize(t){if(!this.Lr.equals(t)){let i=t.width;isNaN(i)&&(i=1/0);let s=t.height;isNaN(s)&&(s=1/0),this.Lr.e(i,s)}}get cellSize(){return this.Oo}set cellSize(t){this.Oo.equals(t)||this.Oo.h(t)}get isGridSnapEnabled(){return this.Rc}set isGridSnapEnabled(t){U.s(t,"boolean",ResizingTool,"isGridSnapEnabled"),this.Rc=t}get dragsMembers(){return this.$S}set dragsMembers(t){U.s(t,"boolean",ResizingTool,"dragsMembers"),this.$S=t}get oppositePoint(){return this.Bm}set oppositePoint(t){this.Bm.equals(t)||this.Bm.h(t)}get originalDesiredSize(){return this.ZS}get originalLocation(){return this.Oc}}class RotatingTool extends Tool{_S;tM;Ms=null;Mr=null;Fx=null;Ss=null;eM;zm;Oc;iM;sM;constructor(t){super(),this.name="Rotating",this._S=45,this.tM=2,this.Oc=new Point,this.Ms=null,this.handleArchetype=new Shape("Ellipse",{desiredSize:Size.Su,fill:"lightblue",stroke:"dodgerblue",strokeWidth:1,cursor:"pointer"}).theme("fill","adornmentFill").theme("stroke","adornmentStroke"),this.Ss=null,this.eM=0,this.zm=new Point(NaN,NaN),this.iM=0,this.sM=50,t&&Object.assign(this,t)}updateAdornments(t){if(t!==null){if(t.Ar()){const e=t.rotateObject;if(e===t||e===t.path||e.isPanelMain)return}if(t.isSelected&&!this.diagram.isReadOnly){const e=t.rotateObject;if(e!==null&&t.canRotate()&&t.actualBounds.isReal()&&t.isVisible()&&e.actualBounds.isReal()&&e.isVisibleObject()){let i=t.findAdornment(this.name);if((i===null||i.adornedObject!==e)&&(i=this.makeAdornment(e)),i!==null){i.angle=e.getDocumentAngle(),i.hasPlaceholder()||(i.location=this.computeAdornmentLocation(e)),t.addAdornment(this.name,i);return}}}t.removeAdornment(this.name)}}makeAdornment(t){let e=null;const i=t.part?.rotateAdornmentTemplate;return i?e=i.copy():this.Fx!==null&&(e=this.Fx.copy()),e===null?null:(e.adornedObject=t,e)}get handleArchetype(){return this.Mr}set handleArchetype(t){t!==null&&U.se(t,GraphObject,RotatingTool,"handleArchetype"),this.Mr=t,t!==null?this.Fx=new Adornment(Panel.Position,{locationSpot:Spot.Center}).add(t).It():this.Fx=null}get handle(){return this.Ss}set handle(t){t!==null&&(t.part instanceof Adornment||U.o("new handle is not in an Adornment: "+t)),this.Ss=t}get adornedObject(){return this.Ms}set adornedObject(t){t!==null&&t.part instanceof Adornment&&U.o("new handle must not be in an Adornment: "+t),this.Ms=t}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;return t.isReadOnly||!t.allowRotate||!t.lastInput.left?!1:this.findToolHandleAt(t.firstInput.documentPoint,this.name)!==null}doActivate(){const t=this.diagram;if(this.adornedObject===null){if(this.handle===null&&(this.handle=this.findToolHandleAt(t.firstInput.documentPoint,this.name)),this.handle===null)return;this.adornedObject=this.handle.part.adornedObject}this.adornedObject===null||this.adornedObject.part===null||(t.isMouseCaptured=!0,t.delaysLayout=!0,this.startTransaction(this.name),this.eM=this.adornedObject.angle,this.zm=this.computeRotationPoint(this.adornedObject),this.Oc=this.adornedObject.part.location.copy(),this.isActive=!0)}computeRotationPoint(t){const e=t.part;if(e!==null){const i=e.locationObject;if(e.rotationSpot.isSpot())return t.getDocumentPoint(e.rotationSpot);if(t===e||t===i)return i.getDocumentPoint(e.locationSpot)}return t.getDocumentPoint(Spot.Center)}computeAdornmentLocation(t){let e=this.rotationPoint;e.isReal()||(e=this.computeRotationPoint(t));const i=t.getLocalPoint(e);let s=this.handleAngle;s=G.Ee(s),s=Math.round(Math.round(s/45)*45);const n=this.handleDistance;return s===0?i.x=t.naturalBounds.width+n:s===45?(i.x=t.naturalBounds.width+n,i.y=t.naturalBounds.height+n):s===90?i.y=t.naturalBounds.height+n:s===135?(i.x=-n,i.y=t.naturalBounds.height+n):s===180?i.x=-n:s===225?(i.x=-n,i.y=-n):s===270?i.y=-n:s===315&&(i.x=t.naturalBounds.width+n,i.y=-n),t.getDocumentPoint(i)}doDeactivate(){const t=this.diagram;this.stopTransaction(),this.handle=null,this.Ms=null,this.zm=new Point(NaN,NaN),t.isMouseCaptured=!1,this.isActive=!1}stopTransaction(){const t=this.diagram,e=super.stopTransaction();return e&&t.undoManager.transactionToUndo!==null&&t.undoManager.transactionToUndo.optimize(),e}doCancel(){const t=this.diagram;t.delaysLayout=!1,this.rotate(this.originalAngle),this.stopTool()}doMouseMove(){const t=this.diagram;if(this.isActive){const e=this.computeRotate(t.lastInput.documentPoint);this.rotate(e)}}doMouseUp(){const t=this.diagram;if(this.isActive){t.delaysLayout=!1;const e=this.computeRotate(t.lastInput.documentPoint);this.rotate(e),t.invalidateDocumentBounds(),this.transactionResult=this.name,t.T("PartRotated",this.adornedObject,this.originalAngle)}this.stopTool()}rotate(t){const e=this.adornedObject;if(e===null||e.part===null)return;e.angle=t;const i=e.part;i.ensureBounds();const s=i.locationObject,n=i.rotateObject;if(s===n||s.isContainedBy(n)){const o=this.Oc.copy();i.location=o.subtract(this.rotationPoint).rotate(t-this.originalAngle).add(this.rotationPoint)}this.diagram.maybeUpdate()}computeRotate(t){let e=this.rotationPoint.directionPoint(t)-this.handleAngle;const i=this.adornedObject?.panel;i&&(e-=i.getDocumentAngle()),e=G.Ee(e);const s=Math.min(Math.abs(this.snapAngleMultiple),180),n=Math.min(Math.abs(this.snapAngleEpsilon),s/2);return!this.diagram.lastInput.shift&&s>0&&n>0&&(e%s<n?e=Math.floor(e/s)*s:e%s>s-n&&(e=(Math.floor(e/s)+1)*s)),G.Ee(e)}get snapAngleMultiple(){return this._S}set snapAngleMultiple(t){U.s(t,"number",RotatingTool,"snapAngleMultiple"),this._S=t}get snapAngleEpsilon(){return this.tM}set snapAngleEpsilon(t){U.s(t,"number",RotatingTool,"snapAngleEpsilon"),this.tM=t}get originalAngle(){return this.eM}get rotationPoint(){return this.zm}set rotationPoint(t){this.zm=t.copy()}get handleAngle(){return this.iM}set handleAngle(t){U.s(t,"number",RotatingTool,"handleAngle"),this.iM=t}get handleDistance(){return this.sM}set handleDistance(t){U.s(t,"number",RotatingTool,"handleDistance"),this.sM=t}}class ClickSelectingTool extends Tool{constructor(t){super(),this.name="ClickSelecting",t&&Object.assign(this,t)}canStart(){return!(!this.isEnabled||this.isBeyondDragSize())}doMouseUp(){this.isActive&&(this.standardMouseSelect(),this.standardMouseClick()||this.diagram.lastInput.isTouchEvent&&this.diagram.toolManager.doToolTip()),this.stopTool()}}class ActionTool extends Tool{Ic;constructor(t){super(),this.name="Action",this.Ic=null,t&&Object.assign(this,t)}canStart(){if(!this.isEnabled)return!1;const t=this.diagram,e=t.lastInput,i=t.findObjectAt(e.documentPoint,s=>{for(;s.panel!==null;){if(s.isActionable)return s;s=s.panel}return s});return i!==null&&i.isActionable?(this.Ic=i,t.Dc=t.findObjectAt(e.documentPoint,null,null),!0):!1}doMouseDown(){if(!this.isActive)this.canStart()&&this.doActivate();else{const e=this.diagram.lastInput,i=this.Ic;if(i===null)return;e.targetObject=i,i.actionDown!==null&&i.actionDown(e,i)}}doMouseMove(){if(this.isActive){const e=this.diagram.lastInput,i=this.Ic;if(i===null)return;e.targetObject=i,i.actionMove!==null&&i.actionMove(e,i)}}doMouseUp(){if(this.isActive){const e=this.diagram.lastInput,i=this.Ic;if(i===null)return;e.targetObject=i,i.actionUp!==null&&i.actionUp(e,i),this.standardMouseClick(s=>{for(;s.panel!==null;){if(s.isActionable&&s===i)return s;s=s.panel}return s},s=>s===i)}this.stopTool()}doCancel(){const e=this.diagram.lastInput,i=this.Ic;i!==null&&(e.targetObject=i,i.actionCancel!==null&&i.actionCancel(e,i),this.stopTool())}doStop(){this.Ic=null}}class ClickCreatingTool extends Tool{Vl;nM;Rc;oM;constructor(t){super(),this.name="ClickCreating",this.Vl=null,this.nM=!0,this.Rc=!1,this.oM=new Point(0,0),t&&Object.assign(this,t)}canStart(){if(!this.isEnabled||this.archetypeNodeData===null)return!1;const t=this.diagram;if(t.isReadOnly||t.isModelReadOnly||!t.allowInsert||!t.lastInput.left||this.isBeyondDragSize())return!1;if(this.isDoubleClick){if(t.lastInput.clickCount===1&&(this.oM=t.lastInput.viewPoint.copy()),t.lastInput.clickCount!==2||this.isBeyondDragSize(this.oM))return!1}else if(t.lastInput.clickCount!==1)return!1;return!(t.currentTool!==this&&t.findPartAt(t.lastInput.documentPoint,!0)!==null)}doMouseUp(){const t=this.diagram;this.isActive&&this.insertPart(t.lastInput.documentPoint),this.stopTool()}insertPart(t){const e=this.diagram,i=this.archetypeNodeData;if(i===null)return null;let s=null;try{if(e.T("ChangingSelection",e.selection),this.startTransaction(this.name),i instanceof Part)i.Di()&&(i.It(),s=i.copy(),s!==null&&e.add(s));else if(i!==null){const n=e.model.copyNodeData(i);e.model.addNodeData(n),s=e.findPartForData(n)}if(s!==null){const n=Point.z(t.x,t.y);this.isGridSnapEnabled&&this.diagram.rM(s,t,n),s.location=n,e.allowSelect&&(e.clearSelection(!0),s.isSelected=!0),Point.i(n)}e.invalidateDocumentBounds(),this.transactionResult=this.name,e.T("PartCreated",s)}finally{this.stopTransaction(),e.T("ChangedSelection",e.selection)}return s}get archetypeNodeData(){return this.Vl}set archetypeNodeData(t){t!==null&&U.wc(t,ClickCreatingTool,"archetypeNodeData"),this.Vl=t}get isDoubleClick(){return this.nM}set isDoubleClick(t){U.s(t,"boolean",ClickCreatingTool,"isDoubleClick"),this.nM=t}get isGridSnapEnabled(){return this.Rc}set isGridSnapEnabled(t){U.s(t,"boolean",ClickCreatingTool,"isGridSnapEnabled"),this.Rc=t}}class DragSelectingTool extends Tool{Qa;lM;Bl;constructor(t){super(),this.name="DragSelecting",this.Qa=175,this.lM=!1,this.Bl=new Part({layerName:"Tool",selectable:!1}).add(new Shape("Rectangle",{name:"SHAPE",fill:null,stroke:"magenta"}).theme("stroke","dragSelect")).It(),t&&Object.assign(this,t)}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;if(!t.allowSelect)return!1;const e=t.lastInput;return!(!e.left||t.currentTool!==this&&(!this.isBeyondDragSize()||e.timestamp-t.firstInput.timestamp<this.delay||t.findPartAt(e.documentPoint,!0)!==null))}doActivate(){const t=this.diagram;this.isActive=!0,t.isMouseCaptured=!0,t.skipsUndoManager=!0,this.box&&t.add(this.box),this.doMouseMove()}doDeactivate(){const t=this.diagram;t.stopAutoScroll(),this.box&&t.remove(this.box),t.skipsUndoManager=!1,t.isMouseCaptured=!1,this.isActive=!1}doMouseMove(){const t=this.diagram;if(this.isActive&&this.box!==null){const e=this.computeBoxBounds();let i=this.box.findObject("SHAPE");i===null&&(i=this.box.findMainElement());const s=Size.l().e(e.width,e.height);i!==null&&(i.desiredSize=s),this.box.Ec(e.x,e.y,!1),Size.i(s),(t.allowHorizontalScroll||t.allowVerticalScroll)&&t.doAutoScroll(t.lastInput.viewPoint)}}doMouseUp(){if(this.isActive){const t=this.diagram;this.box&&t.remove(this.box);try{t.currentCursor="wait",t.T("ChangingSelection",t.selection),this.selectInRect(this.computeBoxBounds()),t.T("ChangedSelection",t.selection)}finally{t.currentCursor=""}}this.stopTool()}computeBoxBounds(){const t=this.diagram;return new Rect(t.firstInput.documentPoint,t.lastInput.documentPoint)}selectInRect(t){const e=this.diagram,i=e.lastInput,s=e.findPartsIn(t,this.isPartialInclusion);if(U.ur?i.meta:i.control)if(i.shift){const n=s.iterator;for(;n.next();){const o=n.value;o.isSelected&&(o.isSelected=!1)}}else{const n=s.iterator;for(;n.next();){const o=n.value;o.isSelected=!o.isSelected}}else if(i.shift){const n=s.iterator;for(;n.next();){const o=n.value;o.isSelected||(o.isSelected=!0)}}else{const n=new List,o=e.selection.iterator;for(;o.next();){const a=o.value;s.has(a)||n.add(a)}const r=n.iterator;for(;r.next();){const a=r.value;a.isSelected=!1}const l=s.iterator;for(;l.next();){const a=l.value;a.isSelected||(a.isSelected=!0)}}}get delay(){return this.Qa}set delay(t){U.s(t,"number",DragSelectingTool,"delay"),this.Qa=t}get isPartialInclusion(){return this.lM}set isPartialInclusion(t){U.s(t,"boolean",DragSelectingTool,"isPartialInclusion"),this.lM=t}get box(){return this.Bl}set box(t){t!==null&&t.It(),this.Bl=t}}class PanningTool extends Tool{Rx;LA;Ro;aM;constructor(t){super(),this.name="Panning",this.Rx=new Point,this.LA=new Point,this.Ro=!1;const e=this;this.aM=()=>{const i=e.diagram;i!==null&&i.Le(root.document,"scroll",e.aM,!1),e.stopTool()},t&&Object.assign(this,t)}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;return!(!t.allowHorizontalScroll&&!t.allowVerticalScroll||!t.lastInput.left||t.currentTool!==this&&!this.isBeyondDragSize())}doActivate(){const t=this.diagram;this.Ro?(t.lastInput.bubbles=!0,t.Et(root.document,"scroll",this.aM,!1)):(t.currentCursor="move",t.isMouseCaptured=!0,this.Rx.h(t.position)),this.isActive=!0}doDeactivate(){const t=this.diagram;t.currentCursor="",t.isMouseCaptured=!1,this.isActive=!1}doCancel(){const t=this.diagram;t.position=this.Rx,t.isMouseCaptured=!1,this.stopTool()}doMouseMove(){this.AA()}doMouseUp(){this.AA(),this.stopTool()}AA(){const t=this.diagram;if(this.isActive&&t){if(this.Ro){t.lastInput.bubbles=!0;return}const e=t.position,i=t.firstInput.documentPoint,s=t.lastInput.documentPoint;let n=e.x+i.x-s.x,o=e.y+i.y-s.y;t.allowHorizontalScroll||(n=e.x),t.allowVerticalScroll||(o=e.y),t.position=this.LA.e(n,o)}}get bubbles(){return this.Ro}set bubbles(t){U.s(t,"boolean",PanningTool,"bubbles"),this.Ro=t}get originalPosition(){return this.Rx}}class HTMLInfo{Ox;Ix;hM;cM;constructor(t){this.Ox=null,this.Ix=null,this.hM=null,this.cM=null,t&&Object.assign(this,t)}get mainElement(){return this.hM}set mainElement(t){t!==null&&U.se(t,HTMLElement,HTMLInfo,"mainElement"),this.hM=t}get show(){return this.Ox}set show(t){this.Ox!==t&&(t!==null&&U.S(t,HTMLInfo,"show"),this.Ox=t)}get hide(){return this.Ix}set hide(t){this.Ix!==t&&(t!==null&&U.S(t,HTMLInfo,"hide"),this.Ix=t)}get valueFunction(){return this.cM}set valueFunction(t){this.cM=t}}class ContextMenuButtonInfo{ue;Ex;Uc;constructor(t,e,i){this.ue=t,this.Ex=e,this.Uc=i}}class ContextMenuTool extends Tool{fM;Ux;uM;dM;Vx;Bx;Xm;constructor(t){super(),this.name="ContextMenu",this.fM=null,this.Ux=null,this.uM=null,this.dM=new Point,this.Vx=null,this.Xm=!1;const e=this;this.Bx=()=>e.stopTool(),t&&Object.assign(this,t)}xR(){const t=new HTMLInfo;t.show=(r,l,a)=>a.showDefaultContextMenu(),t.hide=(r,l)=>l.hideDefaultContextMenu(),ContextMenuTool.Bu=t;const e=this;this.Bx=()=>e.stopTool();const i=U.Ni("div"),s=U.Ni("div");i.style.cssText="top: 0px;z-index:10002;position: fixed;display: none;text-align: center;left: 25%;width: 50%;background-color: #F5F5F5;padding: 16px;border: 16px solid #444;border-radius: 10px;margin-top: 10px",s.style.cssText="z-index:10001;position: fixed;display: none;top: 0;left: 0;width: 100%;height: 100%;background-color: black;opacity: 0.8;";const n=U.Ni("style");root.document.getElementsByTagName("head")[0].appendChild(n),n.sheet.insertRule(".goCXul { list-style: none; }",0),n.sheet.insertRule(".goCXli {font:700 1.5em Helvetica, Arial, sans-serif;position: relative;min-width: 60px; }",0),n.sheet.insertRule(".goCXa {color: #444;display: inline-block;padding: 4px;text-decoration: none;margin: 2px;border: 1px solid gray;border-radius: 10px; }",0);const o=this.diagram;o!==null&&(o.Et(i,"contextmenu",ContextMenuTool.ih,!1),o.Et(i,"selectstart",ContextMenuTool.ih,!1),o.Et(s,"contextmenu",ContextMenuTool.ih,!1)),i.className="goCXforeground",s.className="goCXbackground",root.document.body&&(root.document.body.appendChild(i),root.document.body.appendChild(s)),ContextMenuTool.Gm=i,ContextMenuTool.Ym=s,ContextMenuTool.gM=!0}static Bu=null;static gM=!1;static Ym;static Gm;static ih(t){return t.preventDefault(),!1}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;return this.isBeyondDragSize()||!t.lastInput.right||t.lastInput.clickCount>1?!1:!!(t.lastInput.isTouchEvent&&this.defaultTouchContextMenu!==null||this.findObjectWithContextMenu()!==null)}doStart(){const t=this.diagram;this.dM.set(t.firstInput.documentPoint)}doStop(){this.hideContextMenu(),this.currentObject=null,this.Xm=!1}findObjectWithContextMenu(t){t===void 0&&(t=null);const e=this.diagram,i=e.lastInput;let s=null;if(t instanceof Diagram||(t instanceof GraphObject?s=t:s=e.findObjectAt(i.documentPoint,null,n=>!n.layer?.isTemporary)),s!==null){let n=s;for(;n!==null;){if(n.contextMenu!==null)return n;n=n.panel}if(e.lastInput.isTouchEvent&&this.defaultTouchContextMenu)return s.part}else if(e.contextMenu!==null)return e;return null}doActivate(){}doMouseDown(){if(super.doMouseDown(),this.isActive&&this.currentContextMenu instanceof Adornment){const t=this.diagram.toolManager.findTool("Action");t!==null&&t.canStart()&&(t.doActivate(),t.doMouseDown(),t.doDeactivate())}this.diagram.toolManager.mouseDownTools.has(this)&&this.doContextClick()}doMouseUp(){if(this.isActive&&this.currentContextMenu instanceof Adornment){const t=this.diagram.toolManager.findTool("Action");t!==null&&t.canStart()&&(t.doActivate(),t.doCancel(),t.doDeactivate())}this.doContextClick()}doContextClick(){const t=this.diagram;if(!this.isActive)this.canStart()&&(this.openMenu(!0),this.isActive||this.stopTool());else{const e=this.currentContextMenu;if(e===null)return;let i=null;e instanceof HTMLInfo||(i=t.findObjectAt(t.lastInput.documentPoint,null,null),i!==null&&i.isContainedBy(e)&&this.standardMouseClick(null,null)),this.maybeStopTool(i)}}maybeStopTool(t){this.stopTool(),this.canStart()&&(this.diagram.currentTool=this,this.doMouseUp())}openMenu(t,e){if(e===void 0&&(e=null),this.Xm)return;this.Xm=!0;let i=!1;if(e instanceof Diagram){const s=this.diagram.lastInput;s.targetObject=null,i=this.oA(null,s,this.diagram)}else t&&this.standardMouseSelect(),i=this.standardMouseClick();if(this.Xm=!1,!i){this.isActive=!0;const s=ContextMenuTool.Bu;if(e===null&&(e=this.findObjectWithContextMenu()),e!==null){const n=e.contextMenu;n!==null?(this.currentObject=e instanceof GraphObject?e:null,this.showContextMenu(n,this.currentObject)):s!==null&&this.showContextMenu(s,this.currentObject)}else s!==null&&this.showContextMenu(s,null);this.currentContextMenu instanceof Adornment&&!this.currentContextMenu.visible&&this.stopTool()}}doMouseMove(){const t=this.diagram.toolManager.findTool("Action");t!==null&&t.doMouseMove(),this.isActive&&this.diagram.toolManager.doMouseMove()}showContextMenu(t,e){e!==null&&U.se(e,GraphObject,ContextMenuTool,"showContextMenu:obj");const i=this.diagram;if(t!==this.currentContextMenu&&this.hideContextMenu(),t instanceof Adornment){const s=t;s.layerName="Tool",s.selectable=!1,s.scale=1/i.scale,s.category=this.name,s.hasPlaceholder()&&(s.placeholder.scale=i.scale);const n=s.diagram;n!==null&&n!==i&&n.remove(s),i.add(s),e!==null?s.adornedObject=e:s.data=i.model,s.ensureBounds(),this.positionContextMenu(s,e)}else t instanceof HTMLInfo&&t.show!==null&&t.show(e,i,this);this.currentContextMenu=t}positionContextMenu(t,e){if(t.hasPlaceholder())return;const i=t,s=this.diagram,n=s.lastInput.documentPoint.copy(),o=i.measuredBounds,r=s.viewportBounds;s.lastInput.isTouchEvent&&(n.x-=o.width),n.x+o.width>r.right&&(n.x-=o.width+5/s.scale),n.x<r.x&&(n.x=r.x),n.y+o.height>r.bottom&&(n.y-=o.height+5/s.scale),n.y<r.y&&(n.y=r.y),i.position=n}hideContextMenu(){const t=this.diagram,e=this.currentContextMenu;e!==null&&(e instanceof Adornment?(t.remove(e),this.Ux!==null&&this.Ux.removeAdornment(e.category),e.data=null,e.adornedObject=null):e instanceof HTMLInfo&&(e.hide!==null?e.hide(t,this):e.mainElement!==null&&(e.mainElement.style.display="none")),this.currentContextMenu=null,this.standardMouseOver())}bR(){const t=this,e=new List;return e.add(new ContextMenuButtonInfo("Copy",i=>i.commandHandler.copySelection(),i=>i.commandHandler.canCopySelection())),e.add(new ContextMenuButtonInfo("Cut",i=>i.commandHandler.cutSelection(),i=>i.commandHandler.canCutSelection())),e.add(new ContextMenuButtonInfo("Delete",i=>i.commandHandler.deleteSelection(),i=>i.commandHandler.canDeleteSelection())),e.add(new ContextMenuButtonInfo("Paste",i=>i.commandHandler.pasteSelection(t.mouseDownPoint),i=>i.commandHandler.canPasteSelection(t.mouseDownPoint))),e.add(new ContextMenuButtonInfo("Select All",i=>i.commandHandler.selectAll(),i=>i.commandHandler.canSelectAll())),e.add(new ContextMenuButtonInfo("Undo",i=>i.commandHandler.undo(),i=>i.commandHandler.canUndo())),e.add(new ContextMenuButtonInfo("Redo",i=>i.commandHandler.redo(),i=>i.commandHandler.canRedo())),e.add(new ContextMenuButtonInfo("Scroll To Part",i=>i.commandHandler.scrollToPart(),i=>i.commandHandler.canScrollToPart())),e.add(new ContextMenuButtonInfo("Zoom To Fit",i=>i.commandHandler.zoomToFit(),i=>i.commandHandler.canZoomToFit())),e.add(new ContextMenuButtonInfo("Reset Zoom",i=>i.commandHandler.resetZoom(),i=>i.commandHandler.canResetZoom())),e.add(new ContextMenuButtonInfo("Group Selection",i=>i.commandHandler.groupSelection(),i=>i.commandHandler.canGroupSelection())),e.add(new ContextMenuButtonInfo("Ungroup Selection",i=>i.commandHandler.ungroupSelection(),i=>i.commandHandler.canUngroupSelection())),e.add(new ContextMenuButtonInfo("Edit Text",i=>i.commandHandler.editTextBlock(),i=>i.commandHandler.canEditTextBlock())),e}showDefaultContextMenu(){const t=this.diagram;this.Vx===null&&(this.Vx=this.bR()),ContextMenuTool.Gm.innerHTML="",ContextMenuTool.Ym.addEventListener("pointerdown",this.Bx,!1);const e=this,i=U.Ni("ul");i.className="goCXul",ContextMenuTool.Gm.appendChild(i),i.innerHTML="";const s=this.Vx.iterator;for(;s.next();){const n=s.value,o=n.Ex,r=n.Uc;if(!U.nt(o)||U.nt(r)&&!r(t))continue;const l=U.Ni("li");l.className="goCXli";const a=U.Ni("a");a.className="goCXa",a.href="#",a.Ex=o,a.addEventListener("pointerdown",function(h){return this.Ex(t),e.stopTool(),h.preventDefault(),!1},!1),a.textContent=n.ue,l.appendChild(a),i.appendChild(l)}ContextMenuTool.Gm.style.display="block",ContextMenuTool.Ym.style.display="block"}hideDefaultContextMenu(){if(this.currentContextMenu===null||this.currentContextMenu!==ContextMenuTool.Bu)return;ContextMenuTool.Gm.style.display="none",ContextMenuTool.Ym.style.display="none";const t=this.diagram;t!==null&&t.Le(ContextMenuTool.Ym,"pointerdown",this.Bx,!1),this.currentContextMenu=null}doMouseWheel(){this.standardMouseWheel()}get currentContextMenu(){return this.fM}set currentContextMenu(t){this.fM=t,this.Ux=t instanceof Adornment?t.adornedPart:null}get defaultTouchContextMenu(){return ContextMenuTool.gM===!1&&ContextMenuTool.Bu===null&&Diagram.isUsingDOM()&&this.xR(),ContextMenuTool.Bu}set defaultTouchContextMenu(t){t===null&&(ContextMenuTool.gM=!0),ContextMenuTool.Bu=t}get currentObject(){return this.uM}set currentObject(t){t!==null&&U.se(t,GraphObject,ContextMenuTool,"currentObject"),this.uM=t}get mouseDownPoint(){return this.dM}}var TextEditingAccept=(w=>(w[w.LostFocus=1]="LostFocus",w[w.MouseDown=2]="MouseDown",w[w.Tab=3]="Tab",w[w.Enter=4]="Enter",w))(TextEditingAccept||{}),TextEditingStarting=(w=>(w[w.SingleClick=1]="SingleClick",w[w.SingleClickSelected=2]="SingleClickSelected",w[w.DoubleClick=3]="DoubleClick",w))(TextEditingStarting||{}),TextEditingState=(w=>(w[w.None=1]="None",w[w.Active=2]="Active",w[w.Editing=3]="Editing",w[w.Validating=4]="Validating",w[w.Invalid=5]="Invalid",w[w.Validated=6]="Validated",w))(TextEditingState||{});class TextEditingTool extends Tool{vi;mM;pM;zl;Gt;yM;wM;xM;zx;Xx;constructor(t){super(),this.name="TextEditing",this.vi=new TextBlock,this.mM=null,this.pM=2,this.zl=null,this.Gt=1,this.yM=1,this.wM=!0,this.xM=null,this.zx=new HTMLInfo,this.Xx=null,this.kR(this.zx),t&&Object.assign(this,t)}static LostFocus=1;static MouseDown=2;static Tab=3;static Enter=4;static SingleClick=1;static SingleClickSelected=2;static DoubleClick=3;static StateNone=1;static StateActive=2;static StateEditing=3;static StateValidating=4;static StateInvalid=5;static StateValidated=6;kR(t){if(!Diagram.isUsingDOM())return;const e=U.Ni("textarea");this.Xx=e;const i=this;e.addEventListener("input",function(s){if(i.textBlock===null)return;const n=i.measureTemporaryTextBlock(this.value),o=this.textScale;this.style.width=20+Math.max(i.textBlock.measuredBounds.width,n.measuredBounds.width)*o+"px",this.rows=Math.max(i.textBlock.lineCount,n.lineCount)},!1),e.addEventListener("keydown",function(s){if(s.isComposing||i.textBlock===null)return;const n=s.key;if(n==="Enter"){i.textBlock.isMultiline===!1&&s.preventDefault(),i.acceptText(4);return}else if(n==="Tab"){i.acceptText(3),s.preventDefault();return}else n==="Escape"&&(i.doCancel(),i.diagram!==null&&i.diagram.doFocus())},!1),e.addEventListener("focus",function(s){i.PR(s)},!1),e.addEventListener("blur",function(s){i.SR(s)},!1),t.valueFunction=()=>e.value,t.mainElement=e,t.show=(s,n,o)=>{if(!(s instanceof TextBlock)||!n||!n.div||!(o instanceof TextEditingTool))return;if(o.state===5){e.style.border="3px solid red",e.focus();return}const r=s.getDocumentPoint(Spot.Center),l=n.position,a=n.scale;let h=s.getDocumentScale()*a;h<o.minimumEditorScale&&(h=o.minimumEditorScale);const c=s.naturalBounds.width*h+6,f=s.naturalBounds.height*h+2,u=(r.x-l.x)*a,d=(r.y-l.y)*a,m=s.verticalAlignment,p=(s.lineHeight+s.spacingAbove+s.spacingBelow)*s.lineCount*h,y=.5*f-.5*p,x=m.y*f-m.y*p+m.offsetY-y-p/2;e.value=s.text,n.div.style.font=s.font;const k=1;e.style.position="absolute",e.style.zIndex="100",e.style.font="inherit",e.style.fontSize=h*100+"%",e.style.lineHeight="normal",e.style.width=c+"px",e.style.left=(u-c/2|0)-k+"px",e.style.top=(d+x|0)-k+"px",e.style.textAlign=s.textAlign,e.style.margin="0",e.style.padding=k+"px",e.style.border="0",e.style.outline="none",e.style.whiteSpace="pre-wrap",e.style.overflow="hidden",e.rows=s.lineCount,e.textScale=h,e.className="goTXarea",n.div.appendChild(e),e.focus(),o.selectsTextOnActivate&&(e.select(),e.setSelectionRange(0,9999))},t.hide=(s,n)=>{s.div&&s.div.removeChild(e)}}get textBlock(){return this.mM}set textBlock(t){t!==null&&U.se(t,TextBlock,TextEditingTool,"textBlock"),this.mM=t}get currentTextEditor(){return this.xM}set currentTextEditor(t){this.xM=t}get defaultTextEditor(){return this.zx}set defaultTextEditor(t){this.zx=t}get starting(){return this.pM}set starting(t){this.pM=t}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;if(t===null||t.isReadOnly||TextEditingTool.Vc&&TextEditingTool.Vc!==this&&(TextEditingTool.Vc.acceptText(2),TextEditingTool.Vc&&TextEditingTool.Vc!==this)||!t.lastInput.left||this.isBeyondDragSize())return!1;const e=t.lastInput.documentPoint,i=t.findObjectAt(e);if(i===null||!(i instanceof TextBlock)||!i.editable||i.part===null||!i.part.canEdit())return!1;const s=i.part;return!(s===null||this.starting===2&&!s.isSelected||this.starting===3&&t.lastInput.clickCount<2)}doStart(){TextEditingTool.Vc=this,this.textBlock!==null&&this.doActivate()}doActivate(){if(this.isActive)return;const t=this.diagram;if(t===null)return;let e=this.textBlock;if(e===null&&(e=t.findObjectAt(t.lastInput.documentPoint)),e===null||!(e instanceof TextBlock)||(this.textBlock=e,e.part===null))return;t.animationManager.stopAnimation(),this.isActive=!0,this.Gt=2;let s=this.defaultTextEditor;e.textEditor!==null&&(s=e.textEditor),this.vi=this.textBlock.copy();const n=new Rect(this.textBlock.getDocumentPoint(Spot.TopLeft),this.textBlock.getDocumentPoint(Spot.BottomRight));t.scrollToRect(n),s!==null&&s.show!==null&&s.show(e,t,this),this.currentTextEditor=s}doCancel(){this.stopTool()}doMouseUp(){this.canStart()&&this.doActivate()}doMouseDown(){this.isActive&&this.acceptText(2)}acceptText(t){switch(t){case 2:this.Gt===6?this.currentTextEditor instanceof HTMLElement&&this.currentTextEditor.focus():(this.Gt===2||this.Gt===5||this.Gt===3)&&(this.Gt=4,this.TA());break;case 1:case 4:case 3:if(t===4&&this.textBlock!==null&&this.textBlock.isMultiline===!0)return;(this.Gt===2||this.Gt===5||this.Gt===3)&&(this.Gt=4,this.TA());break}}TA(){const t=this.textBlock,e=this.diagram,i=this.currentTextEditor;if(t!==null&&i!==null){const s=t.text;let n="";if(i.valueFunction!==null&&(n=i.valueFunction()),!this.isValidText(t,s,n)){this.Gt=5,this.doError(s,n);return}this.startTransaction(this.name),this.Gt=6,this.transactionResult=this.name,t.text=n,this.doSuccess(s,n),e!==null&&e.T("TextEdited",t,s),this.stopTransaction(),this.stopTool(),e!==null&&e.doFocus()}}doError(t,e){const i=this.textBlock;if(i===null)return;i.errorFunction!==null&&i.errorFunction(this,t,e);const s=this.currentTextEditor;s!==null&&s.show!==null&&s.show(i,this.diagram,this)}doSuccess(t,e){const i=this.textBlock;i!==null&&i.textEdited!==null&&i.textEdited(i,t,e)}doDeactivate(){const t=this.diagram;if(t!==null){if(this.Gt=1,this.currentTextEditor!==null){const e=this.currentTextEditor;e!==null&&e.hide!==null&&e.hide(t,this)}this.textBlock=null,this.isActive=!1}}doStop(){TextEditingTool.Vc=null}PR(t){if(this.currentTextEditor===null||this.state===1)return;const e=this.Xx;this.Gt===2&&(this.Gt=3),U.nt(e.select)&&this.selectsTextOnActivate&&(e.select(),e.setSelectionRange(0,9999))}SR(t){if(this.currentTextEditor===null||this.state===1)return;const e=this.Xx;U.nt(e.focus)&&e.focus(),U.nt(e.select)&&this.selectsTextOnActivate&&(e.select(),e.setSelectionRange(0,9999))}isValidText(t,e,i){const s=this.textValidation;if(s!==null&&!s(t,e,i))return!1;const n=t.textValidation;return!(n!==null&&!n(t,e,i))}get textValidation(){return this.zl}set textValidation(t){t!==null&&U.S(t,TextEditingTool,"textValidation"),this.zl=t}get minimumEditorScale(){return this.yM}set minimumEditorScale(t){t!==null&&U.s(t,"number",TextEditingTool,"minimumEditorScale"),this.yM=t}get selectsTextOnActivate(){return this.wM}set selectsTextOnActivate(t){t!==null&&U.s(t,"boolean",TextEditingTool,"selectsTextOnActivate"),this.wM=t}get state(){return this.Gt}set state(t){this.Gt!==t&&(this.Gt=t)}measureTemporaryTextBlock(t){const e=this.vi;return e.text=t,this.textBlock!==null&&e.ht(this.textBlock.Xl,1/0),e}static Vc=null}var AnimationStyle=(w=>(w[w.Default=1]="Default",w[w.AnimateLocations=2]="AnimateLocations",w[w.None=3]="None",w))(AnimationStyle||{});class AnimationManager{a;Ae;Be;Tr;_n;Io;bM;kM;Km;Gx;ke;Bc;bn;Hm;nh;Yx;jm;Kx;zc;Uu;qm;constructor(t){this.a=Diagram.Rm(),this.Ae=!1,this.Km=!1,this.Gx=!1,this.ke=!1,this.Bc=!1,this.Kx=!0,this.zc=1,this.Uu=!1,this.Be=!0,this.Tr=!0,this.Io=600,this.bM=!1,this.kM=!1,this._n=new GSet,this.bn=new Animation,this.Hm=new Animation,this.bn.Ns=this,this.nh=new GSet,this.Yx=new GSet,this.jm=new GSet,this.qm=new GSet,t&&Object.assign(this,t)}Eo(t){this.a=t}RU(){return this.a}canStart(t){return!0}Gl(t){return!this.Be||!this.canStart(t)?!1:(this._n.add(t),this.defaultAnimation.isAnimating&&this.stopAnimation(),this.a.Te(),this.ke=!0,!0)}getBundleAnimation(){return this.Hm}PM(){if(!this.Be||(this.Hm.pi.count>0&&this.Hm.start(),!this.ke))return;const t=this.bn,e=this.a,i=this._n.has("Model");if(i&&(this.Bc=!0,this.zc===1?(t.isViewportUnconstrained=!0,t.pi.clear(),t.add(e,"position",e.position.copy().offset(0,-200),e.position),t.add(e,"opacity",0,1)):this.zc===3&&t.pi.clear(),this.zc===2&&e.Hx.equals(e.ct)?this.Kx=!0:this.Kx=!1,e.T("InitialAnimationStarting",this)),i&&!this.Tr||t.pi.count===0){this._n.clear(),this.ke=!1,t.pi.clear(),t.jx(e),this.Bc=!1,e.C();return}this._n.clear(),e.Dr=!1;const s=t.pi.get(e);e.autoScale!==1&&s!==null&&(delete s.ae.scale,delete s.Cs.scale);const n=this;root.requestAnimationFrame(()=>{n.ke===!1||t.Ae||(e.getRenderingHint("temporaryPixelRatio")&&e.Nx(),e.SM(),n.ke=!1,t.start(),t.Ae&&(n.zu(),e.invalidateDocumentBounds(),t.DA(0),e.Sr(!0),n.Xu(),e.T("AnimationStarting",n)))})}MM(){return this._n.has("Trigger")&&this._n.count===1}vA(t,e,i,s){this.isTicking||this.MM()||t instanceof Link&&(t.fromNode!==null||t.toNode!==null)||this.bn.add(t,"position",e,i,s)}qx(t){return this.bn.qx(t)}NM(t){return this.bn.NM(t)}MR(t){const e=this.nh,i=this;function s(){if(i.jm.count>0&&(e.addAll(i.jm),i.jm.clear(),i.Ae=!0),i.Ae===!1||e.count===0){i.Gx=!1;return}i.Yx.addAll(e);const n=i.Yx.iterator;for(;n.next();){const o=n.value;o.Ae!==!1&&(o.NR()?o.FA(!1):o.Xc=!0)}if(i.Yx.clear(),i.Ae===!1){root.requestAnimationFrame(s);return}i.zu(),i.a.Sr(),i.Xu(),root.requestAnimationFrame(s)}this.Ae?this.RA(t):(this.Ae=!0,this.Gx?this.RA(t):(this.Gx=!0,e.add(t),root.requestAnimationFrame(()=>s())))}RA(t){this.jm.add(t)}CR(){const t=this.nh.iterator;for(;t.next();)t.value.Xc=!1}zu(){if(this.Km)return;const t=this.a;this.bM=t.skipsUndoManager,this.kM=t.yi,t.skipsUndoManager=!0,t.yi=!0,this.Km=!0}Xu(){const t=this.a;t.skipsUndoManager=this.bM,t.yi=this.kM,this.Km=!1}stopAnimation(t){const e=this.bn;if(this.ke===!0&&(this.ke=!1,this.Bc=!1,this._n.clear(),e.LR()&&this.a.requestUpdate()),!this.Ae){e.pi.clear(),e.jx(this.a);return}if(e.Gu(!0),e.jx(null),t===!0){const i=this.nh.toArray();for(let s=0;s<i.length;s++)i[s].Gu(!0)}}Gu(t){this.nh.delete(t),this.nh.count===0&&(this.Ae=!1,this.a.requestUpdate()),t===this.defaultAnimation&&this.a.T("AnimationFinished",this)}Gc(t,e){this.ke&&(!this._n.has("Expand Tree")&&!this._n.has("Expand SubGraph")||(this.bn.Gc(t,e),this.OA(t)))}Yc(t,e){this.ke&&(!this._n.has("Collapse Tree")&&!this._n.has("Collapse SubGraph")||(this.bn.Yc(t,e),this.bn.CM(e,"position",e.position,e.position),this.OA(t)))}IA(t,e){!this.ke||t.equals(e)||this.MM()||(this.a.$a||(t=e.copy()),this.bn.CM(this.a,"position",t,e))}EA(t,e){this.ke&&(this.MM()||this.bn.add(this.a,"scale",t,e))}LM(t,e){t.Fi&&(t.vr=e,this.qm.add(t))}OA(t){const e=t.findLinksConnected();for(;e.next();){const i=e.value;i.Fi&&(i.vr=i.points.copy(),this.qm.add(i))}}get isEnabled(){return this.Be}set isEnabled(t){U.s(t,"boolean",AnimationManager,"isEnabled"),this.Be=t,t&&this.nh.each(e=>{!e.isAnimating&&e.runCount===1/0&&e.start()})}get duration(){return this.Io}set duration(t){U.s(t,"number",AnimationManager,"duration"),t<1&&U.J(t,">= 1",AnimationManager,"duration"),this.Io=t}get isAnimating(){return this.Ae}get isTicking(){return this.Km}get isInitial(){return this.Tr}set isInitial(t){U.s(t,"boolean",AnimationManager,"isInitial"),this.Tr=t}get defaultAnimation(){return this.bn}get activeAnimations(){return this.nh}get initialAnimationStyle(){return this.zc}set initialAnimationStyle(t){this.zc=t}static Wx=new GMap;static defineAnimationEffect(t,e){AnimationManager.Wx.set(t,e)}static AM(t,e,i,s,n){t===null&&(t=[0,0,0,0]),e===null&&(e=[0,0,0,0]);let o=t[0],r=t[1];const l=t[2],a=t[3];let h=e[0],c=e[1];const f=e[2],u=e[3];l===0||l===100?(o=h,r=c):(f===0||f===100)&&(h=o,c=r),Math.abs(h-o)>180&&(h>o?o+=360:h+=360);const d=n(i,o,h-o,s)%360,m=n(i,r,c-r,s),g=n(i,l,f-l,s),p=n(i,a,u-a,s);return"hsla("+d+", "+m+"%, "+g+"%, "+p+")"}static Default=1;static AnimateLocations=2;static None=3}{const w=AnimationManager.Wx,t=(e,i,s,n,o,r)=>{e.position=new Point(n(o,i.x,s.x-i.x,r),n(o,i.y,s.y-i.y,r))};w.set("position:diagram",t),w.set("position",t),w.set("position:part",(e,i,s,n,o,r)=>{o<r?e.Ec(n(o,i.x,s.x-i.x,r),n(o,i.y,s.y-i.y,r),!1):e.position=new Point(n(o,i.x,s.x-i.x,r),n(o,i.y,s.y-i.y,r))}),w.set("location",(e,i,s,n,o,r)=>{o<r?e.Ec(n(o,i.x,s.x-i.x,r),n(o,i.y,s.y-i.y,r),!0):e.location=new Point(n(o,i.x,s.x-i.x,r),n(o,i.y,s.y-i.y,r))}),w.set("position:placeholder",(e,i,s,n,o,r)=>{o<r?e.Ec(n(o,i.x,s.x-i.x,r),n(o,i.y,s.y-i.y,r),!1):e.position=new Point(n(o,i.x,s.x-i.x,r),n(o,i.y,s.y-i.y,r))}),w.set("position:nodeCollapse",(e,i,s,n,o,r)=>{const l=e.actualBounds,a=s.actualBounds,h=a.x+a.width/2-l.width/2,c=a.y+a.height/2-l.height/2;o<r?e.Ec(n(o,i.x,h-i.x,r),n(o,i.y,c-i.y,r),!1):e.position=new Point(n(o,i.x,h-i.x,r),n(o,i.y,c-i.y,r))}),w.set("desiredSize",(e,i,s,n,o,r)=>{e.desiredSize=new Size(n(o,i.width,s.width-i.width,r),n(o,i.height,s.height-i.height,r))}),w.set("width",(e,i,s,n,o,r)=>{e.width=n(o,i,s-i,r)}),w.set("height",(e,i,s,n,o,r)=>{e.height=n(o,i,s-i,r)}),w.set("fill",(e,i,s,n,o,r)=>{e.fill=AnimationManager.AM(i,s,o,r,n)}),w.set("stroke",(e,i,s,n,o,r)=>{e.stroke=AnimationManager.AM(i,s,o,r,n)}),w.set("strokeWidth",(e,i,s,n,o,r)=>{e.strokeWidth=n(o,i,s-i,r)}),w.set("strokeDashOffset",(e,i,s,n,o,r)=>{e.strokeDashOffset=n(o,i,s-i,r)}),w.set("background",(e,i,s,n,o,r)=>{e.background=AnimationManager.AM(i,s,o,r,n)}),w.set("opacity",(e,i,s,n,o,r)=>{e.opacity=n(o,i,s-i,r)}),w.set("scale",(e,i,s,n,o,r)=>{e.scale=n(o,i,s-i,r)}),w.set("angle",(e,i,s,n,o,r)=>{e.angle=n(o,i,s-i,r)})}class Animation{Jx;Wm;Ae;Yu;Io;Ls;UA;Kc;pi;$x;ae;to;Ku;Hc;Zx;Qx;Xc;TM;_x;Ns;a;DM;vM;FM;constructor(t){this.a=null,this.Ns=null,this.TM=null,this._x=null,this.DM=!1,this.Ae=!1,this.Xc=!1,this.ae=0,this.to=0,this.Jx=Animation.EaseInOutQuad,this.Wm=Animation.EaseInOutQuad,this.Ku=!1,this.Hc=!1,this.Zx=1,this.Qx=0,this.Io=NaN,this.Ls=NaN,this.vM=0,this.Yu=null,this.UA=Point.gn,this.pi=new GMap,this.$x=new GMap,this.Kc=new GSet,this.FM=1,t&&Object.assign(this,t)}suspend(){this.Xc=!0}advanceTo(t,e){e&&(this.Xc=!1),this.Ku&&t>=this.Ls&&(this.Hc=!0,t=t-this.Ls),this.vM=t,this.FA(!0),this.Ns.zu(),this.a.Sr(),this.Ns.Xu(),this.a.redraw()}jx(t){if(this.$x.clear(),this.Hc=!1,this.Qx=0,this.Ls=NaN,this.Kc.count>0&&this.Kc.clear(),t!==null){const e=t.links;for(;e.next();)e.value.vr=null}}LR(){return this.pi.count>0}start(){if(this.pi.count===0)return this;if(this.Ae)return this;let t=this.a;const e=this.pi.iterator;for(;e.next();){const s=e.key;t===null&&(s instanceof Diagram?t=s:s instanceof GraphObject&&(t=s.diagram))}if(t!==null)this.a=t,this.Ns=t.animationManager;else return this;const i=this.Ns;return i.isEnabled===!1?this:(this.Ls=isNaN(this.Io)?i.duration:this.Io,this.Wm=this.Jx,i.Bc&&i.zc===1&&this===i.defaultAnimation&&(this.Wm=Animation.EaseOutExpo,this.Ls=isNaN(this.Io)?i.duration===600?900:i.duration:this.Io),this.FM=t.scrollMode,this.isViewportUnconstrained&&(t.oh=2),i.zu(),this.Kc.each(s=>{s.data=null,t.add(s)}),i.Xu(),this.Ae=!0,this.ae=+new Date,this.to=this.ae+this.Ls,i.MR(this),this)}addTemporaryPart(t,e){return t.Di()?(this.Kc.add(t),this.a=e,this):this}add(t,e,i,s,n){if(this.a===null&&(t instanceof Diagram?this.a=t:t instanceof GraphObject&&t.diagram!==null&&(this.a=t.diagram)),t instanceof Part){if(!t.isAnimated)return this;e==="position"&&(e="position:part")}return this.CM(t,e,i,s,n),this}CM(t,e,i,s,n){const o=this.pi;let r,l,a;if(t instanceof Diagram&&e==="position"&&(e="position:diagram"),(e==="fill"||e==="stroke"||e==="background")&&(Brush.Uo(i),Brush.RM(),i=[Brush.ze.n0,Brush.ze.n1,Brush.ze.n2,Brush.ze.n3],Brush.Uo(s),Brush.RM(),s=[Brush.ze.n0,Brush.ze.n1,Brush.ze.n2,Brush.ze.n3]),o.has(t))r=o.get(t),l=r.ae,a=r.Cs,l[e]===void 0&&(l[e]=this.Hu(i)),a[e]=this.Hu(s);else{if(e==="position"&&i.equalsApprox(s))return;l={},a={},l[e]=this.Hu(i),a[e]=this.Hu(s),r=new AnimationState(l,a,n),o.set(t,r)}const h=l[e];h instanceof Point&&!h.isReal()&&h.h(this.UA),n&&e.indexOf("position:")===0&&t instanceof Part?r.tb.location=this.Hu(t.location):n&&(r.tb[e]=this.Hu(i))}Hu(t){return t instanceof Point||t instanceof Size?t.copy():t}AR(t){const e=this.pi;if(e.has(t)){const i=e.get(t);i.eb=!0}}qx(t){if(!this.Ae)return!1;const e=this.pi.get(t);return e!==null&&e.eb}NM(t){if(!this.Ae)return!1;const e=this.pi.get(t);return e!==null&&!!(e.ae.position||e.ae["position:part"]||e.ae.location)}NR(){if(this.Kc.count>0)return!0;const t=this.pi.iterator;for(;t.next();){const e=t.key;if(e instanceof GraphObject&&e.diagram!==null||e instanceof Diagram)return!0}return!1}FA(t){if(this.Xc&&!t)return;const e=this.Ns;if(this.Ae===!1)return;const i=+new Date;let s=i>this.to?this.Ls:i-this.ae;t&&(s=this.vM,s<this.Ls?(this.ae=+new Date-s,this.to=this.ae+this.Ls):s=this.Ls),e.zu(),this.DA(s),this.a.Sr(!0),e.Xu(),i>this.to&&(this.Ku&&!this.Hc?(this.ae=+new Date,this.to=this.ae+this.Ls,this.Hc=!0):this.Gu(!1))}DA(t){const e=this.Ls,i=this.pi.iterator,s=this.Hc;for(;i.next();){const n=i.key;if(n instanceof GraphObject&&n.diagram===null)continue;const o=i.value,r=s?o.Cs:o.ae,l=s?o.ae:o.Cs,a=AnimationManager.Wx;for(const h in l)h==="position"&&(l["position:placeholder"]||l["position:nodeCollapse"])||a.get(h)!==null&&a.get(h)(n,r[h],l[h],this.Wm,t,e,this)}}stop(){return this.Ae?(this.Gu(!0),this):this}Gu(t){if(this._x!==null&&this._x.TR(this.TM),!this.Ae)return;const e=this.a,i=this.Ns;i.Bc=!1,this.Ae=!1,this.Xc=!1,i.zu();const s=this.pi,n=this.Kc.iterator;for(;n.next();)e.remove(n.value);const o=this.Ku,r=s.iterator,l=AnimationManager.Wx;for(;r.next();){const h=r.key,c=r.value,f=o?c.Cs:c.ae,u=o?c.ae:c.Cs,d=c.tb;for(const m in u)if(l.get(m)!==null){let g=m;c.ib&&(g==="position:nodeCollapse"||g==="position:placeholder")&&(g="position"),l.get(g)(h,f[m],d[m]!==void 0?d[m]:c.ib?f[m]:u[m],this.Wm,this.Ls,this.Ls,this)}c.ib&&d.location!==void 0&&h instanceof Part&&(h.location=d.location),c.eb&&h instanceof Part&&h.Xe(!1)}this.Qx++;const a=!t&&this.Zx>this.Qx;if(!a&&(this===i.Hm||this===i.defaultAnimation)&&this.pi.clear(),e.sb.clear(),e.pS(!1),e.invalidateDocumentBounds(),e.C(),e.Sr(!0),i.defaultAnimation===this){const h=i.qm.iterator;for(;h.next();)h.value.DR();i.qm.clear()}if(e.Sr(!0),this.isViewportUnconstrained&&(e.scrollMode=this.FM),i.Xu(),a){this.Hc=!1,this.start();return}this.jx(null),e.VA(),i.Gu(this),this.Yu&&this.Yu(this),e.requestUpdate()}Gc(t,e){const i=e.actualBounds;let s=null;if(e instanceof Group&&(s=e.placeholder),s!==null&&s.visible){const n=s.getDocumentPoint(Spot.TopLeft),o=s.padding;n.x+=o.left,n.y+=o.top,this.add(t,"position",n,t.position,!1)}else this.add(t,"position",new Point(i.x+i.width/2,i.y+i.height/2),t.position,!1);this.add(t,"scale",.01,t.scale,!1),t instanceof Group&&this.vR(t,e)}vR(t,e){const i=t.memberParts;for(;i.next();){const s=i.value;s instanceof Node&&this.Gc(s,e)}}Yc(t,e){if(!t.isVisible())return;let i=null;if(e instanceof Group&&(i=e.placeholder),i!==null&&i.visible){const s=i.getDocumentPoint(Spot.TopLeft),n=i.padding;s.x+=n.left,s.y+=n.top,this.add(t,"position:placeholder",t.position,s,!0)}else this.add(t,"position:nodeCollapse",t.position,e,!0);this.add(t,"scale",t.scale,.01,!0),this.AR(t),t instanceof Group&&this.FR(t,e)}FR(t,e){const i=t.memberParts;for(;i.next();){const s=i.value;s instanceof Node&&this.Yc(s,e)}}get duration(){return this.Io}set duration(t){U.s(t,"number",Animation,"duration"),t<1&&U.J(t,">= 1",Animation,"duration"),this.Io=t}get reversible(){return this.Ku}set reversible(t){this.Ku=t}get runCount(){return this.Zx}set runCount(t){t>0?this.Zx=t:U.o("Animation.runCount value must be a positive integer.")}get finished(){return this.Yu}set finished(t){this.Yu!==t&&(t!==null&&U.S(t,Animation,"finished"),this.Yu=t)}get easing(){return this.Jx}set easing(t){this.Jx=t}get isViewportUnconstrained(){return this.DM}set isViewportUnconstrained(t){this.DM=t}get isAnimating(){return this.Ae}getTemporaryState(t){let e=this.$x.get(t);return e===null&&(e={},this.$x.set(t,e)),e}static EaseLinear=(t,e,i,s)=>i*t/s+e;static EaseInOutQuad=(t,e,i,s)=>(t/=s/2,t<1?i/2*t*t+e:-i/2*(--t*(t-2)-1)+e);static EaseInQuad=(t,e,i,s)=>i*(t/=s)*t+e;static EaseOutQuad=(t,e,i,s)=>-i*(t/=s)*(t-2)+e;static EaseInExpo=(t,e,i,s)=>t===0?e:i*Math.pow(2,10*(t/s-1))+e;static EaseOutExpo=(t,e,i,s)=>t===s?e+i:i*(-Math.pow(2,-10*t/s)+1)+e}class AnimationState{ae;Cs;tb;ib;eb;constructor(t,e,i){this.ae=t,this.Cs=e,this.tb={},this.ib=i,this.eb=!1}}var TriggerStart=(w=>(w[w.Default=1]="Default",w[w.Immediate=2]="Immediate",w[w.Bundled=3]="Bundled",w))(TriggerStart||{});class AnimationTrigger{Ti;yn;ju;jc;constructor(t,e,i){this.Ti=null,this.yn=t,this.ju=i||1,this.jc=null,e!==void 0&&(this.jc=e,i===void 0&&(this.ju=2))}copy(){const t=new AnimationTrigger(this.yn);t.ju=this.ju;const e=this.jc;if(e!==null){const i={};e.duration!==void 0&&(i.duration=e.duration),e.finished!==void 0&&(i.finished=e.finished),e.easing!==void 0&&(i.easing=e.easing),t.jc=i}return t}get propertyName(){return this.yn}set propertyName(t){this.yn=t}get animationSettings(){return this.jc}set animationSettings(t){this.jc=t}RR(t){const e=this.jc;e!==null&&(e.duration&&(t.duration=e.duration),e.finished&&(t.finished=e.finished),e.easing&&(t.easing=e.easing))}get startCondition(){return this.ju}set startCondition(t){this.ju=t}static Default=1;static Immediate=2;static Bundled=3}class Layer{a;Pt;Zt;Fr;Yl;Kl;Hl;jl;ql;Wl;Jl;$l;Zl;Ql;_l;ta;Uc;ea;nb;Jm;qu;Ct;constructor(t){GSet.Je(this),this.a=null,this.Ct=new List,this.Pt="",this.Zt=1,this.Fr=!1,this.Yl=!0,this.Kl=!0,this.Hl=!0,this.jl=!0,this.ql=!0,this.Wl=!0,this.Jl=!0,this.$l=!0,this.Zl=!0,this.Ql=!0,this._l=!0,this.ta=!0,this.Uc=!0,this.ea=!0,this.nb=!0,this.Jm=!1,this.qu=[],t&&Object.assign(this,t)}OR(){const t=this.Ct;for(let e=0;e<t.length;e++)t.r[e].OM(null);t.clear(),this.qu.length=0}Eo(t){this.a=t}toString(t){t===void 0&&(t=0);const e='Layer "'+this.name+'"';if(t<=0)return e;let i=0,s=0,n=0,o=0,r=0;const l=this.Ct.iterator;for(;l.next();){const h=l.value;h instanceof Group?n++:h instanceof Node?s++:h instanceof Link?o++:h instanceof Adornment?r++:i++}let a="";if(i>0&&(a+=i+" Parts "),s>0&&(a+=s+" Nodes "),n>0&&(a+=n+" Groups "),o>0&&(a+=o+" Links "),r>0&&(a+=r+" Adornments "),t>1){const h=this.Ct.iterator;for(;h.next();){const c=h.value;a+=`
    `+c.toString();const f=c.data;f!==null&&GSet.xs(f)&&(a+=" #"+GSet.xs(f)),c instanceof Node?a+=" "+U.toString(f):c instanceof Link&&(a+=" "+U.toString(c.fromNode)+" "+U.toString(c.toNode))}}return e+" "+this.Ct.count+": "+a}findObjectAt(t,e,i){if(e===void 0&&(e=null),i===void 0&&(i=null),this.ea===!1)return null;let s=!1;this.diagram!==null&&this.diagram.viewportBounds.containsPoint(t)&&(s=!0);const n=Point.l(),o=this.Ct.r,r=o.length;for(let l=r;l--;){const a=o[l];if(s===!0&&a.Ul()===!1||!a.isVisible())continue;n.h(t),n.Ki(a.Js);let h=a.BA(n,e,i);if(h!==null&&(e!==null&&(h=e(h)),h!==null&&(i===null||i(h))))return Point.i(n),h}return Point.i(n),null}findObjectsAt(t,e,i,s){if(e===void 0&&(e=null),i===void 0&&(i=null),!(s instanceof List)&&!(s instanceof GSet)&&(s=new GSet),this.ea===!1)return s;let n=!1;this.diagram!==null&&this.diagram.viewportBounds.containsPoint(t)&&(n=!0);const o=Point.l(),r=this.Ct.r,l=r.length;for(let a=l;a--;){const h=r[a];if(n===!0&&h.Ul()===!1||!h.isVisible())continue;o.h(t),o.Ki(h.Js);let c=h;h.zA(o,e,i,s)&&(e!==null&&(c=e(c)),c!==null&&(i===null||i(c))&&s.add(c))}return Point.i(o),s}findObjectsIn(t,e,i,s,n){if(e===void 0&&(e=null),i===void 0&&(i=null),s===void 0&&(s=!1),!(n instanceof List)&&!(n instanceof GSet)&&(n=new GSet),this.ea===!1)return n;let o=!1;this.diagram!==null&&this.diagram.viewportBounds.containsRect(t)&&(o=!0);const r=this.Ct.r,l=r.length;for(let a=l;a--;){const h=r[a];if(o===!0&&h.Ul()===!1||!h.isVisible())continue;let c=h;h.$m(t,e,i,s,n)&&(e!==null&&(c=e(c)),c!==null&&(i===null||i(c))&&n.add(c))}return n}SS(t,e,i,s,n,o,r){if(this.ea===!1)return n;const l=this.Ct.r,a=l.length;for(let h=a;h--;){const c=l[h];if(r===!0&&c.Ul()===!1||!o(c)||!c.isVisible())continue;let f=c;c.$m(t,e,i,s,n)&&(e!==null&&(f=e(f)),f!==null&&(i===null||i(f))&&n.add(f))}return n}findObjectsNear(t,e,i,s,n,o){if(i===void 0&&(i=null),s===void 0&&(s=null),n===void 0&&(n=!0),n!==!1&&n!==!0&&((n instanceof List||n instanceof GSet)&&(o=n),n=!0),!(o instanceof List)&&!(o instanceof GSet)&&(o=new GSet),this.ea===!1)return o;let r=!1;this.diagram!==null&&this.diagram.viewportBounds.containsPoint(t)&&(r=!0);const l=Point.l(),a=Point.l(),h=this.Ct.r,c=h.length;for(let f=c;f--;){const u=h[f];if(r===!0&&u.Ul()===!1||!u.isVisible())continue;l.h(t),l.Ki(u.Js),a.e(t.x+e,t.y),a.Ki(u.Js);let d=u;u.XA(l,a,i,s,n,o)&&(i!==null&&(d=i(d)),d!==null&&(s===null||s(d))&&o.add(d))}return Point.i(l),Point.i(a),o}IM(){return this.Ct.r}As(t,e){if(!this.visible)return;const i=this.Ct.r,s=i.length;if(s===0)return;const n=U.ot(),o=U.ot();for(let r=0;r<s;r++){const l=i[r];if(l.EM=r,l instanceof Link){if(l.Fi===!1)continue}else if(l instanceof Adornment&&l.adornedPart!==null)continue;const a=l.actualBounds;l.isVisible()&&a.UL(e,10)?(l.As(!0),n.push(l)):(l.As(!1),l.adornments!==null&&l.adornments.count>0&&o.push(l))}for(let r=0;r<n.length;r++){const l=n[r];l.UM();const a=l.adornments;for(;a.next();){const h=a.value;h.ht(1/0,1/0),h.Ut(),h.As(!0)}}for(let r=0;r<o.length;r++)o[r].UM();U.Z(n),U.Z(o)}Wu(t){let e=1;return this.Zt!==1&&(e=t.globalAlpha,t.globalAlpha=e*this.Zt),e}GA(t,e){for(let i=0;i<e;i++)t[i].qc()}Ge(t,e,i){if(!this.visible||this.Zt===0||(i===void 0&&(i=!0),!i&&this.isTemporary))return;const s=this.Ct.r,n=s.length;if(n===0)return;t.Fr&&this.GA(s,n);const o=this.Wu(t),r=this.qu;r.length=0;const l=e.scale,a=Rect.l();for(let h=0;h<n;h++){const c=s[h];this.Zm(t,c,e,r,l,a,!0)}Rect.i(a),t.Fr&&this.GA(s,n),t.globalAlpha=o}OU(t,e,i){if(!this.visible||this.Zt===0)return;const s=this.Ct.r,n=s.length;if(n===0)return;const o=this.Wu(t),r=this.qu;r.length=0;const l=e.scale,a=Rect.l();for(let h=0;h<n;h++){const c=s[h];i.has(c)||this.Zm(t,c,e,r,l,a,!0)}Rect.i(a),t.globalAlpha=o}IR(t,e,i,s){if(!this.visible||this.Zt===0||!s&&this.isTemporary)return;const n=this.Ct.r,o=n.length;if(o===0)return;const r=this.Wu(t),l=this.qu;l.length=0;const a=e.scale,h=Rect.l();for(let c=0;c<o;c++){const f=n[c];i.has(f)&&this.Zm(t,f,e,l,a,h,!1)}Rect.i(h),t.globalAlpha=r}ER(t,e,i,s,n){if(!this.visible||this.opacity===0)return;const o=this.diagram.grid.part;if(!s&&this.isTemporary){if(n&&o.layer===this){const r=this.Wu(t);o.Ge(t,i),t.globalAlpha=r}}else{const r=this.Wu(t),l=i.scale,a=Rect.l(),h=this.Ct.r,c=h.length;for(let f=0;f<c;f++){const u=h[f];!n&&u===o||this.Zm(t,u,i,null,l,a,!1)}Rect.i(a),t.globalAlpha=r}}IU(t,e,i){if(!this.visible||this.Zt===0)return;const s=this.Wu(t),n=this.qu;n.length=0;const o=e.scale,r=Rect.l(),l=this.Ct.r,a=l.length,h=i.length;for(let c=0;c<a;c++){const f=l[c],u=f.lh(f.actualBounds);this.UR(u,i,h,o)&&this.Zm(t,f,e,n,o,r,!0)}Rect.i(r),t.globalAlpha=s}Zm(t,e,i,s,n,o,r){if(r&&!e.Ul()){t.removePartFromView(e);return}if(s!==null&&e instanceof Link&&(e.isOrthogonal&&s.push(e),e.Fi===!1)){t.removePartFromView(e);return}let l=!1,a=e.containingGroup;for(;a!==null;)l?a.he!==null&&o.intersectRect(a.he):a.he!==null&&(l=!0,o.h(a.he)),a=a.containingGroup;const h=e.actualBounds;let c=!1;if(l&&e.isVisible()){if(!o.intersectsRect(h)){t.removePartFromView(e);return}c=!o.containsRect(h)}c&&(t.save(),t instanceof SVGContext?t.partClipRect=o.copy():(t.beginPath(),t.rect(o.x,o.y,o.width,o.height),t.clip())),h.width*n>i.Qm||h.height*n>i.Qm?e.Ge(t,i):this.VR(t,e,i),c&&(t.restore(),t.clearContextCache(!0))}VR(t,e,i){if(t instanceof SVGContext){e.Ge(t,i);return}const s=e.actualBounds,n=e.naturalBounds;if(s.width===0||s.height===0||isNaN(s.x)||isNaN(s.y)||!e.isVisible())return;const o=e.v;if(e.background===null){e.kn(t,"rgba(0,0,0,0.3)",!0,!1,n,s),t.fillRect(s.x,s.y,s.width,s.height);return}if(t.transform(o.m11,o.m12,o.m21,o.m22,o.dx,o.dy),e.kn(t,e.background,!0,!1,n,s),t.fillRect(0,0,n.width/2,n.height/2),!o.FP()){const r=1/(o.m11*o.m22-o.m12*o.m21);t.transform(o.m22*r,-o.m12*r,-o.m21*r,o.m11*r,r*(o.m21*o.dy-o.m22*o.dx),r*(o.m12*o.dx-o.m11*o.dy))}}UR(t,e,i,s){const n=2/s,o=4/s;for(let r=0;r<i;r++){const l=e[r];if(!(l.width===0||l.height===0)&&t.intersects(l.x-n,l.y-n,l.width+o,l.height+o))return!0}return!1}t(t,e,i,s,n){const o=this.diagram;o!==null&&o.raiseChangedEvent(2,t,this,e,i,s,n)}ah(t,e,i){const s=this.Ct;if(e.OM(this),t>=s.count)t=s.count;else if(s.elt(t)===e)return-1;s.insertAt(t,e),e._m(i);const n=this.diagram;return n!==null&&(i?n.C():n.ah(e)),this.ob(t,e),t}ri(t,e,i){if(!i&&e.layer!==this&&e.layer!==null)return e.layer.ri(t,e,i);const s=this.Ct;if(t<0||t>=s.length){if(t=s.indexOf(e),t<0)return-1}else if(s.elt(t)!==e&&(t=s.indexOf(e),t<0))return-1;e.tp(i),s.removeAt(t);const n=this.diagram;return n!==null&&(i?n.C():n.ri(e)),e.OM(null),t}ob(t,e){t=this.BR(t,e),e instanceof Group&&this.zR(t,e),e.svg!==null&&e.svg.remove()}BR(t,e){const i=e.zOrder;if(isNaN(i))return t;const s=this.Ct,n=s.count;if(n<=1)return t;if(t<0&&(t=s.indexOf(e)),t<0)return-1;let o=t-1,r=NaN;for(;o>=0&&(r=s.elt(o).zOrder,!!isNaN(r));)o--;let l=t+1,a=NaN;for(;l<n&&(a=s.elt(l).zOrder,!!isNaN(a));)l++;if(!isNaN(r)&&r>i)for(;;){if(o===-1||r<=i)return o++,o===t?t:(s.removeAt(t),s.insertAt(o,e),o);for(r=NaN;--o>=0&&(r=s.elt(o).zOrder,!!isNaN(r)););}else if(!isNaN(a)&&a<i)for(;;){if(l===n||a>=i)return l--,l===t?t:(s.removeAt(t),s.insertAt(l,e),l);for(a=NaN;++l<n&&(a=s.elt(l).zOrder,!!isNaN(a)););}return t}zR(t,e){if(e===null||!isNaN(e.zOrder))return;this.XR(t,e);const i=e.containingGroup;i!==null&&this.ob(-1,i)}XR(t,e){if(e.memberParts.count===0)return;let i=-1;const s=this.Ct.r,n=s.length;for(let o=0;o<n;o++){const r=s[o];if(r===e&&(t=o,i>=0)||i<0&&r.containingGroup===e&&(i=o,t>=0))break}if(!(i<0)&&i<t){const o=this.Ct;o.removeAt(t),o.insertAt(i,e)}}get parts(){return this.Ct.iterator}get partsBackwards(){return this.Ct.iteratorBackwards}get diagram(){return this.a}get name(){return this.Pt}set name(t){U.s(t,"string",Layer,"name");const e=this.Pt;if(e!==t){const i=this.diagram;if(i!==null){e===""&&U.o("Cannot rename default Layer to: "+t);const n=i.layers;for(;n.next();)n.value.name===t&&U.o("Layer.name is already present in this diagram: "+t)}this.Pt=t,this.t("name",e,t);const s=this.Ct.iterator;for(;s.next();){const n=s.value;n.layerName=this.Pt}}}get opacity(){return this.Zt}set opacity(t){const e=this.Zt;if(e!==t){U.s(t,"number",Layer,"opacity"),(t<0||t>1)&&U.J(t,"0 <= value <= 1",Layer,"opacity"),this.Zt=t;const i=this.diagram;i!==null&&i.C(),this.t("opacity",e,t)}}get isViewportAligned(){return this.Jm}set isViewportAligned(t){const e=this.Jm;e!==t&&(this.Jm=t,this.diagram&&(this.YA(),this.diagram.C()),this.t("isViewportAligned",e,t),t&&(this.isInDocumentBounds=!1))}YA(){if(!this.Jm)return;const t=this.diagram;if(t===null)return;const e=this.Ct.r,i=e.length,s=t.wt,n=t.xt;for(let o=0;o<i;o++){const r=e[o],l=r.naturalBounds.width,a=r.naturalBounds.height;let h=r.alignment;(h.isDefault()||!h.isSpot())&&(h=Spot.BottomRight);let c=r.alignmentFocus;c.isDefault()&&(c=new Spot(h.x,h.y));const f=h.x*s+h.offsetX-(c.x*l+c.offsetX),u=h.y*n+h.offsetY-(c.y*a+c.offsetY),d=Point.z(f,u);t.GR(d),r.Ec(d.x,d.y,!0),Point.i(d),r.it=1/t.scale}}get isTemporary(){return this.Fr}set isTemporary(t){const e=this.Fr;e!==t&&(U.s(t,"boolean",Layer,"isTemporary"),this.Fr=t,this.t("isTemporary",e,t))}get visible(){return this.Uc}set visible(t){const e=this.Uc;if(e!==t){U.s(t,"boolean",Layer,"visible"),this.Uc=t;const i=this.Ct.iterator;for(;i.next();)i.value.Xe(t);const s=this.diagram;s!==null&&s.C(),this.t("visible",e,t)}}get pickable(){return this.ea}set pickable(t){const e=this.ea;e!==t&&(U.s(t,"boolean",Layer,"pickable"),this.ea=t,this.t("pickable",e,t))}get isInDocumentBounds(){return this.nb}set isInDocumentBounds(t){const e=this.nb;e!==t&&(this.nb=t,this.diagram!==null&&this.diagram.invalidateDocumentBounds(),this.t("isInDocumentBounds",e,t))}get allowCopy(){return this.Yl}set allowCopy(t){const e=this.Yl;e!==t&&(U.s(t,"boolean",Layer,"allowCopy"),this.Yl=t,this.t("allowCopy",e,t))}get allowDelete(){return this.Kl}set allowDelete(t){const e=this.Kl;e!==t&&(U.s(t,"boolean",Layer,"allowDelete"),this.Kl=t,this.t("allowDelete",e,t))}get allowTextEdit(){return this.Hl}set allowTextEdit(t){const e=this.Hl;e!==t&&(U.s(t,"boolean",Layer,"allowTextEdit"),this.Hl=t,this.t("allowTextEdit",e,t))}get allowGroup(){return this.jl}set allowGroup(t){const e=this.jl;e!==t&&(U.s(t,"boolean",Layer,"allowGroup"),this.jl=t,this.t("allowGroup",e,t))}get allowUngroup(){return this.ql}set allowUngroup(t){const e=this.ql;e!==t&&(U.s(t,"boolean",Layer,"allowUngroup"),this.ql=t,this.t("allowUngroup",e,t))}get allowLink(){return this.Wl}set allowLink(t){const e=this.Wl;e!==t&&(U.s(t,"boolean",Layer,"allowLink"),this.Wl=t,this.t("allowLink",e,t))}get allowRelink(){return this.Jl}set allowRelink(t){const e=this.Jl;e!==t&&(U.s(t,"boolean",Layer,"allowRelink"),this.Jl=t,this.t("allowRelink",e,t))}get allowMove(){return this.$l}set allowMove(t){const e=this.$l;e!==t&&(U.s(t,"boolean",Layer,"allowMove"),this.$l=t,this.t("allowMove",e,t))}get allowReshape(){return this.Zl}set allowReshape(t){const e=this.Zl;e!==t&&(U.s(t,"boolean",Layer,"allowReshape"),this.Zl=t,this.t("allowReshape",e,t))}get allowResize(){return this.Ql}set allowResize(t){const e=this.Ql;e!==t&&(U.s(t,"boolean",Layer,"allowResize"),this.Ql=t,this.t("allowResize",e,t))}get allowRotate(){return this._l}set allowRotate(t){const e=this._l;e!==t&&(U.s(t,"boolean",Layer,"allowRotate"),this._l=t,this.t("allowRotate",e,t))}get allowSelect(){return this.ta}set allowSelect(t){const e=this.ta;e!==t&&(U.s(t,"boolean",Layer,"allowSelect"),this.ta=t,this.t("allowSelect",e,t))}}var AutoScale=(w=>(w[w.None=1]="None",w[w.Uniform=2]="Uniform",w[w.UniformToFill=3]="UniformToFill",w))(AutoScale||{}),CycleMode=(w=>(w[w.All=1]="All",w[w.NotDirected=2]="NotDirected",w[w.NotDirectedFast=3]="NotDirectedFast",w[w.NotUndirected=4]="NotUndirected",w[w.DestinationTree=5]="DestinationTree",w[w.SourceTree=6]="SourceTree",w))(CycleMode||{}),ScrollMode=(w=>(w[w.Document=1]="Document",w[w.Infinite=2]="Infinite",w))(ScrollMode||{}),CollapsePolicy=(w=>(w[w.TreeParent=1]="TreeParent",w[w.AllParents=2]="AllParents",w[w.AnyParents=3]="AnyParents",w))(CollapsePolicy||{});class Diagram{Ns;qt;VM;rb;Rr;Ju;lb;ab;hb;cb;fb;ub;hh;oh;db;gb;pb;ia;Wc;Or;ep;yb;wb;$u;eo;Ir;ch;Vo;ip;Jc;sp;$c;Zu;Er;io;BM;zM;xb;bb;XM;kb;GM;YM;KM;Pb;np;Ur;Vr;Br;zr;Xr;Gr;Sb;Yr;Mb;Kr;Hr;jr;qr;Nb;HM;Bo;jM;Cb;Lb;qM;Ce;WM;Zc;JM;js;zo;Be;Ab;Yl;Kl;Tb;Db;Hl;jl;ql;vb;Wl;Jl;$l;Zl;Ql;_l;ta;Fb;Rb;$M;Qu;_u;Ob;Ib;Eb;Ub;op;Vb;Bb;zb;Qt;KA;Xb;HA;td;Pn;so;li;no;jA;sa;ZM;QM;rp;Gb;ed;lp;Yb;Wr;na;fh;_M;t2;ap;Kb;Hb;ls;sd;hp;nd;Xo;Qc;cp;Jr;uh;e2;fp;Ht;v;qi;Dr;Ye;Ts;i2;oa;$r;Fl;Zr;dh;_c;s2;od;gh;rd;zt;ra;ct;it;ld;wt;xt;st;tf;Sx;jb;mh;ef;qb;Wb;dp;YR;KR;$e;Ol;Qm;gp;o2;l2;qA;mp;HR;jR;qR;Jb;WR;JR;$R;ph;WA;la;yh;wh;xh;bh;Eu;ih;Wt;St;sf;jP;qP;Dc;Zt;static $b=null;static JA=new GMap;static a2;static h2=null;Iu;Zb;Qb;ad;_b;t1;pp;c2;yp;wp;xp;Hx;f2;u2;nf;bp;kp;constructor(t,e){if(Diagram.jw||(Diagram.RP(),Diagram.jw=!0),GSet.Je(this),Diagram.$A(this),this.Ht=!0,this.St=null,this.wt=0,this.xt=0,this.st=null,Diagram.isUsingDOM()){const s=this,n=()=>{s.Le(root.document,"DOMContentLoaded",n,!1),s.setRTL()};root.document.body!==null?this.setRTL():s.Et(root.document,"DOMContentLoaded",n,!1)}this.tf=null,Diagram.d2("Model",PartManager);const i=this;return this.WM=s=>i.partManager.doModelDataChanged(s),this.Zc=s=>i.partManager.doModelChanged(s),this.qb=null,this.Wb=null,this.ZA(),this.model=Model.g2(),this.themeManager=new ThemeManager,this.Bo=!0,this.QA(),this.layout=new Layout,this.Bo=!1,this.HR=null,this.jR=null,this.qR=null,this.Jb=null,this.WR=null,this.JR=null,this.$R=null,this.ph=null,this.WA=null,this.la=null,this.yh=null,this.wh=null,this.xh=null,this.bh=null,this.Eu=()=>{},this.ih=null,this.nd=!1,this.sf=new DiagramHelper(this),t!==void 0&&(typeof t=="string"||root.Element&&t instanceof Element?this.m2(t):e=t),e&&this.setProperties(e),this.Ht=!1,this.requestUpdate(),this}lR(){return this.st!==null}get renderer(){return this.Qc}set renderer(t){if(this instanceof Overview)return;t===""&&(t="default");const e=t.toLowerCase(),i=this.Qc;if(e===i)return;this.Qc=e;let s=null;e==="default"||e==="canvas"?(s=this.Xo.get("svg"),s!==null&&s.bt.remove(),this.st&&(this.Wt=this.st._t),this.Wt.clearContextCache(!0)):e==="svg"?(this.Xo.has("svg")?s=this.Xo.get("svg"):(s=new SVGSurface(this,root.document),this.addRenderer("svg",s)),this.div!==null&&(s.bt.role="img",this.div.appendChild(s.bt)),this.Wt=s._t,this.st&&(this.st._t.setTransform(this.$e,0,0,this.$e,0,0),this.st._t.clearRect(0,0,this.wt,this.xt))):e==="debug"&&(this.Xo.has("SVG")||(s=new SVGSurface(this,root.document),this.addRenderer("SVG",s),s.bt.style.backgroundColor="whitesmoke",this.div!==null&&this.div.after(s.bt))),this.Ht||this.redraw()}ZA(){if(this.nf=new List,this.setupRouters(),this.Ns=new AnimationManager,this.Ns.Eo(this),this.qt=17,this.VM=!1,this.ld=!1,this.rb="default",this.zt=new List,this.Xo){const t=this.Xo.get("svg");t!==null&&t.bt.remove(),this.st&&(this.Wt=this.st._t,this.Wt.clearContextCache(!0))}this.Xo=new GMap,this.Qc="default",this.resetRenderingHints(),this.ZR(),this.Zt=1,this.ct=new Point(NaN,NaN).b(),this.Hx=new Point(NaN,NaN),this.it=1,this.fp=1,this.lb=new Point(NaN,NaN).b(),this.ab=NaN,this.hb=1e-4,this.cb=100,this.v=new Transform,this.fb=new Point(NaN,NaN).b(),this.ub=new Rect(NaN,NaN,NaN,NaN).b(),this.hh=new Margin(0,0,0,0).kt(),this.oh=1,this.db=!1,this.gb=null,this.pb=null,this.ia=1,this.Wc=Spot.Default,this.Or=1,this.ep=Spot.Default,this.yb=Spot.None,this.wb=Spot.None,this.qi=!0,this.$u=!1,this.eo=new Set,this.Ir=new GSet,this.ch=new GSet,this.Vo=!1,this.ra=new GMap,this.od=!0,this.ip=250,this.Jc=-1,this.sp=new Margin(16,16,16,16).kt(),this.Dr=!1,this.$c=!1,this.Zu=!0,this.cp=new InputEvent,this.cp.diagram=this,this.Jr=new InputEvent,this.Jr.diagram=this,this.uh=new InputEvent,this.uh.diagram=this,this.Er=null,this.io=null,this.Sx=!1,this.QR(),this.Zr=new GSet,this.xb=!0,this.bb=1,this.XM=!1,this.kb=1,this.Pb="auto",this.np="auto",this.Ur=null,this.Vr=null,this.Br=null,this.zr=null,this.Xr=null,this.Gr=null,this.Sb=null,this.Yr=null,this.Mb=!1,this.Kr=null,this.Hr=null,this.jr=null,this.qr=null,this.Nb=!1,this.jb={},this.mh=[null,null],this.Bo=!1,this.jM=!1,this.Cb=!1,this.Lb=!1,this.qM=!0,this.Ts=!1,this.gh=!1,this.JM=!0,this.js=-2,this.oa=new GMap,this.rd=new List,this.zo=!1,this.Be=!0,this.Ab=!0,this.Yl=!0,this.Kl=!0,this.Tb=!1,this.Db=!0,this.Hl=!0,this.jl=!0,this.ql=!0,this.vb=!0,this.Wl=!0,this.Jl=!0,this.$l=!0,this.Zl=!0,this.Ql=!0,this._l=!0,this.ta=!0,this.Fb=!0,this.Rb=!0,this.$M=!1,this.ef=!1,this.Qu=!0,this._u=!0,this.Ob=!0,this.Ib=!0,this.Eb=16,this.Ub=16,this.op=!1,this.Vb=!1,this.Bb=0,this.zb=0,this.Qt=new Margin(5).kt(),this.KA=new GSet().b(),this.Xb=999999999,this.HA=new GSet().b(),this.dh=!0,this.td=!0,this._c=!0,this.Pn=!1,this.so=!1,this.$r=!0,this.Fl=!1,this.no=!1,this.jA=new GSet,this.s2=new GSet,this.sa=null,this.ZM=new Size(Link._A,Link.tT),this.QM=999,this.rp=!1,this.jP=1,this.qP=0,this.Ye={scale:1,position:new Point,bounds:new Rect,canvasSize:new Size,newCanvasSize:new Size,isScroll:!1},this.Ye.canvasSize=this.Ye.canvasSize,this.Ye.newCanvasSize=this.Ye.newCanvasSize,this.Ye.isScroll=!1,this.Gb=new Rect(NaN,NaN,NaN,NaN).b(),this.ed=new Size(NaN,NaN).b(),this.lp=new Rect(NaN,NaN,NaN,NaN).b(),this.Yb=!1,this.bp=null,this.kp=null,this._R(),this.ls=null,this.sd=!1,this.Dc=null,this.partManager=new PartManager,this.toolManager=new ToolManager,this.toolManager.initializeStandardTools(),this.defaultTool=this.toolManager,this.currentTool=this.defaultTool,this.Qb=null,this.ad=new DraggingOptions,this._b=null,this.t1=null,this.Zb=!1,this.Iu=!1,this.commandHandler=new CommandHandler,this.wp=null,this.xp=Point.mn,this.f2=!1,this.$e=1,this.Ol=null,this.Qm=1,this.pp=0,this.c2=[0,0,0,0,0],this.yp=0,this.gp=1,this.o2=0,this.l2=new Point,this.qA=500,this.hp=new Point,this.mp=!1}static eT=root.document!==void 0;static isUsingDOM(){return Diagram.eT}static useDOM(t){Diagram.eT=t?root.document!==void 0:!1}static Wi=new WeakMap;clear(){this.animationManager.stopAnimation(),this.model.clear(),Diagram.iT(),this.sT(!1),this.rd.clear(),this.nT(),this.sa=null,this.invalidateDocumentBounds(),this.ensureBounds(),this.C()}sT(t){this.animationManager.stopAnimation(!0),this.clearSelection(),this.clearHighlighteds();const e=this.skipsUndoManager,i=this.Ce!==null&&this.Ce!==void 0;i&&(this.skipsUndoManager=!0);let s=null;this.ls!==null&&(s=this.ls.part,s!==null&&this.remove(s));const n=[],o=this.zt.length;if(t){for(let r=0;r<o;r++){const a=this.zt.r[r].parts;for(;a.next();){const h=a.value;h!==s&&h.data===null&&n.push(h)}}for(let r=0;r<n.length;r++){const l=n[r];this.remove(l)}}for(let r=0;r<o;r++)this.zt.r[r].OR();return this.partManager.clear(),this.eo.clear(),this.Ir.clear(),this.ch.clear(),this.ra.clear(),this.Zr.clear(),this.Dc=null,this.rd.clear(),this.nT(),U.CP=[],s!==null&&(this.add(s),this.partManager.parts.delete(s)),i&&(this.skipsUndoManager=e),n}static Pp=null;static e1="";static iT(){Diagram.Pp=null,Diagram.e1=""}static EU(){return null}reset(){this.clear(),this.Ht=!0,this.ZA(),this.themeManager=new ThemeManager,this.aa(),this.Bo=!0,this.QA(),this.layout=new Layout,this.Bo=!1,this.model=Model.g2(),this.model.undoManager=new UndoManager,this.nd=!1,this.Ht=!1,this.C()}_R(){this.Wr=new GMap,this._M=new Node().add(new TextBlock({stroke:"black",font:"10pt sans-serif"}).bind("text","",U.toString).theme("stroke","text").theme("font","normal")),this.Wr.set("",this._M),this.Wr.set("Comment",new Node().add(new TextBlock({stroke:"brown",font:"10pt sans-serif"}).bind("text","",U.toString).theme("stroke","comment").theme("font","normal"))),this.Wr.set("LinkLabel",new Node({selectable:!1,avoidable:!1}).add(new Shape("Ellipse",{fill:"black",stroke:null,desiredSize:new Size(3,3).kt()}).theme("fill","link"))),this.fh=new GMap,this.i2=new Group(Panel.Vertical,{selectionObjectName:"GROUPPANEL"}).add(new TextBlock({stroke:"black",font:"bold 12pt sans-serif"}).bind("text","",U.toString).theme("stroke","text").theme("font","bold"),new Panel(Panel.Auto,{name:"GROUPPPANEL"}).add(new Shape({fill:"rgba(128,128,128,0.2)",stroke:"black",strokeWidth:1}).theme("fill","group").theme("stroke","outline").theme("strokeWidth","group"),new Placeholder({padding:5}).theme("padding","group"))),this.fh.set("",this.i2),this.na=new GMap,this.t2=new Link().add(new Shape({isPanelMain:!0,stroke:"black"}).theme("stroke","link"),new Shape({toArrow:"Standard",fill:"black",stroke:null,strokeWidth:0}).theme("toArrow").theme("fill","link")),this.na.set("",this.t2),this.na.set("Comment",new Link().add(new Shape({isPanelMain:!0,stroke:"brown"}).theme("stroke","comment"))),this.ap=new Adornment(Panel.Auto).add(new Shape({fill:null,stroke:"dodgerblue",strokeWidth:3}).theme("stroke","selection").theme("strokeWidth","selection"),new Placeholder({margin:1.5}).theme("margin","selection","numbers",null,t=>t?new Margin(t/2):1.5)).freezeBindings(),this.Kb=this.ap,this.Hb=new Adornment(Panel.Link).add(new Shape({isPanelMain:!0,fill:null,stroke:"dodgerblue",strokeWidth:3}).theme("stroke","selection").theme("strokeWidth","selection")).freezeBindings()}setRTL(t){let e=t===void 0?this.div:t;e===null&&(e=root.document.body);const i=U.Ni("div");i.dir="rtl",i.style.cssText="font-size: 14px; width: 1px; height: 1px; position: absolute; top: -1000px; overflow: scroll;",i.textContent="A",e.appendChild(i);let s="reverse";i.scrollLeft>0?s="default":(i.scrollLeft=1,i.scrollLeft===0&&(s="negative")),e.removeChild(i),this.rb=s}setScrollWidth(t){let e=t===void 0?this.div:t;e===null&&(e=root.document.body);let i=0;if(Diagram.isUsingDOM()){let s=Diagram.h2,n=Diagram.a2;s===null&&(Diagram.h2=U.Ni("p"),s=Diagram.h2,s.style.width="100%",s.style.height="200px",s.style.boxSizing="content-box",Diagram.a2=U.Ni("div"),n=Diagram.a2,n.style.position="absolute",n.style.visibility="hidden",n.style.width="200px",n.style.height="150px",n.style.boxSizing="content-box",n.appendChild(s)),n.style.overflow="hidden",e.appendChild(n);const o=s.offsetWidth;n.style.overflow="scroll";let r=s.offsetWidth;o===r&&(r=n.clientWidth),e.removeChild(n),i=o-r,i===0&&!U.ur&&(i=11)}this.qt=i,this.VM=!0}fe(t){t in AutoScale?this.autoScale=t:U.dr(this,t)}toString(t){t===void 0&&(t=0);let e="";this.div&&this.div.id&&(e=this.div.id);let i='Diagram "'+e+'"';if(t<=0)return i;const s=this.zt.iterator;for(;s.next();){const n=s.value;i+=`
  `+n.toString(t-1)}return i}static $A(t){Diagram.$b=t}static Rm(){return Diagram.$b}static fromDiv(t){let e=t;if(typeof t=="string"&&(e=root.document.getElementById(t)),e instanceof HTMLDivElement){const i=Diagram.Wi.get(e);if(i)return i}return null}get div(){return this.St}set div(t){if(t!==null&&U.se(t,HTMLDivElement,Diagram,"div"),this.St!==t){const e=this.St;if(e!==null){if(Diagram.Wi.delete(e),e.goDiagram=void 0,e.go=void 0,e.innerHTML="",this.st!==null){const s=this.st.bt;this.Le(s,"pointermove",this.yh,!1),this.Le(s,"pointerdown",this.la,!1),this.Le(s,"pointerup",this.wh,!1),this.Le(s,"pointerout",this.xh,!1),this.Le(s,"pointercancel",this.bh,!1),this.st.dispose()}this.tf&&(this.tf.disconnect(),this.tf=null);const i=this.toolManager;i!==null&&(i.mouseDownTools.each(s=>s.cancelWaitAfter()),i.mouseMoveTools.each(s=>s.cancelWaitAfter()),i.mouseUpTools.each(s=>s.cancelWaitAfter())),i.cancelWaitAfter(),this.currentTool.doCancel(),this.st=null,this.Le(root,"resize",this.Jb,!1),this.Le(root,"wheel",this.ph,!0),Diagram.Rm()===this&&Diagram.$A(null)}else this.la===null&&(this.no=!1);if(this.St=null,t!==null){const i=Diagram.Wi.get(t);i&&(i.div=null),this.m2(t),this.Eu(),this.themeManager&&this.themeManager.tO()}else this.themeManager&&this.themeManager.eO()}}setupRouters(){this.nf.push(new AvoidsNodesRouter)}m2(t){const e=this;if(!Diagram.isUsingDOM())return;t==null&&U.o("Diagram setup requires an argument DIV."),e.St!==null&&U.o("Diagram has already completed setup."),typeof t=="string"?e.St=root.document.getElementById(t):t instanceof HTMLDivElement?e.St=t:U.o("No DIV or DIV id supplied: "+t),e.St===null&&U.o("Invalid DIV id; could not get element with id: "+t);const i=Diagram.Wi.get(e.St);if(i&&i!==this&&U.o("Invalid div id; div already has a Diagram associated with it."),!e.tf&&root.ResizeObserver){const c=root.ResizeObserver,f=U.NP(()=>e.requestUpdate(),250,!1);e.tf=new c(()=>f()),e.tf.observe(e.St)}root.getComputedStyle(e.St,null).position==="static"&&(e.St.style.position="relative");let s=5;const n="rgba(2"+s+"5, 255, 255, 0)";s--,e.St.style["-webkit-tap-highlight-color"]=n,e.St.innerHTML="",Diagram.Wi.set(e.St,e),e.St.goDiagram=e,e.St.go=root.go;const o=new CanvasSurface(e);o.style!==void 0&&(o.style.position="absolute",o.style.top="0px",o.style.left="0px",root.getComputedStyle(e.St,null).getPropertyValue("direction")==="rtl"&&(e.ld=!0),o.style.zIndex="2",o.style.userSelect="none",o.style.MozUserSelect="none",o.style.touchAction="none",o.style.letterSpacing="normal !important",o.style.wordSpacing="normal !important",o.style.lang="unknown"),o.bt.setAttribute("role","application"),e.st=o,e.Wt=o._t;const r=e.Wt;e.$e=e.computePixelRatio(),e.viewSize.isReal()||(e.wt=e.St.clientWidth||1,e.xt=e.St.clientHeight||1),e.oT(e.wt,e.xt);const l=e;e.St.insertBefore(o.bt,e.St.firstChild);const a=new CanvasSurface(null);if(a.width=1,a.height=1,e.YR=a,e.KR=a._t,Diagram.isUsingDOM()){const c=U.Ni("div"),f=U.Ni("div");c.style.position="absolute",c.style.overflow="auto",c.style.width=e.wt+"px",c.style.height=e.xt+"px",c.style.zIndex="1",f.style.position="absolute",f.style.width="1px",f.style.height="1px",e.St.appendChild(c),c.appendChild(f),c.onscroll=Diagram.iO,c.addEventListener("pointerdown",Diagram.sO),c.a=e,c.nO=!0,c.oO=!0,e.qb=c,e.Wb=f}e.Eu=U.NP(()=>{e.Ol=null,e.C()},300,!1),e.Jb=U.NP(()=>{e.SM()},250,!1),e.ih=c=>(c.preventDefault(),!1),e.ph=c=>{if(!l.isEnabled)return;const f=l.of(c,!0);f.bubbles=!0;let u=0,d=0;f.delta=0,c.deltaX!==void 0?(c.deltaX!==0&&(u=c.deltaX>0?1:-1),c.deltaY!==0&&(d=c.deltaY>0?1:-1),f.delta=Math.abs(c.deltaX)>Math.abs(c.deltaY)?-u:-d):c.wheelDeltaX!==void 0?(c.wheelDeltaX!==0&&(u=c.wheelDeltaX>0?-1:1),c.wheelDeltaY!==0&&(d=c.wheelDeltaY>0?-1:1),f.delta=Math.abs(c.wheelDeltaX)>Math.abs(c.wheelDeltaY)?-u:-d):c.wheelDelta!==void 0&&c.wheelDelta!==0&&(f.delta=c.wheelDelta>0?1:-1),l.doMouseWheel(),l.kh(f,c)},e.WA=c=>{if(!l.isEnabled)return;e.ef=!1,l.of(c,!0);const f=l.currentTool;f.cancelWaitAfter(),f.standardMouseOver()},e.la=c=>{if(!l.isEnabled)return;e.ef=!0;const f=l.jb;f[c.pointerId]===void 0&&(f[c.pointerId]=c);const u=l.mh;let d=!1;if(u[0]!==null&&(u[0].pointerId===c.pointerId||u[0].pointerType!==c.pointerType))u[0]=c;else if(u[1]!==null&&u[1].pointerId===c.pointerId)u[1]=c,d=!0;else if(u[0]===null)u[0]=c;else if(u[1]===null)u[1]=c,d=!0;else{c.preventDefault();return}const m=c.pointerType==="touch"||c.pointerType==="pen";m&&(l.Sx=!1,l.mp=!0);const g=l.rO(c,c,d),p=l.l2,y=m?25:10;if(c.timeStamp-l.o2<l.qA&&!(Math.abs(p.x-c.screenX)>y||Math.abs(p.y-c.screenY)>y)?l.gp++:l.gp=1,g.clickCount=l.gp,l.o2=c.timeStamp,l.l2.setTo(c.screenX,c.screenY),l.doMouseDown(),c.button===1){c.preventDefault();return}l.kh(g,c)},e.yh=c=>{if(!l.isEnabled)return;e.ef=!0;const f=l.mh;if(f[0]!==null&&(f[0].pointerId===c.pointerId||f[0].pointerType!==c.pointerType))f[0]=c;else if(f[1]!==null&&f[1].pointerId===c.pointerId){f[1]=c;return}else if(f[0]===null)f[0]=c;else return;if(f[0].pointerId!==c.pointerId)return;const u=l.lO(c,c,f[1]!==null);l.doMouseMove(),l.kh(u,c)},e.wh=c=>{if(!l.isEnabled)return;e.ef=!0;const f=c.pointerType==="touch"||c.pointerType==="pen",u=l.jb;if(f&&l.Sx){delete u[c.pointerId],c.preventDefault();return}const d=l.mh;if(d[0]!==null&&(d[0].pointerId===c.pointerId||d[0].pointerType!==c.pointerType))d[0]=null;else if(d[1]!==null&&d[1].pointerId===c.pointerId){d[1]=null;return}else return;const m=l.p2(c,!1,!0,!1,!0,!1);let g=root.document.elementFromPoint(c.clientX,c.clientY)||null;g!==null&&g.shadowRoot&&(g=g.shadowRoot.elementFromPoint(c.clientX,c.clientY)||null),g!==null&&g.a instanceof Diagram&&g.a!==l&&g.a.Sp(c,m),g===null&&(g=c.target),l.Sp(c,m),m.clickCount=l.gp,m.targetDiagram=l.i1(c,g),m.targetObject=null,l.doMouseUp(),l.kh(m,c),f&&(l.mp=!1)},e.xh=c=>{if(!l.isEnabled)return;e.ef=!1;const f=l.jb;f[c.pointerId]&&delete f[c.pointerId];const u=l.mh;if(u[0]!==null&&u[0].pointerId===c.pointerId&&(u[0]=null),u[1]!==null&&u[1].pointerId===c.pointerId&&(u[1]=null),c.pointerType==="touch"||c.pointerType==="pen")return;const d=l.currentTool;d.cancelWaitAfter(),d.standardMouseOver()},e.bh=c=>{const f=l.mh;f[0]!==null&&f[0].pointerId===c.pointerId?(f[0]=null,l.mp=!1):f[1]!==null&&f[1].pointerId===c.pointerId&&(f[1]=null)};const h=r;if(e.dp=h.F[U.We("7eba17a4ca3b1a8346")][U.We("78a118b7")](h.F,Diagram.Ph,s,s),r.clearContextCache(!0),e.aO(),this.Qc==="svg"){const c=this.Xo.get("svg");this.St&&this.St.appendChild(c.bt),this.Wt=c._t}}addEventListener(t,e,i,s){t.addEventListener(e,i,{capture:s,passive:!1})}Et(t,e,i,s){t.addEventListener(e,i,{capture:s,passive:!1})}removeEventListener(t,e,i,s){t.removeEventListener(e,i,{capture:s})}Le(t,e,i,s){t.removeEventListener(e,i,{capture:s})}aO(){const t=this;let e=this.st.bt;e instanceof HTMLCanvasElement||(e=t.div),this.Et(e,"pointerdown",t.la,!1),this.Et(e,"pointermove",t.yh,!1),this.Et(e,"pointerup",t.wh,!1),this.Et(e,"pointerout",t.xh,!1),this.Et(e,"pointercancel",t.bh,!1),this.Et(e,"pointerenter",t.hO,!1),this.Et(e,"pointerleave",t.cO,!1),this.Et(e,"wheel",t.ph,!1),this.Et(e,"keydown",t.fO,!1),this.Et(e,"keyup",t.uO,!1),this.Et(e,"blur",t.dO,!1),this.Et(e,"focus",t.gO,!1),this.Et(e,"selectstart",i=>(i.preventDefault(),!1),!1),this.Et(e,"contextmenu",i=>(i.preventDefault(),!1),!1),this.Et(root,"resize",t.Jb,!1)}Nx(){this.pp>30&&(this.Ol=1)}pS(t){this.Ol!==null&&(this.Ol=null,t&&this.Eu(),this.pp=0,this.c2=[0,0,0,0,0],this.yp=0)}computePixelRatio(){return this.Ol!==null?this.Ol:root.devicePixelRatio||1}get avgSpf(){return this.pp}doMouseDown(){this.currentTool.doMouseDown()}doMouseMove(){this.currentTool.doMouseMove()}doMouseUp(){this.currentTool.doMouseUp()}doMouseWheel(){this.currentTool.doMouseWheel()}doKeyDown(){const t=this.commandHandler;if(!this.toggleKeyboardControl()){if((t.isFocusEnabled||t.isVirtualPointerEnabled)&&t.doVirtualFocusKeyDown()){const e=this.lastInput;e.bubbles=!1;const i=e.event;i&&(i.stopPropagation&&i.stopPropagation(),i.cancelable!==!1&&i.preventDefault());return}this.currentTool.doKeyDown()}}toggleKeyboardControl(){const t=this.lastInput,e=t.commandKey;if((t.control||t.meta)&&t.alt&&(e==="Enter"||e==="NumpadEnter")){const i=this.commandHandler,s=i.isFocusEnabled||i.isVirtualPointerEnabled;return i.isFocusEnabled=!s,i.isVirtualPointerEnabled=!s,i.focus=i.findFirstFocus(),this.T("FocusOrVirtualPointerEnabledChanged"),!0}return!1}doKeyUp(){const t=this.commandHandler;if((t.isFocusEnabled||t.isVirtualPointerEnabled)&&t.doVirtualFocusKeyUp()){const e=this.lastInput;e.bubbles=!1;const i=e.event;i&&(i.stopPropagation&&i.stopPropagation(),i.cancelable!==!1&&i.preventDefault());return}this.currentTool.doKeyUp()}doFocus(){this.focus()}focus(){if(this.st)if(this.scrollsPageOnFocus)this.st.focus();else{const t=root.scrollX,e=root.scrollY;this.st.focus(),root.scrollTo(t,e)}}gO(t){const e=Diagram.Wi.get(this);e&&e.T("GainedFocus")}dO(t){const e=Diagram.Wi.get(this);e&&e.T("LostFocus")}SM(){if(this.st===null)return;const e=this.St;if(e===null||e.clientWidth===0||e.clientHeight===0)return;this.VM||this.setScrollWidth();const i=this.so?this.qt:0,s=this.Pn?this.qt:0,n=this.$e;if(this.$e=this.computePixelRatio(),this.$e!==n&&(this.$u=!0,this.requestUpdate()),e.clientWidth!==this.wt+i||e.clientHeight!==this.xt+s){this.Sh(),this.qi=!0;const o=this.layout;o!==null&&o.isViewportSized&&this.autoScale===1&&(this.$c=!0,o.p()),this.Ts||this.requestUpdate()}}QA(){let t=0,e=new Layer;e.name="Grid",e.allowSelect=!1,e.pickable=!1,e.isTemporary=!0,e.isInDocumentBounds=!1,this.Qr(e,t++),e=new Layer,e.name="ViewportBackground",e.isViewportAligned=!0,e.isTemporary=!0,e.isInDocumentBounds=!1,this.Qr(e,t++),e=new Layer,e.name="Background",this.Qr(e,t++),e=new Layer,e.name="",this.Qr(e,t++),e=new Layer,e.name="Foreground",this.Qr(e,t++),e=new Layer,e.name="ViewportForeground",e.isViewportAligned=!0,e.isTemporary=!0,e.isInDocumentBounds=!1,this.Qr(e,t++),e=new Layer,e.name="Adornment",e.isTemporary=!0,e.isInDocumentBounds=!1,this.Qr(e,t++),e=new Layer,e.name="Tool",e.isTemporary=!0,e.isInDocumentBounds=!0,this.Qr(e,t++)}rT(){const t=new Panel(Panel.Grid,{name:"GRID"}).add(new Shape("LineH",{stroke:"lightgray",strokeWidth:.5,interval:1}).theme("stroke","gridMinor"),new Shape("LineV",{stroke:"lightgray",strokeWidth:.5,interval:1}).theme("stroke","gridMinor"),new Shape("LineH",{stroke:"gray",strokeWidth:.5,interval:5}).theme("stroke","gridMajor"),new Shape("LineV",{stroke:"gray",strokeWidth:.5,interval:5}).theme("stroke","gridMajor"),new Shape("LineH",{stroke:"gray",strokeWidth:1,interval:10}).theme("stroke","gridMajor"),new Shape("LineV",{stroke:"gray",strokeWidth:1,interval:10}).theme("stroke","gridMajor")),e=new Part({layerName:"Grid",zOrder:0,isInDocumentBounds:!1,isAnimated:!1,pickable:!1,locationObjectName:"GRID"}).add(t);return this.add(e),this.partManager.parts.delete(e),t.visible=!1,t}static iO(){const t=Diagram.Wi.get(this.parentElement||this);if(t){if(t.Vb){t.Vb=!1;return}if(!t.isEnabled){t.lT();return}t.diagramScroll(this)}}static sO(t){if(!this.a.isEnabled){this.a.updateScroll();return}this.a.Bb=t.target.scrollTop,this.a.zb=t.target.scrollLeft}diagramScroll(t){if(this.st===null)return;const e=this.qb,i=this.Wb;this.op=!0;let s=this.documentBounds,n=this.viewportBounds;const o=this.hh;let r=s.x-o.left,l=s.y-o.top;const a=s.width+o.left+o.right,h=s.height+o.top+o.bottom;let c=s.right+o.right,f=s.bottom+o.bottom,u=n.x,d=n.y;const m=n.width,g=n.height;let p=n.right,y=n.bottom;const x=this.scale;let k,b=t.scrollLeft;if(this.ld)switch(this.rb){case"negative":b=b+t.scrollWidth-t.clientWidth;break;case"reverse":b=t.scrollWidth-b-t.clientWidth;break}const P=b;if(m<a||g<h){k=Point.z(this.position.x,this.position.y),this.allowHorizontalScroll&&this.zb!==P&&(k.x=P/x+r,this.zb=P),this.allowVerticalScroll&&this.Bb!==t.scrollTop&&(k.y=t.scrollTop/x+l,this.Bb=t.scrollTop),this.position=k,Point.i(k),this.op=!1,this.td=!1;return}if(k=Point.l(),t.nO&&this.allowHorizontalScroll&&(r<u&&(this.position=k.e(P+r,this.position.y)),c>p)){const S=e.scrollWidth-this.wt;this.position=k.e(-S+P-this.wt/x+c,this.position.y)}if(t.oO&&this.allowVerticalScroll&&(l<d&&(this.position=k.e(this.position.x,t.scrollTop+l)),f>y)){const S=e.scrollHeight-this.xt;this.position=k.e(this.position.x,-S+t.scrollTop-this.xt/x+f)}Point.i(k),this.ha(),this.op=!1,this.td=!1,s=this.documentBounds,n=this.viewportBounds,c=s.right,p=n.right,f=s.bottom,y=n.bottom,r=s.x,u=n.x,l=s.y,d=n.y,m>=a&&r>=u&&c<=p&&(i.style.width="1px"),g>=h&&l>=d&&f<=y&&(i.style.height="1px")}computeBounds(t){return t===void 0&&(t=new Rect),this.Te(),this.aT(t)}aT(t){if(this.fixedBounds.isReal())return t.h(this.fixedBounds),t.addMargin(this.Qt),t;let e=!0;const i=this.zt.r,s=i.length;for(let n=0;n<s;n++){const o=i[n];if(!o.visible||!o.isInDocumentBounds)continue;const r=o.Ct.r,l=r.length;for(let a=0;a<l;a++){const h=r[a];if(!h.isInDocumentBounds||!h.isVisible())continue;const c=h.actualBounds;c.isReal()&&(e?(e=!1,t.h(c)):t.unionRect(c))}}return e&&t.e(0,0,0,0),t.addMargin(this.Qt),t}computePartsBounds(t,e){e===void 0&&(e=!1);let i;if(Array.isArray(t))for(let s=0;s<t.length;s++){const n=t[s];!e&&n instanceof Link||(n.ensureBounds(),i===void 0?i=n.actualBounds.copy():i.unionRect(n.actualBounds))}else{const s=t.iterator;for(;s.next();){const n=s.value;!e&&n instanceof Link||(n.ensureBounds(),i===void 0?i=n.actualBounds.copy():i.unionRect(n.actualBounds))}}return i===void 0?new Rect(NaN,NaN,0,0):i}$s(t){if(!t&&!this.no||this.Ht||this.st===null||!this.documentBounds.isReal())return;if(this.Ht=!0,t){const f=this.initialPosition;if(f.isReal()){this.Ht=!1,this.position=f;return}let u=this.initialDocumentSpot,d=this.initialViewportSpot;u.isNoSpot()&&(u=Spot.TopLeft),d.isNoSpot()&&(d=Spot.TopLeft);const m=Point.l();m.setRectSpot(this.documentBounds,u);const g=this.viewportBounds,p=Rect.z(0,0,g.width,g.height),y=Point.l();y.setRectSpot(p,d),y.e(m.x-y.x,m.y-y.y),this.Ht=!1,this.position=y,Rect.i(p),Point.i(y)}let e=this.ia;t&&this.Or!==1&&(e=this.Or);const i=e!==1?this.hd(e):this.scale,s=this.ct.x,n=this.ct.y,o=this.wt/i,r=this.xt/i;let l=this.Wc;const a=this.ep;if(t&&!l.isSpot()&&(a.isSpot()||a.isDefault())){const f=this.initialDocumentSpot.isSpot()&&this.initialViewportSpot.isSpot();l=a.isDefault()&&!f?Spot.Center:a}this.w2(this.documentBounds,o,r,l,t);const h=this.scale;this.scale=i,this.Ht=!1;const c=this.viewportBounds;c.equalsApproxTo(s,n,o,r)||this.onViewportBoundsChanged(new Rect(s,n,o,r),c,h,!1)}hd(t){const e=this.fp;if(this.st===null)return e;if(t===1)return this.scale;this.ensureBounds();const i=this.documentBounds;if(!i.isReal())return e;const s=i.width,n=i.height,o=this.wt+(this.so?this.qt:0),r=this.xt+(this.Pn?this.qt:0);let l=o/s,a=r/n;const h=this.hh,c=h.left+h.right!==0,f=h.top+h.bottom!==0;(c||f)&&(a===l?(a=(r-this.qt)/n,l=(o-this.qt)/s):a>l?a=(r-this.qt)/n:l=(o-this.qt)/s);let u=0;return t===2?u=Math.min(a,l):t===3&&(a>l?u=(r-this.qt)/n:u=(o-this.qt)/s),u>e&&(u=e),u<this.minScale&&(u=this.minScale),u>this.maxScale&&(u=this.maxScale),u}zoomToFit(){const t=this.oh;this.oh=1,this.scale=this.hd(2),this.alignDocument(Spot.Center,Spot.Center),t!==1&&(this.$s(!1),this.w2(this.documentBounds,this.wt/this.it,this.xt/this.it,this.Wc,!1)),this.oh=t}zoomToRect(t,e){e===void 0&&(e=2);const i=t.width,s=t.height;if(i===0||s===0||isNaN(i)&&isNaN(s))return;let n=1;if(e===2||e===3)if(isNaN(i))n=this.viewportBounds.height*this.scale/s;else if(isNaN(s))n=this.viewportBounds.width*this.scale/i;else{const o=this.wt,r=this.xt;e===3?r/s>o/i?n=(r-(this.Pn?this.qt:0))/s:n=(o-(this.so?this.qt:0))/i:n=Math.min(r/s,o/i)}this.scale=n,this.position=new Point(t.x,t.y)}get mO(){return this.Ht}set mO(t){this.Ht=t}alignDocument(t,e){this.ensureBounds();const i=this.documentBounds,s=this.viewportBounds;this.position=new Point(i.x+(t.x*i.width+t.offsetX)-(e.x*s.width-e.offsetX),i.y+(t.y*i.height+t.offsetY)-(e.y*s.height-e.offsetY))}focusObject(t){if(t instanceof GraphObject){this.wp=t;const e=Point.l();this.xp=this.transformDocToView(t.getDocumentPoint(Spot.TopLeft,e)),Point.i(e)}else this.wp=null,this.xp=Point.mn}w2(t,e,i,s,n){const o=Point.z(this.ct.x,this.ct.y);let r=o.x,l=o.y;if(this.wp!==null){let a=Point.l();a=this.wp.getDocumentPoint(Spot.TopLeft,a),r=a.x-this.xp.x/this.scale,l=a.y-this.xp.y/this.scale,s=Spot.None,Point.i(a)}if(n||this.scrollMode===1){s.isSpot()&&(e>t.width&&(r=t.x+(s.x*t.width+s.offsetX)-(s.x*e-s.offsetX)),i>t.height&&(l=t.y+(s.y*t.height+s.offsetY)-(s.y*i-s.offsetY)));const a=this.hh,h=e-t.width;if(e<t.width+a.left+a.right){let f=r+e/2;f=Math.min(f,t.right+Math.max(h,a.right)-e/2),f=Math.max(f,t.left-Math.max(h,a.left)+e/2),r=f-e/2}else r>t.left?r=t.left:r<t.right-e&&(r=t.right-e);const c=i-t.height;if(i<t.height+a.top+a.bottom){let f=l+i/2;f=Math.min(f,t.bottom+Math.max(c,a.bottom)-i/2),f=Math.max(f,t.top-Math.max(c,a.top)+i/2),l=f-i/2}else l>t.top?l=t.top:l<t.bottom-i&&(l=t.bottom-i)}if(o.x=isFinite(r)?r:-this.Qt.left,o.y=isFinite(l)?l:-this.Qt.top,this.positionComputation!==null){const a=this.positionComputation(this,o);o.x=a.x,o.y=a.y}this.Ns.IA(this.ct,o),this.ct.e(o.x,o.y),this.Mp(),this.aa(),this.pO(),Point.i(o)}findPartAt(t,e){if(e===void 0&&(e=!0),e){const i=this.bS(t,s=>s.part,s=>s.canSelect());if(i instanceof Part)return i}else{const i=this.bS(t,s=>s.part);if(i instanceof Part)return i}return null}findObjectAt(t,e,i){e===void 0&&(e=null),i===void 0&&(i=null),this.Te();const s=this.zt.iteratorBackwards;for(;s.next();){const n=s.value;if(!n.visible)continue;const o=n.findObjectAt(t,e,i);if(o!==null)return o}return null}bS(t,e,i){e===void 0&&(e=null),i===void 0&&(i=null),this.Te();const s=this.zt.iteratorBackwards;for(;s.next();){const n=s.value;if(!n.visible||n.isTemporary)continue;const o=n.findObjectAt(t,e,i);if(o!==null)return o}return null}findPartsAt(t,e,i){return e===void 0&&(e=!0),this.yO(t,s=>s.part,e?s=>s instanceof Part&&s.canSelect():null,i)}yO(t,e,i,s){e===void 0&&(e=null),i===void 0&&(i=null),!(s instanceof List)&&!(s instanceof GSet)&&(s=new GSet),this.Te();const n=this.zt.iteratorBackwards;for(;n.next();){const o=n.value;!o.visible||o.isTemporary||o.findObjectsAt(t,e,i,s)}return s}findObjectsAt(t,e,i,s){e===void 0&&(e=null),i===void 0&&(i=null),!(s instanceof List)&&!(s instanceof GSet)&&(s=new GSet),this.Te();const n=this.zt.iteratorBackwards;for(;n.next();){const o=n.value;o.visible&&o.findObjectsAt(t,e,i,s)}return s}findPartsIn(t,e,i,s){return e===void 0&&(e=!1),i===void 0&&(i=!0),this.wO(t,null,n=>n instanceof Part&&(!i||n.canSelect()),e,s)}findObjectsIn(t,e,i,s,n){e===void 0&&(e=null),i===void 0&&(i=null),s===void 0&&(s=!1),!(n instanceof List)&&!(n instanceof GSet)&&(n=new GSet),this.Te();const o=this.zt.iteratorBackwards;for(;o.next();){const r=o.value;r.visible&&r.findObjectsIn(t,e,i,s,n)}return n}SS(t,e,i,s,n,o){const r=new GSet;this.Te();const l=this.zt.iteratorBackwards;for(;l.next();){const a=l.value;a.visible&&a.SS(t,e,i,s,r,n,o)}return r}wO(t,e,i,s,n){e===void 0&&(e=null),i===void 0&&(i=null),s===void 0&&(s=!1),!(n instanceof List)&&!(n instanceof GSet)&&(n=new GSet),this.Te();const o=this.zt.iteratorBackwards;for(;o.next();){const r=o.value;!r.visible||r.isTemporary||r.findObjectsIn(t,e,i,s,n)}return n}findPartsNear(t,e,i,s,n){return i===void 0&&(i=!0),s===void 0&&(s=!0),this.xO(t,e,null,o=>o instanceof Part&&(!s||o.canSelect()),i,n)}findObjectsNear(t,e,i,s,n,o){i===void 0&&(i=null),s===void 0&&(s=null),n===void 0&&(n=!0),n!==!1&&n!==!0&&((n instanceof List||n instanceof GSet)&&(o=n),n=!0),!(o instanceof List)&&!(o instanceof GSet)&&(o=new GSet),this.Te();const r=this.zt.iteratorBackwards;for(;r.next();){const l=r.value;l.visible&&l.findObjectsNear(t,e,i,s,n,o)}return o}xO(t,e,i,s,n,o){i===void 0&&(i=null),s===void 0&&(s=null),n===void 0&&(n=!0),n!==!1&&n!==!0&&((n instanceof List||n instanceof GSet)&&(o=n),n=!0),!(o instanceof List)&&!(o instanceof GSet)&&(o=new GSet),this.Te();const r=this.zt.iteratorBackwards;for(;r.next();){const l=r.value;!l.visible||l.isTemporary||l.findObjectsNear(t,e,i,s,n,o)}return o}acceptEvent(t){return this.of(t,t instanceof MouseEvent)}of(t,e){const i=this.Jr;this.Jr=this.uh,this.uh=i,i.diagram=this,i.event=t,e?this.Sp(t,i):(i.viewPoint=this.Jr.viewPoint,i.documentPoint=this.Jr.documentPoint);let s=0;const n=t;return n.ctrlKey&&(s+=1),n.altKey&&(s+=2),n.shiftKey&&(s+=4),n.metaKey&&(s+=8),i.modifiers=s,i.button=n.button,n.buttons!==void 0&&(i.buttons=n.buttons),U.ur&&n.button===0&&n.ctrlKey&&(i.button=2),i.down=!1,i.up=!1,i.clickCount=1,i.delta=0,i.handled=!1,i.bubbles=!1,i.timestamp=t.timeStamp,i.isMultiTouch=!1,i.targetDiagram=this.i1(t,t.target),i.targetObject=null,i}i1(t,e){if(e===null)return null;const i=Diagram.Wi.get(e);if(i)return i;let s=t.path;if(!s&&U.nt(t.composedPath)&&(s=t.composedPath()),s&&s[0]){const n=Diagram.Wi.get(s[0]);if(n)return n}return null}rO(t,e,i){const s=this.p2(t,!0,!1,!1,!0,i);return this.Sp(e,s),s.targetDiagram=this.i1(t,t.target),s.targetObject=null,i||s.clone(this.cp),s}lO(t,e,i){const s=this.p2(t,!1,!1,!1,!1,i);let n=root.document.elementFromPoint(e.clientX,e.clientY)||null;n!==null&&n.shadowRoot&&(n=n.shadowRoot.elementFromPoint(e.clientX,e.clientY)||null);let o=this,r=t;if(n){const l=this.i1(t,n);l&&(r=e,o=l)}return s.targetDiagram=o,this.Sp(r,s),s.targetObject=null,s}p2(t,e,i,s,n,o){const r=this.Jr;this.Jr=this.uh,this.uh=r,r.diagram=this,r.clickCount=1,r.delta=0;let l=0;return t.ctrlKey&&(l+=1),t.altKey&&(l+=2),t.shiftKey&&(l+=4),t.metaKey&&(l+=8),r.modifiers=l,r.event=t,r.timestamp=t.timeStamp,r.button=i?this.firstInput.button:t.button,r.buttons=t.buttons,U.ur&&t.button===0&&t.ctrlKey&&(r.button=2),r.down=e,r.up=i,r.handled=s,r.bubbles=n,r.isMultiTouch=o,r}kh(t,e){return t.bubbles?!0:(e.stopPropagation!==void 0&&e.stopPropagation(),e.cancelable!==!1&&e.preventDefault(),e.cancelBubble=!0,!1)}fO(t){const e=Diagram.Wi.get(this);if(!e||!e.isEnabled)return!1;const i=e.of(t,!1);return i.key=t.key,i.code=t.code,i.down=!0,e.doKeyDown(),e.kh(i,t)}uO(t){const e=Diagram.Wi.get(this);if(!e||!e.isEnabled)return!1;const i=e.of(t,!1);return i.key=t.key,i.code=t.code,i.up=!0,e.doKeyUp(),e.kh(i,t)}hO(t){const e=Diagram.Wi.get(this);if(!e||!e.isEnabled)return!1;const i=e.of(t,!0);return e.mouseEnter!==null&&e.mouseEnter(i),e.currentTool.standardMouseOver(),e.kh(i,t)}cO(t){const e=Diagram.Wi.get(this);if(!e||!e.isEnabled)return!1;const i=e.of(t,!0);return e.mouseLeave!==null&&e.mouseLeave(i),e.kh(i,t)}getMouse(t){const e=this.st;if(e===null)return new Point(0,0);const i=e.getBoundingClientRect(),s=(t.clientX-i.left)*(this.wt/i.width),n=(t.clientY-i.top)*(this.xt/i.height);return new Point(s,n).Ki(this.v)}Sp(t,e){const i=this.st;let s=0,n=0;if(i!==null){const r=i.getBoundingClientRect();s=(t.clientX-r.left)*(this.wt/r.width),n=(t.clientY-r.top)*(this.xt/r.height)}e.viewPoint.e(s,n);const o=Point.z(s,n);this.v.Ci(o),e.documentPoint.h(o),Point.i(o)}_L(t,e,i){let s;if(this.mh[0]!==null)s=this.mh[e];else return;const n=this.st;if(n!==null){const o=n.getBoundingClientRect();i.e((s.clientX-o.left)*(this.wt/o.width),(s.clientY-o.top)*(this.xt/o.height))}}invalidateDocumentBounds(){this.dh||(this.dh=!0,this.requestUpdate(!1))}bO(){this.Ts||this.Te(),this.ensureBounds()}redraw(){this.Ht||this.Ts||(this.C(),this.maybeUpdate())}isUpdateRequested(){return this.Dr}delayInitialization(t){t===void 0&&(t=null);const e=this.animationManager,i=e.isEnabled;e.stopAnimation(),e.isEnabled=!1,this.Sr(),this.no=!1,this.Hx=new Point(NaN,NaN),e.isEnabled=i,this.Ts=!0;const s=this;t!==null&&U.dn(()=>{s.Ts=!1,e.Gl("Model"),t(s)},1)}requestUpdate(t){if(t===void 0&&(t=!1),this.Dr===!0||this.Ht||t===!1&&this.Ts)return;this.Dr=!0;const e=this;root.requestAnimationFrame(()=>{e.Dr&&e.maybeUpdate()})}maybeUpdate(){this.Zu&&!this.Dr||(this.Zu&&(this.Zu=!1),this.Sr())}b2(t,e){!this.td||this.Ht||this.animationManager.defaultAnimation.isAnimating||this.lT()||(t&&this.Te(),e&&this.$s(!1))}Sr(t){if(this.Ts||(this.Dr=!1,this.St===null&&!this.ed.isReal()))return;this.Ts=!0;const e=this.animationManager,i=this.rd;if(!e.isAnimating&&i.length!==0){const c=i.r,f=c.length;for(let u=0;u<f;u++){const d=c[u];d.wi(!1),d.c()}i.clear()}const s=this.s2;s.count>0&&(s.each(c=>c.k2()),s.clear());let n=!1,o=!1;e.defaultAnimation.isAnimating&&(o=!0,n=this.skipsUndoManager,this.skipsUndoManager=!0),e.ke||this.SM(),t||this.b2(!1,!0);const r=!this.undoManager.isUndoingRedoing&&(this.Fl||this.nf.count!==0&&this.Ir.size!==0),l=!this.no||this.$r;this.Te(!0);let a=!1;(l||r)&&(this.no?this.P2(!this.$c,r):(this.startTransaction("Initial Layout"),e.isEnabled===!1&&e.stopAnimation(),this.P2(!1,r)),a=l),this.$c=!1,this.Fl=!1,this.Te(),this.ls!==null&&(this.ls.visible&&!this.sd&&(this.ca(),this.sd=!0),!this.ls.visible&&this.sd&&(this.sd=!1)),this.Cb||this.bO(),t||this.b2(!0,!1);let h=!1;if(a){const c=Rect.l();c.h(this.viewportBounds),this.no||(this.no=!0,h=!0,this.skipsUndoManager||(this.undoManager.kx=!0),this.undoManager.Px=!0,this.kO()),this.PO(),this.Te(!1),t||this.b2(!0,!0),Rect.i(c)}else if(e.Bc&&e.Kx){if(this.Or!==1)this.scale=this.hd(this.Or);else if(this.ia!==1)this.scale=this.hd(this.ia);else{const c=this.initialScale;isFinite(c)&&c>0&&(this.scale=c)}this.$s(!0)}a&&h&&this.commitTransaction("Initial Layout"),t||this.Ge(this.Wt),o&&(this.skipsUndoManager=n),this.Ts=!1}get $a(){return this.no}kO(){if(this.Or!==1)this.scale=this.hd(this.Or);else if(this.ia!==1)this.scale=this.hd(this.ia);else{const e=this.initialScale;isFinite(e)&&e>0&&(this.scale=e)}this.$s(!0);const t=this.zt.r;this.As(t,t.length,this,this.viewportBounds),this.T("InitialLayoutCompleted"),this.Hx.h(this.ct),this.ca()}PO(){this.T("LayoutCompleted")}Np(t){this.eo.add(t)}addInvalidRoute(t){this.Vo?this.ch.add(t):this.Ir.add(t)}Te(t){if(this.eo.size!==0&&!(!this.Ts&&this.animationManager.isTicking)){if(this.Ts||(this.Fl=!0),t){this.hT(this.eo);return}for(let e=0;e<23&&this.eo.size!==0;e++){const i=new Set(this.eo);this.eo.clear(),this.k2(i,this.eo)}this.nodes.each(e=>{e instanceof Group&&e.cT(!1)})}}hT(t,e){for(const i of t)!i.Di()||i instanceof Group||(i._r()?(i.ht(1/0,1/0),i.Ut()):e&&e.add(i));for(const i of t)if(i instanceof Group){if(!i.isVisible())continue;this.s1(i)}}k2(t,e){this.hT(t,e);for(const i of t){if(!(i instanceof Link))continue;const s=i;s.isVisible()&&(s._r()?(s.ht(1/0,1/0),s.Ut()):e.add(s))}for(const i of t)i instanceof Adornment&&i.isVisible()&&(i._r()?(i.ht(1/0,1/0),i.Ut()):e.add(i))}cd(t){const e=t instanceof Diagram,i=e?t.links:t.memberParts,s=this.eo;if(e)this.Te(!0);else{for(;i.next();){const n=i.value;s.has(n)&&(!n.Di()||n instanceof Group||n._r()&&(n.ht(1/0,1/0),n.Ut()))}for(i.reset();i.next();){const n=i.value;if(s.has(n)&&n instanceof Group){if(!n.isVisible())continue;this.s1(n)}}i.reset()}for(;i.next();){const n=i.value;n instanceof Link&&s.has(n)&&n.isVisible()&&n._r()&&(n.ht(1/0,1/0),n.Ut())}}s1(t){const e=U.ot(),i=U.ot(),s=t.memberParts;for(;s.next();){const o=s.value;o.isVisible()&&(o instanceof Group?(o.Go()||o.as()||o.fa())&&this.s1(o):o instanceof Link?o.fromNode===t||o.toNode===t?i.push(o):e.push(o):(o.ht(1/0,1/0),o.Ut()))}let n=e.length;for(let o=0;o<n;o++){const r=e[o];r.ht(1/0,1/0),r.Ut()}U.Z(e),t.ht(1/0,1/0),t.Ut(),n=i.length;for(let o=0;o<n;o++){const r=i[o];r.ht(1/0,1/0),r.Ut()}U.Z(i)}As(t,e,i,s){if(!(!this._c&&!this.animationManager.isAnimating)){for(let n=0;n<e;n++)t[n].As(i,s);this.Te()}}Ge(t){if(this.St===null)return;this.st===null&&U.o("No canvas specified"),this.Qc==="svg"?this.SO(t):this.MO(t)}MO(t){const e=this.animationManager;if(e.ke||e.isAnimating&&!e.isTicking)return;const i=new Date;if(this.Cp(),this.St&&this.St.style.opacity==="0")return;const s=t!==this.Wt,n=this.zt.r,o=n.length,r=this;if(this.As(n,o,r,r.viewportBounds),s)t.clearContextCache(!0),this.ha();else if(!this.qi&&!e.isAnimating)return;const l=this.v,a=this.$e;t.setTransform(a,0,0,a,0,0),t.clearRect(0,0,this.wt,this.xt),this.Zt!==1&&(t.globalAlpha=this.Zt),this.S2(t);for(let m=0;m<o;m++)t.setTransform(a,0,0,a,0,0),t.transform(l.m11,l.m12,l.m21,l.m22,l.dx,l.dy),t.commitTransform(),n[m].Ge(t,r);let h=!1;this.sf?this.sf.Ph(this,t)&&(h=this.dp()):h=!0,h&&(Transform.prototype.Ci=Transform.prototype.Mu),s?(this.Wt.clearContextCache(!0),this.ha()):(this._c=!1,this.qi=!1);const f=+new Date-+i,u=!1,d=this.c2;if(u||this.Ol===null){d[this.yp]=f,this.yp=(this.yp+1)%d.length;let m=0;for(let g=0;g<d.length;g++)m+=d[g];this.pp=m/d.length}if(this.Zt!==1&&(t.globalAlpha=1),u){t.setTransform(1,0,0,1,0,0);for(let m=0;m<d.length;m++)t.fillText(d[m].toString(),20,150+ +(m*20))}}SO(t){if(this.St===null)return;const e=this.animationManager;if(e.ke||e.isAnimating&&!e.isTicking)return;this.Cp();const i=this.wt,s=this.xt;t.surface.resize(i,s,i,s);const o=this.zt.r,r=o.length,l=this;if(this.As(o,r,l,l.viewportBounds),!this.qi&&!e.isAnimating)return;const a=this.v;t.lastDrawnPart=null,t.setDiagramPosScale(a.m11,a.m12,a.m21,a.m22,a.dx,a.dy),this.Zt!==1&&(t.globalAlpha=this.Zt),this.S2(t);const h=this.$e,c=this.st._t;c.setTransform(h,0,0,h,0,0),c.clearRect(0,0,this.wt,this.xt);for(let u=0;u<r;u++)o[u].Ge(t,l);let f=!1;this.sf?this.sf.Ph(this,c)&&(f=this.dp()):f=!0,f&&(Transform.prototype.Ci=Transform.prototype.Mu),this._c=!1,this.qi=!1}o1(t,e,i,s,n,o,r,l,a){if(this.St===null)return;this.st===null&&U.o("No canvas specified"),o===void 0&&(o=null),r===void 0&&(r=null),l===void 0&&(l=!1),a===void 0&&(a=!1),this.Cp(),this.Wt.clearContextCache(!0),this.ha(),this.gh=!0;const h=this.it;this.it=s;const c=this,f=this.zt.r,u=f.length;try{const d=new Rect(n.x,n.y,i.width/s,i.height/s),m=d.copy();m.addMargin(e),this.ca(m),this.Te(),this.As(f,u,c,d),t.setTransform(1,0,0,1,0,0),t.clearRect(0,0,i.width,i.height),r!==null&&r!==""&&(t.fillStyle=r,t.fillBackground(0,0,i.width,i.height));const g=Transform.l();g.Ue(),g.Gs(e.left,e.top),g.it(s),(n.x!==0||n.y!==0)&&g.Gs(-n.x,-n.y),t.setTransform(g.m11,g.m12,g.m21,g.m22,g.dx,g.dy),t.commitTransform(),t instanceof SVGContext&&t.setDiagramPosScale(g.m11,g.m12,g.m21,g.m22,g.dx,g.dy),Transform.i(g),this.S2(t),t.globalAlpha=this.Zt;const p=this.findLayer("Grid");if(o){const y=new GSet,x=o.iterator;for(x.reset();x.next();){const k=x.value;k instanceof Part&&(!a&&k.layer===p||(k.qc(),y.add(k)))}for(let k=0;k<u;k++)f[k].IR(t,c,y,l);y.each(k=>k.qc())}else for(let y=0;y<u;y++){const x=f[y];x===p?a&&x.Ge(t,c,!0):x.Ge(t,c,l)}this.gh=!1,this.sf&&this.sf.Ph(this,this.Wt)&&this.dp()}finally{this.it=h,this.Wt.clearContextCache(!0),this.ha(),this.As(f,u,c,c.viewportBounds),this.ca(),this.Wt instanceof SVGContext&&(this.Wt.diagramGroup.replaceChildren(),this.redraw())}}getRenderingHint(t){return this.Rr[t]}setRenderingHint(t,e){t==="minDrawingLength"&&(this.Qm=e),this.Rr[t]=e,this.redraw()}resetRenderingHints(){this.Rr=new PropertyCollection,this.Rr.drawShadows=!0,this.Rr.textGreeking=!0,this.Rr.viewportOptimizations=!U.ur,this.Rr.temporaryPixelRatio=!0,this.Rr.pictureRatioOptimization=!0,this.Rr.minDrawingLength=1,this.Qm=1}S2(t){const e=this.Rr;if(e===null)return;if(e.imageSmoothingEnabled!==void 0){const s=!!e.imageSmoothingEnabled;t.setImageSmoothingEnabled(s)}const i=e.defaultFont;i!=null&&(t.font=i)}getInputOption(t){return this.Ju[t]}setInputOption(t,e){this.Ju[t]=e}ZR(){this.Ju=new PropertyCollection,this.Ju.extraTouchArea=10,this.Ju.extraTouchThreshold=10,this.Ju.hasGestureZoom=!0}set(t){return t?(Object.assign(this,t),this):this}attach(t){return this.setProperties(t)}setProperties(t){return Diagram.Lp(this,t),this}static Lp(t,e){if(!e)return;const i=t instanceof Panel,s=t instanceof Diagram;for(const n in e){n===""&&U.o("Setting properties requires non-empty property names");let o=t,r=n;if(i||s){const a=n.indexOf(".");if(a>0){const h=n.substring(0,a);i?o=t.findObject(h):(o=t[h],o==null&&(o=t.toolManager[h])),U.$(o)?r=n.substring(a+1):U.o("Unable to find object named: "+h+" in "+t.toString()+" when trying to set property: "+n)}}if(r[0]!=="_"&&!U.Hw(o,r))if(s&&r==="ModelChanged"){t.addModelChangedListener(e[r]);continue}else if(s&&r==="Changed"){t.addChangedListener(e[r]);continue}else if(s&&U.Hw(t.toolManager,r))o=t.toolManager;else if(s&&t.fT(r)){t.addDiagramListener(r,e[r]);continue}else if(t instanceof Model&&r==="Changed"){t.addChangedListener(e[r]);continue}else U.o('Trying to set undefined property "'+r+'" on object: '+o.toString());const l=e[n];o[r]=l,r[0]==="_"&&o instanceof GraphObject&&o.addCopyProperty(r)}}VA(){if(this.ra.count!==0&&!(this.undoManager.transactionLevel>1)){for(;this.ra.count>0;){const t=this.ra;this.ra=new GMap;const e=t.iterator;for(;e.next();){const i=e.key;i.invalidateOtherJumpOvers(e.value),i.Ze()}}this.C()}}C(t){if(t===void 0)this.qi=!0,this.requestUpdate();else{const e=this.viewportBounds;t.isReal()&&e.intersectsRect(t)&&(this.qi=!0,this.requestUpdate())}this.T("InvalidateDraw")}invalidateViewport(t,e){if(this.qi===!0)return;if(this.qi=!0,this.Qc==="svg"){this.maybeUpdate();return}this.getRenderingHint("temporaryPixelRatio")===!0?(this.Nx(),this.maybeUpdate(),this.pS(!0)):this.maybeUpdate()}Sh(){this.td=!0}ha(){this._c=!0}Cp(){this.$u!==!1&&(this.$u=!1,this.oT(this.wt,this.xt))}oT(t,e){this.aa();const i=this.$e,s=t*i,n=e*i;this.st.resize(s,n,t,e)&&(this.qi=!0,this.Wt.clearContextCache(!0))}lT(){const t=this.st;if(t===null||this.ed.isReal())return!0;const e=this.wt,i=this.xt,s=this.St;let n=!1,o=this.so?this.qt:0,r=this.Pn?this.qt:0,l=s.clientWidth||e+o,a=s.clientHeight||i+r;const h=this.viewportBounds,c=h.x,f=h.y,u=h.width,d=h.height;if((l!==e+o||a!==i+r)&&(this.so=!1,this.Pn=!1,o=0,r=0,this.wt=l,this.xt=a,this.$u=!0,n=!0,this.aa()),!this.no||!this.viewportBounds.isReal())return!0;const m=this.qb,g=this.Wb;if(this.td=!1,!n&&!this.so&&!this.Pn&&!this.Qu&&!this._u)return!0;const p=this.documentBounds;let y=0,x=0,k=0,b=0;const P=h.width,S=h.height,L=this.hh;this.contentAlignment.isSpot()?(p.width>P&&(y=L.left,x=L.right),p.height>S&&(k=L.top,b=L.bottom)):(y=L.left,x=L.right,k=L.top,b=L.bottom);const C=p.width+y+x,M=p.height+k+b,N=this.scale,T=N;let A=C>l/N,D=M>a/N;if(!n&&!this.so&&!this.Pn&&!A&&!D)return!0;const v=p.x-y,R=h.x,F=p.right+x;let O=h.right+o;const z=p.y-k,Y=h.y,E=p.bottom+b;let X=h.bottom+r,B="1px",H="1px";if(this.scrollMode===1&&(A||D)){if(A&&this.hasHorizontalScrollbar&&this.allowHorizontalScroll){let V=1;v+1<R&&(V=Math.max((R-v)*N+this.wt,V)),F>O+1&&(V=Math.max((F-O)*N+this.wt,V)),P+o+1<C&&(V=Math.max((C-P)*N+this.wt,V)),B=V.toString()+"px"}if(D&&this.hasVerticalScrollbar&&this.allowVerticalScroll){let V=1;z+1<Y&&(V=Math.max((Y-z)*N+this.xt,V)),E>X+1&&(V=Math.max((E-X)*N+this.xt,V)),S+r+1<M&&(V=Math.max((M-S)*N+this.xt,V)),H=V.toString()+"px"}}let j=B!=="1px",W=H!=="1px";if(!(j&&W)&&(j||W)){if(A=!(C<P+o),D=!(M<S+r),W&&(O-=this.qt),j&&(X-=this.qt),A&&this.hasHorizontalScrollbar&&this.allowHorizontalScroll){let $=1;v+1<R&&($=Math.max((R-v)*N+this.wt,$)),F>O+1&&($=Math.max((F-O)*N+this.wt,$)),P+1<C&&($=Math.max((C-P)*N+this.wt,$)),B=$.toString()+"px"}j=B!=="1px";let V=this.xt;if(j!==this.Pn&&(V=j?this.xt-this.qt:this.xt+this.qt),D&&this.hasVerticalScrollbar&&this.allowVerticalScroll){let $=1;z+1<Y&&($=Math.max((Y-z)*N+V,$)),E>X+1&&($=Math.max((E-X)*N+V,$)),S+1<M&&($=Math.max((M-S)*N+V,$)),H=$.toString()+"px"}W=H!=="1px"}if(this.op&&!(j!==this.Pn||W!==this.so))return(e!==this.wt||i!==this.xt)&&this.maybeUpdate(),!1;if(j!==this.Pn&&(B==="1px"?this.xt=this.xt+this.qt:this.xt=Math.max(this.xt-this.qt,1),n=!0),this.Pn=j,g.style.width=B,W!==this.so&&(H==="1px"?this.wt=this.wt+this.qt:this.wt=Math.max(this.wt-this.qt,1),n=!0,this.ld)){const V=Point.l();W?(t.style.left=this.qt+"px",this.position=V.e(this.ct.x+this.qt/this.scale,this.ct.y)):(t.style.left="0px",this.position=V.e(this.ct.x-this.qt/this.scale,this.ct.y)),Point.i(V)}n&&this.aa(),this.so=W,g.style.height=H,this.Vb=!0,n&&(this.$u=!0);let Z=m.scrollLeft;if(this.hasHorizontalScrollbar&&this.allowHorizontalScroll&&(P+1<C?Z=(this.position.x-v)*N:v+1<R?Z=m.scrollWidth-m.clientWidth:F>O+1&&(Z=this.position.x*N)),this.ld)switch(this.rb){case"negative":Z=-(m.scrollWidth-Z-m.clientWidth);break;case"reverse":Z=m.scrollWidth-Z-m.clientWidth;break}if(m.scrollLeft=Z,this.hasVerticalScrollbar&&this.allowVerticalScroll&&(S+1<M?m.scrollTop=(this.position.y-z)*N:z+1<Y?m.scrollTop=m.scrollHeight-m.clientHeight:E>X+1&&(m.scrollTop=this.position.y*N)),l=this.wt,a=this.xt,m.style.width=l+(this.so?this.qt:0)+"px",m.style.height=a+(this.Pn?this.qt:0)+"px",e!==l||i!==a||this.animationManager.ke){const V=Rect.z(c,f,u,d);return this.onViewportBoundsChanged(V,this.viewportBounds,T,n),Rect.i(V),!1}return!0}add(t){const e=t.diagram;if(e===this)return;e!==null&&U.o("Cannot add part "+t.toString()+" to "+this.toString()+". It is already a part of "+e.toString());let i=this.findLayer(t.layerName);if(i===null&&(i=this.findLayer("")),i===null&&U.o('Cannot add a Part when unable find a Layer named "'+t.layerName+'" and there is no default Layer'),t.layer===i)return;const s=i.ah(99999999,t,t.diagram===this);s>=0&&this.raiseChangedEvent(3,"parts",i,null,t,null,s),i.isTemporary||this.invalidateDocumentBounds(),t.invalidateLayout(1);const n=t.layerChanged;n!==null&&n(t,null,i)}ah(t){this.partManager.ah(t);const e=this;t.Sn(s=>e.uT(s)),t.data||t.Yo(),t.hasPlaceholder()&&t.c(),t.data!==null&&t.Sn(s=>e.partManager.M2(s,null)),(t.as()===!0||t.fa()===!0)&&this.Np(t),t.dT(!0,this),t.gT()?(t.actualBounds.isReal()&&this.C(t.lh(t.actualBounds)),this.invalidateDocumentBounds()):t.isVisible()&&t.actualBounds.isReal()&&this.C(t.lh(t.actualBounds)),this.bp!==null&&this.bp(this,t),this.requestUpdate()}ri(t){t.clearAdornments(),this.partManager.ri(t);const e=this;t.data!==null&&t.Sn(s=>e.partManager.N2(s,e)),this.eo.delete(t),t instanceof Link&&this.Ir.delete(t),t.gT()?(t.actualBounds.isReal()&&this.C(t.lh(t.actualBounds)),this.invalidateDocumentBounds()):t.isVisible()&&t.actualBounds.isReal()&&this.C(t.lh(t.actualBounds)),this.kp!==null&&this.kp(this,t),this.requestUpdate()}remove(t){this.C2(t,!0)}C2(t,e){const i=t.layer;if(i===null||i.diagram!==this)return;t.isSelected=!1,t.isHighlighted=!1,t.invalidateLayout(2),e&&t.rf();const s=i.ri(-1,t,!1);s>=0&&this.raiseChangedEvent(4,"parts",i,t,null,s,null);const n=t.layerChanged;n!==null&&n(t,i,null)}removeParts(t,e){if(e===void 0&&(e=!1),Array.isArray(t)){const i=t.length;for(let s=0;s<i;s++){const n=t[s];e&&!n.canDelete()||this.remove(n)}}else{const i=new GSet;i.addAll(t);const s=i.iterator;for(;s.next();){const n=s.value;e&&!n.canDelete()||this.remove(n)}}}copyParts(t,e,i){i===void 0&&(i=!1);let s=null;const n=e||this,o=n.model;let r=!1,l=!1;try{o.Um()&&(r=o.copiesParentKeyOfNodeData,o.copiesParentKeyOfNodeData=n.commandHandler.copiesParentKey),(o.Em()||o.l1())&&(l=o.copiesGroupKeyOfNodeData,o.copiesGroupKeyOfNodeData=n.commandHandler.copiesGroupKey),s=this.partManager.copyParts(t,e,i)}finally{o.Um()&&(o.copiesParentKeyOfNodeData=r),(o.Em()||o.l1())&&(o.copiesGroupKeyOfNodeData=l)}return s}moveParts(t,e,i,s){if(i===void 0&&(i=!1),s===void 0&&(s=this.Ap()),this.toolManager===null)return;const o=new GMap;if(t!==null)if(Array.isArray(t))for(let r=0;r<t.length;r++)this.tl(o,t[r],i,s);else{const r=t.iterator;for(;r.next();)this.tl(o,r.value,i,s)}else{let r=this.parts;for(;r.next();){const l=r.value;this.tl(o,l,i,s)}for(r=this.nodes;r.next();){const l=r.value;this.tl(o,l,i,s)}for(r=this.links;r.next();){const l=r.value;this.tl(o,l,i,s)}}this.Cx(o,e,s,i)}tl(t,e,i,s,n){if(!t.has(e)&&(n===void 0&&(n=!1),!(i&&!n&&!e.canMove()&&!e.canCopy())))if(s===void 0&&(s=this.Ap()),e instanceof Node){if(t.set(e,this.Ws(s,e,e.location)),e instanceof Group&&(e.hasPlaceholder()||s.dragsMembers)){const r=e.memberParts;for(;r.next();){const l=r.value;this.tl(t,l,i,s,s.groupsAlwaysMove)}}const o=e.linksConnected;for(;o.next();){const r=o.value;if(t.has(r))continue;const l=r.fromNode,a=r.toNode;l!==null&&t.has(l)&&a!==null&&t.has(a)&&this.tl(t,r,i,s)}if(s.dragsTree){const r=e.findTreeChildrenNodes();for(;r.next();){const l=r.value;this.tl(t,l,i,s)}}}else if(e instanceof Link){t.set(e,this.Ws(s,e));const o=e.labelNodes;for(;o.next();){const r=o.value;this.tl(t,r,i,s)}}else e instanceof Adornment||t.set(e,this.Ws(s,e,e.location))}Cx(t,e,i,s){if(t===null||t.count===0)return;const n=Point.l(),o=Point.l();o.h(e),isNaN(o.x)&&(o.x=0),isNaN(o.y)&&(o.y=0);const r=this.Zb;r||this.uA(t);const l=U.ot(),a=U.ot(),h=t.iterator;let c=Point.l();for(;h.next();){const g=h.key,p=h.value;if(g.Di()){const y=this.mT(g,t);if(y!==null)l.push(new DraggingNodeInfoPair(g,p,y));else if(!s||g.canMove()){const x=p.point;n.h(x),this.computeMove(g,n.add(o),i,c),g.location=c,p.shifted===void 0&&(p.shifted=new Point),p.shifted.h(c.subtract(x))}}else h.key instanceof Link&&a.push(new KeyValuePair(h.key,h.value))}Point.i(c);const f=l.length;for(let g=0;g<f;g++){const p=l[g],y=p.pT.point;n.h(y),p.a1.shifted===void 0&&(p.a1.shifted=new Point),p.Ri.location=n.add(p.a1.shifted)}const u=Point.l(),d=Point.l(),m=a.length;for(let g=0;g<m;g++){const p=a[g],y=p.key;if(y instanceof Link){if(y.suspendsRouting){y.vr=null;const x=y.fromNode,k=y.toNode;if(this.draggedLink!==null&&i.dragsLink){const b=p.value.point;if(y.dragComputation===null){t.set(y,this.Ws(i,y,o));const P=o.x-b.x,S=o.y-b.y;y.Pr(P,S)}else{const P=Point.z(0,0),S=y.getPoint(0);S&&S.isReal()&&P.h(S),c=Point.l().h(P).add(o);let L=c;i.isGridSnapEnabled&&(i.isGridSnapRealtime||this.lastInput.up)&&(L=Point.l(),this.rM(y,c,L,i)),c.h(y.dragComputation(y,c,L)).subtract(P),t.set(y,this.Ws(i,y,c));const C=c.x-b.x,M=c.y-b.y;y.Pr(C,M),Point.i(P),Point.i(c),L!==c&&Point.i(L)}}else{if(x!==null){u.h(x.location);const b=t.get(x);b!==null&&u.subtract(b.point)}if(k!==null){d.h(k.location);const b=t.get(k);b!==null&&d.subtract(b.point)}if(x!==null&&k!==null)if(u.equalsApprox(d)){const b=p.value.point,P=n;P.h(u),P.subtract(b),t.set(y,this.Ws(i,y,u)),y.Pr(P.x,P.y)}else y.suspendsRouting=!1,y.$t();else{const b=p.value.point;let P;x!==null?P=u:k!==null?P=d:P=o,t.set(y,this.Ws(i,y,P));const S=P.x-b.x,L=P.y-b.y;y.Pr(S,L)}}}else if(y.fromNode===null||y.toNode===null){const x=p.value.point;t.set(y,this.Ws(i,y,o));const k=o.x-x.x,b=o.y-x.y;y.Pr(k,b)}}}Point.i(n),Point.i(o),Point.i(u),Point.i(d),U.Z(l),U.Z(a),r||(this.Te(),this.mS(t))}computeMove(t,e,i,s){if(s===void 0&&(s=new Point),s.h(e),t===null)return s;let n=e;const o=i.isGridSnapEnabled;o&&(i.isGridSnapRealtime||this.lastInput.up)&&(n=Point.l(),this.rM(t,e,n,i));const r=t.dragComputation!==null?t.dragComputation(t,e,n):n,l=t.minLocation;let a=l.x;isNaN(a)&&(a=o?Math.round(t.location.x*1e3)/1e3:t.location.x);let h=l.y;isNaN(h)&&(h=o?Math.round(t.location.y*1e3)/1e3:t.location.y);const c=t.maxLocation;let f=c.x;isNaN(f)&&(f=o?Math.round(t.location.x*1e3)/1e3:t.location.x);let u=c.y;return isNaN(u)&&(u=o?Math.round(t.location.y*1e3)/1e3:t.location.y),s.e(Math.max(a,Math.min(r.x,f)),Math.max(h,Math.min(r.y,u))),n!==e&&Point.i(n),s}Ap(){const t=this.toolManager.findTool("Dragging");return t instanceof DraggingTool?t.dragOptions:this.ad}rM(t,e,i,s){if(s===void 0&&(s=this.Ap()),i.h(e),t===null)return i;const n=this.grid,o=s.gridSnapCellSize;let r=o.width,l=o.height;const a=s.gridSnapOrigin;let h=a.x,c=a.y;const f=s.gridSnapCellSpot;if(n!==null){const d=n.gridCellSize;isNaN(r)&&(r=d.width),isNaN(l)&&(l=d.height);const m=n.gridOrigin;isNaN(h)&&(h=m.x),isNaN(c)&&(c=m.y)}const u=Point.z(0,0);return u.setSpot(0,0,r,l,f),G._g(e.x,e.y,h+u.x,c+u.y,r,l,i),Point.i(u),i}uA(t){if(t===null)return;this.Zb=!0;const e=t.iterator;for(;e.next();){const i=e.key;i instanceof Link&&(i.suspendsRouting=!0)}}mS(t){if(t===null)return;const e=t.iterator;for(;e.next();){const i=e.key;i instanceof Link&&(i.suspendsRouting=!1,i.yT()&&i.$t())}this.Zb=!1}get draggedLink(){return this.Qb}set draggedLink(t){this.Qb!==t&&(this.Qb=t,t!==null&&(this._b=t.fromPort,this.t1=t.toPort))}get kS(){return this._b}set kS(t){this._b=t}get PS(){return this.t1}set PS(t){this.t1=t}mT(t,e){const i=t.containingGroup;if(i!==null){let s=this.mT(i,e);if(s!==null||(s=e.get(i),s!==null))return s}return null}Ws(t,e,i){if(i===void 0)return new DraggingInfo(Point.gn);let s=t.isGridSnapEnabled;return!t.groupsSnapMembers&&e.containingGroup!==null&&(s=!1),s?new DraggingInfo(new Point(Math.round(i.x*1e3)/1e3,Math.round(i.y*1e3)/1e3)):new DraggingInfo(i.copy())}L2(t,e){if(t.diagram!==null&&t.diagram!==this&&U.o("Cannot share a Layer with another Diagram: "+t+" of "+t.diagram),e===null?t.diagram!==null&&U.o("Cannot add an existing Layer to this Diagram again: "+t):(e.diagram!==this&&U.o("Existing Layer must be in this Diagram: "+e+" not in "+e.diagram),t===e&&U.o("Cannot move a Layer before or after itself: "+t)),t.diagram===this)return;const i=t.name,s=this.zt,n=s.count;for(let o=0;o<n;o++)s.elt(o).name===i&&U.o("Cannot add Layer with the name '"+i+"'; a Layer with the same name is already present in this Diagram.")}addLayer(t){this.L2(t,null),t.Eo(this);const e=this.zt;let i=e.count-1;if(!t.isTemporary)for(;i>=0&&e.elt(i).isTemporary;)i--;return e.insertAt(i+1,t),this.Ce!==null&&this.raiseChangedEvent(3,"layers",this,null,t,null,i+1),this.C(),this.invalidateDocumentBounds(),this}addLayerBefore(t,e){this.L2(t,e),t.Eo(this);const i=this.zt,s=i.indexOf(t);s>=0&&(i.delete(t),this.Ce!==null&&this.raiseChangedEvent(4,"layers",this,t,null,s,null));const n=i.count;let o;for(o=0;o<n;o++)if(i.elt(o)===e){i.insertAt(o,t);break}return this.Ce!==null&&this.raiseChangedEvent(3,"layers",this,null,t,null,o),this.C(),s<0&&this.invalidateDocumentBounds(),this}addLayerAfter(t,e){this.L2(t,e),t.Eo(this);const i=this.zt,s=i.indexOf(t);s>=0&&(i.delete(t),this.Ce!==null&&this.raiseChangedEvent(4,"layers",this,t,null,s,null));const n=i.count;let o;for(o=0;o<n;o++)if(i.elt(o)===e){i.insertAt(o+1,t);break}return this.Ce!==null&&this.raiseChangedEvent(3,"layers",this,null,t,null,o+1),this.C(),s<0&&this.invalidateDocumentBounds(),this}Qr(t,e){t.Eo(this),this.zt.insertAt(e,t)}wT(t){this.zt.removeAt(t)}removeLayer(t){if(t.diagram!==this&&U.o("Cannot remove a Layer from another Diagram: "+t+" of "+t.diagram),t.name==="")return;const e=this.zt,i=e.indexOf(t);if(e.delete(t)){const n=t.Ct.copy().iterator;for(;n.next();){const o=n.value,r=o.layerName;r!==t.name?o.layerName=r:o.layerName=""}this.Ce!==null&&this.raiseChangedEvent(4,"layers",this,t,null,i,null),this.C(),this.invalidateDocumentBounds()}}findLayer(t){const e=this.layers;for(;e.next();){const i=e.value;if(i.name===t)return i}return null}findRouter(t){for(const e of this.nf)if(e.name===t)return e;return null}addModelChangedListener(t){return U.S(t,Diagram,"addModelChangedListener:listener"),this.io===null&&(this.io=new List),this.io.add(t),this.model&&this.model.addChangedListener(t),this}removeModelChangedListener(t){U.S(t,Diagram,"removeModelChangedListener:listener"),this.io!==null&&(this.io.delete(t),this.io.count===0&&(this.io=null)),this.model.removeChangedListener(t)}addChangedListener(t){return U.S(t,Diagram,"addChangedListener:listener"),this.Er===null&&(this.Er=new List),this.Er.add(t),this}removeChangedListener(t){U.S(t,Diagram,"removeChangedListener:listener"),this.Er!==null&&(this.Er.delete(t),this.Er.count===0&&(this.Er=null))}A2(t){if(!this.skipsUndoManager&&!this.model.skipsUndoManager&&this.model.undoManager.handleChanged(t),t.change!==1&&(this.isModified=!0),this.Er!==null){const e=this.Er,i=e.length;for(let s=0;s<i;s++)e.elt(s)(t)}}raiseChangedEvent(t,e,i,s,n,o,r){o===void 0&&(o=null),r===void 0&&(r=null);const l=new ChangedEvent;l.diagram=this,l.change=t,l.propertyName=e,l.object=i,l.oldValue=s,l.oldParam=o,l.newValue=n,l.newParam=r,this.A2(l)}raiseChanged(t,e,i,s,n){this.raiseChangedEvent(2,t,this,e,i,s,n)}t(t,e,i,s,n){this.raiseChangedEvent(2,t,this,e,i,s,n)}get partAdded(){return this.bp}set partAdded(t){this.partAdded!==t&&(this.bp=t)}get partRemoved(){return this.kp}set partRemoved(t){this.partRemoved!==t&&(this.kp=t)}get animationManager(){return this.Ns}get undoManager(){return this.Ce.undoManager}get skipsUndoManager(){return this.Bo}set skipsUndoManager(t){U.s(t,"boolean",Diagram,"skipsUndoManager"),this.Bo=t,this.Ce.skipsUndoManager=t}get delaysLayout(){return this.Lb}set delaysLayout(t){this.Lb=t}tA(t,e){if(t===null||t.diagram!==this)return;const i=this.yi;try{this.yi=!0;const s=t.change;if(s===2){const n=t.object,o=t.propertyName,r=t.getValue(e);if(t.diagram.model.et(n,o,r),n instanceof GraphObject){const l=n.part;l!==null&&l.invalidateAdornments()}this.isModified=!0}else if(s===3){const n=t.object,o=t.newParam,r=t.newValue;if(n instanceof Panel)if(typeof o=="number"&&r instanceof GraphObject){e?n.ri(o):n.insertAt(o,r);const l=n.part;l!==null&&l.invalidateAdornments()}else typeof o=="number"&&r instanceof RowColumnDefinition&&(r.isRow?n.xT(o,e?void 0:r):n.bT(o,e?void 0:r));else if(n instanceof Layer){const l=t.oldParam===!0;typeof o=="number"&&r instanceof Part&&(e?(l||(r.isSelected=!1,r.isHighlighted=!1,r.invalidateAdornments()),n.ri(l?o:-1,r,l)):n.ah(o,r,l))}else n instanceof Diagram?typeof o=="number"&&r instanceof Layer&&(e?this.wT(o):this.Qr(r,o)):U.o("unknown ChangeType.Insert object: "+t.toString());this.isModified=!0}else if(s===4){const n=t.object,o=t.oldParam,r=t.oldValue;if(n instanceof Panel)typeof o=="number"&&r instanceof GraphObject?e?n.insertAt(o,r):n.ri(o):typeof o=="number"&&r instanceof RowColumnDefinition&&(r.isRow?n.xT(o,e?r:void 0):n.bT(o,e?r:void 0));else if(n instanceof Layer){const l=t.newParam===!0;typeof o=="number"&&r instanceof Part&&(e?n.Ct.indexOf(r)<0&&n.ah(o,r,l):(l||(r.isSelected=!1,r.isHighlighted=!1,r.invalidateAdornments()),n.ri(l?o:-1,r,l)))}else n instanceof Diagram?typeof o=="number"&&r instanceof Layer&&(e?this.Qr(r,o):this.wT(o)):U.o("unknown ChangeType.Remove object: "+t.toString());this.isModified=!0}else s===1||U.o("unknown ChangedEvent: "+t.toString())}finally{this.yi=i}}startTransaction(t){return this.undoManager.startTransaction(t)}commitTransaction(t){return this.undoManager.commitTransaction(t)}rollbackTransaction(){return this.undoManager.rollbackTransaction()}commit(t,e){let i=e;i===void 0&&(i="");const s=this.skipsUndoManager;i===null&&(this.skipsUndoManager=!0,i=""),this.undoManager.startTransaction(i);let n=!1;try{t(this),n=!0}finally{n?this.undoManager.commitTransaction(i):this.undoManager.rollbackTransaction(),this.skipsUndoManager=s}}updateAllTargetBindings(t){this.partManager.updateAllTargetBindings(t)}updateAllThemeBindings(){if(this.partManager.updateAllThemeBindings(),this.ls!==null){const t=this.ls.part;t!==null&&t.Yo()}}setDivBackground(t){this.div&&(this.div.style.backgroundColor=t)}updateAllRelationshipsFromData(){this.partManager.updateAllRelationshipsFromData()}Mp(){const t=this.v,e=this.it,i=this.ct;t.Ue(),e!==1&&t.it(e),(i.x!==0||i.y!==0)&&t.Gs(-i.x,-i.y)}kT(t,e){const i=this.animationManager;if(this.Ht||this.Ts){this.it=e,this.aa(),this.C(),this.Sh(),i.EA(t,this.it),this.Mp();return}if(this.st===null){this.it=e,this.Mp();return}this.Ht=!0;const n=this.viewportBounds.copy(),o=this.wt,r=this.xt;let l=this.zoomPoint.x,a=this.zoomPoint.y;const h=this.contentAlignment;isNaN(l)&&(h.isSide()?h.includesSide(Spot.LeftSide)?l=0:h.includesSide(Spot.RightSide)&&(l=o-1):h.isSpot()?l=h.x*(o-1):l=o/2),isNaN(a)&&(h.isSide()?h.includesSide(Spot.TopSide)?a=0:h.includesSide(Spot.BottomSide)&&(a=r-1):h.isSpot()?a=h.y*(r-1):a=r/2),this.scaleComputation!==null&&!this.animationManager.defaultAnimation.isAnimating&&(e=this.scaleComputation(this,e)),e<this.minScale&&(e=this.minScale),e>this.maxScale&&(e=this.maxScale);const c=Point.z(this.ct.x+l/t-l/e,this.ct.y+a/t-a/e);this.position=c,Point.i(c),this.it=e,this.Mp(),this.aa(),this.Ht=!1,this.onViewportBoundsChanged(n,this.viewportBounds,t,!1),this.$s(!1),i.EA(t,this.it),this.C()}pO(){const t=this.zt.r;for(let e=0;e<t.length;e++)t[e].YA()}onViewportBoundsChanged(t,e,i,s){if(t.equals(e))return;s===void 0&&(s=!1),s||this.Sh(),this.ha();const n=this.layout;n!==null&&n.isViewportSized&&this.autoScale===1&&(t.width!==e.width||t.height!==e.height)&&n.p();const o=this.currentTool;this.ef===!0&&o instanceof ToolManager&&!this.animationManager.isTicking&&(this.lastInput.documentPoint=this.transformViewToDoc(this.lastInput.viewPoint),o.cA(this)),this.Ht||this.invalidateViewport(t,e),this.ca(),this.Ye.scale=i,this.Ye.position.x=t.x,this.Ye.position.y=t.y,this.Ye.bounds.h(t),this.Ye.canvasSize.width=Math.round(t.width*i),this.Ye.canvasSize.height=Math.round(t.height*i),this.Ye.newCanvasSize.width=this.wt,this.Ye.newCanvasSize.height=this.xt,this.Ye.isScroll=s,this.T("ViewportBoundsChanged",this.Ye,t),this.isVirtualized&&this.links.each(r=>{r.isAvoiding&&r.actualBounds.intersectsRect(e)&&r.$t()})}ca(t){const e=this.ls;if(e===null||!e.visible||e.part===null||e.layer===null)return;const i=t!==void 0?t:this.Gb;if(!i.isReal())return;const s=i.width,n=i.height;if(e.scale=1,e.angle=0,e.layer.isViewportAligned)e.width=s*this.scale,e.height=n*this.scale,e.part.alignment=Spot.TopLeft;else{e.Pe===null&&(e.Pe=new GridPanelSettings);const o=e.Pe.lf;if(!o.isReal())return;e.width=s+o.width*2,e.height=n+o.height*2;const r=Point.l();G._g(i.x,i.y,0,0,o.width,o.height,r),r.offset(-o.width,-o.height),e.part.location=r,Point.i(r)}}clearSelection(t){t===void 0&&(t=!1);const e=this.selection;if(e.count===0)return;t||this.T("ChangingSelection",e);const i=e.toArray(),s=i.length;for(let n=0;n<s;n++){const o=i[n];o.isSelected=!1}e.ce(),e.clear(),e.b(),t||this.T("ChangedSelection",e)}select(t){t!==null&&t.diagram===this&&(!t.isSelected||this.selection.count>1)&&(this.T("ChangingSelection",this.selection),this.clearSelection(!0),t.isSelected=!0,this.T("ChangedSelection",this.selection))}selectCollection(t){if(this.T("ChangingSelection",this.selection),this.clearSelection(!0),Array.isArray(t)){const e=t.length;for(let i=0;i<e;i++){const s=t[i];s instanceof Part||U.o("Diagram.selectCollection given something that is not a Part: "+s),s.isSelected=!0}}else{const e=t.iterator;for(;e.next();){const i=e.value;i instanceof Part||U.o("Diagram.selectCollection given something that is not a Part: "+i),i.isSelected=!0}}this.T("ChangedSelection",this.selection)}clearHighlighteds(){const t=this.highlighteds;if(t.count>0){const e=t.toArray(),i=e.length;for(let s=0;s<i;s++){const n=e[s];n.isHighlighted=!1}t.ce(),t.clear(),t.b()}}highlight(t){t!==null&&t.diagram===this&&(!t.isHighlighted||this.highlighteds.count>1)&&(this.clearHighlighteds(),t.isHighlighted=!0)}highlightCollection(t){const e=new GSet().addAll(t),s=this.highlighteds.copy().removeAll(e).iterator;for(;s.next();){const o=s.value;o.isHighlighted=!1}const n=e.iterator;for(;n.next();){const o=n.value;o instanceof Part||U.o("Diagram.highlightCollection given something that is not a Part: "+o),o.isHighlighted=!0}}scroll(t,e,i){i===void 0&&(i=1);const s=e==="up"||e==="down";let n=0;const o=Point.l();if(t==="pixel")n=i;else if(t==="line")n=i*(s?this.scrollVerticalLineChange:this.scrollHorizontalLineChange);else if(t==="page"){let l=s?this.viewportBounds.height:this.viewportBounds.width;if(l*=this.scale,l!==0){const a=Math.max(l-(s?this.scrollVerticalLineChange:this.scrollHorizontalLineChange),0);n=i*a}}else if(t==="document"){const l=this.documentBounds,a=this.viewportBounds;e==="up"?this.position=o.e(a.x,l.y):e==="left"?this.position=o.e(l.x,a.y):e==="down"?this.position=o.e(a.x,l.bottom-a.height):e==="right"&&(this.position=o.e(l.right-a.width,a.y)),Point.i(o);return}else U.o("scrolling unit must be 'pixel', 'line', 'page', or 'document', not: "+t);n/=this.scale;const r=this.position;e==="up"?this.position=o.e(r.x,r.y-n):e==="down"?this.position=o.e(r.x,r.y+n):e==="left"?this.position=o.e(r.x-n,r.y):e==="right"?this.position=o.e(r.x+n,r.y):U.o("scrolling direction must be 'up', 'down', 'left', or 'right', not: "+e),Point.i(o)}scrollToRect(t){const e=this.viewportBounds;if(e.containsRect(t))return;const i=t.center;i.x-=e.width/2,i.y-=e.height/2,this.position=i}centerRect(t){const e=this.viewportBounds,i=t.center;i.x-=e.width/2,i.y-=e.height/2,this.position=i}transformDocToView(t){return t.copy().v(this.v)}transformViewToDoc(t){return t.copy().Ki(this.v)}GR(t){return t.Ki(this.v)}static None=1;static Uniform=2;static UniformToFill=3;static CycleAll=1;static CycleNotDirected=2;static CycleNotDirectedFast=3;static CycleNotUndirected=4;static CycleDestinationTree=5;static CycleSourceTree=6;static DocumentScroll=1;static InfiniteScroll=2;static TreeParentCollapsed=1;static AllParentsCollapsed=2;static AnyParentsCollapsed=3;get opacity(){return this.Zt}set opacity(t){const e=this.Zt;e!==t&&(U.s(t,"number",Diagram,"opacity"),(t<0||t>1)&&U.J(t,"0 <= value <= 1",Diagram,"opacity"),this.Zt=t,this.t("opacity",e,t),this.C())}get validCycle(){return this.kb}set validCycle(t){const e=this.kb;e!==t&&(this.kb=t,this.t("validCycle",e,t))}get layers(){return this.zt.iterator}get isModelReadOnly(){const t=this.Ce;return t===null?!1:t.isReadOnly}set isModelReadOnly(t){const e=this.Ce;e!==null&&(e.isReadOnly=t)}get isReadOnly(){return this.zo}set isReadOnly(t){const e=this.zo;e!==t&&(U.s(t,"boolean",Diagram,"isReadOnly"),this.zo=t,this.t("isReadOnly",e,t))}get isEnabled(){return this.Be}set isEnabled(t){const e=this.Be;e!==t&&(U.s(t,"boolean",Diagram,"isEnabled"),this.Be=t,this.t("isEnabled",e,t))}get allowClipboard(){return this.Ab}set allowClipboard(t){const e=this.Ab;e!==t&&(U.s(t,"boolean",Diagram,"allowClipboard"),this.Ab=t,this.t("allowClipboard",e,t))}get allowCopy(){return this.Yl}set allowCopy(t){const e=this.Yl;e!==t&&(U.s(t,"boolean",Diagram,"allowCopy"),this.Yl=t,this.t("allowCopy",e,t))}get allowDelete(){return this.Kl}set allowDelete(t){const e=this.Kl;e!==t&&(U.s(t,"boolean",Diagram,"allowDelete"),this.Kl=t,this.t("allowDelete",e,t))}get allowDragOut(){return this.Tb}set allowDragOut(t){const e=this.Tb;e!==t&&(U.s(t,"boolean",Diagram,"allowDragOut"),this.Tb=t,this.t("allowDragOut",e,t))}get allowDrop(){return this.Db}set allowDrop(t){const e=this.Db;e!==t&&(U.s(t,"boolean",Diagram,"allowDrop"),this.Db=t,this.t("allowDrop",e,t))}get allowTextEdit(){return this.Hl}set allowTextEdit(t){const e=this.Hl;e!==t&&(U.s(t,"boolean",Diagram,"allowTextEdit"),this.Hl=t,this.t("allowTextEdit",e,t))}get allowGroup(){return this.jl}set allowGroup(t){const e=this.jl;e!==t&&(U.s(t,"boolean",Diagram,"allowGroup"),this.jl=t,this.t("allowGroup",e,t))}get allowUngroup(){return this.ql}set allowUngroup(t){const e=this.ql;e!==t&&(U.s(t,"boolean",Diagram,"allowUngroup"),this.ql=t,this.t("allowUngroup",e,t))}get allowInsert(){return this.vb}set allowInsert(t){const e=this.vb;e!==t&&(U.s(t,"boolean",Diagram,"allowInsert"),this.vb=t,this.t("allowInsert",e,t))}get allowLink(){return this.Wl}set allowLink(t){const e=this.Wl;e!==t&&(U.s(t,"boolean",Diagram,"allowLink"),this.Wl=t,this.t("allowLink",e,t))}get allowRelink(){return this.Jl}set allowRelink(t){const e=this.Jl;e!==t&&(U.s(t,"boolean",Diagram,"allowRelink"),this.Jl=t,this.t("allowRelink",e,t))}get allowMove(){return this.$l}set allowMove(t){const e=this.$l;e!==t&&(U.s(t,"boolean",Diagram,"allowMove"),this.$l=t,this.t("allowMove",e,t))}get allowReshape(){return this.Zl}set allowReshape(t){const e=this.Zl;e!==t&&(U.s(t,"boolean",Diagram,"allowReshape"),this.Zl=t,this.t("allowReshape",e,t))}get allowResize(){return this.Ql}set allowResize(t){const e=this.Ql;e!==t&&(U.s(t,"boolean",Diagram,"allowResize"),this.Ql=t,this.t("allowResize",e,t))}get allowRotate(){return this._l}set allowRotate(t){const e=this._l;e!==t&&(U.s(t,"boolean",Diagram,"allowRotate"),this._l=t,this.t("allowRotate",e,t))}get allowSelect(){return this.ta}set allowSelect(t){const e=this.ta;e!==t&&(U.s(t,"boolean",Diagram,"allowSelect"),this.ta=t,this.t("allowSelect",e,t))}get allowUndo(){return this.Fb}set allowUndo(t){const e=this.Fb;e!==t&&(U.s(t,"boolean",Diagram,"allowUndo"),this.Fb=t,this.t("allowUndo",e,t))}get allowZoom(){return this.Rb}set allowZoom(t){const e=this.Rb;e!==t&&(U.s(t,"boolean",Diagram,"allowZoom"),this.Rb=t,this.t("allowZoom",e,t))}get hasVerticalScrollbar(){return this._u}set hasVerticalScrollbar(t){const e=this._u;e!==t&&(U.s(t,"boolean",Diagram,"hasVerticalScrollbar"),this._u=t,this.Sh(),this.C(),this.t("hasVerticalScrollbar",e,t),this.$s(!1))}get hasHorizontalScrollbar(){return this.Qu}set hasHorizontalScrollbar(t){const e=this.Qu;e!==t&&(U.s(t,"boolean",Diagram,"hasHorizontalScrollbar"),this.Qu=t,this.Sh(),this.C(),this.t("hasHorizontalScrollbar",e,t),this.$s(!1))}get allowHorizontalScroll(){return this.Ob}set allowHorizontalScroll(t){const e=this.Ob;e!==t&&(U.s(t,"boolean",Diagram,"allowHorizontalScroll"),this.Ob=t,this.t("allowHorizontalScroll",e,t),this.$s(!1))}get allowVerticalScroll(){return this.Ib}set allowVerticalScroll(t){const e=this.Ib;e!==t&&(U.s(t,"boolean",Diagram,"allowVerticalScroll"),this.Ib=t,this.t("allowVerticalScroll",e,t),this.$s(!1))}get scrollHorizontalLineChange(){return this.Eb}set scrollHorizontalLineChange(t){const e=this.Eb;e!==t&&(U.s(t,"number",Diagram,"scrollHorizontalLineChange"),t<0&&U.J(t,">= 0",Diagram,"scrollHorizontalLineChange"),this.Eb=t,this.t("scrollHorizontalLineChange",e,t))}get scrollVerticalLineChange(){return this.Ub}set scrollVerticalLineChange(t){const e=this.Ub;e!==t&&(U.s(t,"number",Diagram,"scrollVerticalLineChange"),t<0&&U.J(t,">= 0",Diagram,"scrollVerticalLineChange"),this.Ub=t,this.t("scrollVerticalLineChange",e,t))}get lastInput(){return this.uh}set lastInput(t){this.uh=t}get previousInput(){return this.Jr}set previousInput(t){this.Jr=t}get firstInput(){return this.cp}set firstInput(t){this.cp=t}get currentCursor(){return this.Pb}set currentCursor(t){if(t===""&&(t=this.np),this.Pb!==t){U.s(t,"string",Diagram,"currentCursor");const i=this.st,s=this.St;if(i===null||s===null)return;this.Pb=t;const n=i.style.cursor;i.style.cursor=t,s.style.cursor=t,i.style.cursor===n&&(i.style.cursor="-webkit-"+t,s.style.cursor="-webkit-"+t,i.style.cursor===n&&(i.style.cursor="-moz-"+t,s.style.cursor="-moz-"+t,i.style.cursor===n&&(i.style.cursor=t,s.style.cursor=t)))}}get defaultCursor(){return this.np}set defaultCursor(t){t===""&&(t="auto");const e=this.np;e!==t&&(U.s(t,"string",Diagram,"defaultCursor"),this.np=t,this.t("defaultCursor",e,t))}get click(){return this.Ur}set click(t){const e=this.Ur;e!==t&&(t!==null&&U.S(t,Diagram,"click"),this.Ur=t,this.t("click",e,t))}get doubleClick(){return this.Vr}set doubleClick(t){const e=this.Vr;e!==t&&(t!==null&&U.S(t,Diagram,"doubleClick"),this.Vr=t,this.t("doubleClick",e,t))}get contextClick(){return this.Br}set contextClick(t){const e=this.Br;e!==t&&(t!==null&&U.S(t,Diagram,"contextClick"),this.Br=t,this.t("contextClick",e,t))}get mouseOver(){return this.zr}set mouseOver(t){const e=this.zr;e!==t&&(t!==null&&U.S(t,Diagram,"mouseOver"),this.zr=t,this.t("mouseOver",e,t))}get mouseHover(){return this.Xr}set mouseHover(t){const e=this.Xr;e!==t&&(t!==null&&U.S(t,Diagram,"mouseHover"),this.Xr=t,this.t("mouseHover",e,t))}get mouseHold(){return this.Gr}set mouseHold(t){const e=this.Gr;e!==t&&(t!==null&&U.S(t,Diagram,"mouseHold"),this.Gr=t,this.t("mouseHold",e,t))}get mouseDragOver(){return this.Sb}set mouseDragOver(t){const e=this.Sb;e!==t&&(t!==null&&U.S(t,Diagram,"mouseDragOver"),this.Sb=t,this.t("mouseDragOver",e,t))}get mouseDrop(){return this.Yr}set mouseDrop(t){const e=this.Yr;e!==t&&(this.Yr=t,this.t("mouseDrop",e,t))}get handlesDragDropForTopLevelParts(){return this.Mb}set handlesDragDropForTopLevelParts(t){const e=this.Mb;e!==t&&(U.s(t,"boolean",Diagram,"handlesDragDropForTopLevelParts"),this.Mb=t,this.t("handlesDragDropForTopLevelParts",e,t))}get mouseEnter(){return this.Kr}set mouseEnter(t){const e=this.Kr;e!==t&&(t!==null&&U.S(t,Diagram,"mouseEnter"),this.Kr=t,this.t("mouseEnter",e,t))}get mouseLeave(){return this.Hr}set mouseLeave(t){const e=this.Hr;e!==t&&(t!==null&&U.S(t,Diagram,"mouseLeave"),this.Hr=t,this.t("mouseLeave",e,t))}get toolTip(){return this.jr}set toolTip(t){const e=this.jr;e!==t&&(this.jr=t,this.t("toolTip",e,t))}get contextMenu(){return this.qr}set contextMenu(t){const e=this.qr;e!==t&&(this.qr=t,this.t("contextMenu",e,t))}get commandHandler(){return this.HM}set commandHandler(t){const e=this.HM;e!==t&&(e&&e.doStop(),this.HM=t,t.Eo(this),t.doStart())}get toolManager(){return this.GM}set toolManager(t){this.GM!==t&&(this.GM=t,t.diagram=this)}get defaultTool(){return this.YM}set defaultTool(t){const e=this.YM;e!==t&&(this.YM=t,t.diagram=this,this.currentTool===e&&(this.currentTool=t))}get currentTool(){return this.KM}set currentTool(t){const e=this.KM;e&&(e.isActive&&e.doDeactivate(),e.cancelWaitAfter(),e.doStop()),t===null&&(t=this.defaultTool),t!==null&&(this.KM=t,t.diagram=this,t.doStart())}get selection(){return this.KA}get maxSelectionCount(){return this.Xb}set maxSelectionCount(t){const e=this.Xb;if(e!==t)if(U.s(t,"number",Diagram,"maxSelectionCount"),t>=0&&!isNaN(t)){if(this.Xb=t,this.t("maxSelectionCount",e,t),!this.undoManager.isUndoingRedoing){const i=this.selection.count-t;if(i>0){this.T("ChangingSelection",this.selection);const s=this.selection.toArray();for(let n=0;n<i;n++)s[n].isSelected=!1;this.T("ChangedSelection",this.selection)}}}else U.J(t,">= 0",Diagram,"maxSelectionCount")}get nodeSelectionAdornmentTemplate(){return this.ap}set nodeSelectionAdornmentTemplate(t){const e=this.ap;e!==t&&(this.ap=t.It(),this.t("nodeSelectionAdornmentTemplate",e,t))}get groupSelectionAdornmentTemplate(){return this.Kb}set groupSelectionAdornmentTemplate(t){const e=this.Kb;e!==t&&(this.Kb=t.It(),this.t("groupSelectionAdornmentTemplate",e,t))}get linkSelectionAdornmentTemplate(){return this.Hb}set linkSelectionAdornmentTemplate(t){const e=this.Hb;e!==t&&(this.Hb=t.It(),this.t("linkSelectionAdornmentTemplate",e,t))}get highlighteds(){return this.HA}get isModified(){const t=this.undoManager;return t.isEnabled?t.currentTransaction!==null?!0:this.nd&&this.js!==t.historyIndex:this.nd}set isModified(t){if(this.nd!==t){U.s(t,"boolean",Diagram,"isModified"),this.nd=t;const i=this.undoManager;!t&&i.isEnabled&&(this.js=i.historyIndex),t||this.PT()}}PT(){const t=this.isModified;this.JM!==t&&(this.JM=t,this.T("Modified"))}get model(){return this.Ce}set model(t){const e=this.Ce;if(e!==t){this.currentTool.doCancel(),e&&e.undoManager!==t.undoManager&&e.undoManager.isInTransaction&&U.o("Do not replace a Diagram.model while a transaction is in progress.");const i=this.sT(!0);this.no=!1,this.Zu=!0,this.js=-2,this.Dr=!1;const s=this.Ht;this.Ht=!0,this.animationManager.Gl("Model"),e&&(this.io!==null&&this.io.each(n=>e.removeChangedListener(n)),e.removeChangedListener(this.Zc)),this.Ce=t,this.partManager=this.NO(this.Ce.type),this.initializePartManager(this.partManager);for(let n=0;n<i.length;n++)this.add(i[n]);t.addChangedListener(this.WM),this.partManager.T2(),t.removeChangedListener(this.WM),t.addChangedListener(this.Zc),this.io!==null&&this.io.each(n=>t.addChangedListener(n)),this.Ht=s,this.invalidateDocumentBounds(),this.Ht||this.C(),e&&t.undoManager.copyProperties(e.undoManager)}}get themeManager(){return this.u2}set themeManager(t){const e=this.u2;e!==t&&(e&&e.removeDiagram(this),this.u2=t,t!==null&&t.addDiagram(this))}initializePartManager(t){}static d2(t,e){Diagram.JA.set(t,e)}static get licenseKey(){return Diagram.D2.last()}static set licenseKey(t){Diagram.D2.add(t.replace(/\s/g,""))}static get version(){return Diagram.CO}static D2=new List;static CO="3.1.0";NO(t){const e=Diagram.JA.get(t);return e!==null?new e:new PartManager}get G(){return this.qM}set G(t){this.qM=t}get sb(){return this.jA}LO(t){if(t.model!==this.model)return;const e=t.change,i=t.propertyName;if(e===1&&i[0]==="S"){if(i==="StartingFirstTransaction"){const s=this,n=this.toolManager;n.mouseDownTools.each(o=>o.diagram=s),n.mouseMoveTools.each(o=>o.diagram=s),n.mouseUpTools.each(o=>o.diagram=s),this.routers.each(o=>o.diagram=s),!this.Ts&&!this.no&&(this.$c=!0,this.Zu&&(this.Dr=!0))}else if(i==="StartingUndo"||i==="StartingRedo"){const s=this.animationManager;this.skipsUndoManager||(s.defaultAnimation.isAnimating&&s.stopAnimation(),s.getBundleAnimation().isAnimating&&s.getBundleAnimation().stop()),this.T("ChangingSelection",this.selection)}else if(i==="StartedTransaction"){const s=this.animationManager;s.defaultAnimation.isAnimating&&!this.skipsUndoManager&&s.stopAnimation()}return}if(this.G){this.G=!1;try{if(t.modelChange===""&&e===1){(i==="FinishedUndo"||i==="FinishedRedo")&&(this.T("ChangedSelection",this.selection),this.Te());const s=this.animationManager;i==="RolledBackTransaction"&&s.stopAnimation(),this.VA(),this.$c=!0,this.maybeUpdate(),(this.undoManager.transactionLevel===0||this.undoManager.transactionLevel===1)&&s.PM(),i==="CommittedTransaction"&&this.undoManager.isJustDiscarded&&(this.js=Math.min(this.js,this.undoManager.historyIndex-1)),(i==="CommittedTransaction"||i==="RolledBackTransaction")&&this.undoManager.Px&&U.dn(()=>{this.isModified=!1},1);const n=t.isTransactionFinished;if(n&&(this.PT(),this.sb.clear(),this.animationManager.CR()),!this.Nb&&n&&this.lastInput.targetDiagram){this.Nb=!0;const o=this;U.dn(()=>{o.currentTool.standardMouseOver(),o.Nb=!1},10)}}}finally{this.G=!0}}}get yi(){return this.jM}set yi(t){this.jM=t}get Ou(){return this.Cb}set Ou(t){this.Cb=t}uT(t){const e=t.D.r;for(const i of e)i instanceof Picture&&this.v2(i)}v2(t){const e=t.element;if(e===null||!(e instanceof HTMLImageElement)||(e.hs instanceof GSet&&e.hs.add(this),t.AO(),!e.Tp))return;const i=e.getAttribute("src")||"",s=this.oa.get(i);if(s===null){Picture.ST(t,e);const n=[];n.push(t),this.oa.set(i,n)}else{for(let n=0;n<s.length;n++)if(s[n]===t)return;s.push(t)}}TO(t){const e=t.D.r,i=e.length;for(let s=0;s<i;s++)this.F2(e[s])}F2(t){if(!(t instanceof Picture))return;const e=t.element;if(e===null||!(e instanceof HTMLImageElement)||!e.Tp)return;const i=e.getAttribute("src")||"",s=this.oa.get(i);if(s!==null){for(let n=0;n<s.length;n++)if(s[n]===t){s.splice(n,1),s.length===0&&(this.oa.delete(i),Picture.DO(e),e.hs instanceof GSet&&e.hs.delete(this),Picture.clearCache(i));return}}}nT(){Picture.clearCache(),this.oa.clear()}rebuildParts(){this.partManager.rebuildParts()}Yc(t,e){this.Ns.Yc(t,e)}Gc(t,e){this.Ns.Gc(t,e)}findPartForKey(t){return this.partManager.findPartForKey(t)}findNodeForKey(t){return this.partManager.findNodeForKey(t)}findLinkForKey(t){return this.partManager.findLinkForKey(t)}findPartForData(t){return this.partManager.findPartForData(t)}findNodeForData(t){return this.partManager.findNodeForData(t)}findLinkForData(t){return this.partManager.findLinkForData(t)}findNodesByExample(...t){return this.partManager.findNodesByExample(...t)}findLinksByExample(...t){return this.partManager.findLinksByExample(...t)}get nodeTemplate(){return this.Wr.get("")}set nodeTemplate(t){const e=this.Wr.get("");e!==t&&(this.Wr.set("",t),this.t("nodeTemplate",e,t),this.undoManager.isUndoingRedoing||this.rebuildParts())}get nodeTemplateMap(){return this.Wr}set nodeTemplateMap(t){const e=this.Wr;e!==t&&(this.Wr=t,this.t("nodeTemplateMap",e,t),this.undoManager.isUndoingRedoing||this.rebuildParts())}get groupTemplate(){return this.fh.get("")}set groupTemplate(t){const e=this.fh.get("");e!==t&&(this.fh.set("",t),this.t("groupTemplate",e,t),this.undoManager.isUndoingRedoing||this.rebuildParts())}get groupTemplateMap(){return this.fh}set groupTemplateMap(t){const e=this.fh;e!==t&&(this.fh=t,this.t("groupTemplateMap",e,t),this.undoManager.isUndoingRedoing||this.rebuildParts())}get linkTemplate(){return this.na.get("")}set linkTemplate(t){const e=this.na.get("");e!==t&&(this.na.set("",t),this.t("linkTemplate",e,t),this.undoManager.isUndoingRedoing||this.rebuildParts())}get linkTemplateMap(){return this.na}set linkTemplateMap(t){const e=this.na;e!==t&&(this.na=t,this.t("linkTemplateMap",e,t),this.undoManager.isUndoingRedoing||this.rebuildParts())}get isMouseCaptured(){return this.$M}set isMouseCaptured(t){const e=this.st;if(e===null)return;const i=e.bt;i instanceof SVGElement||(t?(this.lastInput.bubbles=!1,this.Le(i,"pointermove",this.yh,!1),this.Le(i,"pointerdown",this.la,!1),this.Le(i,"pointerup",this.wh,!1),this.Le(i,"pointerout",this.xh,!1),this.Le(i,"pointercancel",this.bh,!1),this.Et(root,"pointermove",this.yh,!0),this.Et(root,"pointerdown",this.la,!0),this.Et(root,"pointerup",this.wh,!0),this.Et(root,"pointerout",this.xh,!0),this.Et(root,"pointercancel",this.bh,!0),this.Le(i,"wheel",this.ph,!1),this.Et(root,"wheel",this.ph,!0),this.Et(root,"selectstart",this.ih,!1)):(this.Le(root,"pointermove",this.yh,!0),this.Le(root,"pointerdown",this.la,!0),this.Le(root,"pointerup",this.wh,!0),this.Le(root,"pointerout",this.xh,!0),this.Le(root,"pointercancel",this.bh,!0),this.Et(i,"pointermove",this.yh,!1),this.Et(i,"pointerdown",this.la,!1),this.Et(i,"pointerup",this.wh,!1),this.Et(i,"pointerout",this.xh,!1),this.Et(i,"pointercancel",this.bh,!1),this.Le(root,"wheel",this.ph,!0),this.Le(root,"selectstart",this.ih,!1),this.Et(i,"wheel",this.ph,!1)),this.$M=t)}get position(){return this.ct}set position(t){if(this.ct.equals(t))return;const e=Point.l().h(this.ct),i=this.viewportBounds.copy();if(this.ct.h(t),this.animationManager.IA(e,this.ct),!this.Ht&&!(this.st===null&&!this.ed.isReal())){this.Ht=!0;const s=this.scale,n=this.wt/s,o=this.xt/s;this.w2(this.lp,n,o,this.Wc,!1),this.Ht=!1}else this.aa(),this.Mp();if(!this.Ht){const s=this.viewportBounds;this.onViewportBoundsChanged(i,s,this.it,!1)}Point.i(e)}get initialPosition(){return this.lb}set initialPosition(t){this.lb.equals(t)||(this.lb=t.N())}get initialScale(){return this.ab}set initialScale(t){this.ab!==t&&(U.s(t,"number",Diagram,"initialScale"),this.ab=t)}get grid(){return this.ls===null&&(this.ls=this.rT()),this.ls}set grid(t){let e=this.ls;if(e!==t){e===null&&(this.ls=this.rT(),e=this.ls),t.type!==Panel.Grid&&U.o("Diagram.grid must be a Panel of type Panel.Grid");const i=e.panel;i!==null&&i.remove(e),this.ls=t,t.name="GRID",i!==null&&i.add(t),this.sd=!1,this.C(),this.t("grid",e,t)}}get viewportBounds(){return this.Gb}aa(){const t=this.Gb,e=this.ct,i=this.it;t.e(e.x,e.y,Math.max(this.wt,0)/i,Math.max(this.xt,0)/i),this.ha()}get viewSize(){return this.ed}set viewSize(t){const e=this.viewSize;if(!e.equals(t)){t=t.N(),this.ed=t;let i=0,s=0;t.isReal()?(i=t.width,s=t.height):this.St!==null&&(i=this.St.clientWidth||1,s=this.St.clientHeight||1),this.wt=i,this.xt=s,this.aa(),this.invalidateDocumentBounds(),this.t("viewSize",e,t),this.C()}}get fixedBounds(){return this.ub}set fixedBounds(t){const e=this.ub;e.equals(t)||((t.width===-1/0||t.height===1/0||t.height===-1/0)&&U.o("fixedBounds width/height must not be Infinity"),t=t.N(),this.ub=t,this.invalidateDocumentBounds(),this.t("fixedBounds",e,t))}get scrollMargin(){return this.hh}set scrollMargin(t){typeof t=="number"&&(t=new Margin(t));const e=this.hh;e.equals(t)||(t=t.N(),this.hh=t,this.t("scrollMargin",e,t),this.Eu())}get scrollMode(){return this.oh}set scrollMode(t){const e=this.oh;e!==t&&(this.oh=t,t===1&&this.$s(!1),this.t("scrollMode",e,t),this.Sh(),this.C())}get scrollsPageOnFocus(){return this.db}set scrollsPageOnFocus(t){const e=this.db;e!==t&&(U.s(t,"boolean",Diagram,"scrollsPageOnFocus"),this.db=t,this.t("scrollsPageOnFocus",e,t))}get positionComputation(){return this.gb}set positionComputation(t){const e=this.gb;e!==t&&(t!==null&&U.S(t,Diagram,"positionComputation"),this.gb=t,this.$s(!1),this.t("positionComputation",e,t))}get scaleComputation(){return this.pb}set scaleComputation(t){const e=this.pb;e!==t&&(t!==null&&U.S(t,Diagram,"scaleComputation"),this.pb=t,this.kT(this.scale,this.scale),this.t("scaleComputation",e,t))}get documentBounds(){return this.lp}MT(t){this.dh=!1;let e=this.lp;e.equals(t)||(e=e.copy(),this.lp.h(t),this.$s(!1),this.T("DocumentBoundsChanged",void 0,e),this.Sh(),this.C())}ensureBounds(){if(this.dh){const t=Rect.l();this.MT(this.computeBounds(t)),Rect.i(t)}}get isVirtualized(){return this.Yb}set isVirtualized(t){const e=this.Yb;e!==t&&(U.s(t,"boolean",Diagram,"isVirtualized"),this.Yb=t,this.t("isVirtualized",e,t))}get scale(){return this.it}set scale(t){const e=this.it;e!==t&&this.kT(e,t)}get defaultScale(){return this.fp}set defaultScale(t){this.fp=t}get autoScale(){return this.ia}set autoScale(t){const e=this.ia;e!==t&&(this.ia=t,this.t("autoScale",e,t),t!==1&&this.$s(!1))}get initialAutoScale(){return this.Or}set initialAutoScale(t){const e=this.Or;e!==t&&(this.Or=t,this.t("initialAutoScale",e,t))}get initialViewportSpot(){return this.wb}set initialViewportSpot(t){const e=this.wb;e!==t&&(t.isSpot()||U.o("initialViewportSpot must be a specific Spot: "+t),this.wb=t,this.t("initialViewportSpot",e,t))}get initialDocumentSpot(){return this.yb}set initialDocumentSpot(t){const e=this.yb;e!==t&&(t.isSpot()||U.o("initialViewportSpot must be a specific Spot: "+t),this.yb=t,this.t("initialDocumentSpot",e,t))}get minScale(){return this.hb}set minScale(t){const e=this.hb;e!==t&&(t>0?(this.hb=t,this.t("minScale",e,t),t>this.scale&&(this.scale=t)):U.J(t,"> 0",Diagram,"minScale"))}get maxScale(){return this.cb}set maxScale(t){const e=this.cb;e!==t&&(t>0?(this.cb=t,this.t("maxScale",e,t),t<this.scale&&(this.scale=t)):U.J(t,"> 0",Diagram,"maxScale"))}get zoomPoint(){return this.fb}set zoomPoint(t){this.fb.equals(t)||(t=t.N(),this.fb=t)}get contentAlignment(){return this.Wc}set contentAlignment(t){const e=this.Wc;e.equals(t)||(t=t.N(),this.Wc=t,this.t("contentAlignment",e,t),this.$s(!1))}get initialContentAlignment(){return this.ep}set initialContentAlignment(t){const e=this.ep;e.equals(t)||(t=t.N(),this.ep=t,this.t("initialContentAlignment",e,t))}get padding(){return this.Qt}set padding(t){typeof t=="number"&&(t=new Margin(t));const e=this.Qt;e.equals(t)||(t=t.N(),this.Qt=t,this.invalidateDocumentBounds(),this.t("padding",e,t))}get partManager(){return this.e2}set partManager(t){const e=this.e2;e!==t&&(t.diagram!==null&&U.o("Cannot share PartManagers between Diagrams: "+t.toString()),e&&e.Eo(null),this.e2=t,t.Eo(this))}get nodes(){return this.partManager.nodes.iterator}get links(){return this.partManager.links.iterator}get parts(){return this.partManager.parts.iterator}findTopLevelNodesAndLinks(){const t=new GSet,e=this.nodes;for(;e.next();){const s=e.value;s.isTopLevel&&t.add(s)}const i=this.links;for(;i.next();){const s=i.value;s.isTopLevel&&t.add(s)}return t.iterator}findTopLevelGroups(){return this.Zr.iterator}get routers(){return this.nf}doLinkRouting(t){this.Vo=!0;const e=this.nf.r;for(let i=0;i<e.length;i++)e[i].canRoute(t)&&e[i].routeLinks(this.Ir,t);this.Vo=!1}get layout(){return this.li}set layout(t){const e=this.li;e!==t&&(this.li=t,t.diagram=this,t.group=null,this.$r=!0,this.t("layout",e,t),this.requestUpdate())}layoutDiagram(t){this.Te(),t&&this.h1(!0),this.Ts?this.P2(!1,this.Fl||this.nf.count!==0&&this.eo.size!==0):(this.$c=!0,this.Sr())}h1(t){const e=this.Zr.iterator;for(;e.next();)this.NT(e.value,t);this.layout&&(t?this.layout.isValidLayout=!1:this.layout.p())}NT(t,e){if(t===null)return;const i=t.Mh.iterator;for(;i.next();){const s=i.value;this.NT(s,e)}t.layout!==null&&(e?t.layout.isValidLayout=!1:t.layout.p())}P2(t,e){if(this.Lb)return;const i=this.G;this.G=!0;const s="Layout",n=this.undoManager.transactionLevel,o=this.layout,r=this.animationManager;try{n===0&&(this.undoManager.Dl=!0,this.startTransaction(s)),n<=1&&!r.defaultAnimation.isAnimating&&!r.ke&&(t||r.Gl(s)),this.$r=!1;let l=this.Zr.iterator;for(;l.next();)this.cd(l.value),this.CT(l.value,t,n,e);let a=!1;if(o.isValidLayout||(!t||o.isRealtime||o.isRealtime===null||n===0?(o.doLayout(this),this.cd(this),a=!0,o.isValidLayout=!0):this.$r=!0),a||this.cd(this),this.doLinkRouting(this),this.Ir.clear(),this.ch.size!==0){for(let h=0;h<23&&this.ch.size!==0;h++){for(l=this.Zr.iterator;l.next();)this.LT(l.value);const c=this.Ir;this.Ir=this.ch,this.ch=c,this.cd(this),this.doLinkRouting(this)}this.Ir.clear(),this.ch.clear()}}finally{const l=this.undoManager.Dl;n===0&&(this.commitTransaction(s),this.undoManager.Dl=!1),l&&(n===0||n===1)&&r.PM(),this.$r&&(this.$r=!o.isValidLayout),this.G=i}}CT(t,e,i,s){const n=t.Mh.iterator;for(;n.next();)this.CT(n.value,e,i,s);const o=t.layout;o!==null&&!o.isValidLayout?!e||o.isRealtime||i===0?(t.Nh=!t.location.isReal(),o.doLayout(t),t.invalidateLayout(32),this.s1(t),this.cd(t),this.doLinkRouting(t),o.isValidLayout=!0):(this.doLinkRouting(t),this.$r=!0):s&&this.doLinkRouting(t)}LT(t){const e=t.Mh.iterator;for(;e.next();)this.LT(e.value);this.cd(t),this.doLinkRouting(t)}get isTreePathToChildren(){return this.xb}set isTreePathToChildren(t){const e=this.xb;if(e!==t&&(U.s(t,"boolean",Diagram,"isTreePathToChildren"),this.xb=t,this.t("isTreePathToChildren",e,t),!this.undoManager.isUndoingRedoing)){const i=this.nodes;for(;i.next();)i.value.Dp()}}findTreeRoots(){const t=new List,e=this.nodes;for(;e.next();){const i=e.value;i.isTopLevel&&i.findTreeParentLink()===null&&t.add(i)}return t.iterator}get treeCollapsePolicy(){return this.bb}set treeCollapsePolicy(t){const e=this.bb;e!==t&&(t!==1&&t!==2&&t!==3&&U.o("Unknown Diagram.treeCollapsePolicy: "+t),this.bb=t,this.t("treeCollapsePolicy",e,t))}get isCollapsingExpanding(){return this.XM}set isCollapsingExpanding(t){this.XM=t}QR(){const t=new GMap,e=new GMap;function i(s){const n=s.toLowerCase(),o=new List;t.set(s,o),t.set(n,o),e.set(s,s),e.set(n,s)}i("InitialAnimationStarting"),i("AnimationStarting"),i("AnimationFinished"),i("BackgroundSingleClicked"),i("BackgroundDoubleClicked"),i("BackgroundContextClicked"),i("ClipboardChanged"),i("ClipboardPasted"),i("DocumentBoundsChanged"),i("ExternalObjectsDropped"),i("FocusOrVirtualPointerEnabledChanged"),i("GainedFocus"),i("InitialLayoutCompleted"),i("LayoutCompleted"),i("LinkDrawn"),i("LinkRelinked"),i("LinkReshaped"),i("LostFocus"),i("Modified"),i("ObjectSingleClicked"),i("ObjectDoubleClicked"),i("ObjectContextClicked"),i("PartCreated"),i("PartResized"),i("PartRotated"),i("SelectionMoved"),i("SelectionCopied"),i("SelectionDeleting"),i("SelectionDeleted"),i("SelectionGrouped"),i("SelectionUngrouped"),i("ChangingSelection"),i("ChangedSelection"),i("SubGraphCollapsed"),i("SubGraphExpanded"),i("TextEdited"),i("ThemeChanged"),i("TreeCollapsed"),i("TreeExpanded"),i("ViewportBoundsChanged"),i("InvalidateDraw"),this.BM=t,this.zM=e}fT(t){const e=this.zM.get(t);return e!==null?e:this.zM.get(t.toLowerCase())}R2(t){let e=this.BM.get(t);if(e!==null)return e;const i=t.toLowerCase();if(e=this.BM.get(i),e!==null)return e;U.o("Unknown DiagramEvent name: "+t)}addDiagramListener(t,e){U.s(t,"string",Diagram,"addDiagramListener:name"),U.S(e,Diagram,"addDiagramListener:listener");const i=this.R2(t);return i!==null&&i.add(e),this}removeDiagramListener(t,e){U.s(t,"string",Diagram,"removeDiagramListener:name"),U.S(e,Diagram,"addDiagramListener:listener");const i=this.R2(t);i!==null&&i.delete(e)}raiseDiagramEvent(t,e,i){this.T(t,e,i)}T(t,e,i){const s=this.R2(t),n=new DiagramEvent;n.diagram=this;const o=this.fT(t);o!==null&&(n.name=o),e!==void 0&&(n.subject=e),i!==void 0&&(n.parameter=i);const r=s.length;if(r===1)s.elt(0)(n);else if(r!==0){const l=s.toArray();for(let a=0;a<r;a++){const h=l[a];h(n)}}}isUnoccupied(t,e){return this.getPositions(!1,null,e||null).isUnoccupied(t.x,t.y,t.width,t.height)}computeOccupiedArea(t){return this.isVirtualized?this.viewportBounds.copy():this.dh?this.aT(t):t.h(this.documentBounds)}getPositions(t,e,i){let s=this.sa;s===null&&(this.sa=s=new PositionArray(this.avoidanceCellSize));let n=e;if(s.Ko||s.Ch!==n||s.O2!==i){if(s.I2=Math.max(s.af+1,Math.floor(this.avoidanceLimit/this.avoidanceCellSize.width)),s.E2=Math.max(s.af+1,Math.floor(this.avoidanceLimit/this.avoidanceCellSize.height)),n!==null&&(n=this.AT(n)),n===null){const o=Rect.l();this.computeOccupiedArea(o),o.inflate(100,100),s.c1(o);const r=this.nodes;for(;r.next();){const l=r.value,a=l.layer;a===null||!a.visible||a.isTemporary||this.U2(l,i,o)}Rect.i(o)}else{if(n.memberParts.count>0){const l=this.computePartsBounds(n.memberParts,!1);l.inflate(20,20),s.c1(l)}const o=Rect.l(),r=n.memberParts;for(;r.next();){const l=r.value;l instanceof Node&&this.U2(l,i,o)}Rect.i(o)}s.Ch=n,s.O2=i,s.Ko=!1}else t&&s.TT();return s}get avoidanceCellSize(){return this.ZM}set avoidanceCellSize(t){this.sa=null,this.ZM=new Size(Math.max(1,t.width),Math.max(1,t.height))}get avoidanceLimit(){return this.QM}set avoidanceLimit(t){this.QM=Math.max(1,t)}AT(t){return t.canAvoid()?t:t.containingGroup!==null?this.AT(t.containingGroup):null}U2(t,e,i){if(t===e||!t.isVisible())return;const s=t.canAvoid();if(s){const n=t.getAvoidableRect(i);this.sa.vO(n.x,n.y,n.width,n.height)}if(t instanceof Group&&(!s||t.avoidableMembers)){const n=t.memberParts;for(;n.next();){const o=n.value;o instanceof Node&&this.U2(o,e,i)}}}V2(t){this.sa!==null&&!this.sa.Ko&&(t===void 0||t.canAvoid())&&(this.sa.Ko=!0)}get autoScrollInterval(){return this.ip}set autoScrollInterval(t){const e=this.ip;e!==t&&(this.ip=t,this.t("autoScrollInterval",e,t))}get autoScrollRegion(){return this.sp}set autoScrollRegion(t){typeof t=="number"&&(t=new Margin(t));const e=this.sp;e.equals(t)||(t=t.N(),this.sp=t,this.invalidateDocumentBounds(),this.t("autoScrollRegion",e,t))}doAutoScroll(t){this.hp.h(t);const e=Point.l();this.computeAutoScrollPosition(this.hp,e).equalsApprox(this.position)?this.stopAutoScroll():this.DT(),Point.i(e)}DT(){if(this.Jc!==-1)return;const t=this.ip,e=this;this.Jc=U.dn(()=>{if(e.Jc===-1||(e.stopAutoScroll(),e.lastInput.event===null))return;const s=Point.l(),n=e.computeAutoScrollPosition(e.hp,s);if(!n.equalsApprox(e.position)){e.position=n,e.lastInput.documentPoint=e.transformViewToDoc(e.hp),e.doMouseMove(),e.dh=!0;const o=Rect.l();e.computeBounds(o),o.unionRect(e.documentBounds),e.MT(o),Rect.i(o),e.qi=!0,e.maybeUpdate(),e.DT()}Point.i(s)},t)}stopAutoScroll(){this.Jc!==-1&&(U.yc(this.Jc),this.Jc=-1)}computeAutoScrollPosition(t,e){let i=this.position;e===void 0&&(e=new Point),e.h(i);const s=this.sp;if(s.top<=0&&s.left<=0&&s.right<=0&&s.bottom<=0)return e;const n=this.viewportBounds,o=this.scale,r=Rect.z(0,0,n.width*o,n.height*o),l=Point.z(0,0);if(t.x>=r.x&&t.x<r.x+s.left&&this.allowHorizontalScroll){let a=Math.max(this.scrollHorizontalLineChange,1);a=a|0,l.x-=a,t.x<r.x+s.left/2&&(l.x-=a),t.x<r.x+s.left/4&&(l.x-=4*a)}else if(t.x<=r.x+r.width&&t.x>r.x+r.width-s.right&&this.allowHorizontalScroll){let a=Math.max(this.scrollHorizontalLineChange,1);a=a|0,l.x+=a,t.x>r.x+r.width-s.right/2&&(l.x+=a),t.x>r.x+r.width-s.right/4&&(l.x+=4*a)}if(t.y>=r.y&&t.y<r.y+s.top&&this.allowVerticalScroll){let a=Math.max(this.scrollVerticalLineChange,1);a=a|0,l.y-=a,t.y<r.y+s.top/2&&(l.y-=a),t.y<r.y+s.top/4&&(l.y-=4*a)}else if(t.y<=r.y+r.height&&t.y>r.y+r.height-s.bottom&&this.allowVerticalScroll){let a=Math.max(this.scrollVerticalLineChange,1);a=a|0,l.y+=a,t.y>r.y+r.height-s.bottom/2&&(l.y+=a),t.y>r.y+r.height-s.bottom/4&&(l.y+=4*a)}return l.equalsApprox(Point.gn)||(e.x=i.x+l.x/o,e.y=i.y+l.y/o),Rect.i(r),Point.i(l),e}makeSvg(t){this.Xo.has("SVG")||this.addRenderer("SVG",new SVGSurface(this,root.document));const e=new SVGSurface(this,root.document,!0);t===void 0&&(t={});const i=this;function s(n,o){const r=i.vT(n,"SVG",e),l=r!==null?r.svg:null,a=n.svgFinished;return l&&a&&a(l),U.nt(o)?(o(l),null):l}return this.FT(s,t)}makeSVG(t){return this.makeSvg(t)}addRenderer(t,e){this.Xo.set(t,e)}removeRenderer(t){this.Xo.delete(t)}cacheGroupExternalLinks(t){this.f2=t,t||this.nodes.each(e=>{e instanceof Group&&(e.vp=null)})}FT(t,e){const i=e.callback;let s=!0;const o=this.oa.iterator;for(;o.next();)if(!o.value[0].Mn){s=!1;break}if(!U.nt(i)||s)return t(e,i,this);const r=this;function l(){const c=+new Date;for(s=!0,o.reset();o.next();)if(!o.value[0].Mn){s=!1;break}if(s||c-h>a){t(e,i,r);return}root.requestAnimationFrame(l)}const a=e.callbackTimeout||300,h=+new Date;return root.requestAnimationFrame(()=>l()),null}makeImage(t){return Diagram.isUsingDOM()?(t===void 0&&(t={}),t.returnType="Image",this.makeImageData(t)):null}makeImageData(t){return t===void 0&&(t={}),this.FT(this.FO,t)}static img="image";FO(t,e,i){const s=i.vT(t,"canvas",null);if(s===null)return null;const n=s.F.canvas;let o=null;if(n!==null){let r=t.returnType;switch(r===void 0?r="string":r=r.toLowerCase(),r){case Diagram.img+"data":o=s.getImageData(0,0,n.width,n.height);break;case Diagram.img:const a=(t.document||document).createElement("img");a.src=n.toDataURL(t.type,t.details),o=a;break;case"blob":{const h=n;return U.nt(e)||(o="",U.o('Error: Diagram.makeImageData called with "returnType: toBlob", but no required "callback" function property defined.')),U.nt(h.toBlob)?(h.toBlob(e,t.type,t.details),"toBlob"):(e(null),null)}case"string":default:o=n.toDataURL(t.type,t.details)}}return U.nt(e)?(e(o),null):o}static RO=!1;vT(t,e,i){if(this.animationManager.stopAnimation(),this.maybeUpdate(),this.st===null)return null;U.$(t)||U.o("properties argument must be an Object.");let n=!1,o=t.size||null,r=t.scale||null;t.scale!==void 0&&isNaN(t.scale)&&(r="NaN");let l=t.maxSize;t.maxSize===void 0&&(n=!0,e==="SVG"?l=new Size(1/0,1/0):l=new Size(2e3,2e3));const a=t.position||null;let h=t.parts||null;Array.isArray(h)&&(h=new List(h));let c=t.padding===void 0?1:t.padding;const f=t.background||null;let u=t.omitTemporary;u===void 0&&(u=!0);const d=t.document||document,m=t.elementFinished||null;let g=t.showTemporary;g===void 0&&(g=!u);let p=t.showGrid;p===void 0&&(p=g),o!==null&&isNaN(o.width)&&isNaN(o.height)&&(o=null),typeof c=="number"?c=new Margin(c):c instanceof Margin||U.o("MakeImage padding must be a Margin or a number."),c.left=Math.max(c.left,0),c.right=Math.max(c.right,0),c.top=Math.max(c.top,0),c.bottom=Math.max(c.bottom,0),this.Wt.clearContextCache(!0);const y=new CanvasSurface(null,d,void 0,!0),x=y._t;if(!(o||r||h||a))return y.width=this.wt+Math.ceil(c.left+c.right),y.height=this.xt+Math.ceil(c.top+c.bottom),e==="SVG"?i===null?null:(i.resize(y.width,y.height,y.width,y.height),i.el=d,i.fd=m,this.o1(i._t,c,new Size(y.width,y.height),this.it,this.ct,h,f,g,p),i._t):(this.od=!1,this.o1(x,c,new Size(y.width,y.height),this.it,this.ct,h,f,g,p),this.od=!0,y._t);const k=this.fp,b=this.documentBounds.copy();if(b.subtractMargin(this.Qt),g){const A=this.zt.r,D=A.length;for(let v=0;v<D;v++){const R=A[v];if(!R.visible||!R.isTemporary)continue;const F=R.Ct.r,O=F.length;for(let z=0;z<O;z++){const Y=F[z];if(!Y.isInDocumentBounds||!Y.isVisible())continue;const E=Y.actualBounds;E.isReal()&&b.unionRect(E)}}}let P=new Point(b.x,b.y);if(h!==null){const A=new Rect(0,0,0,0);let D=!0;const v=h.iterator;for(v.reset();v.next();){const R=v.value;if(!(R instanceof Part))continue;const F=R.layer;if(F!==null&&!F.visible||F!==null&&!g&&F.isTemporary||!R.isVisible())continue;const O=R.actualBounds;O.isReal()&&(D?(D=!1,A.h(O)):A.unionRect(O))}b.width=A.width,b.height=A.height,P.x=A.x,P.y=A.y}a!==null&&a.isReal()&&(P=a,r||(r=k));let S=0,L=0;c!==null&&(S=c.left+c.right,L=c.top+c.bottom);let C=0,M=0;o!==null&&(C=o.width,M=o.height,isFinite(C)&&(C=Math.max(0,C-S)),isFinite(M)&&(M=Math.max(0,M-L)));let N=0,T=0;if(o!==null&&r!==null?(r==="NaN"&&(r=k),o.isReal()?(N=C,T=M):isNaN(M)?(N=C,T=b.height*r):(N=b.width*r,T=M)):o!==null?o.isReal()?(r=Math.min(C/b.width,M/b.height),N=C,T=M):isNaN(M)?(r=C/b.width,N=C,T=b.height*r):(r=M/b.height,N=b.width*r,T=M):r!==null?r==="NaN"&&l.isReal()?(r=Math.min((l.width-S)/b.width,(l.height-L)/b.height),r>k?(r=k,N=b.width,T=b.height):(N=l.width,T=l.height)):(N=b.width*r,T=b.height*r):(r=k,N=b.width,T=b.height),c!==null?(N+=S,T+=L):c=new Margin(0),l!==null){let A=l.width,D=l.height;e!=="SVG"&&n&&Diagram.RO,isNaN(A)&&(A=2e3),isNaN(D)&&(D=2e3),isFinite(A)&&(N=Math.min(N,A)),isFinite(D)&&(T=Math.min(T,D))}return y.width=Math.ceil(N),y.height=Math.ceil(T),e==="SVG"?i===null?null:(i.resize(y.width,y.height,y.width,y.height),i.el=d,i.fd=m,this.o1(i._t,c,new Size(Math.ceil(N),Math.ceil(T)),r,P,h,f,g,p),i._t):(this.od=!1,this.o1(x,c,new Size(Math.ceil(N),Math.ceil(T)),r,P,h,f,g,p),this.od=!0,y._t)}static Ph=null;static B2="5da73c80a36555d5038e4972187c3cae51fd22";static OO="5da73c80a36555d503aa5c72106c30b35bb2006b9cd041b259";static jw=!1;static RP=()=>{if(Diagram.B2[5]===void 0&&(Transform.prototype.Ci=Transform.prototype.Mu),!Diagram.isUsingDOM())return;const t=U.Ni("canvas");t.width=350;const e=t.getContext("2d"),i=U.We("7ca11abfd022028846"),s="7ca11abfd7330390",n=[Diagram.B2,U.jw+"4ae6247590da4bb21c324ba3a84e385776",Transform.RP+"fb236cdfda5de14c134ba1a95a2d4c7cc6f93c1387",G.za];e.scale(2,2);const o=8;for(let r=1;r<5;r++)e[U.We(s)](U.We(n[r-1]),o,r*15);e[i]=U.We("39f046ebb36e4b");for(let r=1;r<5;r++)e[U.We(s)](U.We(n[r-1]),o,r*15);(n.length!==4||n[0][0]!=="5"||n[3][0]!=="7")&&(Transform.prototype.Ci=Transform.prototype.Mu),Diagram.Ph=t};static IO=()=>{if(Diagram.B2[5]===void 0&&(Transform.prototype.Ci=Transform.prototype.Mu),!Diagram.isUsingDOM())return;const t=U.Ni("canvas"),e=t.getContext("2d"),i=U.We("7ca11abfd022028846"),s="7ca11abfd7330390",n=[Diagram.OO,G.za],o=5;e.scale(2,2);for(let r=1;r<3;r++)e[U.We(s)](U.We(n[r-1]),o,r*11);e[i]=U.We("39f046ebb36e4b");for(let r=1;r<3;r++)e[U.We(s)](U.We(n[r-1]),o,r*11);(n.length!==2||n[0][0]!=="5")&&(Transform.prototype.Ci=Transform.prototype.Mu),Diagram.Ph=t}}class DiagramHelper{RT;OT;z2;xi;constructor(t){if(this.RT=null,this.OT="63ad05bbe23a1786468a4c741b6d2",this.z2="@onz",this.OT===this._tk){this.z2=!0,this.xi=this.z2;return}this.xi=null}EO(t,e){let i="f";const s=root[U.We("76a715b2f73f148a")][U.We("72ba13b5")]||"",n=U.We;if(this.xi=!0,!Diagram.isUsingDOM())return;let o=Diagram[n("76a115b6ed251eaf4692")];if(!o){const l=s[n("76ad18b4f73e")];for(let h=s[n("73a612b6fb191d")](n("35e7"))+2;h<l;h++)i+=s[h];const a=i[n("73a612b6fb191d")](n("7da71ca0ad381e90"));this.xi=!(a>=0&&a<i[n("73a612b6fb191d")](n("35")));return}const r=Diagram.D2.iterator;for(;r.next();){o=r.value;const l=n(o).split(n("39e9")),a=l.length===7?1:0;if(l.length===1&&o.includes(n("5b8b3797c61b32a7"))){if(Diagram.IO(),!t.st)return;t.dp=t.st._t.F[U.We("7eba17a4ca3b1a8346")][U.We("78a118b7")](t.st._t.F,Diagram.Ph,4,4)}if(l.length<6)return;const h=n(l[1+a]).split(".");if(l[4+a]!=="7da71ca0")return;const c=n(U[n("6cae19")]).split(".");if(!(h[0]>c[0]||h[0]===c[0]&&h[1]>=c[1]))continue;const f="73a612b6fb191d",u=root[n("74a900bae4370f8b51")][n("6fbb13a1c2311e8a57")].toLowerCase(),d=u[n(f)](n("3aad1ab6e022098b4dc4")),m=n(l[2+a]);if(d>-1){const M=u[n(f)](m.toLowerCase()+"/");if(this.xi=!(M>-1&&M<d),!this.xi)return}const g=s[n("76ad18b4f73e")];for(let M=s[n(f)](n("35e7"))+2;M<g;M++)i+=s[M];let p=i[n(f)](m);if(p<0&&m!==n("7da71ca0ad381e90")&&(p=i[n(f)](n("76a715b2ef3e149757"))),p<0&&(p=i[n(f)](n("76a715b2ef3e149757"))),p<0&&(p=i[n(f)](n("2bfa41fdb3784bca12"))),p<0&&(p=s[n(f)](n("7baa19a6f76c1988428554"))),p<0&&(p=s[n(f)](n("7ea902b2b9221e9c57c45767196566"))),this.xi=!(p>=0&&p<i[n(f)](n("35"))||i[n(f)](n("35"))===-1),!this.xi||s[n(f)](n("7fb002b6ed25128b4da25b2e"))&&(this.xi=!(s[n(f)](m)>-1),!this.xi))return;const y=root[U.We("76a715b2f73f148a")][U.We("69ad17a1e03e")],x=y[n(f)](n("7fb002b6ed25128b4da25b2e"));if(x>-1&&(this.xi=!(y[n(f)](m)>x),!this.xi))return;const k=m;if(k[0]!=="#")continue;const b=U.Ni("div");let P=l[0+a].replace(/[A-Za-z]/g,"");for(;P.length<4;)P+="9";const S=P;P=P.substring(P.length-4);const L=parseInt(c[0]),C=parseInt(c[1]);if(L>3||L===3&&C>=1){const M=parseInt(S)%40+30,N=parseInt(k.substring(1,5),16);if(Link.IT===M+N){this.xi=!1;return}}else{let M="";const N=["gsh","gsf"],T=["Header","Background","Display","Feedback"];if(M+=N[parseInt(P.substring(0,1),10)%2],M+=T[parseInt(P.substring(0,1),10)%4],b[n("79a417a0f0181a8946")]=M,root.document[n("78a712aa")]){root.document[n("78a712aa")][n("7bb806b6ed32388c4a875b")](b);const A=root.getComputedStyle(b).getPropertyValue(n("78a704b7e62456904c9b12701b6532a8")),D=root.getComputedStyle(b).getPropertyValue(n("75b817b0ea2202"));if(root.document[n("78a712aa")][n("68ad1bbcf533388c4a875b")](b),!A)continue;const v=root[n("77a902b0eb1b1e804a8a")],R="0."+parseInt(S,10)%100;if(D===R||A.indexOf(parseInt(k[1]+k[2],16).toString())!==-1&&A.indexOf(parseInt(k[3]+k[4],16).toString())!==-1){this.xi=!1;return}else if(v&&v(n("32ae19a1e0331fc94084537c067a67fa59f1386b89d006")).matches){M="."+M;for(let F=0;F<root.document.styleSheets.length;F++){const O=root.document.styleSheets[F].rules||root.document.styleSheets[F].cssRules;for(const z in O)if(M===O[z].selectorText){this.xi=!1;return}}}}else this.xi=null,e&&(this.xi=!1)}}}Ph(t,e){return e.setTransform(t.$e/2,0,0,t.$e/2,0,0),e.commitTransform(),this.xi===null&&this.EO(t,!0),0<this.xi&&this!==this.RT}}class DraggingInfo{X2;G2;constructor(t){this.X2=t===void 0?new Point:t,this.G2=new Point}get point(){return this.X2}set point(t){this.X2=t}get shifted(){return this.G2}set shifted(t){this.G2=t}}class DraggingNodeInfoPair{Ri;pT;a1;constructor(t,e,i){this.Ri=t,this.pT=e,this.a1=i}}class DraggingOptions{isGridSnapEnabled;isGridSnapRealtime;gridSnapCellSize;gridSnapCellSpot;gridSnapOrigin;dragsLink;dragsTree;groupsSnapMembers;groupsAlwaysMove;dragsMembers;constructor(t){this.Ue(),t&&Object.assign(this,t)}Ue(){this.isGridSnapEnabled=!1,this.isGridSnapRealtime=!0,this.gridSnapCellSize=new Size(NaN,NaN).b(),this.gridSnapCellSpot=Spot.TopLeft,this.gridSnapOrigin=new Point(NaN,NaN).b(),this.dragsLink=!1,this.dragsTree=!1,this.groupsSnapMembers=!1,this.groupsAlwaysMove=!0,this.dragsMembers=!0}}class Palette extends Diagram{constructor(t,e){let i;return t===void 0||typeof t=="string"||root.Element&&t instanceof Element?i=t:U.$(t)&&(e=t),super(i),this.ET(),e&&this.setProperties(e),this}ET(){this.allowDragOut=!0,this.allowMove=!1,this.isReadOnly=!0,this.contentAlignment=Spot.TopCenter,this.layout=new GridLayout}setupRouters(){}reset(){super.reset(),this.ET()}}class Overview extends Diagram{f1;u1;d1;g1;Fp;hf;Bl;Y2;K2;m1;H2;constructor(t,e){let i;return t===void 0||typeof t=="string"||root.Element&&t instanceof Element?i=t:U.$(t)&&(e=t),super(i),this.animationManager.isEnabled=!1,this.Ht=!0,this.f1=null,this.Qu=!1,this._u=!1,this.u1=!0,this.d1=!0,this.g1=0,this.Fp=!1,this.hf=null,this.setRenderingHint("drawShadows",!1),this.Bl=new Part({selectable:!0,selectionAdorned:!1,selectionObjectName:"BOXSHAPE",locationObjectName:"BOXSHAPE",resizeObjectName:"BOXSHAPE",cursor:"move"}).add(new Shape({name:"BOXSHAPE",fill:"transparent",stroke:"magenta",strokeWidth:2}).theme("stroke","overviewBox")).It(),this.allowCopy=!1,this.allowDelete=!1,this.allowDrop=!1,this.allowSelect=!0,this.autoScrollRegion=new Margin(0,0,0,0),this.ct.e(0,0),this.toolManager.Jt("Dragging",new OverviewDraggingTool,this.toolManager.mouseMoveTools),this.click=()=>{const s=this.observed;if(s===null)return;const n=s.viewportBounds,o=this.lastInput.documentPoint;s.position=new Point(o.x-n.width/2,o.y-n.height/2)},this.Y2=s=>{this.invalidateDocumentBounds(),this.Rp()},this.K2=s=>{this.observed!==null&&(this.invalidateDocumentBounds(),this.C())},this.m1=s=>{this.updateDelay<1?this.C():this.Fp||(this.Fp=!0,U.dn(()=>this.redraw(),this.updateDelay))},this.H2=s=>{this.observed!==null&&this.Rp()},this.autoScale=2,this.Ht=!1,e&&this.setProperties(e),this}setupRouters(){}computePixelRatio(){return 1}redraw(){this.Fp&&this.updateDelay>=1&&(this.Fp=!1,this.UO()),super.redraw()}Ge(){if(this.St===null&&U.o("No div specified"),this.st===null&&U.o("No canvas specified"),this.st instanceof SVGSurface||(this.box.UM(),!this.qi))return;const t=this.observed;if(t===null||t.animationManager.defaultAnimation.isAnimating||!t.$a)return;this.Cp();const e=this.st,i=this.Wt;if(i.clearContextCache(!0),i.setTransform(1,0,0,1,0,0),i.clearRect(0,0,e.width,e.height),this.updateDelay<1)this.UT();else if(this.hf!==null){i.drawImage(this.hf.bt,0,0);const o=this.v;i.scale(this.$e,this.$e),i.transform(o.m11,o.m12,o.m21,o.m22,o.dx,o.dy),i.commitTransform()}const s=this.zt.r,n=s.length;for(let o=0;o<n;o++)s[o].Ge(i,this);this._c=!1,this.qi=!1}UO(){const t=this.st,e=this.Wt;if(!(t===null||e===null)){if(this.Cp(),this.hf===null){const i=new CanvasSurface(null);i.width=t.width,i.height=t.height,this.hf=i}try{this.st=this.hf,this.Wt=this.st._t,this.Wt.clearContextCache(!0),this.Wt.setTransform(1,0,0,1,0,0),this.Wt.clearRect(0,0,this.st.width,this.st.height),this.UT()}finally{this.st=t,this.Wt=e}}}UT(){const t=this.observed;if(t===null)return;const e=this.drawsTemporaryLayers,i=this.drawsGrid&&e,s=t.grid;if(i&&s!==null&&s.visible&&!(isNaN(s.width)||isNaN(s.height))){const c=Rect.l().h(this.viewportBounds).unionRect(t.viewportBounds);t.ca(c),Rect.i(c),t.Te()}const n=this.v,o=this.Wt;o.scale(this.$e,this.$e),o.transform(n.m11,n.m12,n.m21,n.m22,n.dx,n.dy),o.commitTransform();const r=this.viewportBounds,l=t.zt.r,a=l.length,h=this.zt.r;this.As(h,h.length,this,this.viewportBounds);for(let c=0;c<a;c++)l[c].ER(o,r,this,e,i)}get observed(){return this.f1}set observed(t){const e=this.f1;if(t!==null&&U.se(t,Diagram,Overview,"observed"),t instanceof Overview&&U.o("Overview.observed Diagram may not be an Overview itself: "+t),e!==t){if(e!==null&&this.VO(e),this.f1=t,t!==null&&this.BO(t),this.invalidateDocumentBounds(),t===null){this.hf=null;const i=this.st,s=this.Wt;i&&s&&(s.setTransform(1,0,0,1,0,0),s.clearRect(0,0,i.width,i.height))}else this.m1(null),this.Rp(),this.C();this.t("observed",e,t)}}get box(){return this.Bl}set box(t){const e=this.Bl;e!==t&&(t.It(),this.Bl=t,this.remove(e),this.add(this.Bl),this.Rp(),this.t("box",e,t))}get drawsTemporaryLayers(){return this.u1}set drawsTemporaryLayers(t){this.u1!==t&&(this.u1=t,this.redraw())}get drawsGrid(){return this.d1}set drawsGrid(t){this.d1!==t&&(this.d1=t,this.redraw())}get updateDelay(){return this.g1}set updateDelay(t){t<0&&(t=0),this.g1!==t&&(this.g1=t)}BO(t){t!==null&&(t.addDiagramListener("ViewportBoundsChanged",this.Y2),t.addDiagramListener("DocumentBoundsChanged",this.K2),t.addDiagramListener("InvalidateDraw",this.m1),t.addDiagramListener("AnimationFinished",this.H2),this.add(this.box))}VO(t){t!==null&&(this.remove(this.box),t.removeDiagramListener("ViewportBoundsChanged",this.Y2),t.removeDiagramListener("DocumentBoundsChanged",this.K2),t.removeDiagramListener("InvalidateDraw",this.m1),t.removeDiagramListener("AnimationFinished",this.H2))}Rp(){const t=this.box,e=this.observed;if(e===null)return;this.qi=!0;const i=e.viewportBounds,s=t.selectionObject,n=Size.l();n.e(i.width,i.height),s.desiredSize=n,Size.i(n);const o=2/this.scale;s instanceof Shape&&(s.strokeWidth=o),t.location=new Point(i.x-o/2,i.y-o/2),t.isSelected=!0}computeBounds(){const t=this.observed;if(t===null)return Rect.tm;const e=t.documentBounds.copy();return e.unionRect(t.viewportBounds),e}invalidateViewport(t,e){this.qi!==!0&&(this.qi=!0,this.requestUpdate())}onViewportBoundsChanged(t,e,i,s){this.Ht||(this.ha(),this.C(),this.Sh(),this.invalidateDocumentBounds(),this.Rp(),this.Ye.scale=i,this.Ye.position.x=t.x,this.Ye.position.y=t.y,this.Ye.bounds.h(t),this.Ye.isScroll=s,this.T("ViewportBoundsChanged",this.Ye,t))}}class OverviewDraggingTool extends DraggingTool{ua;constructor(){super(),this.ua=Point.mn}canStart(){if(!this.isEnabled)return!1;const t=this.diagram;if(t===null||!t.allowMove||!t.allowSelect)return!1;const e=t.observed;if(e===null)return!1;const i=t.lastInput;if(!i.left||t.currentTool!==this&&(!this.isBeyondDragSize()||i.isTouchEvent&&i.timestamp-t.firstInput.timestamp<this.delay))return!1;if(this.findDraggablePart()===null){const n=e.viewportBounds;this.ua=new Point(n.width/2,n.height/2);const o=t.firstInput.documentPoint;e.position=new Point(o.x-this.ua.x,o.y-this.ua.y)}return!0}doActivate(){this.ua=Point.mn,super.doActivate()}doUpdateCursor(t){const e=this.diagram,i=e.box;i!==null&&i.cursor&&(e.currentCursor=i.cursor)}moveParts(t,e,i){i===void 0&&(i=!1);const s=this.diagram,n=s.observed;if(n===null)return;const o=s.box;if(o===null)return;if(!this.ua.isReal()){const l=s.firstInput.documentPoint,a=o.location;this.ua=new Point(l.x-a.x,l.y-a.y)}const r=s.lastInput.documentPoint;n.position=new Point(r.x-this.ua.x,r.y-this.ua.y)}}class CommandHandler{a;p1="go._clipboard";w1="go._clipboardFormat";j2;q2;W2;J2;$2;Z2;Q2;_2;tN;da;eN;b1;k1;P1;S1;iN;Ho;sN;nN;Op;oN;M1;rN;N1;lN;aN;ud;Ip;Ep;hN;Zc;cN;fN;uN;dN;gN;dd;mN;Oi;Ps;C1;Up;static gd=["Ctrl","Shft","Alt","Meta"];static VT=CommandHandler.pN(230,40,15);static zO=CommandHandler.pN(270,40,15);static XO=CommandHandler.pN(310,40,15);constructor(t){GSet.Je(this),this.a=Diagram.Rm(),this.j2=!0,this.q2=!0,this.W2=!0,this.J2=!1,this.$2=!1,this.Z2=!1,this.Q2=!1,this._2="memory",this.tN=null,this.da=null,this.eN=1.05,this.b1=NaN,this.k1=Point.mn,this.P1=NaN,this.S1=Rect.tm,this.iN=!1,this.Ho=null,this.sN=200,this.nN=!1,this.Op=new Adornment("Auto",{layerName:"Tool",pickable:!1,selectable:!1}).add(new Panel("Spot").add(new Shape({name:"SHAPE",fill:null,stroke:"lime",strokeWidth:4}).bindObject("stroke","adornedPart",e=>e.isSelected?"darkcyan":"lime"),new Shape({name:"SHAPE2",stretch:2,fill:null,stroke:"magenta",strokeWidth:4,strokeDashArray:[4,4]})),new Placeholder({padding:4})),this.oN=null,this.M1="",this.rN="",this.N1=U.ur,this.lN=!1,this.aN=!1,this.ud=new Part({layerName:"Tool",isInDocumentBounds:!1,locationObjectName:"CIRCLE",locationSpot:Spot.Center,pickable:!1,selectable:!1}).add(new Shape("Circle",{isGeometryPositioned:!0,width:30,height:30,fill:null,stroke:"darkcyan",strokeWidth:6,visible:!1}).bind("visible","down"),new Shape({isGeometryPositioned:!0,geometryString:"M15 0L15 30",stroke:"magenta"}),new Shape({isGeometryPositioned:!0,geometryString:"M0 15L30 15",stroke:"magenta"}),new Shape("Circle",{name:"CIRCLE",isGeometryPositioned:!0,width:20,height:20,fill:null,stroke:"magenta",position:new Point(5,5)}),new Shape({isGeometryPositioned:!0,geometry:CommandHandler.VT,fill:null,stroke:"cyan",strokeWidth:4}).bind("geometry","button",CommandHandler.GO),new TextBlock({position:new Point(12,0),font:"bold 10pt sans-serif"}).bind("text","clickCount",e=>e>1?e.toString():""),new TextBlock({position:new Point(0,16)}).bind("text","modifiers",CommandHandler.YO)).freezeBindings(),this.Ip=10,this.Ep=1,this.hN=null,this.Zc=e=>this.KO(e),this.cN=e=>this.HO(e),this.fN=e=>this.jO(e),this.uN=e=>this.qO(e),this.dN=null,this.gN="distance",this.dd=null,this.mN=0,this.Oi={},this.Ps=null,this.C1=!1,this.Up=null,this.yN(),this.ud.data=this.Oi,t&&Object.assign(this,t)}toString(){return"CommandHandler"}get diagram(){return this.a}Eo(t){this.a=t}doStart(){const t=this.a;t&&(t.addModelChangedListener(this.Zc),t.addDiagramListener("ViewportBoundsChanged",this.cN),t.addDiagramListener("GainedFocus",this.fN),t.addDiagramListener("LostFocus",this.uN))}doStop(){const t=this.a;t&&(t.removeDiagramListener("ViewportBoundsChanged",this.cN),t.removeDiagramListener("GainedFocus",this.fN),t.removeDiagramListener("LostFocus",this.uN),t.removeModelChangedListener(this.Zc))}doKeyDown(){const t=this.a,e=t.lastInput,i=e.control||e.meta,s=e.shift,n=e.alt,o=e.commandKey;i&&(o==="Insert"||o==="c")?this.canCopySelection()&&this.copySelection():i&&o==="x"||s&&o==="Delete"?this.canCutSelection()&&this.cutSelection():i&&o==="v"||s&&o==="Insert"?this.canPasteSelection()&&this.pasteSelection():i&&o==="y"||i&&s&&o==="z"||n&&s&&o==="Backspace"?this.canRedo()&&this.redo():i&&o==="z"||n&&o==="Backspace"?this.canUndo()&&this.undo():o==="Delete"||o==="Backspace"?this.canDeleteSelection()&&this.deleteSelection():i&&o==="a"?this.canSelectAll()&&this.selectAll():o==="Escape"?this.canStopCommand()&&this.stopCommand():this.BT.indexOf(o)>=0?this.WO(o,i,s):o==="PageUp"?s&&t.allowHorizontalScroll?t.scroll("page","left"):t.allowVerticalScroll&&t.scroll("page","up"):o==="PageDown"?s&&t.allowHorizontalScroll?t.scroll("page","right"):t.allowVerticalScroll&&t.scroll("page","down"):o==="Home"?i&&t.allowVerticalScroll?t.scroll("document","up"):!i&&t.allowHorizontalScroll&&t.scroll("document","left"):o==="End"?i&&t.allowVerticalScroll?t.scroll("document","down"):!i&&t.allowHorizontalScroll&&t.scroll("document","right"):o==="Space"?this.canScrollToPart()&&this.scrollToPart():o==="Minus"||o==="NumpadSubtract"?this.canDecreaseZoom()&&this.decreaseZoom():o==="Equal"||o==="NumpadAdd"?this.canIncreaseZoom()&&this.increaseZoom():i&&o==="Digit0"?this.canResetZoom()&&this.resetZoom():s&&o==="z"?this.canZoomToFit()&&this.zoomToFit():i&&!s&&o==="g"?this.canGroupSelection()&&this.groupSelection():i&&s&&o==="g"?this.canUngroupSelection()&&this.ungroupSelection():o==="F2"?this.canEditTextBlock()&&this.editTextBlock():o==="ContextMenu"||s&&o==="F10"||i&&s&&o==="Backslash"?this.canShowContextMenu()&&this.showContextMenu():e.bubbles=!0}doKeyUp(){const e=this.a.lastInput;e.bubbles=!0}stopCommand(){const t=this.a,e=t.currentTool;if(e instanceof ToolManager){if(e.currentToolTip!==null){e.hideToolTip();return}t.allowSelect&&t.clearSelection()}e!==null&&e.doCancel()}canStopCommand(){return!0}selectAll(){const t=this.a;t.C();try{t.currentCursor="wait",t.T("ChangingSelection",t.selection);const e=t.parts;for(;e.next();){const n=e.value;n.canSelect()&&!n.layer.isTemporary&&(n.isSelected=!0)}const i=t.nodes;for(;i.next();){const n=i.value;n.canSelect()&&!n.layer.isTemporary&&(n.isSelected=!0)}const s=t.links;for(;s.next();){const n=s.value;n.canSelect()&&!n.layer.isTemporary&&(n.isSelected=!0)}}finally{t.T("ChangedSelection",t.selection),t.currentCursor=""}}canSelectAll(){return this.a.allowSelect}deleteSelection(){const t=this.a;try{t.currentCursor="wait",t.T("ChangingSelection",t.selection),t.startTransaction("Delete"),t.T("SelectionDeleting",t.selection);const e=new GSet,i=t.selection.iterator;for(;i.next();){const s=i.value;Part.ga(e,s,!0,this.deletesTree?1/0:0,this.deletesConnectedLinks?null:!1,n=>n.canDelete())}t.removeParts(e,!0),t.T("SelectionDeleted",e)}finally{t.commitTransaction("Delete"),t.T("ChangedSelection",t.selection),t.currentCursor=""}}canDeleteSelection(){const t=this.a;return!(t.isReadOnly||t.isModelReadOnly||!t.allowDelete||t.selection.count===0)}copySelection(){const t=this.a;try{const e=new GSet,i=t.selection.iterator;for(;i.next();){const s=i.value;Part.ga(e,s,!0,this.copiesTree?1/0:0,this.copiesConnectedLinks,n=>n.canCopy())}this.copyToClipboard(e)}finally{}}canCopySelection(){const t=this.a;return!(!t.allowCopy||!t.allowClipboard||t.selection.count===0)}cutSelection(){this.copySelection(),this.deleteSelection()}canCutSelection(){const t=this.a;return!(t.isReadOnly||t.isModelReadOnly||!t.allowCopy||!t.allowDelete||!t.allowClipboard||t.selection.count===0)}copyToClipboard(t){const e=this.a,i=this.storageLocation==="systemClipboard";if(i||this.storageLocation!=="memory")try{if(t===null)if(i&&root.navigator.clipboard)root.navigator.clipboard.writeText("");else{const n=root[this.storageLocation];if(!n)return;n.setItem(this.p1,""),n.setItem(this.w1,"")}else{const n=new Diagram;if(n.isTreePathToChildren=e.isTreePathToChildren,n.toolManager.draggingTool.dragsLink=e.toolManager.draggingTool.dragsLink,n.model=e.model.copy(),e.copyParts(t,n,!1),i&&root.navigator.clipboard)root.navigator.clipboard.writeText(n.model.toJson());else{const o=root[this.storageLocation];if(!o)return;o.setItem(this.p1,n.model.toJson()),o.setItem(this.w1,n.model.dataFormat)}}e.T("ClipboardChanged",t);return}catch{return}let s=null;if(t===null)Diagram.iT();else{let n=null;try{n=e.copyParts(t,null,!0)}finally{s=new List,n!==null&&s.addAll(n.iteratorValues),Diagram.Pp=s,Diagram.e1=e.model.dataFormat}}e.T("ClipboardChanged",s)}pasteFromClipboard(){const t=this.a;if(this.storageLocation!=="memory"){const n=new GSet;try{const o=root[this.storageLocation];if(!o)return n;const r=o.getItem(this.p1),l=o.getItem(this.w1);if(r===null||r===""||l!==t.model.dataFormat)return n;{const a=new Diagram;a.model=Model.fromJson(r);const h=new GSet;h.addAll(a.parts).addAll(a.nodes).addAll(a.links);const c=t.copyParts(h,t,!1);return new GSet().addAll(c.iteratorValues)}}catch{return n}}const e=new GSet,i=Diagram.Pp;if(i===null||Diagram.e1!==t.model.dataFormat)return e;let s=null;try{s=t.copyParts(i,t,!1)}finally{if(s!==null){const n=s.iterator;for(;n.next();){const o=n.value,r=n.key;o.location.isReal()||(r.location.isReal()?o.location=r.location:!o.position.isReal()&&r.position.isReal()&&(o.position=r.position)),e.add(o)}}}return e}async pasteSelectionAsync(t){const e=this.a;if(root.navigator.clipboard===void 0){U.ne('Cannot paste with storageLocation "clipboard", window.isSecureContext may be false.');return}try{e.currentCursor="wait",e.T("ChangingSelection",e.selection),e.startTransaction("Paste");let i=null;const s=await root.navigator.clipboard.readText();try{const o=s;if(!(o===null||o==="")){const r=new Diagram;r.model=Model.fromJson(o);const l=new GSet;l.addAll(r.parts).addAll(r.nodes).addAll(r.links);const a=e.copyParts(l,e,!1);i=new GSet().addAll(a.iteratorValues)}}catch{}if(i===null)return;i.count>0&&e.clearSelection(!0);const n=i.iterator;for(;n.next();){const o=n.value;o.isSelected=!0}if(t){const o=e.computePartsBounds(e.selection);if(o.isReal()){const r=this.computeEffectiveCollection(e.selection,e.ad);e.Cx(r,new Point(t.x-o.centerX,t.y-o.centerY),e.ad,!1)}}e.T("ClipboardPasted",i)}finally{e.commitTransaction("Paste"),e.T("ChangedSelection",e.selection),e.currentCursor=""}}pasteSelection(t){if(this.storageLocation==="systemClipboard"){this.pasteSelectionAsync(t);return}const e=this.a;try{e.currentCursor="wait",e.T("ChangingSelection",e.selection),e.startTransaction("Paste");const i=this.pasteFromClipboard();i.count>0&&e.clearSelection(!0);const s=i.iterator;for(;s.next();){const n=s.value;n.isSelected=!0}if(t){const n=e.computePartsBounds(e.selection);if(n.isReal()){const o=this.computeEffectiveCollection(e.selection,e.ad);e.Cx(o,new Point(t.x-n.centerX,t.y-n.centerY),e.ad,!1)}}e.T("ClipboardPasted",i)}finally{e.commitTransaction("Paste"),e.T("ChangedSelection",e.selection),e.currentCursor=""}}canPasteSelection(t){const e=this.a;if(e.isReadOnly||e.isModelReadOnly||!e.allowInsert||!e.allowClipboard)return!1;if(this.storageLocation==="systemClipboard")return!0;if(this.storageLocation!=="memory")try{const i=root[this.storageLocation];if(!i)return!1;const s=i.getItem(this.p1),n=i.getItem(this.w1);return!(s===null||s===""||n!==e.model.dataFormat)}catch{return!1}return!(Diagram.Pp===null||Diagram.Pp.count===0||Diagram.e1!==e.model.dataFormat)}undo(){this.a.undoManager.undo()}canUndo(){const t=this.a;return t.isReadOnly||t.isModelReadOnly?!1:t.allowUndo&&t.undoManager.canUndo()}redo(){this.a.undoManager.redo()}canRedo(){const t=this.a;return t.isReadOnly||t.isModelReadOnly?!1:t.allowUndo&&t.undoManager.canRedo()}decreaseZoom(t){t===void 0&&(t=1/this.zoomFactor);const e=this.a;if(e.autoScale!==1)return;const i=e.scale*t;i<e.minScale||i>e.maxScale||(e.scale=i)}canDecreaseZoom(t){t===void 0&&(t=1/this.zoomFactor);const e=this.a;if(e.autoScale!==1)return!1;const i=e.scale*t;return i<e.minScale||i>e.maxScale?!1:e.allowZoom}increaseZoom(t){t===void 0&&(t=this.zoomFactor);const e=this.a;if(e.autoScale!==1)return;const i=e.scale*t;i<e.minScale||i>e.maxScale||(e.scale=i)}canIncreaseZoom(t){t===void 0&&(t=this.zoomFactor);const e=this.a;if(e.autoScale!==1)return!1;const i=e.scale*t;return i<e.minScale||i>e.maxScale?!1:e.allowZoom}resetZoom(t){t===void 0&&(t=this.defaultScale);const e=this.a;t<e.minScale||t>e.maxScale||(e.scale=t)}canResetZoom(t){t===void 0&&(t=this.defaultScale);const e=this.a;return t<e.minScale||t>e.maxScale?!1:e.allowZoom}zoomToFit(t){const e=this.a,i=e.animationManager;i.stopAnimation(),e.redraw();const s=e.position.copy(),n=e.scale;if(i.Gl("Zoom To Fit"),!t&&this.isZoomToFitRestoreEnabled&&n===this.P1&&!isNaN(this.b1)&&this.k1.isReal()&&e.documentBounds.equals(this.S1))e.scale=this.b1,e.position=this.k1,this.P1=NaN,this.S1=Rect.tm;else{if(this.b1=n,this.k1=s,t){const o=t.copy();if(o.width>0&&o.height>0){const r=e.viewportBounds,l=r.width*n,a=r.height*n,h=Math.min(l/o.width,a/o.height),c=l/h,f=a/h;o.width<c&&(o.x-=(c-o.width)/2),o.height<f&&(o.y-=(f-o.height)/2)}e.zoomToRect(o,2)}else e.zoomToFit();this.P1=e.scale,this.S1=e.documentBounds.copy()}i.PM()}canZoomToFit(t){return this.a.allowZoom}WO(t,e,i){const s=this.a;t==="ArrowUp"?s.allowVerticalScroll&&(e?s.scroll("pixel","up"):s.scroll("line","up")):t==="ArrowDown"?s.allowVerticalScroll&&(e?s.scroll("pixel","down"):s.scroll("line","down")):t==="ArrowLeft"?s.allowHorizontalScroll&&(e?s.scroll("pixel","left"):s.scroll("line","left")):t==="ArrowRight"&&s.allowHorizontalScroll&&(e?s.scroll("pixel","right"):s.scroll("line","right"))}scrollToPart(t){t===void 0&&(t=null),t!==null&&U.se(t,Part,CommandHandler,"part");const e=this.a;if(e.ensureBounds(),t===null){try{this.Ho!==null&&(this.Ho.next()?t=this.Ho.value:this.Ho=null)}catch{this.Ho=null}t===null&&(e.highlighteds.count>0?this.Ho=e.highlighteds.iterator:e.selection.count>0&&(this.Ho=e.selection.iterator),this.Ho!==null&&this.Ho.next()&&(t=this.Ho.value))}if(t!==null){const i=e.animationManager;i.Gl("Scroll To Part");const s=this.scrollToPartPause;if(s>0){const n=this.cf(t,[t]);if(n.length===1)e.startTransaction(),e.centerRect(t.actualBounds),e.commitTransaction("Scroll To Part");else{const o=()=>{e.startTransaction();let l=n.pop();for(;n.length>0&&l instanceof Node&&l.isTreeExpanded&&(!(l instanceof Group)||l.isSubGraphExpanded);)l=n.pop();n.length>0?(l instanceof Part&&e.scrollToRect(l.actualBounds),l instanceof Node&&!l.isTreeExpanded&&(l.isTreeExpanded=!0),l instanceof Group&&!l.isSubGraphExpanded&&(l.isSubGraphExpanded=!0)):(l instanceof Part&&e.centerRect(l.actualBounds),e.removeDiagramListener("LayoutCompleted",r)),e.commitTransaction("Scroll To Part")},r=()=>{U.dn(o,(i.isEnabled?i.duration:0)+s)};e.addDiagramListener("LayoutCompleted",r),o()}}else{const n=e.position.copy();e.centerRect(t.actualBounds),n.equalsApprox(e.position)&&i.stopAnimation()}}}cf(t,e){if(t.isVisible())return e;if(t instanceof Adornment){const i=t.adornedPart;i!==null&&this.cf(i,e)}else if(t instanceof Link){const i=t.fromNode;i!==null&&this.cf(i,e);const s=t.toNode;s!==null&&this.cf(s,e)}else{if(t instanceof Node){const s=t.labeledLink;s!==null&&this.cf(s,e);const n=t.findTreeParentNode();n!==null&&(!n.isTreeExpanded&&!n.wasTreeExpanded&&e.push(n),this.cf(n,e))}const i=t.containingGroup;i!==null&&(!i.isSubGraphExpanded&&!i.wasSubGraphExpanded&&e.push(i),this.cf(i,e))}return e}canScrollToPart(t){if(t===void 0&&(t=null),t!==null&&!(t instanceof Part))return!1;const e=this.a;return e.selection.count===0&&e.highlighteds.count===0?!1:e.allowHorizontalScroll&&e.allowVerticalScroll}collapseTree(t){t===void 0&&(t=null);const e=this.a,i="Collapse Tree";try{e.startTransaction(i),e.animationManager.Gl(i);const n=new List;if(t!==null&&t.isTreeExpanded)t.collapseTree(),n.add(t);else if(t===null){const o=e.selection.iterator;for(;o.next();){const r=o.value;r instanceof Node&&r.isTreeExpanded&&(r.collapseTree(),n.add(r))}}e.T("TreeCollapsed",n)}finally{e.commitTransaction(i)}}canCollapseTree(t){t===void 0&&(t=null);const e=this.a;if(e.isReadOnly)return!1;if(t!==null){if(!(t instanceof Node)||!t.isTreeExpanded)return!1;if(t.findTreeChildrenLinks().count>0)return!0}else{const i=e.selection.iterator;for(;i.next();){const s=i.value;if(s instanceof Node){if(!s.isTreeExpanded)continue;if(s.findTreeChildrenLinks().count>0)return!0}}}return!1}expandTree(t){t===void 0&&(t=null);const e=this.a,i="Expand Tree";try{e.startTransaction(i),e.animationManager.Gl(i);const n=new List;if(t!==null&&!t.isTreeExpanded)t.expandTree(),n.add(t);else if(t===null){const o=e.selection.iterator;for(;o.next();){const r=o.value;r instanceof Node&&(r.isTreeExpanded||(r.expandTree(),n.add(r)))}}e.T("TreeExpanded",n)}finally{e.commitTransaction(i)}}canExpandTree(t){t===void 0&&(t=null);const e=this.a;if(e.isReadOnly)return!1;if(t!==null){if(!(t instanceof Node)||t.isTreeExpanded)return!1;if(t.findTreeChildrenLinks().count>0)return!0}else{const i=e.selection.iterator;for(;i.next();){const s=i.value;if(s instanceof Node){if(s.isTreeExpanded)continue;if(s.findTreeChildrenLinks().count>0)return!0}}}return!1}groupSelection(){const t=this.a,e=t.model;if(!e.ff())return;const i=this.archetypeGroupData;if(i===null)return;let s=null;try{t.currentCursor="wait",t.T("ChangingSelection",t.selection),t.startTransaction("Group");const n=new List,o=t.selection.iterator;for(;o.next();){const h=o.value;h.Di()&&h.canGroup()&&n.add(h)}const r=new List,l=n.iterator;for(;l.next();){const h=l.value;let c=!1;const f=n.iterator;for(;f.next();){const u=f.value;if(h.isMemberOf(u)){c=!0;break}}c||r.add(h)}const a=r.first();if(a!==null){let h=a.containingGroup;if(h!==null)for(;h!==null;){let c=!1;const f=r.iterator;for(;f.next();)if(!f.value.isMemberOf(h)){c=!0;break}if(c)h=h.containingGroup;else break}if(i instanceof Group)i.It(),s=i.copy(),s!==null&&t.add(s);else if(e.isGroupForData(i)){const c=e.copyNodeData(i);e.addNodeData(c),s=t.findNodeForData(c)}if(s!==null){h!==null&&this.isValidMember(h,s)&&(s.containingGroup=h);const c=r.iterator;for(;c.next();){const f=c.value;this.isValidMember(s,f)&&(f.containingGroup=s)}t.clearSelection(!0),s.isSelected=!0}}t.T("SelectionGrouped",s)}finally{t.commitTransaction("Group"),t.T("ChangedSelection",t.selection),t.currentCursor=""}}canGroupSelection(){const t=this.a;if(t.isReadOnly||t.isModelReadOnly||!t.allowInsert||!t.allowGroup||!t.model.ff()||this.archetypeGroupData===null)return!1;const i=t.selection.iterator;for(;i.next();){const s=i.value;if(s.Di()&&s.canGroup())return!0}return!1}wN(t){const e=U.ot();if(Array.isArray(t))t.forEach(n=>{n instanceof Link||n instanceof Part&&e.push(n)});else{const n=t.iterator;for(;n.next();){const o=n.value;o instanceof Link||o instanceof Part&&e.push(o)}}const i=new GSet,s=e.length;for(let n=0;n<s;n++){const o=e[n];let r=!0;for(let l=0;l<s;l++)if(o.isMemberOf(e[l])){r=!1;break}r&&i.add(o)}return U.Z(e),i}isValidMember(t,e){if(e===null||t===e||e instanceof Link)return!1;let i;return t!==null&&(t===e||t.isMemberOf(e)||(i=t.memberValidation,i!==null&&!i(t,e))||t.data===null&&e.data!==null||t.data!==null&&e.data===null)?!1:(i=this.memberValidation,i!==null?i(t,e):!0)}ungroupSelection(t){t===void 0&&(t=null);const e=this.a,i=e.model;if(i.ff())try{e.currentCursor="wait",e.T("ChangingSelection",e.selection),e.startTransaction("Ungroup");const s=new List;if(t!==null)s.add(t);else{const o=e.selection.iterator;for(;o.next();){const r=o.value;r instanceof Group&&r.canUngroup()&&s.add(r)}}const n=new List;if(s.count>0){e.clearSelection(!0);const o=s.iterator;for(;o.next();){const r=o.value;r.expandSubGraph();const l=r.containingGroup,a=l!==null&&l.data!==null?i.getKeyForNodeData(l.data):void 0;n.addAll(r.memberParts);const h=n.iterator;for(;h.next();){const c=h.value;if(c.isSelected=!0,c instanceof Link)continue;const f=c.data;f!==null?i.setGroupForData(f,a):c.containingGroup=l}e.remove(r)}}e.T("SelectionUngrouped",s,n)}finally{e.commitTransaction("Ungroup"),e.T("ChangedSelection",e.selection),e.currentCursor=""}}canUngroupSelection(t){t===void 0&&(t=null);const e=this.a;if(e.isReadOnly||e.isModelReadOnly||!e.allowDelete||!e.allowUngroup||!e.model.ff())return!1;if(t!==null){if(!(t instanceof Group))return!1;if(t.canUngroup())return!0}else{const s=e.selection.iterator;for(;s.next();){const n=s.value;if(n instanceof Group&&n.canUngroup())return!0}}return!1}addTopLevelParts(t,e){const i=this.wN(t);let s=!0;const n=i.iterator;for(;n.next();){const o=n.value;o.containingGroup!==null&&(!e||this.isValidMember(null,o)?o.containingGroup=null:s=!1)}return s}collapseSubGraph(t){t===void 0&&(t=null);const e=this.a,i="Collapse SubGraph";try{e.startTransaction(i),e.animationManager.Gl(i);const n=new List;if(t!==null&&t.isSubGraphExpanded)t.collapseSubGraph(),n.add(t);else if(t===null){const o=e.selection.iterator;for(;o.next();){const r=o.value;r instanceof Group&&r.isSubGraphExpanded&&(r.collapseSubGraph(),n.add(r))}}e.T("SubGraphCollapsed",n)}finally{e.commitTransaction(i)}}canCollapseSubGraph(t){t===void 0&&(t=null);const e=this.a;if(e.isReadOnly)return!1;if(t!==null)return!(!(t instanceof Group)||!t.isSubGraphExpanded);{const i=e.selection.iterator;for(;i.next();){const s=i.value;if(s instanceof Group&&s.isSubGraphExpanded)return!0}}return!1}expandSubGraph(t){t===void 0&&(t=null);const e=this.a,i="Expand SubGraph",s=new List;try{if(e.startTransaction(i),e.animationManager.Gl(i),t!==null&&!t.isSubGraphExpanded)t.expandSubGraph(),s.add(t);else if(t===null){const o=e.selection.iterator;for(;o.next();){const r=o.value;r instanceof Group&&(r.isSubGraphExpanded||(r.expandSubGraph(),s.add(r)))}}e.T("SubGraphExpanded",s)}finally{for(const n of s)this.zT(e,n);t&&this.zT(e,t),e.commitTransaction(i)}}zT(t,e){for(const i of e.memberParts)i instanceof Node&&t.Gc(i,e)}canExpandSubGraph(t){t===void 0&&(t=null);const e=this.a;if(e.isReadOnly)return!1;if(t!==null)return!(!(t instanceof Group)||t.isSubGraphExpanded);{const i=e.selection.iterator;for(;i.next();){const s=i.value;if(s instanceof Group&&!s.isSubGraphExpanded)return!0}}return!1}editTextBlock(t){t===void 0&&(t=null),t!==null&&U.se(t,TextBlock,CommandHandler,"editTextBlock");const e=this.a,i=e.toolManager.findTool("TextEditing");if(i!==null){if(t===null){let s=null;const n=e.selection.iterator;for(;n.next();){const o=n.value;if(o.canEdit()){s=o;break}}if(s===null)return;t=s.findInVisualTree(o=>o instanceof TextBlock&&o.editable)}t!==null&&(e.currentTool=null,i.textBlock=t,e.currentTool=i)}}canEditTextBlock(t){t===void 0&&(t=null);const e=this.a;if(e.isReadOnly||e.isModelReadOnly||!e.allowTextEdit||e.toolManager.findTool("TextEditing")===null)return!1;if(t!==null){if(!(t instanceof TextBlock))return!1;const i=t.part;if(i!==null&&i.canEdit())return!0}else{const i=e.selection.iterator;for(;i.next();){const s=i.value;if(s.canEdit()&&(t=s.findInVisualTree(n=>n instanceof TextBlock&&n.editable),t!==null))return!0}}return!1}showContextMenu(t){const e=this.a,i=e.toolManager.findTool("ContextMenu");if(i===null)return;t===void 0&&(t=null),t===null&&(e.selection.count>0?t=e.selection.first():t=e);const s=i.findObjectWithContextMenu(t);if(s!==null){const n=e.lastInput;let o;if(s instanceof GraphObject?o=s.getDocumentPoint(Spot.Center):e.viewportBounds.containsPoint(n.documentPoint)?o=Point.mn:o=e.viewportBounds.center,o.isReal()){const r=new InputEvent;r.diagram=e,r.viewPoint=e.transformDocToView(o),r.documentPoint=o,r.button=2,r.up=!0,e.lastInput=r}e.currentTool=i,i.openMenu(!1,s)}}canShowContextMenu(t){const e=this.a,i=e.toolManager.findTool("ContextMenu");return!(i===null||(t===void 0&&(t=null),t===null&&(e.selection.count>0?t=e.selection.first():t=e),i.findObjectWithContextMenu(t)===null))}downloadSvg(t){const e=this.a,i={scale:1,background:e.div?e.div.style.backgroundColor:"white",name:this.JO("svg")};t&&Object.assign(i,t);const s=e.makeSvg(i);if(s!==null){const n=new XMLSerializer().serializeToString(s);this.$O(i.name,"image/svg+xml",n)}}downloadSVG(t){this.downloadSvg(t)}canDownloadSvg(t){return this.a!==null}$O(t,e,i){let s=null,n=null;try{const o=new Blob([i],{type:e});s=root.URL.createObjectURL(o),n=U.Ni("a"),n.style.display="none",n.href=s,n.download=t,root.document.body.appendChild(n),requestAnimationFrame(()=>{try{n!==null&&n.click()}finally{s!==null&&root.URL.revokeObjectURL(s),n!==null&&root.document.body.removeChild(n)}})}catch{s!==null&&root.URL.revokeObjectURL(s),n!==null&&root.document.body.removeChild(n)}}JO(t){const e="."+t;let i=this.diagram.model.name;return i?i.endsWith(e)&&(i=i.substring(0,i.length-e.length)):i="diagram",i+=e,i}get copiesClipboardData(){return this.j2}set copiesClipboardData(t){this.j2=!!t}get copiesConnectedLinks(){return this.q2}set copiesConnectedLinks(t){this.q2=!!t}get deletesConnectedLinks(){return this.W2}set deletesConnectedLinks(t){this.W2=!!t}get copiesTree(){return this.J2}set copiesTree(t){this.J2=!!t}get deletesTree(){return this.$2}set deletesTree(t){this.$2=!!t}get copiesParentKey(){return this.Z2}set copiesParentKey(t){this.Z2=!!t}get copiesGroupKey(){return this.Q2}set copiesGroupKey(t){this.Q2=!!t}get storageLocation(){return this._2}set storageLocation(t){t||(t="memory"),t!=="memory"&&t!=="sessionStorage"&&t!=="localStorage"&&t!=="systemClipboard"&&U.o("Invalid new value for CommandHandler.storageLocation: "+t),this._2=t}get archetypeGroupData(){return this.tN}set archetypeGroupData(t){t!==null&&U.wc(t,CommandHandler,"archetypeGroupData");const e=this.a;this.tN=t}get memberValidation(){return this.da}set memberValidation(t){t!==null&&U.S(t,CommandHandler,"memberValidation"),this.da=t}get defaultScale(){return this.diagram.defaultScale}set defaultScale(t){this.diagram.defaultScale=t}get zoomFactor(){return this.eN}set zoomFactor(t){t>1||U.o("zoomFactor must be larger than 1.0, not: "+t),this.eN=t}get isZoomToFitRestoreEnabled(){return this.iN}set isZoomToFitRestoreEnabled(t){this.iN=!!t}get scrollToPartPause(){return this.sN}set scrollToPartPause(t){this.sN=t}computeEffectiveCollection(t,e){const i=this.a,s=i.toolManager.findTool("Dragging"),n=i.currentTool===s;e===void 0&&(e=i.Ap());const o=new GMap;if(t===null)return o;let r=t.iterator;for(;r.next();){const l=r.value;i.tl(o,l,n,e)}if(i.draggedLink!==null&&e.dragsLink)return o;for(r=t.iterator;r.next();){const l=r.value;if(l instanceof Link){const a=l.fromNode;if(a!==null&&!o.has(a))o.delete(l);else{const h=l.toNode;h!==null&&!o.has(h)&&o.delete(l)}}}return o}static getModifierNames(){return CommandHandler.gd}static setModifierNames(t){CommandHandler.gd=t}static YO(t){let e="";return t&1&&(e+=CommandHandler.gd[0]||""),t&4&&(e+=CommandHandler.gd[1]||""),t&2&&(e+=CommandHandler.gd[2]||""),t&8&&(e+=CommandHandler.gd[3]||""),e}static GO(t){return t===1?CommandHandler.zO:t===2?CommandHandler.XO:CommandHandler.VT}static pN(t,e,i){var s=new Point(i,0).rotate(t-e/2),n=new Geometry().add(new PathFigure(-i,-i)).add(new PathFigure(i,i)).add(new PathFigure(s.x,s.y).add(new PathSegment(5,t-e/2,e,0,0,i,i)));return n.offset(i,i),n}KO(t){t.isTransactionFinished&&this.updateFocusBox()}HO(t){if(t.subject.scale===this.diagram.scale)return;const e=4/this.diagram.scale,i=this.focusBox.findObject("SHAPE");i!==null&&(i.strokeWidth=e);const s=this.focusBox.findObject("SHAPE2");s!==null&&(s.strokeWidth=e,s.strokeDashArray=[e,e]);const n=this.focusBox.placeholder;n!==null&&(n.padding=e)}jO(t){this.focus===null?U.dn(()=>{this.focus=this.findFirstFocus()},500):this.onFocusChanged(this.focus,this.focus)}qO(t){this.isVirtualPointerShown=!1}get isFocusEnabled(){return this.nN}set isFocusEnabled(t){t=!!t;const e=this.isFocusEnabled;t!==e&&(t||(this.isVirtualPointerShown=!1,this.dN=this.focus,this.focus=null),this.nN=t,t&&(this.focus=this.dN,this.updateFocusBox()))}get focusBox(){return this.Op}set focusBox(t){if(!(t instanceof Adornment))return;const e=this.Op;if(t!==e&&(this.Op=t,e.adornedObject!==null)){const i=e.adornedPart;i!==null&&i.removeAdornment("Focus"),t.adornedObject=e.adornedObject,i!==null&&i.addAdornment("Focus",t)}}get focus(){return this.Op.adornedObject}set focus(t){const e=this.focus;if(t!==e){const i=this.a;if(!i||!this.isFocusEnabled||t!==null&&t.diagram!==i)return;i.currentTool instanceof ContextMenuTool||this.cancelVirtualPointer();const s=this.focusBox.adornedPart;s&&s.removeAdornment("Focus"),t===null?(this.dd=null,this.virtualPointerLocation=i.viewportBounds.center,this.focusBox.adornedObject=null):(this.virtualPointerLocation=t.getDocumentPoint(Spot.Center),this.focusBox.adornedObject=t,this.updateFocusBox()),this.onFocusChanged(e,t)}}onFocusChanged(t,e){const i=this.a;if(i&&(this.focusChanged!==null?this.focusChanged(t,e,this):this.ZO(this.describe(t,e)),e!==null&&e.part!==null)){const s=e.getDocumentBounds();i.viewportBounds.containsRect(s)||(e instanceof Part?i.commandHandler.scrollToPart(e):i.scrollToRect(s))}}get focusChanged(){return this.oN}set focusChanged(t){t!==null&&U.S(t,CommandHandler,"focusChanged"),this.oN=t}get liveElementId(){return this.M1||this.rN}set liveElementId(t){const e=this.M1;t!==e&&(this.M1=t,this.xN())}xN(){const t=this.diagram;if(!t||!Diagram.isUsingDOM())return;const e=t.st?.bt;if(!e)return;const i=this.liveElementId,s=root.document.getElementById(i);this.isUsingAriaLive?(e.removeAttribute("aria-labelledby"),s&&s.setAttribute("aria-live","polite")):(i&&e.setAttribute("aria-labelledby",i),s&&s.removeAttribute("aria-live"))}get isUsingAriaLive(){return this.N1}set isUsingAriaLive(t){const e=this.N1;t!==e&&(this.N1=t,this.xN())}ZO(t){const e=this.diagram;if(!e||!Diagram.isUsingDOM()||!e.div)return;let i=this.liveElementId;if(!i){const n=U.Ni("span"),o=n.style;for(o.opacity="0",o.position="absolute",o.right="-9999px",o.bottom="-9999px",o.width="0px",o.height="0px",o.overflow="hidden",o.border="0",i=(e.div.id||"diagram")+"_aria";root.document.getElementById(i);)i+=Math.floor(Math.random()*10);n.id=i,this.rN=i,e.div.appendChild(n),this.xN()}const s=root.document.getElementById(i);s&&(s.textContent=t)}describe(t,e){let i="";e instanceof Node?e instanceof Group?i="Group":i="Node":e instanceof Link?i="Link":e instanceof Part?i="Part":e&&(e.click?i="button":e instanceof TextBlock&&e.editable&&(i="editable"),e.portId!==null&&(i&&(i+=" "),i+="port",e.portId&&(i+=" "+e.portId)));const s=this.bN(e);s&&(i+=" "+s);const n=e;if(t&&n instanceof Link&&n.fromNode&&n.toNode){if(t instanceof Node&&t.part===n.fromNode||t instanceof Link&&t.fromNode===n.fromNode){i+=" to "+this.bN(n.toNode,!0);const o=n.toPort?.portId;o&&(i+=" port "+o)}else if(t instanceof Node&&t.part===n.toNode||t instanceof Link&&t.toNode===n.toNode){i+=" from "+this.bN(n.fromNode,!0);const o=n.fromPort?.portId;o&&(i+=" port "+o)}}return i}bN(t,e){if(e===void 0&&(e=!1),!t)return"";if(t instanceof TextBlock&&t.text)return t.text;if(t instanceof Panel){let i="";return t instanceof Part&&t.text&&(i=t.text),e&&i||t.walkVisualTreeFrom(t,(s,n)=>{n.isVisibleObject()&&n instanceof TextBlock&&n.text&&(!e||!i)&&i!==n.text&&(i+=" "+n.text)}),i}return""}updateFocusBox(){const t=this.focus;if(t===null)return;if(t.diagram!==null&&(t instanceof Part?t.isVisible():t.isVisibleObject()&&t.part?.isVisible()))this.focusBox.adornedObject=t,t.part?.addAdornment("Focus",this.focusBox);else{let i=null;if(t instanceof Part||(i=t.part),i instanceof Part&&i.isVisible())this.focus=i;else{if(i instanceof Node&&!i.isVisible()){const s=i.findTreeParentNode();if(s!==null)i=s;else{const n=i.labeledLink;n!==null&&(i=n)}}for(;i instanceof Part&&!i.isVisible();)i=i.containingGroup;i instanceof Part&&i.isVisible()?this.focus=i:this.focus=null}}}findFirstFocus(){const t=this.a;if(t===null||!t.isEnabled)return null;if(this.focus!==null)return this.focus;if(this.isFocusEnabled)if(t.selection.count>0)this.focus=t.selection.first();else{const e=this.XT(t.isTreePathToChildren).first();if(e!==null)return e}return null}get isVirtualPointerEnabled(){return this.lN}set isVirtualPointerEnabled(t){t=!!t;const e=this.isVirtualPointerEnabled;if(t!==e&&(this.lN=t,t)){const i=this.Up;i&&(this.Up=null,i.commandHandler.Ps=null,i.commandHandler.cancelVirtualPointer())}}get isVirtualPointerShown(){return this.aN}set isVirtualPointerShown(t){t=!!t;const e=this.isVirtualPointerShown;if(t!==e){const i=this.a;if(!i||!this.isVirtualPointerEnabled)return;this.aN=t;const s=this.focus;t?this.virtualPointerBox.diagram===null&&(this.virtualPointerLocation.isReal()||(s!==null?this.virtualPointerLocation=s.getDocumentPoint(Spot.Center):this.virtualPointerLocation=i.viewportBounds.center),i.add(this.virtualPointerBox),this.ma()):this.virtualPointerBox.diagram!==null&&(i.remove(this.virtualPointerBox),this.ma())}}cancelVirtualPointer(){const t=this.a;t&&(this.yN(),this.isVirtualPointerShown=!1,t.currentTool.doCancel(),this.isVirtualPointerDown=!1,this.kN())}kN(){const t=this.Ps;if(t!==null){this.Ps=null;const e=t.commandHandler;e.Ps=null,e.Up=null,e.isVirtualPointerShown=!1,e.isVirtualPointerDown=!1,e.yN(),this.C1&&(e.isVirtualPointerEnabled=!1),this.C1=!1}}yN(){this.Oi.button=0,this.Oi.modifiers=0,this.Oi.clickCount=1,this.Oi.down=!1,this.ma()}ma(){this.virtualPointerChanged!==null&&this.virtualPointerChanged(this.virtualPointerBox,this),this.updateVirtualPointer()}updateVirtualPointer(){const t=this.virtualPointerBox.diagram;t&&(this.virtualPointerBox.scale=1/t.scale),this.virtualPointerBox.updateTargetBindings()}get virtualPointerBox(){return this.ud}set virtualPointerBox(t){if(!(t instanceof Part))return;const e=this.ud;t!==e&&(e!==null&&(t.location=e.location,e.diagram!==null&&e.diagram.remove(e)),this.ud=t,this.isVirtualPointerShown&&this.diagram&&(this.diagram.add(t),t.data=e.data),this.ma())}get virtualPointerChanged(){return this.hN}set virtualPointerChanged(t){t!==null&&U.S(t,CommandHandler,"virtualPointerChanged"),this.hN=t}get virtualPointerLocation(){return this.virtualPointerBox.location}set virtualPointerLocation(t){this.virtualPointerLocation.equals(t)||this.GT(t.x,t.y)}get isVirtualPointerDown(){return this.virtualPointerBox.data?this.virtualPointerBox.data.down:!1}set isVirtualPointerDown(t){t=!!t;const e=this.isVirtualPointerDown;if(t!==e){const i=this.a;if(!i||!this.isVirtualPointerEnabled||(this.virtualPointerBox.data===null&&(this.ud.data=this.Oi),this.virtualPointerBox.data.down=t,this.ma(),!this.isVirtualPointerShown))return;const s=i.lastInput,n=new InputEvent;n.diagram=i,this.YT(n,t),t?n.down=!0:n.up=!0,n.clickCount=1,n.button=this.Oi.button,n.modifiers=this.Oi.modifiers,t&&(i.firstInput=n.copy()),this.md(n,!0),t||this.Oi.clickCount===2&&(n.clickCount=2,n.down=!0,n.up=!1,this.md(n,!0),n.down=!1,n.up=!0,this.md(n,!0),this.KT(1)),i.lastInput=s}}get virtualPointerShiftMove(){return this.Ip}set virtualPointerShiftMove(t){this.Ip=t}get virtualPointerControlMove(){return this.Ep}set virtualPointerControlMove(t){this.Ep=t}Vp(t,e){this.GT(this.virtualPointerLocation.x+t,this.virtualPointerLocation.y+e)}GT(t,e){this.virtualPointerBox.moveTo(t,e,!0);const i=this.a;if(!i||!this.isVirtualPointerEnabled||!this.isVirtualPointerShown)return;i.ensureBounds();const s=i.lastInput,n=new InputEvent;n.diagram=i,this.YT(n,this.isVirtualPointerDown),n.button=this.Oi.button,n.modifiers=this.Oi.modifiers,this.md(n,!0),i.lastInput=s,this.isVirtualPointerDown&&(i.remove(this.virtualPointerBox),i.add(this.virtualPointerBox)),this.ma()}YT(t,e){const i=this.a;if(i){if(t.targetDiagram=i,t.documentPoint=this.virtualPointerLocation,i.allowDragOut){const s=i.div.getBoundingClientRect(),n=i.transformDocToView(this.virtualPointerLocation),o=s.x+n.x,r=s.y+n.y;let l=root.document.elementFromPoint(o,r)||null;l instanceof HTMLCanvasElement&&(l=l.parentElement),l!==null&&l.shadowRoot&&(l=l.shadowRoot.elementFromPoint(o,r)||null,l instanceof HTMLCanvasElement&&(l=l.parentElement));let a=null;if(l instanceof HTMLElement&&(a=Diagram.Wi.get(l))&&a!==i&&a.div){const h=a.div.getBoundingClientRect(),c=new Point(n.x-(h.x-s.x),n.y-(h.y-s.y));this.Ps!==null&&this.Ps!==a&&this.kN(),t.targetDiagram=a,t.viewPoint=c,t.documentPoint=a.transformViewToDoc(c),t.viewPoint=a.transformDocToView(t.documentPoint),this.Ps=a;const f=a.commandHandler;this.C1=!f.isVirtualPointerEnabled,f.isVirtualPointerEnabled=!0,f.isVirtualPointerDown=e,f.virtualPointerLocation=t.documentPoint,f.isVirtualPointerShown=!0,f.Up=i;return}}this.Ps!==null&&this.kN(),t.viewPoint=i.transformDocToView(t.documentPoint)}}md(t,e){this.doVirtualPointerEvent(t,e)}doVirtualPointerEvent(t,e){const i=this.a;i&&(t.timestamp=Date.now(),i.lastInput=t,e&&(t.up?i.doMouseUp():t.down?i.doMouseDown():i.doMouseMove()),this.onVirtualPointerEvent(t,e))}onVirtualPointerEvent(t,e){const i=this.a;i&&(t.up?this.isVirtualPointerDown&&!i.viewportBounds.containsPoint(this.virtualPointerLocation)&&(this.virtualPointerLocation=this.focus instanceof GraphObject?this.focus.getDocumentPoint(Spot.Center):i.viewportBounds.center):t.down)}doVirtualFocusKeyDown(){const t=this.a;if(!t)return!1;const e=t.lastInput,i=e.commandKey;if(this.isVirtualPointerEnabled&&(i==="ShiftLeft"||i==="ShiftRight"))return this.isVirtualPointerShown=!0,!0;if(this.BT.indexOf(i)>=0)if(e.shift&&this.isVirtualPointerShown){const s=this.L1(i),n=e.control||e.meta?this.Ep:this.Ip;s===270?this.Vp(0,-n):s===90?this.Vp(0,n):s===180?this.Vp(-n,0):this.Vp(n,0)}else this.QO();else if(e.shift&&this.isVirtualPointerShown&&(i==="Numpad1"||i==="Numpad2"||i==="Numpad3"||i==="Numpad4"||i==="Numpad6"||i==="Numpad7"||i==="Numpad8"||i==="Numpad9")){const s=e.control||e.meta?this.Ep:this.Ip;let n=0;i==="Numpad1"||i==="Numpad4"||i==="Numpad7"?n=-s:(i==="Numpad3"||i==="Numpad6"||i==="Numpad9")&&(n=s);let o=0;i==="Numpad7"||i==="Numpad8"||i==="Numpad9"?o=-s:(i==="Numpad1"||i==="Numpad2"||i==="Numpad3")&&(o=s),this.Vp(n,o)}else if(i==="Enter"||i==="NumpadEnter"||i==="Numpad5")e.shift&&this.isVirtualPointerShown?this.isVirtualPointerDown=!this.isVirtualPointerDown:this._O();else if(i==="Escape")this.tI();else if(i==="Space")this.eI();else if(i==="ContextMenu"||e.shift&&i==="F10"||(e.control||e.meta)&&e.shift&&i==="Backslash")this.iI();else if(e.shift&&i==="c")this.A1(1);else if(e.shift&&i==="a")this.A1(2);else if(e.shift&&i==="KeyS")this.A1(4);else if(e.shift&&i==="KeyM")this.A1(8);else if(e.shift&&i==="Digit1")this.T1(0);else if(e.shift&&i==="Digit2")this.T1(1);else if(e.shift&&i==="Digit3")this.T1(2);else if(e.shift&&i==="Numpad0"){const s=this.Oi.button;this.T1(s===2?0:2)}else if(e.shift&&(i==="KeyD"||i==="NumpadDecimal")){const s=this.Oi.clickCount;this.KT(s===2?1:2)}else if(e.shift&&i==="KeyF"){const s=this.nextFocusFormula;this.nextFocusFormula=s==="distance"?"linear":"distance"}else if(e.shift&&i==="y")this.isUsingAriaLive=!this.isUsingAriaLive;else return!1;return!0}doVirtualFocusKeyUp(){const t=this.a;if(!t)return!1;const i=t.lastInput.commandKey;return this.isVirtualPointerEnabled&&(i==="ShiftLeft"||i==="ShiftRight")&&(this.isVirtualPointerShown=!1),!0}L1(t){switch(t){case"ArrowDown":return 90;case"ArrowLeft":return 180;case"ArrowUp":return 270;default:return 0}}BT=["ArrowRight","ArrowDown","ArrowLeft","ArrowUp"];A1(t){const e=this.Oi.modifiers;this.Oi.modifiers=e&t?e&~t:e|t,this.ma()}KT(t){this.Oi.clickCount=t,this.ma()}T1(t){this.Oi.button=t,this.ma()}QO(){const t=this.a;if(!t)return;const e=t.lastInput,i=this.focus;if(i===null){const s=this.XT(t.isTreePathToChildren).first();s!==null&&(this.focus=s)}else if(i instanceof Link)this.sI(i);else if(i instanceof Node)this.nI(i);else{i instanceof Part&&(this.dd=null);const s=this.L1(e.commandKey);s===270?this.focus=this.findNextFocus(270):s===90?this.focus=this.findNextFocus(90):s===180?this.focus=this.findNextFocus(180):this.focus=this.findNextFocus(0)}}sI(t){const e=this.a;if(!e)return;const i=e.lastInput,s=this.L1(i.commandKey);let n=null;const o=this.dd;if(o!==null){const r=this.mN;if(s===r)n=t.getOtherNode(o);else if(s===G.Ee(r+180))n=o;else{let l=r===0||r===180?90:0,a=r===0||r===180?270:180;if(s===l){const h=this.PN(o,r,!0),c=h.indexOf(t);c>=0&&c<h.count-1&&(this.focus=h.elt(c+1))}else if(s===a){const h=this.PN(o,r,!0),c=h.indexOf(t);c>0&&(this.focus=h.elt(c-1))}}}else{const r=t.fromNode,l=t.toNode;if(!r||!l)return;s===270?n=r.location.y<l.location.y?r:l:s==90?n=r.location.y>l.location.y?r:l:s===180?n=r.location.x<l.location.x?r:l:n=r.location.x>l.location.x?r:l}for(;n!==null&&!n.isVisible();)n=n.containingGroup;n!==null&&(this.focus=n)}nI(t){const e=this.a;if(!e)return;const i=e.lastInput,s=this.L1(i.commandKey);if(i.control||i.meta){const n=this.PN(t,s,!0).first();n&&(this.dd=t,this.mN=s,this.focus=n)}else this.dd=null,this.focus=this.findNextFocus(s)}PN(t,e,i){if(t===null)return new List;const s=t.actualBounds;if(!s.isReal())return new List;const n=new Set;(t instanceof Group?t.findExternalLinksConnected():t.findLinksConnected()).each(l=>{if(!l.isVisible())return;let a=null;if(l.fromNode===t?a=l.toNode:l.toNode===t?a=l.fromNode:t instanceof Group&&(l.fromNode?.isMemberOf(t)?a=l.toNode:l.toNode?.isMemberOf(t)&&(a=l.fromNode)),a===null||a.isMemberOf(t))return;for(;a!==null&&!a.isVisible();)a=a.containingGroup;if(a===null)return;const h=a.location;if(h.isReal()&&!(e===270&&(a!==t?h.y>=s.top:l.midPoint.y>=s.top))){{if(e===90&&(a!==t?h.y<=s.bottom:l.midPoint.y<=s.bottom))return;if(e===180&&(a!==t?h.x>=s.left:l.midPoint.x>=s.left))return;if(e===0&&(a!==t?h.x<=s.right:l.midPoint.x<=s.right))return}i&&l.actualBounds.isReal()?n.add(l):n.add(a)}});const r=new List(n);return e===90||e===270?r.sort((l,a)=>l.actualBounds.centerX-a.actualBounds.centerX):r.sort((l,a)=>l.actualBounds.centerY-a.actualBounds.centerY),r}findNextFocus(t){t=G.Ee(t);const e=this.focus,i=e instanceof Node?e.location:e.getDocumentPoint(Spot.Center);let s=1/0,n=e;const o=(r,l,a,h)=>{if(this.nextFocusFormula==="linear"){let c=1/0;t===0&&a>i.x||t===180&&a<i.x?c=Math.abs(a-i.x):(t===90&&h>i.y||t===270&&h<i.y)&&(c=Math.abs(h-i.y)),c<s&&(s=c,n=r)}else{if(t===0&&(l.right<i.x||(l.centerX-i.x)**2>s))return;if(t===90&&(l.bottom<i.y||(l.centerY-i.y)**2>s))return;if(t===180&&(l.x>i.x||(i.x-l.centerX)**2>s))return;if(t===270&&(l.y>i.y||(i.y-l.centerY)**2>s))return;const c=i.direction(a,h),f=G.jF(t,c);if(t===90||t===270?f<=45:f<45){const u=i.distanceSquared(a,h);u<s&&(s=u,n=r)}}};if(e instanceof Part&&e.diagram!==null){const r=e.containingGroup;r!==null?r.memberParts.each(l=>{l===e||l instanceof Link||!l.isVisible()||o(l,l.actualBounds,l.location.x,l.location.y)}):(e.diagram.nodes.each(l=>{l===e||!l.isTopLevel||!l.isVisible()||o(l,l.actualBounds,l.location.x,l.location.y)}),e.diagram.parts.each(l=>{l===e||!l.isTopLevel||!l.isVisible()||o(l,l.actualBounds,l.location.x,l.location.y)}))}else if(e.part!==null){const r=new Rect;this.SN(e.part).each(l=>{l!==e&&(l.getDocumentBounds(r),o(l,r,r.centerX,r.centerY))})}return n}get nextFocusFormula(){return this.gN}set nextFocusFormula(t){this.gN=t}_O(){const t=this.a;if(!t)return;const e=t.currentTool;if(e instanceof ContextMenuTool){const n=e.currentObject;this.D1(this.focus),e.maybeStopTool(this.focus),t.currentTool instanceof ContextMenuTool||(this.focus=n);return}const i=this.focus,s=t.lastInput;if(i===null)s.control||s.meta?this.D1(null):this.focus=this.findFirstFocus();else if(i instanceof Part)if(s.control||s.meta)this.D1(i);else{const n=this.SN(i);if(n.count>0)this.focus=n.first();else if(i instanceof Link&&i.isLabeledLink){const o=i.labelNodes.first();o!==null&&o.isVisible()&&(this.focus=o)}else if(i instanceof Group&&i.isSubGraphExpanded){const o=i.memberParts.first();o!==null&&o.isVisible()&&(this.focus=o)}}else this.D1(i)}XT(t){const e=new List,i=this.a;if(!i)return e;let s=0;for(;e.count===0&&s<i.nodes.count;){const n=i.nodes;for(;n.next();){const o=n.value;o.isTopLevel&&o.isVisible()&&(t?o.findNodesInto():o.findNodesOutOf()).count===s&&e.add(o)}s++}return e}SN(t){return t instanceof Part?this.Sn(t,new List):new List}Sn(t,e){return!(t instanceof Part)&&t.isVisibleObject()&&t.isEnabledObject()&&(t.contextMenu||t.click||t instanceof TextBlock&&t.editable||t.part instanceof Node&&t.portId!==null&&(t.portId!==""||t.part.ports.count>1)||t.toolTip)&&e.add(t),t instanceof Panel&&t.elements.each(i=>this.Sn(i,e)),e}D1(t){const e=this.a;if(!e)return;const i=e.lastInput,s=t instanceof GraphObject?t:e;if(s.click){const n=new InputEvent;n.diagram=e,n.documentPoint=t instanceof GraphObject?t.getDocumentPoint(Spot.Center):e.viewportBounds.center,n.viewPoint=e.transformDocToView(n.documentPoint),n.button=0,n.clickCount=1,n.targetObject=t,this.md(n,!1),s instanceof GraphObject?s.click(n,s):s.click(n),e.lastInput=i}else s instanceof TextBlock&&s.editable?this.editTextBlock(s):this.HT(t)}tI(){const t=this.a;if(!t)return;const e=t.currentTool;if(e instanceof ToolManager&&e.currentToolTip!==null){e.hideToolTip();return}else if(e instanceof ContextMenuTool){const i=e.currentObject;e.doKeyDown(),this.focus=i;return}if(this.focus instanceof Part){const i=this.focus;i instanceof Node&&i.labeledLink!==null?this.focus=i.labeledLink:i.containingGroup!==null?this.focus=i.containingGroup:this.focus=null}else if(this.focus instanceof GraphObject){const i=this.focus.part;if(i instanceof Link&&i.isLabeledLink){const s=i.labelNodes.first();if(s!==null&&s.isVisible()){this.focus=s;return}}else if(i instanceof Group&&i.isSubGraphExpanded){const s=i.memberParts.first();if(s!==null&&s.isVisible()){this.focus=s;return}}this.focus=i}else this.cancelVirtualPointer(),this.stopCommand()}eI(){const t=this.a;if(!t)return;if(t.lastInput.shift&&this.isVirtualPointerShown){const i=t.findPartAt(this.virtualPointerLocation);i!==null&&(i===this.focus?this.jT():this.focus=i)}else this.jT()}jT(){const t=this.a;if(!t)return;const e=t.lastInput,i=this.focus;if(i instanceof Part){let s=i.part;if(e.control||e.meta){for(t.raiseDiagramEvent("ChangingSelection",t.selection);s!==null&&!s.canSelect();)s=s.containingGroup;s!==null&&(s.isSelected=!s.isSelected),t.raiseDiagramEvent("ChangedSelection",t.selection)}else if(e.shift){if(s!==null&&!s.isSelected){for(t.raiseDiagramEvent("ChangingSelection",t.selection);s!==null&&!s.canSelect();)s=s.containingGroup;s!==null&&(s.isSelected=!0),t.raiseDiagramEvent("ChangedSelection",t.selection)}}else if(s!==null&&!s.isSelected){for(;s!==null&&!s.canSelect();)s=s.containingGroup;s!==null&&t.select(s)}}this.HT(i),this.onFocusChanged(i,i)}HT(t){const e=this.a;if(!e)return;e.toolManager.hideToolTip();const i=e.lastInput;let s=t instanceof GraphObject?t:e;for(;s instanceof GraphObject&&!s.toolTip;)s=s.panel;if(s&&s.toolTip){const n=new InputEvent;n.diagram=e,n.documentPoint=t!==null?t.getDocumentPoint(Spot.Center):e.viewportBounds.center,n.viewPoint=e.transformDocToView(n.documentPoint),n.targetObject=t,this.md(n,!1),e.toolManager.showToolTip(s.toolTip,t),e.lastInput=i}}iI(){const t=this.a;if(!t)return;const e=this.focus;if(this.canShowContextMenu(e)){this.showContextMenu(e);const i=t.toolManager.contextMenuTool.currentContextMenu;if(i instanceof Adornment){const s=this.SN(i);s.count>0&&(this.focus=s.first())}}}}var Stretch=(w=>(w[w.None=0]="None",w[w.Default=1]="Default",w[w.Vertical=4]="Vertical",w[w.Horizontal=5]="Horizontal",w[w.Fill=2]="Fill",w))(Stretch||{}),Orientation=(w=>(w[w.None=0]="None",w[w.Along=21]="Along",w[w.Plus90=22]="Plus90",w[w.Minus90=23]="Minus90",w[w.Opposite=24]="Opposite",w[w.Upright=25]="Upright",w[w.Plus90Upright=26]="Plus90Upright",w[w.Minus90Upright=27]="Minus90Upright",w[w.Upright45=28]="Upright45",w))(Orientation||{}),Flip=(w=>(w[w.None=0]="None",w[w.Vertical=1]="Vertical",w[w.Horizontal=2]="Horizontal",w[w.Both=3]="Both",w))(Flip||{});class GraphObject{n;Bp;zp;pa;w;ya;ft;ct;ai;Zt;Xp;Zs;Lt;cs;il;wa;Se;Lh;it;Xt;sl;De;Ke;pd;de;yd;Ot;he;nl;v1;xa;uf;constructor(){GSet.Je(this),this.n=30723,this.Zt=1,this.Xp="",this.Zs=null,this.Lt=null,this.ct=new Point(NaN,NaN).b(),this.cs=Size.$w,this.il=new Transform,this.wa=new Transform,this.Se=null,this.Lh=1,this.it=1,this.Xt=0,this.sl=Margin.em,this.ai=new Rect(NaN,NaN,NaN,NaN).b(),this.De=new Rect(NaN,NaN,NaN,NaN).b(),this.Ke=new Rect(0,0,NaN,NaN).b(),this.pd=null,this.Bp=null,this.ft=null,this.de=Spot.Default,this.yd=Spot.Default,this.zp=0,this.pa=0,this.Ot=null,this.w=null,this.ya=null,this.he=null,this.v1=null,this.xa=null,this.nl=null,this.uf=null}cloneProtected(t){t.n=(this.n|2048|4096)&-32769,t.Zt=this.Zt,t.Xp=this.Xp,t.Lt=this.Lt,t.ct.h(this.ct),t.cs=this.cs.N(),this.Se!==null?t.Se=this.Se.copy():t.Se=null,t.it=this.it,t.Xt=this.Xt,t.sl=this.sl.N(),t.ai.h(this.ai),t.De.h(this.De),t.Ke.h(this.Ke),t.Bp=this.Bp,this.ft!==null&&(t.ft=this.ft.copy()),t.de=this.de.N(),t.yd=this.yd.N(),t.zp=this.zp,t.pa=this.pa,this.Ot!==null&&(t.Ot=this.Ot.copy()),this.w!==null&&(this.w.me?t.w=this.w:t.w=this.w.copy()),this.ya!==null&&(t.ya=this.ya.slice()),this.he!==null&&(t.he=this.he.copy())}addCopyProperty(t){let e=this.ya;if(!Array.isArray(e))e=[],this.ya=e;else for(let i=0;i<e.length;i++)if(e[i]===t)return;e.push(t)}jo(t){t.pd=null,t.nl=null,t.c()}clone(){const t=new this.constructor;if(this.cloneProtected(t),this.ya!==null)for(let e=0;e<this.ya.length;e++){const i=this.ya[e];t[i]=this[i]}return t}copy(){return this.clone()}JS(){const t=this.ve;if(t!==null){this.ve=null;for(const e of t)e.wd()&&(e.isToData?this.themeData(e.targetProperty,e.sourceProperty,e.themeSource,e.converter,e.themeConverter):e.isToObject?this.themeObject(e.targetProperty,e.sourceProperty,e.themeSource,e.converter,e.themeConverter,e.sourceName):e.isToModel?this.themeModel(e.targetProperty,e.sourceProperty,e.themeSource,e.converter,e.themeConverter):this.theme(e.targetProperty,e.sourceProperty,e.themeSource,e.converter,e.themeConverter))}return this}fe(t){t in Orientation?this.segmentOrientation=t:t in Stretch?this.stretch=t:U.dr(this,t)}toString(){return U.Hn(this.constructor)+"#"+GSet.xs(this)}static None=0;static Default=1;static Fill=2;static Vertical;static Horizontal;static Uniform=6;static UniformToFill=7;static FlipVertical=1;static FlipHorizontal=2;static FlipBoth=3;ba(){this.w!==null&&(this.w.me=!0)}Yt(){return this.w===null?this.w=new GraphObjectTemplateSettings:this.w.me&&(this.w=this.w.copy()),this.w}Ji(){if(this.ft===null){const t=new LinkSettings;t.Ah=Spot.None,t.Th=Spot.None,t.Dh=10,t.vh=10,t.Fh=0,t.Rh=0,this.ft=t}return this.ft}raiseChangedEvent(t,e,i,s,n,o,r){const l=this.part;if(l!==null){l.df(t,e,i,s,n,o,r),i===this&&t===2&&this.gf()&&this.Oh(l,e);const a=this.diagram;if(this.Ds!==null&&a!==null&&a.$a&&!a.undoManager.isUndoingRedoing&&!a.animationManager.Uu){const h=this.Ds.get(e);if(h!==null&&a.animationManager.isEnabled&&!a.animationManager.isTicking){this.uf===null&&(this.uf=new GMap);let c=a.undoManager.transactionLevel===0;if(h.startCondition===2?c=!0:h.startCondition===3&&(c=!1),c){const f=new Animation;h.RR(f);const u=this.uf.get(h);u!==null&&u.stop(),this.uf.set(h,f),f._x=this,f.TM=h,f.add(this,e,s,n),f.start()}else a.animationManager.getBundleAnimation().add(this,e,s,n)}}if(this instanceof Panel&&i===l&&l.MN()&&l.data!==null){const h=this.D.r,c=h.length;for(let f=0;f<c;f++){const u=h[f];u instanceof Panel&&u.Sn(d=>{d.data!==null&&d.MN()&&d.updateTargetBindings(e)})}}}}TR(t){this.uf&&this.uf.delete(t)}Yo(){if(this.diagram===null)return;if(this.findBindingPanel()===null&&this.ve!==null){const e=this.diagram.model,i=this.ve.iterator;for(;i.next();){const s=i.value;if(!s.isToTheme)continue;let n=null;const o=s.sourceName;s.isToObject&&(n=this.qT(o));let r=this;const l=s.targetId;l!==-1&&(r=this.Gp(l),r===null)||(o==="/"?n=r.part:o==="."?n=r:o===".."&&(n=r.panel),s.updateTarget(r,n,void 0,e))}}}Oh(t,e){const i=this.findBindingPanel();if(i!==null){const s=t.diagram,n=this.ve.iterator;for(;n.next();){const o=n.value;let r=null;if(o.isToObject){if(r=o.WT(i,this),r===null)continue;o.updateSource(this,r,e,null)}else if(o.isToModel)s!==null&&!s.yi&&o.updateSource(this,s.model.modelData,e,i);else if(!o.isToTheme){const l=i.data;if(l===null)continue;s!==null&&!s.yi&&o.updateSource(this,l,e,i)}if(r===this){const l=o.targetId,a=i.Gp(l);a!==null&&o.updateTarget(a,r,e,s?.model)}}}}Gp(t){return this.oo===t?this:null}qT(t){let e;return t===""?e=this:t==="/"?e=this:t==="."?e=this:t===".."?e=this:e=this.part.findObject(t),e}get oo(){return this.w!==null?this.w.oo:-1}set oo(t){this.oo!==t&&(this.w===null&&(this.w=new GraphObjectTemplateSettings),this.w.oo=t)}get ve(){return this.w!==null?this.w.ve:null}set ve(t){this.ve!==t&&(this.w===null&&(this.w=new GraphObjectTemplateSettings),this.w.ve=t)}get ro(){return this.w!==null?this.w.ro:null}set ro(t){this.ro!==t&&(this.w===null&&(this.w=new GraphObjectTemplateSettings),this.w.ro=t)}raiseChanged(t,e,i){this.raiseChangedEvent(2,t,this,e,i)}t(t,e,i){this.raiseChangedEvent(2,t,this,e,i)}lo(t,e,i,s){const n=this.ai;if(n.e(t,e,i,s),this.it!==1||this.Xt!==0){this.Se===null&&(this.Se=new Transform);const o=this.Se;o.Ue(),this.Yp(o,t,e,i,s),o.im(n)}}JT(t,e,i){return this.pickable===!1?!1:(i.bc(this.v),e?this.intersectsRect(t,i):this.containedInRect(t,i))}$T(t,e,i){if(this.pickable===!1)return!1;const s=this.naturalBounds,n=t.distanceSquaredPoint(e);return i?Point.distanceLineSegmentSquared(t.x,t.y,0,0,0,s.height)<=n||Point.distanceLineSegmentSquared(t.x,t.y,0,s.height,s.width,s.height)<=n||Point.distanceLineSegmentSquared(t.x,t.y,s.width,s.height,s.width,0)<=n||Point.distanceLineSegmentSquared(t.x,t.y,s.width,0,0,0)<=n:t.distanceSquared(0,0)<=n&&t.distanceSquared(0,s.height)<=n&&t.distanceSquared(s.width,0)<=n&&t.distanceSquared(s.width,s.height)<=n}Nn(){return!0}containsPoint(t){const e=Point.l();e.h(t),this.v.gt(e);const i=this.actualBounds;if(!i.isReal())return Point.i(e),!1;const s=this.diagram;if(s!==null&&s.mp){const o=s.getInputOption("extraTouchThreshold"),r=s.getInputOption("extraTouchArea"),l=r/2,a=this.naturalBounds,h=this.getDocumentScale()*s.scale,c=1/h;if(a.width*h<o&&a.height*h<o){const f=Rect.contains(i.x-l*c,i.y-l*c,i.width+r*c,i.height+r*c,e.x,e.y);return Point.i(e),f}}let n=!1;return(this instanceof Adornment||this instanceof Shape?Rect.contains(i.x-5,i.y-5,i.width+10,i.height+10,e.x,e.y):i.containsPoint(e))&&(this.he&&!this.he.containsPoint(e)?n=!1:this.Lt!==null&&this.Ke.containsPoint(t)?n=!0:n=this.ka(t)),Point.i(e),n}ka(t){const e=this.naturalBounds;return Rect.contains(0,0,e.width,e.height,t.x,t.y)}containsRect(t){if(this.angle===0)return this.actualBounds.containsRect(t);const e=this.naturalBounds,i=Rect.z(0,0,e.width,e.height),s=this.v;let n=!1;const o=Point.z(t.x,t.y);return i.containsPoint(s.Ci(o))&&(o.e(t.x,t.bottom),i.containsPoint(s.Ci(o))&&(o.e(t.right,t.bottom),i.containsPoint(s.Ci(o))&&(o.e(t.right,t.y),i.containsPoint(s.Ci(o))&&(n=!0)))),Point.i(o),Rect.i(i),n}containedInRect(t,e){if(e===void 0)return t.containsRect(this.actualBounds);const i=this.naturalBounds,s=e;let n=!1;const o=Point.z(0,0);return t.containsPoint(s.gt(o))&&(o.e(0,i.height),t.containsPoint(s.gt(o))&&(o.e(i.width,i.height),t.containsPoint(s.gt(o))&&(o.e(i.width,0),t.containsPoint(s.gt(o))&&(n=!0)))),Point.i(o),n}intersectsRect(t,e){if(e===void 0&&(e=this.v,this.angle===0))return t.intersectsRect(this.actualBounds);const i=this.naturalBounds,s=e,n=Point.z(0,0),o=Point.z(0,i.height),r=Point.z(i.width,i.height),l=Point.z(i.width,0);let a=!1;if(t.containsPoint(s.gt(n))||t.containsPoint(s.gt(o))||t.containsPoint(s.gt(r))||t.containsPoint(s.gt(l)))a=!0;else{const h=Rect.z(0,0,i.width,i.height),c=Point.z(t.x,t.y);h.containsPoint(s.Ci(c))?a=!0:(c.e(t.x,t.bottom),h.containsPoint(s.Ci(c))?a=!0:(c.e(t.right,t.bottom),h.containsPoint(s.Ci(c))?a=!0:(c.e(t.right,t.y),h.containsPoint(s.Ci(c))&&(a=!0)))),Point.i(c),Rect.i(h),a||(G.nx(t,n,o)||G.nx(t,o,r)||G.nx(t,r,l)||G.nx(t,l,n))&&(a=!0)}return Point.i(n),Point.i(o),Point.i(r),Point.i(l),a}getDocumentPoint(t,e){if(e===void 0&&(e=new Point),t instanceof Spot){const i=t,s=this.naturalBounds;return e.e(i.x*s.width+i.offsetX,i.y*s.height+i.offsetY),this.Js.gt(e),e}else return e.set(t),this.Js.gt(e),e}getDocumentBounds(t){t===void 0&&(t=new Rect);const e=this.naturalBounds,i=this.Js,s=Point.z(0,0).v(i);return t.e(s.x,s.y,0,0),s.e(e.width,0).v(i),t.re(s.x,s.y,0,0),s.e(e.width,e.height).v(i),t.re(s.x,s.y,0,0),s.e(0,e.height).v(i),t.re(s.x,s.y,0,0),Point.i(s),t}getDocumentAngle(){return this.Js.YF()}getDocumentScale(){if(this.Kp()===!1)return this.Lh;const t=this.it;return this.panel!==null?t*this.panel.getDocumentScale():t}getLocalPoint(t,e){return e===void 0&&(e=new Point),e.h(t),this.Js.Ci(e),e}getNearestIntersectionPoint(t,e,i){return this.mf(t.x,t.y,e.x,e.y,i)}mf(t,e,i,s,n){const o=this.v,r=1/(o.m11*o.m22-o.m12*o.m21),l=o.m22*r,a=-o.m12*r,h=-o.m21*r,c=o.m11*r,f=r*(o.m21*o.dy-o.m22*o.dx),u=r*(o.m12*o.dx-o.m11*o.dy),d=t*l+e*h+f,m=t*a+e*c+u,g=i*l+s*h+f,p=i*a+s*c+u;n.e(0,0);const y=this.naturalBounds,x=G.Cl(0,0,y.width,y.height,d,m,g,p,n);return n.v(o),x}ht(t,e,i,s){if(this.Go()===!1)return;const n=this.sl,o=n.right+n.left,r=n.top+n.bottom;t=Math.max(t-o,0),e=Math.max(e-r,0),i=i||0,s=s||0,i=Math.max(i-o,0),s=Math.max(s-r,0);const l=this.angle;let a=0;const h=this.desiredSize,c=this.Hp();l===90||l===270?(t=isFinite(h.height)?h.height+c:t,e=isFinite(h.width)?h.width+c:e):(t=isFinite(h.width)?h.width+c:t,e=isFinite(h.height)?h.height+c:e);let f=i||0,u=s||0;const d=this instanceof Panel;switch(this.Qs(!0)){case 0:f=0,u=0,d&&(t=1/0,e=1/0);break;case 2:isFinite(t)&&t>i&&(f=t),isFinite(e)&&e>s&&(u=e);break;case 5:isFinite(t)&&t>i&&(f=t),u=0,d&&(e=1/0);break;case 4:isFinite(e)&&e>s&&(u=e),f=0,d&&(t=1/0);break}const g=this.maxSize,p=this.minSize;f>g.width&&p.width<g.width&&(f=g.width),u>g.height&&p.height<g.height&&(u=g.height),i=Math.max(f,p.width),s=Math.max(u,p.height),g.width<i&&(i=Math.min(p.width,i)),g.height<s&&(s=Math.min(p.height,s)),t=Math.min(g.width,t),e=Math.min(g.height,e),t=Math.max(i,t),e=Math.max(s,e),(l===90||l===270)&&(a=t,t=e,e=a,a=i,i=s,s=a),this.ai.ce(),this.xd(t,e,i,s),this.ai.b(),this.ai.isReal()||U.o("Non-real measuredBounds has been set. Object "+this+", measuredBounds: "+this.ai.toString()),this.wi(!1)}xd(t,e,i,s){}_s(){return!1}Ut(t,e,i,s,n){this.pf();const o=Rect.l();o.h(this.De),this.De.ce(),this.as()===!1?this.De.e(t,e,i,s):this.Pa(t,e,i,s),this.De.b(),n===void 0?this.he=null:this.he=n;let r=!1;if(n!==void 0)r=!0;else{let l=this.panel;if(l!==null&&l.ol()&&(l=l.panel),l!==null){const a=l.Ke,h=this.measuredBounds,c=e+h.height,f=t+h.width;if(r=!(0<=t+.05&&f<=a.width+.05&&0<=e+.05&&c<=a.height+.05),this instanceof TextBlock){const u=this.naturalBounds;(this.jp>u.height||this.pe>u.width)&&(r=!0)}}}r?this.n|=256:this.n&=-257,this.De.isReal()||U.o("Non-real actualBounds has been set. Object "+this+", actualBounds: "+this.De.toString()),this.bd(o,this.De),this.ao(!1),Rect.i(o)}Pa(t,e,i,s){}commonArrange(t,e,i,s){if(this.De.e(t,e,i,s),this.desiredSize.isReal())return;const n=this.ai,o=this.sl,r=o.right+o.left,l=o.top+o.bottom,a=n.width+r,h=n.height+l;i+=r,s+=l;let c=this.Qs(!0);switch(a===i&&h===s&&(c=0),c){case 0:(a>i||h>s)&&(this.wi(!0),this.ht(a>i?i:a,h>s?s:h,0,0));break;case 2:this.wi(!0),this.ht(i,s,0,0);break;case 5:this.wi(!0),this.ht(i,h,0,0);break;case 4:this.wi(!0),this.ht(a,s,0,0);break}}bd(t,e){const i=this.part;i!==null&&i.diagram!==null&&((i.selectionObject===this||i.resizeObject===this||i.rotateObject===this)&&i.NN(!0),this.C(),!t.equalsApproxClose(e)&&(i.Sa(),this.qp(i)))}qp(t){this.portId!==null&&(t.NN(!0),t instanceof Node&&t.invalidateConnectedLinks(void 0,this))}get shadowVisible(){return this.w!==null?this.w.Wp:null}set shadowVisible(t){const e=this.shadowVisible;e!==t&&(this.Yt().Wp=t,this.$i(!0),this.C(),this.t("shadowVisible",e,t))}oI(t,e){const i=this.naturalBounds,s=this.wa,n=s.m11,o=s.m21,r=s.dx,l=s.m12,a=s.m22,h=s.dy;let c=0,f=0,u=c,d=f;c=u*n+d*o+r,f=u*l+d*a+h;let m=c,g=f,p=0,y=0;u=i.width+e,d=0,c=u*n+d*o+r,f=u*l+d*a+h;let x=Math.min(m,c),k=Math.min(g,f);p=Math.max(m+p,c)-x,y=Math.max(g+y,f)-k,m=x,g=k,u=i.width+e,d=i.height+e,c=u*n+d*o+r,f=u*l+d*a+h,x=Math.min(m,c),k=Math.min(g,f),p=Math.max(m+p,c)-x,y=Math.max(g+y,f)-k,m=x,g=k,u=0,d=i.height+e,c=u*n+d*o+r,f=u*l+d*a+h,x=Math.min(m,c),k=Math.min(g,f),p=Math.max(m+p,c)-x,y=Math.max(g+y,f)-k,m=x,g=k;const b=t.viewportBounds,P=b.x,S=b.y,L=b.width,C=b.height;return m>L+P||P>p+m||g>C+S||S>y+g}Ge(t,e){if(this.rI(t,e)||!this.visible)return;const i=this.opacity;if(i===0)return;let s=1;i!==1&&(s=t.globalAlpha,t.globalAlpha=s*i);let n="";this.filter!==""&&(n=t.filter,t.filter=this.filter);const o=this.v,r=this.panel;this.Kp()===!0&&this.F1();const l=this.part;let a=!1,h=0;if(l&&e.getRenderingHint("drawShadows")&&(a=l.isShadowed,a)){const g=l.shadowOffset;h=Math.max(g.y,g.x)*e.scale*e.$e}const c=this instanceof Panel&&this.ol(),f=this.De;if(c&&(this.ZT(a,t,!1,r),this.lI(t,e),this.QT(a,t,!1,r),this._T(a,t,!1)),c||!c&&(f.width===0||f.height===0||isNaN(f.x)||isNaN(f.y))){i!==1&&(t.globalAlpha=s),this.filter!==""&&(t.filter=n);return}const u=this._s();if(!e.gh&&u&&this.oI(e,h)){i!==1&&(t.globalAlpha=s),this.filter!==""&&(t.filter=n);return}let d=(this.n&256)!==0;if(t.clipInsteadOfFill&&(d=!1),this instanceof TextBlock&&(t.font=this.font),d){const g=r.Nn()?r.naturalBounds:r.actualBounds;let p=Math.max(f.x,g.x),y=Math.max(f.y,g.y),x=Math.min(f.right,g.right)-p,k=Math.min(f.bottom,g.bottom)-y;const b=this.he;if(b!==null&&(p=b.x,y=b.y,x=b.width,k=b.height),p>f.width+f.x||f.x>g.width+g.x){i!==1&&(t.globalAlpha=s),this.filter!==""&&(t.filter=n);return}t.save(),t.beginPath(),t.rect(p,y,x,k),t.clip()}if(u){if(!l.isVisible()){i!==1&&(t.globalAlpha=s),this.filter!==""&&(t.filter=n);return}if(a){const g=l.shadowOffset;t.shadowsSet(g.x*e.scale*this.scale*e.$e,g.y*e.scale*this.scale*e.$e,l.shadowBlur),t.shadowsOn(),t.shadowColor=l.shadowColor}}const m=this.naturalBounds;if(t.transform(o.m11,o.m12,o.m21,o.m22,o.dx,o.dy),this.ZT(a,t,u,r),this.Lt!==null&&(t.commitTransform(),this.R1(t,m,f)),this.QT(a,t,u,r),this.Ma(t,e),this._T(a,t,u),d&&(t.restore(),t.clearContextCache(this instanceof Panel)),!o.FP()){const g=1/(o.m11*o.m22-o.m12*o.m21);t.transform(o.m22*g,-o.m12*g,-o.m21*g,o.m11*g,g*(o.m21*o.dy-o.m22*o.dx),g*(o.m12*o.dx-o.m11*o.dy))}i!==1&&(t.globalAlpha=s),this.filter!==""&&(t.filter=n)}ZT(t,e,i,s){t&&this.shadowVisible===!0?e.shadowsOn():t&&this.shadowVisible===!1&&e.shadowsOff(),t&&this.O1(s)&&this.shadowVisible===null&&e.shadowsOff()}QT(t,e,i,s){t&&(this.Lt!==null||this.O1(s))?(this.I1(!0),this.shadowVisible===null&&e.shadowsOff()):this.I1(!1)}_T(t,e,i){t&&this.CN()===!0&&e.shadowsOn(),i&&t&&e.shadowsOff()}aI(t,e,i){const s=this.part;let n=!1;s&&t.getRenderingHint("drawShadows")&&(n=s.isShadowed),e.clipInsteadOfFill&&(n=!1),this._s()&&n&&e.shadowsOn(),n&&this.shadowVisible===!0?e.shadowsOn():n&&this.shadowVisible===!1&&e.shadowsOff();const o=this.panel;if(n&&this.O1(o)&&this.shadowVisible===null&&e.shadowsOff(),e.rl){const r=t.computePixelRatio(),l=`drop-shadow(${e.shadowOffsetX/r}px ${e.shadowOffsetY/r}px ${e.shadowBlur/r/2}px ${e.shadowColor})`;this.background!==null&&i.Lt.setAttributeNS(null,"filter",l)}return n&&(this.Lt!==null||this.O1(o))?(this.I1(!0),this.shadowVisible===null&&e.shadowsOff()):this.I1(!1),n}hI(t,e,i,s){if(i.rl){const n=e.computePixelRatio(),o=`drop-shadow(${i.shadowOffsetX/n}px ${i.shadowOffsetY/n}px ${i.shadowBlur/n/2}px ${i.shadowColor})`;this.LN(t,o)}s&&this.CN()===!0&&i.shadowsOn(),this._s()&&i.shadowsOff()}O1(t){return t===null?!1:(t.ol()&&(t=t.panel),t.CN()||(t.type===Panel.Auto||t.type===Panel.Spot)&&t.findMainElement()!==this)}LN(t,e){}R1(t,e,i){const s=this.Hp(),n=e.x,o=e.y,r=e.width+s,l=e.height+s;this.kn(t,this.Lt,!0,!1,e,i),this.Lt instanceof Brush&&this.Lt.type===3?(t.beginPath(),t.rect(n-s/2,o-s/2,r,l),t.fillContext(this.Lt,!1,null)):t.fillRect(n-s/2,o-s/2,r,l)}tD(t,e){let i=t.cI(this);const s=t.xa!==null?t.xa:t.svg;if(s!==null&&i!==-1)if(i===0)this.eD(t,e,s);else{for(;i!==0&&!t.elt(i-1).isVisibleObject();)i--;if(i===0)this.eD(t,e,s);else{const n=t.elt(i-1).svg;n!==null?n.after(e):s.appendChild(e)}}}eD(t,e,i){if(i.Lt)i.Lt.after(e);else if(t.type===Panel.Table){const s=i.getElementsByClassName("gojs-ts"),n=s.length!==0?s[0]:null;n!==null&&n.after(e)}else i.prepend(e)}rI(t,e){if(!(t instanceof SVGContext))return!1;if(!this.visible||this.opacity===0)return this.svg!==null&&this.svg.parentNode!==null&&this.svg.remove(),!0;const i=this.De;if(this._s()&&(!this.isVisible()||i.width===0||i.height===0||isNaN(i.x)||isNaN(i.y)))return this.svg!==null&&this.svg.parentNode!==null&&this.svg.remove(),!0;const s=this.panel,n=this.kd(t);if(this.yf(t,e,n))return this.iD(this.svg),this.svg.parentElement!==null?(this._s()&&(t.lastDrawnPart=this.svg),!0):(this._s()?(t.lastDrawnPart!==null?t.lastDrawnPart.after(this.svg):t.diagramGroup.prepend(this.svg),t.lastDrawnPart=this.svg):s&&this.tD(s,this.svg),!0);if(this.$i(!1),this._s()&&this.isShadowed){const m=this.shadowOffset;t.shadowsSet(m.x*e.scale*this.scale*e.$e,m.y*e.scale*this.scale*e.$e,this.shadowBlur),t.shadowsOn(),t.shadowColor=this.shadowColor}this instanceof TextBlock&&(t.font=this.font),t.currentElement=null;const o=this.v,r=this instanceof Panel,l=this instanceof Panel?this.ol():!1,a=this.svg;if(this.Kp()===!0&&this.F1(),t.setCurrentTransform(1,0,0,1,0,0),t.outerGroup=!1,n)if(t.outerGroup=!0,r&&l)t.newGroup(1,0,0,1,0,0),this.svg=t.lastCreatedElement;else if(r&&this.isClipping){const m=this.findMainElement();let g=0,p=0;m!==null&&(g=m.actualBounds.x,p=m.actualBounds.y),t.newGroup(o.m11,o.m12,o.m21,o.m22,o.dx+g,o.dy+p),this.svg=t.lastCreatedElement,m!==null&&t.createOrUpdateClipGroup(this,m.actualBounds),t.currentElement=t.lastCreatedElement}else r?(t.newGroup(o.m11,o.m12,o.m21,o.m22,o.dx,o.dy),this.svg=t.lastCreatedElement):t.newGroup(1,0,0,1,0,0);const h=this.naturalBounds;r||t.setCurrentTransform(o.m11,o.m12,o.m21,o.m22,o.dx,o.dy),this.background!==null&&(r?(l&&t.setCurrentTransform(o.m11,o.m12,o.m21,o.m22,o.dx,o.dy),this.R1(t,h,i),l&&t.setCurrentTransform(1,0,0,1,0,0)):(t.setCurrentTransform(o.m11,o.m12,o.m21,o.m22,o.dx,o.dy),this.R1(t,h,i)),t.currentElement.Lt=t.lastCreatedElement,t.currentElement.prepend(t.lastCreatedElement));const c=this.aI(e,t,t.currentElement);this.Ma(t,e),r&&t.endGroup(),t.outerGroup&&t.endGroup();const f=t.surface.fd,u=r?this.svg:t.currentElement;if(a!==null&&a.parentNode!==null&&u!==a&&(this.panel===null||a.parentNode===this.panel.svg)){const m=this.svg.getAttribute("filter");return m!==null&&u.setAttribute("filter",m),this.filter!==""&&u.setAttributeNS(null,"filter",this.filter),a.replaceWith(u),this.svg=u,u!==null&&this.Jp(t,s,i,u),!0}if(this.svg=u,f!==null&&u===null&&t.dummyGroup(),u===null)return!0;this.Jp(t,s,i,u),this.hI(u,e,t,c);const d=this._s()?this.opacity*t.globalAlpha:this.opacity;if(d!==1&&u.setAttributeNS(null,"opacity",d.toString()),this.filter!==""&&u.setAttributeNS(null,"filter",this.filter),this._s()){if(a!==null&&u!==a&&a.parentNode===t.diagramGroup){const m=a.getAttribute("filter");m!==null&&u.setAttribute("filter",m),a.replaceWith(u)}else t.lastDrawnPart?t.lastDrawnPart.after(u):t.diagramGroup.prepend(u);t.lastDrawnPart=u}else s!==null&&this.tD(s,u);return f!==null&&f(this,u),this.iD(u),!0}iD(t){const e=this,i=t.dataset;e instanceof GraphObject&&(e.portId!==null&&(i.portId=e.portId),e instanceof Panel&&(isNaN(e.itemIndex)||(i.itemIndex=e.itemIndex.toString()),e instanceof Part&&(i.className=U.Hn(e),e.key!==void 0&&(i.key=e.key.toString()),e.containingGroup!==null&&(i.group=e.containingGroup.key.toString()),e instanceof Link&&(e.fromNode!==null&&e.fromNode.key!==void 0&&(i.fromKey=e.fromNode.key.toString()),e.fromPortId!==""&&(i.fromPortId=e.fromPortId),e.toNode!==null&&e.toNode.key!==void 0&&(i.toKey=e.toNode.key.toString()),e.toPortId!==""&&(i.toPortId=e.toPortId)))))}Jp(t,e,i,s){let n=(this.n&256)!==0;if(t.clipInsteadOfFill&&(n=!1),!n){s.removeAttributeNS(null,"clip-path");return}const o=e.Nn()?e.naturalBounds:e.actualBounds;let r=Math.max(i.x,o.x),l=Math.max(i.y,o.y),a=Math.min(i.right,o.right)-r,h=Math.min(i.bottom,o.bottom)-l;const c=this.he;c!==null&&(r=c.x,l=c.y,a=c.width,h=c.height);const f=Rect.z(r,l,Math.max(a,0),Math.max(h,0));if(this instanceof Panel){const u=Transform.l();u.set(this.v),u.tx(),u.im(f),Transform.i(u)}s.setAttributeNS(null,"clip-path",`path('      M ${f.x},${f.y}       L ${f.width+f.x} ${f.y}       L ${f.width+f.x} ${f.height+f.y}       L ${f.x} ${f.height+f.y} z') view-box`),Rect.i(f)}fI(){if(this.svg===null)return;const t=this.svg.innerHTML.match(/url\(#((CLIP|GRAD).+?)\)/g),e=this.svg.ownerDocument;if(t!==null)for(const i of t){const s=e.getElementById(i.split("#")[1].slice(0,-1));s!==null&&s.remove()}this.svg.remove()}lI(t,e){const i=this.De,s=this.Ke,n=this.Lt;n!==null&&t.commitTransform(),n!==null&&(this.kn(t,n,!0,!1,s,i),n instanceof Brush&&n.type===3?(t.beginPath(),t.rect(i.x,i.y,i.width,i.height),t.fillContext(n,!1,null)):t.fillRect(i.x,i.y,i.width,i.height)),this.Ma(t,e)}Ma(t,e){}wf(){this.$i(!0)}yf(t,e,i){const s=this.svg;if(this.uI()){if(this.wf(),this.$i(!1),s===null)return!1;const c=s.getAttribute("clip-path");if(c!==null&&c.includes("url")){const u=t.svg.getElementById(c.split("#")[1].slice(0,-1));u!==null&&u.remove()}return s.getAttribute("filter")&&s.removeAttribute("filter"),!1}if(s===null)return!1;if(!this.visible)return s.remove(),!1;if(s.nodeName!=="g"&&i||s.nodeName==="g"&&!i)return!1;const n=this.v,o="matrix("+n.m11+", "+n.m12+", "+n.m21+", "+n.m22+", "+n.dx+", "+n.dy+")",r=this instanceof Panel,l=r?this.ol():!1;if(!(r&&l))if(this instanceof Picture){const c=this.E1;t.setCurrentTransform(n.m11,n.m12,n.m21,n.m22,n.dx,n.dy),c!==null&&t.amendImageTransform(c[0],c[1],c[2],c[3],c[4],c[5],c[6],c[7]),i?s.lastElementChild.setAttributeNS(null,"transform",t.getCurrentTransform()):s.setAttributeNS(null,"transform",t.getCurrentTransform())}else if(i&&!r)if(this instanceof Shape){const c=s.getElementsByTagName("path");for(let f=0;f<c.length;f++)c[f].setAttributeNS(null,"transform",o)}else if(this instanceof TextBlock){const c=s.getElementsByTagName("text"),f=typeof this.stroke=="string"?this.stroke:null;for(let u=0;u<c.length;u++)c[u].setAttributeNS(null,"transform",o),f&&c[u].setAttributeNS(null,"fill",f)}else(s.lastElementChild||s).setAttributeNS(null,"transform",o);else if(r&&this.isClipping&&this.xa){const c=this.findMainElement(),f=c!==null?c.actualBounds.x:0,u=c!==null?c.actualBounds.y:0;this.xa.setAttributeNS(null,"transform","matrix(1,0,0,1,"+-f+", "+-u+")"),s.setAttributeNS(null,"transform","matrix("+n.m11+", "+n.m12+", "+n.m21+", "+n.m22+", "+(n.dx+f)+", "+(n.dy+u)+")")}else s.setAttributeNS(null,"transform",o);const a=this._s()?this.opacity*t.globalAlpha:this.opacity;a===1?s.removeAttribute("opacity"):s.setAttributeNS(null,"opacity",a.toString()),t.setCurrentTransform(1,0,0,1,0,0);const h=this.xa?this.xa:this.v1;if(this.background!==null||h.Lt!==void 0){const c=h.Lt;if(this.background===null)t.removeOldGradient(this,h.Lt,"fill"),h.Lt.remove(),h.Lt=void 0;else{if((l||i&&!(this instanceof Panel))&&t.setCurrentTransform(n.m11,n.m12,n.m21,n.m22,n.dx,n.dy),this.R1(t,this.naturalBounds,this.actualBounds),h.Lt){t.removeOldGradient(this,h.Lt,"fill");const f=h.Lt.getAttribute("filter");f!==null&&t.lastCreatedElement.setAttribute("filter",f),h.Lt.replaceWith(t.lastCreatedElement)}else h.prepend(t.lastCreatedElement);h.Lt=t.lastCreatedElement}c&&t.removeOldGradient(this,c,"fill")}return this.Jp(t,this.panel,this.actualBounds,s),!0}kd(t){if(this.background!==null)return!0;let e=(this.n&256)!==0;return t.clipInsteadOfFill&&(e=!1),!!e}static UU(t,e,i,s,n,o,r){let l=.001;const a=o.length;t.moveTo(e,i);let h=s-e;const c=n-i;h===0&&(h=.001);const f=c/h;let u=Math.sqrt(h*h+c*c),d=0,m=!0;l=o[d%a];let g=r!==0;for(;u>=.1;){if(g){for(l=o[d++%a],l-=r;l<0;)l+=o[d++%a],m=!m;g=!1}else l=o[d++%a];l>u&&(l=u);let p=Math.sqrt(l*l/(1+f*f));h<0&&(p=-p),e+=p,i+=f*p,m?t.lineTo(e,i):t.moveTo(e,i),u-=l,m=!m}}kn(t,e,i,s,n,o){let r=1,l=1;if(typeof e=="string"){i?t.fillStyle=e:t.strokeStyle=e;return}else if(e.type===1){i?t.fillStyle=e.color:t.strokeStyle=e.color;return}let a;const h=this.Hp();r=n.width,l=n.height,s?(r=o.width,l=o.height):i||(r+=h,l+=h);const c=t instanceof CanvasSurfaceContext;if(c&&e.Cn&&(e.type===4||e.xf===r&&e.U1===l))a=e.Cn;else{let f=0,u=0,d=0,m=0,g=0,p=0,y=0,x=0;if(s?(y=o.x,x=o.y):i||(y-=h/2,x-=h/2),f=e.start.x*r+e.start.offsetX+y,u=e.start.y*l+e.start.offsetY+x,d=e.end.x*r+e.end.offsetX+y,m=e.end.y*l+e.end.offsetY+x,e.type===2)a=t.createLinearGradient(f,u,d,m);else if(e.type===3)p=isNaN(e.endRadius)?Math.max(r,l)/2:e.endRadius,isNaN(e.startRadius)?(g=0,p=Math.max(r,l)/2):g=e.startRadius,a=t.createRadialGradient(f,u,g,d,m,p);else if(e.type===4)try{a=t.createPattern(e.pattern,"repeat")}catch{a=null}else U.si(e.type,"Brush type");if(e.type!==4){const k=e.colorStops;if(k!==null){const b=k.iterator;for(;b.next();)a.addColorStop(b.key,b.value)}}if(c&&(e.Cn=a,a!==null&&(e.xf=r,e.U1=l),a===null&&e.type===4&&e.xf!==-1)){e.xf=-1;const k=this.diagram;k!==null&&e.xf===-1&&U.dn(()=>{k.redraw()},600)}}i?t.fillStyle=a:t.strokeStyle=a}isContainedBy(t){return t instanceof Panel?this.dI(this,t):!1}dI(t,e){if(t===e||e===null)return!1;let i=t.panel;for(;i!==null;){if(i===e)return!0;i=i.panel}return!1}isVisibleObject(){if(!this.visible)return!1;const t=this.panel;return t!==null?t.isVisibleObject():!0}isEnabledObject(){let t=this instanceof Panel?this:this.panel;for(;t!==null&&t.isEnabled;)t=t.panel;return t===null}get enabledChanged(){return this.w!==null?this.w.$p:null}set enabledChanged(t){const e=this.enabledChanged;e!==t&&(t!==null&&U.S(t,GraphObject,"enabledChanged"),this.Yt().$p=t,this.t("enabledChanged",e,t))}F1(){if(this.V1()===!0){const t=this.il;if(t.Ue(),!this.De.isReal()||!this.ai.isReal()){this.Pd(!1);return}if(t.Gs(this.De.x-this.ai.x,this.De.y-this.ai.y),this.scale!==1||this.angle!==0){const e=this.naturalBounds;this.Yp(t,e.x,e.y,e.width,e.height)}this.Pd(!1),this.Ih(!0)}if(this.Kp()===!0){const t=this.panel;if(t===null)this.wa.set(this.il),this.Lh=this.scale;else if(t.Js!==null){const e=this.wa;e.Ue(),t.Nn()?e.bc(t.wa):t.panel!==null&&e.bc(t.panel.wa),e.bc(this.il),this.Lh=this.scale*t.Lh}this.Ih(!1)}}Yp(t,e,i,s,n){if(this.it!==1&&t.it(this.it),this.Xt===0)return;const o=Point.l();o.setSpot(e,i,s,n,Spot.Center),t.ks(this.Xt,o.x,o.y),Point.i(o)}c(t){if(this.Go())return;t===void 0&&(t=!1),this.wi(!0),this.ao(!0);const e=this.panel;e!==null&&!t&&e.c()}bf(){this.Go()||(this.wi(!0),this.ao(!0))}kf(t){if(this.as())return;const e=this.panel;!t&&e!==null&&e.c(),this.ao(!0)}pf(){this.V1()===!1&&(this.Pd(!0),this.Ih(!0))}AN(){this.Ih(!0)}C(){const t=this.part;t!==null&&t.C()}Qs(t){const e=this.stretch,i=this.panel;if(i===null)return this.qo(e===1?0:e,t);if(i.type===Panel.Table)return this.Zp(i.getRowDefinition(this.row),i.getColumnDefinition(this.column),t);if(i.type===Panel.Auto&&i.findMainElement()===this)return this.qo(2,t);if(e===1){if(i.type===Panel.Spot&&i.findMainElement()===this)return this.qo(2,t);const s=i.defaultStretch;return s===1?this.qo(0,t):this.qo(s,t)}return this.qo(e,t)}Zp(t,e,i){const s=this.stretch;if(s!==1)return this.qo(s,i);let n=null,o=null;switch(t.stretch){case 1:case 5:break;case 4:o=!0;break;case 2:o=!0;break}switch(e.stretch){case 1:case 4:break;case 5:n=!0;break;case 2:n=!0;break}const r=this.panel.defaultStretch;return n===null&&(n=r===5||r===2),o===null&&(o=r===4||r===2),n===!0&&o===!0?this.qo(2,i):n===!0?this.qo(5,i):o===!0?this.qo(4,i):this.qo(0,i)}qo(t,e){if(e)return t;if(t===0)return 0;const i=this.desiredSize;if(i.isReal())return 0;const s=!isNaN(i.width),n=!isNaN(i.height),o=this.angle;if(s)if(o!==90&&o!==270){if(t===5)return 0;if(t===2)return 4}else{if(t===4)return 0;if(t===2)return 5}if(n)if(o!==90&&o!==270){if(t===4)return 0;if(t===2)return 5}else{if(t===5)return 0;if(t===2)return 4}return t}get segmentOrientation(){return this.Ot!==null?this.Ot.Qp:0}set segmentOrientation(t){const e=this.segmentOrientation;e!==t&&(this.Ot===null&&(this.Ot=new LinkElementSettings),this.Ot.Qp=t,this.c(),this.t("segmentOrientation",e,t),t===0&&(this.angle=0))}gI(){this.segmentOrientation=21}get segmentIndex(){return this.Ot!==null?this.Ot._p:-1/0}set segmentIndex(t){t=Math.round(t);const e=this.segmentIndex;e!==t&&(this.Ot===null&&(this.Ot=new LinkElementSettings),this.Ot._p=t,this.c(),this.t("segmentIndex",e,t))}get segmentFraction(){return this.Ot!==null?this.Ot.t0:0}set segmentFraction(t){t<0?t=0:t>1&&(t=1);const e=this.segmentFraction;e!==t&&(this.Ot===null&&(this.Ot=new LinkElementSettings),this.Ot.t0=t,this.c(),this.t("segmentFraction",e,t))}get segmentOffset(){return this.Ot!==null?this.Ot.e0:Point.gn}set segmentOffset(t){const e=this.segmentOffset;e.equals(t)||(t=t.N(),this.Ot===null&&(this.Ot=new LinkElementSettings),this.Ot.e0=t,this.c(),this.t("segmentOffset",e,t))}get stretch(){return this.w!==null?this.w.ho:1}set stretch(t){const e=this.stretch;e!==t&&(this.Yt().ho=t,this.c(),this.t("stretch",e,t))}get name(){return this.w!==null?this.w.Pt:""}set name(t){const e=this.name;e!==t&&(this.Yt().Pt=t,this.part!==null&&this.part.i0(),this.t("name",e,t))}get opacity(){return this.Zt}set opacity(t){t<0?t=0:t>1&&(t=1);const e=this.opacity;if(e!==t){this.Zt=t,this.t("opacity",e,t);const i=this.diagram,s=this.part;i!==null&&s!==null&&i.C(s.lh(s.actualBounds))}}get filter(){return this.Xp}set filter(t){const e=this.filter;if(e!==t){this.Xp=t,this.$i(!0),this.t("filter",e,t);const i=this.diagram,s=this.part;i!==null&&s!==null&&i.C(s.lh(s.actualBounds))}}get visible(){return(this.n&1)!==0}set visible(t){const e=(this.n&1)!==0;if(e!==t){this.n=this.n^1,this.wf(),this.t("visible",e,t);const i=this.panel;i!==null?i.c():this._s()&&this.Xe(t),this.C(),this.sD()}}get pickable(){return(this.n&2)!==0}set pickable(t){const e=(this.n&2)!==0;e!==t&&(this.n=this.n^2,this.t("pickable",e,t))}get fromLinkableDuplicates(){return(this.n&4)!==0}set fromLinkableDuplicates(t){const e=(this.n&4)!==0;e!==t&&(this.n=this.n^4,this.t("fromLinkableDuplicates",e,t))}get fromLinkableSelfNode(){return(this.n&8)!==0}set fromLinkableSelfNode(t){const e=(this.n&8)!==0;e!==t&&(this.n=this.n^8,this.t("fromLinkableSelfNode",e,t))}get toLinkableDuplicates(){return(this.n&16)!==0}set toLinkableDuplicates(t){const e=(this.n&16)!==0;e!==t&&(this.n=this.n^16,this.t("toLinkableDuplicates",e,t))}get toLinkableSelfNode(){return(this.n&32)!==0}set toLinkableSelfNode(t){const e=(this.n&32)!==0;e!==t&&(this.n=this.n^32,this.t("toLinkableSelfNode",e,t))}get isPanelMain(){return(this.n&64)!==0}set isPanelMain(t){const e=(this.n&64)!==0;e!==t&&(this.n=this.n^64,this.c(),this.t("isPanelMain",e,t))}get isActionable(){return(this.n&128)!==0}set isActionable(t){const e=(this.n&128)!==0;e!==t&&(this.n=this.n^128,this.t("isActionable",e,t))}get background(){return this.Lt}set background(t){const e=this.background;e!==t&&(t!==null&&Brush.Sd(t,"GraphObject.background"),t instanceof Brush&&t.b(),this.Lt=t,this.C(),this.t("background",e,t))}CN(){return(this.n&512)!==0}I1(t){t?this.n|=512:this.n&=-513}gf(){return(this.n&1024)!==0}TN(t){t?this.n|=1024:this.n&=-1025}V1(){return(this.n&2048)!==0}Pd(t){t?this.n|=2048:this.n&=-2049}Kp(){return(this.n&4096)!==0}Ih(t){t?this.n|=4096:this.n&=-4097}Go(){return(this.n&8192)!==0}wi(t){t?this.n|=8192:this.n&=-8193}as(){return(this.n&16384)!==0}ao(t){t?this.n|=16384:this.n&=-16385}uI(){return(this.n&32768)!==0}$i(t){t?this.n|=32768:this.n&=-32769}get part(){if(this._s())return this;if(this.nl!==null)return this.nl;let t=this;for(t=t.panel;t;){if(t instanceof Part)return this.nl=t,t;t=t.panel}return null}get svg(){return this.v1}set svg(t){this.v1=t}qc(){this.svg=null}get panel(){return this.Zs}Eh(t){this.Zs=t,this.svg!==null&&this.svg.remove()}get layer(){const t=this.part;return t!==null?t.layer:null}get diagram(){const t=this.part;return t!==null?t.diagram:null}get position(){return this.ct}set position(t){const e=t.x,i=t.y,s=this.position,n=s.x,o=s.y;n!==e&&(!isNaN(n)||!isNaN(e))||o!==i&&(!isNaN(o)||!isNaN(i))?(t=t.copy(),this.DN(t,n,o)&&this.t("position",new Point(n,o),t.copy())):this.vN()}vN(){}DN(t,e,i){return this.ct=t,this.kf(),!0}Ec(t,e,i){this.ct.x===t&&this.ct.y===e||(this.ct.e(t,e),this.pf())}get actualBounds(){return this.De}get scale(){return this.it}set scale(t){const e=this.scale;e!==t&&(t<=0&&U.o("GraphObject.scale for "+this+" must be greater than zero, not: "+t),this.it=t,this.c(),this.t("scale",e,t))}get angle(){return this.Xt}set angle(t){const e=this.angle;if(e!==t){if(t=t%360,t<0&&(t+=360),e===t)return;this.Xt=t,this.sD(),this.c(),this.t("angle",e,t)}}get desiredSize(){return this.cs}set desiredSize(t){const e=t.width,i=t.height,s=this.desiredSize,n=s.width,o=s.height;if((n!==e&&(!isNaN(n)||!isNaN(e))||o!==i&&(!isNaN(o)||!isNaN(i)))&&(t=t.N(),this.cs=t,this.c(),this instanceof Shape&&this.Ze(),this.t("desiredSize",s,t),this.gf())){const r=this.part;r!==null&&(this.Oh(r,"width"),this.Oh(r,"height"))}}get width(){return this.cs.width}set width(t){const e=this.cs.width;if(e!==t&&(!isNaN(e)||!isNaN(t))){const i=this.cs,s=new Size(t,this.cs.height).b();if(this.cs=s,this.c(),this instanceof Shape&&this.Ze(),this.t("desiredSize",i,s),this.gf()){const n=this.part;n!==null&&this.Oh(n,"width")}}}get height(){return this.cs.height}set height(t){const e=this.cs.height;if(e!==t&&(!isNaN(e)||!isNaN(t))){const i=this.cs,s=new Size(this.cs.width,t).b();if(this.cs=s,this.c(),this instanceof Shape&&this.Ze(),this.t("desiredSize",i,s),this.gf()){const n=this.part;n!==null&&this.Oh(n,"height")}}}get minSize(){return this.w!==null?this.w.Cr:Size.xc}set minSize(t){const e=this.minSize;e.equals(t)||(t=t.copy(),isNaN(t.width)&&(t.width=0),isNaN(t.height)&&(t.height=0),t.b(),this.Yt().Cr=t,this.c(),this.t("minSize",e,t))}get maxSize(){return this.w!==null?this.w.Lr:Size.TP}set maxSize(t){const e=this.maxSize;e.equals(t)||(t=t.copy(),isNaN(t.width)&&(t.width=1/0),isNaN(t.height)&&(t.height=1/0),t.b(),this.Yt().Lr=t,this.c(),this.t("maxSize",e,t))}get measuredBounds(){return this.ai}get naturalBounds(){return this.Ke}Hp(){return 0}get margin(){return this.sl}set margin(t){typeof t=="number"&&(t=new Margin(t));const e=this.sl;e.equals(t)||(t=t.N(),this.sl=t,this.c(),this.t("margin",e,t))}get v(){return this.V1()===!0&&this.F1(),this.il}get Js(){return this.Kp()===!0&&this.F1(),this.wa}trigger(t,e,i){let s=null;return typeof t=="string"?s=new AnimationTrigger(t,e,i):s=t,s.Ti=this,this.Ds===null&&(this.Ds=new GMap),this.Ds.set(s.propertyName,s),this}get Ds(){return this.w!==null?this.w.Ds:null}set Ds(t){this.Ds!==t&&(this.Yt().Ds=t)}get Nr(){return this.w!==null?this.w.Nr:0}set Nr(t){this.Nr!==t&&(this.Yt().Nr=t)}get alignment(){return this.de}set alignment(t){const e=this.alignment;e.equals(t)||(t.isNoSpot()&&!t.isDefault()&&U.o("GraphObject.alignment for "+this+" must be a real Spot or Spot.Default, not: "+t),t=t.N(),this.de=t,this.kf(),this.t("alignment",e,t))}get column(){return this.pa}set column(t){t=Math.round(t);const e=this.column;e!==t&&(t<0&&U.J(t,">= 0",GraphObject,"column"),this.pa=t,this.c(),this.t("column",e,t),this.svg!==null&&this.svg.remove())}get columnSpan(){return this.w!==null?this.w.s0:1}set columnSpan(t){t=Math.round(t);const e=this.columnSpan;e!==t&&(t<1&&U.J(t,">= 1",GraphObject,"columnSpan"),this.Yt().s0=t,this.c(),this.t("columnSpan",e,t))}get row(){return this.zp}set row(t){t=Math.round(t);const e=this.row;e!==t&&(t<0&&U.J(t,">= 0",GraphObject,"row"),this.zp=t,this.c(),this.t("row",e,t),this.svg!==null&&this.svg.remove())}get rowSpan(){return this.w!==null?this.w.o0:1}set rowSpan(t){t=Math.round(t);const e=this.rowSpan;e!==t&&(t<1&&U.J(t,">= 1",GraphObject,"rowSpan"),this.Yt().o0=t,this.c(),this.t("rowSpan",e,t))}get spanAllocation(){return this.w!==null?this.w.r0:null}set spanAllocation(t){const e=this.spanAllocation;e!==t&&(t!==null&&U.S(t,GraphObject,"spanAllocation"),this.Yt().r0=t,this.c(),this.t("spanAllocation",e,t))}get alignmentFocus(){return this.yd}set alignmentFocus(t){const e=this.alignmentFocus;e.equals(t)||(t=t.N(),this.yd=t,this.c(),this.t("alignmentFocus",e,t))}get portId(){return this.Bp}set portId(t){const e=this.portId;if(e!==t){const i=this.part;i!==null&&!(i instanceof Node)&&U.o("Cannot set portID on a Link: "+t);const s=i;e!==null&&s!==null&&s.FN(this),this.Bp=t,t!==null&&s!==null&&(s.Ln=!0,s.nD(this)),this.t("portId",e,t)}}Uh(){const t=this.part;if(t instanceof Node&&(this.portId!==null||this===t.port)){const e=t.diagram;e!==null&&!e.undoManager.isUndoingRedoing&&t.invalidateConnectedLinks(void 0,this)}}sD(){const t=this.diagram;t===null||t.undoManager.isUndoingRedoing||(this instanceof Panel?this instanceof Node?this.invalidateConnectedLinks():this.walkVisualTreeFrom(this,e=>{e.Uh()}):this.Uh())}get toSpot(){return this.ft!==null?this.ft.Th:Spot.None}set toSpot(t){const e=this.toSpot;e.equals(t)||(t=t.N(),this.Ji().Th=t,this.t("toSpot",e,t),this.Uh())}get toEndSegmentLength(){return this.ft!==null?this.ft.vh:10}set toEndSegmentLength(t){const e=this.toEndSegmentLength;e!==t&&(t<0&&U.J(t,">= 0",GraphObject,"toEndSegmentLength"),this.Ji().vh=t,this.t("toEndSegmentLength",e,t),this.Uh())}get toShortLength(){return this.ft!==null?this.ft.Rh:0}set toShortLength(t){const e=this.toShortLength;e!==t&&(this.Ji().Rh=t,this.t("toShortLength",e,t),this.Uh())}get toLinkable(){return this.ft!==null?this.ft.l0:null}set toLinkable(t){const e=this.toLinkable;e!==t&&(this.Ji().l0=t,this.t("toLinkable",e,t))}get toMaxLinks(){return this.ft!==null?this.ft.a0:1/0}set toMaxLinks(t){const e=this.toMaxLinks;e!==t&&(t<0&&U.J(t,">= 0",GraphObject,"toMaxLinks"),this.Ji().a0=t,this.t("toMaxLinks",e,t))}get fromSpot(){return this.ft!==null?this.ft.Ah:Spot.None}set fromSpot(t){const e=this.fromSpot;e.equals(t)||(t=t.N(),this.Ji().Ah=t,this.t("fromSpot",e,t),this.Uh())}get fromEndSegmentLength(){return this.ft!==null?this.ft.Dh:10}set fromEndSegmentLength(t){const e=this.fromEndSegmentLength;e!==t&&(t<0&&U.J(t,">= 0",GraphObject,"fromEndSegmentLength"),this.Ji().Dh=t,this.t("fromEndSegmentLength",e,t),this.Uh())}get fromShortLength(){return this.ft!==null?this.ft.Fh:0}set fromShortLength(t){const e=this.fromShortLength;e!==t&&(this.Ji().Fh=t,this.t("fromShortLength",e,t),this.Uh())}get fromLinkable(){return this.ft!==null?this.ft.h0:null}set fromLinkable(t){const e=this.fromLinkable;e!==t&&(this.Ji().h0=t,this.t("fromLinkable",e,t))}get fromMaxLinks(){return this.ft!==null?this.ft.c0:1/0}set fromMaxLinks(t){const e=this.fromMaxLinks;e!==t&&(t<0&&U.J(t,">= 0",GraphObject,"fromMaxLinks"),this.Ji().c0=t,this.t("fromMaxLinks",e,t))}get cursor(){return this.w!==null?this.w.Il:""}set cursor(t){const e=this.cursor;e!==t&&(U.s(t,"string",GraphObject,"cursor"),this.Yt().Il=t,this.t("cursor",e,t))}get click(){return this.w!==null?this.w.Ur:null}set click(t){const e=this.click;e!==t&&(t!==null&&U.S(t,GraphObject,"click"),this.Yt().Ur=t,this.t("click",e,t))}get doubleClick(){return this.w!==null?this.w.Vr:null}set doubleClick(t){const e=this.doubleClick;e!==t&&(t!==null&&U.S(t,GraphObject,"doubleClick"),this.Yt().Vr=t,this.t("doubleClick",e,t))}get contextClick(){return this.w!==null?this.w.Br:null}set contextClick(t){const e=this.contextClick;e!==t&&(t!==null&&U.S(t,GraphObject,"contextClick"),this.Yt().Br=t,this.t("contextClick",e,t))}get mouseEnter(){return this.w!==null?this.w.Kr:null}set mouseEnter(t){const e=this.mouseEnter;e!==t&&(t!==null&&U.S(t,GraphObject,"mouseEnter"),this.Yt().Kr=t,this.t("mouseEnter",e,t))}get mouseLeave(){return this.w!==null?this.w.Hr:null}set mouseLeave(t){const e=this.mouseLeave;e!==t&&(t!==null&&U.S(t,GraphObject,"mouseLeave"),this.Yt().Hr=t,this.t("mouseLeave",e,t))}get mouseOver(){return this.w!==null?this.w.zr:null}set mouseOver(t){const e=this.mouseOver;e!==t&&(t!==null&&U.S(t,GraphObject,"mouseOver"),this.Yt().zr=t,this.t("mouseOver",e,t))}get mouseHover(){return this.w!==null?this.w.Xr:null}set mouseHover(t){const e=this.mouseHover;e!==t&&(t!==null&&U.S(t,GraphObject,"mouseHover"),this.Yt().Xr=t,this.t("mouseHover",e,t))}get mouseHold(){return this.w!==null?this.w.Gr:null}set mouseHold(t){const e=this.mouseHold;e!==t&&(t!==null&&U.S(t,GraphObject,"mouseHold"),this.Yt().Gr=t,this.t("mouseHold",e,t))}get mouseDragEnter(){return this.w!==null?this.w.f0:null}set mouseDragEnter(t){const e=this.mouseDragEnter;e!==t&&(t!==null&&U.S(t,GraphObject,"mouseDragEnter"),this.Yt().f0=t,this.t("mouseDragEnter",e,t))}get mouseDragLeave(){return this.w!==null?this.w.u0:null}set mouseDragLeave(t){const e=this.mouseDragLeave;e!==t&&(t!==null&&U.S(t,GraphObject,"mouseDragLeave"),this.Yt().u0=t,this.t("mouseDragLeave",e,t))}get mouseDrop(){return this.w!==null?this.w.Yr:null}set mouseDrop(t){const e=this.mouseDrop;e!==t&&(t!==null&&U.S(t,GraphObject,"mouseDrop"),this.Yt().Yr=t,this.t("mouseDrop",e,t))}get actionDown(){return this.w!==null?this.w.d0:null}set actionDown(t){const e=this.actionDown;e!==t&&(t!==null&&U.S(t,GraphObject,"actionDown"),this.Yt().d0=t,this.t("actionDown",e,t))}get actionMove(){return this.w!==null?this.w.g0:null}set actionMove(t){const e=this.actionMove;e!==t&&(t!==null&&U.S(t,GraphObject,"actionMove"),this.Yt().g0=t,this.t("actionMove",e,t))}get actionUp(){return this.w!==null?this.w.m0:null}set actionUp(t){const e=this.actionUp;e!==t&&(t!==null&&U.S(t,GraphObject,"actionUp"),this.Yt().m0=t,this.t("actionUp",e,t))}get actionCancel(){return this.w!==null?this.w.p0:null}set actionCancel(t){const e=this.actionCancel;e!==t&&(t!==null&&U.S(t,GraphObject,"actionCancel"),this.Yt().p0=t,this.t("actionCancel",e,t))}get toolTip(){return this.w!==null?this.w.jr:null}set toolTip(t){const e=this.toolTip;e!==t&&(this.Yt().jr=t,this.t("toolTip",e,t))}get contextMenu(){return this.w!==null?this.w.qr:null}set contextMenu(t){const e=this.contextMenu;e!==t&&(this.Yt().qr=t,this.t("contextMenu",e,t))}findBindingPanel(){let t=this instanceof Panel?this:this.panel;for(;t!==null;){if(t.RN())return t;t=t.panel}return null}bind(t,e,i,s){return this.Pf(t,e,i,s),this}bindTwoWay(t,e,i,s){return this.Pf(t,e,i,s).makeTwoWay(),this}bindModel(t,e,i,s){return this.Pf(t,e,i,s).ofModel(),this}bindObject(t,e,i,s,n){return this.Pf(t,e,i,s).ofObject(n),this}theme(t,e,i,s,n){return this.Na(t,e,i,s,n),this}themeData(t,e,i,s,n){return this.Na(t,e,i,s,n).ofData(),this}themeObject(t,e,i,s,n,o){return this.Na(t,e,i,s,n).ofObject(o),this}themeModel(t,e,i,s,n){return this.Na(t,e,i,s,n).ofModel(),this}Pf(t,e,i,s){let n=null;return typeof t=="string"?n=new Binding(t,e,i,s):n=t,this.y0(n),n}Na(t,e,i,s,n){let o=null;return typeof t=="string"?o=new ThemeBinding(t,e,i,s,n):o=t,this.y0(o),o}y0(t){t.Ti=this;const e=this.findBindingPanel();e!==null&&e.oD()&&U.o("Cannot add a Binding to a template that has already been copied: "+t),this.ve===null&&(this.ve=new List),this.ve.add(t)}set(t){return t?(Object.assign(this,t),this):this}attach(t){return GraphObject.ON(this,t),this}apply(t,...e){return t.apply(this,[this,...e]),this}setProperties(t){return Diagram.Lp(this,t),this}static make(t,...e){let i=arguments,s=null,n=null;if(U.nt(t))n=t;else if(typeof t=="string"){const r=GraphObject.B1.get(t);U.nt(r)?(i=Array.prototype.slice.call(i),s=r(i),U.$(s)||U.o('GraphObject.make invoked object builder "'+t+'", but it did not return an Object')):n=root.go[t]}s===null&&((n==null||!n.constructor)&&U.o("GraphObject.make requires a class function or GoJS class name or name of an object builder, not: "+t),s=new n);let o=1;if(s instanceof Diagram&&i.length>1){const r=s,l=i[1];(typeof l=="string"||l instanceof HTMLDivElement)&&(r.m2(l),o++)}for(let r=o;r<i.length;r++){const l=i[r];l===void 0?U.o("Undefined value at argument "+r+" for object being constructed by GraphObject.make: "+s):s&&GraphObject.ON(s,l)}return s}static ON(t,e){if(typeof e=="number")GraphObject.mI(t,e);else if(typeof e=="string")GraphObject.pI(t,e);else if(e instanceof GraphObject)t instanceof Panel||U.o("A GraphObject can only be added to a Panel, not to: "+t),t.add(e);else if(e instanceof RowColumnDefinition){let i=null;e.isRow&&U.nt(t.getRowDefinition)?i=t.getRowDefinition(e.index):!e.isRow&&U.nt(t.getColumnDefinition)&&(i=t.getColumnDefinition(e.index)),i instanceof RowColumnDefinition?i.z1(e):U.o("A RowColumnDefinition can only be added to an object that implements getRowDefinition/getColumnDefinition, not to: "+t)}else if(e instanceof PanelLayout){const i=t;i.type=e}else if(e instanceof Binding)t instanceof GraphObject||t instanceof RowColumnDefinition?t.bind(e):U.o("A Binding can only be applied to a GraphObject or RowColumnDefinition, not to: "+t);else if(e instanceof AnimationTrigger)t instanceof GraphObject?t.trigger(e):U.o("An AnimationTrigger can only be applied to a GraphObject, not to: "+t);else if(e instanceof PathFigure)t instanceof Geometry&&t.type===4?t.figures.add(e):U.o("A PathFigure can only be added to a Path Geometry, not to: "+t);else if(e instanceof PathSegment)t instanceof PathFigure?t.segments.add(e):U.o("A PathSegment can only be added to a PathFigure, not to: "+t);else if(e instanceof Layout)t instanceof Diagram||t instanceof Group?t.layout=e:U.o("A Layout can only be assigned to a Diagram or a Group, not to: "+t);else if(Array.isArray(e))for(let i=0;i<e.length;i++){const s=e[i];GraphObject.ON(t,s)}else U.$(e)?GraphObject.yI(t,e):U.o('Unknown initializer "'+e+'" for object being constructed by GraphObject.make: '+t)}static pI(t,e){if(t instanceof TextBlock)t.text=e;else if(t instanceof Shape)t.figure=e;else if(t instanceof Picture)t.source=e;else if(t instanceof Panel){const i=PanelLayout.fs.get(e);i!==null&&(t.type=i)}else if(t instanceof Brush){const i=U.Wa(BrushType,e);i!==null?t.type=i:U.o("Unknown Brush type as an argument to GraphObject.make: "+e)}else if(t instanceof Geometry){const i=U.Wa(GeometryType,e);i!==null&&(t.type=i)}else if(t instanceof PathSegment){const i=U.Wa(SegmentType,e);i!==null&&(t.type=i)}}static mI(t,e){U.nt(t.fe)?t.fe(e):U.dr(t,e)}static yI(t,e){if(t instanceof Brush){const i=new PropertyCollection;for(const s in e){const n=parseFloat(s);isNaN(n)?i[s]=e[s]:t.addColorStop(n,e[s])}Diagram.Lp(t,i)}else if(t instanceof RowColumnDefinition){if(e.row!==void 0){const s=e.row;(s==null||s===1/0||isNaN(s)||s<0)&&U.o("Must specify non-negative integer row for RowColumnDefinition "+e+", not: "+s),t.isRow=!0,t.index=s}else if(e.column!==void 0){const s=e.column;(s==null||s===1/0||isNaN(s)||s<0)&&U.o("Must specify non-negative integer column for RowColumnDefinition "+e+", not: "+s),t.isRow=!1,t.index=s}const i=new PropertyCollection;for(const s in e)s==="row"||s==="column"||(i[s]=e[s]);Diagram.Lp(t,i)}else Diagram.Lp(t,e)}static build(t,e,...i){const s=GraphObject.B1.get(t);if(U.nt(s)){const n=s([t].concat(i));if(n instanceof GraphObject)return e&&n.setProperties(e),n}U.o('GraphObject.build invoked object builder "'+t+'", but it did not return an Object')}static defineBuilder(t,e){U.s(t,"string",GraphObject,"defineBuilder:name"),U.S(e,GraphObject,"defineBuilder:func");const i=t.toLowerCase();GraphObject.B1.set(t,e)}static isBuilderDefined(t){return GraphObject.B1.has(t)}static takeBuilderArgument(t,e,i){i===void 0&&(i=null);const s=t[1];return(U.nt(i)?i(s):typeof s=="string")?(t.splice(1,1),s):(e===void 0&&U.o("no "+(U.nt(i)?"satisfactory":"string")+" argument for GraphObject builder "+t[0]),e)}static B1=new GMap}GraphObject.Vertical=4,GraphObject.Horizontal=5,GraphObject.defineBuilder("Button",w=>{const t="#f5f5f5",e="#737373",i="#d4d4d4",s="#737373",n="#a3a3a3",o=2.76142374915397,r=2.761423749153969,l=new Panel(Panel.Auto,{isActionable:!0,enabledChanged:(a,h)=>{if(a instanceof Panel){const c=a.findObject("ButtonBorder");if(c!==null)if(a._buttonFillNormal===void 0&&(a._buttonFillNormal=c.fill),h){let f=null;a.layer!==null&&a.diagram!==null&&a.isVisibleObject()&&(f=a.layer.findObjectAt(a.diagram.lastInput.documentPoint)),f===a||f!==null&&f.isContainedBy(a)?c.fill=a._buttonFillOver:c.fill=a._buttonFillNormal}else c.fill=a._buttonFillDisabled}},cursor:"pointer"}).attach({_buttonFillNormal:void 0,_buttonStrokeNormal:void 0,_buttonFillOver:i,_buttonStrokeOver:s,_buttonFillDisabled:n}).add(new Shape("RoundedRectangle",{name:"ButtonBorder",spot1:new Spot(0,0,o,r),spot2:new Spot(1,1,-o,-r),parameter1:2,fill:t,stroke:e}));return l.mouseEnter=(a,h,c)=>{if(!h.isEnabledObject()||!(h instanceof Panel))return;const f=h.findObject("ButtonBorder");f instanceof Shape&&(h._buttonFillNormal===void 0&&(h._buttonFillNormal=f.fill),f.fill=h._buttonFillOver,h._buttonStrokeNormal===void 0&&(h._buttonStrokeNormal=f.stroke),f.stroke=h._buttonStrokeOver)},l.mouseLeave=(a,h,c)=>{if(!h.isEnabledObject()||!(h instanceof Panel))return;const f=h.findObject("ButtonBorder");f instanceof Shape&&(h._buttonFillNormal!==void 0&&(f.fill=h._buttonFillNormal),h._buttonStrokeNormal!==void 0&&(f.stroke=h._buttonStrokeNormal))},l}),GraphObject.defineBuilder("TreeExpanderButton",w=>{const t=GraphObject.build("Button");return t.attach({_treeExpandedFigure:"MinusLine",_treeCollapsedFigure:"PlusLine",visible:!1}),t.add(new Shape("MinusLine",{name:"ButtonIcon",stroke:"#0a0a0a",strokeWidth:2,desiredSize:Size.Su}).bindObject("figure","isTreeExpanded",(e,i)=>{const s=i.panel;return e?s._treeExpandedFigure:s._treeCollapsedFigure})),t.bindObject("visible","isTreeLeaf",e=>!e),t.click=(e,i)=>{let s=i.part;if(s instanceof Adornment&&(s=s.adornedPart),!(s instanceof Node))return;const n=s.diagram;if(n===null)return;const o=n.commandHandler;if(s.isTreeExpanded){if(!o.canCollapseTree(s))return}else if(!o.canExpandTree(s))return;e.handled=!0,s.isTreeExpanded?o.collapseTree(s):o.expandTree(s)},t}),GraphObject.defineBuilder("SubGraphExpanderButton",w=>{const t=GraphObject.build("Button");return t.attach({_subGraphExpandedFigure:"MinusLine",_subGraphCollapsedFigure:"PlusLine"}),t.add(new Shape("MinusLine",{name:"ButtonIcon",stroke:"#0a0a0a",strokeWidth:2,desiredSize:Size.Su}).bindObject("figure","isSubGraphExpanded",(e,i)=>{const s=i.panel;return e?s._subGraphExpandedFigure:s._subGraphCollapsedFigure})),t.click=(e,i)=>{let s=i.part;if(s instanceof Adornment&&(s=s.adornedPart),!(s instanceof Group))return;const n=s.diagram;if(n===null)return;const o=n.commandHandler;if(s.isSubGraphExpanded){if(!o.canCollapseSubGraph(s))return}else if(!o.canExpandSubGraph(s))return;e.handled=!0,s.isSubGraphExpanded?o.collapseSubGraph(s):o.expandSubGraph(s)},t}),GraphObject.defineBuilder("ToolTip",w=>new Adornment(Panel.Auto,{isShadowed:!0,shadowColor:"rgba(0, 0, 0, .4)",shadowOffset:new Point(0,2),mouseOver:(t,e)=>{const i=t.diagram.toolManager;i.extendToolTip(i.toolTipDuration)}}).add(new Shape("RoundedRectangle",{name:"Border",parameter1:1,fill:"#f5f5f5",strokeWidth:0,spot1:new Spot(0,0,4,6),spot2:new Spot(1,1,-4,-4)}))),GraphObject.defineBuilder("ContextMenu",w=>new Adornment(Panel.Vertical,{background:"#f5f5f5",isShadowed:!0,shadowColor:"rgba(0, 0, 0, .4)",shadowOffset:new Point(0,2)}).bindObject("background","",t=>t.adornedPart!==null&&t.hasPlaceholder()?null:"#f5f5f5")),GraphObject.defineBuilder("ContextMenuButton",w=>{const t=GraphObject.build("Button");t.stretch=5;const e=t.findObject("ButtonBorder");return e instanceof Shape&&(e.figure="Rectangle",e.strokeWidth=0,e.spot1=new Spot(0,0,4,6),e.spot2=new Spot(1,1,-4,-4)),t}),GraphObject.defineBuilder("PanelExpanderButton",w=>{const t=GraphObject.takeBuilderArgument(w,"COLLAPSIBLE"),e=GraphObject.build("Button");e.attach({_buttonExpandedFigure:"M0 0 M0 6 L4 2 8 6 M8 8",_buttonCollapsedFigure:"M0 0 M0 2 L4 6 8 2 M8 8","ButtonBorder.fill":"rgba(0, 0, 0, 0)",_buttonFillNormal:"rgba(0, 0, 0, 0)","ButtonBorder.stroke":null,_buttonStrokeNormal:null,_buttonFillOver:"rgba(0, 0, 0, .2)",_buttonStrokeOver:null}),e.add(new Shape({name:"ButtonIcon",strokeWidth:2}).bindObject("geometryString","visible",s=>s?e._buttonExpandedFigure:e._buttonCollapsedFigure,void 0,t));const i=e.findObject("ButtonBorder");return i instanceof Shape&&(i.stroke=null,i.fill="rgba(0, 0, 0, 0)"),e.click=(s,n)=>{if(!(n instanceof Panel))return;const o=n.diagram;if(o===null||o.isReadOnly)return;let r=n.findBindingPanel();if(r===null&&(r=n.part),r!==null){const l=r.findObject(t);l!==null&&(s.handled=!0,o.startTransaction("Collapse/Expand Panel"),l.visible=!l.visible,o.commitTransaction("Collapse/Expand Panel"))}},e}),GraphObject.defineBuilder("CheckBoxButton",w=>{const t=GraphObject.takeBuilderArgument(w),e=GraphObject.build("Button",{desiredSize:new Size(14,14)});e.attach({"ButtonBorder.spot1":new Spot(0,0,1,1),"ButtonBorder.spot2":new Spot(1,1,-1,-1)});const i=new Shape({name:"ButtonIcon",geometryString:"M0 0 M0 8.85 L4.9 13.75 16.2 2.45 M16.2 16.2",strokeWidth:2,stretch:2,geometryStretch:6,visible:!1});return t!==""&&i.bindTwoWay("visible",t),e.add(i),e.click=(s,n)=>{if(!(n instanceof Panel))return;const o=s.diagram;if(o===null||o.isReadOnly||t!==""&&o.model.isReadOnly)return;s.handled=!0;const r=n.findObject("ButtonIcon");o.startTransaction("checkbox"),r!==null&&(r.visible=!r.visible),U.nt(n._doClick)&&n._doClick(s,n),o.commitTransaction("checkbox")},e}),GraphObject.defineBuilder("CheckBox",w=>{const t=GraphObject.takeBuilderArgument(w),e=GraphObject.build("CheckBoxButton",{name:"Button",isActionable:!1,margin:new Margin(0,1,0,0)},t),i=new Panel("Horizontal",{isActionable:!0,cursor:e.cursor,margin:new Margin(1),mouseEnter:e.mouseEnter,mouseLeave:e.mouseLeave,click:e.click}).attach({_buttonFillNormal:e._buttonFillNormal,_buttonStrokeNormal:e._buttonStrokeNormal,_buttonFillOver:e._buttonFillOver,_buttonStrokeOver:e._buttonStrokeOver,_buttonFillDisabled:e._buttonFillDisabled,_buttonClick:e.click});return i.add(e),e.mouseEnter=null,e.mouseLeave=null,e.click=null,i}),GraphObject.defineBuilder("AutoRepeatButton",w=>{const t=GraphObject.takeBuilderArgument(w,50,r=>typeof r=="number"),e=GraphObject.takeBuilderArgument(w,500,r=>typeof r=="number");function i(r,l){n(r,l),l.click&&(l.Md=U.dn(()=>s(r,l),e))}function s(r,l){l.Md&&U.yc(l.Md),l.click&&(l.Md=U.dn(()=>{l.click&&(l.click(r,l),s(r,l))},t))}function n(r,l){l.Md&&(U.yc(l.Md),l.Md=void 0)}const o=GraphObject.build("Button");return o.actionDown=(r,l)=>i(r,l),o.actionUp=(r,l)=>n(r,l),o.actionCancel=(r,l)=>n(r,l),o}),GraphObject.defineBuilder("ToggleSwitch",function(w){const t=GraphObject.takeBuilderArgument(w);t||U.o("ToggleSwitch must be data-bound to a property name, not: "+t);const e=GraphObject.takeBuilderArgument(w,!1,h=>typeof h=="boolean"),i="gray",s="transparent",n="white",a=new Panel("Auto",{width:e?15:28,height:e?28:15}).attach({_buttonFillOff:i,_buttonBorderOff:s,_buttonIconFillOff:n,_buttonFillOn:"green",_buttonBorderOn:"transparent",_buttonIconFillOn:"white"}).add(new Shape("Capsule",{name:"ButtonBorder",fill:i,stroke:s,strokeWidth:1}).bind("fill",t,(h,c)=>h?c.panel._buttonFillOn:c.panel._buttonFillOff).bind("stroke",t,(h,c)=>h?c.panel._buttonBorderOn:c.panel._buttonBorderOff)).add(new Shape("Circle",{name:"ButtonIcon",width:11,height:11,fill:n,stroke:null,alignment:e?Spot.Bottom:Spot.Left}).bind("fill",t,(h,c)=>h?c.panel._buttonIconFillOn:c.panel._buttonIconFillOff).bind("alignment",t,h=>h?e?Spot.Top:Spot.Right:e?Spot.Bottom:Spot.Left));return a.click=function(h,c){if(!c.isEnabledObject())return;const f=h.diagram;if(f===null||f.isReadOnly||t!==""&&f.model.isReadOnly)return;h.handled=!0;const u=c.findBindingPanel();u!==null&&(f.startTransaction("toggle switch"),f.model.set(u.data,t,!u.data[t]),typeof c._doClick=="function"&&c._doClick(h,c),f.commitTransaction("toggle switch"))},a}),GraphObject.defineBuilder("Toggle",function(w){const t=GraphObject.takeBuilderArgument(w),e=GraphObject.build("ToggleSwitch",{name:"Button"},t),i=new Panel("Horizontal",{cursor:e.cursor,margin:1,mouseEnter:e.mouseEnter,mouseLeave:e.mouseLeave,click:e.click}).attach({_buttonClick:e.click}).add(e);return e.mouseEnter=null,e.mouseLeave=null,e.click=null,i});class GraphObjectTemplateSettings{me;Pt;oo;ve;ro;vs;Il;Ur;Vr;Br;Kr;Hr;zr;Xr;Gr;f0;u0;Yr;d0;g0;m0;p0;jr;qr;$p;r0;Ds;Cr;Lr;ho;o0;s0;Nr;Wp;w0;x0;constructor(){this.me=!1,this.Pt="",this.oo=-1,this.ve=null,this.ro=null,this.vs=null,this.Il="",this.Ur=null,this.Vr=null,this.Br=null,this.Kr=null,this.Hr=null,this.zr=null,this.Xr=null,this.Gr=null,this.f0=null,this.u0=null,this.Yr=null,this.d0=null,this.g0=null,this.m0=null,this.p0=null,this.jr=null,this.qr=null,this.$p=null,this.r0=null,this.Ds=null,this.Cr=Size.xc,this.Lr=Size.TP,this.ho=1,this.o0=1,this.s0=1,this.Nr=0,this.Wp=null,this.w0=null,this.x0="category"}copy(){const t=new GraphObjectTemplateSettings;return t.Pt=this.Pt,t.oo=this.oo,t.ve=this.ve,t.vs=this.vs,t.Il=this.Il,t.Ur=this.Ur,t.Vr=this.Vr,t.Br=this.Br,t.Kr=this.Kr,t.Hr=this.Hr,t.zr=this.zr,t.Xr=this.Xr,t.Gr=this.Gr,t.f0=this.f0,t.u0=this.u0,t.Yr=this.Yr,t.d0=this.d0,t.g0=this.g0,t.m0=this.m0,t.p0=this.p0,t.jr=this.jr,t.qr=this.qr,t.$p=this.$p,t.r0=this.r0,t.Ds=this.Ds,t.Cr=this.Cr.N(),t.Lr=this.Lr.N(),t.ho=this.ho,t.o0=this.o0,t.s0=this.s0,t.Nr=this.Nr,t.Wp=this.Wp,t.w0=this.w0,t.x0=this.x0,t}}class STransform{m;constructor(){this.m=[1,0,0,1,0,0]}copy(){const t=new STransform;return t.m[0]=this.m[0],t.m[1]=this.m[1],t.m[2]=this.m[2],t.m[3]=this.m[3],t.m[4]=this.m[4],t.m[5]=this.m[5],t}translate(t,e){this.m[4]+=this.m[0]*t+this.m[2]*e,this.m[5]+=this.m[1]*t+this.m[3]*e}scale(t,e){this.m[0]*=t,this.m[1]*=t,this.m[2]*=e,this.m[3]*=e}rotate(t,e,i){if(t=G.Ee(t),t===0)return;this.translate(e,i);let s=0,n=0;if(t===90)s=0,n=1;else if(t===180)s=-1,n=0;else if(t===270)s=0,n=-1;else{const h=t*Math.PI/180;s=Math.cos(h),n=Math.sin(h)}const o=this.m[0]*s+this.m[2]*n,r=this.m[1]*s+this.m[3]*n,l=this.m[0]*-n+this.m[2]*s,a=this.m[1]*-n+this.m[3]*s;this.m[0]=o,this.m[1]=r,this.m[2]=l,this.m[3]=a,this.translate(-e,-i)}}class SGradient{type;x1;y1;r1;x2;y2;r2;colors;pattern;constructor(t){this.type=t,this.x1=0,this.y1=0,this.r1=0,this.x2=0,this.y2=0,this.r2=0,this.colors=[],this.pattern=null}addColorStop(t,e){this.colors.push({offset:t,color:e})}}class SVGSurface{bt;_t;el;fd;IN;constructor(t,e,i){const s=e===void 0?root.document:e;this.el=s,this.IN="http://www.w3.org/2000/svg";const n="http://www.w3.org/2000/xmlns/";s!==void 0&&(this.bt=this.makeElement("svg",{width:"1px",height:"1px",viewBox:"0 0 1 1"}),this.style.display="block",this.style.letterSpacing="normal",this.style.wordSpacing="normal",i||(this.style.position="absolute"),this.bt.setAttributeNS(n,"xmlns",this.IN),this.bt.setAttributeNS(n,"xmlns:xlink","http://www.w3.org/1999/xlink")),this.fd=null,this._t=new SVGContext(this,i)}resize(t,e,i,s){return this.width!==t||this.height!==e?(this.width=t,this.height=e,this.style.width=i+"px",this.style.height=s+"px",this.bt.setAttributeNS(null,"width",i+"px"),this.bt.setAttributeNS(null,"height",s+"px"),this.bt.setAttributeNS(null,"viewBox","0 0 "+i+" "+s),this._t.EN.firstElementChild.setAttributeNS(null,"width",i+"px"),this._t.EN.firstElementChild.setAttributeNS(null,"height",s+"px"),!0):!1}makeElement(t,e,i){const s=this.el.createElementNS(this.IN,t);if(U.$(e))for(const n in e)s.setAttributeNS(n==="href"?"http://www.w3.org/1999/xlink":"",n,e[n]);return i!==void 0&&(s.textContent=i),s}getBoundingClientRect(){return this.bt.getBoundingClientRect()}focus(){this.bt.focus()}get width(){return this.bt.width.baseVal.value}set width(t){this.bt.setAttribute("width",t+"px")}get height(){return this.bt.height.baseVal.value}set height(t){this.bt.setAttribute("height",t+"px")}dispose(){this.el=null}get style(){return this.bt.style}}class SVGContext{Sf;Mf;An;Fe;Zi;fillStyle;font;globalAlpha;lineCap;lineDashOffset;lineJoin;lineWidth;miterLimit;shadowBlur;shadowColor;shadowOffsetX;shadowOffsetY;strokeStyle;textAlign;imageSmoothingEnabled;clipInsteadOfFill;lastCreatedElement;Nf;Cf;surface;svg;EN;rD;X1;Wo;Ca;Vh;currentElement;clipPathGroup;diagramGroup;lastDrawnPart;currentPath;outerGroup;pathAttributes;rl;Fr;filter;letterSpacing;wordSpacing;partClipRect;constructor(t,e){if(this.surface=t,this.svg=t.bt,this.Nf=[],this.Cf=[],this.fillStyle="#000000",this.font="10px sans-serif",this.globalAlpha=1,this.lineCap="butt",this.lineDashOffset=0,this.lineJoin="miter",this.lineWidth=1,this.miterLimit=10,this.shadowBlur=0,this.shadowColor="rgba(0, 0, 0, 0)",this.shadowOffsetX=0,this.shadowOffsetY=0,this.rl=!1,this.strokeStyle="#000000",this.textAlign="start",this.clipInsteadOfFill=!1,this.Sf=0,this.Mf=0,this.An=0,this.lastCreatedElement=null,this.currentElement=null,this.Fe=[],this.pathAttributes={},this.X1=!1,this.Wo=null,this.Ca=0,this.rD={},this.Fr=!!e,this.filter="",this.partClipRect=null,this.Zi=new STransform,this.letterSpacing="0px",this.wordSpacing="0px",t.el===null||t.el===void 0)return;this.clipPathGroup=this.newGroup2(),this.diagramGroup=this.newGroup2("gojs-diagram"),this.lastDrawnPart=null,this.currentPath=null;const i=GSet.qw++,s=this.makeElement("clipPath",{id:"mainClip"+i}),n={x:0,y:0,width:t.width,height:t.height};s.appendChild(this.makeElement("rect",n)),this.EN=s,this.svg.appendChild(this.clipPathGroup),this.clipPathGroup.appendChild(this.diagramGroup),this.svg.appendChild(s),this.clipPathGroup.setAttributeNS(null,"clip-path","url(#mainClip"+i+")")}setDiagramPosScale(t,e,i,s,n,o){this.diagramGroup===void 0?this.newGroup(t,e,i,s,n,o):this.diagramGroup.setAttribute("transform","matrix("+t+", "+e+", "+i+", "+s+", "+n+", "+o+")")}resetInnerSVG(){this.diagramGroup!==null&&(this.diagramGroup.innerHTML="")}arc(t,e,i,s,n,o,r,l){const a=2*Math.PI,h=1e-6,c=a-h,f=i*Math.cos(s),u=i*Math.sin(s),d=t+f,m=e+u,g=o?0:1;let p=o?s-n:n-s;(Math.abs(r-d)>h||Math.abs(l-m)>h)&&this.Fe.push(["L",d,+m]),p<0&&(p=p%a+a),p>c?(this.Fe.push(["A",i,i,0,1,g,t-f,e-u]),this.Fe.push(["A",i,i,0,1,g,d,m])):p>h&&this.Fe.push(["A",i,i,0,+(p>=Math.PI),g,t+i*Math.cos(n),e+i*Math.sin(n)])}beginPath(){this.Fe=[],this.pathAttributes={stroke:"none",fill:"none"}}endPath(t){this.wI(this.Fe,this.Zi,t||0)}bezierCurveTo(t,e,i,s,n,o){this.Fe.push(["C",t,e,i,s,n,o])}clearRect(t,e,i,s){}clip(){this.pathAttributes.clipPath=!0}closePath(){this.Fe.push(["z"])}createLinearGradient(t,e,i,s){const n=new SGradient("linear");return n.x1=t,n.y1=e,n.x2=i,n.y2=s,n}createPattern(t,e){let i="";t instanceof HTMLCanvasElement&&(i=t.toDataURL()),t instanceof HTMLImageElement&&(i=t.getAttribute("src"));const s=this.rD;if(s[i])return"url(#"+s[i]+")";const n="PATTERN"+GSet.qw++,o={width:t.width,height:t.height,id:n,patternUnits:"userSpaceOnUse"},r={x:0,y:0,width:t.width,height:t.height,href:i},l=this.makeElement("pattern",o);return l.appendChild(this.makeElement(Diagram.img,r)),this.svg.appendChild(l),s[i]=n,"url(#"+n+")"}createRadialGradient(t,e,i,s,n,o){const r=new SGradient("radial");return r.x1=t,r.y1=e,r.r1=i,r.x2=s,r.y2=n,r.r2=o,r}amendImageTransform(t,e,i,s,n,o,r,l){const a=r/i,h=l/s;(n!==0||o!==0)&&this.Zi.translate(n,o),(a!==1||h!==1)&&this.Zi.scale(a,h),(t!==0||e!==0)&&this.Zi.translate(-t,-e)}drawImage(t,e,i,s,n,o,r,l,a){let h="";t instanceof HTMLCanvasElement&&(h=t.toDataURL()),t instanceof HTMLImageElement&&(h=t.getAttribute("src"));const c=t instanceof HTMLImageElement?t.naturalWidth:t.width,f=t instanceof HTMLImageElement?t.naturalHeight:t.height;s===void 0&&(o=e,r=i,l=s=c,a=n=f),s=s||0,n=n||0,o=o||0,r=r||0,l=l||0,a=a||0,this.amendImageTransform(e,i,s,n,o,r,l,a);const u={x:0,y:0,width:c||s,height:f||n,href:h};!G.X(s,l)||!G.X(n,a)?u.preserveAspectRatio="none":h.toLowerCase().indexOf(".svg")===-1&&h.toLowerCase().indexOf("data:image/svg")===-1&&(u.preserveAspectRatio="xMidYMid slice"),(e!==0||i!==0||s!==c||n!==f)&&(s+=e,n+=i,u["clip-path"]=`path('M ${e},${i} L ${s} ${i} L ${s} ${n} L ${e} ${n} z')`),this.processCommon(Diagram.img,u,this.Zi),this.Nd(Diagram.img,u)}fill(t,e){t&&(this.pathAttributes["fill-rule"]="evenodd"),this.setFill(this.pathAttributes)}fillContext(t,e,i){this.clipInsteadOfFill?this.clip():this.fill(e,i)}createOrUpdateClipGroup(t,e){const i=this.newGroup(1,0,0,1,-e.x,-e.y);i.setAttributeNS(null,"class","spotClip"),t.xa=i}fillRect(t,e,i,s){this.addRect("fill",[t,e,i,s],this.Zi)}fillBackground(t,e,i,s){const n={x:t,y:e,width:i,height:s};this.processCommon("fill",n,this.Zi),this.setFill(n),this.svg.prepend(this.makeElement("rect",n))}fillText(t,e,i){this.addText("fill",[t,e,i],this.Zi)}lineTo(t,e){this.Fe.push(["L",t,e])}moveTo(t,e){this.Fe.push(["M",t,e])}quadraticCurveTo(t,e,i,s){this.Fe.push(["Q",t,e,i,s])}rect(t,e,i,s){this.Fe.push(["M",t,e],["L",t+i,e],["L",t+i,e+s],["L",t,e+s],["z"])}restore(){this.Zi=this.Nf.pop(),this.Fe=this.Nf.pop();const t=this.Nf.pop();this.fillStyle=t.fillStyle,this.font=t.font,this.globalAlpha=t.globalAlpha,this.lineCap=t.lineCap,this.lineDashOffset=t.lineDashOffset,this.lineJoin=t.lineJoin,this.lineWidth=t.lineWidth,this.miterLimit=t.miterLimit,this.shadowBlur=t.shadowBlur,this.shadowColor=t.shadowColor,this.shadowOffsetX=t.shadowOffsetX,this.shadowOffsetY=t.shadowOffsetY,this.strokeStyle=t.strokeStyle,this.textAlign=t.textAlign,this.partClipRect=t.partClipRect,this.letterSpacing=t.letterSpacing,this.wordSpacing=t.wordSpacing}save(){const t={fillStyle:this.fillStyle,font:this.font,globalAlpha:this.globalAlpha,lineCap:this.lineCap,lineDashOffset:this.lineDashOffset,lineJoin:this.lineJoin,lineWidth:this.lineWidth,miterLimit:this.miterLimit,shadowBlur:this.shadowBlur,shadowColor:this.shadowColor,shadowOffsetX:this.shadowOffsetX,shadowOffsetY:this.shadowOffsetY,strokeStyle:this.strokeStyle,textAlign:this.textAlign,partClipRect:this.partClipRect};this.Nf.push(t);const e=[];for(let i=0;i<this.Fe.length;i++)e.push(this.Fe[i]);this.Nf.push(e),this.Nf.push(this.Zi.copy())}setTransform(t,e,i,s,n,o){t===1&&e===0&&i===0&&s===1&&n===0&&o===0||this.newGroup(t,e,i,s,n,o)}setCurrentTransform(t,e,i,s,n,o){this.Zi.m=[t,e,i,s,n,o]}getCurrentTransform(){const t=this.Zi.m;return"matrix("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+", "+t[4]+", "+t[5]+")"}scale(t,e){this.Zi.scale(t,e)}translate(t,e){this.Zi.translate(t,e)}transform(t,e,i,s,n,o){}commitTransform(){}stroke(){this.setStroke(this.pathAttributes)}strokeContext(){this.clipInsteadOfFill||this.stroke()}strokeRect(t,e,i,s){this.addRect("stroke",[t,e,i,s],this.Zi)}makeElement(t,e,i){return this.surface.makeElement(t,e,i)}Nd(t,e,i){const s=this.makeElement(t,e,i);return this.currentElement!==null?this.currentElement.appendChild(s):this.currentElement=s,this.lastCreatedElement=s,s}processCommon(t,e,i){if(t==="fill"?this.setFill(e):t==="stroke"&&this.setStroke(e),i!==null){const s=i.m;e.transform="matrix("+s[0]+", "+s[1]+", "+s[2]+", "+s[3]+", "+s[4]+", "+s[5]+")"}}setFill(t){if(this.fillStyle instanceof SGradient){t.fill=this.addGradient(this.fillStyle,"fill");return}if(/^rgba\(/.test(this.fillStyle)){const i=/^\s*rgba\s*\(([^,\s]+)\s*,\s*([^,\s]+)\s*,\s*([^,\s]+)\s*,\s*([^,\s]+)\)\s*$/i.exec(this.fillStyle);t.fill="rgb("+i[1]+","+i[2]+","+i[3]+")",t["fill-opacity"]=i[4]}else t.fill=this.fillStyle}setFillOrStrokeInPlace(t,e){const i=e?"fill":"stroke";if(this.fillStyle instanceof SGradient){t.setAttributeNS(null,"fill",this.addGradient(this.fillStyle,i));return}if(/^rgba\(/.test(this.fillStyle)){const n=/^\s*rgba\s*\(([^,\s]+)\s*,\s*([^,\s]+)\s*,\s*([^,\s]+)\s*,\s*([^,\s]+)\)\s*$/i.exec(this.fillStyle);t.setAttributeNS(null,i,"rgb("+n[1]+","+n[2]+","+n[3]+")"),t.setAttributeNS(null,i+"-opacity",n[4])}else t.setAttributeNS(null,i,this.fillStyle)}setStroke(t){if(this.strokeStyle instanceof SGradient)t.stroke=this.addGradient(this.strokeStyle,"stroke");else if(/^rgba\(/.test(this.strokeStyle)){const i=/^\s*rgba\s*\(([^,\s]+)\s*,\s*([^,\s]+)\s*,\s*([^,\s]+)\s*,\s*([^,\s]+)\)\s*$/i.exec(this.strokeStyle);t.stroke="rgb("+i[1]+","+i[2]+","+i[3]+")",t["stroke-opacity"]=i[4]}else t.stroke=this.strokeStyle;t["stroke-width"]=this.lineWidth,t["stroke-linecap"]=this.lineCap,t["stroke-linejoin"]=this.lineJoin,t["stroke-miterlimit"]=this.miterLimit,this.X1&&(t["stroke-dasharray"]=this.Wo.toString(),t["stroke-dashoffset"]=this.Ca)}addGradient(t,e){let i="";const s=this.currentPath!==null?this.currentPath.getAttribute(e):null;if(s!==null&&s.indexOf("GRAD")!==-1){i=s.split("#")[1].slice(0,-1);const l=this.svg.getElementById(i);l!==null&&l.remove()}else i="GRAD"+GSet.qw++;let n;if(t.type==="linear"){const l={x1:t.x1,x2:t.x2,y1:t.y1,y2:t.y2,id:i,gradientUnits:"userSpaceOnUse"};n=this.makeElement("linearGradient",l)}else if(t.type==="radial"){const l={x1:t.x1,x2:t.x2,y1:t.y1,y2:t.y2,r1:t.r1,r2:t.r2,id:i};n=this.makeElement("radialGradient",l)}else U.o("invalid gradient");const o=t.colors.sort((l,a)=>l.offset>a.offset?1:-1),r=o.length;for(let l=0;l<r;l++){const a=o[l],h=a.color;n.appendChild(this.makeElement("stop",{offset:a.offset,"stop-color":h}))}return this.svg.appendChild(n),"url(#"+i+")"}addRect(t,e,i){const s={x:e[0],y:e[1],width:e[2],height:e[3]};this.processCommon(t,s,i),this.Nd("rect",s)}addText(t,e,i){let s=this.textAlign;s==="left"?s="start":s==="right"?s="end":s==="center"&&(s="middle");const n={x:e[1],y:e[2],style:"font: "+this.font,"text-anchor":s};n["letter-spacing"]=this.letterSpacing,n["word-spacing"]=this.wordSpacing,this.processCommon(t,n,i),this.Nd("text",n,e[0])}wI(t,e,i){const s=this.xI(t),n=this.pathAttributes;if(n.clipPath){this.Cf.length>1&&this.Cf[this.Cf.length-2].setAttributeNS(null,"clip-path",'path("'+s+'") view-box');return}if(n.d=s,this.processCommon("",n,e),this.currentPath!==null){const r=this.currentPath;if(r.nodeName!=="g")for(const l in n)l!=="transform"&&r.setAttributeNS(null,l,n[l]);else{const l=r.getElementsByTagName("path");for(const a in n)a!=="transform"&&l[i].setAttributeNS(null,a,n[a])}}else this.Nd("path",n)}xI(t){const e=[];for(let i=0;i<t.length;i++){const s=t[i].slice(),n=[s.shift()];if(n[0]==="A")n.push(s.shift()+","+s.shift(),s.shift(),s.shift()+","+s.shift(),s.shift()+","+s.shift());else for(;s.length;)n.push(s.shift()+","+s.shift());e.push(n.join(" "))}return e.join(" ")}newGroup(t,e,i,s,n,o){const r=new STransform;r.m=[t,e,i,s,n,o];const l={};this.processCommon("g",l,r);const a=this.Nd("g",l);return this.Cf.push(a),a}newGroup2(t){const e={};t&&(e.class=t);const i=this.Nd("g",e);return this.Cf.push(i),i}endGroup(){return this.Cf.pop()}dummyGroup(){return this.newGroup2(),this.endGroup()}shadowsSet(t,e,i){this.Sf=t,this.Mf=e,this.An=i}shadowsOff(){this.rl=!1,this.shadowOffsetX=0,this.shadowOffsetY=0,this.shadowBlur=0}shadowsOn(){this.rl=!0,this.shadowOffsetX=this.Sf,this.shadowOffsetY=this.Mf,this.shadowBlur=this.An}enableDash(t,e){this.X1=!0,this.Wo=t,this.Ca=e}disableDash(){this.X1=!1}clearContextCache(t){}setImageSmoothingEnabled(t){}rotate(t){this.Zi.rotate(t*57.2958,0,0)}getImageData(t,e,i,s){return null}measureText(t){return null}removeOldGradient(t,e,i){const s=e.getAttribute(i);if(s===null)return;const n=s.split("#");if(n.length===1)return;const o=this.svg.getElementById(n[1].slice(0,-1));if(o!==null){const r=new RegExp(o.id,"g");this.svg.innerHTML.match(r).length===1&&o.remove()}}removePartFromView(t){t.svg!==null&&t.svg.parentNode===this.diagramGroup&&t.svg.remove()}}class CanvasSurface{bt;_t;el;fd;constructor(t,e,i,s){const n=e===void 0?root.document:e;this.el=n,this.fd=null;const o=n.createElement("canvas");o.tabIndex=0,this.bt=o,this._t=new CanvasSurfaceContext(o,i,s),t&&Diagram.Wi.set(o,t)}resize(t,e,i,s){return this.width!==t||this.height!==e?(this.width=t,this.height=e,this.style.width=i+"px",this.style.height=s+"px",!0):!1}toDataURL(t,e){return this.bt.toDataURL(t,e)}getBoundingClientRect(){return this.bt.getBoundingClientRect()}focus(){this.bt.focus()}get width(){return this.bt.width}set width(t){this.bt.width=t}get height(){return this.bt.height}set height(t){this.bt.height=t}dispose(){Diagram.Wi.delete(this.bt),this.el=null}get style(){return this.bt.style}}class CanvasSurfaceContext{F;G1;Y1;K1;clipInsteadOfFill;Sf;Mf;An;Vh;rl;Fr;constructor(t,e,i){t.getContext||U.o("Browser does not support HTML Canvas Element"),this.F=t.getContext("2d",e),this.G1="",this.Y1="",this.K1="",this.clipInsteadOfFill=!1,this.Sf=0,this.Mf=0,this.An=0,this.rl=!1,this.Vh=new Transform,this.Fr=!!i}createOrUpdateClipGroup(t,e){}setImageSmoothingEnabled(t){this.F.imageSmoothingEnabled=t}get fillStyle(){return this.F.fillStyle}set fillStyle(t){this.K1!==t&&(this.F.fillStyle=t,this.K1=t)}get font(){return this.F.font}set font(t){this.G1!==t&&(this.F.font=t,this.G1=t)}get globalAlpha(){return this.F.globalAlpha}set globalAlpha(t){this.F.globalAlpha=t}get lineCap(){return this.F.lineCap}set lineCap(t){this.F.lineCap=t}get lineDashOffset(){return this.F.lineDashOffset}set lineDashOffset(t){this.F.lineDashOffset=t}get lineJoin(){return this.F.lineJoin}set lineJoin(t){this.F.lineJoin=t}get lineWidth(){return this.F.lineWidth}set lineWidth(t){this.F.lineWidth=t}get miterLimit(){return this.F.miterLimit}set miterLimit(t){this.F.miterLimit=t}get shadowBlur(){return this.F.shadowBlur}set shadowBlur(t){this.F.shadowBlur=t}get shadowColor(){return this.F.shadowColor}set shadowColor(t){this.F.shadowColor=t}get shadowOffsetX(){return this.F.shadowOffsetX}set shadowOffsetX(t){this.F.shadowOffsetX=t}get shadowOffsetY(){return this.F.shadowOffsetY}set shadowOffsetY(t){this.F.shadowOffsetY=t}get strokeStyle(){return this.F.strokeStyle}set strokeStyle(t){this.Y1!==t&&(this.F.strokeStyle=t,this.Y1=t)}get textAlign(){return this.F.textAlign}set textAlign(t){this.F.textAlign=t}get imageSmoothingEnabled(){return this.F.imageSmoothingEnabled}set imageSmoothingEnabled(t){this.F.imageSmoothingEnabled=t}get filter(){return this.F.filter}set filter(t){t===""?this.F.filter="none":this.F.filter=t}get letterSpacing(){return this.F.letterSpacing}set letterSpacing(t){this.F.letterSpacing=t}get wordSpacing(){return this.F.wordSpacing}set wordSpacing(t){this.F.wordSpacing=t}arc(t,e,i,s,n,o,r,l){this.F.arc(t,e,i,s,n,o)}beginPath(){this.F.beginPath()}endPath(){}bezierCurveTo(t,e,i,s,n,o){this.F.bezierCurveTo(t,e,i,s,n,o)}clearRect(t,e,i,s){this.commitTransform(),this.F.clearRect(t,e,i,s)}clip(t){t?this.F.clip(t):this.F.clip()}closePath(){this.F.closePath()}createLinearGradient(t,e,i,s){return this.F.createLinearGradient(t,e,i,s)}createPattern(t,e){return this.F.createPattern(t,e)}createRadialGradient(t,e,i,s,n,o){return this.F.createRadialGradient(t,e,i,s,n,o)}drawImage(t,e,i,s,n,o,r,l,a){s===void 0?this.F.drawImage(t,e,i):this.F.drawImage(t,e,i,s,n,o,r,l,a)}fill(t,e){e?this.F.fill(e,t?"evenodd":"nonzero"):this.F.fill(t?"evenodd":"nonzero")}fillRect(t,e,i,s){this.F.fillRect(t,e,i,s)}fillBackground(t,e,i,s){this.F.fillRect(t,e,i,s)}fillText(t,e,i){this.F.fillText(t,e,i)}getImageData(t,e,i,s){return this.F.getImageData(t,e,i,s)}lineTo(t,e){this.F.lineTo(t,e)}measureText(t){return this.F.measureText(t)}moveTo(t,e){this.F.moveTo(t,e)}quadraticCurveTo(t,e,i,s){this.F.quadraticCurveTo(t,e,i,s)}rect(t,e,i,s){this.F.rect(t,e,i,s)}restore(){this.F.restore()}save(){this.commitTransform(),this.F.save()}rotate(t){this.Vh.ks(t*57.2958,0,0)}setTransform(t,e,i,s,n,o){this.Vh.setTo(t,e,i,s,n,o)}scale(t,e){this.Vh.it(t,e)}translate(t,e){this.Vh.Gs(t,e)}stroke(t){t?this.F.stroke(t):this.F.stroke()}transform(t,e,i,s,n,o){if(t===1&&e===0&&i===0&&s===1&&n===0&&o===0)return;const r=this.Vh,l=r.m11*t+r.m21*e,a=r.m12*t+r.m22*e,h=r.m11*i+r.m21*s,c=r.m12*i+r.m22*s;r.dx=r.m11*n+r.m21*o+r.dx,r.dy=r.m12*n+r.m22*o+r.dy,r.m11=l,r.m12=a,r.m21=h,r.m22=c}commitTransform(){const t=this.Vh;this.F.setTransform(t.m11,t.m12,t.m21,t.m22,t.dx,t.dy)}fillContext(t,e,i){this.radialFill(t,e,i)||this.fillOrClip(e,i)}radialFill(t,e,i){if(!(t instanceof Brush)||t.type!==3)return!1;const s=t.xf,n=t.U1;return n>s?(this.scale(s/n,1),this.translate((n-s)/2,0)):s>n&&(this.scale(1,n/s),this.translate(0,(s-n)/2)),this.fillOrClip(e,i),n>s?(this.translate(-(n-s)/2,0),this.scale(1/(s/n),1)):s>n&&(this.translate(0,-(s-n)/2),this.scale(1,1/(n/s))),!0}strokeContext(){this.clipInsteadOfFill||this.stroke()}fillOrClip(t,e){this.clipInsteadOfFill?this.clip(e):this.fill(t,e)}shadowsSet(t,e,i){this.Sf=t,this.Mf=e,this.An=i}shadowsOff(){this.rl=!1,this.shadowOffsetX=0,this.shadowOffsetY=0,this.shadowBlur=0}shadowsOn(){this.rl=!0,this.shadowOffsetX=this.Sf,this.shadowOffsetY=this.Mf,this.shadowBlur=this.An}enableDash(t,e){const i=this.F;i.setLineDash!==void 0&&(i.setLineDash(t),i.lineDashOffset=e)}disableDash(){const t=this.F;t.setLineDash!==void 0&&(t.setLineDash(CanvasSurfaceContext.EmptyArray),t.lineDashOffset=0)}clearContextCache(t){t&&(this.G1=""),this.Y1="",this.K1=""}removePartFromView(t){}static EmptyArray=Object.freeze([])}var BrushType=(w=>(w[w.Solid=1]="Solid",w[w.Linear=2]="Linear",w[w.Radial=3]="Radial",w[w.Pattern=4]="Pattern",w))(BrushType||{}),ColorSpace=(w=>(w[w.Lab=1]="Lab",w[w.HSL=2]="HSL",w[w.Oklch=3]="Oklch",w))(ColorSpace||{});class ColorNumbers{n0;n1;n2;n3;constructor(){this.n0=0,this.n1=0,this.n2=0,this.n3=0}}class Brush{f;W;Bh;ae;Cs;b0;k0;Jo;P0;Cn;xf;U1;constructor(t,e){if(GSet.Je(this),this.f=!1,t===void 0)this.W=1,this.Bh="black";else if(typeof t=="string"){const s=U.Wa(BrushType,t);s!==null?(this.W=s,this.Bh="black"):(this.W=1,this.Bh=t)}else Object.keys(BrushType).hasOwnProperty(t)?(this.W=t,this.Bh="black"):typeof t=="object"&&(this.W=1,e=t);const i=this.W;if(i===2?(this.ae=Spot.TopCenter,this.Cs=Spot.BottomCenter):i===3?(this.ae=Spot.Center,this.Cs=Spot.Center):(this.ae=Spot.None,this.Cs=Spot.None),this.b0=0,this.k0=NaN,this.Jo=null,this.P0=null,this.Cn=null,this.xf=0,this.U1=0,e){const s={};for(const n in e)isFinite(parseFloat(n))?this.addColorStop(parseFloat(n),e[n]):s[n]=e[n];Object.assign(this,s)}}copy(){const t=new Brush;return t.W=this.W,t.Bh=this.Bh,t.ae=this.ae.N(),t.Cs=this.Cs.N(),t.b0=this.b0,t.k0=this.k0,this.Jo!==null&&(t.Jo=this.Jo.copy()),t.P0=this.P0,t}b(){return this.f=!0,this.Jo!==null&&this.Jo.b(),this}fe(t){t in BrushType?this.type=t:U.dr(this,t)}toString(){let t="Brush(";if(this.type===1)t+=this.color;else if(this.type===2?t+="Linear ":this.type===3?t+="Radial ":this.type===4?t+="Pattern ":t+="(unknown) ",t+=this.start+" "+this.end,this.colorStops!==null){const e=this.colorStops.iterator;for(;e.next();){const i=e.key,s=e.value;t+=" "+i+":"+s}}return t+=")",t}addColorStop(t,e){return this.f&&U.L(this),(typeof t!="number"||!isFinite(t)||t>1||t<0)&&U.J(t,"0 <= loc <= 1",Brush,"addColorStop:loc"),U.s(e,"string",Brush,"addColorStop:color"),this.Jo===null&&(this.Jo=new GMap),this.Jo.set(t,e),this.W===1&&(this.type=2),this.Cn=null,this}get type(){return this.W}set type(t){this.f&&U.L(this,t),this.W=t,this.start.isNoSpot()&&(t===2?this.start=Spot.TopCenter:t===3&&(this.start=Spot.Center)),this.end.isNoSpot()&&(t===2?this.end=Spot.BottomCenter:t===3&&(this.end=Spot.Center)),this.Cn=null}get color(){return this.Bh}set color(t){this.f&&U.L(this,t),this.Bh=t,this.Cn=null}get start(){return this.ae}set start(t){this.f&&U.L(this,t),this.ae=t.N(),this.Cn=null}get end(){return this.Cs}set end(t){this.f&&U.L(this,t),this.Cs=t.N(),this.Cn=null}get startRadius(){return this.b0}set startRadius(t){this.f&&U.L(this,t),t<0&&U.J(t,">= zero",Brush,"startRadius"),this.b0=t,this.Cn=null}get endRadius(){return this.k0}set endRadius(t){this.f&&U.L(this,t),t<0&&U.J(t,">= zero",Brush,"endRadius"),this.k0=t,this.Cn=null}get colorStops(){return this.Jo}set colorStops(t){this.f&&U.L(this,t),this.Jo=t,this.Cn=null}get pattern(){return this.P0}set pattern(t){this.f&&U.L(this,t),this.P0=t,this.Cn=null}static randomColor(t,e){t===void 0&&(t=128),e===void 0&&(e=Math.max(t,255));const i=Math.abs(e-t);let s=Math.floor(t+Math.random()*i).toString(16),n=Math.floor(t+Math.random()*i).toString(16),o=Math.floor(t+Math.random()*i).toString(16);return s.length<2&&(s="0"+s),n.length<2&&(n="0"+n),o.length<2&&(o="0"+o),"#"+s+n+o}static isValidColor(t){return root.CSS?root.CSS.supports("color",t):!0}static lighten(t){return Brush.lightenBy(t)}lightenBy(t,e){this.f&&U.L(this);const i=t===void 0||typeof t!="number"?.2:t,s=e===void 0?3:e;if(this.type===1)Brush.Uo(this.color),this.color=Brush.Cd(i,s);else if((this.type===2||this.type===3)&&this.colorStops!==null){const n=this.colorStops.iterator;for(;n.next();)Brush.Uo(n.value),this.addColorStop(n.key,Brush.Cd(i,s))}return this}static lightenBy(t,e,i){const s=e===void 0||typeof e!="number"?.2:e,n=i===void 0?3:i;return Brush.Uo(t),Brush.Cd(s,n)}static darken(t){return Brush.darkenBy(t)}darkenBy(t,e){this.f&&U.L(this);const i=t===void 0||typeof t!="number"?.2:t,s=e===void 0?3:e;if(this.type===1)Brush.Uo(this.color),this.color=Brush.Cd(-i,s);else if((this.type===2||this.type===3)&&this.colorStops!==null){const n=this.colorStops.iterator;for(;n.next();)Brush.Uo(n.value),this.addColorStop(n.key,Brush.Cd(-i,s))}return this}static darkenBy(t,e,i){const s=e===void 0||typeof e!="number"?.2:e,n=i===void 0?3:i;return Brush.Uo(t),Brush.Cd(-s,n)}static mix(t,e,i){Brush.Uo(t);const s=Brush.Y.n0,n=Brush.Y.n1,o=Brush.Y.n2,r=Brush.Y.n3;Brush.Uo(e),i===void 0&&(i=.5);const l=Math.round((Brush.Y.n0-s)*i+s),a=Math.round((Brush.Y.n1-n)*i+n),h=Math.round((Brush.Y.n2-o)*i+o),c=Math.round((Brush.Y.n3-r)*i+r);return`rgba(${l}, ${a}, ${h}, ${c})`}isDark(){if(this.type===1)return Brush.isDark(this.color);if((this.type===2||this.type===3)&&this.colorStops!==null){const t=this.colorStops;if(this.type===3){const l=t.first();return l?Brush.isDark(l.value):!1}if(t.get(.5)!==null)return Brush.isDark(t.get(.5));if(t.count===2){const l=t.toArray();return Brush.isDark(Brush.mix(l[0].value,l[1].value))}const e=t.iterator;let i=-1,s=-1,n=1,o=1;for(;e.next();){const l=e.key,a=Math.abs(.5-e.key);n>o&&a<n?(i=l,n=a):o>=n&&a<o&&(s=l,o=a)}if(i>s){let l=i;i=s,s=l,l=n,n=o,o=l}const r=s-i;return Brush.isDark(Brush.mix(t.get(i),t.get(s),1-o/r))}return!1}static isDark(t){return t?t instanceof Brush?t.isDark():(Brush.Uo(t),(299*Brush.Y.n0+587*Brush.Y.n1+114*Brush.Y.n2)/1e3<128):!1}static Cd(t,e){switch(e){case 1:return Brush.bI(),Brush.co.n0=Math.min(100,Math.max(0,Brush.co.n0+100*t)),Brush.kI(),"rgba("+Brush.Y.n0+", "+Brush.Y.n1+", "+Brush.Y.n2+", "+Brush.Y.n3+")";case 2:return Brush.RM(),Brush.ze.n2=Math.min(100,Math.max(0,Brush.ze.n2+100*t)),"hsla("+Brush.ze.n0+", "+Brush.ze.n1+"%, "+Brush.ze.n2+"%, "+Brush.ze.n3+")";case 3:return Brush.SI(),Brush.fo.n0=Math.min(100,Math.max(0,Brush.fo.n0+100*t)),Brush.MI(),"rgba("+Brush.Y.n0+", "+Brush.Y.n1+", "+Brush.Y.n2+", "+Brush.Y.n3+")";default:U.o("Unknown color space: "+e)}}static Uo(t){Brush.S0===!1&&(Brush.S0=!0,Brush.us=Diagram.isUsingDOM()?new CanvasSurface(null,void 0,{willReadFrequently:!0})._t:null);const e=Brush.us;if(e===null)return;e.clearRect(0,0,1,1),e.fillStyle="#000000";const i=e.fillStyle;if(e.fillStyle=t,e.fillStyle!==i){e.fillRect(0,0,1,1);const s=e.getImageData(0,0,1,1).data;Brush.Y.n0=s[0],Brush.Y.n1=s[1],Brush.Y.n2=s[2],Brush.Y.n3=s[3]/255}else{e.fillStyle="#FFFFFF";const s=e.fillStyle;e.fillStyle=t,e.fillStyle,Brush.Y.n0=0,Brush.Y.n1=0,Brush.Y.n2=0,Brush.Y.n3=1}}static RM(){const t=Brush.Y.n0/255,e=Brush.Y.n1/255,i=Brush.Y.n2/255,s=Math.max(t,e,i),n=Math.min(t,e,i),o=s-n;let r,l;const a=(s+n)/2;if(o===0)r=l=0;else{switch(s){case t:r=(e-i)/o%6;break;case e:r=(i-t)/o+2;break;case i:r=(t-e)/o+4;break;default:r=0;break}r*=60,r<0&&(r+=360),l=o/(1-Math.abs(2*a-1))}Brush.ze.n0=Math.round(r),Brush.ze.n1=Math.round(l*100),Brush.ze.n2=Math.round(a*100),Brush.ze.n3=Brush.Y.n3}static VU(){const t=Brush.ze.n0,e=Brush.ze.n1/100,i=Brush.ze.n2/100;let s,n,o;const r=(1-Math.abs(2*i-1))*e,l=t/60,a=r*(1-Math.abs(l%2-1));l>=0&&l<1?(s=r,n=a,o=0):l>=1&&l<2?(s=a,n=r,o=0):l>=2&&l<3?(s=0,n=r,o=a):l>=3&&l<4?(s=0,n=a,o=r):l>=4&&l<5?(s=a,n=0,o=r):(s=r,n=0,o=a);const h=i-.5*r;s+=h,n+=h,o+=h,Brush.Y.n0=Math.round(s*255),Brush.Y.n1=Math.round(n*255),Brush.Y.n2=Math.round(o*255),Brush.Y.n3=Brush.ze.n3}static bI(){Brush.lD(),Brush.NI()}static kI(){Brush.CI(),Brush.aD()}static UN(t){return t/=255,t<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}static VN(t){return t<=.0031308?t*12.92:1.055*Math.pow(t,1/2.4)-.055}static lD(){const t=Brush.UN(Brush.Y.n0),e=Brush.UN(Brush.Y.n1),i=Brush.UN(Brush.Y.n2);Brush.At.n0=.4124564*t+.3575761*e+.1804375*i,Brush.At.n1=.2126729*t+.7151522*e+.072175*i,Brush.At.n2=.0193339*t+.119192*e+.9503041*i,Brush.At.n3=Brush.Y.n3}static aD(){const t=3.2404542*Brush.At.n0+-1.5371385*Brush.At.n1+-.4985314*Brush.At.n2,e=-.969266*Brush.At.n0+1.8760108*Brush.At.n1+.041556*Brush.At.n2,i=.0556434*Brush.At.n0+-.2040259*Brush.At.n1+1.0572252*Brush.At.n2;Brush.Y.n0=Brush.VN(t)*255,Brush.Y.n1=Brush.VN(e)*255,Brush.Y.n2=Brush.VN(i)*255,Brush.Y.n3=Brush.At.n3,Brush.Y.n0=Math.round(Brush.Y.n0),Brush.Y.n0>255?Brush.Y.n0=255:Brush.Y.n0<0&&(Brush.Y.n0=0),Brush.Y.n1=Math.round(Brush.Y.n1),Brush.Y.n1>255?Brush.Y.n1=255:Brush.Y.n1<0&&(Brush.Y.n1=0),Brush.Y.n2=Math.round(Brush.Y.n2),Brush.Y.n2>255?Brush.Y.n2=255:Brush.Y.n2<0&&(Brush.Y.n2=0)}static BN=216/24389;static H1=24389/27;static Ld=[95.047,100,108.883];static zN(t){return t>Brush.BN?Math.pow(t,1/3):(Brush.H1*t+16)/116}static NI(){const t=Brush.zN(Brush.At.n0*100/Brush.Ld[0]),e=Brush.zN(Brush.At.n1*100/Brush.Ld[1]),i=Brush.zN(Brush.At.n2*100/Brush.Ld[2]);Brush.co.n0=116*e-16,Brush.co.n1=500*(t-e),Brush.co.n2=200*(e-i),Brush.co.n3=Brush.At.n3}static hD(t){const e=t*t*t;return e>Brush.BN?e:(116*t-16)/Brush.H1}static CI(){const t=(Brush.co.n0+16)/116,e=Brush.co.n1/500+t,i=t-Brush.co.n2/200;Brush.At.n0=Brush.Ld[0]/100*Brush.hD(e),Brush.At.n1=Brush.Ld[1]/100*(Brush.co.n0>Brush.H1*Brush.BN?Math.pow(t,3):Brush.co.n0/Brush.H1),Brush.At.n2=Brush.Ld[2]/100*Brush.hD(i),Brush.At.n3=Brush.co.n3}static LI(){let t=.8190224*Brush.At.n0+.3619062*Brush.At.n1+-.1288737*Brush.At.n2,e=.03298366*Brush.At.n0+.9292868*Brush.At.n1+.03614466*Brush.At.n2,i=.04817719*Brush.At.n0+.2642395*Brush.At.n1+.6335478*Brush.At.n2;t=Math.cbrt(t),e=Math.cbrt(e),i=Math.cbrt(i),Brush.ge.n0=.2104542*t+.7936177*e+-.004072046*i,Brush.ge.n1=1.977998*t+-2.428592*e+.4505937*i,Brush.ge.n2=.02590403*t+.7827717*e+-.8086757*i,Brush.ge.n3=Brush.At.n3,Brush.ge.n0*=100}static AI(){Brush.ge.n0/=100;let t=.9999999*Brush.ge.n0+.3963377*Brush.ge.n1+.2158037*Brush.ge.n2,e=1.000000009*Brush.ge.n0+-.1055613*Brush.ge.n1+-.06385417*Brush.ge.n2,i=1.00000005*Brush.ge.n0+-.08948418*Brush.ge.n1+-1.291485*Brush.ge.n2;t=t**3,e=e**3,i=i**3,Brush.At.n0=1.2268798*t+-.5578149*e+.281391*i,Brush.At.n1=-.04057576*t+1.112286*e+-.07171106*i,Brush.At.n2=-.07637294*t+-.4214933*e+1.586924*i,Brush.At.n3=Brush.ge.n3}static TI(){const t=Math.atan2(Brush.ge.n2,Brush.ge.n1)*180/Math.PI;Brush.fo.n0=Brush.ge.n0,Brush.fo.n1=Math.sqrt(Brush.ge.n1**2+Brush.ge.n2**2),Brush.fo.n2=t>=0?t:t+360,Brush.fo.n3=Brush.ge.n3}static DI(){Brush.ge.n0=Brush.fo.n0,Brush.ge.n1=Brush.fo.n1*Math.cos(Brush.fo.n2*Math.PI/180),Brush.ge.n2=Brush.fo.n1*Math.sin(Brush.fo.n2*Math.PI/180),Brush.ge.n3=Brush.fo.n3}static SI(){Brush.lD(),Brush.LI(),Brush.TI()}static MI(){Brush.DI(),Brush.AI(),Brush.aD()}static Sd(t,e){typeof t=="string"||t instanceof Brush||U.o("Value for "+e+" must be a color string or a Brush, not "+t)}static Solid=1;static Linear=2;static Radial=3;static Pattern=4;static Lab=1;static HSL=2;static us=null;static S0=!1;static Y=new ColorNumbers;static ze=new ColorNumbers;static At=new ColorNumbers;static co=new ColorNumbers;static ge=new ColorNumbers;static fo=new ColorNumbers}class PanelLayout{Pt="Base";static fs=new GMap;static Tn(t,e){e.name=t,PanelLayout.fs.set(t,e)}get name(){return this.Pt}set name(t){this.Pt=t}constructor(){}get classType(){return Panel}measure(t,e,i,s,n,o,r){}measureElement(t,e,i,s,n){t.ht(e,i,s,n)}arrange(t,e,i){}arrangeElement(t,e,i,s,n,o){t.Ut(e,i,s,n,o)}remeasureObject(t){t.bf()}Ge(t,e,i){}}class PanelLayoutPosition extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){const l=s.length,a=t.$o();for(let h=0;h<l;h++){const c=s[h];if(!c.visible&&c!==a)continue;const f=c.margin,u=f.right+f.left,d=f.top+f.bottom;c.ht(e,i,o,r);const m=c.measuredBounds,g=Math.max(m.width+u,0),p=Math.max(m.height+d,0);let y=c.position.x,x=c.position.y;if(isFinite(y)||(y=0),isFinite(x)||(x=0),c instanceof Shape&&c.isGeometryPositioned){const k=c.strokeWidth/2;y-=k,x-=k}n.re(y,x,g,p)}}arrange(t,e,i){const s=e.length,n=t.padding,o=i.x-n.left,r=i.y-n.top;for(let l=0;l<s;l++){const a=e[l],h=a.measuredBounds,c=a.margin,f=a.position.x,u=a.position.y;let d=isNaN(f)?-o:f-o,m=isNaN(u)?-r:u-r;if(a instanceof Shape&&a.isGeometryPositioned){const g=a.strokeWidth/2;d-=g,m-=g}a.visible&&a.Ut(d+c.left,m+c.top,h.width,h.height)}}}PanelLayout.Tn("Position",new PanelLayoutPosition);class PanelLayoutHorizontal extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){const l=s.length,a=U.ot(),h=t.$o();for(let f=0;f<l;f++){const u=s[f];if(!u.visible&&u!==h)continue;const d=u.Qs(!1);if(d!==0&&d!==5){a.push(u);continue}u.ht(1/0,i,0,r);const m=u.margin,g=u.measuredBounds,p=Math.max(g.width+m.right+m.left,0),y=Math.max(g.height+m.top+m.bottom,0);n.jn(n.width+p,Math.max(n.height,y))}const c=a.length;t.desiredSize.height?i=Math.min(t.desiredSize.height,t.maxSize.height):n.height!==0&&(i=Math.min(n.height,t.maxSize.height));for(let f=0;f<c;f++){const u=a[f];if(!u.visible&&u!==h)continue;const d=u.margin,m=d.right+d.left,g=d.top+d.bottom;u.ht(1/0,i,0,r);const p=u.measuredBounds,y=Math.max(p.width+m,0),x=Math.max(p.height+g,0);n.width+=y,n.height=Math.max(n.height,x)}U.Z(a)}arrange(t,e,i){const s=e.length,n=t.padding,o=n.top,r=t.isOpposite;let l=r?i.width:n.left;for(let a=0;a<s;a++){const h=o,c=e[a];if(!c.visible)continue;const f=c.measuredBounds,u=c.margin,d=u.top+u.bottom,m=o+n.bottom;let g=f.height;const p=c.Qs(!1);(isNaN(c.desiredSize.height)&&p===2||p===4)&&(g=Math.max(i.height-d-m,0));const y=g+d+m;let x=c.alignment;x.isDefault()&&(x=t.defaultAlignment),x.isSpot()||(x=Spot.Center),r&&(l-=f.width+u.left+u.right),c.Ut(l+x.offsetX+u.left,h+x.offsetY+u.top+(i.height*x.y-y*x.y),f.width,g),r||(l+=f.width+u.left+u.right)}}}PanelLayout.Tn("Horizontal",new PanelLayoutHorizontal);class PanelLayoutVertical extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){const l=s.length,a=U.ot(),h=t.$o();for(let f=0;f<l;f++){const u=s[f];if(!u.visible&&u!==h)continue;const d=u.Qs(!1);if(d!==0&&d!==4){a.push(u);continue}u.ht(e,1/0,o,0);const m=u.margin,g=u.measuredBounds,p=Math.max(g.width+m.right+m.left,0),y=Math.max(g.height+m.top+m.bottom,0);n.jn(Math.max(n.width,p),n.height+y)}const c=a.length;t.desiredSize.width?e=Math.min(t.desiredSize.width,t.maxSize.width):n.width!==0&&(e=Math.min(n.width,t.maxSize.width));for(let f=0;f<c;f++){const u=a[f];if(!u.visible&&u!==h)continue;const d=u.margin,m=d.right+d.left,g=d.top+d.bottom;u.ht(e,1/0,o,0);const p=u.measuredBounds,y=Math.max(p.width+m,0),x=Math.max(p.height+g,0);n.width=Math.max(n.width,y),n.height+=x}U.Z(a)}arrange(t,e,i){const s=e.length,n=t.padding,o=n.left,r=t.isOpposite;let l=r?i.height:n.top;for(let a=0;a<s;a++){const h=o,c=e[a];if(!c.visible)continue;const f=c.measuredBounds,u=c.margin,d=u.left+u.right,m=o+n.right;let g=f.width;const p=c.Qs(!1);(isNaN(c.desiredSize.width)&&p===2||p===5)&&(g=Math.max(i.width-d-m,0));const y=g+d+m;let x=c.alignment;x.isDefault()&&(x=t.defaultAlignment),x.isSpot()||(x=Spot.Center),r&&(l-=f.height+u.bottom+u.top),c.Ut(h+x.offsetX+u.left+(i.width*x.x-y*x.x),l+x.offsetY+u.top,g,f.height),r||(l+=f.height+u.bottom+u.top)}}}PanelLayout.Tn("Vertical",new PanelLayoutVertical);class PanelLayoutSpot extends PanelLayout{constructor(){super()}static cD=!1;measure(t,e,i,s,n,o,r){const l=s.length;if(l===0)return;const a=t.findMainElement();let h=a.margin,c=0,f=0;const u=h.right+h.left,d=h.top+h.bottom;a.ht(e,i,o,r);let m=a.measuredBounds,g=m.width,p=m.height,y=Math.max(g+u,0),x=Math.max(p+d,0);const k=t.isClipping;k&&a.Hp()!==0&&!PanelLayoutSpot.cD&&(PanelLayoutSpot.cD=!0,U.ne("Main Shape for Spot Panel with isClipping = true must have a zero strokeWidth: "+t.toString()));const b=Rect.z(-h.left,-h.top,y,x);let P=Rect.z(0,0,g,p);this.XN(a,P,!0),g=P.width,p=P.height;let S=!0;const L=t.$o();let C;for(let M=0;M<l;M++){const N=s[M];let T=e,A=i;if(N===a||!N.visible&&N!==L)continue;h=N.margin;let D=h.left,v=h.top;switch(c=h.right+h.left,f=h.top+h.bottom,C=N.Qs(!1),C){case 2:T=g,A=p,c=0,f=0,D=0,v=0;break;case 5:T=g,c=0,D=0;break;case 4:A=p,f=0,v=0;break}N.ht(T,A,0,0),m=N.measuredBounds,y=Math.max(m.width+c,0),x=Math.max(m.height+f,0);let R=N.alignment;R.isDefault()&&(R=t.defaultAlignment),R.isSpot()||(R=Spot.Center);let F=N.alignmentFocus;F.isDefault()&&(F=Spot.Center);let O=null;N instanceof Panel&&N.uo!==""&&(O=N.findObject(N.uo),O===N&&(O=null));let z=P.x-D,Y=P.y-v;if(O!==null){N.Ut(0,0,m.width,m.height);const E=O.actualBounds,X=Point.z(E.x+(F.x*E.width-F.offsetX),E.y+(F.y*E.height-F.offsetY));for(O=O.panel;O!==null&&O!==N;)O.v.gt(X),O=O.panel;z+=R.x*g+R.offsetX-X.x,Y+=R.y*p+R.offsetY-X.y,Point.i(X)}else z+=R.x*g+R.offsetX-(F.x*m.width+F.offsetX),Y+=R.y*p+R.offsetY-(F.y*m.height+F.offsetY);S?(S=!1,n.e(z,Y,y,x)):n.re(z,Y,y,x)}switch(S?n.h(b):k?n.intersect(P.x,P.y,P.width,P.height):n.re(b.x,b.y,b.width,b.height),Rect.i(b),Rect.i(P),C=a.stretch,C===1&&(C=a.Qs(!1)),C){case 0:return;case 2:if(!isFinite(e)&&!isFinite(i))return;break;case 5:if(!isFinite(e))return;break;case 4:if(!isFinite(i))return;break}m=a.measuredBounds,g=m.width,p=m.height,y=Math.max(g+u,0),x=Math.max(p+d,0),h=a.margin,P=Rect.z(-h.left,-h.top,y,x),this.XN(a,P,!0),g=P.width,p=P.height;for(let M=0;M<l;M++){const N=s[M];if(N===a||!N.visible&&N!==L)continue;h=N.margin,c=h.right+h.left,f=h.top+h.bottom,m=N.measuredBounds,y=Math.max(m.width+c,0),x=Math.max(m.height+f,0);let T=N.alignment;T.isDefault()&&(T=t.defaultAlignment),T.isSpot()||(T=Spot.Center);let A=N.alignmentFocus;A.isDefault()&&(A=Spot.Center),S?(S=!1,n.e(T.x*g+T.offsetX-(A.x*m.width+A.offsetX)-h.left,T.y*p+T.offsetY-(A.y*m.height+A.offsetY)-h.top,y,x)):n.re(T.x*g+T.offsetX-(A.x*m.width+A.offsetX)-h.left,T.y*p+T.offsetY-(A.y*m.height+A.offsetY)-h.top,y,x)}S?n.h(b):k?n.intersect(P.x,P.y,P.width,P.height):n.re(b.x,b.y,b.width,b.height),Rect.i(P)}arrange(t,e,i){const s=e.length;if(s===0)return;const n=t.findMainElement(),o=n.measuredBounds,r=o.width,l=o.height,a=t.padding,h=a.left,c=a.top;let f=h-i.x,u=c-i.y;n.Ut(f,u,r,l);const d=Rect.z(0,0,r,l);this.XN(n,d,!1);for(let m=0;m<s;m++){const g=e[m];if(g===n)continue;const p=g.measuredBounds,y=p.width,x=p.height;let k=g.alignment;k.isDefault()&&(k=t.defaultAlignment),k.isSpot()||(k=Spot.Center);let b=g.alignmentFocus;b.isDefault()&&(b=Spot.Center);let P=null;if(g instanceof Panel&&g.uo!==""&&(P=g.findObject(g.uo),P===g&&(P=null)),P!==null){const S=P.actualBounds,L=Point.z(S.x+(b.x*S.width-b.offsetX),S.y+(b.y*S.height-b.offsetY));for(P=P.panel;P!==null&&P!==g;)P.v.gt(L),P=P.panel;f=k.x*d.width+k.offsetX-L.x,u=k.y*d.height+k.offsetY-L.y,Point.i(L)}else f=k.x*d.width+k.offsetX-(b.x*y+b.offsetX),u=k.y*d.height+k.offsetY-(b.y*x+b.offsetY);f+=d.x-i.x,u+=d.y-i.y,g.visible&&g.Ut(h+f,c+u,y,x)}Rect.i(d)}XN(t,e,i){let s=null;if(t instanceof Panel&&t.uo!==""&&(s=t.findObject(t.uo),s===t&&(s=null)),s!==null)for(i&&t.Ut(0,0,e.width,e.height),e.h(s.actualBounds),s=s.panel;s!==null&&s!==t;)s.v.im(e),s=s.panel}}PanelLayout.Tn("Spot",new PanelLayoutSpot);class PanelLayoutAuto extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){const l=s.length;if(l===0)return;const a=t.findMainElement();let h=a.margin,c=e,f=i;const u=h.right+h.left,d=h.top+h.bottom;a.ht(e,i,o,r);let m=a.measuredBounds,g=0,p=null;a instanceof Shape&&(p=a,g=p.strokeWidth*p.scale);let y=Math.max(m.width+u,0),x=Math.max(m.height+d,0),k=t.GN(a);const b=k.x*y+k.offsetX,P=k.y*x+k.offsetY;let S=t.YN(a);const L=S.x*y+S.offsetX,C=S.y*x+S.offsetY;isFinite(e)&&(c=Math.max(Math.abs(b-L)-g,0)),isFinite(i)&&(f=Math.max(Math.abs(P-C)-g,0));let M=0,N=0;o>0&&(M=Math.max(Math.abs(k.x*o+k.offsetX-(S.x*o+S.offsetX))-g,0)),r>0&&(N=Math.max(Math.abs(k.y*r+k.offsetY-(S.y*r+S.offsetY))-g,0));const T=Size.l();T.e(0,0);const A=t.$o();for(let F=0;F<l;F++){const O=s[F];if(O===a||!O.visible&&O!==A)continue;h=O.margin;const z=h.right+h.left,Y=h.top+h.bottom;O.ht(c,f,M,N),m=O.measuredBounds,y=Math.max(m.width+z,0),x=Math.max(m.height+Y,0),T.e(Math.max(y,T.width),Math.max(x,T.height))}if(l===1){m=a.measuredBounds,n.width=y,n.height=x,Size.i(T);return}k=t.GN(a),S=t.YN(a);let D=0,v=0;S.x!==k.x&&S.y!==k.y&&(D=T.width/Math.abs(S.x-k.x),v=T.height/Math.abs(S.y-k.y)),Size.i(T),g=0,p!==null&&(g=p.strokeWidth*p.scale,p.QS()===6&&(D=v=Math.max(D,v))),D+=Math.abs(k.offsetX)+Math.abs(S.offsetX)+g,v+=Math.abs(k.offsetY)+Math.abs(S.offsetY)+g;let R=a.stretch;switch(R===1&&(R=a.Qs(!1)),R){case 0:o=0,r=0;break;case 2:isFinite(e)&&(D=e),isFinite(i)&&(v=i);break;case 5:isFinite(e)&&(D=e),r=0;break;case 4:o=0,isFinite(i)&&(v=i);break}a.bf(),a.ht(D,v,o,r),n.width=a.measuredBounds.width+u,n.height=a.measuredBounds.height+d}arrange(t,e,i){const s=e.length;if(s===0)return;const n=t.findMainElement(),o=n.measuredBounds,r=Rect.l();r.e(0,0,1,1);let l=n.margin;const a=l.left,h=l.top,c=t.padding,f=c.left,u=c.top;let d=a,m=h,g=o.width,p=o.height;n.Ut(f+d,u+m,g,p);const y=t.GN(n),x=t.YN(n),k=0+y.x*o.width+y.offsetX,b=0+y.y*o.height+y.offsetY,P=0+x.x*o.width+x.offsetX,S=0+x.y*o.height+x.offsetY;r.x=k,r.y=b,r.re(P,S,0,0),r.x+=a+f,r.y+=h+u;for(let L=0;L<s;L++){const C=e[L];if(C===n)continue;const M=C.measuredBounds;l=C.margin;const N=Math.max(M.width+l.right+l.left,0),T=Math.max(M.height+l.top+l.bottom,0);let A=C.alignment;A.isDefault()&&(A=t.defaultAlignment),A.isSpot()||(A=Spot.Center),d=r.width*A.x+A.offsetX-N*A.x+l.left+r.x,m=r.height*A.y+A.offsetY-T*A.y+l.top+r.y,g=r.width,p=r.height,C.visible&&(Rect.contains(r.x,r.y,r.width,r.height,d,m,M.width,M.height)?C.Ut(d,m,M.width,M.height):C.Ut(d,m,M.width,M.height,new Rect(r.x,r.y,r.width,r.height)))}Rect.i(r)}}PanelLayout.Tn("Auto",new PanelLayoutAuto);class PanelLayoutTable extends PanelLayout{constructor(){super(),this.name="Table"}measure(t,e,i,s,n,o,r){let l=s.length;const a=U.ot(),h=U.ot();for(let K=0;K<l;K++){const I=s[K],q=I instanceof Panel?I:null;if(q!==null&&q.ol()&&I.visible){h.push(q);const Q=q.D.r,nt=Q.length;for(let et=0;et<nt;et++){const it=Q[et];q.type===Panel.TableRow?it.row=I.row:q.type===Panel.TableColumn&&(it.column=I.column),a.push(it)}}else a.push(I)}l=a.length,l===0&&(t.getRowDefinition(0),t.getColumnDefinition(0));const c=[];for(let K=0;K<l;K++){const I=a[K];I.visible&&(I.wi(!0),I.ao(!0),c[I.row]||(c[I.row]=[]),c[I.row][I.column]||(c[I.row][I.column]=[]),c[I.row][I.column].push(I))}U.Z(a);const f=U.ot(),u=U.ot(),d=U.ot(),m={count:0},g={count:0};let p=e,y=i;const x=t.Qi,k=t._i;let b;l=x.length;for(let K=0;K<l;K++)b=x[K],b!==void 0&&(b.actual=0,b.Re=0);l=k.length;for(let K=0;K<l;K++)b=k[K],b!==void 0&&(b.actual=0,b.Re=0);let P=c.length,S=0;for(let K=0;K<P;K++)c[K]&&(S=Math.max(S,c[K].length));const L=Math.min(t.topIndex,P-1),C=Math.min(t.leftIndex,S-1);let M=0,N;P=c.length;const T=t.$o();for(let K=0;K<P;K++){if(!c[K])continue;S=c[K].length;const I=t.getRowDefinition(K);I.actual=0,I.Re=0;for(let q=0;q<S;q++){if(!c[K][q])continue;const Q=t.getColumnDefinition(q);f[q]===void 0&&(Q.actual=0,Q.Re=0,f[q]=!0);const nt=c[K][q],et=nt.length;for(let it=0;it<et;it++){const st=nt[it];if(!st.visible&&st!==T)continue;const ut=st.rowSpan>1,lt=st.columnSpan>1;(ut||lt)&&!(K<L)&&!(q<C)&&u.push(st);const ht=st.margin,ot=ht.right+ht.left,rt=ht.top+ht.bottom;N=st.Zp(I,Q,!1);const ct=st.desiredSize,_=!isNaN(ct.width),dt=!isNaN(ct.height);if(N!==0&&!(_&&dt)&&!(K<L)&&!(q<C)&&(!lt&&m[q]===void 0&&(N===2||N===5)&&(m[q]=-1,m.count++),!ut&&g[K]===void 0&&(N===2||N===4)&&(g[K]=-1,g.count++),!ut&&!lt&&d.push(st)),st.ht(1/0,1/0,0,0),K<L||q<C)continue;const ft=st.measuredBounds,gt=Math.max(ft.width+ot,0),pt=Math.max(ft.height+rt,0);if(st.rowSpan===1&&(N===0||N===5)){b=t.getRowDefinition(K);const mt=b.computeEffectiveSpacing(),yt=b.j===0;M=Math.max(pt-b.actual,0),M+(yt?mt:0)>y&&(M=Math.max(y-mt,0)),b.Re=b.Re+M,b.actual=b.j+M,y=Math.max(y-(M+(yt?mt:0)),0)}if(st.columnSpan===1&&(N===0||N===4)){b=t.getColumnDefinition(q);const mt=b.computeEffectiveSpacing(),yt=b.j===0;M=Math.max(gt-b.actual,0),M+(yt?mt:0)>p&&(M=Math.max(p-mt,0)),b.Re=b.Re+M,b.actual=b.j+M,p=Math.max(p-(M+(yt?mt:0)),0)}(ut||lt)&&st.bf()}}}U.Z(f);let A=0,D=0;l=t.columnCount;for(let K=0;K<l;K++){const I=k[K];I!==void 0&&(A+=isNaN(I.bi)?I.Re:I.bi,I.Re!==0&&(A+=I.computeEffectiveSpacing()))}l=t.rowCount;for(let K=0;K<l;K++){const I=x[K];I!==void 0&&(D+=isNaN(I.bi)?I.Re:I.bi,I.Re!==0&&(D+=I.computeEffectiveSpacing()))}p=Math.max(e-A,0),y=Math.max(i-D,0);let v=y,R=p;l=d.length;for(let K=0;K<l;K++){const I=d[K],q=t.getRowDefinition(I.row),Q=t.getColumnDefinition(I.column),nt=I.measuredBounds,et=I.margin,it=et.right+et.left,st=et.top+et.bottom;Q.Re===0&&m[I.column]!==void 0?m[I.column]=Math.max(nt.width+it,m[I.column]):m[I.column]=null,q.Re===0&&g[I.row]!==void 0?g[I.row]=Math.max(nt.height+st,g[I.row]):g[I.row]=null}let F=0,O=0,z;for(z in g)z!=="count"&&(F+=g[z]);for(z in m)z!=="count"&&(O+=m[z]);const Y=Size.l();for(let K=0;K<l;K++){const I=d[K];if(!I.visible&&I!==T)continue;const q=t.getRowDefinition(I.row),Q=t.getColumnDefinition(I.column);let nt=0;isFinite(Q.width)?nt=Q.width:(isFinite(p)&&m[I.column]!==null?O===0?nt=Q.actual+p:nt=m[I.column]/O*R:m[I.column]!==null?nt=p:nt=Q.actual||p,nt=Math.max(0,nt-Q.computeEffectiveSpacing()));let et=0;switch(isFinite(q.height)?et=q.height:(isFinite(y)&&g[I.row]!==null?F===0?et=q.actual+y:et=g[I.row]/F*v:g[I.row]!==null?et=y:et=q.actual||y,et=Math.max(0,et-q.computeEffectiveSpacing())),Y.e(Math.max(Q.minimum,Math.min(nt,Q.maximum)),Math.max(q.minimum,Math.min(et,q.maximum))),N=I.Zp(q,Q,!1),N){case 5:Y.height=Math.max(Y.height,q.actual+y);break;case 4:Y.width=Math.max(Y.width,Q.actual+p);break}const it=I.margin,st=it.right+it.left,ut=it.top+it.bottom;I.bf();let lt=Q.minimum,ht=q.minimum;const ot=I.measuredBounds;ot.width===0&&m[I.column]!==null&&(lt=Math.max(lt,m[I.column])),ot.height===0&&g[I.row]!==null&&(ht=Math.max(lt,g[I.row])),I.ht(Y.width,Y.height,lt,ht);const rt=I.measuredBounds;let ct=Math.max(rt.width+st,0),_=Math.max(rt.height+ut,0);isFinite(p)&&(ct=Math.min(ct,Y.width)),isFinite(y)&&(_=Math.min(_,Y.height));let dt=0;dt=q.actual,q.actual=Math.max(q.actual,_),q.Re=Math.max(q.Re,_),M=q.actual-dt,y=Math.max(y-M,0),g[I.row]===null&&(v=Math.max(v-M,0)),dt=Q.actual,Q.actual=Math.max(Q.actual,ct),Q.Re=Math.max(Q.Re,ct),M=Q.actual-dt,p=Math.max(p-M,0),m[I.column]===null&&(R=Math.max(R-M,0))}U.Z(d);const E=Size.l(),X=U.ot(),B=U.ot();if(l=u.length,l!==0)for(let K=0;K<P;K++){if(!c[K])continue;S=c[K].length;const I=t.getRowDefinition(K);X[K]=I.actual;for(let q=0;q<S;q++){if(!c[K][q])continue;const Q=t.getColumnDefinition(q);B[q]=Q.actual}}for(let K=0;K<l;K++){const I=u[K];if(!I.visible&&I!==T)continue;const q=t.getRowDefinition(I.row),Q=t.getColumnDefinition(I.column);switch(Y.e(Math.max(Q.minimum,Math.min(e,Q.maximum)),Math.max(q.minimum,Math.min(i,q.maximum))),N=I.Zp(q,Q,!1),N){case 2:B[Q.index]!==0&&(Y.width=Math.min(Y.width,B[Q.index])),X[q.index]!==0&&(Y.height=Math.min(Y.height,X[q.index]));break;case 5:B[Q.index]!==0&&(Y.width=Math.min(Y.width,B[Q.index]));break;case 4:X[q.index]!==0&&(Y.height=Math.min(Y.height,X[q.index]));break}isFinite(Q.width)&&(Y.width=Q.width),isFinite(q.height)&&(Y.height=q.height),E.e(0,0);let nt=Q.minimum,et=q.minimum;for(let _=1;_<I.rowSpan&&!(I.row+_>=t.rowCount);_++){if(b=t.getRowDefinition(I.row+_),M=0,N===2||N===4){if(b.j===0)continue;M=Math.max(b.minimum,b.j===0?b.maximum:Math.min(b.j,b.maximum))}else M=Math.max(b.minimum,isNaN(b.bi)?b.maximum:Math.min(b.bi,b.maximum));E.height+=M,et+=b.minimum}for(let _=1;_<I.columnSpan&&!(I.column+_>=t.columnCount);_++){if(b=t.getColumnDefinition(I.column+_),M=0,N===2||N===5){if(b.j===0)continue;M=Math.max(b.minimum,b.j===0?b.maximum:Math.min(b.j,b.maximum))}else M=Math.max(b.minimum,isNaN(b.bi)?b.maximum:Math.min(b.bi,b.maximum));E.width+=M,nt+=b.minimum}Y.width+=E.width,Y.height+=E.height;const it=I.margin,st=it.right+it.left,ut=it.top+it.bottom;I.ht(Y.width,Y.height,nt,et);const lt=I.measuredBounds,ht=Math.max(lt.width+st,0),ot=Math.max(lt.height+ut,0);let rt=0;for(let _=0;_<I.rowSpan&&!(I.row+_>=t.rowCount);_++)b=t.getRowDefinition(I.row+_),rt+=b.total||0;if(rt<ot){let _=ot-rt;const dt=ot-rt;if(I.spanAllocation!==null){const at=I.spanAllocation;for(let ft=0;ft<I.rowSpan&&!(_<=0||I.row+ft>=t.rowCount);ft++){b=t.getRowDefinition(I.row+ft);const gt=b.j||0,pt=at(I,b,dt);b.actual=Math.min(b.maximum,gt+pt),b.j!==gt&&(_-=b.j-gt)}}for(;_>0&&b!==void 0;){const at=b.j||0;if(isNaN(b.height)&&b.maximum>at&&(b.actual=Math.min(b.maximum,at+_),b.j!==at&&(_-=b.j-at)),b.index===0)break;b=t.getRowDefinition(b.index-1)}}let ct=0;for(let _=0;_<I.columnSpan&&!(I.column+_>=t.columnCount);_++)b=t.getColumnDefinition(I.column+_),ct+=b.total||0;if(ct<ht){let _=ht-ct;const dt=ht-ct;if(I.spanAllocation!==null){const at=I.spanAllocation;for(let ft=0;ft<I.columnSpan&&!(_<=0||I.column+ft>=t.columnCount);ft++){b=t.getColumnDefinition(I.column+ft);const gt=b.j||0,pt=at(I,b,dt);b.actual=Math.min(b.maximum,gt+pt),b.j!==gt&&(_-=b.j-gt)}}for(;_>0&&b!==void 0;){const at=b.j||0;if(isNaN(b.width)&&b.maximum>at&&(b.actual=Math.min(b.maximum,at+_),b.j!==at&&(_-=b.j-at)),b.index===0)break;b=t.getColumnDefinition(b.index-1)}}}U.Z(u),Size.i(E),Size.i(Y),X!==void 0&&U.Z(X),B!==void 0&&U.Z(B);let H=0,j=0;const W=t.desiredSize,Z=t.maxSize;N=t.Qs(!0),A=0,D=0;let V=0,$=0;l=t.columnCount;for(let K=0;K<l;K++)if(k[K]!==void 0){if(b=t.getColumnDefinition(K),isFinite(b.width)){V+=b.width,V+=b.computeEffectiveSpacing();continue}else if(b.j1()===2){V+=b.j,V+=b.computeEffectiveSpacing();continue}b.j!==0&&(A+=b.j,A+=b.computeEffectiveSpacing())}isFinite(W.width)?H=Math.min(W.width,Z.width):N!==0&&isFinite(e)?H=e:H=A,H=Math.max(H,isFinite(e)?Math.min(o,e):o),H=Math.max(H-V,0);const J=A===0?1:Math.max(H/A,1);for(let K=0;K<l;K++)k[K]!==void 0&&(b=t.getColumnDefinition(K),!isFinite(b.width)&&b.j1()!==2&&(b.actual=b.j*J),b.position=n.width,b.j!==0&&(n.width+=b.j,n.width+=b.computeEffectiveSpacing()));l=t.rowCount;for(let K=0;K<l;K++)if(x[K]!==void 0){if(b=t.getRowDefinition(K),isFinite(b.height)){$+=b.height,$+=b.computeEffectiveSpacing();continue}else if(b.j1()===2){$+=b.j,$+=b.computeEffectiveSpacing();continue}b.j!==0&&(D+=b.j,D+=b.computeEffectiveSpacing())}isFinite(W.height)?j=Math.min(W.height,Z.height):N!==0&&isFinite(i)?j=i:j=D,j=Math.max(j,isFinite(i)?Math.min(r,i):r),j=Math.max(j-$,0);const tt=D===0?1:Math.max(j/D,1);for(let K=0;K<l;K++)x[K]!==void 0&&(b=t.getRowDefinition(K),!isFinite(b.height)&&b.j1()!==2&&(b.actual=b.j*tt),b.position=n.height,b.j!==0&&(n.height+=b.j,n.height+=b.computeEffectiveSpacing()));l=h.length;for(let K=0;K<l;K++){const I=h[K];let q=0,Q=0;I.type===Panel.TableRow?(q=n.width,b=t.getRowDefinition(I.row),Q=b.actual):(b=t.getColumnDefinition(I.column),q=b.actual,Q=n.height),I.measuredBounds.e(0,0,q,Q),I.wi(!1)}U.Z(h),t.La=c}arrange(t,e,i){const s=e.length,n=t.padding,o=n.left,r=n.top,l=t.La;if(l===null)return;let a=0,h=0;const c=l.length;let f=0;for(let C=0;C<c;C++)l[C]&&(f=Math.max(f,l[C].length));const u=t.Qi,d=t._i;let m=0,g=0,p=Math.min(t.topIndex,c-1);if(u.length>0){for(;p!==c&&(u[p]===void 0||u[p].j===0);)p++;p=Math.max(Math.min(p,c-1),0),m=-u[p].position}let y=Math.min(t.leftIndex,f-1);if(d.length>0){for(;y!==f&&(d[y]===void 0||d[y].j===0);)y++;y=Math.max(Math.min(y,f-1),0),g=-d[y].position}let x=0,k=0;for(;x!==c&&u[x]===void 0;)x++;for(;k!==c&&d[k]===void 0;)k++;const b=t.part;let P=t.getRowDefinition(x),S=t.getColumnDefinition(k);for(let C=0;C<e.length;C++){const M=e[C];if(!(M instanceof Panel&&M.visible&&M.ol()))continue;M.type===Panel.TableRow?(P=t.getRowDefinition(M.row),S=t.getColumnDefinition(k)):(P=t.getRowDefinition(x),S=t.getColumnDefinition(M.column)),h=P.position+m+r,P.j!==0&&(h+=P.computeEffectiveSpacingTop(Math.max(x,p))),a=S.position+g+o,S.j!==0&&(a+=S.computeEffectiveSpacingTop(Math.max(k,y)));const N=M.measuredBounds;M.pf(),M.actualBounds.ce();const T=M.actualBounds,A=Rect.z(T.x,T.y,T.width,T.height);if(T.x=M.type===Panel.TableRow?o:a,T.y=M.type===Panel.TableColumn?r:h,T.width=N.width,T.height=N.height,M.actualBounds.b(),M.ao(!1),A.equalsApproxClose(T)){Rect.i(A);continue}b!==null&&(b.Sa(),M.qp(b)),Rect.i(A)}const L=Size.l();for(let C=0;C<c;C++){if(!l[C])continue;f=l[C].length;const M=t.getRowDefinition(C);h=M.position+m+r,M.j!==0&&(h+=M.computeEffectiveSpacingTop(Math.max(x,p)));for(let N=0;N<f;N++){if(!l[C][N])continue;const T=t.getColumnDefinition(N);a=T.position+g+o,T.j!==0&&(a+=T.computeEffectiveSpacingTop(Math.max(k,y)));const A=l[C][N],D=A.length;for(let v=0;v<D;v++){const R=A[v],F=R.measuredBounds;L.e(0,0);for(let ot=1;ot<R.rowSpan&&!(C+ot>=t.rowCount);ot++){const rt=t.getRowDefinition(C+ot);rt.j!==0&&(L.height+=rt.total)}for(let ot=1;ot<R.columnSpan&&!(N+ot>=t.columnCount);ot++){const rt=t.getColumnDefinition(N+ot);rt.j!==0&&(L.width+=rt.total)}const O=T.j+L.width,z=M.j+L.height;let Y=a,E=h;const X=O,B=z,H=a,j=h;let W=O,Z=z;a+O>i.width&&(W=Math.max(i.width-a,0)),h+z>i.height&&(Z=Math.max(i.height-h,0));let V=R.alignment,$=0,J=0,tt=0,K=0;if(V.isDefault()){V=t.defaultAlignment,V.isSpot()||(V=Spot.Center),$=V.x,J=V.y,tt=V.offsetX,K=V.offsetY;const ot=T.alignment,rt=M.alignment;ot.isSpot()&&($=ot.x,tt=ot.offsetX),rt.isSpot()&&(J=rt.y,K=rt.offsetY)}else $=V.x,J=V.y,tt=V.offsetX,K=V.offsetY;(isNaN($)||isNaN(J))&&($=.5,J=.5,tt=0,K=0);let I=F.width,q=F.height;const Q=R.margin,nt=Q.left+Q.right,et=Q.top+Q.bottom,it=R.Zp(M,T,!1);isNaN(R.desiredSize.width)&&(it===2||it===5)&&(I=Math.max(O-nt,0)),isNaN(R.desiredSize.height)&&(it===2||it===4)&&(q=Math.max(z-et,0));const st=R.maxSize,ut=R.minSize;I=Math.min(st.width,I),q=Math.min(st.height,q),I=Math.max(ut.width,I),q=Math.max(ut.height,q);const lt=I+nt,ht=q+et;Y+=X*$-lt*$+tt+Q.left,E+=B*J-ht*J+K+Q.top,R.visible&&(Rect.contains(H,j,W,Z,Y,E,F.width,F.height)?R.Ut(Y,E,I,q):R.Ut(Y,E,I,q,new Rect(H,j,W,Z)))}}}Size.i(L);for(let C=0;C<s;C++){const M=e[C],N=M instanceof Panel?M:null;if(N!==null&&N.ol()){const T=M.actualBounds;M.naturalBounds.ce(),M.naturalBounds.e(0,0,T.width,T.height),M.naturalBounds.b()}}}}PanelLayout.Tn("Table",new PanelLayoutTable);class PanelLayoutTableRow extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){}arrange(t,e,i){}}PanelLayout.Tn("TableRow",new PanelLayoutTableRow);class PanelLayoutTableColumn extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){}arrange(t,e,i){}}PanelLayout.Tn("TableColumn",new PanelLayoutTableColumn);class PanelLayoutViewbox extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){s.length!==1&&U.o("Viewbox Panel must contain exactly one GraphObject.");const a=s[0];a.it=1,a.bf(),a.ht(1/0,1/0,o,r);let h=a.measuredBounds;const c=a.margin,f=c.right+c.left,u=c.top+c.bottom;if(isFinite(e)||isFinite(i)){const d=a.scale,m=h.width,g=h.height,p=Math.max(e-f,0),y=Math.max(i-u,0);let x=1;t.viewboxStretch===6?(m!==0&&g!==0&&(x=Math.min(p/m,y/g)),x===0&&(x=1e-4),a.it*=x):(m!==0&&g!==0&&(x=Math.max(p/m,y/g)),x===0&&(x=1e-4),a.it*=x),d!==a.scale&&(a.wi(!0),a.ht(1/0,1/0,o,r))}h=a.measuredBounds,n.width=isFinite(e)?e:Math.max(h.width+f,0),n.height=isFinite(i)?i:Math.max(h.height+u,0)}arrange(t,e,i){const s=e[0],n=s.measuredBounds,o=s.margin,r=o.right+o.left,l=o.top+o.bottom,a=Math.max(n.width+r,0),h=Math.max(n.height+l,0);let c=s.alignment;c.isDefault()&&(c=t.defaultAlignment),c.isSpot()||(c=Spot.Center),s.Ut(i.width*c.x-a*c.x+c.offsetX,i.height*c.y-h*c.y+c.offsetY,n.width,n.height)}}PanelLayout.Tn("Viewbox",new PanelLayoutViewbox);class PanelLayoutGrid extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){t.Pe===null&&(t.Pe=new GridPanelSettings),this.vI(t),this.FI(t)}arrange(t,e,i){}Ge(t,e,i){const s=t.naturalBounds;e.save(),e.beginPath(),e.rect(0,0,s.width,s.height),e.clip(),e.endPath(),this.RI(t,e,i),e.restore(),e.clearContextCache(!1)}RI(t,e,i){let s=t.getDocumentScale()*i.scale;s<=0&&(s=1);const n=t.gridCellSize,o=n.width,r=n.height,l=t.naturalBounds,a=t.actualBounds,h=l.width,c=l.height,f=Math.ceil(h/o),u=Math.ceil(c/r),d=t.gridOrigin,m=d.x,g=d.y,p=t.Pe.M0,y=t.D.r,x=y.length;for(let k=0;k<x;k++){const b=y[k];if(!b.visible)continue;const P=b.interval||1,S=Math.abs(P);if(o*S*s<2)continue;let L=b.segmentIndex;(!isFinite(L)||isNaN(L))&&(L=0),L<0&&(L=S-Math.min(-L,S)),L=Math.round(L%S);const C=b.opacity;let M=1;if(C!==1){if(C===0)continue;M=e.globalAlpha,e.globalAlpha=M*C}const N=p[k];let T=!1;const A=b.strokeDashArray;if(A!==null&&(T=!0,e.enableDash(A,b.strokeDashOffset)),b.stroke!==null&&b.strokeWidth>0&&(b.figure==="LineV"||b.figure==="LineH")){if(e.lineWidth=b.strokeWidth,t.kn(e,b.stroke,!1,!1,l,a),e.beginPath(),b.figure==="LineV"){const D=Math.floor((m-o)/o);for(let v=D;v<=D+f;v++){const R=v*o+m;0<=R&&R<=h&&this.q1(v,P,L,N)&&(e.moveTo(R,0),e.lineTo(R,c))}}else if(b.figure==="LineH"){const D=Math.floor((g-r)/r);for(let v=D;v<=D+u;v++){const R=v*r+g;0<=R&&R<=c&&this.q1(v,P,L,N)&&(e.moveTo(0,R),e.lineTo(h,R))}}e.stroke(),e.endPath()}else if(b.fill!==null){if(t.kn(e,b.fill,!0,!1,l,a),b.figure==="BarV"){let D=b.width;isNaN(D)&&(D=o);const v=Math.floor((m-o)/o);for(let R=v;R<=v+f;R++){const F=R*o+m;0<=F+D&&F<=h&&this.q1(R,P,L,N)&&e.fillRect(F,0,D,c)}}else if(b.figure==="BarH"){let D=b.height;isNaN(D)&&(D=r);const v=Math.floor((g-r)/r);for(let R=v;R<=v+u;R++){const F=R*r+g;0<=F+D&&F<=c&&this.q1(R,P,L,N)&&e.fillRect(0,F,h,D)}}}T&&e.disableDash(),C!==1&&(e.globalAlpha=M)}}q1(t,e,i,s){if(e<0)return t%e===i;if(t%e!==i)return!1;const n=s.length;for(let o=0;o<n;o++){const r=s[o];if(t%r===i)return!1}return!0}FI(t){const e=[],i=t.D.r,s=i.length;for(let n=0;n<s;n++){const o=i[n],r=[];if(e.push(r),!o.visible)continue;const l=o.interval;if(l<0)continue;const a=o.figure,h=this.KN(a);for(let c=0;c<s;c++){if(c===n)continue;const f=i[c];if(!f.visible)continue;const u=f.figure;if(this.KN(u)!==h)continue;const d=f.interval;d>l&&r.push(d)}}t.Pe.M0=e}KN(t){return t==="LineV"||t==="BarV"}vI(t){let e=1,i=1;const s=t.D.r,n=s.length;for(let l=0;l<n;l++){const a=s[l],h=Math.abs(a.interval);h<2||(this.KN(a.figure)?i=i*h/G.HL(i,h):e=e*h/G.HL(e,h))}const o=t.gridCellSize,r=t.Pe;r.lf.isReal()?r.lf.e(i*o.width,e*o.height):r.lf=new Size(i*o.width,e*o.height)}}PanelLayout.Tn("Grid",new PanelLayoutGrid);class PanelLayoutLink extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){const l=s.length;if(!(t instanceof Adornment||t instanceof Link))return;let a=null,h=null;if(t instanceof Link&&(a=t),t instanceof Adornment&&(h=t,a=h.adornedPart,t.Lf===null&&(t.Lf=[])),!(a instanceof Link))return;const c=a;if(l===0){t.naturalBounds.jn(0,0),t.measuredBounds.e(0,0,0,0);return}const f=t instanceof Adornment?null:a.path,u=a.routeBounds,d=t.Zo;d.e(0,0,u.width,u.height);const m=c.points,g=a.pointsCount;h!==null?h.Ad(!1):a!==null&&a.Ad(!1);const p=u.width,y=u.height,x=t.Lf;if(x.length=0,f!==null){this.measureLinkPath(t,p,y,f);const S=f.measuredBounds;d.unionRect(S),x.push(S)}const k=Transform.l(),b=Point.l(),P=Point.l();for(let S=0;S<l;S++){const L=s[S];if(L===f)continue;let C=L.measuredBounds;if(L.isPanelMain&&L instanceof Shape){this.measureLinkPath(t,p,y,L),C=L.measuredBounds,d.unionRect(C),x.push(C);continue}if(g<2){L.ht(1/0,1/0,0,0),C=L.measuredBounds,d.unionRect(C),x.push(C);continue}const M=L.segmentIndex,N=L.segmentFraction;let T=L.alignmentFocus;T.isNoSpot()&&(T=Spot.Center);const A=L.segmentOrientation,D=L.segmentOffset;let v=0,R=0,F=0,O=0;if(isNaN(M)){const V=c.ut,$=U.ot();V.getPointAndAngleAlongPath(N,$);const J=Point.z($[0],$[1]);O=$[2],A!==0&&(F=c.computeAngle(L,A,O),L.Xt=F,L.wi(!0),L.ao(!0)),v=J.x,R=J.y,Point.i(J),U.Z($)}else if(M<-g||M>=g){const V=Point.l();c.HN(V),O=c.midAngle,A!==0&&(F=c.computeAngle(L,A,O),L.Xt=F,L.wi(!0),L.ao(!0)),v=V.x-u.x,R=V.y-u.y,Point.i(V)}else{let V,$,J=0;if(M>=0?(V=m.elt(M),$=M<g-1?m.elt(M+1):V):(J=g+M,V=m.elt(J),$=J>0?m.elt(J-1):V),V.equalsApprox($)){let tt,K;M>=0?(tt=M>0?m.elt(M-1):V,K=M<g-2?m.elt(M+2):$):(tt=J<g-1?m.elt(J+1):V,K=J>1?m.elt(J-2):$);const I=tt.distanceSquaredPoint(V),q=$.distanceSquaredPoint(K);I>q+10?O=M>=0?tt.directionPoint(V):V.directionPoint(tt):q>I+10?O=M>=0?$.directionPoint(K):K.directionPoint($):O=M>=0?tt.directionPoint(K):K.directionPoint(tt)}else O=M>=0?V.directionPoint($):$.directionPoint(V);A!==0&&(F=c.computeAngle(L,A,O),L.Xt=F,L.wi(!0),L.ao(!0)),v=V.x+($.x-V.x)*N-u.x,R=V.y+($.y-V.y)*N-u.y}L.ht(1/0,1/0,0,0),C=L.measuredBounds;const z=L.naturalBounds;let Y=0;L instanceof Shape&&(Y=L.strokeWidth);const E=z.width+Y,X=z.height+Y;k.Ue(),k.Gs(-C.x,-C.y),k.it(L.scale,L.scale),k.ks(A===0?L.angle:O,E/2,X/2),(A===22||A===26)&&k.ks(90,E/2,X/2),(A===23||A===27)&&k.ks(-90,E/2,X/2),A===28&&(O>45&&O<135||O>225&&O<315)&&k.ks(-O,E/2,X/2);const B=new Rect(0,0,E,X);b.setRectSpot(B,T),k.gt(b);const H=-b.x+Y/2*L.scale,j=-b.y+Y/2*L.scale;P.h(D);const W=isNaN(D.x),Z=isNaN(D.y);if(W||Z){const V=E/2+Link.W1,$=X/2+Link.W1,J=O>=45&&O<=135,tt=O>=225&&O<=315;A===0&&(J||tt)?(P.x=Z?V:D.y,P.y=W?$:D.x,J?M>=0||isNaN(M)&&N<.5||W&&(P.y=-$):tt&&((M>=0||isNaN(M)&&N<.5)&&W&&(P.y=-$),Z&&(P.x=-V))):(W&&(M>=0||isNaN(M)&&N<.5?P.x=V:P.x=-V),Z&&(P.y=-$),P.rotate(O))}else P.rotate(O);v+=P.x,R+=P.y,B.e(v+H,R+j,C.width,C.height),x.push(B),d.unionRect(B)}if(a!==null){const S=a.labelNodes;for(;S.next();)S.value.ht(1/0,1/0)}t.Zo=d,t.position.e(u.x+d.x,u.y+d.y),n.jn(d.width||0,d.height||0),Transform.i(k),Point.i(b),Point.i(P)}arrange(t,e,i){const s=e.length;if(!(t instanceof Adornment||t instanceof Link))return;let n=t,o=null;t instanceof Adornment&&(o=t,n=o.adornedPart);const r=t,l=t instanceof Adornment?null:n.path,a=t.Lf;if(a.length!==0){let u=0;if(l!==null&&u<a.length){const d=a[u];u++,l.Ut(d.x-r.Zo.x,d.y-r.Zo.y,d.width,d.height)}for(let d=0;d<s;d++){const m=e[d];if(m!==l&&u<a.length){const g=a[u];u++,m.Ut(g.x-r.Zo.x,g.y-r.Zo.y,g.width,g.height)}}}const h=n.points,c=h.count;if(c>=2&&r instanceof Link){const u=r.labelNodes;for(;u.next();){const d=u.value;r.OI(d,c,h)}}o!==null?o.Ad(!1):n.Ad(!1);const f=t.fD(Point.l());t.location.e(t.position.x+f.x,t.position.y+f.y),Point.i(f)}measureLinkPath(t,e,i,s){if(s.Go()===!1)return;let n=s.strokeWidth;if(n===0&&t instanceof Adornment&&t.type===Panel.Link&&t.adornedObject instanceof Shape&&(n=t.adornedObject.strokeWidth),n=n*s.it,t instanceof Link&&t.ut!==null){const o=t.geometry.bounds;s.lo(o.x-n/2,o.y-n/2,o.width+n,o.height+n)}else if(t instanceof Adornment&&t.adornedPart.ut!==null){const o=t.adornedPart.ut.bounds;s.lo(o.x-n/2,o.y-n/2,o.width+n,o.height+n)}else s.lo(-(n/2),-(n/2),e+n,i+n);s.II(),s.wi(!1)}}PanelLayout.Tn("Link",new PanelLayoutLink);class PanelLayoutGraduated extends PanelLayout{constructor(){super()}measure(t,e,i,s,n,o,r){const l=t.findMainElement();if(!(l instanceof Shape))return;t.ts=[];const a=l.margin,h=a.right+a.left,c=a.top+a.bottom;l.ht(e,i,o,r);const f=l.measuredBounds,u=f.width,d=f.height,m=Math.max(u+h,0),g=Math.max(d+c,0),p=new Rect(-a.left,-a.top,m,g);t.ts.push(p),n.h(p),this.determineGraduatedMarks(t,l);const y=t.Fs;if(y===null)return;const x=s.length;for(let k=0;k<x;k++){const b=s[k],P=y[k];!b.visible||b===l||P.length===0||(b instanceof Shape?this.measureGraduatedTicks(t,b,P,n):b instanceof TextBlock&&this.measureGraduatedLabels(t,b,P,n),b.wi(!1))}}arrange(t,e,i){if(t.ts===null)return;const s=t.findMainElement(),n=t.Fs;if(n===null)return;const o=t.ts;let r=0,l=o[r];r++,s!==null&&s.Ut(l.x-i.x,l.y-i.y,l.width,l.height);const a=e.length;for(let h=0;h<a;h++){const c=e[h],f=n[h];!c.visible||c===s||f.length===0||(l=o[r],r++,c.Ut(l.x-i.x,l.y-i.y,l.width,l.height))}t.ts=null}measureGraduatedTicks(t,e,i,s){let n=e.alignmentFocus;n.isNoSpot()&&(n=Spot.TopCenter);const o=e.angle;e.Xt=0,e.ht(1/0,1/0,0,0),e.Xt=o;const r=e.measuredBounds,l=r.width,a=r.height,h=Rect.z(0,0,l,a),c=Point.l();c.setRectSpot(h,n),Rect.i(h);const f=-c.x,u=-c.y,d=new Rect,m=i.length;for(let g=0;g<m;g++){const p=i[g],y=p.pt.x,x=p.pt.y,k=p.angle;for(let b=0;b<4;b++){switch(b){case 0:c.e(f,u);break;case 1:c.e(f+l,u);break;case 2:c.e(f,u+a);break;case 3:c.e(f+l,u+a);break}c.rotate(k+e.angle),c.offset(y,x),g===0&&b===0?d.e(c.x,c.y,0,0):d.unionPoint(c),c.offset(-y,-x),c.rotate(-k-e.angle)}}Point.i(c),t.ts!==null&&t.ts.push(d),s.re(d.x,d.y,d.width,d.height)}measureGraduatedLabels(t,e,i,s){t.vi===null&&(t.vi=new TextBlock);const n=t.vi;this.uD(e,n);let o=e.alignmentFocus;o.isNoSpot()&&(o=Spot.TopCenter);const r=e.segmentOrientation,l=e.segmentOffset,a=new Rect;let h=0,c=0,f=0,u=0,d=0;const m=i.length;for(let g=0;g<m;g++){const p=i[g];h=p.pt.x,c=p.pt.y,f=p.angle,u=e.angle,d=e.angle,r!==0&&(r===21||r===25?d=f+e.angle:d=f,u=Link.computeAngle(r,d)),n.Xt=u,n.text=p.text||"",n.ht(1/0,1/0,0,0);const y=n.measuredBounds,x=n.naturalBounds,k=x.width,b=x.height,P=Transform.l();P.Ue(),P.Gs(-y.x,-y.y),P.it(n.scale,n.scale),P.ks(d,k/2,b/2),(r===22||r===26)&&P.ks(90,k/2,b/2),(r===23||r===27)&&P.ks(-90,k/2,b/2),r===28&&(f>45&&f<135||f>225&&f<315)&&P.ks(-f,k/2,b/2);const S=Rect.z(0,0,k,b),L=Point.l();L.setRectSpot(S,o),P.gt(L);const C=-L.x,M=-L.y,N=Point.l();N.h(l),isNaN(N.x)&&(N.x=k/2+3),isNaN(N.y)&&(N.y=-(b/2+3)),N.rotate(f),h+=N.x+C,c+=N.y+M;const T=new Rect(h,c,y.width,y.height),A=new Rect(y.x,y.y,y.width,y.height),D=new Rect(x.x,x.y,x.width,x.height);p.labelAngle=u,p.lineCount=n.lineCount,p.lines=n.getMetrics(),p.actualBounds=T,p.measuredBounds=A,p.naturalBounds=D,g===0?a.h(T):a.unionRect(T),Point.i(N),Point.i(L),Rect.i(S),Transform.i(P)}t.ts!==null&&t.ts.push(a),s.re(a.x,a.y,a.width,a.height)}determineGraduatedMarks(t,e){const i=e.geometry,s=e.strokeWidth,n=i.flattenedSegments,o=i.flattenedLengths,r=i.flattenedTotalLength,l=n.length;let a=0,h=0;const c=U.ot();for(let x=0;x<l;x++){const k=n[x],b=[];a=0,h=0;const P=k.length;for(let S=0;S<P;S+=2){const L=k[S],C=k[S+1];if(S===0){a=L,h=C;continue}let M=Math.atan2(C-h,L-a)*180/Math.PI;M<0&&(M+=360),b.push(M),a=L,h=C}c.push(b)}const f=this.EI(t),u=t.D.r,d=u.length;let m=0,g=0,p=r;t.Fs=[];let y;for(let x=0;x<d;x++){const k=u[x];if(y=[],!k.visible||k===e){t.Fs.push(y);continue}const b=Math.abs(k.interval),P=t.graduatedTickUnit;if(P*b*r/t.graduatedRange<2&&k.graduatedSkip===null){t.Fs.push(y);continue}let S=o[0][0],L=0,C=0;g=r*k.graduatedStart-1e-4,p=r*k.graduatedEnd+1e-4;const M=P*b;let N=t.graduatedTickBase;if(N<t.graduatedMin){let v=(t.graduatedMin-N)/M;v=v%1===0?v:Math.floor(v+1),N+=v*M}else if(N>t.graduatedMin+M){const v=Math.floor((N-t.graduatedMin)/M);N-=v*M}const T=f[x],A=N,D=t.graduatedMax*1e-6;for(let v=1;N<=t.graduatedMax+D;v++){if(this.UI(t,N-t.graduatedTickBase,T)&&(N>t.graduatedMax&&(N=t.graduatedMax),(k.graduatedSkip===null||k instanceof TextBlock&&!k.graduatedSkip(N,k)||k instanceof Shape&&!k.graduatedSkip(N,k))&&(m=(N-t.graduatedMin)*r/t.graduatedRange,m>r&&(m=r),g<=m&&m<=p))){let R=c[L][C],F=o[L][C];for(;L<o.length;){for(;m>S&&C<o[L].length-1;)C++,R=c[L][C],F=o[L][C],S+=F;if(m<=S)break;L++,C=0,R=c[L][C],F=o[L][C],S+=F}const O=n[L],z=O[C*2],Y=O[C*2+1],E=O[C*2+2],X=O[C*2+3],B=(m-(S-F))/F,H=new Point(z+(E-z)*B+s/2-i.bounds.x,Y+(X-Y)*B+s/2-i.bounds.y);if(H.scale(e.scale,e.scale),R=this.VI(R,B,O,c[L],C),k instanceof TextBlock){let j="";k.graduatedFunction!==null?(j=k.graduatedFunction(N,k),j=j!=null?j.toString():""):j=(+N.toFixed(2)).toString(),j!==""&&y.push({pt:H,angle:R,text:j})}else y.push({pt:H,angle:R})}N=A+v*M}t.Fs.push(y)}U.Z(c)}VI(t,e,i,s,n){if(e<.5005&&e>.4995)return t;let o=t;if(e<.5?n>0?o=s[n-1]:G.X(i[0],i[i.length-2])&&G.X(i[1],i[i.length-1])&&(o=s[s.length-1]):e>.5&&(n+1<s.length?o=s[n+1]:G.X(i[0],i[i.length-2])&&G.X(i[1],i[i.length-1])&&(o=s[0])),t!==o){let r=Math.abs(t-o);if(r>180&&(t<o?t+=360:o+=360,r=Math.abs(t-o)),e<5e-4||e>.9995)return(t+o)/2%360;if(r<10){const l=1-Math.abs(.5-e);return(t*l+o*(1-l))%360}}return t}EI(t){if(t.ds===null){const e=[],i=t.D.r,s=i.length;for(let n=0;n<s;n++){const o=i[n],r=[];if(e.push(r),!o.visible)continue;const l=o.interval;if(!(l<0))for(let a=0;a<s;a++){if(a===n)continue;const h=i[a];if(!h.visible||o.constructor!==h.constructor)continue;const c=h.interval;c>l&&r.push(c)}}t.ds=e}return t.ds}UI(t,e,i){const s=i.length;for(let n=0;n<s;n++){const o=i[n]*t.graduatedTickUnit,r=e%o,l=t.graduatedTickUnit*1e-6;if(r<l&&r>-l)return!1}return!0}Ge(t,e,i){const s=i.gh;i.gh=!0;const n=t.naturalBounds,o=n.width,r=n.height,l=e instanceof SVGContext;e.save(),e.beginPath(),e.rect(-1,-1,o+1,r+1),e.clip(),e.endPath();const a=t.findMainElement();a.Ge(e,i);let h=t.getDocumentScale()*i.scale;h<=0&&(h=1);const c=a.actualBounds,f=t.D.r,u=t.Fs,d=f.length;for(let m=0;m<d;m++){const g=f[m],p=u[m],y=p.length;if(!(!g.visible||g===a||p.length===0)){if(g instanceof Shape){if(t.graduatedTickUnit*g.interval*a.geometry.flattenedTotalLength/t.graduatedRange*h<2&&g.graduatedSkip===null)continue;const x=g.measuredBounds,k=g.strokeWidth*g.scale;let b=g.alignmentFocus;b.isNoSpot()&&(b=Spot.TopCenter);for(let P=0;P<y;P++){const S=p[P].pt,L=p[P].angle;this.BI(g,S,c,L,x,k,b),g.Ge(e,i),l&&(t.svg.appendChild(g.svg),g.svg=null),g.il.Ue()}}else if(g instanceof TextBlock){t.vi===null&&(t.vi=new TextBlock);const x=t.vi;this.uD(g,x),x.jN=!0;for(let k=0;k<y;k++){const b=p[k];if(b.actualBounds&&b.measuredBounds&&b.naturalBounds){x.zI(b);const P=b.actualBounds;x.Ut(P.x,P.y,P.width,P.height),this.XI(x,c,P,b.measuredBounds,b.naturalBounds),x.nl=g.part,x.Zs=g.panel,x.Ge(e,i),x.Zs=null,x.nl=null,l&&(t.svg.appendChild(x.svg),x.svg=null)}}}}}i.gh=s,e.restore(),e.clearContextCache(!0)}BI(t,e,i,s,n,o,r){const l=t.il;l.Ue(),l.Gs(e.x+i.x,e.y+i.y),l.ks(s+t.angle,0,0),l.Gs(-n.width*r.x+r.offsetX+o/2,-n.height*r.y+r.offsetY+o/2),l.it(t.scale,t.scale),t.Pd(!1),t.wa.set(t.il),t.Lh=t.scale,t.Ih(!1)}XI(t,e,i,s,n){const o=t.il;o.Ue(),o.Gs(i.x+e.x,i.y+e.y),o.Gs(-s.x,-s.y),t.Yp(o,n.x,n.y,n.width,n.height),t.Pd(!1),t.wa.set(t.il),t.Lh=t.scale,t.Ih(!1)}uD(t,e){e.GI(t)}}PanelLayout.Tn("Graduated",new PanelLayoutGraduated);var ViewboxStretch=(w=>(w[w.Uniform=6]="Uniform",w[w.UniformToFill=7]="UniformToFill",w))(ViewboxStretch||{});class Panel extends GraphObject{W;D;Qt;Td;Qn;ll;uo;Zo;qN;O;Dd;rt;Pe;te;vd;Aa;tn;constructor(t,e){if(super(),t===void 0)this.W=Panel.Position;else if(typeof t=="string"){const i=PanelLayout.fs.get(t);i!==null?this.W=i:U.o("PanelLayout not loaded: "+t)}else t instanceof PanelLayout?this.W=t:(this.W=Panel.Position,t&&(e=t));this.n|=4194304|(this.W===Panel.Grid?1048576:0),this.D=new List,this.Qt=Margin.em,this.Td=Spot.Default,this.Qn=1,this.ll=null,this.uo="",this.Zo=new Rect(NaN,NaN,NaN,NaN),this.qN=null,this.O=null,this.Dd=6,this.Pe=null,this.rt=null,this.te=null,this.vd=NaN,this.Aa=null,this.tn=null,e&&Object.assign(this,e)}cloneProtected(t){super.cloneProtected(t),t.W=this.W,t.Qt=this.Qt.N(),t.Td=this.Td.N(),t.Qn=this.Qn,t.uo=this.uo,t.Zo.h(this.Zo),this.O!==null&&(t.O=this.O.copy(t)),t.Dd=this.Dd,this.rt!==null&&(t.rt=this.rt.copy()),this.Pe!==null&&(t.Pe=this.Pe.copy()),t.te=this.te,t.vd=this.vd,t.Aa=this.Aa}jo(t){super.jo(t),t.D=this.D;const e=t.D.r,i=e.length;for(let s=0;s<i;s++){const n=e[s];n.Zs=t}t.ll=null}copy(){const t=super.copy(),e=this.D.r,i=e.length;for(let s=0;s<i;s++){const o=e[s].copy();t.YI(o)}return t}toString(){return"Panel("+this.type.name+")#"+GSet.xs(this)}get type(){return this.W}set type(t){const e=this.W;e!==t&&(this.W=t,this.Af=this.W===Panel.Grid,this.c(),this.t("type",e,t))}get elements(){return this.D.iterator}get naturalBounds(){return this.Ke}get padding(){return this.Qt}set padding(t){typeof t=="number"?(t<0&&U.J(t,">= 0",Panel,"padding"),t=new Margin(t)):(t.left<0&&U.J(t.left,">= 0",Panel,"padding:value.left"),t.right<0&&U.J(t.right,">= 0",Panel,"padding:value.right"),t.top<0&&U.J(t.top,">= 0",Panel,"padding:value.top"),t.bottom<0&&U.J(t.bottom,">= 0",Panel,"padding:value.bottom"));const e=this.Qt;e.equals(t)||(t=t.N(),this.Qt=t,this.c(),this.t("padding",e,t))}get defaultAlignment(){return this.Td}set defaultAlignment(t){const e=this.Td;e.equals(t)||(t=t.N(),this.Td=t,this.c(),this.t("defaultAlignment",e,t))}get defaultStretch(){return this.Qn}set defaultStretch(t){const e=this.Qn;e!==t&&(this.Qn=t,this.c(),this.t("defaultStretch",e,t))}get defaultSeparatorPadding(){return this.O!==null?this.O.N0:Margin.em}set defaultSeparatorPadding(t){typeof t=="number"&&(t=new Margin(t));const e=this.defaultSeparatorPadding;e.equals(t)||(t=t.N(),this.O===null&&(this.O=new TablePanelSettings),this.O.N0=t,this.c(),this.t("defaultSeparatorPadding",e,t))}get defaultRowSeparatorStroke(){return this.O!==null?this.O.C0:null}set defaultRowSeparatorStroke(t){const e=this.defaultRowSeparatorStroke;e!==t&&(t===null||typeof t=="string"||t instanceof Brush)&&(t instanceof Brush&&t.b(),this.O===null&&(this.O=new TablePanelSettings),this.O.C0=t,this.C(),this.t("defaultRowSeparatorStroke",e,t))}get defaultRowSeparatorStrokeWidth(){return this.O!==null?this.O.L0:1}set defaultRowSeparatorStrokeWidth(t){const e=this.defaultRowSeparatorStrokeWidth;e!==t&&isFinite(t)&&t>=0&&(this.O===null&&(this.O=new TablePanelSettings),this.O.L0=t,this.c(),this.t("defaultRowSeparatorStrokeWidth",e,t))}get defaultRowSeparatorDashArray(){return this.O!==null?this.O.A0:null}set defaultRowSeparatorDashArray(t){const e=this.defaultRowSeparatorDashArray;if(e!==t){if(t!==null&&!Array.isArray(t)&&U.si(t,"Array",Panel,"defaultRowSeparatorDashArray:value"),t!==null){const i=t.length;let s=0;for(let n=0;n<i;n++){const o=t[n];(typeof o!="number"||!(o>=0)||!isFinite(o))&&U.o("defaultRowSeparatorDashArray value "+o+" at index "+n+" must be a positive number or zero."),s+=o}if(s===0){if(e===null)return;t=null}}this.O===null&&(this.O=new TablePanelSettings),this.O.A0=t,this.C(),this.t("defaultRowSeparatorDashArray",e,t)}}get defaultColumnSeparatorStroke(){return this.O!==null?this.O.T0:null}set defaultColumnSeparatorStroke(t){const e=this.defaultColumnSeparatorStroke;e!==t&&(t===null||typeof t=="string"||t instanceof Brush)&&(t instanceof Brush&&t.b(),this.O===null&&(this.O=new TablePanelSettings),this.O.T0=t,this.C(),this.t("defaultColumnSeparatorStroke",e,t))}get defaultColumnSeparatorStrokeWidth(){return this.O!==null?this.O.D0:1}set defaultColumnSeparatorStrokeWidth(t){const e=this.defaultColumnSeparatorStrokeWidth;e!==t&&isFinite(t)&&t>=0&&(this.O===null&&(this.O=new TablePanelSettings),this.O.D0=t,this.c(),this.t("defaultColumnSeparatorStrokeWidth",e,t))}get defaultColumnSeparatorDashArray(){return this.O!==null?this.O.v0:null}set defaultColumnSeparatorDashArray(t){const e=this.defaultColumnSeparatorDashArray;if(e!==t){if(t!==null&&!Array.isArray(t)&&U.si(t,"Array",Panel,"defaultColumnSeparatorDashArray:value"),t!==null){const i=t.length;let s=0;for(let n=0;n<i;n++){const o=t[n];(typeof o!="number"||!(o>=0)||!isFinite(o))&&U.o("defaultColumnSeparatorDashArray value "+o+" at index "+n+" must be a positive number or zero."),s+=o}if(s===0){if(e===null)return;t=null}}this.O===null&&(this.O=new TablePanelSettings),this.O.v0=t,this.C(),this.t("defaultColumnSeparatorDashArray",e,t)}}get La(){return this.O!==null?this.O.La:null}set La(t){this.O===null&&(this.O=new TablePanelSettings),this.O.La=t}get viewboxStretch(){return this.Dd}set viewboxStretch(t){const e=this.Dd;e!==t&&(this.Dd=t,this.c(),this.t("viewboxStretch",e,t))}get gridCellSize(){return this.Pe!==null?this.Pe.Fd:Size.OL}set gridCellSize(t){this.Pe===null&&(this.Pe=new GridPanelSettings);const e=this.Pe.Fd;if(!e.equals(t)){(!t.isReal()||t.width===0||t.height===0)&&U.o("Invalid Panel.gridCellSize: "+t),this.Pe.Fd=t.N();const i=this.diagram;i!==null&&this===i.grid&&i.ca(),this.C(),this.t("gridCellSize",e,t)}}get gridOrigin(){return this.Pe!==null?this.Pe.Rd:Point.gn}set gridOrigin(t){this.Pe===null&&(this.Pe=new GridPanelSettings);const e=this.Pe.Rd;if(!e.equals(t)){t.isReal()||U.o("Invalid Panel.gridOrigin: "+t),this.Pe.Rd=t.N();const i=this.diagram;i!==null&&this===i.grid&&i.ca(),this.C(),this.t("gridOrigin",e,t)}}get graduatedMin(){return this.rt!==null?this.rt.F0:0}set graduatedMin(t){const e=this.graduatedMin;if(e!==t&&(this.rt===null&&(this.rt=new GradPanelSettings),this.rt.F0=t,this.c(),this.t("graduatedMin",e,t),this.gf())){const i=this.part;i!==null&&this.Oh(i,"graduatedRange")}}get graduatedMax(){return this.rt!==null?this.rt.R0:100}set graduatedMax(t){const e=this.graduatedMax;if(e!==t&&(this.rt===null&&(this.rt=new GradPanelSettings),this.rt.R0=t,this.c(),this.t("graduatedMax",e,t),this.gf())){const i=this.part;i!==null&&this.Oh(i,"graduatedRange")}}get graduatedRange(){return this.graduatedMax-this.graduatedMin}get graduatedTickUnit(){return this.rt!==null?this.rt.O0:10}set graduatedTickUnit(t){const e=this.graduatedTickUnit;e!==t&&t>0&&(this.rt===null&&(this.rt=new GradPanelSettings),this.rt.O0=t,this.c(),this.t("graduatedTickUnit",e,t))}get graduatedTickBase(){return this.rt!==null?this.rt.I0:0}set graduatedTickBase(t){const e=this.graduatedTickBase;e!==t&&(this.rt===null&&(this.rt=new GradPanelSettings),this.rt.I0=t,this.c(),this.t("graduatedTickBase",e,t))}get Fs(){return this.rt!==null?this.rt.Fs:null}set Fs(t){this.rt!==null?this.rt.Fs=t:t!==null&&(this.rt=new GradPanelSettings,this.rt.Fs=t)}get ts(){return this.rt!==null?this.rt.ts:null}set ts(t){this.rt!==null?this.rt.ts=t:t!==null&&(this.rt=new GradPanelSettings,this.rt.ts=t)}get ds(){return this.rt!==null?this.rt.ds:null}set ds(t){this.rt!==null?this.rt.ds=t:t!==null&&(this.rt=new GradPanelSettings,this.rt.ds=t)}get vi(){return this.rt!==null?this.rt.vi:null}set vi(t){this.rt!==null?this.rt.vi=t:t!==null&&(this.rt=new GradPanelSettings,this.rt.vi=t)}qp(t){super.qp(t);const e=this.D.r,i=e.length;for(let s=0;s<i;s++)e[s].qp(t)}Ma(t,e){if(this.W===Panel.Grid){t.commitTransform(),this.W.Ge(this,t,e);return}if(this.W===Panel.Graduated){t.commitTransform(),this.W.Ge(this,t,e);return}if(this.W===Panel.Table)if(t.commitTransform(),t instanceof SVGContext){const r=t.currentElement;t.currentElement=t.newGroup2("gojs-ts"),this.WN(t,e),t.endGroup(),t.currentElement=r}else this.WN(t,e);const i=this.isClipping&&this.W===Panel.Spot;i&&t.save();const s=this.findMainElement(),n=this.D.r,o=n.length;for(let r=0;r<o;r++){const l=n[r];i&&l===s&&(t.clipInsteadOfFill=!0),l.Ge(t,e),i&&l===s&&(t.clipInsteadOfFill=!1)}i&&(t.restore(),t.clearContextCache(!0))}WN(t,e){t.lineCap="butt";const i=this.rowCount>0?this.Qi:null,s=this.columnCount>0?this._i:null;i!==null&&this.J1(t,e,!0,i,!0),s!==null&&this.J1(t,e,!1,s,!0),i!==null&&this.dD(t,!0,i),s!==null&&this.dD(t,!1,s),i!==null&&this.J1(t,e,!0,i,!1),s!==null&&this.J1(t,e,!1,s,!1)}dD(t,e,i){const s=i.length,n=this.actualBounds,o=this.naturalBounds;let r=!0;for(let l=0;l<s;l++){const a=i[l];if(a===void 0||a.actual===0)continue;if(r){r=!1;continue}if(e){if(a.position>o.height)continue}else if(a.position>o.width)continue;let h=a.separatorStrokeWidth;isNaN(h)&&(h=e?this.defaultRowSeparatorStrokeWidth:this.defaultColumnSeparatorStrokeWidth);let c=a.separatorStroke;if(c===null&&(c=e?this.defaultRowSeparatorStroke:this.defaultColumnSeparatorStroke),h===0||c===null)continue;this.kn(t,c,!1,!1,o,n);let f=!1,u=a.separatorDashArray;u===null&&(u=e?this.defaultRowSeparatorDashArray:this.defaultColumnSeparatorDashArray),u!==null&&(f=!0,t.enableDash(u,0)),t.beginPath();const d=a.position+h;e?d>o.height&&(h-=d-o.height):d>o.width&&(h-=d-o.width);let m=a.position+h/2;t.lineWidth=h;const g=this.Qt;if(e){m+=g.top;const p=g.left,y=o.width-g.right;t.moveTo(p,m),t.lineTo(y,m)}else{m+=g.left;const p=g.top,y=o.height-g.bottom;t.moveTo(m,p),t.lineTo(m,y)}t.stroke(),t.endPath(),f&&t.disableDash()}}J1(t,e,i,s,n){const o=s.length,r=this.actualBounds,l=this.naturalBounds,a=this.gD(!0),h=this.gD(!1);for(let c=0;c<o;c++){const f=s[c];if(f===void 0||f.background===null||f.coversSeparators===n||f.actual===0)continue;const u=i?r.height:r.width;if(f.position>u)continue;let d=f.computeEffectiveSpacing(),m=f.separatorStrokeWidth;isNaN(m)&&(m=i?this.defaultRowSeparatorStrokeWidth:this.defaultColumnSeparatorStrokeWidth);let g=f.separatorStroke;g===null&&(g=i?this.defaultRowSeparatorStroke:this.defaultColumnSeparatorStroke),(g===null||f.index===(i?a:h))&&(m=0),d-=m;const p=f.position+m;let y=d+f.actual;if(p+y>u&&(y=u-p),y<=0)continue;const x=this.Qt;this.kn(t,f.background,!0,!1,l,r),i?t.fillRect(x.left,p+x.top,r.width-(x.left+x.right),y):t.fillRect(p+x.left,x.top,y,r.height-(x.top+x.bottom))}}gD(t){const e=t?this.rowCount:this.columnCount;for(let i=0;i<e;i++){const s=t?this.Qi[i]:this._i[i];if(s!==void 0)return s.index}return 0}wf(){const t=this.D.r,e=t.length;for(let i=0;i<e;i++)t[i].wf();this.$i(!0)}yf(t,e,i){const s=this.svg;if(s===null)return!1;if(this.type===Panel.Table){const r=s.getElementsByClassName("gojs-ts"),l=r.length!==0?r[0]:null;l!==null&&(l.innerHTML=""),t.currentElement=l,this.WN(t,e),t.currentElement=null}else{if(this.W===Panel.Grid)return s.innerHTML="",s.remove(),!1;if(this.W===Panel.Graduated)return s.innerHTML="",s.remove(),!1;if(this.W===Panel.Spot&&this.isClipping)return s.innerHTML="",s.remove(),this.xa=null,this.wf(),!1}if(!super.yf(t,e,i))return!1;const n=this.D.r,o=n.length;for(let r=0;r<o;r++)n[r].Ge(t,e);return!0}kd(t){return!0}Jp(t,e,i,s){if(!this.isClipping){if(this._s()&&t.partClipRect!==null){const n=t.partClipRect,o=this.D.r;let r=0,l=0;for(let a=0;a<o.length;a++){if(!o[a].isVisibleObject())continue;const h=o[a].actualBounds;r=a===0?h.x:Math.min(h.x,r),l=a===0?h.y:Math.min(h.y,l)}s.setAttributeNS(null,"clip-path",`path('M ${n.x-i.x-r},${n.y-i.y-l} l ${n.width} 0 l 0 ${n.height} l -${n.width} 0 z')`);return}super.Jp(t,e,i,s)}}mf(t,e,i,s,n){const o=this.Nn(),r=this.v,l=1/(r.m11*r.m22-r.m12*r.m21);let a=r.m22*l,h=-r.m12*l,c=-r.m21*l,f=r.m11*l,u=l*(r.m21*r.dy-r.m22*r.dx),d=l*(r.m12*r.dx-r.m11*r.dy);if(this.background!==null){const m=t*a+e*c+u,g=t*h+e*f+d,p=i*a+s*c+u,y=i*h+s*f+d;n.e(0,0);const x=this.naturalBounds,k=G.Cl(0,0,x.width,x.height,m,g,p,y,n);return n.v(r),k}else{o||(a=1,h=0,c=0,f=1,u=0,d=0);const m=t*a+e*c+u,g=t*h+e*f+d,p=i*a+s*c+u,y=i*h+s*f+d;n.e(p,y);let x=(p-m)**2+(y-g)**2,k=!1;const b=this.D.r,P=b.length,S=Point.l();let L=null,C=1/0,M=null;const N=this.isClipping&&this.W===Panel.Spot;N&&(M=Point.l(),L=this.findMainElement(),k=L.mf(m,g,p,y,M),k&&(C=(m-M.x)**2+(g-M.y)**2));for(let T=0;T<P;T++){const A=b[T];if(!A.visible||A===L||!A.mf(m,g,p,y,S))continue;k=!0;const D=(m-S.x)**2+(g-S.y)**2;D<x&&(x=D,n.set(S))}return N&&(C>x&&n.set(M),Point.i(M)),Point.i(S),o&&n.v(r),k}}qc(){const t=this.D.r,e=t.length;for(let i=0;i<e;i++)t[i].qc();super.qc()}c(t){if(this.Go())return;super.c(t);let e=null;(this.W===Panel.Auto||this.W===Panel.Link)&&(e=this.findMainElement());const i=this.D.r,s=i.length;for(let n=0;n<s;n++){const o=i[n];if((o===e||o.isPanelMain)&&o.c(!0),o.desiredSize.isReal()||!o.visible)continue;const r=o.Qs(!1);!(o instanceof Placeholder)&&!(o instanceof Panel)&&!(o instanceof TextBlock)&&r===0||o.c(!0)}}bf(){if(this.Go())return;this.wi(!0),this.ao(!0);const t=this.D.r,e=t.length;for(let i=0;i<e;i++)t[i].bf()}pf(){if(this.V1()===!1){this.Pd(!0),this.Ih(!0);const t=this.D.r,e=t.length;for(let i=0;i<e;i++)t[i].AN()}}AN(){this.Ih(!0);const t=this.D.r,e=t.length;for(let i=0;i<e;i++)t[i].AN()}xd(t,e,i,s){const n=this.Zo;n.e(0,0,0,0);const o=this.desiredSize,r=this.minSize;i===void 0&&(i=r.width,s=r.height),i=Math.max(i,r.width),s=Math.max(s,r.height);const l=this.maxSize;isNaN(o.width)||(t=Math.min(o.width,l.width)),isNaN(o.height)||(e=Math.min(o.height,l.height)),t=Math.max(i,t),e=Math.max(s,e);const a=this.Qt;t=Math.max(t-a.left-a.right,0),e=Math.max(e-a.top-a.bottom,0);const h=this.D.r;this.W.measure(this,t,e,h,n,i,s);let c=n.width+a.left+a.right,f=n.height+a.top+a.bottom;isFinite(o.width)&&(c=o.width),isFinite(o.height)&&(f=o.height),c=Math.min(l.width,c),f=Math.min(l.height,f),c=Math.max(r.width,c),f=Math.max(r.height,f),c=Math.max(i,c),f=Math.max(s,f),n.jn(c,f),this.naturalBounds.jn(c,f),this.lo(0,0,c,f)}findMainElement(){if(this.ll===null){const t=this.D.r,e=t.length;if(e===0)return null;for(let i=0;i<e;i++){const s=t[i];if(s.isPanelMain===!0)return this.ll=s,s}this.ll=t[0]}return this.ll}$o(){return this.part!==null?this.part.locationObject:null}get panelLayoutState(){return this.qN}set panelLayoutState(t){this.qN=t}Pa(t,e,i,s){const n=this.D.r;if(this.actualBounds.e(t,e,i,s),!this.desiredSize.isReal()){let o=this.Qs(!0);const r=this.measuredBounds,l=r.width,a=r.height,h=this.sl,c=h.left+h.right,f=h.top+h.bottom;switch(l===i&&a===s&&(o=0),o){case 0:(l>i||a>s)&&(this.c(),this.ht(l>i?i:l,a>s?s:a,0,0));break;case 2:this.c(!0),this.ht(i+c,s+f,0,0);break;case 5:this.c(!0),this.ht(i+c,a+f,0,0);break;case 4:this.c(!0),this.ht(l+c,s+f,0,0);break}}this.W.arrange(this,n,this.Zo)}ka(t){const e=this.naturalBounds,i=this.$o();if(Rect.contains(0,0,e.width,e.height,t.x,t.y)){const s=this.D.r,n=s.length,o=Point.z(0,0);for(let r=n;r--;){const l=s[r];if(!(!l.visible&&l!==i)&&(o.set(t).Ki(l.v),l.containsPoint(o)))return Point.i(o),!0}return Point.i(o),this.Lt!==null}return!1}Gp(t){if(this.oo===t)return this;const e=this.D.r,i=e.length;for(let s=0;s<i;s++){const o=e[s].Gp(t);if(o!==null)return o}return null}walkVisualTreeFrom(t,e){if(e(this,t),t instanceof Panel){const i=t.D.r,s=i.length;for(let n=0;n<s;n++)this.walkVisualTreeFrom(i[n],e)}}Sn(t){this.mD(this,t)}mD(t,e){e(t);const i=t.D.r,s=i.length;for(let n=0;n<s;n++){const o=i[n];o instanceof Panel&&this.mD(o,e)}}KI(t){this.pD(this,t)}pD(t,e){if(e(t),t instanceof Panel){const i=t.D.r,s=i.length;for(let n=0;n<s;n++)this.pD(i[n],e)}}findInVisualTree(t){return this.yD(this,t)}yD(t,e){if(e(t))return t;if(t instanceof Panel){const i=t.D.r,s=i.length;for(let n=0;n<s;n++){const o=this.yD(i[n],e);if(o!==null)return o}}return null}findObject(t){if(this.name===t)return this;const e=this.D.r;let i=e.length;this.HI()&&(i=this.E0());for(let s=0;s<i;s++){const n=e[s];if(n instanceof Panel){const o=n.findObject(t);if(o!==null)return o}if(n.name===t)return n}return null}wD(){const t=this.D.r,e=t.length;let i=0;for(let s=0;s<e;s++){const n=t[s];n instanceof Panel?i=Math.max(i,n.wD()):n instanceof Shape&&(i=Math.max(i,n.jI()))}return i}Nn(){return!(this.type===Panel.TableRow||this.type===Panel.TableColumn)}ol(){return this.type===Panel.TableRow||this.type===Panel.TableColumn}BA(t,e,i){if(this.pickable===!1||(e===void 0&&(e=null),i===void 0&&(i=null),this.as()))return null;const s=this.naturalBounds,n=1/this.getDocumentScale(),o=this.Nn(),r=o?t:Point.z(t.x,t.y).Ki(this.v),l=this.diagram;let a=10,h=5;if(l!==null&&(a=l.getInputOption("extraTouchArea"),h=a/2),Rect.contains(-(h*n),-(h*n),s.width+a*n,s.height+a*n,r.x,r.y)){if(!this.Af){const f=this.D.r,u=f.length,d=Point.l(),m=this.isClipping&&this.W===Panel.Spot,g=m?this.findMainElement():null;if(m&&g&&(g.Nn()?d.set(t).Ki(g.v):d.set(t),!g.containsPoint(d)))return Point.i(d),o||Point.i(r),null;const p=this.$o();for(let y=u;y--;){const x=f[y];if(!x.visible&&x!==p||(x.Nn()?d.set(t).Ki(x.v):d.set(t),m&&x===g))continue;let k=null;if(x instanceof Panel?k=x.BA(d,e,i):x.pickable===!0&&x.containsPoint(d)&&(k=x),k!==null&&(e!==null&&(k=e(k)),k!==null&&(i===null||i(k))))return Point.i(d),o||Point.i(r),k}Point.i(d)}if(this.background===null)return o||Point.i(r),null;const c=Rect.contains(0,0,s.width,s.height,r.x,r.y)?this:null;return o||Point.i(r),c}return o||Point.i(r),null}zA(t,e,i,s){if(this.pickable===!1)return!1;e===void 0&&(e=null),i===void 0&&(i=null);const n=this.naturalBounds,o=this.Nn(),r=o?t:Point.z(t.x,t.y).Ki(this.v),l=this.ol(),a=Rect.contains(0,0,n.width,n.height,r.x,r.y);if(l||a){if(!this.Af){const h=this.D.r,c=h.length,f=Point.l(),u=this.$o();for(let d=c;d--;){const m=h[d];if(!m.visible&&m!==u)continue;m.Nn()?f.set(t).Ki(m.v):f.set(t);let g=m;const p=m instanceof Panel?m:null;if(p!==null?p.zA(f,e,i,s):g.containsPoint(f)){if(g.pickable===!1)continue;e!==null&&(g=e(g)),g!==null&&(i===null||i(g))&&s.add(g)}}Point.i(f)}return o||Point.i(r),a&&this.background!==null}return o||Point.i(r),!1}$m(t,e,i,s,n,o){if(this.pickable===!1)return!1;e===void 0&&(e=null),i===void 0&&(i=null);let r=o;if(r===void 0&&(r=Transform.l(),r.Ue()),r.bc(this.v),this.containedInRect(t,r))return this.JN(e,i,n),o===void 0&&Transform.i(r),!0;if(this.intersectsRect(t,r)){if(!this.Af){const l=this.$o(),a=this.D.r,h=a.length;for(let c=h;c--;){const f=a[c];if(!f.visible&&f!==l)continue;const u=f.actualBounds,d=this.naturalBounds;if(u.x>d.width||u.y>d.height||u.x+u.width<0||u.y+u.height<0)continue;let m=f;const g=f instanceof Panel?f:null,p=Transform.l();p.set(r),(g!==null?g.$m(t,e,i,s,n,p):m.JT(t,s,p))&&(e!==null&&(m=e(m)),m!==null&&(i===null||i(m))&&n.add(m)),Transform.i(p)}}return o===void 0&&Transform.i(r),s}return o===void 0&&Transform.i(r),!1}JN(t,e,i){const s=this.D.r,n=s.length;for(let o=n;o--;){const r=s[o];if(!r.visible)continue;const l=r.actualBounds,a=this.naturalBounds;if(l.x>a.width||l.y>a.height||l.x+l.width<0||l.y+l.height<0)continue;r instanceof Panel&&r.JN(t,e,i);let h=r;t!==null&&(h=t(h)),h!==null&&(e===null||e(h))&&i.add(h)}}XA(t,e,i,s,n,o){if(this.pickable===!1)return!1;i===void 0&&(i=null),s===void 0&&(s=null);const r=this.naturalBounds,l=this.Nn(),a=l?t:Point.z(t.x,t.y).Ki(this.v),h=l?e:Point.z(e.x,e.y).Ki(this.v),c=a.distanceSquaredPoint(h),f=a.x>0&&a.x<r.width&&a.y>0&&a.y<r.height||Point.distanceLineSegmentSquared(a.x,a.y,0,0,0,r.height)<=c||Point.distanceLineSegmentSquared(a.x,a.y,0,r.height,r.width,r.height)<=c||Point.distanceLineSegmentSquared(a.x,a.y,r.width,r.height,r.width,0)<=c||Point.distanceLineSegmentSquared(a.x,a.y,r.width,0,0,0)<=c,u=a.distanceSquared(0,0)<=c&&a.distanceSquared(0,r.height)<=c&&a.distanceSquared(r.width,0)<=c&&a.distanceSquared(r.width,r.height)<=c;if(l||(Point.i(a),Point.i(h)),f){if(!this.Af){const d=Point.l(),m=Point.l(),g=this.$o(),p=this.D.r,y=p.length;for(let x=y;x--;){const k=p[x];if(!k.visible&&k!==g)continue;const b=k.actualBounds,P=this.naturalBounds;if(l&&(b.x>P.width||b.y>P.height||b.x+b.width<0||b.y+b.height<0))continue;if(k.Nn()){const C=k.v;d.set(t).Ki(C),m.set(e).Ki(C)}else d.set(t),m.set(e);let S=k;const L=k instanceof Panel?k:null;(L!==null?L.XA(d,m,i,s,n,o):S.$T(d,m,n))&&(i!==null&&(S=i(S)),S!==null&&(s===null||s(S))&&o.add(S))}Point.i(d),Point.i(m)}return n?f:u}return!1}GN(t){let e=null;if(t instanceof Shape){e=t.spot1,e===Spot.Default&&(e=null);const i=t.geometry;i!==null&&e===null&&(e=i.spot1)}return e===null&&(e=Spot.TopLeft),e}YN(t){let e=null;if(t instanceof Shape){e=t.spot2,e===Spot.Default&&(e=null);const i=t.geometry;i!==null&&e===null&&(e=i.spot2)}return e===null&&(e=Spot.BottomRight),e}add(...t){for(let e=0;e<t.length;e++)this.insertAt(this.D.count,t[e]);return this}elt(t){return this.D.elt(t)}insertAt(t,e){e instanceof Part&&U.o("Cannot add a Part to a Panel: "+e+"; use a Panel instead"),(this===e||this.isContainedBy(e))&&(this===e&&U.o("Cannot make a Panel contain itself: "+this.toString()),U.o("Cannot make a Panel indirectly contain itself: "+this.toString()+" already contains "+e.toString()));const i=e.panel;if(i!==null&&i!==this&&U.o("Cannot add a GraphObject that already belongs to another Panel to this Panel: "+e.toString()+", already contained by "+i.toString()+", cannot be shared by this Panel: "+this.toString()),this.W===Panel.Grid&&!(e instanceof Shape)&&U.o("Can only add Shapes to a Grid Panel, not: "+e),this.W===Panel.Graduated&&!(e instanceof Shape||e instanceof TextBlock)&&U.o("Can only add Shapes or TextBlocks to a Graduated Panel, not: "+e),e.Eh(this),e.nl=null,this.itemArray!==null){const r=e.data;U.$(r)&&(this.tn===null&&(this.tn=new GMap),this.tn.set(r,e))}const s=this.D;let n=-1;if(i===this){let r=-1;const l=this.D.r,a=l.length;for(let h=0;h<a;h++)if(l[h]===e){r=h;break}if(r!==-1){if(r===t||r+1>=s.count&&t>=s.count)return;s.removeAt(r),n=r}else U.o("element "+e.toString()+" has panel "+i.toString()+" but is not contained by it.")}(t<0||t>s.count)&&(t=s.count),s.insertAt(t,e),(t===0||e.isPanelMain)&&(this.ll=null),this.Go()||this.c(),e.c(!1),e.portId!==null?this.Ln=!0:e instanceof Panel&&e.Ln===!0&&(this.Ln=!0),this.ds=null,this.isEnabledObject()||this.$1(e,!1);const o=this.part;if(o!==null){o.i0(),o.Tf(),this.Ln&&o instanceof Node&&(o.Ln=!0),o.Ln&&o instanceof Node&&(o.hi=null);const r=this.diagram;if(r!==null&&r.undoManager.isUndoingRedoing)return;n!==-1&&o.raiseChangedEvent(4,"elements",this,e,null,n,null),o.raiseChangedEvent(3,"elements",this,null,e,null,t)}}get Ln(){return(this.n&8388608)!==0}set Ln(t){(this.n&8388608)!==0!==t&&(this.n=this.n^8388608)}MN(){return(this.n&16777216)!==0}$N(t){t?this.n|=16777216:this.n&=-16777217}YI(t){t.Eh(this),t.nl=null;const e=this.D,i=e.count;e.insertAt(i,t);const s=this.part;if(s!==null){s.i0(),t.portId!==null&&s instanceof Node&&(s.Ln=!0);const n=this.diagram;if(n!==null&&n.undoManager.isUndoingRedoing)return;s.raiseChangedEvent(3,"elements",this,null,t,null,i)}}cI(t){const e=this.D.r,i=e.length;let s=-1;for(let n=0;n<i;n++)if(e[n]===t){s=n;break}return s}remove(t){const e=this.D.r,i=e.length;let s=-1;for(let n=0;n<i;n++)if(e[n]===t){s=n;break}s!==-1&&this.ri(s,!0)}removeAt(t){t>=0&&this.ri(t,!0)}ri(t,e){const i=this.D,s=i.elt(t);if(s.nl=null,s.Eh(null),this.tn!==null){const o=s.data;U.$(o)&&this.tn.delete(o)}i.removeAt(t),this.wi(!1),this.c(),this.ll===s&&(this.ll=null),this.ds=null;const n=this.part;if(n!==null){n.i0(),n.Tf(),n.invalidateAdornments(),n instanceof Node&&(s instanceof Panel?s.walkVisualTreeFrom(s,(r,l)=>n.FN(l,e)):n.FN(s,e));const o=this.diagram;if(o!==null&&o.undoManager.isUndoingRedoing)return;n.raiseChangedEvent(4,"elements",this,s,null,t,null)}}get Qi(){return this.O===null&&(this.O=new TablePanelSettings),this.O.Qi}get rowCount(){return this.O===null?0:this.Qi.length}getRowDefinition(t){t<0&&U.J(t,">= 0",Panel,"getRowDefinition:idx"),t=Math.round(t);const e=this.Qi;if(e[t]===void 0){const i=new RowColumnDefinition;i.Eh(this),i.isRow=!0,i.index=t,e[t]=i,this.raiseChangedEvent(3,"rowdefs",this,null,i,null,t)}return e[t]}removeRowDefinition(t){if(t<0&&U.J(t,">= 0",Panel,"removeRowDefinition:idx"),this.rowCount===0)return;t=Math.round(t);const e=this.Qi,i=e[t];if(i){e[t]=void 0;let s=e.length-1;for(;s>=0&&e[s--]===void 0;)e.length--;this.raiseChangedEvent(4,"rowdefs",this,i,null,t,null),this.c()}}xT(t,e){const i=this.Qi;if(!(t<0)){if(i[t]=e instanceof RowColumnDefinition?e:void 0,!e){let s=i.length-1;for(;s>=0&&i[s--]===void 0;)i.length--}this.c()}}get _i(){return this.O===null&&(this.O=new TablePanelSettings),this.O._i}get columnCount(){return this.O===null?0:this._i.length}getColumnDefinition(t){t<0&&U.J(t,">= 0",Panel,"getColumnDefinition:idx"),t=Math.round(t);const e=this._i;if(e[t]===void 0){const i=new RowColumnDefinition;i.Eh(this),i.isRow=!1,i.index=t,e[t]=i,this.raiseChangedEvent(3,"coldefs",this,null,i,null,t)}return e[t]}removeColumnDefinition(t){if(t<0&&U.J(t,">= 0",Panel,"removeColumnDefinition:idx"),this.columnCount===0)return;t=Math.round(t);const e=this._i,i=e[t];if(i){e[t]=void 0;let s=e.length-1;for(;s>=0&&e[s--]===void 0;)e.length--;this.raiseChangedEvent(4,"coldefs",this,i,null,t,null),this.c()}}bT(t,e){const i=this._i;if(!(t<0)){if(i[t]=e instanceof RowColumnDefinition?e:void 0,!e){let s=i.length-1;for(;s>=0&&i[s--]===void 0;)i.length--}this.c()}}addRowColumnDefinition(t){let e=null;return t.isRow?e=this.getRowDefinition(t.index):t.isRow||(e=this.getColumnDefinition(t.index)),e&&e.z1(t),this}addRowDefinition(t,e){const i=this.getRowDefinition(t);return i&&i.z1(new RowColumnDefinition(e)),this}addColumnDefinition(t,e){const i=this.getColumnDefinition(t);return i&&i.z1(new RowColumnDefinition(e)),this}get rowSizing(){return this.O!==null?this.O.U0:3}set rowSizing(t){const e=this.rowSizing;e!==t&&(this.O===null&&(this.O=new TablePanelSettings),this.O.U0=t,this.c(),this.t("rowSizing",e,t))}get columnSizing(){return this.O!==null?this.O.V0:3}set columnSizing(t){const e=this.columnSizing;e!==t&&(this.O===null&&(this.O=new TablePanelSettings),this.O.V0=t,this.c(),this.t("columnSizing",e,t))}get topIndex(){return this.O!==null?this.O.B0:0}set topIndex(t){const e=this.topIndex;e!==t&&((!isFinite(t)||t<0)&&U.o("Panel.topIndex must be greater than zero and a real number, not: "+t),this.O===null&&(this.O=new TablePanelSettings),this.O.B0=t,this.c(),this.t("topIndex",e,t))}get leftIndex(){return this.O!==null?this.O.z0:0}set leftIndex(t){const e=this.leftIndex;e!==t&&((!isFinite(t)||t<0)&&U.o("Panel.leftIndex must be greater than zero and a real number, not: "+t),this.O===null&&(this.O=new TablePanelSettings),this.O.z0=t,this.c(),this.t("leftIndex",e,t))}findRowForLocalY(t){if(t<0||this.type!==Panel.Table||this.rowCount===0)return-1;let e=0;const i=this.Qi,s=i.length;let n=this.topIndex;for(;n<s;n++){const o=i[n];if(o!==void 0&&(e+=o.total,t<e))return n}return n}findColumnForLocalX(t){if(t<0||this.type!==Panel.Table||this.columnCount===0)return-1;let e=0;const i=this._i,s=i.length;let n=this.leftIndex;for(;n<s;n++){const o=i[n];if(o!==void 0&&(e+=o.total,t<e))return n}return n}graduatedPointForValue(t,e){if(e===void 0&&(e=new Point(NaN,NaN)),this.type!==Panel.Graduated)return e.e(NaN,NaN),e;t=Math.min(Math.max(t,this.graduatedMin),this.graduatedMax);const i=this.findMainElement();return i.geometry.getPointAlongPath((t-this.graduatedMin)/this.graduatedRange,e),i.v.gt(e)}graduatedValueForPoint(t){if(this.type!==Panel.Graduated)return NaN;const e=this.findMainElement();return e.v.Ci(t),e.geometry.getFractionForPoint(t)*this.graduatedRange+this.graduatedMin}get data(){return this.te}set data(t){const e=this.te;if(e!==t){const i=this instanceof Part&&!(this instanceof Adornment);i&&U.s(t,"object",Panel,"data"),this.It(),this.te=t;const s=this.diagram;if(s!==null)if(i){s.partManager.qI(this,e,t);let n=this.adornments;for(;n.next();){const o=n.value,r=o.adornedObject;if(r!==null){const l=r.findBindingPanel();l!==null&&(o.data=l.data)}}}else{const n=this.panel;n!==null&&n.tn!==null&&(e!==null&&n.tn.delete(e),t!==null&&n.tn.set(t,this))}if(this.t("data",e,t),s!==null&&s.undoManager.isUndoingRedoing)return;t!==null&&this.updateTargetBindings()}}get itemIndex(){return this.vd}set itemIndex(t){const e=this.vd;e!==t&&(this.vd=t,this.t("itemIndex",e,t))}get vs(){return this.w!==null?this.w.vs:null}set vs(t){this.ve!==t&&(this.w===null&&(this.w=new GraphObjectTemplateSettings),this.w.vs=t)}RN(){return this.vs!==null}oD(){const t=this.vs;return t!==null&&t.f}freezeBindings(){return this.It()}It(){let t=this.vs;if(t===null)this.data!==null&&U.o("Template cannot have .data be non-null: "+this),this.vs=t=new List;else if(t.f)return this;const e=new List;this.$N(!1),this.walkVisualTreeFrom(this,(n,o)=>{o.ba();const r=o.ve;if(r!==null){o.TN(!1);const l=r.iterator;for(;l.next();){const a=l.value;a.mode===2&&o.TN(!0);const h=a.sourceName;if(a.isToObject){h==="/"&&n.$N(!0);const c=a.WT(n,o);c!==null&&(e.add(c),c.ro===null&&(c.ro=new List),c.ro.add(a))}t.add(a)}}if(o instanceof Panel&&o.type===Panel.Table){if(o.rowCount>0){const l=o.Qi,a=l.length;for(let h=0;h<a;h++){const c=l[h];if(c!==void 0&&c.Rs!==null){const f=c.Rs.iterator;for(;f.next();){const u=f.value;u.Ti=c,u.Od=2,u.Df=c.index,t.add(u)}}}}if(o.columnCount>0){const l=o._i,a=l.length;for(let h=0;h<a;h++){const c=l[h];if(c!==void 0&&c.Rs!==null){const f=c.Rs.iterator;for(;f.next();){const u=f.value;u.Ti=c,u.Od=1,u.Df=c.index,t.add(u)}}}}}});const i=e.iterator;for(;i.next();){const n=i.value;if(n.ro!==null){n.TN(!0);const o=n.ro.iterator;for(;o.next();){const r=o.value;n.ve===null&&(n.ve=new List),n.ve.add(r)}}n.ro=null}let s=t.iterator;for(;s.next();){const n=s.value;let o=n.Ti;if(o!==null){n.Ti=null;const r=n.targetProperty,l=r.indexOf(".");if(l>0&&o instanceof Panel){const a=r.substring(0,l),h=r.substring(l+1),c=o.findObject(a);c!==null?(o=c,n.targetProperty=h):(U.ne('Warning: unable to find GraphObject named "'+a+'" for Binding: '+n.toString()),o=null)}if(o instanceof RowColumnDefinition){const a=GSet.xs(o.panel);n.targetId=a===void 0?-1:a,o.panel.oo=n.targetId}else if(o instanceof GraphObject){const a=GSet.xs(o);n.targetId=a===void 0?-1:a,o.oo=n.targetId}else U.o("Unknown type of binding target: "+o);n.check(o)}}return t.b(),this instanceof Part&&this.Di()&&this.ensureBounds(),this}static BU=!1;copyTemplate(t){t===void 0&&(t=!1);const e=this.copy();return e.KI(i=>{i instanceof Panel&&(i.vs=null,i.te=null);const s=i.ve;s!==null&&(i.ve=null,s.each(o=>i.bind(o.copy())));const n=i.Ds;n!==null&&(i.Ds=null,n.each(o=>i.trigger(o.value.copy())))}),t&&e.It(),e}updateTargetBindings(t){const e=this.vs;if(e===null)return;t===void 0&&(t="");const i=this.diagram?.model,s=e.iterator;for(;s.next();){const n=s.value,o=this.ZN(n,t);if(o===null)continue;const{data:r,elt:l}=o;n.isToTheme&&this.diagram===null||l!==void 0&&n.updateTarget(l,r,void 0,i)}}WI(t){if(t===""){this.updateTargetBindings(t);return}const e=this.vs;if(e===null)return;const i=this.diagram?.model,s=e.iterator;for(;s.next();){const n=s.value;if(n.isToData&&n.sourceProperty!=="")continue;const o=this.ZN(n,"");if(o===null)continue;const{data:r,elt:l}=o;l!==void 0&&n.updateTarget(l,r,void 0,i)}}Yo(){if(this.diagram!==null)if(this.RN()){const t=this.diagram.model,e=this.vs.iterator;for(;e.next();){const i=e.value;if(!i.isToTheme)continue;const s=this.ZN(i);if(s===null)continue;const{data:n,elt:o}=s;o!==void 0&&i.updateTarget(o,n,void 0,t)}}else{const t=this.D.r,e=t.length;for(let i=0;i<e;i++)t[i].Yo()}}ZN(t,e=""){const i=t.sourceProperty;if(e!==""&&i!==""&&i!==e)return null;const s=t.targetProperty;if(t.converter===null&&s==="")return null;let o=this.data;const r=t.sourceName;if(t.isToObject){if(o=this.qT(r),o===null)return null}else if(t.isToModel){const c=this.diagram;if(c===null)return null;o=c.model.modelData}let l=this;const a=t.targetId;if(a!==-1){if(l=this.Gp(a),l===null)return null}else t.Ti!==null&&(l=t.Ti);r==="/"?o=l.part:r==="."?o=l:r===".."&&(o=l.panel);const h=t.Od;if(h!==0){if(!(l instanceof Panel))return null;h===1?l=l.getColumnDefinition(t.Df):h===2&&(l=l.getRowDefinition(t.Df))}return{data:o,elt:l}}get itemArray(){return this.Aa}set itemArray(t){const e=this.Aa;if(e!==t||t!==null&&this.JI(t)){const i=this.diagram;if(e!==t&&(i!==null&&e!==null&&i.partManager.N2(this,i),this.Aa=t,i!==null&&t!==null&&i.partManager.M2(this,i)),this.t("itemArray",e,t),i!==null&&i.undoManager.isUndoingRedoing)return;this.xD(e,t)}}findItemPanelForData(t){return t==null||this.tn===null?null:(U.wc(t,Panel,"findItemPanelForData"),this.tn.get(t))}JI(t){const e=this.D.r,i=e.length,s=t.length;let n=0,o=null;for(;n<i&&(o=e[n],!(o instanceof Panel)||o.data===null);)n++,o=e[n];if(i-n!==s)return!0;if(o===null)return s>0;let r=0;for(;n<i&&r<s;){if(o=e[n],!(o instanceof Panel)||o.data!==t[r])return!0;n++,r++}return!1}E0(){if(this.type===Panel.Spot||this.type===Panel.Auto)return Math.min(this.D.length,1);if(this.type===Panel.Link){const t=this.D,e=t.length;let i=0;for(;i<e;i++){const s=t.elt(i);if(!(s instanceof Shape)||!s.isPanelMain)return i}return i}if(this.type===Panel.Table&&this.D.length>0){const e=this.D.elt(0);if(e.isPanelMain&&e instanceof Panel&&e.ol())return 1}return 0}rebuildItemElements(){const t=this.E0();for(;this.D.length>t;)this.ri(this.D.length-1,!1);this.xD(null,this.itemArray)}xD(t,e){const i=this.E0(),s=e;if(s===null||s.length===0){for(;this.D.length>i;)this.ri(this.D.length-1,!1);return}if(this.D.length<=i){const n=s.length;for(let o=0;o<n;o++)this.Z1(s[o],o,!0)}else{let n=i;for(let r=0;r<s.length;r++,n++){const l=s[r],a=n<this.D.length?this.D.elt(n):null;if(a instanceof Panel){if(a.data!==l){const h=this.QN(a.data,r),c=this.QN(l,r);let f=c!==h;if(!f){const u=this._N(a.data,r,h);f=this._N(l,r,c)!==u}f?(this.ri(n,!1),this.Z1(l,r,!1)):a.data=l}}else this.Z1(l,r,!1)}for(;n<this.D.length;)this.ri(n,!1);this.ll=null,this.tC(i,0),this.Go()||this.c(),this.ds=null,this.isEnabledObject()||this.$1(this,!1);const o=this.part;o!==null&&(o.i0(),o.Tf(),this.Ln&&o instanceof Node&&(o.Ln=!0),o.Ln&&o instanceof Node&&(o.hi=null))}}Z1(t,e,i){if(t==null||e<0)return;const s=this.QN(t,e),n=this._N(t,e,s);if(n!==null){n.It();const o=n.copy();if(o.MN()){const l=this.findBindingPanel();l!==null&&l.$N(!0)}U.$(t)&&(this.tn===null&&(this.tn=new GMap),this.tn.set(t,o));const r=e+this.E0();this.insertAt(r,o),i&&(o.te=t,this.tC(r,e),o.te=null),o.data=t}}$I(t){if(t<0)return;const e=t+this.E0();this.ri(e,!0),this.tC(e,t)}tC(t,e){const i=this.D;let s=t,n=e;for(;s<i.length;){const o=i.elt(s);o instanceof Panel&&o.ZI(s,n),s++,n++}}ZI(t,e){this.type===Panel.TableRow?this.row=t:this.type===Panel.TableColumn&&(this.column=t),this.itemIndex=e}HI(){return this.Aa!==null||this.itemTemplateMap!==null}get itemTemplate(){const t=this.itemTemplateMap;if(t!==null){const e=t.get("");if(e)return e}return Panel.bD()}set itemTemplate(t){const e=this.itemTemplate;if(e!==t){(t instanceof Part||t.isPanelMain)&&U.o("Panel.itemTemplate must not be a Part or be Panel.isPanelMain: "+t),this.itemTemplateMap===null&&(this.itemTemplateMap=new GMap),this.itemTemplateMap.set("",t),this.t("itemTemplate",e,t);const i=this.diagram;if(i!==null&&i.undoManager.isUndoingRedoing)return;this.rebuildItemElements()}}get itemTemplateMap(){return this.w!==null?this.w.w0:null}set itemTemplateMap(t){const e=this.itemTemplateMap;if(e!==t){const i=t.iterator;for(;i.next();){const n=i.value}this.Yt().w0=t,this.t("itemTemplateMap",e,t);const s=this.diagram;if(s!==null&&s.undoManager.isUndoingRedoing)return;this.rebuildItemElements()}}get itemCategoryProperty(){return this.w!==null?this.w.x0:"category"}set itemCategoryProperty(t){const e=this.itemCategoryProperty;e!==t&&(typeof t!="string"&&!U.nt(t)&&U.si(t,"string or function",Panel,"itemCategoryProperty"),this.Yt().x0=t,this.t("itemCategoryProperty",e,t))}QN(t,e){if(t===null)return"";const i=this.itemCategoryProperty;let s="";if(U.nt(i))s=i(t);else if(typeof i=="string"&&U.$(t)){if(i==="")return"";const n=this.diagram,o=n!==null?n.model:null;o?s=o.Mt(t,i):s=Model.Mt(t,i)}else return"";if(s===void 0)return"";if(typeof s=="string")return s;U.o("Panel.getCategoryForItemData found a non-string category for "+t+": "+s)}static kD=!1;static eC;static bD(){return Panel.eC||(Panel.eC=new Panel().add(new TextBlock().bind("text","",U.toString).theme("stroke","text"))),Panel.eC}_N(t,e,i){let s=null;const n=this.itemTemplateMap;return n!==null&&(s=n.get(i),s===null&&(s=n.get(""))),s===null&&(Panel.kD||(Panel.kD=!0,U.ne('No item template Panel found for category "'+i+'" on '+this),U.ne("  Using default item template.")),s=Panel.bD()),s}get Af(){return(this.n&1048576)!==0}set Af(t){const e=(this.n&1048576)!==0;e!==t&&(U.s(t,"boolean",Panel,"isAtomic"),this.n=this.n^1048576,this.t("isAtomic",e,t))}get isClipping(){return(this.n&2097152)!==0}set isClipping(t){const e=(this.n&2097152)!==0;e!==t&&(this.wf(),this.n=this.n^2097152,this instanceof Group&&(this.he=null),this.c(),this.t("isClipping",e,t))}get isOpposite(){return(this.n&33554432)!==0}set isOpposite(t){const e=(this.n&33554432)!==0;e!==t&&(this.n=this.n^33554432,this.c(),this.t("isOpposite",e,t))}get isEnabled(){return(this.n&4194304)!==0}set isEnabled(t){const e=(this.n&4194304)!==0;if(e!==t){const i=this.panel===null||this.panel.isEnabledObject();this.n=this.n^4194304,this.t("isEnabled",e,t);const s=this.diagram;if(s!==null&&s.undoManager.isUndoingRedoing)return;i&&this.$1(this,t)}}$1(t,e){const i=t.enabledChanged;if(i!==null&&i(t,e),t instanceof Panel){const s=t.D.r,n=s.length;for(let o=0;o<n;o++){const r=s[o];e&&r instanceof Panel&&!r.isEnabled||this.$1(r,e)}}}get alignmentFocusName(){return this.uo}set alignmentFocusName(t){const e=this.uo;e!==t&&(this.uo=t,this.c(),this.t("alignmentFocusName",e,t))}static definePanelLayout(t,e){PanelLayout.Tn(t,e)}static isLayoutDefined(t){return PanelLayout.fs.has(t)}static Position=PanelLayout.fs.get("Position");static Horizontal=PanelLayout.fs.get("Horizontal");static Vertical=PanelLayout.fs.get("Vertical");static Spot=PanelLayout.fs.get("Spot");static Auto=PanelLayout.fs.get("Auto");static Table=PanelLayout.fs.get("Table");static Viewbox=PanelLayout.fs.get("Viewbox");static TableRow=PanelLayout.fs.get("TableRow");static TableColumn=PanelLayout.fs.get("TableColumn");static Link=PanelLayout.fs.get("Link");static Grid=PanelLayout.fs.get("Grid");static Graduated=PanelLayout.fs.get("Graduated")}Panel.definePanelLayout=Panel.definePanelLayout;class GradPanelSettings{F0;R0;O0;I0;Fs;ts;ds;vi;constructor(){this.F0=0,this.R0=100,this.O0=10,this.I0=0,this.Fs=null,this.ts=null,this.ds=null,this.vi=null}copy(){const t=new GradPanelSettings;return t.F0=this.F0,t.R0=this.R0,t.O0=this.O0,t.I0=this.I0,t.Fs=this.Fs,t.ts=this.ts,t.ds=this.ds,t.vi=this.vi,t}}class GridPanelSettings{Fd;Rd;lf;M0;constructor(){this.Fd=Size.OL,this.Rd=Point.gn,this.lf=Size.$w,this.M0=[]}copy(){const t=new GridPanelSettings;return t.Fd=this.Fd.copy(),t.Rd=this.Rd.copy(),t.lf=this.lf.copy(),t.M0=this.M0,t}}class TablePanelSettings{Qi;_i;U0;V0;B0;z0;N0;L0;C0;A0;D0;T0;v0;La;constructor(){this.Qi=[],this._i=[],this.U0=3,this.V0=3,this.B0=0,this.z0=0,this.N0=Margin.em,this.L0=1,this.C0=null,this.A0=null,this.D0=1,this.T0=null,this.v0=null,this.La=null}copy(t){const e=new TablePanelSettings,i=this.Qi,s=i.length,n=e.Qi;for(let a=0;a<s;a++){const h=i[a];if(h===void 0)continue;const c=h.copy();c.Eh(t),n[a]=c}const o=this._i,r=o.length,l=e._i;for(let a=0;a<r;a++){const h=o[a];if(h===void 0)continue;const c=h.copy();c.Eh(t),l[a]=c}return e.U0=this.U0,e.V0=this.V0,e.B0=this.B0,e.z0=this.z0,e.N0=this.N0.N(),e.L0=this.L0,e.C0=this.C0,e.A0=this.A0,e.D0=this.D0,e.T0=this.T0,e.v0=this.v0,e.La=this.La,e}}var Sizing=(w=>(w[w.Default=1]="Default",w[w.None=2]="None",w[w.ProportionalExtra=3]="ProportionalExtra",w))(Sizing||{});class RowColumnDefinition{Zs;X0;Tt;zh;Xh;de;ct;Id;ho;al;Ed;Ud;Gh;Lt;Vd;Rs;j;Re;bi;constructor(t){GSet.Je(this),this.Zs=null,this.X0=!0,this.Tt=0,this.bi=NaN,this.zh=0,this.Xh=1/0,this.de=Spot.Default,this.j=0,this.Re=0,this.ct=0,this.Rs=null,this.Id=1,this.ho=1,this.al=null,this.Ed=null,this.Ud=NaN,this.Gh=null,this.Lt=null,this.Vd=!1,t&&(Object.assign(this,t),t.column!==void 0?(this.isRow=!1,this.index=t.column):t.row!==void 0&&(this.isRow=!0,this.index=t.row))}copy(){const t=new RowColumnDefinition;return t.X0=this.X0,t.Tt=this.Tt,t.bi=this.bi,t.zh=this.zh,t.Xh=this.Xh,t.de=this.de,t.j=this.j,t.Re=this.Re,t.ct=this.ct,t.ho=this.ho,t.Id=this.Id,this.al===null?t.al=null:t.al=this.al.N(),t.Ed=this.Ed,t.Ud=this.Ud,t.Gh=null,this.Gh!==null&&(t.separatorDashArray=this.Gh.slice()),t.Lt=this.Lt,t.Vd=this.Vd,t.Rs=this.Rs,t}z1(t){t.isRow?t.height!==void 0&&(this.height=t.height):t.width!==void 0&&(this.width=t.width),t.minimum!==void 0&&(this.minimum=t.minimum),t.maximum!==void 0&&(this.maximum=t.maximum),t.alignment!==void 0&&(this.alignment=t.alignment),t.stretch!==void 0&&(this.stretch=t.stretch),t.sizing!==void 0&&(this.sizing=t.sizing),t.separatorPadding!==void 0&&(this.separatorPadding=t.separatorPadding),t.separatorStroke!==void 0&&(this.separatorStroke=t.separatorStroke),t.separatorStrokeWidth!==void 0&&(this.separatorStrokeWidth=t.separatorStrokeWidth),t.separatorDashArray!==void 0&&(this.Gh=t.separatorDashArray),t.background!==void 0&&(this.background=t.background),t.coversSeparators!==void 0&&(this.coversSeparators=t.coversSeparators),t.Rs!==void 0&&(this.Rs=t.Rs)}fe(t){t in Sizing?this.sizing=t:U.dr(this,t)}toString(){return"RowColumnDefinition "+(this.isRow?"(Row ":"(Column ")+this.index+") #"+GSet.xs(this)}static Default=1;static None=2;static ProportionalExtra=3;Eh(t){this.Zs=t}computeEffectiveSpacingTop(t){let e=0;const i=this.Zs;if(this.index!==t){let n=this.separatorStroke;n===null&&i!==null&&(n=this.isRow?i.defaultRowSeparatorStroke:i.defaultColumnSeparatorStroke),n!==null&&(e=this.separatorStrokeWidth,isNaN(e)&&(i!==null?e=this.isRow?i.defaultRowSeparatorStrokeWidth:i.defaultColumnSeparatorStrokeWidth:e=0))}let s=this.al;if(s===null)if(i!==null)s=i.defaultSeparatorPadding;else return e;return e+(this.isRow?s.top:s.left)}computeEffectiveSpacing(){let t=0;const e=this.Zs;let i=0;const s=this.isRow;if(e!==null&&e.type===Panel.Table){const o=s?e.Qi.length:e._i.length;for(let r=0;r<o;r++){const l=s?e.Qi[r]:e._i[r];if(l!==void 0&&l.j!==0){i=l.index;break}}}if(this.index!==i){let o=this.separatorStroke;o===null&&e!==null&&(o=s?e.defaultRowSeparatorStroke:e.defaultColumnSeparatorStroke),o!==null&&(t=this.separatorStrokeWidth,isNaN(t)&&(e!==null?t=s?e.defaultRowSeparatorStrokeWidth:e.defaultColumnSeparatorStrokeWidth:t=0))}let n=this.al;if(n===null)if(e!==null)n=e.defaultSeparatorPadding;else return t;return t+(this.isRow?n.top+n.bottom:n.left+n.right)}t(t,e,i,s,n){const o=this.Zs;if(o!==null&&(o.raiseChangedEvent(2,t,this,e,i,s,n),this.Rs!==null)){const r=o.diagram;if(r!==null&&!r.yi){const l=o.findBindingPanel();if(l!==null){const a=l.data;if(a!==null){const h=this.Rs.iterator;for(;h.next();)h.value.updateSource(this,a,t,l)}}}}}get panel(){return this.Zs}get isRow(){return this.X0}set isRow(t){this.X0=t}get index(){return this.Tt}set index(t){this.Tt=t}get height(){return this.bi}set height(t){const e=this.bi;e!==t&&(t<0&&U.J(t,">= 0",RowColumnDefinition,"height"),this.bi=t,this.actual=this.j,this.panel!==null&&this.panel.c(),this.t("height",e,t))}get width(){return this.bi}set width(t){const e=this.bi;e!==t&&(t<0&&U.J(t,">= 0",RowColumnDefinition,"width"),this.bi=t,this.actual=this.j,this.panel!==null&&this.panel.c(),this.t("width",e,t))}get minimum(){return this.zh}set minimum(t){const e=this.zh;e!==t&&((t<0||!isFinite(t))&&U.J(t,">= 0",RowColumnDefinition,"minimum"),this.zh=t,this.actual=this.j,this.panel!==null&&this.panel.c(),this.t("minimum",e,t))}get maximum(){return this.Xh}set maximum(t){const e=this.Xh;e!==t&&(t<0&&U.J(t,">= 0",RowColumnDefinition,"maximum"),this.Xh=t,this.actual=this.j,this.panel!==null&&this.panel.c(),this.t("maximum",e,t))}get alignment(){return this.de}set alignment(t){const e=this.de;e.equals(t)||(this.de=t.N(),this.panel!==null&&this.panel.c(),this.t("alignment",e,t))}get stretch(){return this.ho}set stretch(t){const e=this.ho;e!==t&&(this.ho=t,this.panel!==null&&this.panel.c(),this.t("stretch",e,t))}get separatorPadding(){return this.al}set separatorPadding(t){typeof t=="number"&&(t=new Margin(t));const e=this.al;(t===null||e===null||!e.equals(t))&&(t!==null&&(t=t.N()),this.al=t,this.panel!==null&&this.panel.c(),this.t("separatorPadding",e,t))}get separatorStroke(){return this.Ed}set separatorStroke(t){const e=this.Ed;e!==t&&(t!==null&&Brush.Sd(t,"RowColumnDefinition.separatorStroke"),t instanceof Brush&&t.b(),this.Ed=t,this.panel!==null&&this.panel.c(),this.t("separatorStroke",e,t))}get separatorStrokeWidth(){return this.Ud}set separatorStrokeWidth(t){const e=this.Ud;e!==t&&(this.Ud=t,this.panel!==null&&this.panel.c(),this.t("separatorStrokeWidth",e,t))}get separatorDashArray(){return this.Gh}set separatorDashArray(t){const e=this.Gh;if(e!==t){if(t!==null&&!Array.isArray(t)&&U.si(t,"Array",RowColumnDefinition,"separatorDashArray:value"),t!==null){const i=t.length;let s=0;for(let n=0;n<i;n++){const o=t[n];(typeof o!="number"||!(o>=0)||!isFinite(o))&&U.o("separatorDashArray value "+o+" at index "+n+" must be a positive number or zero."),s+=o}if(s===0){if(e===null)return;t=null}}this.Gh=t,this.panel!==null&&this.panel.C(),this.t("separatorDashArray",e,t)}}get background(){return this.Lt}set background(t){const e=this.Lt;e!==t&&(t!==null&&Brush.Sd(t,"RowColumnDefinition.background"),t instanceof Brush&&t.b(),this.Lt=t,this.panel!==null&&this.panel.C(),this.t("background",e,t))}get coversSeparators(){return this.Vd}set coversSeparators(t){const e=this.Vd;e!==t&&(U.s(t,"boolean",RowColumnDefinition,"coversSeparators"),this.Vd=t,this.panel!==null&&this.panel.C(),this.t("coversSeparators",e,t))}get sizing(){return this.Id}set sizing(t){const e=this.Id;e!==t&&(this.Id=t,this.panel!==null&&this.panel.c(),this.t("sizing",e,t))}j1(){if(this.sizing===1){const t=this.Zs;return t===null?2:this.isRow?t.rowSizing:t.columnSizing}return this.sizing}get actual(){return this.j}set actual(t){isNaN(this.bi)?this.j=Math.max(Math.min(this.Xh,t),this.zh):this.j=Math.max(Math.min(this.Xh,this.bi),this.zh)}get measured(){return this.Re}set measured(t){this.Re=t}get total(){return this.j+this.computeEffectiveSpacing()}get position(){return this.ct}set position(t){this.ct=t}bind(t,e,i,s){return this.Pf(t,e,i,s),this}bindTwoWay(t,e,i,s){const n=this.Pf(t,e,i,s);return s===void 0&&n.makeTwoWay(),this}theme(t,e,i,s,n){return this.Na(t,e,i,s,n),this}themeData(t,e,i,s,n){return this.Na(t,e,i,s,n).ofData(),this}themeObject(t,e,i,s,n,o){return this.Na(t,e,i,s,n).ofObject(o),this}themeModel(t,e,i,s,n){return this.Na(t,e,i,s,n).ofModel(),this}Pf(t,e,i,s){let n;return typeof t=="string"?n=new Binding(t,e,i,s):n=t,this.y0(n),n}Na(t,e,i,s,n){let o;return typeof t=="string"?o=new ThemeBinding(t,e,i,s,n):o=t,this.y0(o),o}y0(t){t.Ti=this;const e=this.panel;if(e!==null){const i=e.findBindingPanel();i!==null&&i.oD()&&U.o("Cannot add a Binding to a RowColumnDefinition that is already frozen: "+t+" on "+e)}this.Rs===null&&(this.Rs=new List),this.Rs.add(t)}}class Shape extends GraphObject{ut;en;Bd;Yh;Qe;Qo;Wo;Kt;zd;Xd;K;constructor(t,e){super(),this.ut=null,this.en=null,this.Bd="None",this.Yh="black",this.Qe="black",this.Qo=1,this.Wo=null,this.Kt=null,this.zd=NaN,this.Xd=NaN,this.K=null,typeof t=="string"?this.figure=t:t&&Object.assign(this,t),e&&Object.assign(this,e)}cloneProtected(t){super.cloneProtected(t),t.ut=this.ut,t.en=this.en,t.Bd=this.Bd,t.Yh=this.Yh,t.Qe=this.Qe,t.Qo=this.Qo,this.Wo!==null&&(t.Wo=this.Wo.slice()),this.Kt!==null&&(this.Kt.me?t.Kt=this.Kt:t.Kt=this.Kt.copy()),t.zd=this.zd,t.Xd=this.Xd,this.K!==null&&(t.K=this.K.copy())}Kh(){return this.Kt===null?this.Kt=new ShapeTemplateSettings:this.Kt.me&&(this.Kt=this.Kt.copy()),this.Kt}ba(){super.ba(),this.Kt!==null&&(this.Kt.me=!0)}fe(t){t in GeometryStretch?this.geometryStretch=t:super.fe(t)}toString(){return"Shape("+(this.figure!=="None"?this.figure:this.toArrow!=="None"?this.toArrow:this.fromArrow)+")#"+GSet.xs(this)}QI(t,e){const i=this.pathPattern;if(i===null)return;i.ht(1/0,1/0);const s=i.measuredBounds;i.Ut(0,0,s.width,s.height);const n=this.geometry;if(n===null)return;t.save(),t.beginPath();const o=U.ot();if(n.type===1)o.push(n.startX),o.push(n.startY),o.push(n.endX),o.push(n.endY),this.Gd(t,e,o,i);else if(n.type===4){const r=n.figures.iterator;for(;r.next();){const l=r.value;o.length=0,o.push(l.startX),o.push(l.startY);let a=l.startX,h=l.startY,c=a,f=h;const u=l.segments.r,d=u.length;for(let m=0;m<d;m++){const g=u[m];switch(g.type){case 1:this.Gd(t,e,o,i),o.length=0,o.push(g.endX),o.push(g.endY),a=g.endX,h=g.endY,c=a,f=h;break;case 2:o.push(g.endX),o.push(g.endY),a=g.endX,h=g.endY;break;case 3:G.Wn(a,h,g.point1X,g.point1Y,g.point2X,g.point2Y,g.endX,g.endY,.5,o),a=g.endX,h=g.endY;break;case 4:G.sm(a,h,g.point1X,g.point1Y,g.endX,g.endY,.5,o),a=g.endX,h=g.endY;break;case 5:{const p=g.Fo(l),y=p.length;if(y===0){o.push(g.centerX),o.push(g.centerY),a=g.centerX,h=g.centerY;break}for(let x=0;x<y;x++){const k=p[x];G.Wn(a,h,k[2],k[3],k[4],k[5],k[6],k[7],.5,o),a=k[6],h=k[7]}break}case 6:{const p=g.Ja(l,a,h),y=p.length;if(y===0){o.push(g.endX),o.push(g.endY),a=g.endX,h=g.endY;break}for(let x=0;x<y;x++){const k=p[x];G.Wn(a,h,k[2],k[3],k[4],k[5],k[6],k[7],.5,o),a=k[6],h=k[7]}break}default:U.o("Segment not of valid type: "+g.type)}g.isClosed&&(o.push(c),o.push(f),this.Gd(t,e,o,i))}this.Gd(t,e,o,i)}}else if(n.type===2)o.push(n.startX),o.push(n.startY),o.push(n.endX),o.push(n.startY),o.push(n.endX),o.push(n.endY),o.push(n.startX),o.push(n.endY),o.push(n.startX),o.push(n.startY),this.Gd(t,e,o,i);else if(n.type===3){const r=new PathFigure;r.startX=n.endX,r.startY=(n.startY+n.endY)/2;const l=new PathSegment(5);l.startAngle=0,l.sweepAngle=360,l.centerX=(n.startX+n.endX)/2,l.centerY=(n.startY+n.endY)/2,l.radiusX=Math.abs(n.startX-n.endX)/2,l.radiusY=Math.abs(n.startY-n.endY)/2,r.add(l);const a=l.Fo(r),h=a.length;if(h===0)o.push(l.centerX),o.push(l.centerY);else{let c=r.startX,f=r.startY;for(let u=0;u<h;u++){const d=a[u];G.Wn(c,f,d[2],d[3],d[4],d[5],d[6],d[7],.5,o),c=d[6],f=d[7]}}this.Gd(t,e,o,i)}U.Z(o),t.restore(),t.clearContextCache(!1)}_I(t){let e=t.measuredBounds.width;return t instanceof Shape&&(e-=t.strokeWidth),e<1&&(e=1),e}Gd(t,e,i,s){const n=i.length;if(n<4)return;const o=s.measuredBounds,r=Math.max(1,o.width),l=o.height;let a=i[0],h=i[1],c=0,f=0,u=0,d=0,m=0,g=0,p=0,y=0;const x=U.ot();for(let N=2;N<n;N+=2)c=i[N],f=i[N+1],u=c-a,d=f-h,u===0&&(u=.001),m=d/u,g=Math.atan2(d,u),p=Math.sqrt(u*u+d*d),x.push([u,g,m,p]),y+=p,a=c,h=f;a=i[0],h=i[1];const k=this._I(s);let b=k;const P=r/2;let S=P!==0,L=0,C=x[L];u=C[0],g=C[1],m=C[2],p=C[3];let M=0;for(;y>=.1;){if(M===0&&(S?(b=k,b-=P,y-=P,S=!1):b=k,b===0&&(b=1)),b>y){b=y,U.Z(x);return}b>p?(M=b-p,b=p):M=0;let N=Math.sqrt(b*b/(1+m*m));if(u<0&&(N=-N),a+=N,h+=m*N,t.translate(a,h),t.rotate(g),t.translate(-(r/2),-(l/2)),M===0&&s.Ma(t,e),t.translate(r/2,l/2),t.rotate(-g),t.translate(-a,-h),y-=b,p-=b,M!==0){if(L++,L===x.length){U.Z(x);return}C=x[L],u=C[0],g=C[1],m=C[2],p=C[3],b=M}}U.Z(x)}Ma(t,e){const i=t instanceof SVGContext;let s=this.Qe;const n=this.Yh;if(s===null&&n===null)return;const o=this.ut;if(o===null)return;t.commitTransform();const r=this.actualBounds,l=this.naturalBounds;n!==null&&this.kn(t,n,!0,!1,l,r);const a=this.part;let h=this.Qo;s!==null&&h===0&&a!==null&&(this.isPanelMain||a.findMainElement()===this)&&(h=a.tE()),h===0&&(s=null),s!==null&&h!==0&&(this.kn(t,s,!1,!1,l,r),t.lineWidth=h,t.lineJoin=this.strokeJoin,t.lineCap=this.strokeCap,t.miterLimit=this.strokeMiterLimit);let c=!1;a&&e.getRenderingHint("drawShadows")&&(c=a.isShadowed),t.rl===!1&&(c=!1);let f=!0;s!==null&&(n===null||n==="transparent")&&(f=!1);let u=!1;const d=this.strokeDashArray;if(d!==null&&(u=!0,t.enableDash(d,this.strokeDashOffset)),o.type===1)t.beginPath(),t.moveTo(o.startX,o.startY),t.lineTo(o.endX,o.endY),s!==null&&t.strokeContext(),t.endPath();else if(o.type===2){const m=o.startX,g=o.startY,p=o.endX,y=o.endY,x=Math.min(m,p),k=Math.min(g,y),b=Math.abs(p-m),P=Math.abs(y-g);t.beginPath(),t.rect(x,k,b,P),n!==null&&t.fillContext(n,!1,null),s!==null&&(f&&c&&t.shadowsOff(),t.strokeContext(),f&&c&&t.shadowsOn()),t.endPath()}else if(o.type===3){const m=o.startX,g=o.startY,p=o.endX,y=o.endY,x=Math.abs(p-m)/2,k=Math.abs(y-g)/2,b=Math.min(m,p)+x,P=Math.min(g,y)+k;t.beginPath(),t.moveTo(b,P-k),t.bezierCurveTo(b+G.qn*x,P-k,b+x,P-G.qn*k,b+x,P),t.bezierCurveTo(b+x,P+G.qn*k,b+G.qn*x,P+k,b,P+k),t.bezierCurveTo(b-G.qn*x,P+k,b-x,P+G.qn*k,b-x,P),t.bezierCurveTo(b-x,P-G.qn*k,b-G.qn*x,P-k,b,P-k),t.closePath(),n!==null&&t.fillContext(n,!1,null),s!==null&&(f&&c&&t.shadowsOff(),t.strokeContext(),f&&c&&t.shadowsOn()),t.endPath()}else if(o.type===4){const m=o.figures,g=m.length;for(let p=0;p<g;p++){const y=m.r[p];i?(t.beginPath(),this.PD(t,y)):y.ji===null&&(y.ji=new Path2D,this.PD(y.ji,y));const x=y.isFilled;c?y.isShadowed?(x===!0&&n!=="transparent"&&n!==null&&t.fillContext(n,y.isEvenOdd,y.ji),s!==null&&(x&&f&&t.shadowsOff(),t.stroke(y.ji),x&&f&&t.shadowsOn())):(t.shadowsOff(),x&&n!=="transparent"&&n!==null&&t.fillContext(n,y.isEvenOdd,y.ji),s!==null&&t.stroke(y.ji),t.shadowsOn()):(x&&n!==null&&t.fillContext(n,y.isEvenOdd,y.ji),s!==null&&t.stroke(y.ji)),t.endPath(p)}}u&&t.disableDash(),this.QI(t,e)}PD(t,e){t.moveTo(e.startX,e.startY);const i=e.segments.r,s=i.length;let n=null;for(let o=0;o<s;o++){const r=i[o];switch(r.type){case 1:t.moveTo(r.endX,r.endY);break;case 2:t.lineTo(r.endX,r.endY);break;case 3:t.bezierCurveTo(r.point1X,r.point1Y,r.point2X,r.point2Y,r.endX,r.endY);break;case 4:t.quadraticCurveTo(r.point1X,r.point1Y,r.endX,r.endY);break;case 5:if(r.radiusX===r.radiusY){const l=n!==null?n.endX:e.startX,a=n!==null?n.endY:e.startY,h=Math.PI/180;t.arc(r.point1X,r.point1Y,r.radiusX,r.startAngle*h,(r.startAngle+r.sweepAngle)*h,r.sweepAngle<0,l,a)}else{const l=r.Fo(e),a=l.length;if(a===0){t.lineTo(r.centerX,r.centerY);break}for(let h=0;h<a;h++){const c=l[h];h===0&&t.lineTo(c[0],c[1]),t.bezierCurveTo(c[2],c[3],c[4],c[5],c[6],c[7])}}break;case 6:{let l=0,a=0,h;if(n!==null&&n.type===5){h=n.Fo(e);const f=h.length;if(f===0){t.lineTo(r.endX,r.endY);break}const u=h[f-1]||null;u!==null&&(l=u[6],a=u[7])}else l=n!==null?n.endX:e.startX,a=n!==null?n.endY:e.startY;h=r.Ja(e,l,a);const c=h.length;if(c===0){t.lineTo(r.endX,r.endY);break}for(let f=0;f<c;f++){const u=h[f];t.bezierCurveTo(u[2],u[3],u[4],u[5],u[6],u[7])}break}}r.isClosed&&t.closePath(),n=r}}yf(t,e,i){if(!super.yf(t,e,i)||this.Qe===null&&this.Yh===null||this.ut===null||this.pathPattern!==null)return!1;const s=this.svg.getElementsByTagName("path");return this.geometry.figures.length!==s.length?!1:(t.currentPath=this.svg,this.Ma(t,e),t.currentPath=null,!0)}kd(t){return this.geometry!==null&&this.geometry.figures.length>1||this.pathPattern!==null?!0:super.kd(t)}LN(t,e){if(t.nodeName!=="g")t.setAttributeNS(null,"filter",e);else{const i=t.getElementsByTagName("path");for(let s=0;s<i.length;s++)i[s].setAttributeNS(null,"filter",e)}}getDocumentPoint(t,e){if(e===void 0&&(e=new Point),t instanceof Spot){const i=t;i.isNoSpot()&&U.o("getDocumentPoint Spot must be a real, specific Spot, not: "+i.toString());const s=this.naturalBounds,n=this.strokeWidth;return e.e(i.x*(s.width+n)-n/2+s.x+i.offsetX,i.y*(s.height+n)-n/2+s.y+i.offsetY),this.Js.gt(e),e}else return e.set(t),this.Js.gt(e),e}getDocumentBounds(t){t===void 0&&(t=new Rect);const e=this.naturalBounds,i=this.Js,s=Rect.z(e.x,e.y,e.width,e.height),n=this.strokeWidth;s.inflate(n/2,n/2);const o=Point.z(s.x,s.y).v(i);return t.e(o.x,o.y,0,0),o.e(s.right,s.y).v(i),t.re(o.x,o.y,0,0),o.e(s.right,s.bottom).v(i),t.re(o.x,o.y,0,0),o.e(s.x,s.bottom).v(i),t.re(o.x,o.y,0,0),Rect.i(s),Point.i(o),t}ka(t,e){const i=this.geometry;if(i===null||this.fill===null&&this.stroke===null)return!1;const s=i.bounds;let n=this.strokeWidth/2;i.type===1&&!e&&(n+=2);const o=Rect.l();if(o.h(s),o.inflate(n+2,n+2),!o.containsPoint(t))return Rect.i(o),!1;const r=n+1e-4;if(i.type===1){if(this.stroke===null)return!1;const l=(i.startX-i.endX)*(t.x-i.endX)+(i.startY-i.endY)*(t.y-i.endY),a=(i.endX-i.startX)*(t.x-i.startX)+(i.endY-i.startY)*(t.y-i.startY);return l<0||a<0?!1:(Rect.i(o),G.Ve(i.startX,i.startY,i.endX,i.endY,n,t.x,t.y))}else if(i.type===2){const l=i.startX,a=i.startY,h=i.endX,c=i.endY;if(o.x=Math.min(l,h),o.y=Math.min(a,c),o.width=Math.abs(h-l),o.height=Math.abs(c-a),this.fill===null){if(o.inflate(-r,-r),o.containsPoint(t))return Rect.i(o),!1;o.inflate(r,r)}this.stroke!==null&&o.inflate(n,n);const f=o.containsPoint(t);return Rect.i(o),f}else if(i.type===3){const l=i.startX,a=i.startY,h=i.endX,c=i.endY;let f=Math.min(l,h),u=Math.min(a,c);const d=Math.abs(h-l),m=Math.abs(c-a);let g=d/2,p=m/2;if(f=t.x-(f+g),u=t.y-(u+p),this.fill===null){if(g-=r,p-=r,g<=0||p<=0)return Rect.i(o),!1;if(f*f/(g*g)+u*u/(p*p)<=1)return Rect.i(o),!1;g+=r,p+=r}return this.stroke!==null&&(g+=r,p+=r),Rect.i(o),g<=0||p<=0?!1:f*f/(g*g)+u*u/(p*p)<=1}else{if(i.type===4)return Rect.i(o),this.fill===null?i.ZL(t.x,t.y,n):i.UP(t,n,this.strokeWidth>1,e);U.o("Unknown Geometry type: "+i.type)}}xd(t,e,i,s){const n=this.desiredSize,o=this.Qo;t=Math.max(t,0),e=Math.max(e,0);let r;if(this.en!==null)r=this.geometry.bounds;else{const g=this.figure;let p=Shape.iC[g];if(p===void 0){let y=G.Jn[g];typeof y=="string"&&(y=G.Jn[y]),U.nt(y)?(p=y(null,100,100),Shape.iC[g]=p):U.o("Unsupported Figure: "+g)}r=p.bounds}let l=r.width,a=r.height,h=r.width,c=r.height;switch(this.Qs(!0)){case 0:i=0,s=0;break;case 2:h=Math.max(t-o,0),c=Math.max(e-o,0);break;case 5:h=Math.max(t-o,0),s=0;break;case 4:i=0,c=Math.max(e-o,0);break}isFinite(n.width)&&(h=n.width),isFinite(n.height)&&(c=n.height);const u=this.maxSize,d=this.minSize;i=Math.max(i-o,d.width),s=Math.max(s-o,d.height),h=Math.min(u.width,h),c=Math.min(u.height,c),h=isFinite(h)?Math.max(i,h):Math.max(l,i),c=isFinite(c)?Math.max(s,c):Math.max(a,s);const m=this.QS();switch(m){case 0:break;case 2:l=h,a=c;break;case 6:{let g=Math.min(h/l,c/a);isFinite(g)||(g=1),l=l*g,a=a*g;break}default:U.o(m+" is not a valid geometryStretch.")}if(this.en!==null){l===0&&(l=.001),a===0&&(a=.001);const g=this.en.sR(l,a);this.ut=g}else(this.ut===null||!G.X(this.ut.Pc,t-o)||!G.X(this.ut.Sc,e-o))&&(this.ut=Shape.eE(this,l,a));r=this.ut.bounds,t===1/0||e===1/0?this.lo(r.x-o/2,r.y-o/2,t===0&&l===0?0:r.width+o,e===0&&a===0?0:r.height+o):this.lo(-(o/2),-(o/2),h+o,c+o),n.isReal()?(h=n.width,c=n.height,h=Math.min(u.width,h),c=Math.min(u.height,c),h=Math.max(d.width,h),c=Math.max(d.height,c),this.Ke.e(0,0,h,c)):this.Ke.h(r)}QS(){const t=this.geometryStretch;return this.en!==null?t===1?2:t:t===1?Shape.iC[this.figure].defaultStretch:t}Pa(t,e,i,s){this.commonArrange(t,e,i,s)}getNearestIntersectionPoint(t,e,i){return this.mf(t.x,t.y,e.x,e.y,i)}mf(t,e,i,s,n){const o=this.v,r=1/(o.m11*o.m22-o.m12*o.m21),l=o.m22*r,a=-o.m12*r,h=-o.m21*r,c=o.m11*r,f=r*(o.m21*o.dy-o.m22*o.dx),u=r*(o.m12*o.dx-o.m11*o.dy),d=t*l+e*h+f,m=t*a+e*c+u,g=i*l+s*h+f,p=i*a+s*c+u,y=this.Qo/2;let x=this.ut;x===null&&(this.ht(1/0,1/0),x=this.ut);const k=x.bounds;let b=!1;if(x.type===1)if(this.strokeWidth<=1.5)b=G.vo(x.startX,x.startY,x.endX,x.endY,d,m,g,p,n);else{let P=0,S=0;if(x.startX===x.endX)P=y,S=0;else{const T=(x.endY-x.startY)/(x.endX-x.startX);S=y/Math.sqrt(1+T*T),P=S*T}const L=U.ot();let C=new Point;G.vo(x.startX+P,x.startY+S,x.endX+P,x.endY+S,d,m,g,p,C)&&L.push(C),C=new Point,G.vo(x.startX-P,x.startY-S,x.endX-P,x.endY-S,d,m,g,p,C)&&L.push(C),C=new Point,G.vo(x.startX+P,x.startY+S,x.startX-P,x.startY-S,d,m,g,p,C)&&L.push(C),C=new Point,G.vo(x.endX+P,x.endY+S,x.endX-P,x.endY-S,d,m,g,p,C)&&L.push(C);const M=L.length;if(M===0)return U.Z(L),!1;b=!0;let N=1/0;for(let T=0;T<M;T++){const A=L[T],D=(A.x-d)**2+(A.y-m)**2;D<N&&(N=D,n.x=A.x,n.y=A.y)}U.Z(L)}else if(x.type===2)b=G.Cl(k.x-y,k.y-y,k.x+k.width+y,k.y+k.height+y,d,m,g,p,n);else if(x.type===3){const P=Rect.z(k.x,k.y,k.width,k.height).inflate(y,y);b=this.iE(P,d,m,g,p,n),Rect.i(P)}else if(x.type===4){let P=0,S=0,L=0,C=0;const M=Point.l();let N=g-d,T=p-m,A=N*N+T*T,D=d,v=m;if(A>0&&k.contains(D,v)&&(M.x=D,M.y=v,this.containsPoint(M)))for(N!==0&&Math.abs(N)<.5?(T*=.5/N,N=.5):T!==0&&Math.abs(T)<.5&&(N*=.5/T,T=.5),D-=N,v-=T;k.contains(D,v);)D-=N,v-=T;const R=.6;n.x=g,n.y=p;for(let Y=0;Y<x.figures.count;Y++){const E=x.figures.r[Y],X=E.isFilled?D:d,B=E.isFilled?v:m,H=E.segments;P=E.startX,S=E.startY;let j=P,W=S;for(let Z=0;Z<H.count;Z++){const V=H.r[Z],$=V.type;L=V.endX,C=V.endY;let J=!1;switch($){case 1:j=L,W=C;break;case 2:J=this.Q1(P,S,L,C,X,B,g,p,M);break;case 3:{J=G.nm(P,S,V.point1X,V.point1Y,V.point2X,V.point2Y,L,C,X,B,g,p,R,M);break}case 4:{J=G.nm(P,S,P+2/3*(V.point1X-P),S+2/3*(V.point1Y-S),L+2/3*(V.point1X-L),C+2/3*(V.point1Y-C),L,C,X,B,g,p,R,M);break}case 5:case 6:{const tt=V.type===5?V.Fo(E):V.Ja(E,P,S),K=tt.length;if(K===0){J=this.Q1(P,S,V.type===5?V.centerX:V.endX,V.type===5?V.centerY:V.endY,X,B,g,p,M);break}let I=null;for(let q=0;q<K;q++){if(I=tt[q],q===0&&this.Q1(P,S,I[0],I[1],X,B,g,p,M)){const Q=this._1(X,B,M,A,n);Q<A&&(A=Q,b=!0)}if(G.nm(I[0],I[1],I[2],I[3],I[4],I[5],I[6],I[7],X,B,g,p,R,M)){const Q=this._1(X,B,M,A,n);Q<A&&(A=Q,b=!0)}}L=I[6],C=I[7];break}default:U.o("Unknown Segment type: "+$)}if(P=L,S=C,J){const tt=this._1(X,B,M,A,n);tt<A&&(A=tt,b=!0)}if(V.isClosed&&(L=j,C=W,this.Q1(P,S,L,C,X,B,g,p,M))){const tt=this._1(X,B,M,A,n);tt<A&&(A=tt,b=!0)}}}let F=i-t,O=s-e;const z=Math.sqrt(F*F+O*O);z!==0&&(F/=z,O/=z),n.x-=F*y,n.y-=O*y,Point.i(M)}else U.o("Unknown Geometry type: "+x.type);return b?(this.v.gt(n),!0):!1}_1(t,e,i,s,n){const o=i.x-t,r=i.y-e,l=o*o+r*r;return l<s?(n.x=i.x,n.y=i.y,l):s}Q1(t,e,i,s,n,o,r,l,a){if(G.X(t,i)&&G.X(e,s)||G.X(n,r)&&G.X(o,l))return!1;let h=!1;const c=(n-r)*(e-s)-(o-l)*(t-i);if(c===0)return!1;if(a.x=((n*l-o*r)*(t-i)-(n-r)*(t*s-e*i))/c,a.y=((n*l-o*r)*(e-s)-(o-l)*(t*s-e*i))/c,(t>i?t-i:i-t)<(e>s?e-s:s-e)){const f=e<s?e:s,u=e<s?s:e;(a.y>f||G.X(a.y,f))&&(a.y<u||G.X(a.y,u))&&(h=!0)}else{const f=t<i?t:i,u=t<i?i:t;(a.x>f||G.X(a.x,f))&&(a.x<u||G.X(a.x,u))&&(h=!0)}return h}sE(t,e,i){return this.pickable===!1?!1:(i.bc(this.v),e?this.nE(t,i):this.containedInRect(t,i))}containedInRect(t,e){if(e===void 0)return t.containsRect(this.actualBounds);let i=this.ut;i===null&&(this.ht(1/0,1/0),i=this.ut);const s=i.bounds,n=this.strokeWidth/2;let o=!1;const r=Point.l();return r.e(s.x-n,s.y-n),t.containsPoint(e.gt(r))&&(r.e(s.x-n,s.bottom+n),t.containsPoint(e.gt(r))&&(r.e(s.right+n,s.bottom+n),t.containsPoint(e.gt(r))&&(r.e(s.right+n,s.y-n),t.containsPoint(e.gt(r))&&(o=!0)))),Point.i(r),o}intersectsRect(t,e){if(this.containedInRect(t,e)||e===void 0&&(e=this.v,t.containsRect(this.actualBounds)))return!0;const i=Transform.l();i.set(e),i.tx();const s=t.left,n=t.right,o=t.top,r=t.bottom,l=Point.l();if(l.e(s,o),i.gt(l),this.ka(l,!0))return Point.i(l),!0;if(l.e(n,o),i.gt(l),this.ka(l,!0))return Point.i(l),!0;if(l.e(s,r),i.gt(l),this.ka(l,!0))return Point.i(l),!0;if(l.e(n,r),i.gt(l),this.ka(l,!0))return Point.i(l),!0;const a=Point.l(),h=Point.l();i.set(e),i.zL(this.v),i.tx(),a.x=n,a.y=o,a.v(i),l.x=s,l.y=o,l.v(i);let c=!1;return this.Hh(l,a,h)?c=!0:(l.x=n,l.y=r,l.v(i),this.Hh(l,a,h)?c=!0:(a.x=s,a.y=r,a.v(i),this.Hh(l,a,h)?c=!0:(l.x=s,l.y=o,l.v(i),this.Hh(l,a,h)&&(c=!0)))),Point.i(l),Transform.i(i),Point.i(a),Point.i(h),c}Hh(t,e,i){if(!this.getNearestIntersectionPoint(t,e,i))return!1;const s=t.x,n=t.y,o=e.x,r=e.y,l=i.x,a=i.y;if(s===o){let h=0,c=0;return n<r?(h=n,c=r):(h=r,c=n),a>=h&&a<=c}else{let h=0,c=0;return s<o?(h=s,c=o):(h=o,c=s),l>=h&&l<=c}}nE(t,e){if(this.containedInRect(t,e)||e===void 0&&(e=this.v,t.containsRect(this.actualBounds)))return!0;const i=t.left,s=t.right,n=t.top,o=t.bottom,r=Point.l(),l=Point.l(),a=Point.l(),h=Transform.l();h.set(e),h.zL(this.v),h.tx(),l.x=s,l.y=n,l.v(h),r.x=i,r.y=n,r.v(h);let c=!1;return this.Hh(r,l,a)?c=!0:(r.x=s,r.y=o,r.v(h),this.Hh(r,l,a)?c=!0:(l.x=i,l.y=o,l.v(h),this.Hh(r,l,a)?c=!0:(r.x=i,r.y=n,r.v(h),this.Hh(r,l,a)&&(c=!0)))),Transform.i(h),Point.i(r),Point.i(l),Point.i(a),c}$T(t,e,i){if(i&&this.fill!==null&&this.ka(t,!0))return!0;let s=t.distanceSquaredPoint(e);const n=s;this.strokeWidth>1.5&&(s=this.strokeWidth/2+Math.sqrt(s),s*=s);let o=this.ut;if(o===null&&(this.ht(1/0,1/0),o=this.ut,o===null))return!1;if(!i){const f=o.bounds,u=f.x,d=f.y,m=f.x+f.width,g=f.y+f.height;if(Point.distanceSquared(t.x,t.y,u,d)<=s&&Point.distanceSquared(t.x,t.y,m,d)<=s&&Point.distanceSquared(t.x,t.y,u,g)<=s&&Point.distanceSquared(t.x,t.y,m,g)<=s)return!0}function r(f,u){const d=f.length;for(let m=0;m<d;m+=2)if(u.distanceSquared(f[m],f[m+1])>s)return!0;return!1}const l=o.startX,a=o.startY,h=o.endX,c=o.endY;if(o.type===1){const f=Point.distanceLineSegmentSquared(t.x,t.y,l,a,h,c),u=(h-l)*(t.x-l)+(c-a)*(t.y-a),d=(l-h)*(t.x-h)+(a-c)*(t.y-c),m=u>=0&&d>=0?s:n;return f<=m}else if(o.type===2){let f=!1;return i&&(f=Point.distanceLineSegmentSquared(t.x,t.y,l,a,l,c)<=s||Point.distanceLineSegmentSquared(t.x,t.y,l,a,h,a)<=s||Point.distanceLineSegmentSquared(t.x,t.y,h,a,h,c)<=s||Point.distanceLineSegmentSquared(t.x,t.y,l,c,h,c)<=s),f}else if(o.type===3){const f=(l+h)/2,u=(a+c)/2,d=t.x-f,m=t.y-u,g=Math.abs(h-l)/2,p=Math.abs(c-a)/2;if(g===0||p===0)return Point.distanceLineSegmentSquared(t.x,t.y,l,a,h,c)<=s;if(i){const y=G.WF(g,p,d,m);return y*y<=s}else return!(Point.distanceSquared(d,m,-g,0)>=s||Point.distanceSquared(d,m,0,-p)>=s||Point.distanceSquared(d,m,0,p)>=s||Point.distanceSquared(d,m,g,0)>=s)}else if(o.type===4){const f=o.bounds,u=f.x,d=f.y,m=f.x+f.width,g=f.y+f.height;if(t.x>m&&t.x<u&&t.y>g&&t.y<d&&Point.distanceLineSegmentSquared(t.x,t.y,u,d,u,g)>s&&Point.distanceLineSegmentSquared(t.x,t.y,u,d,m,d)>s&&Point.distanceLineSegmentSquared(t.x,t.y,m,g,u,g)>s&&Point.distanceLineSegmentSquared(t.x,t.y,m,g,m,d)>s)return!1;const p=Math.sqrt(s);if(i){if(this.fill===null?o.ZL(t.x,t.y,p):o.UP(t,p,!0,!1))return!0}else{const y=o.figures;for(let x=0;x<y.count;x++){const k=y.r[x];let b=k.startX,P=k.startY;if(t.distanceSquared(b,P)>s)return!1;const S=k.segments.r,L=S.length;for(let C=0;C<L;C++){const M=S[C];switch(M.type){case 1:case 2:if(b=M.endX,P=M.endY,t.distanceSquared(b,P)>s)return!1;break;case 3:{const N=U.ot();G.Wn(b,P,M.point1X,M.point1Y,M.point2X,M.point2Y,M.endX,M.endY,.8,N);const T=r(N,t);if(U.Z(N),T||(b=M.endX,P=M.endY,t.distanceSquared(b,P)>s))return!1;break}case 4:{const N=U.ot();G.sm(b,P,M.point1X,M.point1Y,M.endX,M.endY,.8,N);const T=r(N,t);if(U.Z(N),T||(b=M.endX,P=M.endY,t.distanceSquared(b,P)>s))return!1;break}case 5:case 6:{const N=M.type===5?M.Fo(k):M.Ja(k,b,P),T=N.length;if(T===0){if(b=M.type===5?M.centerX:M.endX,P=M.type===5?M.centerY:M.endY,t.distanceSquared(b,P)>s)return!1;break}let A=null;const D=U.ot();for(let v=0;v<T;v++)if(A=N[v],D.length=0,G.Wn(A[0],A[1],A[2],A[3],A[4],A[5],A[6],A[7],.8,D),r(D,t))return U.Z(D),!1;U.Z(D),A!==null&&(b=A[6],P=A[7]);break}default:U.o("Unknown Segment type: "+M.type)}}}return!0}}return!1}iE(t,e,i,s,n,o){if(t.width===0)return G.vo(t.x,t.y,t.x,t.y+t.height,e,i,s,n,o);if(t.height===0)return G.vo(t.x,t.y,t.x+t.width,t.y,e,i,s,n,o);{const r=t.width/2,l=t.height/2,a=t.x+r,h=t.y+l;let c=9999;if(e!==s&&(c=(i-n)/(e-s)),Math.abs(c)<9999){const f=i-h-c*(e-a);if(r*r*(c*c)+l*l-f*f<0)return o.x=NaN,o.y=NaN,!1;const u=Math.sqrt(r*r*(c*c)+l*l-f*f),d=(-(r*r*c*f)+r*l*u)/(l*l+r*r*(c*c))+a,m=(-(r*r*c*f)-r*l*u)/(l*l+r*r*(c*c))+a,g=c*(d-a)+f+h,p=c*(m-a)+f+h,y=Math.abs((e-d)**2)+Math.abs((i-g)**2),x=Math.abs((e-m)**2)+Math.abs((i-p)**2);y<x?(o.x=d,o.y=g):(o.x=m,o.y=p)}else{const f=l*l,u=r*r,d=e-a,m=f-f/u*(d*d);if(m<0)return o.x=NaN,o.y=NaN,!1;const g=Math.sqrt(m),p=h+g,y=h-g,x=Math.abs(p-i),k=Math.abs(y-i);x<k?(o.x=e,o.y=p):(o.x=e,o.y=y)}return!0}}jI(){return this.Qo/2*this.strokeMiterLimit*this.getDocumentScale()}get geometry(){return this.ut!==null?this.ut:this.en}set geometry(t){const e=this.ut,i=this.en;if(e===t)return;t!==null?(this.ut=t.b(),this.en=this.ut):(this.ut=null,this.en=null);const s=this.part;if(s!==null&&s.Tf(),this.c(),this.t("geometry",e||i,t),this.gf()){const n=this.part;n!==null&&this.Oh(n,"geometryString")}}get geometryString(){return this.geometry===null?"":this.geometry.toString()}set geometryString(t){const e=Geometry.parse(t),i=e.normalize();this.geometry=e;const s=Point.z(-i.x,-i.y);this.position=s,Point.i(s)}get isGeometryPositioned(){return(this.n&1048576)!==0}set isGeometryPositioned(t){const e=(this.n&1048576)!==0;e!==t&&(this.n=this.n^1048576,this.c(),this.t("isGeometryPositioned",e,t))}Ze(){this.ut=null}get fill(){return this.Yh}set fill(t){const e=this.Yh;e!==t&&(t!==null&&Brush.Sd(t,"Shape.fill"),t instanceof Brush&&t.b(),this.Yh=t,this.C(),this.t("fill",e,t))}get stroke(){return this.Qe}set stroke(t){const e=this.Qe;e!==t&&(t!==null&&Brush.Sd(t,"Shape.stroke"),t instanceof Brush&&t.b(),this.Qe=t,this.C(),this.t("stroke",e,t))}get strokeWidth(){return this.Qo}set strokeWidth(t){const e=this.Qo;if(e!==t)if(t>=0){this.Qo=t,this.c();const i=this.part;i!==null&&i.Tf(),this.t("strokeWidth",e,t)}else U.J(t,"value >= 0",Shape,"strokeWidth:value")}Hp(){return this.Qo}get strokeCap(){return this.Kt!==null?this.Kt.G0:"butt"}set strokeCap(t){const e=this.strokeCap;e!==t&&(typeof t=="string"&&(t==="butt"||t==="round"||t==="square")?(this.Kh().G0=t,this.C(),this.t("strokeCap",e,t)):U.J(t,'"butt", "round", or "square"',Shape,"strokeCap"))}get strokeJoin(){return this.Kt!==null?this.Kt.Y0:"miter"}set strokeJoin(t){const e=this.strokeJoin;e!==t&&(typeof t=="string"&&(t==="miter"||t==="bevel"||t==="round")?(this.Kh().Y0=t,this.C(),this.t("strokeJoin",e,t)):U.J(t,'"miter", "bevel", or "round"',Shape,"strokeJoin"))}get strokeMiterLimit(){return this.Kt!==null?this.Kt.K0:10}set strokeMiterLimit(t){const e=this.strokeMiterLimit;if(e!==t&&t>=1){this.Kh().K0=t,this.C();const i=this.part;i!==null&&i.Tf(),this.t("strokeMiterLimit",e,t)}}get strokeDashArray(){return this.Wo}set strokeDashArray(t){const e=this.Wo;if(e!==t){if(t!==null&&!Array.isArray(t)&&U.si(t,"Array",Shape,"strokeDashArray:value"),t!==null){const i=t.length;let s=0;for(let n=0;n<i;n++){const o=t[n];(!(o>=0)||!isFinite(o))&&U.o("strokeDashArray:value "+o+" at index "+n+" must be a positive number or zero."),s+=o}if(s===0){if(e===null)return;t=null}}this.Wo=t,this.C(),this.t("strokeDashArray",e,t)}}get strokeDashOffset(){return this.Kt!==null?this.Kt.Ca:0}set strokeDashOffset(t){const e=this.strokeDashOffset;e!==t&&t>=0&&(this.Kh().Ca=t,this.C(),this.t("strokeDashOffset",e,t))}get figure(){return this.Bd}set figure(t){const e=this.Bd;if(e!==t){let i=G.Jn[t];if(U.nt(i)?i=t:(i=G.Jn[t.toLowerCase()],(!i||typeof i=="function")&&U.o("Unknown Shape.figure: "+t)),e!==i){const s=this.part;s!==null&&s.Tf(),this.Bd=i,this.en=null,this.Ze(),this.c(),this.t("figure",e,i)}}}get toArrow(){return this.Ot!==null?this.Ot.H0:"None"}set toArrow(t){const e=this.toArrow;if(t===!0?t="Standard":t===!1&&(t=""),e!==t){const i=Shape.SD(t);i===null?U.o("Unknown Shape.toArrow: "+t):e!==i&&(this.Ot===null&&(this.Ot=new LinkElementSettings),this.Ot.H0=i,this.en=null,this.Ze(),this.c(),this.MD(i),this.t("toArrow",e,i))}}get fromArrow(){return this.Ot!==null?this.Ot.j0:"None"}set fromArrow(t){const e=this.fromArrow;if(t===!0?t="Standard":t===!1&&(t=""),e!==t){const i=Shape.SD(t);i===null?U.o("Unknown Shape.fromArrow: "+t):e!==i&&(this.Ot===null&&(this.Ot=new LinkElementSettings),this.Ot.j0=i,this.en=null,this.Ze(),this.c(),this.MD(i),this.t("fromArrow",e,i))}}MD(t){const e=this.diagram;e!==null&&e.undoManager.isUndoingRedoing||(this.gI(),this.toArrow!=="None"?(this.segmentIndex=-1,this.alignmentFocus=Spot.Right):this.fromArrow!=="None"&&(this.segmentIndex=0,this.alignmentFocus=Spot.Left))}get spot1(){return this.Kt!==null?this.Kt.$n:Spot.Default}set spot1(t){const e=this.spot1;e.equals(t)||(t=t.N(),this.Kh().$n=t,this.c(),this.t("spot1",e,t))}get spot2(){return this.Kt!==null?this.Kt.Zn:Spot.Default}set spot2(t){const e=this.spot2;e.equals(t)||(t=t.N(),this.Kh().Zn=t,this.c(),this.t("spot2",e,t))}get parameter1(){return this.zd}set parameter1(t){const e=this.zd;e!==t&&(this.zd=t,this.Ze(),this.c(),this.t("parameter1",e,t))}get parameter2(){return this.Xd}set parameter2(t){const e=this.Xd;e!==t&&(this.Xd=t,this.Ze(),this.c(),this.t("parameter2",e,t))}get naturalBounds(){return this.Ke}II(){const t=this.desiredSize;if(!t.isReal()&&this.ut!==null){const e=this.ut.bounds;this.Ke.h(e)}else this.Ke.e(0,0,t.width,t.height)}get pathPattern(){return this.Kt!==null?this.Kt.q0:null}set pathPattern(t){const e=this.pathPattern;e!==t&&(this.Kh().q0=t,this.C(),this.t("pathPattern",e,t))}get geometryStretch(){return this.Kt!==null?this.Kt.W0:1}set geometryStretch(t){const e=this.geometryStretch;e!==t&&(this.Kh().W0=t,this.c(),this.t("geometryStretch",e,t))}get interval(){return this.K!==null?this.K.vf:1}set interval(t){const e=this.interval;if(t=Math.round(t),e!==t&&t!==0&&isFinite(t)){this.K===null&&(this.K=new GradElementSettings),this.K.vf=t;const i=this.diagram;i!==null&&this.panel===i.grid&&i.ca(),this.c();const s=this.panel;s!==null&&(s.ds=null),this.t("interval",e,t)}}get graduatedStart(){return this.K!==null?this.K.Ff:0}set graduatedStart(t){const e=this.graduatedStart;e!==t&&(t<0?t=0:t>1&&(t=1),this.K===null&&(this.K=new GradElementSettings),this.K.Ff=t,this.c(),this.t("graduatedStart",e,t))}get graduatedEnd(){return this.K!==null?this.K.Rf:1}set graduatedEnd(t){const e=this.graduatedEnd;e!==t&&(t<0?t=0:t>1&&(t=1),this.K===null&&(this.K=new GradElementSettings),this.K.Rf=t,this.c(),this.t("graduatedEnd",e,t))}get graduatedSkip(){return this.K!==null?this.K.Of:null}set graduatedSkip(t){const e=this.graduatedSkip;e!==t&&(t!==null&&U.S(t,Shape,"graduatedSkip"),this.K===null&&(this.K=new GradElementSettings),this.K.Of=t,this.c(),this.t("graduatedSkip",e,t))}polygonContainsRect(t){const e=this;if(!e.part||!e.part.actualBounds.containsRect(t))return!1;const i=e.geometry;if(!i)return!1;const s=t.x,n=t.y,o=t.width,r=t.height,l=Point.l();if(l.x=s,l.y=n,e.getLocalPoint(l,l),!i.containsPoint(l)||o>0&&r>0&&(l.x=s+o,l.y=n+r,e.getLocalPoint(l,l),!i.containsPoint(l))||o>0&&(l.x=s+o,l.y=n,e.getLocalPoint(l,l),!i.containsPoint(l))||r>0&&(l.x=s,l.y=n+r,e.getLocalPoint(l,l),!i.containsPoint(l))||i.type===1)return!1;if(i.type===4){const a=i.figures.iterator;for(;a.next();){const h=a.value;if(!h.isFilled)continue;l.x=h.startX,l.y=h.startY,e.getDocumentPoint(l,l);let c=l.x,f=l.y,u=c,d=f,m=c,g=f;const p=h.segments.iterator;for(;p.next();){const y=p.value;if(l.x=y.endX,l.y=y.endY,e.getDocumentPoint(l,l),m=l.x,g=l.y,y.type===1)c=m,f=g;else if(y.type!==5&&(Rect.intersectsLineSegment(s,n,o,r,u,d,m,g)||y.isClosed&&Rect.intersectsLineSegment(s,n,o,r,m,g,c,f)))return!1;u=m,d=g}}}return Point.i(l),!0}static eE(t,e,i){let n=null;if(t.toArrow!=="None")n=Shape.Dn[t.toArrow];else if(t.fromArrow!=="None")n=Shape.Dn[t.fromArrow];else{let o=G.Jn[t.figure];typeof o=="string"&&(o=G.Jn[o]),o===void 0&&U.o("Unknown Shape.figure: "+t.figure),n=o(t,e,i),n.Pc=e,n.Sc=i}if(n===null){const o=G.Jn.Rectangle;U.nt(o)&&(n=o(t,e,i))}return n}static getFigureGenerators(){const t=new GMap;for(const e in G.Jn){if(e===e.toLowerCase())continue;const i=G.Jn[e];t.set(e,i)}return t.b(),t}static defineFigureGenerator(t,e){U.s(t,"string",Shape,"defineFigureGenerator:name"),typeof e=="string"||U.S(e,Shape,"defineFigureGenerator:func");const i=t.toLowerCase(),s=G.Jn;s[t]=e,s[i]=t}static isFigureDefined(t){return t in G.Jn}static getArrowheadGeometries(){const t=new GMap;for(const e in G.rm)if(Shape.Dn[e]===void 0){const i=Geometry.parse(G.rm[e],!1);Shape.Dn[e]=i;const s=e.toLowerCase();s!==e&&(Shape.Dn[s]=e)}for(const e in Shape.Dn){if(e===e.toLowerCase())continue;const i=Shape.Dn[e];i instanceof Geometry&&t.set(e,i)}return t.b(),t}static defineArrowheadGeometry(t,e){U.s(t,"string",Shape,"defineArrowheadGeometry:name");let i=null;typeof e=="string"?(U.s(e,"string",Shape,"defineArrowheadGeometry:pathstr"),i=Geometry.parse(e,!1)):i=e;const s=t.toLowerCase();(s==="none"||t===s)&&U.o("Shape.defineArrowheadGeometry name must not be empty or None or all-lower-case: "+t);const n=Shape.Dn;n[t]=i,n[s]=t}static isArrowheadDefined(t){return Shape.Dn.has(t)}static Dn=new PropertyCollection;static iC=new PropertyCollection;static SD(t){let e=Shape.Dn[t];if(e===void 0){const i=t.toLowerCase();if(i==="none")return"None";if(e=Shape.Dn[i],e===void 0){let s=null;for(const n in G.rm)if(n.toLowerCase()===i){s=n;break}if(s!==null){const n=Geometry.parse(G.rm[s],!1);return Shape.Dn[s]=n,i!==s&&(Shape.Dn[i]=s),s}}}return typeof e=="string"?e:e instanceof Geometry?t:null}}class ShapeTemplateSettings{me;G0;Y0;K0;Ca;q0;W0;$n;Zn;constructor(){this.me=!1,this.G0="butt",this.Y0="miter",this.K0=10,this.Ca=0,this.q0=null,this.W0=1,this.$n=Spot.Default,this.Zn=Spot.Default}copy(){const t=new ShapeTemplateSettings;return t.G0=this.G0,t.Y0=this.Y0,t.K0=this.K0,t.Ca=this.Ca,t.q0=this.q0,t.W0=this.W0,t.$n=this.$n.N(),t.Zn=this.Zn.N(),t}}var Wrap=(w=>(w[w.None=0]="None",w[w.Fit=1]="Fit",w[w.DesiredSize=2]="DesiredSize",w[w.BreakAll=3]="BreakAll",w))(Wrap||{}),TextOverflow=(w=>(w[w.Clip=0]="Clip",w[w.Ellipsis=1]="Ellipsis",w))(TextOverflow||{}),TextFormat=(w=>(w[w.Trim=0]="Trim",w[w.None=1]="None",w))(TextFormat||{});class TextBlock extends GraphObject{ue;Qe;vn;ki;pe;jp;Yd;K;tt;Xl;go;Fn;Ii;ye;Rn;constructor(t,e){return super(),TextBlock.S0===!1&&(TextBlock.S0=!0,TextBlock.us=Diagram.isUsingDOM()?new CanvasSurface(null)._t:null),this.n|=2097152,this.ue="",this.Qe="black",this.vn="13px sans-serif",this.ki=0,this.pe=0,this.jp=0,this.Yd=null,this.K=null,this.tt=null,this.Xl=0,this.go=null,this.Fn=0,this.Ii=null,this.ye=null,this.Rn=null,typeof t=="string"?this.text=t:t&&Object.assign(this,t),e&&Object.assign(this,e),this}cloneProtected(t){super.cloneProtected(t),t.ue=this.ue,t.Qe=this.Qe,t.vn=this.vn,t.ki=this.ki,t.pe=this.pe,t.jp=this.jp,t.Yd=this.Yd,this.K!==null&&(t.K=this.K.copy()),this.tt!==null&&(this.tt.me?t.tt=this.tt:t.tt=this.tt.copy()),t.Xl=this.Xl,t.go=this.go,t.Fn=this.Fn,t.Ii=this.Ii,t.ye=this.ye,t.Rn=this.Rn}Os(){return this.tt===null?this.tt=new TextBlockTemplateSettings:this.tt.me&&(this.tt=this.tt.copy()),this.tt}ba(){super.ba(),this.tt!==null&&(this.tt.me=!0)}GI(t){this.n=t.n|2048|4096,this.Zt=t.opacity,this.Lt=t.background,this.cs=t.desiredSize.N(),this.minSize=t.minSize.N(),this.maxSize=t.maxSize.N(),t.Se!==null?this.Se=t.Se.copy():this.Se=null,this.it=t.scale,this.Xt=t.angle,this.stretch=t.stretch,this.sl=t.margin.N(),this.de=t.alignment.N(),this.yd=t.alignmentFocus.N(),this.segmentFraction=t.segmentFraction,this.segmentOffset=t.segmentOffset.N(),this.segmentOrientation=t.segmentOrientation,t.he!==null&&(this.he=t.he.copy()),this.shadowVisible=t.shadowVisible,this.ue=t.ue,this.Qe=t.Qe,this.vn=t.vn,this.K!==null&&(this.K=t.K.copy()),t.tt!==null&&(t.tt.me?this.tt=t.tt:this.tt=t.tt.copy()),this.Xl=t.Xl}zI(t){if(this.ue=t.text||"",this.Xt=t.labelAngle||0,this.ki=t.lineCount||0,this.oE(t.lines),t.naturalBounds&&(this.Ke=t.naturalBounds),t.actualBounds){const e=t.actualBounds;this.Ut(e.x,e.y,e.width,e.height)}}fe(t){t in Wrap?this.wrap=t:super.fe(t)}toString(){return this.ue.length>22?'TextBlock("'+this.ue.substring(0,20)+'"...)':'TextBlock("'+this.ue+'")'}static getEllipsis(){return TextBlock.J0}static setEllipsis(t){TextBlock.J0=t,TextBlock.tk=new PropertyCollection,TextBlock.sC=0}static getBaseline(){return TextBlock.ek}static setBaseline(t){TextBlock.ek=t}static ek=null;static getUnderline(){return TextBlock.ik}static setUnderline(t){TextBlock.ik=t}static ik=null;static None=0;static WrapFit=1;static WrapDesiredSize=2;static WrapBreakAll=3;static OverflowClip=0;static OverflowEllipsis=1;static FormatTrim=0;static FormatNone=1;c(){super.c(),this.$i(!0)}get font(){return this.vn}set font(t){const e=this.vn;e!==t&&(this.vn=t,this.go=null,this.c(),this.t("font",e,t))}static isValidFont(t){return root.CSS?root.CSS.supports("font",t):!0}get text(){return this.ue}set text(t){const e=this.ue;t!=null?t=t.toString():t="",e!==t&&(this.ue=t,this.c(),this.t("text",e,t))}get textAlign(){return this.tt!==null?this.tt.$0:"start"}set textAlign(t){const e=this.textAlign;e!==t&&(t==="start"||t==="end"||t==="left"||t==="right"||t==="center")&&(this.Os().$0=t,this.C(),this.t("textAlign",e,t))}get flip(){return this.tt!==null?this.tt.mo:0}set flip(t){const e=this.flip;e!==t&&(this.Os().mo=t,this.C(),this.t("flip",e,t))}get verticalAlignment(){return this.tt!==null?this.tt.hl:Spot.Top}set verticalAlignment(t){const e=this.verticalAlignment;e.equals(t)||(t=t.N(),this.Os().hl=t,this.kf(),this.t("verticalAlignment",e,t))}get naturalBounds(){if(!this.Ke.isReal()){const t=Size.l();this.nC(this.ue,999999,t);let e=t.width;Size.i(t);let i=this.ND(e);const s=this.desiredSize;isNaN(s.width)||(e=s.width),isNaN(s.height)||(i=s.height),this.Ke.jn(e,i)}return this.Ke}get isMultiline(){return(this.n&2097152)!==0}set isMultiline(t){const e=(this.n&2097152)!==0;e!==t&&(this.n=this.n^2097152,this.c(),this.t("isMultiline",e,t))}get isUnderline(){return(this.n&4194304)!==0}set isUnderline(t){const e=(this.n&4194304)!==0;e!==t&&(this.n=this.n^4194304,this.$i(!0),this.C(),this.t("isUnderline",e,t))}get isStrikethrough(){return(this.n&8388608)!==0}set isStrikethrough(t){const e=(this.n&8388608)!==0;e!==t&&(this.n=this.n^8388608,this.$i(!0),this.C(),this.t("isStrikethrough",e,t))}get wrap(){return this.tt!==null?this.tt.Z0:2}set wrap(t){const e=this.wrap;e!==t&&(this.Os().Z0=t,this.c(),this.t("wrap",e,t))}get overflow(){return this.tt!==null?this.tt.Q0:0}set overflow(t){const e=this.overflow;e!==t&&(this.Os().Q0=t,this.c(),this.t("overflow",e,t))}get isOverflowed(){return(this.n&16777216)!==0}oC(t){t?this.n|=16777216:this.n&=-16777217}get stroke(){return this.Qe}set stroke(t){const e=this.Qe;e!==t&&(t!==null&&Brush.Sd(t,"TextBlock.stroke"),t instanceof Brush&&t.b(),this.Qe=t,typeof t!="string"&&this.wf(),this.C(),this.t("stroke",e,t))}get lineCount(){return this.ki}get lineHeight(){return this._0()}get editable(){return(this.n&1048576)!==0}set editable(t){const e=(this.n&1048576)!==0;e!==t&&(this.n=this.n^1048576,this.t("editable",e,t))}get jN(){return(this.n&33554432)!==0}set jN(t){this.n=this.n^33554432}get textEditor(){return this.tt!==null?this.tt.ty:null}set textEditor(t){const e=this.textEditor;e!==t&&(this.Os().ty=t,this.t("textEditor",e,t))}get errorFunction(){return this.tt!==null?this.tt.gs:null}set errorFunction(t){const e=this.errorFunction;e!==t&&(t!==null&&U.S(t,TextBlock,"errorFunction"),this.Os().gs=t,this.t("errorFunction",e,t))}get interval(){return this.K!==null?this.K.vf:1}set interval(t){const e=this.interval;if(t=Math.round(t),e!==t&&t!==0&&isFinite(t)){this.K===null&&(this.K=new GradElementSettings),this.K.vf=t,this.c();const i=this.panel;i!==null&&(i.ds=null),this.t("interval",e,t)}}get graduatedStart(){return this.K!==null?this.K.Ff:0}set graduatedStart(t){const e=this.graduatedStart;e!==t&&(t<0?t=0:t>1&&(t=1),this.K===null&&(this.K=new GradElementSettings),this.K.Ff=t,this.c(),this.t("graduatedStart",e,t))}get graduatedEnd(){return this.K!==null?this.K.Rf:1}set graduatedEnd(t){const e=this.graduatedEnd;e!==t&&(t<0?t=0:t>1&&(t=1),this.K===null&&(this.K=new GradElementSettings),this.K.Rf=t,this.c(),this.t("graduatedEnd",e,t))}get graduatedFunction(){return this.K!==null?this.K.ey:null}set graduatedFunction(t){const e=this.graduatedFunction;e!==t&&(t!==null&&U.S(t,TextBlock,"graduatedFunction"),this.K===null&&(this.K=new GradElementSettings),this.K.ey=t,this.c(),this.t("graduatedFunction",e,t))}get graduatedSkip(){return this.K!==null?this.K.Of:null}set graduatedSkip(t){const e=this.graduatedSkip;e!==t&&(t!==null&&U.S(t,TextBlock,"graduatedSkip"),this.K===null&&(this.K=new GradElementSettings),this.K.Of=t,this.c(),this.t("graduatedSkip",e,t))}Ma(t,e){if(this.Qe===null||this.ue.length===0||this.vn===null)return;const i=this.naturalBounds,s=this.actualBounds,n=i.width,o=i.height,r=this._0();let l=t.textAlign=this.textAlign;const a=e.ld;l==="start"?l=a?"right":"left":l==="end"&&(l=a?"left":"right");const h=this.isUnderline,c=this.isStrikethrough;this.kn(t,this.Qe,!0,!1,i,s),(h||c)&&this.kn(t,this.Qe,!1,!1,i,s);const f=0;let u=0;const d=n;let m=!1;e.Wt===t&&!(e.Wt instanceof SVGContext)&&!this.jN&&e.getRenderingHint("textGreeking")===!0&&r*this.Lh*e.scale<3&&(m=!0);const g=this.spacingAbove,p=this.spacingBelow;switch(this.flip){case 0:break;case 2:t.translate(n,0),t.scale(-1,1);break;case 1:t.translate(0,o),t.scale(1,-1);break;case 3:t.translate(n,o),t.scale(-1,-1);break}t.commitTransform();const y=this.ki,k=(g+r+p)*y;if(o>k){const b=this.verticalAlignment;u=b.y*o-b.y*k+b.offsetY}if(TextBlock.sk&&(t.letterSpacing=this.letterSpacing,t.wordSpacing=this.wordSpacing),y===1&&this.Rn!==null){let b=this.pe;b>d&&(b=d),u+=g,this.CD(this.Rn,t,f,u,d,r,b,m,l,h,c)}else if(this.Ii!==null&&this.ye!==null)for(let b=0;b<y;b++){let P=this.Ii[b];P>d&&(P=d),u+=g,this.CD(this.ye[b],t,f,u,d,r,P,m,l,h,c),u+=r+p}switch(this.flip){case 0:break;case 2:t.scale(-1,1),t.translate(-n,0);break;case 1:t.scale(1,-1),t.translate(0,-o);break;case 3:t.scale(-1,-1),t.translate(-n,-o);break}}CD(t,e,i,s,n,o,r,l,a,h,c){let f=0;if(l){a==="left"?f=0:a==="right"?f=n-r:a==="center"&&(f=(n-r)/2);const m=e.globalAlpha;e.globalAlpha=m/2,e.fillRect(i+f,s+o/4,r,o/2),e.globalAlpha=m;return}a==="left"?f=0:a==="right"?f=n:a==="center"&&(f=n/2);const u=TextBlock.ek!==null?TextBlock.ek(this,o):o*.75;e.fillText(t,i+f,s+u);let d=o/20|0;if(d===0&&(d=1),a==="right"?f-=r:a==="center"&&(f-=r/2),h){const m=TextBlock.ik!==null?TextBlock.ik(this,o):o*.8;this.LD(i+f,s+m,i+f+r,s+m,d,e),e instanceof SVGContext&&e.lastCreatedElement.classList.add("gojs-td")}if(c){let m=s+o-o/2.2|0;d%2!==0&&(m+=.5),this.LD(i+f,m,i+f+r,m,d,e),e instanceof SVGContext&&e.lastCreatedElement.classList.add("gojs-td")}}LD(t,e,i,s,n,o){o.beginPath(),o.lineWidth=n,o.moveTo(t,e),o.lineTo(i,s),o.stroke(),o.endPath()}yf(t,e,i){if(!super.yf(t,e,i))return!1;if(this.kn(t,this.Qe,!0,!1,this.naturalBounds,this.actualBounds),i){if(this.svg.getElementsByTagName("text").length===0)return!0;const n=this.svg.getElementsByClassName("gojs-td");for(let o=0;o<n.length;o++)t.setFillOrStrokeInPlace(n[o],!1)}else this.rE(this.svg,this.ye?this.ye[0]:this.text,t);return!0}rE(t,e,i){t.innerHTML=e,i.setFillOrStrokeInPlace(t,!0)}kd(t){return this.lineCount>1||this.isUnderline||this.isStrikethrough?!0:super.kd(t)}LN(t,e){if(t.nodeName!=="g")t.setAttributeNS(null,"filter",e);else{const i=t.getElementsByTagName("text");for(let s=0;s<i.length;s++)i[s].setAttributeNS(null,"filter",e)}}lE(){this.Fn=0,this.pe=0,this.go=null,this.Ii=null,this.ye=null,this.Rn=null}xd(t,e,i,s){const n=this.ki;this.Xl=t,this.oC(!1);const o=this.vn;TextBlock.us!==null&&(TextBlock.AD!==o&&(TextBlock.us.font=o,TextBlock.AD=o),TextBlock.sk&&(TextBlock.us.letterSpacing=this.letterSpacing,TextBlock.us.wordSpacing=this.wordSpacing)),this.lE();let r=0,l=0;isNaN(this.desiredSize.width)?(r=this.aE(),r=Math.min(r,t/this.scale)):r=this.desiredSize.width,this.panel!==null&&(r=Math.min(r,this.panel.maxSize.width)),l=this.ND(r),isNaN(this.desiredSize.height)?l=Math.min(l,e/this.scale):l=this.desiredSize.height,this.hE(t,l),(this.wrap===1||isNaN(this.desiredSize.width))&&(r=isNaN(t)?this.pe:Math.min(t,this.pe)),r=Math.max(i,r),l=Math.max(s,l),this.Ke.jn(r,l),this.lo(0,0,r,l),this.svg!==null&&n!==this.ki&&this.$i(!0)}Pa(t,e,i,s){this.commonArrange(t,e,i,s)}On(t,e){this.Rn===null?(this.Rn=t,this.pe=e):((this.ye===null||this.Ii===null)&&(this.ye=[],this.Ii=[],this.ye.push(this.Rn),this.Ii.push(this.pe)),this.ye.push(t),this.Ii.push(e),this.ye.length>this.maxLines&&(this.n|=16777216))}nC(t,e,i){const s=this.formatting===0;s&&(t=t.trim());let n=0,o=0,r=0;const l=this.vn,a=this.spacingAbove+this.spacingBelow,h=Math.max(0,this._0()+a),c=this.overflow===1?this.TD(l):0;if(this.ki>=this.maxLines){i!==void 0&&i.e(0,h);return}let f=t;if(this.wrap===0){if(this.Fn=1,o=this.getStringWidth(t),c===0||o<=e){this.pe=Math.max(this.pe,o),this.On(t,this.pe),i!==void 0&&i.e(o,h);return}let d=this.Kd(f);f=f.substring(d.length);let m=this.Kd(f);for(o=this.getStringWidth(d+m),r=0;m.length>0&&o<=e;){d+=m,f=f.substring(m.length),m=this.Kd(f),r=o;let g=d+m;s&&(g=g.trim()),o=this.getStringWidth(g)}for(s&&(m=m.trim()),d+=m,e=Math.max(1,e-c);this.getStringWidth(d)>e&&d.length>1;)d=d.substring(0,d.length-1);this.oC(!0),d+=TextBlock.J0,r=this.getStringWidth(d),this.pe=r,this.On(d,r),i!==void 0&&i.e(r,h);return}let u=0;for(f.length===0&&(u=1,this.On(f,0));f.length>0;){let d=this.Kd(f);for(f=f.substring(d.length);this.getStringWidth(d)>e;){let p=1;for(o=this.getStringWidth(d.substring(0,p)),r=0;o<=e;)p++,r=o,o=this.getStringWidth(d.substring(0,p));let y=0;p===1?(y=o,n=Math.max(n,o)):(y=r,n=Math.max(n,r)),p--,p<1&&(p=1);const x=d.substring(0,p);if(this.On(x,y),u++,d=d.substring(p),this.ki+u>this.maxLines)break}let m=this.Kd(f);for(o=this.getStringWidth(d+m),r=0;m.length>0&&o<=e;){d+=m,f=f.substring(m.length),m=this.Kd(f),r=o;let p=d+m;s&&(p=p.trim()),o=this.getStringWidth(p)}if(s&&(d=d.trim()),d==="")continue;d[d.length-1]==="\xAD"&&(d=d.substring(0,d.length-1)+"\u2010");let g=0;if(m.length===0?(g=o,n=Math.max(n,o)):(r=this.getStringWidth(d),g=r,n=Math.max(n,r)),this.On(d,g),u++,this.ki+u>this.maxLines)break}this.Fn=Math.min(this.maxLines-this.ki,u),this.pe=Math.max(this.pe,n),i!==void 0&&i.e(this.pe,h*this.Fn)}hE(t,e){if(this.pe===0||this.Ii===null||this.ye===null||this.overflow!==1)return;const i=this.vn,s=this.overflow===1?this.TD(i):0,n=this.spacingAbove+this.spacingBelow,o=Math.max(0,this._0()+n),r=Math.min(this.maxLines-1,Math.max(Math.floor(e/o+.01)-1,0));if(r+1>=this.ye.length)return;this.oC(!0);let l=this.ye[r];const a=Math.max(1,t-s);for(;this.getStringWidth(l)>a&&l.length>1;)l=l.substring(0,l.length-1);l+=TextBlock.J0;const h=this.getStringWidth(l);this.ye[r]=l,this.ye=this.ye.slice(0,r+1),this.Ii[r]=h,this.Ii=this.Ii.slice(0,r+1),this.Fn=this.ye.length,this.pe=Math.max(this.pe,h),this.ki=this.Fn,this.ki===1&&(this.Rn=this.ye[0])}Kd(t){if(this.wrap===3)return t.substring(0,1);let e=t.length,i=0;const s=TextBlock.cE;for(;i<e&&!s.test(t.charAt(i));)i++;for(this.formatting===1&&(e=Math.min(e,i+1));i<e&&s.test(t.charAt(i));)i++;return i>=t.length?t:t.substring(0,i)}getStringWidth(t){return TextBlock.us===null?t.length*8:TextBlock.us.measureText(t).width}_0(){if(this.go!==null)return this.go;const t=this.vn;let e=0;if(TextBlock.us===null)return e=16,this.go=e,e;if(TextBlock.rC[t]!==void 0&&TextBlock.DD<5e3)e=TextBlock.rC[t];else{TextBlock.us.letterSpacing="0px";const i=TextBlock.us.measureText("M");TextBlock.us.letterSpacing=this.letterSpacing,e=i.width*1.3,TextBlock.rC[t]=e,TextBlock.DD++}return this.go=e,e}TD(t){if(TextBlock.us===null)return 6;let e=0;return TextBlock.tk[t]!==void 0&&TextBlock.sC<5e3?e=TextBlock.tk[t]:(e=TextBlock.us.measureText(TextBlock.J0).width,TextBlock.tk[t]=e,TextBlock.sC++),e}nk(t,e){return t.indexOf(`
`,e)}ND(t){let e=this.ue.replace(/\r\n/g,`
`).replace(/\r/g,`
`);const i=this.spacingAbove+this.spacingBelow,s=Math.max(0,this._0()+i);if(e.length===0)return this.pe=0,this.ki=1,s;if(!this.isMultiline){const a=this.nk(e,0);a>=0&&(e=e.substring(0,a))}let n=0;this.ki=0;let o=0,r=-1,l=!1;for(;!l;){if(r=this.nk(e,o),r===-1&&(r=e.length,l=!0),o<=r){const a=e.substring(o,r);if(this.wrap!==0){this.Fn=0;const h=Size.l();this.nC(a,t,h),n+=h.height,Size.i(h),this.ki+=this.Fn}else this.nC(a,t),n+=s,this.ki++;this.ki===this.maxLines&&(l=!0)}o=r+1}return this.jp=n,n}aE(){let t=this.ue.replace(/\r\n/g,`
`).replace(/\r/g,`
`);if(t.length===0)return 8;if(this.isMultiline){let e=0,i=0,s=!1;for(;!s;){let n=this.nk(t,i);n===-1&&(n=t.length,s=!0);let o=t.substring(i,n);this.formatting===0&&(o=o.trim()),e=Math.max(e,this.getStringWidth(o)),i=n+1}return e}else{const e=this.nk(t,0);return e>=0&&(t=t.substring(0,e)),this.getStringWidth(t)}}get textValidation(){return this.tt!==null?this.tt.zl:null}set textValidation(t){const e=this.textValidation;e!==t&&(t!==null&&U.S(t,TextBlock,"textValidation"),this.Os().zl=t,this.t("textValidation",e,t))}get textEdited(){return this.tt!==null?this.tt.iy:null}set textEdited(t){const e=this.textEdited;e!==t&&(t!==null&&U.S(t,TextBlock,"textEdited"),this.Os().iy=t,this.t("textEdited",e,t))}get spacingAbove(){return this.tt!==null?this.tt.ny:0}set spacingAbove(t){const e=this.spacingAbove;e!==t&&(this.Os().ny=t,this.c(),this.t("spacingAbove",e,t))}get spacingBelow(){return this.tt!==null?this.tt.ly:0}set spacingBelow(t){const e=this.spacingBelow;e!==t&&(this.Os().ly=t,this.c(),this.t("spacingBelow",e,t))}get letterSpacing(){return this.tt!==null?this.tt.hy:"0px"}set letterSpacing(t){const e=this.letterSpacing;e!==t&&(TextBlock.sk=!0,this.Os().hy=t,this.c(),this.t("letterSpacing",e,t))}get wordSpacing(){return this.tt!==null?this.tt.cy:"0px"}set wordSpacing(t){const e=this.wordSpacing;e!==t&&(TextBlock.sk=!0,this.Os().cy=t,this.c(),this.t("wordSpacing",e,t))}get formatting(){return this.tt!==null?this.tt.fy:0}set formatting(t){const e=this.formatting;e!==t&&(this.Os().fy=t,this.c(),this.t("formatting",e,t))}get maxLines(){return this.tt!==null?this.tt.uy:1/0}set maxLines(t){const e=this.maxLines;e!==t&&(t=Math.floor(t),t<=0&&U.J(t,"> 0",TextBlock,"maxLines"),this.Os().uy=t,this.c(),this.t("maxLines",e,t))}getMetrics(){return[this.pe,this.Xl,this.go,this.Fn,this.Ii,this.ye,this.Rn||""]}oE(t){t!==void 0&&(this.pe=t[0],this.Xl=t[1],this.go=t[2],this.Fn=t[3],this.Ii=t[4],this.ye=t[5],this.Rn=t[6])}get metrics(){return{arrSize:this.Ii!==null?this.Ii:[this.pe],arrText:this.ye!==null?this.ye:[this.Rn],maxLineWidth:this.pe,fontHeight:this.go}}get choices(){return this.Yd}set choices(t){const e=this.Yd;e!==t&&(this.Yd=t,this.t("choices",e,t))}static cE=new RegExp("[ \u200B\xAD]");static rC=new PropertyCollection;static DD=0;static tk=new PropertyCollection;static sC=0;static J0="...";static AD="";static us=null;static S0=!1;static sk=!1}class TextBlockTemplateSettings{me;gs;mo;fy;uy;Q0;ny;ly;$0;iy;ty;zl;hl;Z0;hy;cy;constructor(){this.me=!1,this.gs=null,this.mo=0,this.fy=0,this.uy=1/0,this.Q0=0,this.ny=0,this.ly=0,this.$0="start",this.iy=null,this.ty=null,this.zl=null,this.hl=Spot.Top,this.Z0=2,this.hy="0px",this.cy="0px"}copy(){const t=new TextBlockTemplateSettings;return t.gs=this.gs,t.mo=this.mo,t.fy=this.fy,t.uy=this.uy,t.Q0=this.Q0,t.ny=this.ny,t.ly=this.ly,t.$0=this.$0,t.iy=this.iy,t.ty=this.ty,t.zl=this.zl,t.hl=this.hl,t.Z0=this.Z0,t.hy=this.hy,t.cy=this.cy,t}}class GradElementSettings{vf;Ff;Rf;ey;Of;constructor(){this.vf=1,this.Ff=0,this.Rf=1,this.ey=null,this.Of=null}copy(){const t=new GradElementSettings;return t.vf=this.vf,t.Ff=this.Ff,t.Rf=this.Rf,t.ey=this.ey,t.Of=this.Of,t}}var ImageStretch=(w=>(w[w.None=0]="None",w[w.Fill=2]="Fill",w[w.Uniform=6]="Uniform",w[w.UniformToFill=7]="UniformToFill",w))(ImageStretch||{});class Picture extends GraphObject{cl;sn;fl;If;gs;ul;Ef;mo;Uf;Vf;E1;constructor(t,e){super(),this.n|=2097152,this.cl=null,this.sn="",this.fl=Rect.GF,this.If=2,this.gs=null,this.ul=null,this.Ef=Spot.Center,this.mo=0,this.Uf=null,this.Vf=null,this.E1=null,typeof t=="string"?this.source=t:t&&Object.assign(this,t),e&&Object.assign(this,e)}cloneProtected(t){super.cloneProtected(t),t.sn=this.sn,t.element=this.cl,t.fl=this.fl.N(),t.If=this.If,t.mo=this.mo,t.gs=this.gs,t.ul=this.ul,t.Ef=this.Ef.N(),t.Vf=this.Vf}fe(t){t in ImageStretch?this.imageStretch=t:super.fe(t)}toString(){return"Picture("+this.source+")#"+GSet.xs(this)}get Bf(){return(this.n&1048576)!==0}set Bf(t){this.Bf!==t&&(this.n=this.n^1048576)}get gy(){return(this.n&2097152)!==0}set gy(t){this.gy!==t&&(this.n=this.n^2097152)}get Mn(){return(this.n&4194304)!==0}set Mn(t){this.Mn!==t&&(this.n=this.n^4194304)}static clearCache(t){t===void 0&&(t=""),U.s(t,"string",Picture,"clearCache:url"),t!==""?Picture.my[t]&&(delete Picture.my[t],Picture.ok--):(Picture.my=new PropertyCollection,Picture.ok=0)}static ST(t,e){e.vD||(e.rk=i=>{Picture.fE(e,i),t.desiredSize.isReal()||(t.wi(!1),t.c())},e.lk=i=>Picture.uE(e,i),e.addEventListener("load",e.rk),e.addEventListener("error",e.lk),e.vD=!0)}static DO(t){t.rk&&t.removeEventListener("load",t.rk),t.lk&&t.removeEventListener("error",t.lk),delete t.rk,delete t.lk,t.vD=!1}get element(){return this.cl}set element(t){const e=this.cl;if(this.$i(!0),e!==t){this.Bf=t instanceof HTMLCanvasElement;const i=t instanceof HTMLImageElement;t!==null&&!(i||t instanceof HTMLVideoElement||this.Bf)&&U.o("Picture.element must be an instance of Image, Canvas, or Video, not: "+t);const s=this.diagram;s!==null&&s.F2(this),this.cl=t,t!==null&&i&&t.hs===void 0&&(t.hs=new GSet),s!==null&&i&&s.v2(this),this.t("element",e,t),this.C()}}AO(){const t=this.cl;if(t===null)return;const e=this.desiredSize.isReal();(this.Bf||t.complete===!0)&&(t.Tp&&(t.yy instanceof Event&&this.gs!==null?this.gs(this,t.yy):t.Mn===!0&&!t.yy&&this.ul!==null&&t.lC&&this.ul(this,t.lC)),t.Mn=!0),t.Mn&&e&&this.diagram!==null&&this.diagram.rd.add(this)}dE(){if(this.cl===null){this.Uf=!1;return}const t=new CanvasSurface(null)._t;try{t.drawImage(this.cl,0,0)}catch{this.gy=!1}try{t.getImageData(0,0,1,1).data[3]&&(this.Uf=!1),this.Uf=!1}catch{this.Uf=!0}}get source(){return this.sn}set source(t){const e=this.sn;if(e!==t){this.$i(!0),U.s(t,"string",Picture,"source"),this.sn=t;let i=Picture.my;if(!Diagram.isUsingDOM()){this.t("source",e,t);return}let s=null;if(i[t]!==void 0)s=i[t];else if(t!==""){Picture.ok>30&&(Picture.clearCache(),i=Picture.my),s=U.Ni("img"),s.Tp=!0,Picture.ST(this,s);const n=this.Vf;n!==null&&(s.crossOrigin=n(this)),s.src=t,i[t]=s,Picture.ok++}this.element=s,s!==null&&s.__goCache===void 0&&(s.__goCache=new PictureCacheArray),this.c(),this.C(),this.t("source",e,t)}}static fE(t,e){t.Mn=!0,t.yy=!1;let i;const s=t.hs.copy();if(s==null)return;const n=s.iterator;for(;n.next();){const o=n.value;o.C();const r=t.getAttribute("src")||"",l=o.oa.get(r);if(l===null)continue;const a=l.length;for(let h=0;h<a;h++)i=l[h],i.desiredSize.isReal()||o.rd.add(i),i.$i(!0),o.requestUpdate(),t.Tp&&(t.lC===void 0&&(t.lC=e),i.ul!==null&&i.ul(i,e))}t.hs.clear()}static uE(t,e){t.yy=e;let i;const s=t.hs.copy();if(s==null)return;const n=s.iterator;for(;n.next();){const o=n.value,r=t.getAttribute("src")||"",l=o.oa.get(r);if(l===null)continue;const a=l.length,h=U.ot();for(let c=0;c<a;c++)h.push(l[c]);if(t.Tp)for(let c=0;c<a;c++)i=h[c],i.gs!==null&&i.gs(i,e);U.Z(h)}t.hs.clear()}reloadSource(){if(this.source==="")return;Picture.clearCache(this.source);const t=this.source;this.source="",this.source=t}redraw(){this.C(),this.$i(!0)}get sourceCrossOrigin(){return this.Vf}set sourceCrossOrigin(t){if(this.Vf!==t&&(t!==null&&U.S(t,Picture,"sourceCrossOrigin"),this.Vf=t,this.element!==null)){const i=this.element.getAttribute("src");this.element instanceof HTMLImageElement&&(t===null&&typeof i=="string"?this.element.crossOrigin=null:t!==null&&(this.element.crossOrigin=t(this)),i&&(this.element.src=i))}}get sourceRect(){return this.fl}set sourceRect(t){const e=this.fl;e.equals(t)||(t=t.N(),this.fl=t,this.C(),this.t("sourceRect",e,t))}get imageStretch(){return this.If}set imageStretch(t){const e=this.If;e!==t&&(this.If=t,this.C(),this.t("imageStretch",e,t))}get flip(){return this.mo}set flip(t){const e=this.mo;e!==t&&(this.mo=t,this.C(),this.t("flip",e,t))}get imageAlignment(){return this.Ef}set imageAlignment(t){const e=this.Ef;e.equals(t)||(t=t.N(),this.Ef=t,this.C(),this.t("imageAlignment",e,t))}get errorFunction(){return this.gs}set errorFunction(t){const e=this.gs;e!==t&&(t!==null&&U.S(t,Picture,"errorFunction"),this.gs=t,this.t("errorFunction",e,t))}get successFunction(){return this.ul}set successFunction(t){const e=this.ul;e!==t&&(t!==null&&U.S(t,Picture,"successFunction"),this.ul=t,this.t("successFunction",e,t))}Ma(t,e){const i=this.cl;if(i===null)return;const s=i.getAttribute("src");if(i instanceof HTMLImageElement&&(s===null||s==="")||i.yy instanceof Event&&t instanceof CanvasSurfaceContext)return;const n=t instanceof SVGContext,o=this.naturalBounds;let r=0,l=0;const a=this.Bf;let h=a?+i.width:i.naturalWidth,c=a?+i.height:i.naturalHeight;if(h===void 0&&i.videoWidth&&(h=i.videoWidth),c===void 0&&i.videoHeight&&(c=i.videoHeight),h===0||c===0)return;const f=h,u=c;this.sourceRect.isReal()&&(r=this.fl.x,l=this.fl.y,h=this.fl.width,c=this.fl.height);let d=h,m=c;const g=this.If,p=this.Ef;switch(g){case 0:if(this.sourceRect.isReal())break;d>=o.width&&(r=r+p.offsetX+(d*p.x-o.width*p.x)),m>=o.height&&(l=l+p.offsetY+(m*p.y-o.height*p.y)),h=Math.min(o.width,d),c=Math.min(o.height,m);break;case 2:d=o.width,m=o.height;break;case 6:case 7:let A=0;g===6?(A=Math.min(o.height/m,o.width/d),d*=A,m*=A):g===7&&(A=Math.max(o.height/m,o.width/d),d*=A,m*=A,d>=o.width&&(r=(r+p.offsetX+(d*p.x-o.width*p.x)/d)*h),m>=o.height&&(l=(l+p.offsetY+(m*p.y-o.height*p.y)/m)*c),h*=1/(d/o.width),c*=1/(m/o.height),d=o.width,m=o.height);break}const y=h*c,x=this.getDocumentScale()*e.scale,k=d*x,b=m*x,P=k*b,S=y/P,L=i.__goCache;let C=null;const M=Picture.gE;if(!n){if(i.Mn&&L!==void 0&&f<8e3&&u<8e3&&P>4&&S>M*M){L.Vt===null&&(L.FD(4,f,u,i),L.FD(16,f,u,i));const A=L.Vt,D=A.length;for(let v=0;v<D&&A[v].Hd*A[v].Hd<S;v++)C=A[v]}if(!e.od&&(this.Uf===null&&this.dE(),this.Uf))return}const N=d<o.width?p.offsetX+(o.width*p.x-d*p.x):0,T=m<o.height?p.offsetY+(o.height*p.y-m*p.y):0;switch(this.flip){case 0:break;case 2:t.translate(Math.min(o.width,d),0),t.scale(-1,1);break;case 1:t.translate(0,Math.min(o.height,m)),t.scale(1,-1);break;case 3:t.translate(Math.min(o.width,d),Math.min(o.height,m)),t.scale(-1,-1);break}if(t.commitTransform(),e.getRenderingHint("pictureRatioOptimization")&&!e.gh&&L!==void 0&&C!==null&&C.Hd!==1){t.save();const A=C.Hd;try{t.drawImage(C.sn,r/A,l/A,Math.min(C.sn.width,h/A),Math.min(C.sn.height,c/A),N,T,Math.min(o.width,d),Math.min(o.height,m)),t instanceof SVGContext&&(this.E1=[r/A,l/A,Math.min(C.sn.width,h/A),Math.min(C.sn.height,c/A),N,T,Math.min(o.width,d),Math.min(o.height,m)])}catch{this.gy=!1}t.restore()}else try{t.drawImage(i,r,l,h,c,N,T,Math.min(o.width,d),Math.min(o.height,m)),t instanceof SVGContext&&(this.E1=[r,l,h,c,N,T,Math.min(o.width,d),Math.min(o.height,m)])}catch{this.gy=!1}switch(this.flip){case 0:break;case 2:t.scale(-1,1),t.translate(-Math.min(o.width,d),0);break;case 1:t.scale(1,-1),t.translate(0,-Math.min(o.height,m));break;case 3:t.scale(-1,-1),t.translate(-Math.min(o.width,d),-Math.min(o.height,m));break}}get naturalBounds(){return this.Ke}xd(t,e,i,s){const n=this.desiredSize,o=this.Qs(!0),r=this.cl,l=this.Bf;let a=0,h=0;(l||!this.Mn&&r&&r.complete)&&(this.Mn=!0),r===null?(isFinite(n.width)||(t=i),isFinite(n.height)||(e=s)):(a=l?+r.width:r.naturalWidth,h=l?+r.height:r.naturalHeight),!isFinite(n.width)&&o!==2&&o!==5?r!==null&&this.Mn!==!1&&(this.sourceRect.isReal()?t=this.sourceRect.width:t=a):(isFinite(t)||(this.sourceRect.isReal()?t=this.sourceRect.width:r!==null&&(t=a)),i=0),!isFinite(n.height)&&o!==2&&o!==4?r!==null&&this.Mn!==!1&&(this.sourceRect.isReal()?e=this.sourceRect.height:e=h):(isFinite(e)||(this.sourceRect.isReal()?e=this.sourceRect.height:r!==null&&(e=h)),s=0),isFinite(n.width)&&(t=n.width),isFinite(n.height)&&(e=n.height);const c=this.maxSize,f=this.minSize;i=Math.max(i||0,f.width),s=Math.max(s||0,f.height),t=Math.min(c.width,t),e=Math.min(c.height,e),t=Math.max(i,t),e=Math.max(s,e),r!==null&&!r.complete&&(isFinite(t)||(t=0),isFinite(e)||(e=0)),this.Ke.jn(t,e),this.lo(0,0,t,e)}Pa(t,e,i,s){this.commonArrange(t,e,i,s)}static my=new PropertyCollection;static ok=0;static gE=4}class PictureCacheArray{Vt;constructor(){this.Vt=null}FD(t,e,i,s){this.Vt===null&&(this.Vt=[]);const n=new CanvasSurface(null),o=n._t,r=1/t;if(n.width=e/t,n.height=i/t,n.width===0||n.height===0)return;const l=new PictureCacheInstance(n.bt,t);let a=s,h=1;if(this.Vt.length>0){const c=this.Vt[this.Vt.length-1];a=c.sn,h=c.Hd}o.setTransform(r*h,0,0,r*h,0,0),o.commitTransform(),o.drawImage(a,0,0),this.Vt.push(l)}}class PictureCacheInstance{sn;Hd;constructor(t,e){this.sn=t,this.Hd=e}}class GeoStream{Ne;fm;constructor(){this.fm=new Geometry,this.Ne=null}Ue(t){t!==null?(this.fm=t,t.figures.clear()):this.fm=new Geometry,this.Ne=null}Au(t,e,i,s,n,o){if(s!==void 0&&s===!0){const r=new PathSegment(1);r.endX=t,r.endY=e,this.Ne.segments.add(r)}else this.Ne=new PathFigure,this.Ne.startX=t,this.Ne.startY=e,this.Ne.isFilled=i,this.Ne.isEvenOdd=o||!1,this.fm.figures.add(this.Ne);n!==void 0&&(this.Ne.isShadowed=n)}_F(){const t=this.Ne.segments.length;t>0&&this.Ne.segments.elt(t-1).close()}tR(){this.Ne.segments.length>0&&(this.Ne.isFilled=!0)}eR(t){this.Ne.isShadowed=t}zU(t){this.Ne.isEvenOdd=t}$F(t,e,i){i===void 0&&(i=!1);const s=new PathSegment(1);s.endX=t,s.endY=e,i&&s.close(),this.Ne.segments.add(s)}Ks(t,e,i){i===void 0&&(i=!1);const s=new PathSegment(2);s.endX=t,s.endY=e,i&&s.close(),this.Ne.segments.add(s)}xr(t,e,i,s,n,o,r){r===void 0&&(r=!1);const l=new PathSegment(3);l.point1X=t,l.point1Y=e,l.point2X=i,l.point2Y=s,l.endX=n,l.endY=o,r&&l.close(),this.Ne.segments.add(l)}Tu(t,e,i,s,n){n===void 0&&(n=!1);const o=new PathSegment(4);o.point1X=t,o.point1Y=e,o.endX=i,o.endY=s,n&&o.close(),this.Ne.segments.add(o)}ZF(t,e,i,s,n,o,r){o===void 0&&(o=0),r===void 0&&(r=!1);const l=new PathSegment(5);l.startAngle=t,l.sweepAngle=e,l.centerX=i,l.centerY=s,l.radiusX=n,o!==0?l.radiusY=o:l.radiusY=n,r&&l.close(),this.Ne.segments.add(l)}QF(t,e,i,s,n,o,r,l){l===void 0&&(l=!1);const a=new PathSegment(6,o,r,t,e,i,s,n);l&&a.close(),this.Ne.segments.add(a)}static aC=null;static qL(t){const e=GeoStream.aC;if(e!==null)return GeoStream.aC=null,e.Ue(t),e;{const i=new GeoStream;return i.Ue(t),i}}static WL(t){GeoStream.aC=t}}{const w=function(n,o){const r=n.toLowerCase(),l=G.Jn;l[n]=o,l[r]=n};w("Rectangle",(n,o,r)=>{const l="r"+o+","+r;let a=G.yr[l];return a!==void 0||(a=new Geometry(2),a.endX=o,a.endY=r,G.wr<G.lm&&(G.yr[l]=a,G.wr++)),a}),w("Square",(n,o,r)=>{const l="s"+o+","+r;let a=G.yr[l];return a!==void 0||(a=new Geometry(2),a.endX=o,a.endY=r,a.defaultStretch=6,G.wr<G.lm&&(G.yr[l]=a,G.wr++)),a});const t=(n,o,r,l,a)=>{(isNaN(l)||l<0)&&(l=5),isNaN(a)&&(a=15);const h="rr"+o+","+r+","+l+","+a;let c=G.yr[h];if(c!==void 0)return c;let f=l;(a&1)===1?(f=Math.min(f,(a&2)===2?o/3:o),f=Math.min(f,(a&8)===8?r/3:r)):f=0;const u=new PathFigure(f,0,!0);c=new Geometry().add(u);const d=Spot.TopLeft.copy(),m=Spot.BottomRight.copy();if((a&2)===2){let g=l;g=Math.min(g,(a&1)===1?o/3:o),g=Math.min(g,(a&4)===4?r/3:r);const p=g*G.qn;u.add(new PathSegment(2,o-g,0)).add(new PathSegment(3,o,g,o-p,0,o,p)),d.offsetY=p,m.offsetX=-p}else u.add(new PathSegment(2,o,0));if((a&4)===4){let g=l;g=Math.min(g,(a&8)===8?o/3:o),g=Math.min(g,(a&2)===2?r/3:r);const p=g*G.qn;u.add(new PathSegment(2,o,r-g)).add(new PathSegment(3,o-g,r,o,r-p,o-p,r)),m.offsetX=-p,m.offsetY=-p}else u.add(new PathSegment(2,o,r));if((a&8)===8){let g=l;g=Math.min(g,(a&4)===4?o/3:o),g=Math.min(g,(a&1)===1?r/3:r);const p=g*G.qn;u.add(new PathSegment(2,g,r)).add(new PathSegment(3,0,r-g,p,r,0,r-p)),d.offsetX=p,m.offsetY=-p}else u.add(new PathSegment(2,0,r));if((a&1)===1){const g=f*G.qn;u.add(new PathSegment(2,0,f)).add(new PathSegment(3,f,0,0,g,g,0).close()),d.offsetX=g,d.offsetY=g}else u.add(new PathSegment(2,0,0).close());return c.spot1=d,c.spot2=m,G.wr<G.lm&&(G.yr[h]=c,G.wr++),c};w("RoundedRectangle",(n,o,r)=>{const l=n?n.parameter1:NaN,a=n?n.parameter2:NaN;return t(n,o,r,l,a)}),w("Border","RoundedRectangle"),w("RoundedTopRectangle",(n,o,r)=>{const l=n?n.parameter1:NaN;return t(n,o,r,l,3)}),w("RoundedBottomRectangle",(n,o,r)=>{const l=n?n.parameter1:NaN;return t(n,o,r,l,12)}),w("RoundedLeftRectangle",(n,o,r)=>{const l=n?n.parameter1:NaN;return t(n,o,r,l,9)}),w("RoundedRightRectangle",(n,o,r)=>{const l=n?n.parameter1:NaN;return t(n,o,r,l,6)}),w("Ellipse",(n,o,r)=>{const l="e"+o+","+r;let a=G.yr[l];return a!==void 0||(a=new Geometry(3),a.endX=o,a.endY=r,a.spot1=Spot.DP,a.spot2=Spot.vP,G.wr<G.lm&&(G.yr[l]=a,G.wr++)),a}),w("Circle",(n,o,r)=>{const l="c"+o+","+r;let a=G.yr[l];return a!==void 0||(a=new Geometry(3),a.endX=o,a.endY=r,a.spot1=Spot.DP,a.spot2=Spot.vP,a.defaultStretch=6,G.wr<G.lm&&(G.yr[l]=a,G.wr++)),a}),w("TriangleRight",(n,o,r)=>new Geometry().add(new PathFigure(0,0).add(new PathSegment(2,o,.5*r)).add(new PathSegment(2,0,r).close())).setSpots(0,.25,.5,.75)),w("TriangleDown",(n,o,r)=>new Geometry().add(new PathFigure(0,0).add(new PathSegment(2,o,0)).add(new PathSegment(2,.5*o,r).close())).setSpots(.25,0,.75,.5)),w("TriangleLeft",(n,o,r)=>new Geometry().add(new PathFigure(o,r).add(new PathSegment(2,0,.5*r)).add(new PathSegment(2,o,0).close())).setSpots(.5,.25,1,.75)),w("TriangleUp",(n,o,r)=>new Geometry().add(new PathFigure(o,r).add(new PathSegment(2,0,r)).add(new PathSegment(2,.5*o,0).close())).setSpots(.25,.5,.75,1)),w("Triangle","TriangleUp"),w("Diamond",(n,o,r)=>new Geometry().add(new PathFigure(.5*o,0).add(new PathSegment(2,0,.5*r)).add(new PathSegment(2,.5*o,r)).add(new PathSegment(2,o,.5*r).close())).setSpots(.25,.25,.75,.75)),w("LineH",(n,o,r)=>{const l=new Geometry(1);return l.startX=0,l.startY=r/2,l.endX=o,l.endY=r/2,l}),w("LineV",(n,o,r)=>{const l=new Geometry(1);return l.startX=o/2,l.startY=0,l.endX=o/2,l.endY=r,l}),w("None","Rectangle"),w("BarH","Rectangle"),w("BarV","Rectangle"),w("MinusLine","LineH"),w("PlusLine",(n,o,r)=>new Geometry().add(new PathFigure(0,r/2,!1).add(new PathSegment(2,o,r/2)).add(new PathSegment(1,o/2,0)).add(new PathSegment(2,o/2,r)))),w("XLine",(n,o,r)=>new Geometry().add(new PathFigure(0,r,!1).add(new PathSegment(2,o,0)).add(new PathSegment(1,0,0)).add(new PathSegment(2,o,r)))),w("LineRight",(n,o,r)=>new Geometry().add(new PathFigure(.25*o,0,!1).add(new PathSegment(2,.75*o,.5*r)).add(new PathSegment(2,.25*o,r)))),w("LineDown",(n,o,r)=>new Geometry().add(new PathFigure(0,.25*r,!1).add(new PathSegment(2,.5*o,.75*r)).add(new PathSegment(2,o,.25*r)))),w("LineLeft",(n,o,r)=>new Geometry().add(new PathFigure(.75*o,0,!1).add(new PathSegment(2,.25*o,.5*r)).add(new PathSegment(2,.75*o,r)))),w("LineUp",(n,o,r)=>new Geometry().add(new PathFigure(0,.75*r,!1).add(new PathSegment(2,.5*o,.25*r)).add(new PathSegment(2,o,.75*r)))),w("Capsule",(n,o,r)=>{const l=new Geometry;if(o<r){const a=o/2,h=new PathFigure(0,a,!0);l.add(h),h.add(new PathSegment(5,180,180,a,a,a,a)),h.add(new PathSegment(2,o,r-a)),h.add(new PathSegment(5,0,180,a,r-a,a,a)),h.add(new PathSegment(2,0,a));const c=isFinite(n.parameter1)?n.parameter1:o*.156;return l.setSpots(0,0,1,1,0,c,0,-c),l}else if(o>r){const a=r/2,h=new PathFigure(a,0,!0);l.add(h),h.add(new PathSegment(2,o-a,0)),h.add(new PathSegment(5,270,180,o-a,a,a,a)),h.add(new PathSegment(2,a,r)),h.add(new PathSegment(5,90,180,a,a,a,a));const c=isFinite(n.parameter1)?n.parameter1:r*.156;return l.setSpots(0,0,1,1,c,0,-c,0),l}else return l.type=3,l.endX=o,l.endY=r,l.spot1=Spot.DP,l.spot2=Spot.vP,l});const e=(n,o)=>new PathFigure(n,o,!1,!1),i=(n,o,r)=>n.add(new PathSegment(2,o,r)),s=(n,o,r)=>n.add(new PathSegment(1,o,r));w("Borders",(n,o,r)=>{let l=n?n.parameter1:NaN;isNaN(l)?l=10:l=l&15;const a=new Geometry;let h;return l===10?(h=e(o,0),i(h,o,r),s(h,0,r),i(h,0,0)):l===5?(h=e(0,0),i(h,o,0),s(h,o,r),i(h,0,r)):l===1?(h=e(0,0),i(h,o,0),s(h,o,r)):l===2?(h=e(o,0),i(h,o,r)):l===4?(h=e(o,r),i(h,0,r)):l===8?(h=e(0,r),i(h,0,0),s(h,o,r)):l===3?(h=e(0,0),i(h,o,0),i(h,o,r)):l===6?(h=e(o,0),i(h,o,r),i(h,0,r)):l===12?(h=e(o,r),i(h,0,r),i(h,0,0)):l===9?(h=e(0,r),i(h,0,0),i(h,o,0)):l===7?(h=e(0,0),i(h,o,0),i(h,o,r),i(h,0,r)):l===14?(h=e(o,0),i(h,o,r),i(h,0,r),i(h,0,0)):l===13?(h=e(o,r),i(h,0,r),i(h,0,0),i(h,o,0)):l===11?(h=e(0,r),i(h,0,0),i(h,o,0),i(h,o,r)):l===15?(h=e(0,0),i(h,o,0),i(h,o,r),i(h,0,r),h.add(new PathSegment(2,0,0).close())):(h=e(0,0),s(h,o,r)),a.add(h),a})}G.rm={"":"",Standard:"F1 m 0,0 l 8,4 -8,4 2,-4 z",Backward:"F1 m 8,0 l -2,4 2,4 -8,-4 z",Triangle:"F1 m 0,0 l 8,4.62 -8,4.62 z",BackwardTriangle:"F1 m 8,4 l 0,4 -8,-4 8,-4 0,4 z",Boomerang:"F1 m 0,0 l 8,4 -8,4 4,-4 -4,-4 z",BackwardBoomerang:"F1 m 8,0 l -8,4 8,4 -4,-4 4,-4 z",SidewaysV:"m 0,0 l 8,4 -8,4 0,-1 6,-3 -6,-3 0,-1 z",BackwardV:"m 8,0 l -8,4 8,4 0,-1 -6,-3 6,-3 0,-1 z",OpenTriangle:"m 0,0 l 8,4 -8,4",BackwardOpenTriangle:"m 8,0 l -8,4 8,4",OpenTriangleLine:"m 0,0 l 8,4 -8,4 m 8.5,0 l 0,-8",BackwardOpenTriangleLine:"m 8,0 l  -8,4 8,4 m -8.5,0 l 0,-8",OpenTriangleTop:"m 0,0 l 8,4 m 0,4",BackwardOpenTriangleTop:"m 8,0 l -8,4 m 0,4",OpenTriangleBottom:"m 0,8 l 8,-4",BackwardOpenTriangleBottom:"m 0,4 l 8,4",HalfTriangleTop:"F1 m 0,0 l 0,4 8,0 z m 0,8",BackwardHalfTriangleTop:"F1 m 8,0 l 0,4 -8,0 z m 0,8",HalfTriangleBottom:"F1 m 0,4 l 0,4 8,-4 z",BackwardHalfTriangleBottom:"F1 m 8,4 l 0,4 -8,-4 z",ForwardSemiCircle:"m 4,0 b 270 180 0 4 4",BackwardSemiCircle:"m 4,8 b 90 180 0 -4 4",Feather:"m 0,0 l 3,4 -3,4",BackwardFeather:"m 3,0 l -3,4 3,4",DoubleFeathers:"m 0,0 l 3,4 -3,4 m 3,-8 l 3,4 -3,4",BackwardDoubleFeathers:"m 3,0 l -3,4 3,4 m 3,-8 l -3,4 3,4",TripleFeathers:"m 0,0 l 3,4 -3,4 m 3,-8 l 3,4 -3,4 m 3,-8 l 3,4 -3,4",BackwardTripleFeathers:"m 3,0 l -3,4 3,4 m 3,-8 l -3,4 3,4 m 3,-8 l -3,4 3,4",ForwardSlash:"m 0,8 l 5,-8",BackSlash:"m 0,0 l 5,8",DoubleForwardSlash:"m 0,8 l 4,-8 m -2,8 l 4,-8",DoubleBackSlash:"m 0,0 l 4,8 m -2,-8 l 4,8",TripleForwardSlash:"m 0,8 l 4,-8 m -2,8 l 4,-8 m -2,8 l 4,-8",TripleBackSlash:"m 0,0 l 4,8 m -2,-8 l 4,8 m -2,-8 l 4,8",Fork:"m 0,4 l 8,0 m -8,0 l 8,-4 m -8,4 l 8,4",BackwardFork:"m 8,4 l -8,0 m 8,0 l -8,-4 m 8,4 l -8,4",LineFork:"m 0,0 l 0,8 m 0,-4 l 8,0 m -8,0 l 8,-4 m -8,4 l 8,4",BackwardLineFork:"m 8,4 l -8,0 m 8,0 l -8,-4 m 8,4 l -8,4 m 8,-8 l 0,8",CircleFork:"F1 m 6,4 b 0 360 -3 0 3 z m 0,0 l 6,0 m -6,0 l 6,-4 m -6,4 l 6,4",BackwardCircleFork:"F1 m 0,4 l 6,0 m -6,-4 l 6,4 m -6,4 l 6,-4 m 6,0 b 0 360 -3 0 3",CircleLineFork:"F1 m 6,4 b 0 360 -3 0 3 z m 1,-4 l 0,8 m 0,-4 l 6,0 m -6,0 l 6,-4 m -6,4 l 6,4",BackwardCircleLineFork:"F1 m 0,4 l 6,0 m -6,-4 l 6,4 m -6,4 l 6,-4 m 0,-4 l 0,8 m 7,-4 b 0 360 -3 0 3",Circle:"F1 m 8,4 b 0 360 -4 0 4 z",Block:"F1 m 0,0 l 0,8 8,0 0,-8 z",StretchedDiamond:"F1 m 0,3 l 5,-3 5,3 -5,3 -5,-3 z",Diamond:"F1 m 0,4 l 4,-4 4,4 -4,4 -4,-4 z",Chevron:"F1 m 0,0 l 5,0 3,4 -3,4 -5,0 3,-4 -3,-4 z",StretchedChevron:"F1 m 0,0 l 8,0 3,4 -3,4 -8,0 3,-4 -3,-4 z",NormalArrow:"F1 m 0,2 l 4,0 0,-2 4,4 -4,4 0,-2 -4,0 z",X:"m 0,0 l 8,8 m 0,-8 l -8,8",TailedNormalArrow:"F1 m 0,0 l 2,0 1,2 3,0 0,-2 2,4 -2,4 0,-2 -3,0 -1,2 -2,0 1,-4 -1,-4 z",DoubleTriangle:"F1 m 0,0 l 4,4 -4,4 0,-8 z  m 4,0 l 4,4 -4,4 0,-8 z",BigEndArrow:"F1 m 0,0 l 5,2 0,-2 3,4 -3,4 0,-2 -5,2 0,-8 z",ConcaveTailArrow:"F1 m 0,2 h 4 v -2 l 4,4 -4,4 v -2 h -4 l 2,-2 -2,-2 z",RoundedTriangle:"F1 m 0,1 a 1,1 0 0 1 1,-1 l 7,3 a 0.5,1 0 0 1 0,2 l -7,3 a 1,1 0 0 1 -1,-1 l 0,-6 z",SimpleArrow:"F1 m 1,2 l -1,-2 2,0 1,2 -1,2 -2,0 1,-2 5,0 0,-2 2,2 -2,2 0,-2 z",AccelerationArrow:"F1 m 0,0 l 0,8 0.2,0 0,-8 -0.2,0 z m 2,0 l 0,8 1,0 0,-8 -1,0 z m 3,0 l 2,0 2,4 -2,4 -2,0 0,-8 z",BoxArrow:"F1 m 0,0 l 4,0 0,2 2,0 0,-2 2,4 -2,4 0,-2 -2,0 0,2 -4,0 0,-8 z",TriangleLine:"F1 m 8,4 l -8,-4 0,8 8,-4 z m 0.5,4 l 0,-8",CircleEndedArrow:"F1 m 10,4 l -2,-3 0,2 -2,0 0,2 2,0 0,2 2,-3 z m -4,0 b 0 360 -3 0 3 z",DynamicWidthArrow:"F1 m 0,3 l 2,0 2,-1 2,-2 2,4 -2,4 -2,-2 -2,-1 -2,0 0,-2 z",EquilibriumArrow:"m 0,3 l 8,0 -3,-3 m 3,5 l -8,0 3,3",FastForward:"F1 m 0,0 l 3.5,4 0,-4 3.5,4 0,-4 1,0 0,8 -1,0 0,-4 -3.5,4 0,-4 -3.5,4 0,-8 z",Kite:"F1 m 0,4 l 2,-4 6,4 -6,4 -2,-4 z",HalfArrowTop:"F1 m 0,0 l 4,4 4,0 -8,-4 z m 0,8",HalfArrowBottom:"F1 m 0,8 l 4,-4 4,0 -8,4 z",OpposingDirectionDoubleArrow:"F1 m 0,4 l 2,-4 0,2 4,0 0,-2 2,4 -2,4 0,-2 -4,0 0,2 -2,-4 z",PartialDoubleTriangle:"F1 m 0,0 4,3 0,-3 4,4 -4,4 0,-3 -4,3 0,-8 z",LineCircle:"F1 m 0,0 l 0,8 m 7 -4 b 0 360 -3 0 3 z",DoubleLineCircle:"F1 m 0,0 l 0,8 m 2,-8 l 0,8 m 7 -4 b 0 360 -3 0 3 z",TripleLineCircle:"F1 m 0,0 l 0,8 m 2,-8 l 0,8 m 2,-8 l 0,8 m 7 -4 b 0 360 -3 0 3 z",CircleLine:"F1 m 6 4 b 0 360 -3 0 3 z m 1,-4 l 0,8",DiamondCircle:"F1 m 8,4 l -4,4 -4,-4 4,-4 4,4 m 8,0 b 0 360 -4 0 4 z",PlusCircle:"F1 m 8,4 b 0 360 -4 0 4 l -8 0 z m -4 -4 l 0 8",OpenRightTriangleTop:"m 8,0 l 0,4 -8,0 m 0,4",OpenRightTriangleBottom:"m 8,8 l 0,-4 -8,0",Line:"m 0,0 l 0,8",DoubleLine:"m 0,0 l 0,8 m 2,0 l 0,-8",TripleLine:"m 0,0 l 0,8 m 2,0 l 0,-8 m 2,0 l 0,8",PentagonArrow:"F1 m 8,4 l -4,-4 -4,0 0,8 4,0 4,-4 z"};var LayoutConditions=(w=>(w[w.None=0]="None",w[w.Added=1]="Added",w[w.Removed=2]="Removed",w[w.Shown=4]="Shown",w[w.Hidden=8]="Hidden",w[w.NodeSized=16]="NodeSized",w[w.GroupLayout=32]="GroupLayout",w[w.NodeReplaced=64]="NodeReplaced",w[w.Standard=127]="Standard",w[w.All=16777215]="All",w))(LayoutConditions||{});class Part extends Panel{k;_o;H;dl;gl;tr;ue;pl;Ta;nn;er;jd;EM;RD;wy;xy;constructor(t,e){let i;t===void 0||t instanceof PanelLayout||typeof t=="string"?i=t:t&&(e=t),super(i),this.k=2408959,this._o="",this.H=null,this.dl="",this.gl=null,this.tr=null,this.ue="",this.pl=null,this.Ta=null,this.nn=new Point(NaN,NaN).b(),this.er=null,this.jd=NaN,this.EM=-1,this.RD=new Rect,this.wy=null,this.xy=NaN,e&&Object.assign(this,e)}cloneProtected(t){super.cloneProtected(t),t.k=this.k&-4097|16384|32768,t._o=this._o,this.H!==null&&(this.H.me?t.H=this.H:t.H=this.H.copy()),t.dl=this.dl,t.tr=null,t.ue=this.ue,t.nn.h(this.nn),t.jd=this.jd}jo(t){super.jo(t),t.Sa(),t.gl=null,t.er=null,t.wy=null}toString(){let t=U.Hn(this.constructor)+"#"+GSet.xs(this);return this.data!==null&&(t+="("+U.toString(this.data)+")"),t}static LayoutNone=0;static LayoutAdded=1;static LayoutRemoved=2;static LayoutShown=4;static LayoutHidden=8;static LayoutNodeSized=16;static LayoutGroupLayout=32;static LayoutNodeReplaced=64;static LayoutStandard=127;static LayoutAll=16777215;_e(){return this.H===null?this.H=new PartTemplateSettings:this.H.me&&(this.H=this.H.copy()),this.H}ba(){super.ba(),this.H!==null&&(this.H.me=!0)}df(t,e,i,s,n,o,r){const l=this.diagram;l!==null&&(t===3&&e==="elements"?n instanceof Panel?n.Sn(a=>{l.partManager.M2(a,l)}):n instanceof Picture&&l.v2(n):t===4&&e==="elements"&&(n instanceof Panel?n.Sn(a=>l.partManager.N2(a,l)):n instanceof Picture&&l.F2(n)),l.raiseChangedEvent(t,e,i,s,n,o,r))}updateTargetBindings(t){if(super.updateTargetBindings(t),this.data===null)return;const e=this.D.r,i=e.length;for(let n=0;n<i;n++){const o=e[n];o instanceof Panel&&o.Sn(r=>{r.data!==null&&r.WI(t)})}const s=this.adornments;for(;s.next();)s.value.updateTargetBindings(t)}Yo(){if(super.Yo(),this.RN()){const e=this.D.r,i=e.length;for(let s=0;s<i;s++){const n=e[s];n instanceof Panel&&n.Sn(o=>o.Yo())}}const t=this.adornments;for(;t.next();)t.value.Yo()}updateRelationshipsFromData(){this.data!==null&&this.diagram?.partManager.updateRelationshipsFromData(this)}get key(){const t=this.diagram;if(t!==null)return t.model.getKeyForNodeData(this.data)}get adornments(){return this.tr===null?EmptyIterator.instance:this.tr.iteratorValues}findAdornment(t){const e=this.tr;return e===null?null:e.get(t)}addAdornment(t,e){if(e===null)return;let i=null,s=this.tr;if(s!==null&&(i=s.get(t)),i!==e){if(i!==null){const o=i.diagram;o!==null&&o.remove(i)}s===null&&(s=new GMap,this.tr=s),e._o!==t&&(e.category=t),s.set(t,e);const n=this.diagram;if(n!==null){n.add(e);const o=e.adornedObject;if(o!==null){const r=o.findBindingPanel();r!==null&&(e.data=r.data)}}}}removeAdornment(t){const e=this.tr;if(e===null)return;const i=e.get(t);if(i!==null){const s=i.diagram;s!==null&&(s.remove(i),i.data=null)}e.delete(t),e.count===0&&(this.tr=null)}clearAdornments(){const t=this.tr;if(t===null)return;const e=U.ot(),i=t.iterator;for(;i.next();){const n=i.key;e.push(n)}const s=e.length;for(let n=0;n<s;n++)this.removeAdornment(e[n]);U.Z(e)}updateAdornments(){const t=this.diagram;if(t===null)return;this.mE(t),this.pE(t);let e=this.adornments;for(;e.next();){const i=e.value;i.c(),i.hasPlaceholder()&&i.placeholder.c()}for(e=this.adornments;e.next();)e.value.updateTargetBindings()}invalidateAdornments(){const t=this.diagram;t!==null&&(t.ha(),this.OD()!==!0&&this.ID(!0))}UM(){this.OD()!==!1&&(this.updateAdornments(),this.ID(!1))}mE(t){const e="Selection";if(this.isSelected&&this.selectionAdorned){const i=this.selectionObject;if(i!==null&&this.actualBounds.isReal()&&this.isVisible()&&i.isVisibleObject()&&i.actualBounds.isReal()){let s=this.findAdornment(e);if(s===null){let n=this.selectionAdornmentTemplate;n===null&&(this.Ar()?n=t.linkSelectionAdornmentTemplate:this instanceof Group?n=t.groupSelectionAdornmentTemplate:n=t.nodeSelectionAdornmentTemplate),s=n.copy(),s!==null&&(this.Ar()&&this.selectionObject===this.path&&(s.type=Panel.Link),s.adornedObject=i)}if(s!==null){s.type===Panel.Link&&s.c(),this.addAdornment(e,s);return}}}this.removeAdornment(e)}pE(t){const e=this;t.toolManager.mouseDownTools.each(i=>{i.isEnabled&&i.updateAdornments(e)}),t.toolManager.updateAdornments(e)}OM(t){this.pl=t,t===null&&this.fI()}get layer(){return this.pl}get diagram(){const t=this.pl;return t==null?null:t.diagram}get layerName(){return this.dl}set layerName(t){const e=this.dl;if(e===t)return;let i=this.diagram;if(i!==null&&(i.findLayer(t)===null||i.partManager.addsToTemporaryLayer))return;this.dl=t,i!==null&&i.invalidateDocumentBounds(),this.t("layerName",e,t);const s=this.layer;if(s===null||s.name===t||(i=s.diagram,i===null))return;const n=i.findLayer(t);if(n===null||n===s)return;let o=s.ri(-1,this,!0);o>=0&&i.raiseChangedEvent(4,"parts",s,this,null,o,!0),o=n.ah(99999999,this,!0),s.visible!==n.visible&&this.Xe(n.visible),o>=0&&i.raiseChangedEvent(3,"parts",n,null,this,!0,o);const r=this.layerChanged;if(r===null)return;const l=i.G;i.G=!0,r(this,s,n),i.G=l}get layerChanged(){return this.H!==null?this.H.ky:null}set layerChanged(t){const e=this.layerChanged;e!==t&&(t!==null&&U.S(t,Part,"layerChanged"),this._e().ky=t,this.t("layerChanged",e,t))}get zOrder(){return this.jd}set zOrder(t){const e=this.jd;if(e===t)return;this.jd=t;const i=this.layer;i!==null&&i.ob(-1,this),this.t("zOrder",e,t);const s=this.diagram;s!==null&&s.C()}yE(){const t=this.layer;t!==null&&t.ob(-1,this)}ak(){if(this.fa()!==!1)return;this.hC(!0),this.pf();const t=this.diagram;t!==null&&(t.Np(this),t.requestUpdate())}ED(){if(this.k|=2097152,this.fa()===!1)return;const t=this.position,e=this.location;(!e.isReal()||!t.isReal())&&this.UD(t,e);const i=this.De,s=Rect.l().h(i);i.ce(),i.x=t.x,i.y=t.y,i.b(),this.bd(s,i),Rect.i(s),this.hC(!1),this.pf()}lo(t,e,i,s){const n=this.ai;n.e(t,e,i,s),this.Se===null&&(this.Se=new Transform);const o=this.Se;o.Ue(),this.Yp(o,t,e,i,s),this.Se=o,o.FP()||o.im(n)}Yp(t,e,i,s,n){if(this.it!==1&&t.it(this.it),this.Xt===0)return;let o=Spot.Center;this.locationSpot.isSpot()&&(o=this.locationSpot);const r=Point.l();if(this.locationObject!==this){const l=this.locationObject,a=l.naturalBounds;r.setSpot(a.x,a.y,a.width,a.height,o),l.Se!==null&&l.Se.gt(r),r.offset(-l.measuredBounds.x,-l.measuredBounds.y);let h=l.panel;for(;h!==null&&h!==this;)h.Se!==null&&h.Se.gt(r),r.offset(-h.measuredBounds.x,-h.measuredBounds.y),h=h.panel}else r.setSpot(e,i,s,n,o);t.ks(this.Xt,r.x,r.y),Point.i(r)}get locationObject(){if(this.er===null)if(this instanceof Adornment&&this.type!==Panel.Link&&this.hasPlaceholder())this.er=this.placeholder;else{const t=this.locationObjectName;if(t!==""){const e=this.findObject(t);e!==null?this.er=e:this.er=this}else this.er=this}return this.er?.visible?this.er:this}get minLocation(){return this.H!==null?this.H.Py:Point.DL}set minLocation(t){const e=this.minLocation;e.equals(t)||(t=t.N(),this._e().Py=t,this.t("minLocation",e,t))}get maxLocation(){return this.H!==null?this.H.Sy:Point.vL}set maxLocation(t){const e=this.maxLocation;e.equals(t)||(t=t.N(),this._e().Sy=t,this.t("maxLocation",e,t))}get locationObjectName(){return this.H!==null?this.H.My:""}set locationObjectName(t){const e=this.locationObjectName;e!==t&&(this._e().My=t,this.er=null,this.c(),this.t("locationObjectName",e,t))}get locationSpot(){return this.H!==null?this.H.Ny:Spot.TopLeft}set locationSpot(t){const e=this.locationSpot;e.equals(t)||(t=t.N(),this._e().Ny=t,this.c(),this.t("locationSpot",e,t))}move(t,e){e===!0?this.location=t:this.position=t}moveTo(t,e,i){const s=Point.z(t,e);this.move(s,i),Point.i(s)}isVisible(){if(!this.visible)return!1;const t=this.layer;if(t!==null){if(!t.visible)return!1;const i=t.diagram;if(i!==null&&i.animationManager.qx(this))return!0}const e=this.containingGroup;return!(e!==null&&(!e.isSubGraphExpanded||!e.isVisible()))}Xe(t){const e=this.diagram;t?(this.invalidateLayout(4),this.invalidateAdornments(),e!==null&&e.Np(this)):(this.invalidateLayout(8),this.clearAdornments()),this.Sa(),e!==null&&(e.invalidateDocumentBounds(),e.C())}findObject(t){if(this.name===t)return this;let e=this.wy;if(e===null&&(this.wy=e=new GMap),e.get(t)!==null)return e.get(t);const i=super.findObject(t);return i!==null?(e.set(t,i),i):(e.set(t,null),null)}i0(){this.wy=null}getRelativePoint(t,e,i){i===void 0&&(i=new Point);const s=e.isNoSpot()?Spot.Center:e,n=t.naturalBounds;if(i.e(n.width*s.x+s.offsetX,n.height*s.y+s.offsetY),t===null||t===this)return i;t.v.gt(i);let o=t.panel;for(;o!==null&&o!==this;)o.v.gt(i),o=o.panel;return this.Se!==null&&this.Se.gt(i),i.offset(-this.ai.x,-this.ai.y),i}getDocumentBounds(t){return t===void 0&&(t=new Rect),t.h(this.actualBounds)}ensureBounds(){this.ht(1/0,1/0),this.Ut()}fD(t){const e=this.locationSpot,i=this.locationObject;let s=i.naturalBounds;s.isReal()||(s=Rect.tm);const n=i instanceof Shape?i.strokeWidth:0;if(t.setSpot(0,0,s.width+n,s.height+n,e),i!==this){t.offset(-n/2,-n/2),i.v.gt(t);let o=i.panel;for(;o!==null&&o!==this;)o.v.gt(t),o=o.panel}return this.Se!==null&&this.Se.gt(t),t.offset(-this.ai.x,-this.ai.y),t}lh(t,e){const i=e===void 0?this.RD:e,s=this.wE(),n=s*2;if(!this.isShadowed)return i.e(t.x-1-s,t.y-1-s,t.width+2+n,t.height+2+n),i;let o=t.x,r=t.y,l=t.width,a=t.height;const h=this.shadowBlur,c=this.shadowOffset;return l+=h,a+=h,o-=h/2,r-=h/2,c.x>0?l+=c.x:(o+=c.x,l-=c.x),c.y>0?a+=c.y:(r+=c.y,a-=c.y),i.e(o-1,r-1,l+2,a+2),i}tE(){return this.type===Panel.Link&&this instanceof Adornment&&this.category==="Selection"&&this.adornedObject instanceof Shape&&this.adornedPart.findMainElement()===this.adornedObject?this.adornedObject.strokeWidth:0}wE(){return isNaN(this.xy)&&(this.xy=this.wD()),this.xy}Tf(){this.xy=NaN}Ut(){if(this.as()===!1){this.ED();return}this.ao(!1);const t=this.De,e=Rect.l();e.h(t);const i=this.Ul();this.Pa(0,0,this.ai.width,this.ai.height);const s=this.position;this.UD(s,this.location),t.ce(),t.x=s.x,t.y=s.y,t.b(),this.bd(e,t),e.equals(t)?this.As(i):this.Di()&&(!G.u(e.width,t.width)||!G.u(e.height,t.height))&&this.EM>=0&&this.invalidateLayout(16),Rect.i(e),this.hC(!1)}bd(t,e){const i=this.diagram;if(i===null)return;let s=!1;if(i.dh===!1&&t.isReal()){const n=Rect.l();n.h(i.documentBounds),n.subtractMargin(i.padding),t.x>n.x&&t.y>n.y&&t.right<n.right&&t.bottom<n.bottom&&e.x>n.x&&e.y>n.y&&e.right<n.right&&e.bottom<n.bottom&&(s=!0),Rect.i(n)}(this.xE()===!0||!t.equals(e))&&this.dT(s,i),i.C(),!(!t.isReal()&&!e.isReal()||t.equalsApproxClose(e))&&(this instanceof Node&&!i.undoManager.isUndoingRedoing&&this.invalidateConnectedLinks(),this.Sa())}get location(){return this.nn}set location(t){const e=t.x,i=t.y,s=this.nn;(s.x!==e&&(!isNaN(s.x)||!isNaN(e))||s.y!==i&&(!isNaN(s.y)||!isNaN(i)))&&(t=t.copy(),this.bE(t,s)&&this.t("location",s,t.copy()))}bE(t,e){if(this.Ar())return!1;if(this.nn=t,this.k|=2097152,this.as()===!1){this.ak();const i=this.ct;if(i.isReal()){const s=this.diagram;if(s===null||s.animationManager.isTicking||!s.undoManager.isUndoingRedoing){const n=i.copy();i.e(i.x+(t.x-e.x),i.y+(t.y-e.y)),this.VD(s,i,n.x,n.y),this.t("position",n,i.copy())}}}return!0}DN(t,e,i){if(this.Ar()||!t.isReal())return!1;const s=this.diagram;if(s!==null&&this.VD(s,t,e,i),this.ct=t,this.k&=-2097153,this.nn.isReal()&&(s===null||s.animationManager.isTicking||!s.undoManager.isUndoingRedoing)){const n=this.nn;this.nn=new Point(n.x+(t.x-e),n.y+(t.y-i)).b(),this.t("location",n,this.nn.copy())}return this.fa()===!1&&this.as()===!1&&(this.ak(),this.ED()),!0}VD(t,e,i,s){if(t===null||this instanceof Adornment)return;const n=t.animationManager;n.ke&&n.vA(this,new Point(i,s),e,!1)}Ec(t,e,i){const s=this.nn,n=this.ct;if(i){if(s.x===t&&s.y===e)return;this.fa()||this.as()?n.e(NaN,NaN):n.e(n.x+t-s.x,n.y+e-s.y),s.e(t,e)}else{if(n.x===t&&n.y===e)return;s.e(s.x+t-n.x,s.y+e-n.y),n.e(t,e)}this.ak()}vN(){this.k&=-2097153,this.ak()}UD(t,e){const i=this.fD(Point.l()),s=this.diagram,n=e.isReal(),o=t.isReal();n&&o?(this.k&2097152)!==0?this.BD(t,e,s,i):this.zD(t,e,s,i):n?this.BD(t,e,s,i):o&&this.zD(t,e,s,i),this.k|=2097152,Point.i(i),this.pf()}BD(t,e,i,s){const n=t.x,o=t.y;if(t.e(e.x-s.x,e.y-s.y),i!==null){const r=i.animationManager,l=r.defaultAnimation.isAnimating;!l&&r.ke&&!(this instanceof Adornment)&&r.vA(this,new Point(n,o),t,!1),!l&&!(t.x===n&&t.y===o)&&this.t("position",new Point(n,o),t.copy())}}zD(t,e,i,s){const n=e.copy();e.e(t.x+s.x,t.y+s.y),!e.equals(n)&&i!==null&&this.t("location",n,e.copy())}dT(t,e){this.NN(!1),this instanceof Node&&e.V2(this),!this.layer.isTemporary&&!t&&e.invalidateDocumentBounds();const i=this.De,s=e.viewportBounds;s.isReal()?this.Ul()?(i.UL(s,10)||this.As(!1),this.updateAdornments()):this.isVisible()&&i.intersectsRect(s)?(this.As(!0),this.updateAdornments()):this.invalidateAdornments():e._c=!0}_r(){return!0}Di(){return!0}Ar(){return!1}_s(){return!0}hasPlaceholder(){return!1}get category(){return this._o}set category(t){const e=this._o;if(e===t)return;this.svg!==null&&(this.svg.remove(),this.$i(!0));const i=this.diagram,s=this.data;let n=null;if(i!==null&&s!==null&&!(this instanceof Adornment)){const o=i.model.undoManager;o.isEnabled&&!o.isUndoingRedoing&&(n=this.clone(),n.D.addAll(this.D))}if(this._o=t,this.t("category",e,t),i!==null&&s!==null&&!(this instanceof Adornment)){const o=i.model;if(o.undoManager.isUndoingRedoing)return;if(this.Ar()){i.partManager.setLinkCategoryForData(s,t);const r=i.partManager.findLinkTemplateForCategory(t);if(r!==null){r.It();const l=r.copy();l!==null&&this.cC(l,e,t)}}else{o!==null&&o.setCategoryForNodeData(s,t);const r=i.partManager.findTemplateForNodeData(s,t);if(r!==null){r.It();const l=r.copy();if(l!==null&&!(l instanceof Link)){const a=this.location.copy();this.cC(l,e,t),this.location.isReal()||(this.location=a)}}}if(n!==null){const r=this.clone();r.D.addAll(this.D),this.t("self",n,r)}}else if(this instanceof Adornment){const o=this.adornedPart;if(o!==null){const r=o.tr;r!==null&&r.delete(e),o.addAdornment(this.category,this)}}}get self(){return this}set self(t){this.cC(t,this.category,t.category)}static XD=!1;cC(t,e,i){t.constructor!==this.constructor&&(Part.XD||(Part.XD=!0,U.ne('Should not change the class of the Part when changing category from "'+e+'" to "'+i+'"'),U.ne("  Old class: "+U.Hn(this.constructor)+", new class: "+U.Hn(t.constructor)+", part: "+this.toString()))),this.clearAdornments();const s=this.data,n=this.layerName,o=this.isSelected,r=this.isHighlighted;let l=!0,a=!0,h=!1;this instanceof Node&&(l=this.isTreeLeaf,a=this.isTreeExpanded,h=this.wasTreeExpanded),t.jo(this),t.cloneProtected(this),this._o=i,this.svg!==null&&(this.svg.remove(),this.qc(),this.$i(!0)),this.c(),this.C();const c=this.diagram;let f=!0;c!==null&&(f=c.skipsUndoManager,c.skipsUndoManager=!0),this.te=s,this.k=o?this.k|4096:this.k&-4097,this.k=r?this.k|524288:this.k&-524289,this instanceof Node&&(this.E=l?this.E|4:this.E&-5,this.E=a?this.E|1:this.E&-2,this.E=h?this.E|2:this.E&-3),s!==null&&this.updateTargetBindings();const u=this.layerName;u!==n&&(this.dl=n,this.layerName=u),c!==null&&(c.skipsUndoManager=f),this.Di()&&this.invalidateLayout(64)}canCopy(){if(!this.copyable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowCopy)return!1;const e=t.diagram;return e===null?!0:!!e.allowCopy}canDelete(){if(!this.deletable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowDelete)return!1;const e=t.diagram;return e===null?!0:!!e.allowDelete}canEdit(){if(!this.textEditable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowTextEdit)return!1;const e=t.diagram;return e===null?!0:!!e.allowTextEdit}canGroup(){if(!this.groupable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowGroup)return!1;const e=t.diagram;return e===null?!0:!!e.allowGroup}canMove(){if(!this.movable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowMove)return!1;const e=t.diagram;return e===null?!0:!!e.allowMove}canReshape(){if(!this.reshapable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowReshape)return!1;const e=t.diagram;return e===null?!0:!!e.allowReshape}canResize(){if(!this.resizable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowResize)return!1;const e=t.diagram;return e===null?!0:!!e.allowResize}canRotate(){if(!this.rotatable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowRotate)return!1;const e=t.diagram;return e===null?!0:!!e.allowRotate}canSelect(){if(!this.selectable)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowSelect)return!1;const e=t.diagram;return e===null?!0:!!e.allowSelect}get copyable(){return(this.k&1)!==0}set copyable(t){const e=(this.k&1)!==0;e!==t&&(this.k=this.k^1,this.t("copyable",e,t))}get deletable(){return(this.k&2)!==0}set deletable(t){const e=(this.k&2)!==0;e!==t&&(this.k=this.k^2,this.t("deletable",e,t))}get textEditable(){return(this.k&4)!==0}set textEditable(t){const e=(this.k&4)!==0;e!==t&&(this.k=this.k^4,this.t("textEditable",e,t),this.invalidateAdornments())}get groupable(){return(this.k&8)!==0}set groupable(t){const e=(this.k&8)!==0;e!==t&&(this.k=this.k^8,this.t("groupable",e,t))}get movable(){return(this.k&16)!==0}set movable(t){const e=(this.k&16)!==0;e!==t&&(this.k=this.k^16,this.t("movable",e,t))}get selectionAdorned(){return(this.k&32)!==0}set selectionAdorned(t){const e=(this.k&32)!==0;e!==t&&(this.k=this.k^32,this.t("selectionAdorned",e,t),this.invalidateAdornments())}get isInDocumentBounds(){return(this.k&64)!==0}set isInDocumentBounds(t){const e=(this.k&64)!==0;if(e!==t){this.k=this.k^64;const i=this.diagram;i!==null&&i.invalidateDocumentBounds(),this.t("isInDocumentBounds",e,t)}}get isLayoutPositioned(){return(this.k&128)!==0}set isLayoutPositioned(t){const e=(this.k&128)!==0;e!==t&&(this.k=this.k^128,this.t("isLayoutPositioned",e,t),this.invalidateLayout(t?4:8))}get selectable(){return(this.k&256)!==0}set selectable(t){const e=(this.k&256)!==0;e!==t&&(this.k=this.k^256,this.t("selectable",e,t),this.invalidateAdornments())}get reshapable(){return(this.k&512)!==0}set reshapable(t){const e=(this.k&512)!==0;e!==t&&(this.k=this.k^512,this.t("reshapable",e,t),this.invalidateAdornments())}get resizable(){return(this.k&1024)!==0}set resizable(t){const e=(this.k&1024)!==0;e!==t&&(this.k=this.k^1024,this.t("resizable",e,t),this.invalidateAdornments())}get rotatable(){return(this.k&2048)!==0}set rotatable(t){const e=(this.k&2048)!==0;e!==t&&(this.k=this.k^2048,this.t("rotatable",e,t),this.invalidateAdornments())}get isSelected(){return(this.k&4096)!==0}set isSelected(t){const e=(this.k&4096)!==0;if(e!==t){const i=this.diagram;if(t){if(!this.canSelect())return;if(i!==null){const o=i.maxSelectionCount;if(i.selection.count>=o)return}}this.k=this.k^4096;let s=!1;if(i!==null){s=i.skipsUndoManager,i.skipsUndoManager=!0;const o=i.selection;o.ce(),t?o.add(this):o.delete(this),o.b()}this.t("isSelected",e,t),this.invalidateAdornments();const n=this.selectionChanged;n!==null&&n(this),i!==null&&(i.requestUpdate(),i.skipsUndoManager=s)}}get isHighlighted(){return(this.k&524288)!==0}set isHighlighted(t){const e=(this.k&524288)!==0;if(e!==t){this.k=this.k^524288;const i=this.diagram;if(i!==null){const n=i.highlighteds;n.ce(),t?n.add(this):n.delete(this),n.b()}this.t("isHighlighted",e,t),this.C();const s=this.highlightedChanged;s!==null&&s(this)}}get isShadowed(){return(this.k&8192)!==0}set isShadowed(t){const e=(this.k&8192)!==0;e!==t&&(this.k=this.k^8192,this.$i(!0),this.t("isShadowed",e,t),this.C())}OD(){return(this.k&16384)!==0}ID(t){t?this.k|=16384:this.k&=-16385}fa(){return(this.k&32768)!==0}hC(t){t?this.k|=32768:this.k&=-32769}xE(){return(this.k&65536)!==0}NN(t){t?this.k|=65536:this.k&=-65537}Ul(){return(this.k&131072)!==0}As(t){t?this.k|=131072:this.k&=-131073}GD(){return(this.k&1048576)!==0}hk(t){t?this.k|=1048576:this.k&=-1048577}get isAnimated(){return(this.k&262144)!==0}set isAnimated(t){const e=(this.k&262144)!==0;e!==t&&(this.k=this.k^262144,this.t("isAnimated",e,t))}get highlightedChanged(){return this.H!==null?this.H.Cy:null}set highlightedChanged(t){const e=this.highlightedChanged;e!==t&&(t!==null&&U.S(t,Part,"highlightedChanged"),this._e().Cy=t,this.t("highlightedChanged",e,t))}get selectionObjectName(){return this.H!==null?this.H.Ly:""}set selectionObjectName(t){const e=this.selectionObjectName;e!==t&&(this._e().Ly=t,this.gl=null,this.t("selectionObjectName",e,t))}get selectionAdornmentTemplate(){return this.H!==null?this.H.Ay:null}set selectionAdornmentTemplate(t){const e=this.selectionAdornmentTemplate;e!==t&&(t!==null&&t.It(),this._e().Ay=t,this.t("selectionAdornmentTemplate",e,t))}get selectionObject(){if(this.gl===null){const t=this.selectionObjectName;if(t!==null&&t!==""){const e=this.findObject(t);e!==null?this.gl=e:this.gl=this}else if(this instanceof Link){const e=this.path;e!==null?this.gl=e:this.gl=this}else this.gl=this}return this.gl}get selectionChanged(){return this.H!==null?this.H.Ty:null}set selectionChanged(t){const e=this.selectionChanged;e!==t&&(t!==null&&U.S(t,Part,"selectionChanged"),this._e().Ty=t,this.t("selectionChanged",e,t))}get resizeAdornmentTemplate(){return this.H!==null?this.H.Dy:null}set resizeAdornmentTemplate(t){const e=this.resizeAdornmentTemplate;e!==t&&(this._e().Dy=t!==null?t.It():null,this.t("resizeAdornmentTemplate",e,t))}get resizeObjectName(){return this.H!==null?this.H.vy:""}set resizeObjectName(t){const e=this.resizeObjectName;e!==t&&(this._e().vy=t,this.t("resizeObjectName",e,t))}get resizeObject(){const t=this.resizeObjectName;if(t!==""){const e=this.findObject(t);if(e!==null)return e}return this}get resizeCellSize(){return this.H!==null?this.H.Fy:Size.$w}set resizeCellSize(t){const e=this.resizeCellSize;e.equals(t)||(t=t.N(),this._e().Fy=t,this.t("resizeCellSize",e,t))}get rotateAdornmentTemplate(){return this.H!==null?this.H.Ry:null}set rotateAdornmentTemplate(t){const e=this.rotateAdornmentTemplate;e!==t&&(this._e().Ry=t!==null?t.It():null,this.t("rotateAdornmentTemplate",e,t))}get rotateObjectName(){return this.H!==null?this.H.Oy:""}set rotateObjectName(t){const e=this.rotateObjectName;e!==t&&(this._e().Oy=t,this.t("rotateObjectName",e,t))}get rotateObject(){const t=this.rotateObjectName;if(t!==""){const e=this.findObject(t);if(e!==null)return e}return this}get rotationSpot(){return this.H!==null?this.H.Iy:Spot.Default}set rotationSpot(t){const e=this.rotationSpot;e.equals(t)||(t=t.N(),this._e().Iy=t,this.t("rotationSpot",e,t))}get text(){return this.ue}set text(t){const e=this.ue;e!==t&&(this.ue=t,this.t("text",e,t))}get containingGroup(){return this.Ta}set containingGroup(t){if(this.Di()){const e=this.Ta;if(e!==t){t!==null&&(this===t||t.isMemberOf(this))&&(this===t&&U.o("Cannot make a Group a member of itself: "+this.toString()),U.o("Cannot make a Group indirectly contain itself: "+this.toString()+" already contains "+t.toString())),this.invalidateLayout(2);const i=this.diagram;if(e!==null?e.fC(this):this instanceof Group&&i!==null&&i.Zr.delete(this),this.Ta=t,t!==null?t.uC(this):this instanceof Group&&i!==null&&i.Zr.add(this),this.invalidateLayout(1),i!==null&&i.G){const n=this.data,o=i.model;if(n!==null&&o.ff()){const r=t!==null?t.data:null;o.setGroupForData(n,o.getKeyForNodeData(r))}}const s=this.containingGroupChanged;if(s!==null){let n=!0;i!==null&&(n=i.G,i.G=!0),s(this,e,t),i!==null&&(i.G=n)}if(this instanceof Group){const n=new GSet;Part.ga(n,this,!0,0,!0);const o=n.iterator;for(;o.next();){const r=o.value;if(r instanceof Node){const l=r.linksConnected;for(;l.next();)l.value.qd()}}}if(this instanceof Node){const n=this.linksConnected;for(;n.next();)n.value.qd();const o=this.labeledLink;o!==null&&o.qd()}this.t("containingGroup",e,t),t!==null&&t.yE()}}else U.o("cannot set the Part.containingGroup of a Link or Adornment")}Sa(){const t=this.containingGroup;t!==null&&(t.hasPlaceholder()&&t.placeholder.c(),t.c(),t.invalidateConnectedLinks())}C(){const t=this.diagram;t!==null&&!this.as()&&!this.fa()&&this.isVisible()&&this.De.isReal()&&t.C(this.lh(this.De))}c(){if(this.Go())return;super.c();const t=this.diagram;t!==null&&(t.Np(this),this instanceof Node&&this.labeledLink!==null&&this.labeledLink.kf(),t.requestUpdate(!0))}kf(t){if(this.as())return;const e=this.diagram;e!==null&&(e.Np(this),this instanceof Node&&this.invalidateConnectedLinks(),e.requestUpdate()),this.ao(!0)}_m(t){if(!t){const e=this.Ta;e!==null&&e.uC(this)}}tp(t){if(!t){const e=this.Ta;e!==null&&e.fC(this)}}rf(){const t=this.data;if(t!==null){const e=this.diagram;if(e!==null){const i=e.model;i!==null&&i.removeNodeData(t)}}}get containingGroupChanged(){return this.H!==null?this.H.Ey:null}set containingGroupChanged(t){const e=this.containingGroupChanged;e!==t&&(t!==null&&U.S(t,Part,"containingGroupChanged"),this._e().Ey=t,this.t("containingGroupChanged",e,t))}findSubGraphLevel(){return this.dC(this)}dC(t){const e=t.containingGroup;if(e!==null)return 1+this.dC(e);if(t instanceof Node){const i=t.labeledLink;if(i!==null)return this.dC(i)}return 0}findTopLevelPart(){return this.gC(this)}gC(t){const e=t.containingGroup;if(e!==null)return this.gC(e);if(t instanceof Node){const i=t.labeledLink;if(i!==null)return this.gC(i)}return t}get isTopLevel(){return!(this.containingGroup!==null||this instanceof Node&&this.labeledLink!==null)}isMemberOf(t){return t instanceof Group?this.mC(this,t):!1}mC(t,e){if(t===e||e===null)return!1;const i=t.containingGroup;if(i!==null&&(i===e||this.mC(i,e)))return!0;if(t instanceof Node){const s=t.labeledLink;if(s!==null)return this.mC(s,e)}return!1}findCommonContainingGroup(t){if(t===null)return null;if(this===t)return this.containingGroup;let e=this;for(;e!==null;){if(e instanceof Group&&e.hk(!0),e instanceof Node){const s=e.labeledLink;s!==null&&(e=s)}e=e.containingGroup}let i=null;for(e=t;e!==null;){if(e.GD()){i=e;break}if(e instanceof Node){const s=e.labeledLink;s!==null&&(e=s)}e=e.containingGroup}for(e=this;e!==null;){if(e instanceof Group&&e.hk(!1),e instanceof Node){const s=e.labeledLink;s!==null&&(e=s)}e=e.containingGroup}return i}get layoutConditions(){return this.H!==null?this.H.Uy:127}set layoutConditions(t){const e=this.layoutConditions;e!==t&&(this._e().Uy=t,this.t("layoutConditions",e,t))}canLayout(){if(!this.isLayoutPositioned||!this.isVisible())return!1;const t=this.layer;return!(t!==null&&t.isTemporary||this instanceof Node&&this.isLinkLabel)}kE(t){if(!this.isLayoutPositioned||(t&this.layoutConditions)===0)return!1;const e=this.layer;if(e!==null&&e.isTemporary||this instanceof Node&&this.isLinkLabel)return!1;const i=this.diagram;return!(i!==null&&i.undoManager.isUndoingRedoing)}invalidateLayout(t){if(t===void 0&&(t=16777215),!this.kE(t))return;const e=this.Ta;if(e!==null){const i=e.layout;i!==null?i.p():e.invalidateLayout(t)}else{const i=this.diagram;if(i!==null){const s=i.layout;s!==null&&s.p()}}}gT(){if(!this.isVisible())return!1;const t=this.layer;return!(t!==null&&t.isTemporary)}static ga(t,e,i,s,n,o){if(o===void 0&&(o=null),!t.has(e)&&!(o!==null&&!o(e))&&!(e instanceof Adornment)){if(t.add(e),e instanceof Node){if(i&&e instanceof Group){const r=e.memberParts;for(;r.next();){const l=r.value;Part.ga(t,l,i,s,n,o)}}if(n!==!1){const r=e.linksConnected;for(;r.next();){const l=r.value;if(t.has(l))continue;const a=l.fromNode,h=l.toNode,c=a===null||t.has(a),f=h===null||t.has(h);(n?c&&f:c||f)&&Part.ga(t,l,i,s,n,o)}}if(s>1){const r=e.findTreeChildrenNodes();for(;r.next();){const l=r.value;Part.ga(t,l,i,s-1,n,o)}}}else if(e instanceof Link){const r=e.labelNodes;for(;r.next();){const l=r.value;Part.ga(t,l,i,s,n,o)}}}}get dragComputation(){return this.H!==null?this.H.Vy:null}set dragComputation(t){const e=this.dragComputation;e!==t&&(t!==null&&U.S(t,Part,"dragComputation"),this._e().Vy=t,this.t("dragComputation",e,t))}get shadowOffset(){return this.H!==null?this.H.By:Point.FL}set shadowOffset(t){const e=this.shadowOffset;e.equals(t)||(t=t.N(),this._e().By=t,this.C(),this.t("shadowOffset",e,t))}get shadowColor(){return this.H!==null?this.H.zy:"gray"}set shadowColor(t){const e=this.shadowColor;e!==t&&(this._e().zy=t,this.C(),this.t("shadowColor",e,t))}get shadowBlur(){return this.H!==null?this.H.An:4}set shadowBlur(t){const e=this.shadowBlur;e!==t&&(this._e().An=t,this.C(),this.t("shadowBlur",e,t))}}class PartTemplateSettings{me;ky;Ey;Ay;Ly;Ty;Cy;Dy;vy;Fy;Ry;Oy;Iy;My;Ny;Py;Sy;Vy;Uy;By;zy;An;constructor(){this.me=!1,this.ky=null,this.Ey=null,this.Ay=null,this.Ly="",this.Ty=null,this.Cy=null,this.Dy=null,this.vy="",this.Fy=Size.$w,this.Ry=null,this.Oy="",this.Iy=Spot.Default,this.My="",this.Ny=Spot.TopLeft,this.Py=Point.DL,this.Sy=Point.vL,this.Vy=null,this.Uy=127,this.By=Point.FL,this.zy="gray",this.An=4}copy(){const t=new PartTemplateSettings;return t.ky=this.ky,t.Ey=this.Ey,t.Ay=this.Ay,t.Ly=this.Ly,t.Ty=this.Ty,t.Cy=this.Cy,t.Dy=this.Dy,t.vy=this.vy,t.Fy=this.Fy.N(),t.Ry=this.Ry,t.Oy=this.Oy,t.Iy=this.Iy.N(),t.My=this.My,t.Ny=this.Ny.N(),t.Py=this.Py.N(),t.Sy=this.Sy.N(),t.Vy=this.Vy,t.Uy=this.Uy,t.By=this.By.N(),t.zy=this.zy,t.An=this.An,t}}class Adornment extends Part{Ms;Dt;qS;WS;Lf;constructor(t,e){let i;t===void 0||t instanceof PanelLayout||typeof t=="string"?i=t:t&&(e=t),super(i),this.k&=-257,this.dl="Adornment",this.Ms=null,this.qS=0,this.WS=!1,this.Dt=null,this.Lf=null,e&&Object.assign(this,e)}toString(){const t=this.adornedPart;return"Adornment("+this.category+")"+(t!==null?t.toString():"")}updateRelationshipsFromData(){}Ad(t){const e=this.adornedObject;if(!(e instanceof Shape))return;const i=e.part;if(!(i instanceof Link))return;const s=i.path;let n=s.geometry;i.Ad(t),n=s.geometry;const o=this.D.r,r=o.length;for(let l=0;l<r;l++){const a=o[l];a.isPanelMain&&a instanceof Shape&&(a.ut=n)}}hasPlaceholder(){return this.Dt!==null&&this.Dt.isVisibleObject()}get placeholder(){return this.Dt}get adornedObject(){return this.Ms}set adornedObject(t){const e=this.adornedPart;let i=null;t!==null&&(i=t.part),e!==null&&(t===null||e!==i)&&e.removeAdornment(this.category),this.Ms=t,i!==null&&i.addAdornment(this.category,this)}get adornedPart(){const t=this.Ms;return t!==null?t.part:null}_r(){const t=this.Ms;if(t===null)return!0;const e=t.part;return e===null||!e.as()}Di(){return!1}get containingGroup(){return null}df(t,e,i,s,n,o,r){if(t===3&&e==="elements"){if(n instanceof Placeholder)this.Dt===null&&(this.Dt=n);else if(n instanceof Panel){const l=n.findInVisualTree(a=>a instanceof Placeholder);l instanceof Placeholder&&this.Dt===null&&(this.Dt=l)}}else t===4&&e==="elements"&&this.Dt!==null&&(s===this.Dt?this.Dt=null:s instanceof Panel&&this.Dt.isContainedBy(s)&&(this.Dt=null));super.df(t,e,i,s,n,o,r)}updateAdornments(){}rf(){}}var PortSpreading=(w=>(w[w.None=0]="None",w[w.Evenly=1]="Evenly",w[w.Packed=2]="Packed",w))(PortSpreading||{});class Node extends Part{E;vt;zf;yl;Da;hi;ee;constructor(t,e){let i;t===void 0||t instanceof PanelLayout||typeof t=="string"?i=t:t&&(e=t),super(i),this.E=13,this.vt=null,this.ee=new List,this.zf=null,this.yl=null,this.hi=null,this.Da=!1,e&&Object.assign(this,e)}cloneProtected(t){super.cloneProtected(t),t.E=this.E,this.vt!==null&&(this.vt.me?t.vt=this.vt:t.vt=this.vt.copy())}jo(t){super.jo(t),t.invalidateConnectedLinks(),t.yl=this.yl,t.hi=null}static SpreadingNone=0;static SpreadingEvenly=1;static SpreadingPacked=2;wl(){return this.vt===null?this.vt=new NodeTemplateSettings:this.vt.me&&(this.vt=this.vt.copy()),this.vt}ba(){super.ba(),this.vt!==null&&(this.vt.me=!0)}YD(t){t!==null&&(this.yl===null&&(this.yl=new GSet),this.yl.add(t))}KD(t){t!==null&&this.yl!==null&&this.yl.delete(t)}HD(t,e,i){if(t===null||this.yl===null)return null;const s=this.yl.iterator;for(;s.next();){const n=s.value;if(n.Xy===this&&n.ck===t&&n.pC===e&&n.yC===i||n.Xy===t&&n.ck===this&&n.pC===i&&n.yC===e)return n}return null}invalidateLinkBundle(t,e,i){e==null&&(e=""),i==null&&(i="");const s=this.HD(t,e,i);s!==null&&s.Wd()}df(t,e,i,s,n,o,r){t===3&&e==="elements"?this.hi=null:t===4&&e==="elements"&&(this.hi=null),super.df(t,e,i,s,n,o,r)}invalidateConnectedLinks(t,e){const i=this.linksConnected;for(;i.next();){const s=i.value;t&&t.has(s)||e&&s.fromPort!==e&&s.toPort!==e||(this.Pi(s.fromPort),this.Pi(s.toPort),s.$t())}}Pi(t){if(t===null)return;const e=t.pd;e!==null&&e.Wd();const i=t.part,s=i.containingGroup;s!==null&&!i.isVisible()&&s.Pi(s.port)}_r(){return!0}get portSpreading(){return this.vt!==null?this.vt.Gy:1}set portSpreading(t){const e=this.portSpreading;if(e!==t){this.wl().Gy=t,this.t("portSpreading",e,t);const i=this.diagram;if(i!==null&&i.undoManager.isUndoingRedoing)return;this.invalidateConnectedLinks()}}get avoidable(){return(this.E&8)!==0}set avoidable(t){const e=(this.E&8)!==0;if(e!==t){this.E=this.E^8;const i=this.diagram;i!==null&&i.V2(this),this.t("avoidable",e,t)}}get avoidableMargin(){return this.vt!==null?this.vt.Yy:Margin.BL}set avoidableMargin(t){typeof t=="number"&&(t=new Margin(t));const e=this.avoidableMargin;if(!e.equals(t)){t=t.N(),this.wl().Yy=t;const i=this.diagram;i!==null&&i.V2(this),this.t("avoidableMargin",e,t)}}canAvoid(){return this.avoidable&&!this.isLinkLabel}getAvoidableRect(t){return t.set(this.actualBounds),t.addMargin(this.avoidableMargin),t}findVisibleNode(){let t=this;for(;t!==null&&!t.isVisible();)t=t.containingGroup;return t}isVisible(){if(!super.isVisible())return!1;let t=!0,e=1;const i=this.diagram;if(i!==null){if(i.animationManager.qx(this))return!0;t=i.isTreePathToChildren,e=i.treeCollapsePolicy}if(e===1){const n=this.findTreeParentNode();if(n!==null&&!n.isTreeExpanded)return!1}else if(e===2){const n=t?this.findLinksInto():this.findLinksOutOf();let o=!1,r=!1;for(;n.next();){const l=n.value;if(l.isTreeLink){o=!0;const a=t?l.fromNode:l.toNode;if(a&&a.isTreeExpanded){r=!0;break}}}if(o&&!r)return!1}else if(e===3){const n=t?this.findLinksInto():this.findLinksOutOf();let o=!1,r=!1;for(;n.next();){const l=n.value;if(l.isTreeLink){o=!0;const a=t?l.fromNode:l.toNode;if(a&&!a.isTreeExpanded){r=!0;break}}}if(o&&r)return!1}const s=this.labeledLink;return s!==null?s.isVisible():!0}Xe(t){super.Xe(t);const e=this.linksConnected;for(;e.next();){const i=e.value;if(t&&this.containingGroup!==null){const s=i.getOtherNode(this);s!==null&&!s.isMemberOf(this.containingGroup)&&i.$t()}i.Xe(t)}}get linksConnected(){return this.ee.iterator}findExternalTreeLinksConnected(){const t=new GSet,e=new GSet;return this.jD(this,t,e),e.iterator}jD(t,e,i){if(t===null||e.has(t))return;e.add(t);let s=!0;const n=this.diagram;n!==null&&(s=n.isTreePathToChildren),t.linksConnected.each(o=>{o.isTreeLink?(s?o.fromNode===t:o.toNode===t)&&this.jD(s?o.toNode:o.fromNode,e,i):i.add(o)})}findLinksConnected(t){if(t===void 0&&(t=null),t===null)return this.ee.iterator;const e=new ListIterator(this.ee),i=this;return e.predicate=s=>s.fromNode===i&&s.fromPortId===t||s.toNode===i&&s.toPortId===t,e}findLinksOutOf(t){t===void 0&&(t=null);const e=new ListIterator(this.ee),i=this;return e.predicate=s=>s.fromNode!==i?!1:t===null?!0:s.fromPortId===t,e}findLinksInto(t){t===void 0&&(t=null);const e=new ListIterator(this.ee),i=this;return e.predicate=s=>s.toNode!==i?!1:t===null?!0:s.toPortId===t,e}findNodesConnected(t){t===void 0&&(t=null);let e=null,i=null;const s=this.ee.iterator;for(;s.next();){const n=s.value;if(n.fromNode===this){if(t===null||n.fromPortId===t){const o=n.toNode;e!==null?e.add(o):i!==null&&i!==o?(e=new GSet,e.add(i),e.add(o)):i=o}}else if(n.toNode===this&&(t===null||n.toPortId===t)){const o=n.fromNode;e!==null?e.add(o):i!==null&&i!==o?(e=new GSet,e.add(i),e.add(o)):i=o}}return e!==null?e.iterator:i!==null?new SingletonIterator(i):EmptyIterator.instance}findNodesOutOf(t){t===void 0&&(t=null);let e=null,i=null;const s=this.ee.iterator;for(;s.next();){const n=s.value;if(n.fromNode===this&&(t===null||n.fromPortId===t)){const o=n.toNode;e!==null?e.add(o):i!==null&&i!==o?(e=new GSet,e.add(i),e.add(o)):i=o}}return e!==null?e.iterator:i!==null?new SingletonIterator(i):EmptyIterator.instance}findNodesInto(t){t===void 0&&(t=null);let e=null,i=null;const s=this.ee.iterator;for(;s.next();){const n=s.value;if(n.toNode===this&&(t===null||n.toPortId===t)){const o=n.fromNode;e!==null?e.add(o):i!==null&&i!==o?(e=new GSet,e.add(i),e.add(o)):i=o}}return e!==null?e.iterator:i!==null?new SingletonIterator(i):EmptyIterator.instance}findLinksBetween(t,e,i){e===void 0&&(e=null),i===void 0&&(i=null);const s=new ListIterator(this.ee),n=this;return s.predicate=o=>o.fromNode===n&&o.toNode===t&&(e===null||o.fromPortId===e)&&(i===null||o.toPortId===i)||o.fromNode===t&&o.toNode===n&&(i===null||o.fromPortId===i)&&(e===null||o.toPortId===e),s}findLinksTo(t,e,i){e===void 0&&(e=null),i===void 0&&(i=null);const s=new ListIterator(this.ee),n=this;return s.predicate=o=>!(o.fromNode!==n||o.toNode!==t||e!==null&&o.fromPortId!==e||i!==null&&o.toPortId!==i),s}findSuccessorParts(t){return t===void 0&&(t=new GSet),this.qD(this,t),t.remove(this),t}qD(t,e){t!==null&&(e.has(t)||(e.add(t),t.findLinksOutOf().each(i=>{if(e.has(i))return;e.add(i);const s=i.toNode;s!==null&&this.qD(s,e)})))}findPredecessorParts(t){return t===void 0&&(t=new GSet),this.WD(this,t),t.remove(this),t}WD(t,e){t!==null&&(e.has(t)||(e.add(t),t.findLinksInto().each(i=>{if(e.has(i))return;e.add(i);const s=i.fromNode;s!==null&&this.WD(s,e)})))}get linkConnected(){return this.vt!==null?this.vt.Ky:null}set linkConnected(t){const e=this.linkConnected;e!==t&&(t!==null&&U.S(t,Node,"linkConnected"),this.wl().Ky=t,this.t("linkConnected",e,t))}get linkDisconnected(){return this.vt!==null?this.vt.Hy:null}set linkDisconnected(t){const e=this.linkDisconnected;e!==t&&(t!==null&&U.S(t,Node,"linkDisconnected"),this.wl().Hy=t,this.t("linkDisconnected",e,t))}get linkValidation(){return this.vt!==null?this.vt.El:null}set linkValidation(t){const e=this.linkValidation;e!==t&&(t!==null&&U.S(t,Node,"linkValidation"),this.wl().El=t,this.t("linkValidation",e,t))}fk(t,e){this.Pi(e);const i=this.ee.has(t);if(i||this.ee.add(t),!i||t.fromNode===t.toNode){const s=this.linkConnected;if(s!==null){let n=!0;const o=this.diagram;o!==null&&(n=o.G,o.G=!0),s(this,t,e),o!==null&&(o.G=n)}}if(!i){if(!t.isTreeLink)return;const s=t.fromNode,n=t.toNode;if(s!==null&&n!==null&&s!==n){let o=!0;const r=this.diagram;r!==null&&(o=r.isTreePathToChildren);const l=o?n:s,a=o?s:n;if(l.Da||(l.Da=a),a.isTreeLeaf){if(r!==null&&r.undoManager.isUndoingRedoing)return;o?s===a&&(a.isTreeLeaf=!1):n===a&&(a.isTreeLeaf=!1)}}}}uk(t,e){this.Pi(e);const i=this.ee.delete(t);let s=null;if(i||t.toNode===t.fromNode){const n=this.linkDisconnected;if(s=this.diagram,n!==null){let o=!0;s!==null&&(o=s.G,s.G=!0),n(this,t,e),s!==null&&(s.G=o)}}if(i){if(!t.isTreeLink)return;let n=!0;s!==null&&(n=s.isTreePathToChildren);const o=n?t.toNode:t.fromNode,r=n?t.fromNode:t.toNode;if(o!==null&&(o.Da=!1),r!==null&&!r.isTreeLeaf)if(r.ee.count===0){if(r.Da=null,s!==null&&s.undoManager.isUndoingRedoing)return;r.isTreeLeaf=!0}else r.Dp()}}Dp(){if(this.Da=!1,this.ee.count===0)return;let t=!0;const e=this.diagram;if(e!==null&&e.undoManager.isUndoingRedoing)return;e!==null&&(t=e.isTreePathToChildren);const i=this.ee.iterator;for(;i.next();){const s=i.value;if(s.isTreeLink){if(t){if(s.fromNode===this){this.isTreeLeaf=!1;return}}else if(s.toNode===this){this.isTreeLeaf=!1;return}}}this.isTreeLeaf=!0}updateRelationshipsFromData(){const t=this.diagram;t!==null&&t.partManager.updateRelationshipsFromData(this)}_m(t){if(super._m(t),!t){this.Dp();const e=this.zf;e!==null&&e.JD(this)}}tp(t){if(super.tp(t),!t){const e=this.zf;e!==null&&e.$D(this)}}rf(){if(this.ee.count>0){const t=this.diagram;if(t!==null){const e=t.commandHandler!==null?t.commandHandler.deletesConnectedLinks:!0,s=this.ee.copy().iterator;for(;s.next();){const n=s.value;e?t.remove(n):(n.fromNode===this&&(n.fromNode=null),n.toNode===this&&(n.toNode=null))}}}this.labeledLink=null,super.rf()}get isLinkLabel(){return this.zf!==null}get labeledLink(){return this.zf}set labeledLink(t){const e=this.zf;if(e!==t){const i=this.diagram,s=this.data;if(e!==null){if(e.$D(this),i!==null&&s!==null&&!i.undoManager.isUndoingRedoing){const n=e.data,o=i.model;if(n!==null&&o.jh()){const r=o.getKeyForNodeData(s);r!==void 0&&o.removeLabelKeyForLinkData(n,r)}}this.containingGroup=null}if(this.zf=t,t!==null){if(t.JD(this),i!==null&&s!==null&&!i.undoManager.isUndoingRedoing){const n=t.data,o=i.model;if(n!==null&&o.jh()){const r=o.getKeyForNodeData(s);r!==void 0&&o.addLabelKeyForLinkData(n,r)}}this.containingGroup=t.containingGroup}this.kf(),this.t("labeledLink",e,t)}}findVisiblePort(t){let e=t;for(;e!==null&&(!e.actualBounds.isReal()||!e.isVisibleObject());)e=e.panel;return e===null?this.port:e}findPort(t){if(this.hi===null){if(t===""&&this.Ln===!1)return this;this.ZD()}let e=this.hi.get(t);return e!==null||t!==""&&(e=this.hi.get(""),e!==null)?e:this}get port(){return this.findPort("")}get ports(){return this.hi===null&&this.ZD(),this.hi.iteratorValues}ZD(){this.hi===null?this.hi=new GMap:this.hi.clear(),this.walkVisualTreeFrom(this,(t,e)=>t.nD(e)),this.hi.count===0&&this.hi.set("",this)}nD(t){const e=t.portId;e!==null&&this.hi!==null&&this.hi.set(e,t)}FN(t,e){const i=t.portId;if(i!==null){this.hi!==null&&this.hi.delete(i);const s=this.diagram;if(s!==null&&e){let n=null;const o=this.findLinksConnected(i);for(;o.next();){const r=o.value;n===null&&(n=U.ot()),n.push(r)}if(n!==null){for(let r=0;r<n.length;r++){const l=n[r];s.remove(l)}U.Z(n)}}}}isInTreeOf(t){if(t===null||t===this)return!1;let e=!0;const i=this.diagram;i!==null&&(e=i.isTreePathToChildren);let s=this;const n=t;let o;if(e)for(;s!==n;){o=null;const r=s.ee.iterator;for(;r.next();){const l=r.value;if(l.isTreeLink&&(o=l.fromNode,o!==s&&o!==this))break}if(o===this||o===null||o===s)return!1;s=o}else for(;s!==n;){o=null;const r=s.ee.iterator;for(;r.next();){const l=r.value;if(l.isTreeLink&&(o=l.toNode,o!==s&&o!==this))break}if(o===this||o===null||o===s)return!1;s=o}return!0}findTreeRoot(){let t=!0;const e=this.diagram;e!==null&&(t=e.isTreePathToChildren);let i=this,s;if(t)for(;;){s=null;const n=i.ee.iterator;for(;n.next();){const o=n.value;if(o.isTreeLink&&(s=o.fromNode,s!==i&&s!==this))break}if(s===this)return this;if(s===null||s===i)return i;i=s}else for(;;){s=null;const n=i.ee.iterator;for(;n.next();){const o=n.value;if(o.isTreeLink&&(s=o.toNode,s!==i&&s!==this))break}if(s===this)return this;if(s===null||s===i)return i;i=s}}findCommonTreeParent(t){if(t===null)return null;if(this===t)return this;let e=this;for(;e!==null;)e.hk(!0),e=e.findTreeParentNode();let i=null;for(e=t;e!==null;){if(e.GD()){i=e;break}e=e.findTreeParentNode()}for(e=this;e!==null;)e.hk(!1),e=e.findTreeParentNode();return i}findTreeParentLink(){let t=!0;const e=this.diagram;e!==null&&(t=e.isTreePathToChildren);const i=this.ee.iterator;if(t)for(;i.next();){const s=i.value;if(s.isTreeLink&&s.fromNode!==this)return s}else for(;i.next();){const s=i.value;if(s.isTreeLink&&s.toNode!==this)return s}return null}findTreeParentNode(){const t=this.Da;if(t===null)return null;if(t instanceof Node)return t;const e=this.diagram,i=e!==null?e.isTreePathToChildren:!0,s=this.ee.iterator;for(;s.next();){const n=s.value;if(!n.isTreeLink)continue;const o=i?n.fromNode:n.toNode;if(o!==this)return this.Da=o,o}return this.Da=null,null}findTreeParentChain(t){function e(i,s){s.add(i);const n=i.findTreeParentLink();if(n!==null){s.add(n);const o=i.findTreeParentNode();if(o===null)return;e(o,s)}}return t===void 0&&(t=new GSet),e(this,t),t}findTreeLevel(){return this.PE(this)}PE(t){let e=0,i=t.findTreeParentNode();for(;i!==null&&i!==t;)i=i.findTreeParentNode(),e++;return e}findTreeChildrenLinks(){let t=!0;const e=this.diagram;e!==null&&(t=e.isTreePathToChildren);const i=new ListIterator(this.ee),s=this;return t?i.predicate=n=>!(!n.isTreeLink||n.fromNode!==s):i.predicate=n=>!(!n.isTreeLink||n.toNode!==s),i}findTreeChildrenNodes(){let t=!0;const e=this.diagram;e!==null&&(t=e.isTreePathToChildren);let i=null,s=null;const n=this.ee.iterator;if(t)for(;n.next();){const o=n.value;if(o.isTreeLink&&o.fromNode===this){const r=o.toNode;i!==null?i.add(r):s!==null&&s!==r?(i=new List,i.add(s),i.add(r)):s=r}}else for(;n.next();){const o=n.value;if(o.isTreeLink&&o.toNode===this){const r=o.fromNode;i!==null?i.add(r):s!==null&&s!==r?(i=new List,i.add(s),i.add(r)):s=r}}return i!==null?i.iterator:s!==null?new SingletonIterator(s):EmptyIterator.instance}findTreeParts(t,e){return t===void 0&&(t=1/0),U.s(t,"number",Node,"findTreeParts:level"),e===void 0&&(e=new GSet),Part.ga(e,this,!1,t,!0),e}collapseTree(t){t===void 0&&(t=1),t<1&&(t=1);const e=this.diagram;if(e===null||e.isCollapsingExpanding)return;e.isCollapsingExpanding=!0;const i=new GSet;i.add(this),this.QD(i,e.isTreePathToChildren,t,e,this,e.treeCollapsePolicy===1),e.isCollapsingExpanding=!1}QD(t,e,i,s,n,o){if(i>1){const r=e?this.findLinksOutOf():this.findLinksInto();for(;r.next();){const l=r.value;if(!l.isTreeLink)continue;const a=l.getOtherNode(this);a!==null&&a!==this&&!t.has(a)&&(t.add(a),a.QD(t,e,i-1,s,n,o))}}else this._D(t,e,s,n,o)}_D(t,e,i,s,n){const o=s===this?!0:this.isTreeExpanded,r=e?this.findLinksOutOf():this.findLinksInto();for(;r.next();){const l=r.value;if(!l.isTreeLink)continue;const a=l.getOtherNode(this);if(a!==null&&a!==this){const h=t.has(a);if(h||t.add(a),o){const c=e?a.findNodesInto():a.findNodesOutOf(),f=this;c.all(u=>u===f||!u.isTreeExpanded)&&i.Yc(a,s),a.Sa(),a.Xe(!1)}a.isTreeExpanded&&(a.wasTreeExpanded=a.isTreeExpanded,h||a._D(t,e,i,s,n))}}this.isTreeExpanded=!1}expandTree(t){t===void 0&&(t=2),t<2&&(t=2);const e=this.diagram;if(e===null||e.isCollapsingExpanding)return;e.isCollapsingExpanding=!0;const i=new GSet;i.add(this),this.tv(i,e.isTreePathToChildren,t,e,this,e.treeCollapsePolicy===1),e.isCollapsingExpanding=!1}tv(t,e,i,s,n,o){const r=n===this?!1:this.isTreeExpanded,l=e?this.findLinksOutOf():this.findLinksInto();for(;l.next();){const a=l.value;if(!a.isTreeLink)continue;r||a.Fi||a.$t();const h=a.getOtherNode(this);if(h!==null&&h!==this&&!t.has(h)){if(t.add(h),!r){h.Xe(!0),h.Sa();const c=e?h.findNodesInto():h.findNodesOutOf(),f=this;c.all(u=>u===f||!u.isTreeExpanded)&&s.Gc(h,n)}(i>2||h.wasTreeExpanded)&&(h.wasTreeExpanded=!1,h.tv(t,e,i-1,s,n,o))}}this.isTreeExpanded=!0}get isTreeExpanded(){return(this.E&1)!==0}set isTreeExpanded(t){const e=(this.E&1)!==0;if(e!==t){this.E=this.E^1;const i=this.diagram;this.t("isTreeExpanded",e,t);const s=this.treeExpandedChanged;if(s!==null){let n=!0;i!==null&&(n=i.G,i.G=!0),s(this),i!==null&&(i.G=n)}if(i!==null&&i.undoManager.isUndoingRedoing){this.Xe(t);return}t?this.expandTree():this.collapseTree()}}get wasTreeExpanded(){return(this.E&2)!==0}set wasTreeExpanded(t){const e=(this.E&2)!==0;e!==t&&(this.E=this.E^2,this.t("wasTreeExpanded",e,t))}get treeExpandedChanged(){return this.vt!==null?this.vt.jy:null}set treeExpandedChanged(t){const e=this.treeExpandedChanged;e!==t&&(t!==null&&U.S(t,Node,"treeExpandedChanged"),this.wl().jy=t,this.t("treeExpandedChanged",e,t))}get isTreeLeaf(){return(this.E&4)!==0}set isTreeLeaf(t){const e=(this.E&4)!==0;e!==t&&(this.E=this.E^4,this.t("isTreeLeaf",e,t))}get isTreeRoot(){return this.findTreeParentLink()===null}}class NodeTemplateSettings{me;Ky;Hy;El;jy;Yy;Gy;qy;Wy;da;Jy;constructor(){this.me=!1,this.Ky=null,this.Hy=null,this.El=null,this.jy=null,this.Yy=Margin.BL,this.Gy=1,this.qy=null,this.Wy=null,this.da=null,this.Jy=null}copy(){const t=new NodeTemplateSettings;return t.Ky=this.Ky,t.Hy=this.Hy,t.El=this.El,t.jy=this.jy,t.Yy=this.Yy.N(),t.Gy=this.Gy,t.qy=this.qy,t.Wy=this.Wy,t.da=this.da,t.Jy=this.Jy,t}}var LinkAdjusting=(w=>(w[w.None=0]="None",w[w.End=17]="End",w[w.Scale=18]="Scale",w[w.Stretch=19]="Stretch",w))(LinkAdjusting||{}),Routing=(w=>(w[w.Normal=1]="Normal",w[w.Orthogonal=2]="Orthogonal",w[w.AvoidsNodes=6]="AvoidsNodes",w[w.AvoidsNodesStraight=7]="AvoidsNodesStraight",w))(Routing||{}),Curve=(w=>(w[w.None=0]="None",w[w.Bezier=9]="Bezier",w[w.JumpGap=10]="JumpGap",w[w.JumpOver=11]="JumpOver",w))(Curve||{});class Link extends Part{Nt;po;yo;Jd;wo;xo;$d;Xf;Zd;Qd;_d;qh;tg;on;Me;xl;vr;Gf;ir;wC;xC;dk;bC;kC;Wh;gk;ut;sr;static Jh=null;static $h=null;Lf;PC;SC;constructor(t){super(Panel.Link),this.Nt=8,this.po=null,this.yo="",this.Jd=null,this.wo=null,this.xo="",this.$d=null,this.Xf=0,this.Zd=0,this.Qd=0,this._d=NaN,this.qh=1,this.tg=.5,this.on=null,this.Me=new List().b(),this.xl=null,this.vr=null,this.Gf=new Rect,this.ut=new Geometry,this.ir=null,this.sr=null,this.wC=Point.mn,this.xC=Point.mn,this.PC=0,this.SC=0,this.dk=new Point,this.bC=null,this.kC=null,this.Wh=null,this.gk=NaN,this.ft=null,this.Lf=[],t&&Object.assign(this,t)}cloneProtected(t){super.cloneProtected(t),t.Nt=this.Nt&-113,t.yo=this.yo,t.Jd=this.Jd,t.xo=this.xo,t.$d=this.$d,t.Xf=this.Xf,t.Zd=this.Zd,t.Qd=this.Qd,t._d=this._d,t.qh=this.qh,t.tg=this.tg,this.ft!==null&&(t.ft=this.ft.copy())}jo(t){super.jo(t),this.yo=t.yo,this.xo=t.xo,t.xl=null,t.$t(),t.sr=this.sr;const e=t.fromPort;e!==null&&t.fromNode.Pi(e);const i=t.toPort;i!==null&&t.toNode.Pi(i)}fe(t){t in Routing||t in Curve||t in LinkAdjusting?Link.MC(t)?this.routing=t:t===9||t===10||t===11?this.curve=t:t===17||t===18||t===19?this.adjusting=t:t===1||t===0||U.o("Unknown Link enum value for a Link property: "+t):super.fe(t)}static Normal=1;static Orthogonal=2;static AvoidsNodes=6;static AvoidsNodesStraight=7;static None=0;static Bezier=9;static JumpGap=10;static JumpOver=11;static End=17;static Scale=18;static Stretch=19;static OrientAlong=21;static OrientPlus90=22;static OrientMinus90=23;static OrientOpposite=24;static OrientUpright=25;static OrientPlus90Upright=26;static OrientMinus90Upright=27;static OrientUpright45=28;static ev=8;static iv=16;static va=8;static W1=3;static sv=3;static nv=1.333;static NC=1;static CC=0;static ov=10;static Yf=9999;static rv=30;static lv=30;static LC=10;static av=10;static hv=14;static cv=30;static fv=14;static _A=8;static tT=8;static uv=11;static setRoutingParameter(t,e){switch(t){case 1:Link.ev=e;break;case 2:Link.iv=e;break;case 3:Link.va=e;break;case 4:Link.W1=e;break;case 5:Link.sv=e;break;case 6:Link.nv=e;break;case 7:Link.NC=e;break;case 8:Link.CC=e;break;case 9:Link.ov=e;break;case 10:Link.Yf=e;break;case 11:Link.rv=e;break;case 12:Link.lv=e;break;case 13:Link.LC=e;break;case 14:Link.av=e;break;case 15:Link.hv=e;break;case 16:Link.cv=e;break;case 17:Link.fv=e;break;case 18:Link._A=e;break;case 19:Link.tT=e;break;case 20:Link.uv=e;break}t>29&&t<71&&(Link.IT=t+parseInt(e.toString().slice(0,-1)))}static IT;Ji(){return this.ft===null&&(this.ft=new LinkSettings),this.ft}OI(t,e,i){const s=t.segmentIndex,n=t.segmentFraction;let o=t.alignmentFocus;const r=t.segmentOrientation,l=t.segmentOffset;let a=0,h=0,c=0,f=0;if(isNaN(s)){const C=this.ut,M=U.ot();C.getPointAndAngleAlongPath(n,M);const N=Point.z(M[0],M[1]);if(f=M[2],N.add(this.getPoint(0)),C.type===1)N.offset(-C.startX,-C.startY);else{const T=C.figures.first();N.offset(-T.startX,-T.startY)}r!==0&&(c=this.computeAngle(t,r,f),t.angle=c),a=N.x,h=N.y,Point.i(N),U.Z(M)}else if(s<-e||s>=e){const C=Point.l();this.HN(C),f=this.midAngle,r!==0&&(c=this.computeAngle(t,r,f),t.angle=c),a=C.x,h=C.y,Point.i(C)}else{let C,M,N=0;if(s>=0?(C=i.r[s],M=s<e-1?i.r[s+1]:C):(N=e+s,C=i.r[N],M=N>0?i.r[N-1]:C),C.equalsApprox(M)){let T,A;s>=0?(T=s>0?i.r[s-1]:C,A=s<e-2?i.r[s+2]:M):(T=N<e-1?i.r[N+1]:C,A=N>1?i.r[N-2]:M);const D=T.distanceSquaredPoint(C),v=M.distanceSquaredPoint(A);D>v+10?f=s>=0?T.directionPoint(C):C.directionPoint(T):v>D+10?f=s>=0?M.directionPoint(A):A.directionPoint(M):f=s>=0?T.directionPoint(A):A.directionPoint(T)}else f=s>=0?C.directionPoint(M):M.directionPoint(C);r!==0&&(c=this.computeAngle(t,r,f),t.angle=c),a=C.x+(M.x-C.x)*n,h=C.y+(M.y-C.y)*n}if(o.isNone()){t.moveTo(a,h,!0);return}else o.isNoSpot()&&(o=Spot.Center);const u=Transform.l();u.Ue(),u.it(t.scale,t.scale),u.ks(t.angle,0,0);const d=t.naturalBounds,m=Rect.z(0,0,d.width,d.height),g=Point.l();g.setRectSpot(m,o),u.gt(g);let p=-g.x,y=-g.y;const x=d.width,k=d.height,b=Point.bs(l),P=isNaN(l.x),S=isNaN(l.y);if(P||S){const C=x/2+Link.W1,M=k/2+Link.sv,N=f>=45&&f<=135,T=f>=225&&f<=315;r===0&&(N||T)?(b.x=S?C:l.y,b.y=P?M:l.x,N?s>=0||isNaN(s)&&n<.5||P&&(b.y=-M):T&&((s>=0||isNaN(s)&&n<.5)&&P&&(b.y=-M),S&&(b.x=-C))):(P&&(s>=0||isNaN(s)&&n<.5?b.x=C:b.x=-C),S&&(b.y=-M),b.rotate(f))}else b.rotate(f);a+=b.x,h+=b.y,u.im(m),p+=m.x,y+=m.y;const L=Point.z(a+p,h+y);t.move(L),Point.i(L),Point.i(b),Point.i(g),Rect.i(m),Transform.i(u)}_r(){let t=this.fromNode;if(t!==null){const i=t.findVisibleNode();if(i!==null&&(t=i),t.as()||t.fa())return!1}let e=this.toNode;if(e!==null){const i=e.findVisibleNode();if(i!==null&&(e=i),e.as()||e.fa())return!1}return!0}DN(t,e,i){return!1}vN(){}Di(){return!1}computeAngle(t,e,i){return Link.computeAngle(e,i)}static computeAngle(t,e){let i=0;switch(t){default:case 0:i=0;break;case 21:i=e;break;case 22:i=e+90;break;case 23:i=e-90;break;case 24:i=e+180;break;case 25:i=G.Ee(e),i>90&&i<270&&(i-=180);break;case 26:i=G.Ee(e+90),i>90&&i<270&&(i-=180);break;case 27:i=G.Ee(e-90),i>90&&i<270&&(i-=180);break;case 28:if(i=G.Ee(e),i>45&&i<135||i>225&&i<315)return 0;i>90&&i<270&&(i-=180);break}return G.Ee(i)}get fromNode(){return this.po}set fromNode(t){const e=this.po;if(e!==t){const i=this.fromPort;e!==null&&(this.wo!==e&&e.uk(this,i),this.$y(),this.invalidateLayout(2)),this.po=t,t!==null&&this.Xe(t.isVisible()),this.ir=null,this.$t();const s=this.diagram;s!==null&&s.G&&s.partManager.setFromNodeForLink(this,t,e);const n=this.fromPort,o=this.fromPortChanged;if(o!==null){let r=!0;s!==null&&(r=s.G,s.G=!0),o(this,i,n),s!==null&&(s.G=r)}t!==null&&(this.wo!==t&&t.fk(this,n),this.Zy(),this.invalidateLayout(1)),this.t("fromNode",e,t),this.qd()}}get fromPortId(){return this.yo}set fromPortId(t){const e=this.yo;if(e!==t){const i=this.fromPort;i!==null&&this.fromNode?.Pi(i),this.$y(),this.yo=t;const s=this.fromPort;s!==null&&this.fromNode?.Pi(s);const n=this.diagram;if(n!==null){const o=this.data,r=n.model;o!==null&&r.jh()&&r.setFromPortIdForLinkData(o,t)}if(i!==s){this.ir=null,this.$t();const o=this.fromPortChanged;if(o!==null){let r=!0;n!==null&&(r=n.G,n.G=!0),o(this,i,s),n!==null&&(n.G=r)}}this.Zy(),this.t("fromPortId",e,t)}}get fromPort(){const t=this.po;if(t===null)return null;const e=this.yo;return t.findPort(e)}get fromPortChanged(){return this.Jd}set fromPortChanged(t){const e=this.Jd;e!==t&&(t!==null&&U.S(t,Link,"fromPortChanged"),this.Jd=t,this.t("fromPortChanged",e,t))}get toNode(){return this.wo}set toNode(t){const e=this.wo;if(e!==t){const i=this.toPort;e!==null&&(this.po!==e&&e.uk(this,i),this.$y(),this.invalidateLayout(2)),this.wo=t,t!==null&&this.Xe(t.isVisible()),this.ir=null,this.$t();const s=this.diagram;s!==null&&s.G&&s.partManager.setToNodeForLink(this,t,e);const n=this.toPort,o=this.toPortChanged;if(o!==null){let r=!0;s!==null&&(r=s.G,s.G=!0),o(this,i,n),s!==null&&(s.G=r)}t!==null&&(this.po!==t&&t.fk(this,n),this.Zy(),this.invalidateLayout(1)),this.t("toNode",e,t),this.qd()}}get toPortId(){return this.xo}set toPortId(t){const e=this.xo;if(e!==t){const i=this.toPort;i!==null&&this.toNode?.Pi(i),this.$y(),this.xo=t;const s=this.toPort;s!==null&&this.toNode?.Pi(s);const n=this.diagram;if(n!==null){const o=this.data,r=n.model;o!==null&&r.jh()&&r.setToPortIdForLinkData(o,t)}if(i!==s){this.ir=null,this.$t();const o=this.toPortChanged;if(o!==null){let r=!0;n!==null&&(r=n.G,n.G=!0),o(this,i,s),n!==null&&(n.G=r)}}this.Zy(),this.t("toPortId",e,t)}}get toPort(){const t=this.wo;if(t===null)return null;const e=this.xo;return t.findPort(e)}get toPortChanged(){return this.$d}set toPortChanged(t){const e=this.$d;e!==t&&(t!==null&&U.S(t,Link,"toPortChanged"),this.$d=t,this.t("toPortChanged",e,t))}get fromSpot(){return this.ft!==null?this.ft.Ah:Spot.Default}set fromSpot(t){const e=this.fromSpot;if(!e.equals(t)){if(t=t.N(),this.Ji().Ah=t,this.t("fromSpot",e,t),e.isSide()||t.isSide()){const i=this.fromNode;i!==null&&i.Pi(this.fromPort)}this.$t()}}get fromEndSegmentLength(){return this.ft!==null?this.ft.Dh:NaN}set fromEndSegmentLength(t){const e=this.fromEndSegmentLength;if(e!==t){if(t<0&&U.J(t,">= 0",Link,"fromEndSegmentLength"),this.Ji().Dh=t,this.t("fromEndSegmentLength",e,t),this.computeSpot(!0,this.fromPort).isSide()){const i=this.fromNode;i!==null&&i.Pi(this.fromPort)}this.$t()}}get fromShortLength(){return this.ft!==null?this.ft.Fh:NaN}set fromShortLength(t){const e=this.fromShortLength;e!==t&&(this.Ji().Fh=t,this.Ze(),this.t("fromShortLength",e,t))}get toSpot(){return this.ft!==null?this.ft.Th:Spot.Default}set toSpot(t){const e=this.toSpot;if(!e.equals(t)){if(t=t.N(),this.Ji().Th=t,this.t("toSpot",e,t),e.isSide()||t.isSide()){const i=this.toNode;i!==null&&i.Pi(this.toPort)}this.$t()}}get toEndSegmentLength(){return this.ft!==null?this.ft.vh:NaN}set toEndSegmentLength(t){const e=this.toEndSegmentLength;if(e!==t){if(t<0&&U.J(t,">= 0",Link,"toEndSegmentLength"),this.Ji().vh=t,this.t("toEndSegmentLength",e,t),this.computeSpot(!1,this.toPort).isSide()){const i=this.toNode;i!==null&&i.Pi(this.toPort)}this.$t()}}get toShortLength(){return this.ft!==null?this.ft.Rh:NaN}set toShortLength(t){const e=this.toShortLength;e!==t&&(this.Ji().Rh=t,this.Ze(),this.t("toShortLength",e,t))}qd(){const t=this.fromNode,e=this.toNode;let i=null;if(t!==null?e!==null?i=t.findCommonContainingGroup(e):i=t.containingGroup:e!==null?i=e.containingGroup:i=null,this.SE(i),this.isLabeledLink){const s=this.labelNodes;for(;s.next();){const n=s.value;n.containingGroup=i}}}SE(t){const e=this.Ta;if(e!==t){e!==null&&e.fC(this),this.Ta=t,t!==null&&t.uC(this);const i=this.containingGroupChanged;if(i!==null){let s=!0;const n=this.diagram;n!==null&&(s=n.G,n.G=!0),i(this,e,t),n!==null&&(n.G=s)}this.Fi&&(this.bC===e||this.kC===e)&&this.$t()}}Sa(){const t=this.containingGroup;t!==null&&this.fromNode!==t&&this.toNode!==t&&t.computesBoundsIncludingLinks&&super.Sa()}getOtherNode(t){const e=this.fromNode;return t===e?this.toNode:e}getOtherPort(t){const e=this.fromPort;return t===e?this.toPort:e}get isLabeledLink(){return this.on===null?!1:this.on.count>0}get labelNodes(){return this.on===null?EmptyIterator.instance:this.on.iterator}JD(t){this.on===null&&(this.on=new GSet),this.on.add(t),this.c()}$D(t){this.on!==null&&(this.on.delete(t),this.c())}_m(t){if(super._m(t),this.Zh()&&this.invalidateOtherJumpOvers(this.actualBounds),!t){const e=this.po;let i=null;e!==null&&(i=this.fromPort,e.fk(this,i));const s=this.wo;let n=null;s!==null&&(n=this.toPort,(s!==e||n!==i)&&s.fk(this,n)),this.Zy()}}tp(t){if(super.tp(t),this.Zh()&&this.invalidateOtherJumpOvers(this.actualBounds),!t){const e=this.po;let i=null;e!==null&&(i=this.fromPort,e.uk(this,i));const s=this.wo;let n=null;s!==null&&(n=this.toPort,(s!==e||n!==i)&&s.uk(this,n)),this.$y()}}rf(){if(this.Fi=!0,this.on!==null){const e=this.diagram;if(e!==null){const s=this.on.copy().iterator;for(;s.next();){const n=s.value;e.remove(n)}}}if(this.data!==null){const e=this.diagram;e!==null&&e.partManager.AC(this)}}updateRelationshipsFromData(){if(this.data===null)return;const e=this.diagram;e!==null&&e.partManager.updateRelationshipsFromData(this)}move(t,e){const i=e?this.location:this.position;let s=i.x;isNaN(s)&&(s=0);let n=i.y;isNaN(n)&&(n=0);const o=t.x-s,r=t.y-n;if(e===!0)super.move(t,!1);else{const a=Point.z(i.x+o,i.y+r);super.move(a,!1),Point.i(a)}this.Pr(o,r);const l=this.labelNodes;for(;l.next();){const a=l.value,h=a.position;a.moveTo(h.x+o,h.y+r)}}get relinkableFrom(){return(this.Nt&1)!==0}set relinkableFrom(t){const e=(this.Nt&1)!==0;e!==t&&(this.Nt=this.Nt^1,this.t("relinkableFrom",e,t),this.invalidateAdornments())}get relinkableTo(){return(this.Nt&2)!==0}set relinkableTo(t){const e=(this.Nt&2)!==0;e!==t&&(this.Nt=this.Nt^2,this.t("relinkableTo",e,t),this.invalidateAdornments())}canRelinkFrom(){if(!this.relinkableFrom)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowRelink)return!1;const e=t.diagram;return!(e!==null&&!e.allowRelink)}canRelinkTo(){if(!this.relinkableTo)return!1;const t=this.layer;if(t===null)return!0;if(!t.allowRelink)return!1;const e=t.diagram;return!(e!==null&&!e.allowRelink)}get resegmentable(){return(this.Nt&4)!==0}set resegmentable(t){const e=(this.Nt&4)!==0;e!==t&&(this.Nt=this.Nt^4,this.t("resegmentable",e,t),this.invalidateAdornments())}get isTreeLink(){return(this.Nt&8)!==0}set isTreeLink(t){const e=(this.Nt&8)!==0;e!==t&&(this.Nt=this.Nt^8,this.t("isTreeLink",e,t),this.fromNode!==null&&this.fromNode.Dp(),this.toNode!==null&&this.toNode.Dp())}get path(){const t=this.findMainElement();return t instanceof Shape?t:null}get routeBounds(){return this.updateRoute(),this.ME(this.Gf)}ME(t){let e=1/0,i=1/0;const s=this.pointsCount;if(s===0)return t.e(NaN,NaN,0,0),t;if(s===1){const n=this.getPoint(0);e=Math.min(n.x,e),i=Math.min(n.y,i),t.e(n.x,n.y,0,0)}else if(s===2){const n=this.getPoint(0),o=this.getPoint(1);e=Math.min(n.x,o.x),i=Math.min(n.y,o.y),t.e(n.x,n.y,0,0),t.unionPoint(o)}else if(this.computeCurve()===9&&s>=3&&!this.isOrthogonal){let n=this.getPoint(0);if(e=n.x,i=n.y,t.e(e,i,0,0),s===3){const o=this.getPoint(1);e=Math.min(o.x,e),i=Math.min(o.y,i);const r=this.getPoint(2);e=Math.min(r.x,e),i=Math.min(r.y,i),G.Nu(n.x,n.y,o.x,o.y,o.x,o.y,r.x,r.y,.5,t)}else for(let o=3;o<s;o+=3){const r=this.getPoint(o-2);o+3>=s&&(o=s-1);const l=this.getPoint(o-1),a=this.getPoint(o);G.Nu(n.x,n.y,r.x,r.y,l.x,l.y,a.x,a.y,.5,t),e=Math.min(a.x,e),i=Math.min(a.y,i),n=a}}else{const n=this.getPoint(0),o=this.getPoint(1);e=Math.min(n.x,o.x),i=Math.min(n.y,o.y),t.e(n.x,n.y,0,0),t.unionPoint(o);for(let r=2;r<s;r++){const l=this.getPoint(r);e=Math.min(l.x,e),i=Math.min(l.y,i),t.unionPoint(l)}}return this.dk.e(e-t.x,i-t.y),t}get midPoint(){return this.HN(new Point)}HN(t){return this.updateRoute(),this.computeMidPoint(t)}computeMidPoint(t){const e=this.pointsCount;if(e===0)return t.h(Point.mn),t;if(e===1)return t.h(this.getPoint(0)),t;if(e===2){const h=this.getPoint(0),c=this.getPoint(1);return t.e((h.x+c.x)/2,(h.y+c.y)/2),t}if(this.isOrthogonal&&(this.computeCorner()>=15||this.computeCurve()===9)){this.ut.getPointAlongPath(.5,t),t.add(this.getPoint(0));const h=this.ut.figures.first();return t.offset(-h.startX,-h.startY),t}if(this.computeCurve()===9){if(e===3){const f=this.getPoint(0),u=this.getPoint(1),d=this.getPoint(2);return G.YL(f.x,f.y,u.x,u.y,u.x,u.y,d.x,d.y,t),t}const h=(e-1)/3|0,c=(h/2|0)*3;if(h%2===1){const f=this.getPoint(c),u=this.getPoint(c+1),d=this.getPoint(c+2),m=this.getPoint(c+3);return G.YL(f.x,f.y,u.x,u.y,d.x,d.y,m.x,m.y,t),t}else return t.h(this.getPoint(c)),t}const i=this.flattenedLengths,s=this.flattenedTotalLength;let n=0,o=0,r=0;for(;n<s/2&&o<e&&(r=i[o],!(n+r>s/2));)n+=r,o++;const l=this.getPoint(o),a=this.getPoint(o+1);if(Math.abs(l.x-a.x)<1)l.y>a.y?t.e(l.x,l.y-(s/2-n)):t.e(l.x,l.y+(s/2-n));else if(Math.abs(l.y-a.y)<1)l.x>a.x?t.e(l.x-(s/2-n),l.y):t.e(l.x+(s/2-n),l.y);else{const h=(s/2-n)/r,c=h*(a.x-l.x),f=h*(a.y-l.y);t.e(l.x+c,l.y+f)}return t}get midAngle(){return this.updateRoute(),this.computeMidAngle()}computeMidAngle(){const t=this.pointsCount;if(t<2)return NaN;if(t===2){const a=this.getPoint(0),h=this.getPoint(1);return a.directionPoint(h)}if(this.isOrthogonal&&(this.computeCorner()>=15||this.computeCurve()===9))return this.ut.getAngleAlongPath(.5);if(this.computeCurve()===9&&t>=4){const a=(t-1)/3|0;let h=(a/2|0)*3;if(a%2===1){h=Math.floor(h);const c=this.getPoint(h),f=this.getPoint(h+1),u=this.getPoint(h+2),d=this.getPoint(h+3);return G.HF(c.x,c.y,f.x,f.y,u.x,u.y,d.x,d.y)}else if(h>0&&h+1<t){const c=this.getPoint(h-1),f=this.getPoint(h+1);return c.directionPoint(f)}}const e=this.flattenedLengths,i=this.flattenedTotalLength;let s=0,n=0,o=0;for(;s<i/2&&n<t&&(o=e[n],!(s+o>i/2));)s+=o,n++;const r=this.getPoint(n),l=this.getPoint(n+1);if(Math.abs(r.x-l.x)<.5&&Math.abs(r.y-l.y)<Link.NC){if(n>0&&n<t-2){const a=this.getPoint(n-1),h=this.getPoint(n+2);return a.x<h.x?0:a.x>h.x?180:a.y<h.y?90:270}}else if(Math.abs(r.y-l.y)<.5&&Math.abs(r.x-l.x)<Link.NC&&n>0&&n<t-2){const a=this.getPoint(n-1),h=this.getPoint(n+2);return a.y<h.y?90:a.y>h.y?270:a.x<h.x?0:180}return r.directionPoint(l)}get flattenedLengths(){return this.Wh!==null?this.Wh:(this.Fi||this.mk(),this.NE())}get flattenedTotalLength(){let t=this.gk;if(isNaN(t)){const e=this.flattenedLengths,i=e.length;t=0;for(let s=0;s<i;s++)t+=e[s];this.gk=t}return t}NE(){this.Wh===null?this.Wh=[]:this.Wh.length=0;const t=this.Wh,e=this.pointsCount;for(let i=0;i<e-1;i++){let s=0;const n=this.getPoint(i),o=this.getPoint(i+1);G.X(n.x,o.x)?(s=o.y-n.y,s<0&&(s=-s),t.push(s)):G.X(n.y,o.y)?(s=o.x-n.x,s<0&&(s=-s),t.push(s)):(s=Math.sqrt(n.distanceSquaredPoint(o)),t.push(s))}return t}get points(){return this.Me}set points(t){const e=this.Me;if(e===t)return;let i=null;if(Array.isArray(t))i=this.convertPointsArrayToList(t);else if(t instanceof List){i=t.copy();const n=i.iterator;for(;n.next();)n.value.b()}else U.o("Link.points value is not an instance of List or Array: "+t);if(i===null)return;i.b(),this.Me=i,this.Ze(),this.mk();const s=this.diagram;s!==null&&(!s.$a&&!s.undoManager.isUndoingRedoing&&s.sb.add(this),s.animationManager.ke&&s.animationManager.LM(this,i)),this.t("points",e,i)}convertPointsArrayToList(t){let e=null,i=t.length%2===0;if(i){for(let s=0;s<t.length;s++)if(typeof t[s]!="number"||isNaN(t[s])){i=!1;break}}if(i){e=new List;for(let s=0;s<t.length/2;s++)e.add(new Point(t[s*2],t[s*2+1]).b())}else{let s=!0;for(let n=0;n<t.length;n++){const o=t[n];if(!U.$(o)||typeof o.x!="number"||isNaN(o.x)||typeof o.y!="number"||isNaN(o.y)){s=!1;break}}if(s){e=new List;for(let n=0;n<t.length;n++){const o=t[n];e.add(new Point(o.x,o.y).b())}}}return e}get pointsCount(){return this.Me.count}getPoint(t){return this.Me.r[t]}setPoint(t,e){this.Me.setElt(t,e)}setPointAt(t,e,i){this.Me.setElt(t,new Point(e,i))}insertPoint(t,e){this.Me.insertAt(t,e)}insertPointAt(t,e,i){this.Me.insertAt(t,new Point(e,i))}addPoint(t){this.Me.add(t)}addPointAt(t,e){this.Me.add(new Point(t,e))}removePoint(t){this.Me.removeAt(t)}clearPoints(){this.Me.clear()}Pr(t,e){if(t===0&&e===0)return;if(this.pointsCount===0){this.defaultFromPoint.isReal()&&this.defaultFromPoint.offset(t,e),this.defaultToPoint.isReal()&&this.defaultToPoint.offset(t,e);return}const i=this.Fi,s=new List,n=this.Me.iterator;for(;n.next();){const l=n.value;s.add(new Point(l.x+t,l.y+e).b())}s.b();const o=this.Me;this.Me=s;const r=this.diagram;isNaN(t)||isNaN(e)||r!==null&&r.animationManager.ke?this.c():(this.nn.e(this.nn.x+t,this.nn.y+e),this.ct.e(this.ct.x+t,this.ct.y+e),this.kf()),i?this.mk():(this.defaultFromPoint.isReal()&&(this.defaultFromPoint=this.getPoint(0)),this.defaultToPoint.isReal()&&(this.defaultToPoint=this.getPoint(this.pointsCount-1))),r!==null&&r.animationManager.ke&&r.animationManager.LM(this,s),this.t("points",o,s)}startRoute(){this.xl===null&&(this.xl=this.Me,this.Me=this.Me.copy())}commitRoute(){if(this.xl===null)return;const t=this.xl,e=this.Me;let i=1/0,s=1/0;const n=t.r,o=n.length;for(let f=0;f<o;f++){const u=n[f];i=Math.min(u.x,i),s=Math.min(u.y,s)}let r=1/0,l=1/0;const a=e.r,h=a.length;for(let f=0;f<h;f++){const u=a[f];r=Math.min(u.x,r),l=Math.min(u.y,l),u.b()}if(e.b(),h===o)for(let f=0;f<h;f++){const u=n[f],d=a[f];if(u.x-i!==d.x-r||u.y-s!==d.y-l){this.Ze();break}}else this.Ze();this.xl=null;const c=this.diagram;c!==null&&c.animationManager.ke&&c.animationManager.LM(this,e),this.mk(),this.t("points",t,e)}rollbackRoute(){this.xl!==null&&(this.Me=this.xl,this.xl=null)}DR(){this.vr!==null&&(this.points=this.vr,this.vr=null)}mk(){if(this.Me.count===0){this.Fi=!1;return}this.Fi=!0,this.Wh=null,this.gk=NaN,this.defaultFromPoint=this.getPoint(0),this.defaultToPoint=this.getPoint(this.pointsCount-1),this.pk(!1)}invalidateRoute(){this.$t()}$t(){if(this.suspendsRouting)return;const t=this.path;if(t===null)return;const e=this.diagram;if(e){if(e.sb.has(this)||e.undoManager.isUndoingRedoing)return;const i=e.animationManager;if(i.isTicking&&!i.isAnimating)return;this.vr!==null&&!i.isTicking&&(this.vr=null)}this.Fi=!1,this.c(),t.c()}get Fi(){return(this.Nt&16)!==0}set Fi(t){(this.Nt&16)!==0!==t&&(this.Nt=this.Nt^16)}get suspendsRouting(){return(this.Nt&32)!==0}set suspendsRouting(t){(this.Nt&32)!==0!==t&&(this.Nt=this.Nt^32)}get Qy(){return(this.Nt&64)!==0}set Qy(t){(this.Nt&64)!==0!==t&&(this.Nt=this.Nt^64)}get TC(){return(this.Nt&512)!==0}set TC(t){(this.Nt&512)!==0!==t&&(this.Nt=this.Nt^512)}get defaultFromPoint(){return this.wC}set defaultFromPoint(t){this.wC=t&&t.isReal()?t.copy():Point.mn}get defaultToPoint(){return this.xC}set defaultToPoint(t){this.xC=t&&t.isReal()?t.copy():Point.mn}updateRoute(){if(this.Fi||this.Qy)return;let t=!0;try{this.Qy=!0,this.startRoute(),t=this.computePoints()}catch{this.Qy=!1,this.rollbackRoute()}finally{this.Qy=!1,t?this.commitRoute():this.rollbackRoute()}}computePoints(){const t=this.diagram;if(t===null)return!1;let e=this.fromNode,i=null;if(e===null?(Link.Jh||(Link.Jh=new Node,Link.Jh.desiredSize=Size.xc,Link.Jh.ensureBounds()),this.defaultFromPoint.isReal()&&(Link.Jh.location=this.defaultFromPoint,Link.Jh.ensureBounds(),e=Link.Jh,i=Link.Jh)):i=this.fromPort,i!==null&&!e.isVisible()){const m=e.findVisibleNode();m!==null&&m!==e?(e=m,i=m.port):e=m}if(this.bC=e,e===null||!e.location.isReal()||i===null||(i=e.findVisiblePort(i),i===null))return!1;let s=this.toNode,n=null;if(s===null?(Link.$h||(Link.$h=new Node,Link.$h.desiredSize=Size.xc,Link.$h.ensureBounds()),this.defaultToPoint.isReal()&&(Link.$h.location=this.defaultToPoint,Link.$h.ensureBounds(),s=Link.$h,n=Link.$h)):n=this.toPort,n!==null&&!s.isVisible()){const m=s.findVisibleNode();m!==null&&m!==s?(s=m,n=m.port):s=m}if(this.kC=s,s===null||!s.location.isReal()||n===null||(n=s.findVisiblePort(n),n===null))return!1;const o=this.pointsCount,r=this.computeSpot(!0,i),l=this.computeSpot(!1,n),a=this.Qh(r),h=this.Qh(l),c=i===n&&i!==null,f=this.isOrthogonal;let u=this.curve===9;c&&!f?(u=!0,this.ir=!0):this.ir=!1;const d=this.computeAdjusting()===0||c;if(!f&&!c&&a&&h){let m=!1;if(!d&&o>=3){let g=this.getLinkPoint(e,i,r,!0,!1,s,n),p=this.getLinkPoint(s,n,l,!1,!1,e,i);m=this.adjustPoints(0,g,o-1,p),m&&(g=this.getLinkPoint(e,i,r,!0,!1,s,n),p=this.getLinkPoint(s,n,l,!1,!1,e,i),this.adjustPoints(0,g,o-1,p))}m||(this.clearPoints(),u?this.CE(e,i,r,s,n,l):this.LE(e,i,r,s,n,l))}else{const m=c?this.computeCurviness():0;d&&(f&&this.isAvoiding||c)&&this.clearPoints();const g=this.getLinkPoint(e,i,r,!0,f,s,n),p=this.getLinkPoint(s,n,l,!1,f,e,i);let y=0,x=0,k=0;if(f||!a||c){k=this.getLinkDirection(e,i,g,r,!0,f,s,n);let M=this.yk(e,i,r,!0,k);if(c&&(a||r.equals(l)||!f&&r.x+l.x===1&&r.y+l.y===1)&&(k-=f?90:Link.rv,m<0&&(k-=180)),k=G.Ee(k),c&&(M+=Math.abs(m)*(f?1:2)),k===0?y=M:k===90?x=M:k===180?y=-M:k===270?x=-M:(y=M*Math.cos(k*Math.PI/180),x=M*Math.sin(k*Math.PI/180)),r.isNoSpot()&&c){const N=i.getDocumentPoint(Spot.Center,Point.l()),T=Point.z(N.x+y*Link.Yf,N.y+x*Link.Yf);this.getLinkPointFromPoint(e,i,N,T,!0,g),Point.i(N),Point.i(T)}}let b=0,P=0,S=0;if(f||!h||c){S=this.getLinkDirection(s,n,p,l,!1,f,e,i);let M=this.yk(s,n,l,!1,S);if(c&&(h||r.equals(l)||!f&&r.x+l.x===1&&r.y+l.y===1)&&(S+=f?0:Link.lv,m<0&&(S+=180)),S=G.Ee(S),c&&(M+=Math.abs(m)*(f?1:2)),S===0?b=M:S===90?P=M:S===180?b=-M:S===270?P=-M:(b=M*Math.cos(S*Math.PI/180),P=M*Math.sin(S*Math.PI/180)),l.isNoSpot()&&c){const N=n.getDocumentPoint(Spot.Center,Point.l()),T=Point.z(N.x+b*Link.Yf,N.y+P*Link.Yf);this.getLinkPointFromPoint(s,n,N,T,!1,p),Point.i(N),Point.i(T)}}let L=g;(f||!a||c)&&(L=new Point(g.x+y,g.y+x));let C=p;(f||!h||c)&&(C=new Point(p.x+b,p.y+P)),!d&&!f&&a&&o>3&&this.adjustPoints(0,g,o-2,C)?this.setPoint(o-1,p):!d&&!f&&h&&o>3&&this.adjustPoints(1,L,o-1,p)?this.setPoint(0,g):!d&&(f?o>=6:o>4)&&this.adjustPoints(1,L,o-2,C)?(this.setPoint(0,g),this.setPoint(o-1,p)):(this.clearPoints(),this.addPoint(g),(f||!a||c)&&this.addPoint(L),f&&this.addOrthoPoints(L,k,C,S,e,s),(f||!h||c)&&this.addPoint(C),this.addPoint(p))}return t.addInvalidRoute(this),!0}DC(t,e){return Math.abs(e.x-t.x)>Math.abs(e.y-t.y)?(e.x>=t.x?e.x=t.x+9e9:e.x=t.x-9e9,e.y=t.y):(e.y>=t.y?e.y=t.y+9e9:e.y=t.y-9e9,e.x=t.x),e}getLinkPointFromPoint(t,e,i,s,n,o){if(o===void 0&&(o=new Point),t===null||e===null)return o.h(i),o;if(!t.isVisible()){const u=t.findVisibleNode();u!==null&&u!==t&&(t=u,e=t.port)}let r=0,l=0,a=0,h=0,c=null,f=e.panel;if(f!==null&&!f.Nn()&&(f=f.panel),f===null)r=s.x,l=s.y,a=i.x,h=i.y;else{c=f.Js;const u=1/(c.m11*c.m22-c.m12*c.m21),d=c.m22*u,m=-c.m12*u,g=-c.m21*u,p=c.m11*u,y=u*(c.m21*c.dy-c.m22*c.dx),x=u*(c.m12*c.dx-c.m11*c.dy);r=s.x*d+s.y*g+y,l=s.x*m+s.y*p+x,a=i.x*d+i.y*g+y,h=i.x*m+i.y*p+x}return e.mf(r,l,a,h,o),c!==null&&o.v(c),o}AE(t,e){const i=t.pd;return i!==null?i.dv(e):null}wk(t){if(t===null)return null;let e=t.pd;return e===null&&(e=new Knot(t.part,t),t.pd=e),e.dv(this)}getLinkPoint(t,e,i,s,n,o,r,l){if(l===void 0&&(l=new Point),i.isSpot()&&!this.Qh(i))return e.getDocumentPoint(i,l),l;if(i.isSide()){const c=this.wk(e);if(c!==null){const f=c._h;if(l.h(f),n&&this.routing===7){const u=this.wk(r);if(u!==null&&c.Kf<u.Kf){const d=Point.l(),m=Point.l(),g=Rect.l();e.getDocumentPoint(Spot.TopLeft,d),e.getDocumentPoint(Spot.BottomRight,m);const p=d.x,y=d.y,x=m.x,k=m.y;g.x=Math.min(p,x),g.y=Math.min(y,k),g.width=Math.abs(p-x),g.height=Math.abs(y-k);const b=this.computeSpot(!s,r),P=this.getLinkPoint(o,r,b,!s,n,t,e,m);(i.includesSide(Spot.LeftSide)||i.includesSide(Spot.RightSide))&&P.y>=g.y&&P.y<=g.y+g.height?l.y=P.y:(i.includesSide(Spot.TopSide)||i.includesSide(Spot.BottomSide))&&P.x>=g.x&&P.x<=g.x+g.width&&(l.x=P.x),Rect.i(g),Point.i(d),Point.i(m)}}return l}}const a=e.getDocumentPoint(this.eg(i,s),Point.l()),h=Point.l();if(this.pointsCount>(n?6:2))h.h(s?this.getPoint(1):this.getPoint(this.pointsCount-2)),n&&this.DC(a,h);else if(t?.isMemberOf(o)||o?.isMemberOf(t)){const c=e.getDocumentBounds(Rect.l()),f=r.getDocumentBounds(Rect.l());c.isReal()&&f.isReal()?f.containsRect(c)?(h.h(a),this.vC(f,a.x,a.y,0,this.computeSpot(r===this.toPort,r),h)):c.containsRect(f)?(r.getDocumentPoint(Spot.Center,h),this.vC(c,h.x,h.y,0,this.computeSpot(e===this.toPort,e),h)):this.FC(r,a,s,n,h):this.FC(r,a,s,n,h),Rect.i(c),Rect.i(f)}else this.FC(r,a,s,n,h);return this.getLinkPointFromPoint(t,e,a,h,s,l),Point.i(h),Point.i(a),l}FC(t,e,i,s,n){const o=this.computeSpot(!i,t);t.getDocumentPoint(this.eg(o,!i),n),s&&this.DC(e,n)}getLinkDirection(t,e,i,s,n,o,r,l){let a=this.TE(t,e,i,s,n,o,r,l);if(t&&r){const c=Rect.l(),f=Rect.l();if(s.isNone()&&t.isMemberOf(r)&&e&&l){if(e.getDocumentBounds(c),l.getDocumentBounds(f),c.isReal()&&f.isReal()&&f.containsRect(c)){const u=this.computeSpot(l===this.toPort,l);u.equals(Spot.Left)||u.equals(Spot.LeftSide)?a=180:u.equals(Spot.Right)||u.equals(Spot.RightSide)?a=0:u.equals(Spot.Top)||u.equals(Spot.TopSide)?a=270:u.equals(Spot.Bottom)||u.equals(Spot.BottomSide)?a=90:a=G.Ee(a+180)}}else r?.isMemberOf(t)&&e&&l&&(e.getDocumentBounds(c),l.getDocumentBounds(f),c.isReal()&&f.isReal()&&c.containsRect(f)&&(a=G.Ee(a+180)));Rect.i(c),Rect.i(f)}if(this.Qh(s)||e===null)return a;const h=e.getDocumentAngle();return h===0?a:(45<=h&&h<135?a+=90:135<=h&&h<225?a+=180:225<=h&&h<315&&(a+=270),G.Ee(a))}TE(t,e,i,s,n,o,r,l){if(s.isSpot())return G.Qw(null,s.x,s.y);if(s.isSide()){const f=this.wk(e);if(f!==null)switch(f.ci){case 1:return 270;case 8:return 90;case 2:return 180;default:return 0}else return s.includesSide(Spot.TopSide)?270:s.includesSide(Spot.BottomSide)?90:s.includesSide(Spot.LeftSide)?180:0}if(e===null||l===null)return 0;const a=e.getDocumentPoint(Spot.Center,Point.l()),h=Point.l();this.pointsCount>(o?6:2)?o?(h.h(n?this.getPoint(1):this.getPoint(this.pointsCount-2)),this.DC(a,h)):h.h(i):l.getDocumentPoint(Spot.Center,h);let c=0;return Math.abs(h.x-a.x)>Math.abs(h.y-a.y)?h.x>=a.x?c=0:c=180:h.y>=a.y?c=90:c=270,Point.i(h),Point.i(a),c}computeEndSegmentLength(t,e,i,s){return this.yk(t,e,i,s,NaN)}yk(t,e,i,s,n){if(e!==null&&i.isSide()){const r=this.wk(e);if(r!==null)return r.xk}let o=NaN;if(s?o=this.fromEndSegmentLength:o=this.toEndSegmentLength,e!==null&&isNaN(o))if(n===void 0&&(n=NaN),Link.CC>0&&this.computeCurve()===9&&!isNaN(n)&&i.isSpot()){const r=this.getOtherPort(e);if(r){const l=Point.l(),a=Point.l(),h=e.getDocumentPoint(i,l),c=r.getDocumentPoint(i.opposite(),a),f=n>=315||n<=45||n>=135&&n<=225;let u=Math.abs(f?h.x-c.x:h.y-c.y)/Link.CC;return u=Math.max(u,Link.LC),Point.i(l),Point.i(a),u}}else s?o=e.fromEndSegmentLength:o=e.toEndSegmentLength;return isNaN(o)&&(o=Link.LC),o}computeSpot(t,e){return e===void 0&&(e=null),t?this.DE(e||this.fromPort):this.vE(e||this.toPort)}DE(t){if(t===null)return Spot.Center;let e=this.fromSpot;return e.isDefault()&&(e=t.fromSpot),e===Spot.Default?Spot.None:e}vE(t){if(t===null)return Spot.Center;let e=this.toSpot;return e.isDefault()&&(e=t.toSpot),e===Spot.Default?Spot.None:e}Qh(t){return t===Spot.None||t.x===.5&&t.y===.5}eg(t,e){return t.x===.5&&t.y===.5?t:Spot.Center}computeOtherPoint(t,e){if(this.computeAdjusting()!==0&&this.pointsCount>4)return this.computeMidPoint(new Point);{const i=this.AE(e,this);if(i!==null)return i._h;if(t instanceof Group){let s=this.fromNode,n=this.fromPort;n===e&&(s=this.toNode,n=this.toPort);const o=Rect.l(),r=Rect.l();if(n&&s?.isMemberOf(t)){const l=this.computeSpot(n===e,e);if(e.getDocumentBounds(o),n.getDocumentBounds(r),o.isReal()&&r.isReal()&&o.containsRect(r)){const a=n.getDocumentPoint(Spot.Center);return this.vC(o,a.x,a.y,0,l,a),Rect.i(o),Rect.i(r),a}}Rect.i(o),Rect.i(r)}return e.getDocumentPoint(Spot.Center)}}computeShortLength(t){if(t){let e=this.fromShortLength;if(isNaN(e)){const i=this.fromPort;i!==null&&(e=i.fromShortLength)}return isNaN(e)?0:e}else{let e=this.toShortLength;if(isNaN(e)){const i=this.toPort;i!==null&&(e=i.toShortLength)}return isNaN(e)?0:e}}$m(t,e,i,s,n,o){if(this.pickable===!1)return!1;e===void 0&&(e=null),i===void 0&&(i=null);let r;if(o===void 0?(r=Transform.l(),r.Ue()):r=o,r.bc(this.v),this.containedInRect(t,r))return this.JN(e,i,n),o===void 0&&Transform.i(r),!0;if(this.intersectsRect(t,r)){let l=!1;if(!this.Af){const a=this.D.r,h=a.length;for(let c=h;c--;){const f=a[c];if(!f.visible&&f!==this.locationObject)continue;const u=f.actualBounds,d=this.naturalBounds;if(u.x>d.width||u.y>d.height||u.x+u.width<0||u.y+u.height<0)continue;const m=f,g=Transform.l();if(g.set(r),m instanceof Panel?l=m.$m(t,e,i,s,n,g):this.path===m?m instanceof Shape&&(l=m.sE(t,s,g)):l=m.JT(t,s,g),l){let p=m;e!==null&&(p=e(m)),p&&(i===null||i(p))&&n.add(p)}Transform.i(g)}}return o===void 0&&Transform.i(r),l||this.background!==null}return o===void 0&&Transform.i(r),!1}get isOrthogonal(){return(this.qh&2)===2}static MC(t){return(t&2)===2}get isAvoiding(){return(this.qh&4)===4}computeCurve(){if(this.ir===null){const t=this.fromPort,e=t!==null&&t===this.toPort,i=this.isOrthogonal;this.ir=e&&!i}return this.ir?9:this.curve}computeCorner(){if(this.curve===9)return 0;let t=this.corner;return(isNaN(t)||t<0)&&(t=Link.av),t}findMidLabel(){const t=this.path,e=this.D.r,i=e.length;for(let n=0;n<i;n++){const o=e[n];if(!(o===t||o.isPanelMain)&&(o.segmentIndex===-1/0||isNaN(o.segmentIndex)))return o}const s=this.labelNodes;for(;s.next();){const n=s.value;if(n.segmentIndex===-1/0||isNaN(n.segmentIndex))return n}return null}computeSpacing(){if(!this.isVisible())return 0;let t=Link.hv;t=Math.max(t,this.computeThickness());const e=this.fromPort,i=this.toPort;if(e!==null&&i!==null){const s=this.findMidLabel();if(s!==null){const n=s.naturalBounds,o=s.margin,r=isNaN(n.width)?Link.cv:n.width*s.scale+o.left+o.right,l=isNaN(n.height)?Link.fv:n.height*s.scale+o.top+o.bottom,a=s.segmentOrientation;if(a===21||a===25||a===24)t=Math.max(t,l);else if(a===23||a===27||a===22||a===26)t=Math.max(t,r);else{const c=e.getDocumentPoint(Spot.Center).directionPoint(i.getDocumentPoint(Spot.Center))/180*Math.PI;t=Math.max(t,Math.abs(Math.sin(c)*r)+Math.abs(Math.cos(c)*l)+1)}this.curve===9&&(t*=Link.nv)}}return t}arrangeBundledLinks(t,e){if(e)for(let i=0;i<t.length;i++){const s=t[i];s.computeAdjusting()===0&&s.$t()}}computeCurviness(){let t=this.curviness;if(isNaN(t)){t=Link.iv;const e=this.sr;if(e!==null){const i=U.ot();let s=0;const n=e.rn;for(let r=0;r<n.length;r++){const a=n[r].computeSpacing();i.push(a),s+=a}let o=-s/2;for(let r=0;r<n.length;r++){if(n[r]===this){t=o+i[r]/2;break}o+=i[r]}e.Xy===this.fromNode&&(t=-t),U.Z(i)}}return t}computeThickness(){if(!this.isVisible())return 0;const t=this.path;return t!==null?Math.max(t.strokeWidth,1):1}hasCurviness(){return!isNaN(this.curviness)||this.sr!==null}LE(t,e,i,s,n,o){let r=this.getLinkPoint(t,e,i,!0,!1,s,n),l=this.getLinkPoint(s,n,o,!1,!1,t,e);if(this.gv(t,e,i,r,s,n,o,l),this.addPoint(r),this.addPoint(l),this.hasCurviness()){const a=l.x-r.x,h=l.y-r.y,c=this.computeCurviness(),f=c,u=r.x+a/2,d=r.y+h/2;let m=u,g=d;if(G.u(h,0))a>0?g-=f:g+=f;else{const p=-a/h;let y=Math.sqrt(f*f/(p*p+1));c<0&&(y=-y),m=(h<0?-1:1)*y+u,g=p*(m-u)+d}this.insertPointAt(1,m,g)}}gv(t,e,i,s,n,o,r,l){const a=o.getDocumentBounds(Rect.l()),h=e.getDocumentBounds(Rect.l());if(a.intersectsRect(h)&&!a.containsRect(h)&&!h.containsRect(a)){const c=Point.l();e.getDocumentPoint(this.eg(i,!0),c);const f=Point.l();o.getDocumentPoint(this.eg(r,!1),f);const u=h.width*h.height,d=a.width*a.height;u>d?(s.h(c),this.getLinkPointFromPoint(n,o,f,c,!1,f),l.h(f)):u<d?(this.getLinkPointFromPoint(t,e,c,f,!0,c),s.h(c),l.h(f)):(s.h(c),l.h(f)),Point.i(c),Point.i(f)}else if(a.containsPoint(s)){const c=Point.l();e.getDocumentPoint(this.eg(i,!0),c),l.h(c),this.RC(a,c.x,c.y,Link.Yf,l),this.getLinkPointFromPoint(n,o,a.containsPoint(c)?c:s,l,!1,l),this.getLinkPointFromPoint(t,e,c,l,!0,s),Point.i(c)}else if(h.containsPoint(l)){const c=Point.l();o.getDocumentPoint(this.eg(r,!1),c),s.h(c),this.RC(h,c.x,c.y,Link.Yf,s),this.getLinkPointFromPoint(t,e,h.containsPoint(c)?c:l,s,!0,s),this.getLinkPointFromPoint(n,o,c,s,!1,l),Point.i(c)}Rect.i(h),Rect.i(a)}vC(t,e,i,s,n,o){let r=-1;return n.equals(Spot.Left)||n.equals(Spot.LeftSide)?r=180:n.equals(Spot.Right)||n.equals(Spot.RightSide)?r=0:n.equals(Spot.Top)||n.equals(Spot.TopSide)?r=270:(n.equals(Spot.Bottom)||n.equals(Spot.BottomSide))&&(r=90),r===-1?this.RC(t,e,i,0,o):this.mv(t,e,i,0,r,o)}RC(t,e,i,s,n){const o=G.Qw(t,e,i);return this.mv(t,e,i,s,o,n)}mv(t,e,i,s,n,o){return n===0?o.x=t.right+s:n===90?o.y=t.bottom+s:n===180?o.x=t.x-s:n===270?o.y=t.y-s:n===45?(o.x=t.right+s,o.y=t.bottom+s):n===135?(o.x=t.x-s,o.y=t.bottom+s):n===225?(o.x=t.x-s,o.y=t.y-s):n===315&&(o.x=t.right+s,o.y=t.y-s),o}CE(t,e,i,s,n,o){let r=this.getLinkPoint(t,e,i,!0,!1,s,n),l=this.getLinkPoint(s,n,o,!1,!1,t,e);this.gv(t,e,i,r,s,n,o,l),this.addPoint(r),this.addPoint(l);const a=l.x-r.x,h=l.y-r.y,c=this.computeCurviness();let f=0,u=0,d=r.x+a/3,m=r.y+h/3,g=d,p=m;G.u(h,0)?a>0?p-=c:p+=c:(f=-a/h,u=Math.sqrt(c*c/(f*f+1)),c<0&&(u=-u),g=(h<0?-1:1)*u+d,p=f*(g-d)+m),d=r.x+2*a/3,m=r.y+2*h/3;let y=d,x=m;G.u(h,0)?a>0?x-=c:x+=c:(y=(h<0?-1:1)*u+d,x=f*(y-d)+m),this.insertPointAt(1,g,p),this.insertPointAt(2,y,x),this.setPoint(0,this.getLinkPoint(t,e,i,!0,!1,s,n)),this.setPoint(3,this.getLinkPoint(s,n,o,!1,!1,t,e))}adjustPoints(t,e,i,s){let n=this.computeAdjusting();if(this.isOrthogonal){if(n===18)return!1;n===19&&(n=17)}switch(n){case 18:return this.FE(t,e,i,s);case 19:return this.RE(t,e,i,s);case 17:return this.OE(t,e,i,s);default:return!1}}FE(t,e,i,s){const n=this.getPoint(t),o=this.getPoint(i);if(n.equalsApprox(e)&&o.equalsApprox(s))return!0;const r=n.x,l=n.y,a=o.x,h=o.y;let c=a-r,f=h-l;const u=Math.sqrt(c*c+f*f);if(G.X(u,0))return!0;let d=0;G.X(c,0)?f<0?d=-Math.PI/2:d=Math.PI/2:(d=Math.atan(f/Math.abs(c)),c<0&&(d=Math.PI-d));const m=e.x,g=e.y,p=s.x,y=s.y,x=p-m,k=y-g,b=Math.sqrt(x*x+k*k);let P=0;G.X(x,0)?k<0?P=-Math.PI/2:P=Math.PI/2:(P=Math.atan(k/Math.abs(x)),x<0&&(P=Math.PI-P));const S=b/u,L=P-d;this.setPoint(t,e);for(let C=t+1;C<i;C++){const M=this.getPoint(C);c=M.x-r,f=M.y-l;const N=Math.sqrt(c*c+f*f);if(G.X(N,0))continue;let T=0;G.X(c,0)?f<0?T=-Math.PI/2:T=Math.PI/2:(T=Math.atan(f/Math.abs(c)),c<0&&(T=Math.PI-T));const A=T+L,D=N*S,v=m+D*Math.cos(A),R=g+D*Math.sin(A);this.setPointAt(C,v,R)}return this.setPoint(i,s),!0}RE(t,e,i,s){const n=this.getPoint(t),o=this.getPoint(i);if(n.equalsApprox(e)&&o.equalsApprox(s))return!0;const r=n.x,l=n.y,a=o.x,h=o.y,c=(a-r)**2+(h-l)**2,f=e.x,u=e.y,d=s.x,m=s.y;let g=0,p=1;d-f!==0?(g=(m-u)/(d-f),p=Math.sqrt(1+1/(g*g))):g=9e9,this.setPoint(t,e);for(let y=t+1;y<i;y++){const x=this.getPoint(y),k=x.x,b=x.y;let P=.5;c!==0&&(P=((r-k)*(r-a)+(l-b)*(l-h))/c);const S=r+P*(a-r),L=l+P*(h-l);let C=Math.sqrt((k-S)**2+(b-L)**2);b<g*(k-S)+L&&(C=-C),g>0&&(C=-C);const M=f+P*(d-f),N=u+P*(m-u);if(g!==0){const T=M+C/p,A=N-(T-M)/g;this.setPointAt(y,T,A)}else this.setPointAt(y,M,N+C)}return this.setPoint(i,s),!0}OE(t,e,i,s){if(this.isOrthogonal){let n=this.getPoint(t),o=this.getPoint(t+1),r=this.getPoint(t+2),l=o.x,a=o.y;const h=l,c=a;G.u(n.y,o.y)?G.u(o.x,r.x)?a=e.y:G.u(o.y,r.y)&&(l=e.x):G.u(n.x,o.x)&&(G.u(o.y,r.y)?l=e.x:G.u(o.x,r.x)&&(a=e.y)),this.setPointAt(t+1,l,a),n=this.getPoint(i),o=this.getPoint(i-1),r=this.getPoint(i-2);let f=o.x,u=o.y;const d=f,m=u;if(G.u(n.y,o.y)?G.u(o.x,r.x)?u=s.y:G.u(o.y,r.y)&&(f=s.x):G.u(n.x,o.x)&&(G.u(o.y,r.y)?f=s.x:G.u(o.x,r.x)&&(u=s.y)),this.setPointAt(i-1,f,u),this.yT())return this.setPointAt(t+1,h,c),this.setPointAt(i-1,d,m),!1}return this.setPoint(t,e),this.setPoint(i,s),!0}addOrthoPoints(t,e,i,s,n,o){e=G.Ee(e),s=G.Ee(s);const c=s;e>=315||e<45?e=0:45<=e&&e<135?e=90:135<=e&&e<225?e=180:e=270,s>=315||s<45?s=0:45<=s&&s<135?s=90:135<=s&&s<225?s=180:s=270;const f=t,u=i,d=Rect.bs(n.actualBounds),m=Rect.bs(o.actualBounds);d.inflate(Link.va,Link.va),m.inflate(Link.va,Link.va),d.unionPoint(t),m.unionPoint(i);const g=Point.l(),p=Point.l();e===0?u.x>f.x||s===270&&u.y<f.y&&m.right>f.x||s===90&&u.y>f.y&&m.right>f.x?(g.e(u.x,f.y),p.e(u.x,(f.y+u.y)/2),s===180?(g.x=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!1),p.x=g.x,p.y=u.y):s===270&&u.y<f.y||s===90&&u.y>f.y?(f.x<m.left?g.x=this.computeMidOrthoPosition(f.x,f.y,m.left,u.y,!1):f.x<m.right&&(s===270&&f.y<m.top||s===90&&f.y>m.bottom)?g.x=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!1):g.x=m.right,p.x=g.x,p.y=u.y):s===0&&f.x<m.left&&f.y>m.top&&f.y<m.bottom&&(g.x=f.x,f.y<u.y?g.y=Math.min(u.y,m.top):g.y=Math.max(u.y,m.bottom),p.y=g.y)):(g.e(f.x,u.y),p.e((f.x+u.x)/2,u.y),(s===180||s===90&&u.y<d.top||s===270&&u.y>d.bottom)&&(s===180&&(m.containsPoint(f)||d.containsPoint(u))?g.y=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!0):u.y<f.y&&(s===180||s===90)?g.y=this.computeMidOrthoPosition(f.x,d.top,u.x,Math.min(u.y,m.bottom),!0):u.y>f.y&&(s===180||s===270)&&(g.y=this.computeMidOrthoPosition(f.x,d.bottom,u.x,Math.max(u.y,m.top),!0)),p.x=u.x,p.y=g.y),g.y>d.top&&g.y<d.bottom&&(u.x>=d.left&&u.x<=f.x||f.x<=m.right&&f.x>=u.x?(s===90||s===270)&&(g.e(Math.max((f.x+u.x)/2,f.x),f.y),p.e(g.x,u.y)):(s===270||(s===0||s===180)&&u.y<f.y?g.y=Math.min(u.y,s===0?d.top:Math.min(d.top,m.top)):g.y=Math.max(u.y,s===0?d.bottom:Math.max(d.bottom,m.bottom)),p.x=u.x,p.y=g.y))):e===180?u.x<f.x||s===270&&u.y<f.y&&m.left<f.x||s===90&&u.y>f.y&&m.left<f.x?(g.e(u.x,f.y),p.e(u.x,(f.y+u.y)/2),s===0?(g.x=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!1),p.x=g.x,p.y=u.y):s===270&&u.y<f.y||s===90&&u.y>f.y?(f.x>m.right?g.x=this.computeMidOrthoPosition(f.x,f.y,m.right,u.y,!1):f.x>m.left&&(s===270&&f.y<m.top||s===90&&f.y>m.bottom)?g.x=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!1):g.x=m.left,p.x=g.x,p.y=u.y):s===180&&f.x>m.right&&f.y>m.top&&f.y<m.bottom&&(g.x=f.x,f.y<u.y?g.y=Math.min(u.y,m.top):g.y=Math.max(u.y,m.bottom),p.y=g.y)):(g.e(f.x,u.y),p.e((f.x+u.x)/2,u.y),(s===0||s===90&&u.y<d.top||s===270&&u.y>d.bottom)&&(s===0&&(m.containsPoint(f)||d.containsPoint(u))?g.y=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!0):u.y<f.y&&(s===0||s===90)?g.y=this.computeMidOrthoPosition(f.x,d.top,u.x,Math.min(u.y,m.bottom),!0):u.y>f.y&&(s===0||s===270)&&(g.y=this.computeMidOrthoPosition(f.x,d.bottom,u.x,Math.max(u.y,m.top),!0)),p.x=u.x,p.y=g.y),g.y>d.top&&g.y<d.bottom&&(u.x<=d.right&&u.x>=f.x||f.x>=m.left&&f.x<=u.x?(s===90||s===270)&&(g.e(Math.min((f.x+u.x)/2,f.x),f.y),p.e(g.x,u.y)):(s===270||(s===0||s===180)&&u.y<f.y?g.y=Math.min(u.y,s===180?d.top:Math.min(d.top,m.top)):g.y=Math.max(u.y,s===180?d.bottom:Math.max(d.bottom,m.bottom)),p.x=u.x,p.y=g.y))):e===90?u.y>f.y||s===180&&u.x<f.x&&m.bottom>f.y||s===0&&u.x>f.x&&m.bottom>f.y?(g.e(f.x,u.y),p.e((f.x+u.x)/2,u.y),s===270?(g.y=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!0),p.x=u.x,p.y=g.y):s===180&&u.x<f.x||s===0&&u.x>f.x?(f.y<m.top?g.y=this.computeMidOrthoPosition(f.x,f.y,u.x,m.top,!0):f.y<m.bottom&&(s===180&&f.x<m.left||s===0&&f.x>m.right)?g.y=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!0):g.y=m.bottom,p.x=u.x,p.y=g.y):s===90&&f.y<m.top&&f.x>m.left&&f.x<m.right&&(f.x<u.x?g.x=Math.min(u.x,m.left):g.x=Math.max(u.x,m.right),g.y=f.y,p.x=g.x)):(g.e(u.x,f.y),p.e(u.x,(f.y+u.y)/2),(s===270||s===0&&u.x<d.left||s===180&&u.x>d.right)&&(s===270&&(m.containsPoint(f)||d.containsPoint(u))?g.x=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!1):u.x<f.x&&(s===270||s===0)?g.x=this.computeMidOrthoPosition(d.left,f.y,Math.min(u.x,m.right),u.y,!1):u.x>f.x&&(s===270||s===180)&&(g.x=this.computeMidOrthoPosition(d.right,f.y,Math.max(u.x,m.left),u.y,!1)),p.x=g.x,p.y=u.y),g.x>d.left&&g.x<d.right&&(u.y>=d.top&&u.y<=f.y||f.y<=m.bottom&&f.y>=u.y?(s===0||s===180)&&(g.e(f.x,Math.max((f.y+u.y)/2,f.y)),p.e(u.x,g.y)):(s===180||(s===90||s===270)&&u.x<f.x?g.x=Math.min(u.x,s===90?d.left:Math.min(d.left,m.left)):g.x=Math.max(u.x,s===90?d.right:Math.max(d.right,m.right)),p.x=g.x,p.y=u.y))):u.y<f.y||s===180&&u.x<f.x&&m.top<f.y||s===0&&u.x>f.x&&m.top<f.y?(g.e(f.x,u.y),p.e((f.x+u.x)/2,u.y),s===90?(g.y=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!0),p.x=u.x,p.y=g.y):s===180&&u.x<f.x||s===0&&u.x>=f.x?(f.y>m.bottom?g.y=this.computeMidOrthoPosition(f.x,f.y,u.x,m.bottom,!0):f.y>m.top&&(s===180&&f.x<m.left||s===0&&f.x>m.right)?g.y=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!0):g.y=m.top,p.x=u.x,p.y=g.y):s===270&&f.y>m.bottom&&f.x>m.left&&f.x<m.right&&(f.x<u.x?g.x=Math.min(u.x,m.left):g.x=Math.max(u.x,m.right),g.y=f.y,p.x=g.x)):(g.e(u.x,f.y),p.e(u.x,(f.y+u.y)/2),(s===90||s===0&&u.x<d.left||s===180&&u.x>d.right)&&(s===90&&(m.containsPoint(f)||d.containsPoint(u))?g.x=this.computeMidOrthoPosition(f.x,f.y,u.x,u.y,!1):u.x<f.x&&(s===90||s===0)?g.x=this.computeMidOrthoPosition(d.left,f.y,Math.min(u.x,m.right),u.y,!1):u.x>f.x&&(s===90||s===180)&&(g.x=this.computeMidOrthoPosition(d.right,f.y,Math.max(u.x,m.left),u.y,!1)),p.x=g.x,p.y=u.y),g.x>d.left&&g.x<d.right&&(u.y<=d.bottom&&u.y>=f.y||f.y>=m.top&&f.y<=u.y?(s===0||s===180)&&(g.e(f.x,Math.min((f.y+u.y)/2,f.y)),p.e(u.x,g.y)):(s===180||(s===90||s===270)&&u.x<f.x?g.x=Math.min(u.x,s===270?d.left:Math.min(d.left,m.left)):g.x=Math.max(u.x,s===270?d.right:Math.max(d.right,m.right)),p.x=g.x,p.y=u.y))),this.TC=s!==c,this.PC=e,this.SC=s,this.addPoint(g.copy()),this.addPoint(p.copy()),Point.i(g),Point.i(p),Rect.i(d),Rect.i(m)}computeMidOrthoPosition(t,e,i,s,n){let o=0;return this.hasCurviness()&&!this.computeSpot(!0,this.fromPort).isSide()&&!this.computeSpot(!1,this.toPort).isSide()&&(o=this.computeCurviness()),n?(e+s)/2+o:(t+i)/2+o}yT(){if(this.diagram===null||!this.isAvoiding||this.diagram.animationManager.isTicking)return!1;const t=this.points.r,e=t.length;if(e<4)return!1;const i=this.diagram.getPositions(!1,this.containingGroup,null);for(let s=1;s<e-2;s++){const n=t[s],o=t[s+1];if(!i.isUnoccupied(Math.min(n.x,o.x),Math.min(n.y,o.y),Math.abs(n.x-o.x),Math.abs(n.y-o.y)))return!0}return!1}findClosestSegment(t){const e=t.x,i=t.y;let s=this.getPoint(0),n=this.getPoint(1),o=Point.distanceLineSegmentSquared(e,i,s.x,s.y,n.x,n.y),r=0;for(let l=1;l<this.pointsCount-1;l++){s=this.getPoint(l+1);const a=Point.distanceLineSegmentSquared(e,i,n.x,n.y,s.x,s.y);n=s,a<o&&(r=l,o=a)}return r}invalidateGeometry(){this.Ze()}Ze(){this.bl&&(this.bl=!1,this.c())}get bl(){return(this.Nt&128)!==0}set bl(t){(this.Nt&128)!==0!==t&&(this.Nt=this.Nt^128)}get geometry(){if(!this.bl){if(this.updateRoute(),this.pointsCount<2)return this.bl=!0,this.ut;this.ut=this.makeGeometry()}return this.ut}Ad(t){if(!t){if(this.Fi===!1)return;const n=this.findMainElement();if(this.bl&&(n===null||n.geometry!==null))return}this.pointsCount<2?this.bl=!0:this.ut=this.makeGeometry();const e=this.path;if(e===null)return;e.ut=this.ut;const i=this.D.r,s=i.length;for(let n=0;n<s;n++){const o=i[n];o!==e&&o.isPanelMain&&o instanceof Shape&&(o.ut=this.ut)}}IE(t){return this.Zh()&&t.ra.has(this)&&(this.Gf.width!==0||this.Gf.height!==0)&&(t.animationManager.isAnimating||t.currentTool!==t.toolManager)}makeGeometry(){const t=this.ut,e=this.pointsCount;let i=!1;const s=this.diagram;s!==null&&this.IE(s)&&(i=!0);let n=0,o=0,r=Point.bs(this.getPoint(0));const l=Point.bs(r),a=this.Me.r,h=this.computeCurve();if(h===9&&e>=3&&!G.X(this.smoothness,0))if(e===3){let c=this.getPoint(1);n=Math.min(r.x,c.x),o=Math.min(r.y,c.y),c=this.getPoint(2),n=Math.min(n,c.x),o=Math.min(o,c.y)}else if(this.isOrthogonal){for(let c=0;c<e;c++){const f=a[c];l.x=Math.min(f.x,l.x),l.y=Math.min(f.y,l.y)}n=l.x,o=l.y}else{for(let c=3;c<e;c+=3){c+3>=e&&(c=e-1);const f=this.getPoint(c);l.x=Math.min(f.x,l.x),l.y=Math.min(f.y,l.y)}n=l.x,o=l.y}else{for(let c=0;c<e;c++){const f=a[c];l.x=Math.min(f.x,l.x),l.y=Math.min(f.y,l.y)}n=l.x,o=l.y}if(n-=this.dk.x,o-=this.dk.y,r.x-=n,r.y-=o,this.computeShortLength(!0)!==0&&(r=this.tc(r,!0,l)),e===2&&!this.Zh()){let c=Point.bs(this.getPoint(1));return c.x-=n,c.y-=o,this.computeShortLength(!1)!==0&&(c=this.tc(c,!1,l)),t.type=1,t.startX=r.x,t.startY=r.y,t.endX=c.x,t.endY=c.y,this.bl=!0,Point.i(c),Point.i(r),Point.i(l),t}else{t.type=4;const c=GeoStream.qL(t);if(c.Au(r.x,r.y,!1,!1),h===9&&e>=3&&!G.X(this.smoothness,0))if(e===3){const f=this.getPoint(1),u=f.x-n,d=f.y-o,m=Point.bs(this.getPoint(2));m.x-=n,m.y-=o,this.computeShortLength(!1)!==0&&this.tc(m,!1,l),c.xr(u,d,u,d,m.x,m.y),Point.i(m)}else if(this.isOrthogonal){const f=Point.z(n,o),u=Point.bs(this.getPoint(1)),d=Point.z(n,o),m=Point.z(n,o);let g=this.getPoint(0),p;const y=this.smoothness/3;for(let P=1;P<this.pointsCount-1;P++){p=this.getPoint(P);const S=g,L=p,C=this.getPoint(this.OC(p,P,!1));G.X(S.x,L.x)&&G.X(L.x,C.x)||G.X(S.y,L.y)&&G.X(L.y,C.y)||(this.EE(S,L,C,y,d,m),(P===1||P===2&&G.X(g.x,this.getPoint(0).x)&&G.X(g.y,this.getPoint(0).y))&&(u.x=(g.x+p.x)*.5,u.y=(g.y+p.y)*.5),c.xr(u.x-n,u.y-o,d.x-n,d.y-o,p.x-n,p.y-o),f.h(d),u.h(m),g=p)}let x=g.x,k=g.y;const b=Point.bs(this.getPoint(this.pointsCount-1));this.computeShortLength(!1)!==0&&this.tc(b,!1,Point.gn),x=.5*(x+b.x),k=.5*(k+b.y),c.xr(m.x-n,m.y-o,x-n,k-o,b.x-n,b.y-o),Point.i(b),Point.i(f),Point.i(u),Point.i(d),Point.i(m)}else for(let f=3;f<e;f+=3){const u=this.getPoint(f-2);f+3>=e&&(f=e-1);const d=this.getPoint(f-1),m=Point.bs(this.getPoint(f));f===e-1&&this.computeShortLength(!1)!==0&&this.tc(m,!1,Point.gn),c.xr(u.x-n,u.y-o,d.x-n,d.y-o,m.x-n,m.y-o),Point.i(m)}else if(this.isOrthogonal||e===2){const f=Point.bs(this.getPoint(0)),u=Point.l(),d=Point.bs(f),m=this.computeCorner();let g=1,p=0;for(;g<e;){if(g=this.OC(f,g,g>1),u.h(this.getPoint(g)),g>=e-1){if(!f.equals(u))this.computeShortLength(!1)!==0&&this.tc(u,!1,Point.gn),this.On(c,-n,-o,f,u,i);else if(p===0)for(g=1;g<e;)d.h(f),u.h(this.getPoint(g++)),this.On(c,-n,-o,f,u,i),f.h(u);break}p=this.OC(u,g+1,g<e-3);const y=this.getPoint(p);this.UE(c,-n,-o,f,u,y,f,d,m,i),d.h(u),g=p}Point.i(f),Point.i(u),Point.i(d)}else{const f=this.computeCorner();if(e>2&&f>=.5){const u=Point.bs(a[e-1]);this.computeShortLength(!1)!==0&&this.tc(u,!1,Point.gn),r.x+=n,r.y+=o;for(let d=1;d<e;d++){const m=d===1?r:a[d-1],g=d===e-1?u:a[d],p=Math.sqrt(m.distanceSquaredPoint(g)),y=f/p;if(y<.5){if(d>1){const x=m.x+(g.x-m.x)*y,k=m.y+(g.y-m.y)*y;c.Tu(m.x-n,m.y-o,x-n,k-o)}c.Ks(g.x+(m.x-g.x)*y-n,g.y+(m.y-g.y)*y-o)}else d>1&&c.Tu(m.x-n,m.y-o,(m.x+g.x)/2-n,(m.y+g.y)/2-o);d===e-1&&c.Ks(u.x-n,u.y-o)}Point.i(u)}else if(e>=2){const u=Point.bs(a[e-1]);this.computeShortLength(!1)!==0&&this.tc(u,!1,Point.gn);for(let d=1;d<e-1;d++)c.Ks(a[d].x-n,a[d].y-o);c.Ks(u.x-n,u.y-o),Point.i(u)}}return GeoStream.WL(c),this.bl=!0,Point.i(r),Point.i(l),t}}bk(t,e,i,s){let n=i-t;if(isNaN(n)||n===1/0||n===-1/0)return NaN;n<0&&(n=-n);let o=s-e;return isNaN(o)||o===1/0||o===-1/0?NaN:(o<0&&(o=-o),G.X(n,0)?o:G.X(o,0)?n:Math.sqrt(n*n+o*o))}EE(t,e,i,s,n,o){isNaN(s)&&(s=this.smoothness/3);const r=t.x,l=t.y,a=e.x,h=e.y,c=i.x,f=i.y,u=s*this.bk(r,l,a,h),d=s*this.bk(a,h,c,f);if(G.X(l,h)&&G.X(a,c)&&(a>r?f>h?(n.x=a-u,n.y=h-u,o.x=a+d,o.y=h+d):(n.x=a-u,n.y=h+u,o.x=a+d,o.y=h-d):f>h?(n.x=a+u,n.y=h-u,o.x=a-d,o.y=h+d):(n.x=a+u,n.y=h+u,o.x=a-d,o.y=h-d)),G.X(r,a)&&G.X(h,f)&&(h>l?c>a?(n.x=a-u,n.y=h-u,o.x=a+d,o.y=h+d):(n.x=a+u,n.y=h-u,o.x=a-d,o.y=h+d):c>a?(n.x=a-u,n.y=h+u,o.x=a+d,o.y=h-d):(n.x=a+u,n.y=h+u,o.x=a-d,o.y=h-d)),G.X(r,a)&&G.X(a,c)||G.X(l,h)&&G.X(h,f)){const m=.5*(r+c),g=.5*(l+f);n.x=m,n.y=g,o.x=m,o.y=g}}tc(t,e,i){const s=this.pointsCount;if(s<2)return t;if(e){const n=this.getPoint(1),o=n.x-i.x,r=n.y-i.y,l=this.bk(t.x,t.y,o,r);if(l===0)return t;const a=s===2?l*.5:l;let h=this.computeShortLength(!0);h>a&&(h=a);const c=h*(o-t.x)/l,f=h*(r-t.y)/l;t.x+=c,t.y+=f}else{const n=this.getPoint(s-2),o=n.x-i.x,r=n.y-i.y,l=this.bk(t.x,t.y,o,r);if(l===0)return t;const a=s===2?l*.5:l;let h=this.computeShortLength(!1);h>a&&(h=a);const c=h*(t.x-o)/l,f=h*(t.y-r)/l;t.x-=c,t.y-=f}return t}OC(t,e,i){const s=this.pointsCount;let n=t;for(;G.X(t.x,n.x)&&G.X(t.y,n.y);){if(e>=s)return s-1;n=this.getPoint(e++)}if(!G.X(t.x,n.x)&&!G.X(t.y,n.y))return e-1;let o=n;for(;G.X(t.x,n.x)&&G.X(n.x,o.x)&&(!i||(t.y>=n.y?n.y>=o.y:n.y<=o.y))||G.X(t.y,n.y)&&G.X(n.y,o.y)&&(!i||(t.x>=n.x?n.x>=o.x:n.x<=o.x));){if(e>=s)return s-1;o=this.getPoint(e++)}return e-2}UE(t,e,i,s,n,o,r,l,a,h){if(G.u(s.y,n.y)&&G.u(n.x,o.x)){let c=Math.min(a,Math.abs(n.x-l.x)/2);const f=Math.min(c,Math.abs(o.y-n.y)/2);if(c=f,G.u(c,0)){this.On(t,e,i,s,n,h),r.h(n);return}let u=n.x;const d=n.y,m=u;let g=d;n.x>s.x?(u=n.x-c,o.y>n.y?g=n.y+f:g=n.y-f):(u=n.x+c,o.y>n.y?g=n.y+f:g=n.y-f);const p=Point.z(u,d);this.On(t,e,i,s,p,h),Point.i(p),t.Tu(n.x+e,n.y+i,m+e,g+i),r.e(m,g)}else if(G.u(s.x,n.x)&&G.u(n.y,o.y)){let c=Math.min(a,Math.abs(n.y-l.y)/2);const f=Math.min(c,Math.abs(o.x-n.x)/2);if(c=f,G.u(f,0)){this.On(t,e,i,s,n,h),r.h(n);return}const u=n.x;let d=n.y,m=u;const g=d;n.y>s.y?(d=n.y-c,o.x>n.x?m=n.x+f:m=n.x-f):(d=n.y+c,o.x>n.x?m=n.x+f:m=n.x-f);const p=Point.z(u,d);this.On(t,e,i,s,p,h),Point.i(p),t.Tu(n.x+e,n.y+i,m+e,g+i),r.e(m,g)}else this.On(t,e,i,s,n,h),r.h(n)}On(t,e,i,s,n,o){if(o||!this.Zh())t.Ks(n.x+e,n.y+i);else{const r=Link.ov,l=r/2,a=[];let h=0;this.isVisible()&&(h=this.VE(s,n,a));let c=s.x,f=s.y;if(h>0){if(G.u(s.y,n.y))if(s.x<n.x){let u=0;for(;u<h;){const d=Math.max(s.x,Math.min(a[u++]-l,n.x-r));t.Ks(d+e,n.y+i),c=d+e,f=n.y+i;let m=Math.min(d+r,n.x);for(;u<h;){const x=a[u];if(x<m+r)u++,m=Math.min(x+l,n.x);else break}const g=n.y-r+i,p=m+e,y=n.y+i;this.curve===10?t.Au(p,y,!1,!1):t.xr(c,g,p,g,p,y),c=p,f=y}}else{let u=h-1;for(;u>=0;){const d=Math.min(s.x,Math.max(a[u--]+l,n.x+r));t.Ks(d+e,n.y+i),c=d+e,f=n.y+i;let m=Math.max(d-r,n.x);for(;u>=0;){const x=a[u];if(x>m-r)u--,m=Math.max(x-l,n.x);else break}const g=n.y-r+i,p=m+e,y=n.y+i;this.curve===10?t.Au(p,y,!1,!1):t.xr(c,g,p,g,p,y),c=p,f=y}}else if(G.u(s.x,n.x))if(s.y<n.y){let u=0;for(;u<h;){const d=Math.max(s.y,Math.min(a[u++]-l,n.y-r));t.Ks(n.x+e,d+i),c=n.x+e,f=d+i;let m=Math.min(d+r,n.y);for(;u<h;){const x=a[u];if(x<m+r)u++,m=Math.min(x+l,n.y);else break}const g=n.x-r+e,p=n.x+e,y=m+i;this.curve===10?t.Au(p,y,!1,!1):t.xr(g,f,g,y,p,y),c=p,f=y}}else{let u=h-1;for(;u>=0;){const d=Math.min(s.y,Math.max(a[u--]+l,n.y+r));t.Ks(n.x+e,d+i),c=n.x+e,f=d+i;let m=Math.max(d-r,n.y);for(;u>=0;){const x=a[u];if(x>m-r)u--,m=Math.max(x-l,n.y);else break}const g=n.x-r+e,p=n.x+e,y=m+i;this.curve===10?t.Au(p,y,!1,!1):t.xr(g,f,g,y,p,y),c=p,f=y}}}t.Ks(n.x+e,n.y+i)}}VE(t,e,i){const s=this.diagram;if(s===null||t.equals(e))return 0;const n=s.layers;for(;n.next();){const o=n.value;if(o!==null&&o.visible){const r=o.IM(),l=r.length;for(let a=0;a<l;a++){const h=r[a];if(!(h instanceof Link))continue;if(h===this)return i.length>0&&i.sort((u,d)=>u-d),i.length;if(!h.isVisible()||!h.Zh())continue;const c=h.routeBounds;if(!c.isReal()||!this.routeBounds.intersectsRect(c)||this.usesSamePort(h))continue;const f=h.path;f!==null&&f.isVisibleObject()&&this.BE(t,e,i,h)}}}return i.length>0&&i.sort((o,r)=>o-r),i.length}BE(t,e,i,s){const n=G.u(t.y,e.y),o=s.pointsCount;let r=s.getPoint(0);const l=Point.l();for(let a=1;a<o;a++){const h=s.getPoint(a);if(a<o-1){const c=s.getPoint(a+1);if(r.y===h.y&&h.y===c.y){if(h.x>r.x&&c.x>=h.x||h.x<r.x&&c.x<=h.x)continue}else if(r.x===h.x&&h.x===c.x&&(h.y>r.y&&c.y>=h.y||h.y<r.y&&c.y<=h.y))continue}this.zE(t,e,r,h,l)&&(n?i.push(l.x):i.push(l.y)),r=h}Point.i(l)}zE(t,e,i,s,n){const o=t.x,r=t.y,l=e.x,a=e.y,h=i.x,c=i.y,f=s.x,u=s.y;if(G.u(o,l)){if(!G.u(r,a)&&G.u(c,u)&&Math.min(r,a)<c&&Math.max(r,a)>c&&Math.min(h,f)<o&&Math.max(h,f)>o&&!G.u(h,f))return n.x=o,n.y=c,!0}else if(G.u(r,a)&&G.u(h,f)&&Math.min(o,l)<h&&Math.max(o,l)>h&&Math.min(c,u)<r&&Math.max(c,u)>r&&!G.u(c,u))return n.x=h,n.y=r,!0;return n.x=0,n.y=0,!1}get firstPickIndex(){return this.pointsCount<=2?0:this.isOrthogonal||!this.Qh(this.computeSpot(!0))?1:0}get lastPickIndex(){const t=this.pointsCount;return t===0?0:t<=2?t-1:this.isOrthogonal||!this.Qh(this.computeSpot(!1))?t-2:t-1}Zh(){const t=this.curve;return t===11||t===10}pk(t){if(t||this.Zh()){const e=this.diagram;e!==null&&!e.animationManager.isTicking&&!e.ra.has(this)&&(this.Gf.width!==0||this.Gf.height!==0)&&e.ra.set(this,this.Gf.copy())}}invalidateOtherJumpOvers(t){const e=this.layer;if(e===null||!e.visible||e.isTemporary)return;const i=e.diagram;if(i===null||i.animationManager.isTicking)return;let s=!1;const n=i.layers;for(;n.next();){const o=n.value;if(o.visible){if(o===e){s=!0;let r=!1;const l=o.IM(),a=l.length;for(let h=0;h<a;h++){const c=l[h];c instanceof Link&&(c===this?r=!0:r&&this.pv(c,t))}}else if(s){const r=o.IM(),l=r.length;for(let a=0;a<l;a++){const h=r[a];h instanceof Link&&this.pv(h,t)}}}}}pv(t,e){if(t===null||!t.bl||!t.Fi||!t.Zh())return;const i=t.routeBounds;i.isReal()&&(!this.routeBounds.intersectsRect(i)&&!e.intersectsRect(i)||this.usesSamePort(t)||t.Ze())}usesSamePort(t){const e=this.pointsCount,i=t.pointsCount;if(e>0&&i>0){const s=this.getPoint(0),n=t.getPoint(0);if(s.equalsApprox(n))return!0;const o=this.getPoint(e-1),r=t.getPoint(i-1);if(o.equalsApprox(r)||s.equalsApprox(r)||o.equalsApprox(n))return!0}else if(this.fromNode===t.fromNode||this.toNode===t.toNode||this.fromNode===t.toNode||this.toNode===t.fromNode)return!0;return!1}isVisible(){if(!super.isVisible())return!1;const t=this.containingGroup;let e=!0;const i=this.diagram;i!==null&&(e=i.isTreePathToChildren);const s=this.fromNode;if(s!==null){if(this.isTreeLink&&e&&!s.isTreeExpanded)return!1;if(s===t)return!0;let o=s;for(;o!==null;){if(o.labeledLink===this)return!0;o=o.containingGroup}const r=s.findVisibleNode();if(r===null||r===t)return!1}const n=this.toNode;if(n!==null){if(this.isTreeLink&&!e&&!n.isTreeExpanded)return!1;if(n===t)return!0;let o=n;for(;o!==null;){if(o.labeledLink===this)return!0;o=o.containingGroup}const r=n.findVisibleNode();if(r===null||r===t)return!1}return!0}Xe(t){if(super.Xe(t),t&&this.pk(!1),this.sr!==null&&this.sr.Wd(),this.on!==null){const i=this.on.iterator;for(;i.next();)i.value.Xe(t)}}get adjusting(){return this.Xf}set adjusting(t){const e=this.Xf;e!==t&&(this.Xf=t,this.t("adjusting",e,t))}computeAdjusting(){return this.isAvoiding&&this.diagram!==null&&this.diagram.animationManager.defaultAnimation.isAnimating?17:this.Xf}get corner(){return this.Zd}set corner(t){const e=this.Zd;e!==t&&(this.Zd=t,this.Ze(),this.t("corner",e,t))}get curve(){return this.Qd}set curve(t){const e=this.Qd;e!==t&&(this.Qd=t,this.$t(),this.Ze(),this.pk(e===10||e===11||t===10||t===11),this.t("curve",e,t))}get curviness(){return this._d}set curviness(t){const e=this._d;e!==t&&(this._d=t,this.$t(),this.Ze(),this.t("curviness",e,t))}get routing(){return this.qh}set routing(t){const e=this.qh;e!==t&&(this.qh=t,this.isAvoiding&&this.diagram!==null&&(this.diagram.rp=!0),this.ir=null,this.$t(),this.pk(Link.MC(e)||Link.MC(t)),this.t("routing",e,t))}get smoothness(){return this.tg}set smoothness(t){const e=this.tg;e!==t&&(this.tg=t,this.Ze(),this.t("smoothness",e,t))}Zy(){const t=this.po;if(t===null)return;const e=this.wo;if(e===null||!isNaN(this.curviness))return;const i=this.yo,s=this.xo;let n=null,o=null;const r=t.ee.r,l=r.length;for(let a=0;a<l;a++){const h=r[a];!(h.po===t&&h.yo===i&&h.wo===e&&h.xo===s)&&!(h.po===e&&h.yo===s&&h.wo===t&&h.xo===i)||(o===null?o=h:(n===null&&(n=[],n.push(o)),n.push(h)))}if(n!==null){let a=t.HD(e,i,s);a===null&&(a=new LinkBundle(t,i,e,s),t.YD(a),e.YD(a)),a.rn=n;for(let h=0;h<n.length;h++){const c=n[h];c.sr=a}a.Wd()}}$y(){const t=this.sr;if(t!==null){if(!isNaN(this.curviness))return;this.sr=null;const e=t.rn.indexOf(this);e>=0&&(t.rn.splice(e,1),t.Wd())}}Ar(){return!0}get key(){const t=this.diagram;if(!(t===null||!t.model.jh()))return t.model.getKeyForLinkData(this.data)}}class LinkBundle{Ko;qs;Xy;pC;ck;yC;rn;constructor(t,e,i,s){GSet.Je(this),this.Ko=!1,this.qs=!1,this.Xy=t,this.pC=e,this.ck=i,this.yC=s,this.rn=[]}Wd(){if(!this.Ko){const t=this.rn;if(t.length>0){const e=t[0].diagram;e!==null&&(e.s2.add(this),this.qs=e.undoManager.isUndoingRedoing)}}this.Ko=!0}k2(){if(this.Ko){this.Ko=!1;const t=this.rn;if(t.length>0){const e=t[0],i=e.diagram,s=i===null||i.$a&&!this.qs;this.qs=!1,e.arrangeBundledLinks(t,s),t.length===1&&(e.sr=null,t.length=0)}t.length===0&&(this.Xy.KD(this),this.ck.KD(this))}}}class PositionArray{fi;ui;ec;ic;we;xe;Vt;Fa;Ra;Ch;O2;Ko;_y;af;I2;E2;constructor(t){GSet.Je(this),this.Ch=null,this.O2=null,this.Ko=!0,this._y=!1,this.fi=1,this.ui=1,this.ec=-1,this.ic=-1,this.we=t.width,this.xe=t.height,this.Vt=[],this.Fa=0,this.Ra=0,this.af=Link.uv,this.I2=this.af*2,this.E2=this.af*2}static ln=0;static sc=1;static ig=999999;static IC=PositionArray.ig+1;static EC=PositionArray.ig+2;c1(t){if(t.width<=0||t.height<=0)return;const e=t.x,i=t.y,s=t.x+t.width,n=t.y+t.height;this.fi=Math.floor((e-this.we)/this.we)*this.we,this.ui=Math.floor((i-this.xe)/this.xe)*this.xe,this.ec=Math.ceil((s+2*this.we)/this.we)*this.we,this.ic=Math.ceil((n+2*this.xe)/this.xe)*this.xe;const o=1+(Math.ceil((this.ec-this.fi)/this.we)|0),r=1+(Math.ceil((this.ic-this.ui)/this.xe)|0);if(this.Vt.length===0||this.Fa<o-1||this.Ra<r-1){const l=[];for(let a=0;a<=o;a++)l[a]=new Uint32Array(r);this.Vt=l,this.Fa=o-1,this.Ra=r-1}this.XE(PositionArray.IC)}get bounds(){return new Rect(this.fi,this.ui,this.ec-this.fi,this.ic-this.ui)}get cellWidth(){return this.we}set cellWidth(t){t>0&&t!==this.we&&(this.we=t,this.c1(this.bounds))}get cellHeight(){return this.xe}set cellHeight(t){t>0&&t!==this.xe&&(this.xe=t,this.c1(this.bounds))}sg(t,e){return this.fi<=t&&t<=this.ec&&this.ui<=e&&e<=this.ic}bo(t,e){if(!this.sg(t,e))return PositionArray.IC;t-=this.fi,t/=this.we,e-=this.ui,e/=this.xe;const i=t|0,s=e|0;return this.Vt[i][s]}vO(t,e,i,s){if(!this.sg(t,e))return;const n=(t-this.fi)/this.we|0,o=(e-this.ui)/this.xe|0,r=(t+i-this.fi)/this.we|0,l=(e+s-this.ui)/this.xe|0,a=Math.min(r,this.Fa),h=Math.min(l,this.Ra);for(let c=n;c<=a;c++){const f=this.Vt[c];if(f.fill)f.fill(PositionArray.ln,o,h+1);else for(let u=o;u<=h;u++)f[u]=PositionArray.ln}}XE(t){for(let e=0;e<=this.Fa;e++){const i=this.Vt[e];if(i.fill)i.fill(t);else for(let s=0;s<=this.Ra;s++)i[s]=t}}TT(){for(let t=0;t<=this.Fa;t++){const e=this.Vt[t];for(let i=0;i<=this.Ra;i++)e[i]>=PositionArray.sc&&(e[i]=PositionArray.IC)}}GE(t,e){return this.bo(t,e)===PositionArray.ln}isUnoccupied(t,e,i,s){if(t>this.ec||t+i<this.fi||e>this.ic||e+s<this.ui)return!0;let n=(t-this.fi)/this.we|0,o=(e-this.ui)/this.xe|0,r=Math.max(0,i)/this.we+1|0,l=Math.max(0,s)/this.xe+1|0;if(n<0&&(r+=n,n=0),o<0&&(l+=o,o=0),r<0||l<0)return!0;const a=Math.min(n+r-1,this.Fa)|0,h=Math.min(o+l-1,this.Ra)|0;for(let c=n;c<=a;c++){const f=this.Vt[c];for(let u=o;u<=h;u++)if(f[u]===PositionArray.ln)return!1}return!0}maxAvoidsLinksSpaceH(t,e,i,s){if(t>this.ec||e<this.fi||i>this.ic||i<this.ui)return 0;const n=(t-this.fi)/this.we|0,o=(e-this.fi)/this.we|0,r=(i-this.ui)/this.xe|0,l=s/this.xe+1|0;let a;for(a=0;a<l/2;a++){let h=!1;for(let c=n;c<=o;c++)if(this.Vt[c][r+a]===PositionArray.ln||this.Vt[c][r-a]===PositionArray.ln){h=!0;break}if(h)return Math.max(0,(2*a-1)*this.xe)}return s}maxAvoidsLinksSpaceV(t,e,i,s){if(t>this.ic||e<this.ui||i>this.ec||i<this.fi)return 0;const n=(t-this.ui)/this.xe|0,o=(e-this.ui)/this.xe|0,r=(i-this.fi)/this.we|0,l=s/this.we+1|0;let a;for(a=0;a<l/2;a++){let h=!1;for(let c=n;c<=o;c++)if(this.Vt[r+a][c]===PositionArray.ln||this.Vt[r-a][c]===PositionArray.ln){h=!0;break}if(h)return Math.max(0,(2*a-1)*this.we)}return s}YE(t,e,i,s,n,o,r,l){t=t|0,e=e|0;let a=this.Vt[t][e];if(a>=PositionArray.sc&&a<PositionArray.ig)for(s?e+=i:t+=i,a+=1;n<=t&&t<=o&&r<=e&&e<=l;){const h=this.Vt[t][e];if(a>=h)break;this.Vt[t][e]=a,a+=1,s?e+=i:t+=i}return s?e:t}ko(t,e,i,s,n,o,r,l){if(t<n||t>o||e<r||e>l)return;const a=this.YE(t,e,i,s,n,o,r,l);if(s)if(i>0)for(let h=e+i;h<a;h+=i)this.ko(t,h,1,!s,n,o,r,l),this.ko(t,h,-1,!s,n,o,r,l);else for(let h=e+i;h>a;h+=i)this.ko(t,h,1,!s,n,o,r,l),this.ko(t,h,-1,!s,n,o,r,l);else if(i>0)for(let h=t+i;h<a;h+=i)this.ko(h,e,1,!s,n,o,r,l),this.ko(h,e,-1,!s,n,o,r,l);else for(let h=t+i;h>a;h+=i)this.ko(h,e,1,!s,n,o,r,l),this.ko(h,e,-1,!s,n,o,r,l)}kk(t,e,i,s,n,o,r,l,a,h){let c=t|0,f=e|0,u=PositionArray.ln,d=PositionArray.sc;for(this.Vt[c][f]=d;u===PositionArray.ln&&c>r&&c<l&&f>a&&f<h;)d+=1,this.Vt[c][f]=d,o?f+=n:c+=n,u=this.Vt[c][f];return o?f:c}Pk(t,e,i,s,n,o,r,l,a,h){let c=i|0,f=s|0,u=PositionArray.ln;const d=PositionArray.ig;for(this.Vt[c][f]=d;u===PositionArray.ln&&c>r&&c<l&&f>a&&f<h;)this.Vt[c][f]=d,o?f+=n:c+=n,u=this.Vt[c][f]}yv(t,e,i,s,n,o){this._y=!1;let r=t.x,l=t.y;if(!this.sg(r,l))return;r-=this.fi,r/=this.we,l-=this.ui,l/=this.xe;let a=i.x,h=i.y;if(!this.sg(a,h))return;if(a-=this.fi,a/=this.we,h-=this.ui,h/=this.xe,Math.abs(r-a)<=1&&Math.abs(l-h)<=1){this._y=!0;return}let c=n.x,f=n.y,u=n.x+n.width,d=n.y+n.height;c-=this.fi,c/=this.we,f-=this.ui,f/=this.xe,u-=this.fi,u/=this.we,d-=this.ui,d/=this.xe;const m=Math.max(0,Math.min(this.Fa,c|0)),g=Math.min(this.Fa,Math.max(0,u|0)),p=Math.max(0,Math.min(this.Ra,f|0)),y=Math.min(this.Ra,Math.max(0,d|0)),x=0,k=90,b=270,P=this.Vt,S=r|0,L=l|0,C=a|0,M=h|0,N=e===x||e===k?1:-1,T=e===k||e===b;P[S][L]===PositionArray.ln?(this.kk(S,L,C,M,N,T,m,g,p,y),this.kk(S,L,C,M,1,!T,m,g,p,y),this.kk(S,L,C,M,-1,!T,m,g,p,y)):this.kk(S,L,C,M,N,T,S,L,S,L),P[C][M]===PositionArray.ln?(this.Pk(S,L,C,M,s===x||s===k?1:-1,s===k||s===b,m,g,p,y),this.Pk(S,L,C,M,1,!(s===k||s===b),m,g,p,y),this.Pk(S,L,C,M,-1,!(s===k||s===b),m,g,p,y)):this.Pk(S,L,C,M,N,T,C,M,C,M);const A=U.ot();if(o&&this.wv(C,M,s,S,L,A)){(A[0]!==C||A[1]!==M)&&(A.unshift(M),A.unshift(C)),(A[A.length-2]!==S||A[A.length-1]!==L)&&(A.push(S),A.push(L));let D=PositionArray.sc,v=A[A.length-2],R=A[A.length-1];P[v][R]=D++;for(let F=A.length-4;F>=0;F-=2){v=A[F+2],R=A[F+3];const O=A[F],z=A[F+1];for(;O>v?v++:O<v?v--:z>R?R++:z<R&&R--,P[v][R]=D++,!(v===O&&R===z););}}else this.ko(S,L,1,!1,m,g,p,y),this.ko(S,L,-1,!1,m,g,p,y),this.ko(S,L,1,!0,m,g,p,y),this.ko(S,L,-1,!0,m,g,p,y);U.Z(A)}wv(t,e,i,s,n,o){const c=this.Vt;let f=t,u=e;for(;;){if(f===s&&u===n)return!0;let d=f,m=u;if(i===0)if(d<s)d++;else break;else if(i===90)if(m<n)m++;else break;else if(i===180)if(d>s)d--;else break;else if(m>n)m--;else break;const g=c[d][m];if(g===0||g===PositionArray.EC)break;f=d,u=m}for(;;){let d=i,m=f,g=u;i===0?g<n?(d=90,g++):g>n&&(d=270,g--):i===90?m<s?(d=0,m++):m>s&&(d=180,m--):i===180?g<n?(d=90,g++):g>n&&(d=270,g--):m<s?(d=0,m++):m>s&&(d=180,m--);const p=c[m][g];if(d!==i&&p!==0&&p!==PositionArray.EC){if(o.push(f),o.push(u),this.wv(f,u,d,s,n,o))return!0;o.pop(),o.pop()}if(c[f][u]=PositionArray.EC,i===0){if(f===t)return!1;f--}else if(i===90){if(u===e)return!1;u--}else if(i===180){if(f===t)return!1;f++}else{if(u===e)return!1;u++}}}}class Knot{Ri;kl;Ei;ng;constructor(t,e){GSet.Je(this),this.Ri=t,this.kl=e,this.Ei=[],this.ng=!1}toString(){const t=this.Ei;let e=this.Ri.toString()+" "+t.length.toString()+":";for(let i=0;i<t.length;i++){const s=t[i];s!==null&&(e+=`
  `+s.toString())}return e}KE(t,e,i,s){const n=e.offsetY;switch(n){case 8:return 90;case 2:return 180;case 1:return 270;case 4:return 0}let o=i;switch(n){case 9:return o>180?270:90;case 6:return o>90&&o<=270?180:0}const r=Math.atan2(t.height,t.width)*180/Math.PI;switch(n){case 3:return o>r&&o<=180+r?180:270;case 5:return o>180-r&&o<=360-r?270:0;case 12:return o>r&&o<=180+r?90:0;case 10:return o>180-r&&o<=360-r?180:90;case 7:return o>90&&o<=180+r?180:o>180+r&&o<=360-r?270:0;case 13:return o>180&&o<=360-r?270:o>r&&o<=180?90:0;case 14:return o>r&&o<=180-r?90:o>180-r&&o<=270?180:0;case 11:return o>180-r&&o<=180+r?180:o>180+r?270:90}return s&&n!==15&&(o-=15,o<0&&(o+=360)),o>r&&o<180-r?90:o>=180-r&&o<=180+r?180:o>180+r&&o<360-r?270:0}Wd(){this.Ei.length=0}dv(t){let e=this.Ei;e.length===0&&(this.HE(),e=this.Ei);for(let i=0;i<e.length;i++){const s=e[i];if(s!==null&&s.es===t)return s}return null}HE(){if(!this.ng){const t=this.ng;this.ng=!0;let e,i=null;const s=this.Ri,n=s instanceof Group?s:null;if(n!==null&&!n.isSubGraphExpanded){if(!n.actualBounds.isReal())return this.ng=t,this.Ei;i=n,e=i.findExternalLinksConnected()}else s.isTreeExpanded?e=s.findLinksConnected(this.kl.portId):e=s.findExternalTreeLinksConnected();this.Ei.length=0;let o=0;const r=this.kl.getDocumentPoint(Spot.TopLeft,Point.l()),l=this.kl.getDocumentPoint(Spot.BottomRight,Point.l()),a=Rect.z(r.x,r.y,0,0);a.unionPoint(l),Point.i(r),Point.i(l);const h=Point.z(a.x+a.width/2,a.y+a.height/2),c=this.kl.getDocumentAngle(),f=e.iterator;for(;f.next();){const g=f.value;if(!g.isVisible()||g.fromPort===g.toPort)continue;const p=g.fromPort===this.kl||i!==null&&g.fromNode!==null&&g.fromNode.isMemberOf(i),y=g.computeSpot(p,this.kl);if(!y.isSide())continue;let x;if(p?x=g.toPort:x=g.fromPort,x===null)continue;let k=x.part;if(k===null)continue;const b=k.findVisibleNode();b!==null&&b!==k&&(k=b,x=k.port);const P=g.computeOtherPoint(k,x);let S=h.directionPoint(P);c!==0&&(S=G.Ee(S-c));const L=this.KE(a,y,S,g.isOrthogonal);let C=0;L===0?(C=4,S>180&&(S-=360)):L===90?(C=8,S>270&&(S-=360)):L===180?C=2:(C=1,S<90&&(S+=360));let M=this.Ei[o];M===void 0?(M=new LinkInfo(g,S,C),this.Ei[o]=M):(M.es=g,M.Xt=S,M.ci=C),M.Sk.h(P),o++}Point.i(h),this.jE();const u=this.Ei.length;let d=-1,m=0;for(o=0;o<u;o++){const g=this.Ei[o];g!==void 0&&(g.ci!==d&&(d=g.ci,m=0),g.og=m,m++)}for(d=-1,m=0,o=u-1;o>=0;o--){const g=this.Ei[o];g!==void 0&&(g.ci!==d&&(d=g.ci,m=g.og+1),g.Kf=m)}this.qE(this.Ei),this.WE(this.Ei),this.ng=t,Rect.i(a)}return this.Ei}JE(t,e){return t===e?0:t===null?-1:e===null?1:t.ci<e.ci?-1:t.ci>e.ci?1:t.Xt<e.Xt?-1:t.Xt>e.Xt?1:0}jE(){this.Ei.sort(Knot.prototype.JE)}qE(t){const e=this.kl,i=this.Ri.portSpreading,s=Point.l(),n=Point.l(),o=Point.l(),r=Point.l();e.getDocumentPoint(Spot.TopLeft,s),e.getDocumentPoint(Spot.TopRight,n),e.getDocumentPoint(Spot.BottomRight,o),e.getDocumentPoint(Spot.BottomLeft,r);let l=0,a=0,h=0,c=0;if(i===2)for(let x=0;x<t.length;x++){const k=t[x];if(k===null)continue;const b=k.es.computeThickness();switch(k.ci){case 8:h+=b;break;case 2:c+=b;break;case 1:l+=b;break;default:case 4:a+=b;break}}let f=0,u=0,d=1,m=n,g=o,p=0,y=0;for(let x=0;x<t.length;x++){const k=t[x];if(k===null)continue;if(f!==k.ci){switch(f=k.ci,f){case 8:m=o,g=r;break;case 2:m=r,g=s;break;case 1:m=s,g=n;break;default:case 4:m=n,g=o;break}switch(p=g.x-m.x,y=g.y-m.y,f){case 8:h>Math.abs(p)?(d=Math.abs(p)/h,h=Math.abs(p)):d=1;break;case 2:c>Math.abs(y)?(d=Math.abs(y)/c,c=Math.abs(y)):d=1;break;case 1:l>Math.abs(p)?(d=Math.abs(p)/l,l=Math.abs(p)):d=1;break;default:case 4:a>Math.abs(y)?(d=Math.abs(y)/a,a=Math.abs(y)):d=1;break}u=0}const b=k._h;if(i===2){let P=k.es.computeThickness();switch(P*=d,b.h(m),f){case 8:b.x=m.x+p/2+h/2-u-P/2;break;case 2:b.y=m.y+y/2+c/2-u-P/2;break;case 1:b.x=m.x+p/2-l/2+u+P/2;break;default:case 4:b.y=m.y+y/2-a/2+u+P/2;break}u+=P}else{let P=.5;i===1&&(P=(k.og+1)/(k.Kf+1)),b.x=m.x+p*P,b.y=m.y+y*P}}Point.i(s),Point.i(n),Point.i(o),Point.i(r)}WE(t){for(let e=0;e<t.length;e++){const i=t[e];i!==null&&(i.xk=this.$E(i,e))}}$E(t,e){const i=t.es,s=i.fromPort===this.kl;let n=0;switch(t.ci){case 1:n=270;break;case 2:n=180;break;case 4:n=0;break;case 8:n=90;break}const o=i.yk(this.Ri,this.kl,Spot.None,s,n);let r=t.og;if(r<0)return o;const l=t.Kf;if(l<=1||!i.isOrthogonal)return o;const h=t.Sk,c=t._h,f=t.ci===2||t.ci===8;f&&(r=l-1-r);const u=Link.ev,d=t.ci===2||t.ci===4,m=r<=0?c:this.Ei[f?e+1:e-1]._h,g=r>=l-1?c:this.Ei[f?e-1:e+1]._h;return(d?h.y>=m.y&&h.y<=g.y:h.x>=m.x&&h.x<=g.x)?o:(d?h.y<c.y:h.x<c.x)?o+r*u:o+(l-1-r)*u}}class LinkInfo{es;Xt;ci;Sk;og;Kf;_h;xk;constructor(t,e,i){this.es=t,this.Xt=e,this.ci=i,this.Sk=new Point,this.og=0,this.Kf=0,this._h=new Point,this.xk=0}toString(){return this.es.toString()+" "+this.Xt.toString()+" "+this.ci.toString()+":"+this.og.toString()+"/"+this.Kf.toString()+" "+this._h.toString()+" "+this.xk.toString()+" "+this.Sk.toString()}}class LinkSettings{Ah;Th;Dh;vh;Fh;Rh;h0;l0;c0;a0;constructor(){this.Ah=Spot.Default,this.Th=Spot.Default,this.Dh=NaN,this.vh=NaN,this.Fh=NaN,this.Rh=NaN,this.h0=null,this.l0=null,this.c0=1/0,this.a0=1/0}copy(){const t=new LinkSettings;return t.Ah=this.Ah.N(),t.Th=this.Th.N(),t.Dh=this.Dh,t.vh=this.vh,t.Fh=this.Fh,t.Rh=this.Rh,t.h0=this.h0,t.l0=this.l0,t.c0=this.c0,t.a0=this.a0,t}}class LinkElementSettings{_p;t0;e0;Qp;H0;j0;constructor(){this._p=-1/0,this.t0=0,this.e0=Point.gn,this.Qp=0,this.H0="None",this.j0="None"}copy(){const t=new LinkElementSettings;return t._p=this._p,t.t0=this.t0,t.e0=this.e0.N(),t.Qp=this.Qp,t.H0=this.H0,t.j0=this.j0,t}}class Group extends Node{rg;Dt;Mh;vp;he;li;constructor(t,e){let i;t===void 0||t instanceof PanelLayout||typeof t=="string"?i=t:t&&(e=t),super(i),this.E=this.E|4608,this.rg=new GSet,this.Dt=null,this.li=new Layout,this.li.group=this,this.Mh=new GSet,this.vp=null,this.he=null,e&&Object.assign(this,e)}cloneProtected(t){super.cloneProtected(t),this.E=this.E&-32769;const e=t.findInVisualTree(i=>i instanceof Placeholder);e instanceof Placeholder?t.Dt=e:t.Dt=null,this.li!==null?(t.li=this.li.copy(),t.li.group=t):(t.li!==null&&(t.li.group=null),t.li=null),this.he!==null&&(t.he=this.he.copy())}jo(t){super.jo(t);const e=t.findSubGraphParts(),i=t.memberParts;for(;i.next();){const s=i.value;if(s.c(),s.invalidateLayout(8),s.clearAdornments(),s instanceof Node)s.invalidateConnectedLinks(e);else if(s instanceof Link){const n=s.labelNodes;for(;n.next();)n.value.invalidateConnectedLinks(e)}}}df(t,e,i,s,n,o,r){if(t===3&&e==="elements"){if(n instanceof Placeholder)this.Dt===null?this.Dt=n:this.Dt!==n&&U.o("Cannot insert a second Placeholder into the visual tree of a Group.");else if(n instanceof Panel){const l=n.findInVisualTree(a=>a instanceof Placeholder);l instanceof Placeholder&&(this.Dt===null?this.Dt=l:this.Dt!==l&&U.o("Cannot insert a second Placeholder into the visual tree of a Group."))}}else t===4&&e==="elements"&&this.Dt!==null&&(s===this.Dt?this.Dt=null:s instanceof Panel&&this.Dt.isContainedBy(s)&&(this.Dt=null));super.df(t,e,i,s,n,o,r)}bd(t,e){if(super.bd(t,e),this.isClipping&&this.type!==Panel.Spot&&this.isSubGraphExpanded){let i=this.resizeObject;i instanceof Panel&&(i=i.findMainElement()),this.he===null&&(this.he=new Rect),i.getDocumentBounds(this.he),i instanceof Shape&&this.he.inflate(-i.strokeWidth,-i.strokeWidth)}}Pa(t,e,i,s){this.hasPlaceholder()&&(this.er=this.placeholder),super.Pa(t,e,i,s)}ensureBounds(){this.isSubGraphExpanded&&this.memberParts.each(e=>{e.ensureBounds()}),super.ensureBounds()}_r(){if(!super._r())return!1;const t=this.memberParts;for(;t.next();){const e=t.value;if(e instanceof Node){if(!e.isVisible())continue;if(e.as())return!1}else if(e instanceof Link){if(!e.isVisible())continue;if(e.as()&&e.fromNode!==this&&e.toNode!==this)return!1}}return!0}hasPlaceholder(){return this.Dt!==null&&this.Dt.isVisibleObject()&&this.isSubGraphExpanded}get placeholder(){return this.Dt}get computesBoundsAfterDrag(){return(this.E&2048)!==0}set computesBoundsAfterDrag(t){const e=(this.E&2048)!==0;e!==t&&(this.E=this.E^2048,this.t("computesBoundsAfterDrag",e,t))}get computesBoundsIncludingLinks(){return(this.E&4096)!==0}set computesBoundsIncludingLinks(t){const e=(this.E&4096)!==0;e!==t&&(this.E=this.E^4096,this.t("computesBoundsIncludingLinks",e,t))}get computesBoundsIncludingLocation(){return(this.E&8192)!==0}set computesBoundsIncludingLocation(t){const e=(this.E&8192)!==0;e!==t&&(this.E=this.E^8192,this.t("computesBoundsIncludingLocation",e,t))}get handlesDragDropForMembers(){return(this.E&16384)!==0}set handlesDragDropForMembers(t){const e=(this.E&16384)!==0;e!==t&&(this.E=this.E^16384,this.t("handlesDragDropForMembers",e,t))}get avoidableMembers(){return(this.E&131072)!==0}set avoidableMembers(t){const e=(this.E&131072)!==0;e!==t&&(this.E=this.E^131072,this.t("avoidableMembers",e,t))}get memberParts(){return this.rg.iterator}uC(t){if(this.rg.add(t)){t instanceof Group&&this.Mh.add(t);const i=this.memberAdded;if(i!==null){let s=!0;const n=this.diagram;n!==null&&(s=n.G,n.G=!0),i(this,t),n!==null&&(n.G=s)}(!this.isVisible()||!this.isSubGraphExpanded)&&t.Xe(!1)}if(t instanceof Link&&!this.computesBoundsIncludingLinks)return;let e=this.Dt;e===null&&(e=this),e.c()}fC(t){if(this.rg.delete(t)){t instanceof Group&&this.Mh.delete(t);const i=this.memberRemoved;if(i!==null){let s=!0;const n=this.diagram;n!==null&&(s=n.G,n.G=!0),i(this,t),n!==null&&(n.G=s)}(!this.isVisible()||!this.isSubGraphExpanded)&&t.Xe(!0)}if(t instanceof Link&&!this.computesBoundsIncludingLinks)return;let e=this.Dt;e===null&&(e=this),e.c()}rf(){if(this.rg.count>0){const t=this.diagram;if(t!==null){const i=this.rg.copy().iterator;for(;i.next();){const s=i.value;t.remove(s)}}}super.rf()}get layout(){return this.li}set layout(t){const e=this.li;if(e!==t){t!==null&&t.diagram!==null&&t.diagram.layout===t&&U.o("A layout cannot be both the Diagram.layout and a Group.layout: "+t),e!==null&&(e.diagram=null,e.group=null),this.li=t;const i=this.diagram;t!==null&&(t.diagram=i,t.group=this),i!==null&&(i.$r=!0),this.t("layout",e,t),i!==null&&i.requestUpdate()}}get memberAdded(){return this.vt!==null?this.vt.qy:null}set memberAdded(t){const e=this.memberAdded;e!==t&&(t!==null&&U.S(t,Group,"memberAdded"),this.wl().qy=t,this.t("memberAdded",e,t))}get memberRemoved(){return this.vt!==null?this.vt.Wy:null}set memberRemoved(t){const e=this.memberRemoved;e!==t&&(t!==null&&U.S(t,Group,"memberRemoved"),this.wl().Wy=t,this.t("memberRemoved",e,t))}get memberValidation(){return this.vt!==null?this.vt.da:null}set memberValidation(t){const e=this.memberValidation;e!==t&&(t!==null&&U.S(t,Group,"memberValidation"),this.wl().da=t,this.t("memberValidation",e,t))}canAddMembers(t){const e=this.diagram;if(e===null)return!1;const i=e.commandHandler,n=i.wN(t).iterator;for(;n.next();){const o=n.value;if(!i.isValidMember(this,o))return!1}return!0}addMembers(t,e){const i=this.diagram;if(i===null)return!1;const s=i.commandHandler,n=s.wN(t);let o=!0;const r=n.iterator;for(;r.next();){const l=r.value;!e||s.isValidMember(this,l)?l.containingGroup=this:o=!1}return o}get ungroupable(){return(this.E&256)!==0}set ungroupable(t){const e=(this.E&256)!==0;e!==t&&(this.E=this.E^256,this.t("ungroupable",e,t))}canUngroup(){if(!this.ungroupable)return!1;const t=this.layer;if(t===null||!t.allowUngroup)return!1;const e=t.diagram;return!(e!==null&&!e.allowUngroup)}invalidateConnectedLinks(t){const e=this.ZE();if(super.invalidateConnectedLinks(t),e)return;this.cT(!0);const i=this.findExternalLinksConnected();for(;i.next();){const s=i.value;if(t!==void 0&&t.has(s))continue;const n=s.fromNode;if(n!==null&&n!==this&&n.isMemberOf(this)&&!n.isVisible())n.Pi(s.fromPort),n.Pi(s.toPort),s.$t();else{const o=s.toNode;o!==null&&o!==this&&o.isMemberOf(this)&&!o.isVisible()&&(o.Pi(s.fromPort),o.Pi(s.toPort),s.$t())}}}findExternalLinksConnected(){const t=this.diagram!==null&&this.diagram.f2;if(t&&this.vp!==null)return this.vp.iterator;const e=this.findSubGraphParts();e.add(this);const i=new GSet,s=e.iterator;for(;s.next();){const n=s.value;if(!(n instanceof Node))continue;const o=n.linksConnected;for(;o.next();){const r=o.value;e.has(r)||i.add(r)}}return t&&(this.vp=i),i.iterator}findExternalNodesConnected(){const t=this.findSubGraphParts();t.add(this);const e=new GSet,i=t.iterator;for(;i.next();){const s=i.value;if(!(s instanceof Node))continue;const n=s.linksConnected;for(;n.next();){const o=n.value,r=o.fromNode;r!==null&&(!t.has(r)||r===this)&&e.add(r);const l=o.toNode;l!==null&&(!t.has(l)||l===this)&&e.add(l)}}return e.iterator}XU(){function t(i,s){i!==null&&(s.add(i),t(i.containingGroup,s))}const e=new GSet;return t(this,e),e}findSubGraphParts(){const t=new GSet;return Part.ga(t,this,!0,0,!0),t.delete(this),t}Xe(t){super.Xe(t);const e=this.memberParts;for(;e.next();)e.value.Xe(t)}collapseSubGraph(){const t=this.diagram;if(t===null||t.isCollapsingExpanding)return;t.isCollapsingExpanding=!0;const e=this.findSubGraphParts();this.xv(e,t,this),t.isCollapsingExpanding=!1}xv(t,e,i){const s=this.memberParts;for(;s.next();){const n=s.value;if(n.Xe(!1),n instanceof Group&&n.isSubGraphExpanded&&(n.wasSubGraphExpanded=n.isSubGraphExpanded,n.xv(t,e,i)),n instanceof Node)n.invalidateConnectedLinks(t),e.Yc(n,i);else if(n instanceof Link){const o=n.labelNodes;for(;o.next();)o.value.invalidateConnectedLinks(t)}}this.isSubGraphExpanded=!1}expandSubGraph(){const t=this.diagram;if(t===null||t.isCollapsingExpanding)return;t.isCollapsingExpanding=!0;const e=this.findSubGraphParts();this.bv(e,t,this),t.isCollapsingExpanding=!1}bv(t,e,i){const s=this.memberParts;for(;s.next();){const n=s.value;if(n.Xe(!0),n instanceof Group&&n.wasSubGraphExpanded&&(n.wasSubGraphExpanded=!1,n.bv(t,e,i)),n instanceof Node)n.invalidateConnectedLinks(t);else if(n instanceof Link){const o=n.labelNodes;for(;o.next();)o.value.invalidateConnectedLinks(t)}}this.isSubGraphExpanded=!0}get isSubGraphExpanded(){return(this.E&512)!==0}set isSubGraphExpanded(t){const e=(this.E&512)!==0;if(e!==t){this.E=this.E^512;const i=this.diagram;this.t("isSubGraphExpanded",e,t);const s=this.subGraphExpandedChanged;if(s!==null){let n=!0;i!==null&&(n=i.G,i.G=!0),s(this),i!==null&&(i.G=n)}if(i!==null&&i.undoManager.isUndoingRedoing){this.Dt!==null&&this.Dt.c(),this.memberParts.each(n=>n.updateAdornments());return}t?this.expandSubGraph():this.collapseSubGraph()}}get wasSubGraphExpanded(){return(this.E&1024)!==0}set wasSubGraphExpanded(t){const e=(this.E&1024)!==0;e!==t&&(this.E=this.E^1024,this.t("wasSubGraphExpanded",e,t))}get subGraphExpandedChanged(){return this.vt!==null?this.vt.Jy:null}set subGraphExpandedChanged(t){const e=this.subGraphExpandedChanged;e!==t&&(t!==null&&U.S(t,Group,"subGraphExpandedChanged"),this.wl().Jy=t,this.t("subGraphExpandedChanged",e,t))}move(t,e){e===void 0&&(e=!1);const i=e?this.location:this.position,s=i.x,n=i.y,o=t.x,r=t.y;if((s===o||isNaN(s)&&isNaN(o))&&(n===r||isNaN(n)&&isNaN(r)))return;const l=o-(isNaN(s)?0:s),a=r-(isNaN(n)?0:n),h=Point.l();super.move(t,e);const c=new GSet,u=this.findSubGraphParts().iterator;for(;u.next();){const d=u.value;d instanceof Link&&(d.suspendsRouting&&c.add(d),!(!d.Fi&&(d.fromNode===this||d.toNode===this))&&(d.suspendsRouting=!0))}for(u.reset();u.next();){const d=u.value;if(d.Ar()||d instanceof Node&&d.isLinkLabel)continue;const m=d.position,g=d.location;m.isReal()?(h.x=m.x+l,h.y=m.y+a,d.position=h):g.isReal()&&(h.x=g.x+l,h.y=g.y+a,d.location=h)}for(u.reset();u.next();){const d=u.value;if(!(d instanceof Link)||(d.suspendsRouting=c.has(d),!d.Fi&&(d.fromNode===this||d.toNode===this)))continue;const m=d.position;h.x=m.x+l,h.y=m.y+a,h.isReal()?d.move(h):d.$t()}Point.i(h)}ZE(){return(this.E&65536)!==0}cT(t){(this.E&65536)!==0!==t&&(this.E=this.E^65536)}get Nh(){return(this.E&32768)!==0}set Nh(t){(this.E&32768)!==0!==t&&(this.E=this.E^32768)}}class Placeholder extends GraphObject{Qt;lg;constructor(t){super(),this.Qt=Margin.em,this.lg=new Rect(NaN,NaN,NaN,NaN),t&&Object.assign(this,t)}cloneProtected(t){super.cloneProtected(t),t.Qt=this.Qt.N(),t.lg=this.lg.copy()}ka(t){if(this.background===null)return!1;const e=this.naturalBounds;return Rect.contains(0,0,e.width,e.height,t.x,t.y)}xd(t,e,i,s){const n=this.part;if((n===null||!(n instanceof Group)&&!(n instanceof Adornment))&&U.o("Placeholder is not inside a Group or Adornment."),n instanceof Group){const o=this.computeBorder(this.lg),r=this.minSize,l=isFinite(r.width)?Math.max(r.width,o.width):o.width,a=isFinite(r.height)?Math.max(r.height,o.height):o.height,h=this.Ke;h.jn(l||0,a||0),this.lo(0,0,h.width,h.height);const c=n.memberParts;let f=!1;for(;c.next();)if(c.value.isVisible()){f=!0;break}const u=n.diagram;if(f&&u!==null&&!u.animationManager.NM(n)&&!isNaN(o.x)&&!isNaN(o.y)){const d=Point.l();d.setRectSpot(o,n.locationSpot),n.location=d,Point.i(d)}}else{const o=n,r=this.Ke,l=this.Qt,a=l.left+l.right,h=l.top+l.bottom,c=o.adornedObject,f=c.getDocumentAngle();o.angle=f;let u=0;c instanceof Shape&&(u=c.strokeWidth);const d=c.getDocumentScale(),m=c.naturalBounds,g=(m.width+u)*d,p=(m.height+u)*d;if(o.type!==Panel.Link){const y=o.category==="Selection"?Spot.TopLeft:o.locationSpot,x=c.getDocumentPoint(y,Point.l());o.location=x,Point.i(x)}if(!isNaN(g)&&!isNaN(p))r.jn(g+a||0,p+h||0),this.lo(-l.left,-l.top,r.width,r.height);else{const y=c.getDocumentPoint(Spot.TopLeft,Point.l()),x=Rect.z(y.x,y.y,0,0);x.unionPoint(c.getDocumentPoint(Spot.BottomRight,y)),x.unionPoint(c.getDocumentPoint(Spot.TopRight,y)),x.unionPoint(c.getDocumentPoint(Spot.BottomLeft,y)),r.jn(x.width+a||0,x.height+h||0),this.lo(-l.left,-l.top,r.width,r.height),Point.i(y),Rect.i(x)}}}Pa(t,e,i,s){this.actualBounds.e(t,e,i,s)}computeBorder(t){const e=this.part,i=e.diagram;if(i===null||i.animationManager.isAnimating)return t;if(e instanceof Group&&!e.layer.isTemporary&&e.computesBoundsAfterDrag&&this.lg.isReal()){const r=i.toolManager.findTool("Dragging");if(r===i.currentTool&&r.mR(e,this.lg,t))return t}const s=Rect.l(),n=this.computeMemberBounds(s),o=this.Qt;return e instanceof Group&&!e.isSubGraphExpanded?t.e(n.x-o.left,n.y-o.top,0,0):t.e(n.x-o.left,n.y-o.top,Math.max(n.width+o.left+o.right,0),Math.max(n.height+o.top+o.bottom,0)),Rect.i(s),e instanceof Group&&e.computesBoundsIncludingLocation&&e.location.isReal()&&t.unionPoint(e.location),t}computeMemberBounds(t){if(!(this.part instanceof Group))return t.e(0,0,0,0),t;const e=this.part;let i=1/0,s=1/0,n=-1/0,o=-1/0;const r=e.memberParts;for(;r.next();){const l=r.value;if(!l.isVisible()||l instanceof Link&&(!e.computesBoundsIncludingLinks||l.Go()||l.fromNode===e||l.toNode===e))continue;const a=l.actualBounds;a.left<i&&(i=a.left),a.top<s&&(s=a.top),a.right>n&&(n=a.right),a.bottom>o&&(o=a.bottom)}if(!isFinite(i)||!isFinite(s)){const l=e.location;t.e(l.x,l.y,0,0)}else t.e(i,s,n-i,o-s);return t}get padding(){return this.Qt}set padding(t){typeof t=="number"&&(t=new Margin(t));const e=this.Qt;e.equals(t)||(t=t.N(),this.Qt=t,this.t("padding",e,t),this.c())}}class Layout{a;Ch;ag;Tr;hg;cg;Vo;Pl;fg;ug;Po;constructor(t){GSet.Je(this),this.a=null,this.Ch=null,this.ag=!0,this.Tr=!0,this.hg=!1,this.cg=new Point(0,0),this.Vo=!0,this.Pl=null,this.fg=null,this.ug=!1,this.Po=null,t&&Object.assign(this,t)}cloneProtected(t){t.ag=this.ag,t.Tr=this.Tr,t.hg=this.hg,t.cg.h(this.cg),t.Vo=this.Vo,t.Pl=this.Pl,t.fg=this.fg,t.ug=!0}copy(){const t=new this.constructor;return this.cloneProtected(t),t}fe(t){U.dr(this,t)}toString(){let t=U.Hn(this.constructor);return t+="(",this.group!==null&&(t+=" in "+this.group),this.diagram!==null&&(t+=" for "+this.diagram),t+=")",t}get diagram(){return this.a}set diagram(t){this.a=t}get group(){return this.Ch}set group(t){this.Ch!==t&&(this.Ch=t,t!==null&&(this.a=t.diagram))}get isOngoing(){return this.ag}set isOngoing(t){this.ag!==t&&(U.s(t,"boolean",Layout,"isOngoing"),this.ag=t)}get isInitial(){return this.Tr}set isInitial(t){U.s(t,"boolean",Layout,"isInitial"),this.Tr=t,t||(this.ug=!0)}get isViewportSized(){return this.hg}set isViewportSized(t){this.hg!==t&&(U.s(t,"boolean",Layout,"isViewportSized"),this.hg=t,t&&this.p())}get isRouting(){return this.Vo}set isRouting(t){this.Vo!==t&&(U.s(t,"boolean",Layout,"isRouting"),this.Vo=t)}get isRealtime(){return this.Pl}set isRealtime(t){this.Pl!==t&&(t!==null&&U.s(t,"boolean",Layout,"isRealtime"),this.Pl=t)}get isValidLayout(){return this.ug}set isValidLayout(t){if(this.ug!==t&&(U.s(t,"boolean",Layout,"isValidLayout"),this.ug=t,!t)){const e=this.diagram;e!==null&&(e.$r=!0)}}invalidateLayout(){if(!this.isValidLayout)return;const t=this.diagram;if(t===null||t.undoManager.isUndoingRedoing)return;const e=t.animationManager;e.isTicking||(e.defaultAnimation.isAnimating&&e.stopAnimation(),(this.isOngoing&&t.$a||this.isInitial&&!t.$a)&&(this.isValidLayout=!1,t.requestUpdate()))}p(){this.invalidateLayout()}get network(){return this.Po}set network(t){this.Po!==t&&(this.Po=t,t!==null&&(t.layout=this))}createNetwork(){return new LayoutNetwork(this)}makeNetwork(t){const e=this.createNetwork();return t instanceof Diagram?(e.addParts(t.nodes,!0),e.addParts(t.links,!0)):t instanceof Group?e.addParts(t.memberParts):e.addParts(t.iterator),e}updateParts(){this.isValidLayout=!0;let t=this.diagram;if(t===null&&this.network!==null){const e=this.network.vertexes.iterator;for(;e.next();){const s=e.value.node;if(s!==null&&(t=s.diagram,t!==null))break}}try{t!==null&&t.startTransaction("Layout"),this.commitLayout()}finally{t!==null&&t.commitTransaction("Layout")}}commitLayout(){if(this.network===null)return;const t=this.network.vertexes.iterator;for(;t.next();)t.value.commit();if(this.isRouting){const e=this.network.edges.iterator;for(;e.next();)e.value.commit()}}doLayout(t){const e=new GSet;if(t instanceof Diagram?(this.Oa(e,t.nodes,!0,this.Nh,!0,!1,!0),this.Oa(e,t.parts,!0,this.Nh,!0,!1,!0)):t instanceof Group?this.Oa(e,t.memberParts,!1,this.Nh,!0,!1,!0):e.addAll(t.iterator),e.count>0){const s=this.diagram;s!==null&&s.startTransaction("Layout"),this.doMinimalNoNetworkLayout(e),s!==null&&s.commitTransaction("Layout")}this.isValidLayout=!0}doMinimalNoNetworkLayout(t){const e=t.count,i=Math.ceil(Math.sqrt(e));this.arrangementOrigin=this.initialOrigin(this.arrangementOrigin);const s=this.arrangementOrigin.x,n=this.arrangementOrigin.y;let o=s,r=n,l=0,a=0;const h=t.iterator;for(;h.next();){const c=h.value;c.ensureBounds();const f=c.measuredBounds,u=f.width,d=f.height;c.moveTo(o,r),c instanceof Group&&(c.Nh=!1),o+=Math.max(u,50)+20,a=Math.max(a,Math.max(d,50)),l>=i-1?(l=0,o=s,r+=a+20,a=0):l++}}Nh(t){return!!(!t.location.isReal()&&!t.position.isReal()||t instanceof Group&&t.Nh)}Oa(t,e,i,s,n,o,r){const l=e.iterator;for(;l.next();){const a=l.value;if(!(i&&!a.isTopLevel)&&!(s!==null&&!s(a))&&a.canLayout())if(n&&a instanceof Node){if(a.isLinkLabel)continue;a instanceof Group&&a.layout===null?this.Oa(t,a.memberParts,!1,s,n,o,r):(a.ensureBounds(),t.add(a))}else o&&a instanceof Link?t.add(a):r&&a.Di()&&!(a instanceof Node)&&(a.ensureBounds(),t.add(a))}}getLayoutBounds(t,e){const i=this.boundsComputation;return i!==null?(e||(e=new Rect),i(t,this,e)):!e&&t.margin.equalTo(0,0,0,0)?t.actualBounds:(e||(e=new Rect),e.set(t.actualBounds),e.addMargin(t.margin),e)}get boundsComputation(){return this.fg}set boundsComputation(t){this.fg!==t&&(t!==null&&U.S(t,Layout,"boundsComputation"),this.fg=t,this.p())}collectParts(t){const e=new GSet;return t instanceof Diagram?(this.Oa(e,t.nodes,!0,null,!0,!0,!0),this.Oa(e,t.links,!0,null,!0,!0,!0),this.Oa(e,t.parts,!0,null,!0,!0,!0)):t instanceof Group?this.Oa(e,t.memberParts,!1,null,!0,!0,!0):this.Oa(e,t.iterator,!1,null,!0,!0,!0),e}get arrangementOrigin(){return this.cg}set arrangementOrigin(t){this.cg.equals(t)||(this.cg.h(t),this.p())}initialOrigin(t){const e=this.group;if(e!==null)if(e.hasPlaceholder()){const i=e.placeholder,s=i.getDocumentPoint(Spot.TopLeft);(isNaN(s.x)||isNaN(s.y))&&s.set(t);const n=i.padding;return s.x+=n.left,s.y+=n.top,s}else{const i=e.position.copy();return(isNaN(i.x)||isNaN(i.y))&&i.set(t),i}return t}}class LayoutNetwork{li;So;In;tw;ew;constructor(t){GSet.Je(this),this.li=t,this.So=new GSet,this.In=new GSet,this.tw=new GMap,this.ew=new GMap}clear(){if(this.So){const t=this.So.iterator;for(;t.next();)t.value.clear()}if(this.In){const t=this.In.iterator;for(;t.next();)t.value.clear()}this.So=new GSet,this.In=new GSet,this.tw=new GMap,this.ew=new GMap}toString(t){t===void 0&&(t=0);let e="LayoutNetwork"+(this.layout!==null?"("+this.layout.toString()+")":"");if(t<=0)return e;if(e+=" vertexes: "+this.So.count+" edges: "+this.In.count,t>1){const i=this.So.iterator;for(;i.next();){const n=i.value;e+=`
    `+n.toString(t-1)}const s=this.In.iterator;for(;s.next();){const n=s.value;e+=`
    `+n.toString(t-1)}}return e}get layout(){return this.li}set layout(t){t!==null&&(this.li=t)}get vertexes(){return this.So}get edges(){return this.In}createVertex(){return new LayoutVertex(this)}createEdge(){return new LayoutEdge(this)}addParts(t,e,i){if(t===null)return;e===void 0&&(e=!1),U.s(e,"boolean",LayoutNetwork,"addParts:toplevelonly"),i===void 0&&(i=null),i===null&&(i=n=>{if(n instanceof Node)return!n.isLinkLabel;if(n instanceof Link){const o=n.fromNode;if(o===null||o.isLinkLabel)return!1;const r=n.toNode;return!(r===null||r.isLinkLabel)}return!1});const s=t.iterator;for(;s.next();){const n=s.value;if(n instanceof Node&&!(e&&!n.isTopLevel)&&n.canLayout()&&i(n))if(n instanceof Group&&n.layout===null)this.addParts(n.memberParts,!1);else{if(this.findVertex(n)!==null)continue;const o=this.createVertex();o.node=n,this.addVertex(o)}}for(s.reset();s.next();){const n=s.value;if(!(n instanceof Link)||e&&!n.isTopLevel||!n.canLayout()||!i(n)||this.findEdge(n)!==null)continue;const o=n.fromNode,r=n.toNode;if(o===null||r===null||o===r)continue;const l=this.findGroupVertex(o),a=this.findGroupVertex(r);this.linkVertexes(l,a,n)}}findGroupVertex(t){const e=t.findVisibleNode();if(e===null)return null;let i=this.findVertex(e);if(i!==null)return i;let s=e.containingGroup;for(;s!==null;){if(i=this.findVertex(s),i!==null)return i;s=s.containingGroup}return null}addVertex(t){this.So.add(t);const e=t.node;e!==null&&this.tw.set(e,t),t.network=this}addNode(t){let e=this.findVertex(t);return e===null&&(e=this.createVertex(),e.node=t,this.addVertex(e)),e}deleteVertex(t){if(this.kv(t)){let e=t.nr;for(let i=e.count-1;i>=0;i--){const s=e.elt(i);this.deleteEdge(s)}e=t.or;for(let i=e.count-1;i>=0;i--){const s=e.elt(i);this.deleteEdge(s)}}}kv(t){const e=this.So.delete(t);if(e){const i=t.node;i!==null&&this.tw.delete(i)}return e}deleteNode(t){const e=this.findVertex(t);e!==null&&this.deleteVertex(e)}findVertex(t){return this.tw.get(t)}addEdge(t){this.UC(t);const e=t.toVertex;e!==null&&e.addSourceEdge(t);const i=t.fromVertex;i!==null&&i.addDestinationEdge(t)}UC(t){this.In.add(t);const e=t.link;e!==null&&this.findEdge(e)===null&&this.ew.set(e,t),t.network=this}addLink(t){const e=t.fromNode,i=t.toNode;let s=this.findEdge(t);return s===null?(s=this.createEdge(),s.link=t,e!==null&&(s.fromVertex=this.addNode(e)),i!==null&&(s.toVertex=this.addNode(i)),this.addEdge(s)):(e!==null?s.fromVertex=this.addNode(e):s.fromVertex=null,i!==null?s.toVertex=this.addNode(i):s.toVertex=null),s}deleteEdge(t){const e=t.toVertex;e!==null&&e.deleteSourceEdge(t);const i=t.fromVertex;i!==null&&i.deleteDestinationEdge(t),this.VC(t)}VC(t){const e=this.In.delete(t);if(e){const i=t.link;i!==null&&this.ew.delete(i)}return e}deleteLink(t){const e=this.findEdge(t);e!==null&&this.deleteEdge(e)}findEdge(t){return this.ew.get(t)}linkVertexes(t,e,i){if(t===null||e===null)return null;if(t.network===this&&e.network===this){const s=this.createEdge();return s.link=i,s.fromVertex=t,s.toVertex=e,this.addEdge(s),s}return null}reverseEdge(t){const e=t.fromVertex,i=t.toVertex;e===null||i===null||(e.deleteDestinationEdge(t),i.deleteSourceEdge(t),t.reverseEdge(),e.addSourceEdge(t),i.addDestinationEdge(t))}deleteSelfEdges(){const t=U.ot(),e=this.In.iterator;for(;e.next();){const s=e.value;s.fromVertex===s.toVertex&&t.push(s)}const i=t.length;for(let s=0;s<i;s++)this.deleteEdge(t[s]);U.Z(t)}deleteArtificialVertexes(){const t=U.ot(),e=this.So.iterator;for(;e.next();){const o=e.value;o.node===null&&o.data===null&&t.push(o)}let i=t.length;for(let o=0;o<i;o++)this.deleteVertex(t[o]);const s=U.ot(),n=this.In.iterator;for(;n.next();){const o=n.value;o.link===null&&o.data===null&&s.push(o)}i=s.length;for(let o=0;o<i;o++)this.deleteEdge(s[o]);U.Z(t),U.Z(s)}deleteUselessEdges(){const t=U.ot(),e=this.In.iterator;for(;e.next();){const s=e.value;(s.fromVertex===null||s.toVertex===null)&&t.push(s)}const i=t.length;for(let s=0;s<i;s++)this.deleteEdge(t[s]);U.Z(t)}isSingleton(t){return!(t.nr.count>0||t.or.count>0)}splitIntoSubNetworks(t){t===void 0&&(t=!0),t&&(this.deleteArtificialVertexes(),this.deleteUselessEdges(),this.deleteSelfEdges());const e=new List;let i=!0;for(;i;){i=!1;const s=this.So.iterator;for(;s.next();){const n=s.value;if(this.isSingleton(n))continue;const o=this.layout.createNetwork();e.add(o),this.QE(o,n),i=!0;break}}return e.sort((s,n)=>s===null||n===null||s===n?0:n.vertexes.count-s.vertexes.count),e}QE(t,e){if(e===null)return;const i=new List;for(i.add(e);i.count>0;){const s=i.first();if(i.removeAt(0),!s||s.network===t)continue;this.kv(s),t.addVertex(s);let n=s.sourceEdges;for(;n.next();){const o=n.value;o.network!==t&&(this.VC(o),t.UC(o),o.fromVertex&&i.add(o.fromVertex))}for(n=s.destinationEdges;n.next();){const o=n.value;o.network!==t&&(this.VC(o),t.UC(o),o.toVertex&&i.add(o.toVertex))}}}findAllParts(){const t=new GSet,e=this.So.iterator;for(;e.next();){const s=e.value;s.node&&t.add(s.node)}const i=this.In.iterator;for(;i.next();){const s=i.value;s.link&&t.add(s.link)}return t}}class LayoutVertex{Po;te;Ri;Ui;is;nr;or;constructor(t){GSet.Je(this),this.Po=t,this.Ui=new Rect(0,0,10,10),this.is=new Point(5,5),this.te=null,this.Ri=null,this.nr=new List,this.or=new List}clear(){this.te=null,this.Ri=null,this.nr=new List,this.or=new List}toString(t){t===void 0&&(t=0);let e="LayoutVertex#"+GSet.xs(this);if(t>0&&(e+=this.node!==null?"("+this.node.toString()+")":"",t>1)){let i="",s=!0,n=this.nr.iterator;for(;n.next();){const r=n.value;s?s=!1:i+=",",i+=r.toString(0)}let o="";for(s=!0,n=this.or.iterator;n.next();){const r=n.value;s?s=!1:o+=",",o+=r.toString(0)}e+=" sources: "+i+" destinations: "+o}return e}get Mo(){return this.nr.AL}get rr(){return this.or.AL}get data(){return this.te}set data(t){if(this.te=t,t!==null&&t.bounds){const e=t.bounds,i=e.x,s=e.y,n=e.width,o=e.height;this.is.e(n/2,o/2),this.Ui.e(i,s,n,o)}}get node(){return this.Ri}set node(t){if(this.Ri!==t){if(this.Ri=t,t===null)return;t.ensureBounds();const e=this.network.layout,i=Rect.l(),s=e.getLayoutBounds(t,i);let n=s.x,o=s.y;const r=s.width,l=s.height;if(isNaN(n)&&(n=0),isNaN(o)&&(o=0),this.Ui.e(n,o,r,l),Rect.i(i),!(t instanceof Group)){const a=t.locationObject.getDocumentPoint(Spot.Center);if(a.isReal()){this.is.e(a.x-n,a.y-o);return}}this.is.e(r/2,l/2)}}get bounds(){return this.Ui}set bounds(t){this.Ui.equals(t)||this.Ui.h(t)}get focus(){return this.is}set focus(t){this.is.equals(t)||this.is.h(t)}get centerX(){return this.Ui.x+this.is.x}set centerX(t){const e=this.Ui;e.x+this.is.x!==t&&(e.x=t-this.is.x)}get centerY(){return this.Ui.y+this.is.y}set centerY(t){const e=this.Ui;e.y+this.is.y!==t&&(e.y=t-this.is.y)}get focusX(){return this.is.x}set focusX(t){const e=this.is;e.x!==t&&(e.x=t)}get focusY(){return this.is.y}set focusY(t){const e=this.is;e.y!==t&&(e.y=t)}get x(){return this.Ui.x}set x(t){const e=this.Ui;e.x!==t&&(e.x=t)}get y(){return this.Ui.y}set y(t){const e=this.Ui;e.y!==t&&(e.y=t)}get width(){return this.Ui.width}set width(t){const e=this.Ui;e.width!==t&&(e.width=t)}get height(){return this.Ui.height}set height(t){const e=this.Ui;e.height!==t&&(e.height=t)}commit(){const t=this.te;if(t!==null){const i=this.bounds,s=t.bounds;U.$(s)?(s.x=i.x,s.y=i.y,s.width=i.width,s.height=i.height):t.bounds=i.copy();return}const e=this.node;if(e!==null){const i=this.bounds;if(!(e instanceof Group)){const s=Rect.l();e.ensureBounds();const n=this.network.layout.getLayoutBounds(e,s),o=e.locationObject.getDocumentPoint(Spot.Center);if(n.isReal()&&o.isReal()){e.moveTo(i.x+this.focusX-(o.x-n.x)+e.margin.left,i.y+this.focusY-(o.y-n.y+e.margin.top)),Rect.i(s);return}Rect.i(s)}e.moveTo(i.x+e.margin.left,i.y+e.margin.top)}}addSourceEdge(t){t!==null&&(this.nr.has(t)||this.nr.add(t))}deleteSourceEdge(t){t!==null&&this.nr.delete(t)}addDestinationEdge(t){t!==null&&(this.or.has(t)||this.or.add(t))}deleteDestinationEdge(t){t!==null&&this.or.delete(t)}get network(){return this.Po}set network(t){this.Po=t}get sourceVertexes(){const t=new GSet,e=this.sourceEdges;for(;e.next();){const i=e.value;i.fromVertex&&t.add(i.fromVertex)}return t.iterator}get destinationVertexes(){const t=new GSet,e=this.destinationEdges;for(;e.next();){const i=e.value;i.toVertex&&t.add(i.toVertex)}return t.iterator}get vertexes(){const t=new GSet;let e=this.sourceEdges;for(;e.next();){const i=e.value;i.fromVertex&&t.add(i.fromVertex)}for(e=this.destinationEdges;e.next();){const i=e.value;i.toVertex&&t.add(i.toVertex)}return t.iterator}get sourceEdges(){return this.nr.iterator}get destinationEdges(){return this.or.iterator}get edges(){const t=new List;let e=this.sourceEdges;for(;e.next();){const i=e.value;t.add(i)}for(e=this.destinationEdges;e.next();){const i=e.value;t.add(i)}return t.iterator}get edgesCount(){return this.nr.count+this.or.count}static standardComparer(t,e){const i=t.Ri,s=e.Ri;if(i)if(s){const n=i.text,o=s.text;return n<o?-1:n>o?1:0}else return 1;else return s!==null?-1:0}static smartComparer(t,e){if(t!==null)if(e!==null){const i=t.Ri,s=e.Ri;if(i!==null)if(s!==null){const n=i.text.toLocaleLowerCase(),o=s.text.toLocaleLowerCase(),r=n.split(/([+-]?[.]?\d+(?:\.\d*)?(?:e[+-]?\d+)?)/),l=o.split(/([+-]?[.]?\d+(?:\.\d*)?(?:e[+-]?\d+)?)/);let a=0;for(;a<r.length;a++)if(l[a]!==""&&l[a]!==void 0){const h=parseFloat(r[a]),c=parseFloat(l[a]);if(isNaN(h))if(isNaN(c)){if(r[a].localeCompare(l[a])!==0)return r[a].localeCompare(l[a]);continue}else return 1;else{if(isNaN(c))return-1;if(h-c!==0)return h-c;continue}}else{if(r[a]==="")continue;return 1}return l[a]!==""&&l[a]!==void 0?-1:0}else return 1;else return s!==null?-1:0}else return 1;else return e!==null?-1:0}}class LayoutEdge{Po;te;es;ss;ns;constructor(t){GSet.Je(this),this.Po=t,this.te=null,this.es=null,this.ss=null,this.ns=null}clear(){this.te=null,this.es=null,this.ss=null,this.ns=null}toString(t){t===void 0&&(t=0);let e="LayoutEdge#"+GSet.xs(this);return t>0&&(e+=this.es!==null?"("+this.es.toString()+")":"",t>1&&(e+=" "+(this.ss?this.ss.toString():"null")+" --> "+(this.ns?this.ns.toString():"null"))),e}reverseEdge(){const t=this.ss;this.ss=this.ns,this.ns=t}commit(){}getOtherVertex(t){return this.ns===t?this.ss:this.ss===t?this.ns:null}get network(){return this.Po}set network(t){this.Po=t}get data(){return this.te}set data(t){this.te!==t&&(this.te=t)}get link(){return this.es}set link(t){this.es!==t&&(this.es=t)}get fromVertex(){return this.ss}set fromVertex(t){this.ss!==t&&(this.ss=t)}get toVertex(){return this.ns}set toVertex(t){this.ns!==t&&(this.ns=t)}}var GridAlignment=(w=>(w[w.Position=0]="Position",w[w.Location=1]="Location",w))(GridAlignment||{}),GridArrangement=(w=>(w[w.LeftToRight=10]="LeftToRight",w[w.RightToLeft=11]="RightToLeft",w))(GridArrangement||{}),GridSorting=(w=>(w[w.Forwards=20]="Forwards",w[w.Reverse=21]="Reverse",w[w.Ascending=22]="Ascending",w[w.Descending=23]="Descending",w))(GridSorting||{});class GridLayout extends Layout{dg;gg;Oo;En;de;He;Si;Mi;constructor(t){super(),this.isViewportSized=!0,this.dg=NaN,this.gg=NaN,this.Oo=new Size(NaN,NaN).b(),this.En=new Size(10,10).b(),this.de=1,this.He=10,this.Si=22,this.Mi=GridLayout.standardComparer,t&&Object.assign(this,t)}cloneProtected(t){super.cloneProtected(t),t.dg=this.dg,t.gg=this.gg,t.Oo.h(this.Oo),t.En.h(this.En),t.de=this.de,t.He=this.He,t.Si=this.Si,t.Mi=this.Mi}fe(t){t in GridSorting?this.sorting=t:t in GridArrangement?this.arrangement=t:t in GridAlignment?this.alignment=t:super.fe(t)}doLayout(t){this.arrangementOrigin=this.initialOrigin(this.arrangementOrigin);const e=this.collectParts(t),i=this.diagram,n=e.copy().iterator;for(;n.next();){const m=n.value;if(m.Ar()&&(m.fromNode!==null||m.toNode!==null)){e.delete(m);continue}if(m.ensureBounds(),m instanceof Group){const g=m.memberParts;for(;g.next();){const p=g.value;e.delete(p)}}}const o=e.toArray();if(o.length===0)return;switch(this.sorting){case 20:break;case 21:o.reverse();break;case 22:o.sort(this.comparer);break;case 23:o.sort(this.comparer),o.reverse();break}let r=this.wrappingColumn;isNaN(r)&&(r=0);let l=this.wrappingWidth;if(isNaN(l)&&i!==null){const m=i.viewportBounds,g=i.padding;l=Math.max(m.width-g.left-g.right,0)}else l=Math.max(this.wrappingWidth,0);r<=0&&l<=0&&(r=1);let a=this.spacing.width;isFinite(a)||(a=0);let h=this.spacing.height;isFinite(h)||(h=0),i!==null&&i.startTransaction("Layout");const c=[];switch(this.alignment){case 0:this._E(o,l,r,a,h,c);break;case 1:this.t3(o,l,r,a,h,c);break}let f=0,u=0,d=0;for(let m=0;m<c.length;m++){const g=c[m];f=Math.min(f,g.x),u=Math.min(u,g.y),d=Math.max(d,g.x+g.width)}this.arrangement===11?this.commitLayers(c,new Point(f+a/2-(d+f),u-h/2)):this.commitLayers(c,new Point(f-a/2,u-h/2)),i!==null&&i.commitTransaction("Layout"),this.isValidLayout=!0}_E(t,e,i,s,n,o){const r=Rect.l();let l=Math.max(this.cellSize.width,1);if(!isFinite(l)){l=0;for(let p=0;p<t.length;p++){const y=t[p],x=this.getLayoutBounds(y,r);l=Math.max(l,x.width)}}l+=s,l=Math.max(l,1);let a=Math.max(this.cellSize.height,1);if(!isFinite(a)){a=0;for(let p=0;p<t.length;p++){const y=t[p],x=this.getLayoutBounds(y,r);a=Math.max(a,x.height)}}a+=n,a=Math.max(a,1);const h=this.arrangement,c=this.arrangementOrigin.x,f=this.arrangementOrigin.y;let u=c,d=f,m=0,g=0;for(let p=0;p<t.length;p++){const y=t[p],x=this.getLayoutBounds(y,r),k=Math.ceil((x.width+s)/l),b=Math.ceil((x.height+n)/a),P=k*l,S=b*a;let L=0;switch(h){case 11:L=Math.abs(u-x.width);break;default:L=u+x.width;break}(i>0&&m>i-1||e>0&&m>0&&L-c>e)&&(o.push(new Rect(0,d,e+s,g)),m=0,u=c,d+=g,g=0),g=Math.max(g,S);let C=0;switch(h){case 11:C=-x.width;break;default:C=0;break}switch(y.moveTo(u+C+y.margin.left,d+y.margin.top),h){case 11:u-=P;break;default:u+=P;break}m++}o.push(new Rect(0,d,e+s,g)),Rect.i(r)}t3(t,e,i,s,n,o){const r=Rect.l();let l=Math.max(this.cellSize.width,1),a=0,h=0,c=0;const f=Point.l();for(let C=0;C<t.length;C++){const M=t[C],N=this.getLayoutBounds(M,r),T=M.getRelativePoint(M.locationObject,M.locationSpot,f);a=Math.max(a,T.x),h=Math.max(h,N.width-T.x),c=Math.max(c,T.y)}const u=this.arrangement;switch(u){case 11:a+=s;break;default:h+=s;break}isFinite(l)?l=Math.max(l+s,1):l=Math.max(a+h,1);const d=this.arrangementOrigin.x,m=this.arrangementOrigin.y;let g=d,p=m,y=0;e>=a&&(e-=a);let x=0,k=0;const b=Math.max(this.cellSize.height,1);c=0;let P=0,S=!0;const L=Point.l();for(let C=0;C<t.length;C++){const M=t[C],N=this.getLayoutBounds(M,r),T=M.getRelativePoint(M.locationObject,M.locationSpot,f);if(y>0)switch(u){case 11:{let D=(g-d-(N.width-T.x))/l;G.X(Math.round(D),D)?D=Math.round(D):D=Math.floor(D),g=D*l+d;break}default:{let D=(g-d+T.x)/l;G.X(Math.round(D),D)?D=Math.round(D):D=Math.ceil(D),g=D*l+d;break}}else switch(u){case 11:x=g+T.x+N.width;break;default:x=g-T.x;break}let A=0;switch(u){case 11:A=-(g+T.x)+x;break;default:A=g+N.width-T.x-x;break}if(i>0&&y>i-1||e>0&&y>0&&A>e){o.push(new Rect(0,S?p-c:p,e+s,P+c+n));for(let D=0;D<y&&C!==y;D++){const v=t[C-y+D],R=v.getRelativePoint(v.locationObject,v.locationSpot,L);v.moveTo(v.position.x,v.position.y+c-R.y)}P+=n,S?p+=P:p+=P+c,c=0,P=0,y=0,g=d,S=!1}switch(g===d&&(u===11?k=Math.max(k,N.width-T.x):k=Math.min(k,-T.x)),c=Math.max(c,T.y),P=Math.max(P,N.height-T.y),isFinite(b)&&(P=Math.max(P,Math.max(N.height,b)-T.y)),S?M.moveTo(g-T.x,p-T.y):M.moveTo(g-T.x,p),u){case 11:g-=T.x+s;break;default:g+=N.width-T.x+s;break}y++}if(o.push(new Rect(0,p,e+s,(S?P:P+c)+n)),t.length!==y)for(let C=0;C<y;C++){const M=t[t.length-y+C],N=M.getRelativePoint(M.locationObject,M.locationSpot,f);M.moveTo(M.position.x,M.position.y+c-N.y)}if(Point.i(f),Point.i(L),u===11)for(let C=0;C<o.length;C++){const M=o[C];M.width+=k,M.x-=k}else for(let C=0;C<o.length;C++){const M=o[C];M.x>k&&(M.width+=M.x-k,M.x=k)}Rect.i(r)}commitLayers(t,e){}get wrappingWidth(){return this.dg}set wrappingWidth(t){this.dg!==t&&(U.s(t,"number",GridLayout,"wrappingWidth"),(t>0||isNaN(t))&&(this.dg=t,this.isViewportSized=isNaN(t),this.p()))}get wrappingColumn(){return this.gg}set wrappingColumn(t){this.gg!==t&&(U.s(t,"number",GridLayout,"wrappingColumn"),(t>0||isNaN(t))&&(this.gg=t,this.p()))}get cellSize(){return this.Oo}set cellSize(t){this.Oo.equals(t)||(this.Oo.h(t),this.p())}get spacing(){return this.En}set spacing(t){this.En.equals(t)||(this.En.h(t),this.p())}get alignment(){return this.de}set alignment(t){this.de!==t&&(t===1||t===0)&&(this.de=t,this.p())}get arrangement(){return this.He}set arrangement(t){this.He!==t&&(t===10||t===11)&&(this.He=t,this.p())}get sorting(){return this.Si}set sorting(t){this.Si!==t&&(t===20||t===21||t===22||t===23)&&(this.Si=t,this.p())}get comparer(){return this.Mi}set comparer(t){this.Mi!==t&&(U.S(t,GridLayout,"comparer"),this.Mi=t,this.p())}static standardComparer(t,e){const i=t.text,s=e.text;return i<s?-1:i>s?1:0}static smartComparer(t,e){if(t!==null)if(e!==null){const i=t.text.toLocaleLowerCase(),s=e.text.toLocaleLowerCase(),n=i.split(/([+-]?[.]?\d+(?:\.\d*)?(?:e[+-]?\d+)?)/),o=s.split(/([+-]?[.]?\d+(?:\.\d*)?(?:e[+-]?\d+)?)/);let r=0;for(;r<n.length;r++)if(o[r]!==""&&o[r]!==void 0){const l=parseFloat(n[r]),a=parseFloat(o[r]);if(isNaN(l))if(isNaN(a)){if(n[r].localeCompare(o[r])!==0)return n[r].localeCompare(o[r]);continue}else return 1;else{if(isNaN(a))return-1;if(l-a!==0)return l-a;continue}}else{if(n[r]==="")continue;return 1}return o[r]!==""&&o[r]!==void 0?-1:0}else return 1;else return e!==null?-1:0}static Position=0;static Location=1;static LeftToRight=10;static RightToLeft=11;static Forward=20;static Reverse=21;static Ascending=22;static Descending=23}class PartManager{mg;rn;Ct;No;pg;yg;a;BC;constructor(){this.mg=new GSet,this.rn=new GSet,this.Ct=new GSet,this.No=new GMap,this.pg=new GMap,this.yg=new GMap,this.a=null,this.BC=!1}clear(){this.mg.clear(),this.rn.clear(),this.Ct.clear(),this.No.clear(),this.pg.clear(),this.yg.clear()}Eo(t){this.a=t}ah(t){if(t instanceof Node){if(this.mg.add(t),t instanceof Group){const i=t.containingGroup;i===null?this.diagram.Zr.add(t):i.Mh.add(t);const s=t.layout;s!==null&&(s.diagram=this.diagram)}}else t instanceof Link?(this.rn.add(t),t.isAvoiding&&(this.diagram.rp=!0)):t instanceof Adornment||this.Ct.add(t);const e=t.data;e!==null&&(t instanceof Adornment||(t instanceof Link?this.Pv(e,t):this.No.set(e,t)))}ri(t){if(t.clearAdornments(),t instanceof Node){if(this.mg.delete(t),t instanceof Group){const i=t.containingGroup;i===null?this.diagram.Zr.delete(t):i.Mh.delete(t);const s=t.layout;s!==null&&(s.diagram=null)}}else t instanceof Link?this.rn.delete(t):t instanceof Adornment||this.Ct.delete(t);const e=t.data;e!==null&&(t instanceof Adornment||(t instanceof Link?this.Sv(e,t):this.No.delete(e)))}Pv(t,e){this.pg.set(t,e)}Sv(t,e){this.pg.delete(t)}rebuildParts(){const t=this.diagram;if(t===null)return;const e=t.nodeTemplateMap.iterator;for(;e.next();){const u=e.value,d=e.key;(!u.Di()||u instanceof Group)&&U.o(`Invalid node template in Diagram.nodeTemplateMap: template for "${d}" must be a Node or a simple Part, not a Group or Link: ${u}`)}const i=t.groupTemplateMap.iterator;for(;i.next();){const u=i.value,d=i.key;u instanceof Group||U.o(`Invalid group template in Diagram.groupTemplateMap: template for "${d}" must be a Group, not a normal Node or Link: ${u}`)}const s=t.linkTemplateMap.iterator;for(;s.next();){const u=s.value,d=s.key;u instanceof Link||U.o(`Invalid link template in Diagram.linkTemplateMap: template for "${d}" must be a Link, not a normal Node or simple Part: ${u}`)}const n=U.ot(),o=t.selection.iterator;for(;o.next();){const d=o.value.data;d&&n.push(d)}const r=U.ot(),l=t.highlighteds.iterator;for(;l.next();){const d=l.value.data;d&&r.push(d)}const a=U.ot(),h=this.nodes.iterator;for(;h.next();){const u=h.value;u.data!==null&&(a.push(u.data),a.push(u.location))}const c=this.links.iterator;for(;c.next();){const u=c.value;u.data!==null&&(a.push(u.data),a.push(u.location))}const f=this.parts.iterator;for(;f.next();){const u=f.value;u.data!==null&&(a.push(u.data),a.push(u.location))}this.Mv(),this.T2();for(let u=0;u<n.length;u++){const d=this.findPartForData(n[u]);d!==null&&(d.isSelected=!0)}for(let u=0;u<r.length;u++){const d=this.findPartForData(r[u]);d!==null&&(d.isHighlighted=!0)}for(let u=0;u<a.length;u+=2){const d=this.findPartForData(a[u]);d!==null&&(d.location=a[u+1])}U.Z(n),U.Z(r),U.Z(a)}T2(){const t=this.diagram.model;this.iw(t.nodeDataArray)}iw(t,e){const i=this.diagram.model;t.forEach(s=>{i.containsNodeData(s)&&this.Nv(s,!1)}),t.forEach(s=>{i.containsNodeData(s)&&this.Mk(s)}),e!==!1&&this.diagram.h1(!1)}Nv(t,e){if(t==null||this.diagram.undoManager.isUndoingRedoing||this.No.has(t))return null;e===void 0&&(e=!0);const i=this.e3(t);return i!==null&&e&&this.Mk(t),i}e3(t){if(t==null||this.diagram.undoManager.isUndoingRedoing||this.No.has(t))return null;const e=this.i3(t),i=this.findTemplateForNodeData(t,e);if(i!==null){i.It();const s=i.copy();if(s!==null){const n=this.diagram.yi;return this.diagram.yi=!0,s._o=e,s.te=t,this.addsToTemporaryLayer&&(s.dl="Tool"),this.diagram.add(s),s.te=null,s.data=t,this.diagram.yi=n,s}}return null}insertLink(t,e,i,s){return null}Mk(t){}i3(t){return this.diagram.model.getCategoryForNodeData(t)}static Cv=!1;static Lv=!1;findTemplateForNodeData(t,e){const i=this.diagram,s=i.model,n=s.ff()&&s.isGroupForData(t);let o=null;return n?(o=i.groupTemplateMap.get(e),o===null&&(o=i.groupTemplateMap.get(""),o===null&&(PartManager.Lv||(PartManager.Lv=!0,U.ne('No Group template found for category "'+e+'"'),U.ne("  Using default group template")),o=i.i2))):(o=i.nodeTemplateMap.get(e),o===null&&(o=i.nodeTemplateMap.get(""),o===null&&(PartManager.Cv||(PartManager.Cv=!0,U.ne('No Node template found for category "'+e+'"'),U.ne("  Using default node template")),o=i._M))),o}getLinkCategoryForData(t){return""}setLinkCategoryForData(t,e){}setFromNodeForLink(t,e,i){}setToNodeForLink(t,e,i){}static Av=!1;findLinkTemplateForCategory(t){const e=this.diagram;let i=e.linkTemplateMap.get(t);return i===null&&(i=e.linkTemplateMap.get(""),i===null&&(PartManager.Av||(PartManager.Av=!0,U.ne('No Link template found for category "'+t+'"'),U.ne("  Using default link template")),i=e.t2)),i}qI(t,e,i){t instanceof Link?(e!==null&&this.Sv(e,t),i!==null&&this.Pv(i,t)):t instanceof Part&&(e!==null&&this.No.delete(e),i!==null&&this.No.set(i,t))}Mv(){const t=this.diagram.model;this.zC(t.nodeDataArray)}zC(t){t.forEach(e=>{this.Nk(e)})}Nk(t){const e=this.findPartForData(t);e!==null&&(this.diagram.C2(e,!1),this.XC(e))}XC(t){}AC(t){}findPartForKey(t){if(t==null)return null;const i=this.diagram.model.findNodeDataForKey(t);return i!==null?this.No.get(i):null}findNodeForKey(t){if(t==null)return null;const i=this.diagram.model.findNodeDataForKey(t);if(i===null)return null;const s=this.No.get(i);return s instanceof Node?s:null}findLinkForKey(t){return null}findPartForData(t){if(t===null)return null;let e=this.No.get(t);return e!==null||(e=this.pg.get(t)),e}findNodeForData(t){if(t===null)return null;const e=this.No.get(t);return e instanceof Node?e:null}findLinkForData(t,e){return t===null?null:this.pg.get(t)}findNodesByExample(...t){const e=new GSet,i=this.mg.iterator;for(;i.next();){const s=i.value,n=s.data;if(n!==null)for(let o=0;o<arguments.length;o++){const r=arguments[o];if(U.$(r)&&this.GC(n,r)){e.add(s);break}}}return e.iterator}findLinksByExample(...t){const e=new GSet,i=this.rn.iterator;for(;i.next();){const s=i.value,n=s.data;if(n!==null)for(let o=0;o<arguments.length;o++){const r=arguments[o];if(U.$(r)&&this.GC(n,r)){e.add(s);break}}}return e.iterator}GC(t,e){for(const i in e){const s=t[i],n=e[i];if(Array.isArray(n)){if(!Array.isArray(s))return!1;const o=s,r=n;if(o.length<r.length)return!1;for(let l=0;l<o.length;l++){const a=o[l],h=r[l];if(h!==void 0&&!this.Tv(a,h))return!1}}else if(!this.Tv(s,n))return!1}return!0}Tv(t,e){if(U.nt(e)){if(!e(t))return!1}else if(e instanceof RegExp){if(!t||!e.test(t.toString()))return!1}else if(U.$(t)&&U.$(e)){if(!this.GC(t,e))return!1}else if(t!==e)return!1;return!0}doModelDataChanged(t){if(t.model===this.diagram.model&&this.diagram.G){this.diagram.G=!1;try{const e=t.change;t.modelChange===""&&t.object!==null&&e===2&&this.nw(t.object,t.propertyName)}finally{this.diagram.G=!0}}}doModelChanged(t){const e=this.diagram;if(!e||t.model!==e.model)return;const i=t.change;if(e.LO(t),!!e.G){e.G=!1;try{const s=t.modelChange;if(s!=="")if(i===2){if(s==="nodeCategory"){const n=t.object;if(n!==null){const o=this.findPartForData(n),r=t.newValue;o!==null&&typeof r=="string"&&(o.category=r)}}else if(s==="nodeDataArray"){const n=t.oldValue;this.zC(n);const o=t.newValue;this.iw(o)}e.isModified=!0}else if(i===3){const n=t.newValue;s==="nodeDataArray"&&U.$(n)&&this.Nv(n),e.isModified=!0}else if(i===4){const n=t.oldValue;s==="nodeDataArray"&&U.$(n)&&this.Nk(n),e.isModified=!0}else i===1&&(s==="SourceChanged"?t.object!==null?this.nw(t.object,t.propertyName):(this.updateAllRelationshipsFromData(),this.updateAllTargetBindings()):s==="ModelDisplaced"&&this.rebuildParts());else if(i===2){const n=t.propertyName,o=t.object,r=e.model;o===r?(n==="nodeKeyProperty"||n==="nodeCategoryProperty")&&(e.undoManager.isUndoingRedoing||this.rebuildParts()):o!==null&&this.nw(o,n),e.isModified=!0}else(i===3||i===4)&&(this.s3(t,e.model),e.isModified=!0)}finally{e.G=!0}}}updateAllTargetBindings(t){t===void 0&&(t="");let e=this.parts.iterator;for(;e.next();)e.value.updateTargetBindings(t);for(e=this.nodes.iterator;e.next();)e.value.updateTargetBindings(t);for(e=this.links.iterator;e.next();)e.value.updateTargetBindings(t)}updateAllThemeBindings(){let t=this.parts.iterator;for(;t.next();)t.value.Yo();for(t=this.nodes.iterator;t.next();)t.value.Yo();for(t=this.links.iterator;t.next();)t.value.Yo()}updateAllRelationshipsFromData(){const t=this.diagram.model,e=new GSet,i=t.nodeDataArray;for(let o=0;o<i.length;o++){const r=i[o];e.add(r)}const s=[];this.nodes.each(o=>{o.data!==null&&!e.has(o.data)&&s.push(o.data)}),this.parts.each(o=>{o.data!==null&&!e.has(o.data)&&s.push(o.data)}),s.forEach(o=>t.Dv(o,!1));for(let o=0;o<i.length;o++){const r=i[o];this.findPartForData(r)===null&&t.vv(r,!1)}this.Fv();let n=this.parts.iterator;for(;n.next();)n.value.updateRelationshipsFromData();for(n=this.nodes.iterator;n.next();)n.value.updateRelationshipsFromData();for(n=this.links.iterator;n.next();)n.value.updateRelationshipsFromData()}Fv(){}updateRelationshipsFromData(t){}nw(t,e){if(typeof e=="string"){const i=this.findPartForData(t);if(i!==null)i.updateTargetBindings(e);else{const s=this.o3(t);if(s!==null&&s.length>0){for(let o=0;o<s.length;o++)s[o].updateTargetBindings(e);const n=s[0].part;if(n!==null){const o=n.adornments;for(;o.next();)o.value.updateTargetBindings(e)}U.Z(s)}}t===this.diagram.model.modelData&&this.updateAllTargetBindings(e)}}o3(t){let e=null;const i=this.yg.iterator;for(;i.next();){const s=i.value;for(let n=0;n<s.length;n++){const r=s[n].findItemPanelForData(t);r!==null&&(e===null&&(e=U.ot()),e.push(r))}if(e!==null)break}return e}YC(t){return this.yg.get(t)}s3(t,e){const i=t.object;if(!Array.isArray(i))return;const s=t.change===3,n=s?t.newParam:t.oldParam,o=s?t.newValue:t.oldValue,r=this.YC(i);if(Array.isArray(r))for(let l=0;l<r.length;l++){const a=r[l];s?a.Z1(o,n,!0):a.$I(n)}}M2(t,e){e!==null&&t.Sn(s=>e.uT(s));const i=t.Aa;if(Array.isArray(i)){const s=this.YC(i);if(s===null)this.yg.set(i,[t]);else{for(let n=0;n<s.length;n++)if(s[n]===t)return;s.push(t)}}}N2(t,e){t.Sn(s=>e.TO(s));const i=t.Aa;if(Array.isArray(i)){const s=this.YC(i);if(s!==null){for(let n=0;n<s.length;n++)if(s[n]===t){s.splice(n,1),s.length===0&&this.yg.delete(i);return}}}}copyParts(t,e,i){i===void 0&&(i=!1);const s=new GMap;if(Array.isArray(t))for(let o=0;o<t.length;o++)this.Ck(t[o],e,s,i);else{const o=t.iterator;for(;o.next();)this.Ck(o.value,e,s,i)}if(e!==null){const o=e.model,r=e.Ap().dragsLink,l=new GSet,a=new GMap,h=s.iterator;for(;h.next();){const c=h.value;if(c instanceof Link)!r&&(c.fromNode===null||c.toNode===null)&&l.add(c);else if(c instanceof Node&&c.data!==null){if(o.Um()){const f=c,u=h.key,d=u.findTreeParentNode();if(d!==null){const m=s.get(d);if(m!==null){o.setParentKeyForNodeData(f.data,o.getKeyForNodeData(m.data));const g=e.findLinkForData(f.data),p=u.findTreeParentLink();p!==null&&g!==null&&a.set(p,g)}}}else if(o.l1()){const f=c,u=h.key,d=o.isRelatedKeysPathTo?u.findNodesOutOf():u.findNodesInto();for(;d.next();){const m=d.value,g=s.get(m);if(g!==null){o.addRelatedKeyForNodeData(f.data,g.key);const p=e.partManager.findLinkForData(f.data,g.key),y=this.findLinkForData(u.data,m.key);y!==null&&p!==null&&a.set(y,p)}else o.removeRelatedKeyForNodeData(f.data,m.key)}}}}if(l.count>0&&e.removeParts(l,!1),a.count>0){const c=a.iterator;for(;c.next();){const f=c.key,u=c.value;s.set(f,u)}}}if(e!==null&&this.diagram!==null){const o=e.model,r=o.afterCopyFunction;if(r!==null){const l=new GMap;s.each(h=>{h.key.data!==null&&l.set(h.key.data,h.value.data)});const a=this.diagram.model;r(l,o,a)}}const n=s.iterator;for(;n.next();)n.value.updateTargetBindings();return s}Ck(t,e,i,s){if(t===null||s&&!t.canCopy())return null;if(i.has(t))return i.get(t);const n=this.KC(t,e);if(!(n instanceof Part))return null;if(n.isSelected=!1,n.isHighlighted=!1,i.set(t,n),t instanceof Node){const o=t.linksConnected;for(;o.next();){const r=o.value;if(r.fromNode===t){const l=i.get(r);l!==null&&(l.fromNode=n)}if(r.toNode===t){const l=i.get(r);l!==null&&(l.toNode=n)}}if(t instanceof Group&&n instanceof Group){const r=t.memberParts;for(;r.next();){const l=r.value,a=this.Ck(l,e,i,s);a instanceof Link||a!==null&&(a.containingGroup=n)}}}else if(t instanceof Link&&n instanceof Link){const o=t.fromNode;if(o!==null){const a=i.get(o);a!==null&&(n.fromNode=a)}const r=t.toNode;if(r!==null){const a=i.get(r);a!==null&&(n.toNode=a)}const l=t.labelNodes;for(;l.next();){const a=l.value,h=this.Ck(a,e,i,s);h!==null&&h instanceof Node&&(h.labeledLink=n)}}return n}KC(t,e){let i=null;const s=t.data;if(s!==null&&e!==null){const n=e.model;if(!(t instanceof Link)){const o=n.copyNodeData(s);n.addNodeData(o),i=e.findPartForData(o)}}else if(t.It(),i=t.copy(),i!==null){const n=this.diagram;if(e!==null)e.add(i);else if(s!==null&&n!==null&&n.commandHandler!==null&&n.commandHandler.copiesClipboardData){const o=n.model;let r=null;i instanceof Link||(r=o.copyNodeData(s)),i.data=r}}return i}get nodes(){return this.mg}get links(){return this.rn}get parts(){return this.Ct}get diagram(){return this.a}get addsToTemporaryLayer(){return this.BC}set addsToTemporaryLayer(t){this.BC=t}}class GraphLinksPartManager extends PartManager{T2(){const t=this.diagram.model;this.iw(t.nodeDataArray),this.Rv(t.linkDataArray)}iw(t){super.iw(t,!1);const e=this.links.iterator;for(;e.next();)e.value.qd();this.diagram.h1(!1)}Rv(t){t.forEach(e=>{this.Ov(e)}),this.diagram.h1(!1)}Ov(t){if(t==null||this.diagram.undoManager.isUndoingRedoing||this.findLinkForData(t))return null;const e=this.getLinkCategoryForData(t),i=this.findLinkTemplateForCategory(e);if(i!==null){i.It();const s=i.copy();if(s!==null){const n=this.diagram.yi;this.diagram.yi=!0,s._o=e,s.te=t;const o=this.diagram.model,r=o.Lk(t,!0);r!==""&&(s.fromPortId=r);const l=o.Vi(t,!0);if(l!==void 0){const f=this.findNodeForKey(l);f instanceof Node&&(s.fromNode=f)}const a=o.Lk(t,!1);a!==""&&(s.toPortId=a);const h=o.Vi(t,!1);if(h!==void 0){const f=this.findNodeForKey(h);f instanceof Node&&(s.toNode=f)}const c=o.getLabelKeysForLinkData(t);return Array.isArray(c)&&c.forEach(f=>{const u=this.findNodeForKey(f);u!==null&&(u.labeledLink=s)}),this.addsToTemporaryLayer&&(s.dl="Tool"),this.diagram.add(s),s.te=null,s.data=t,this.diagram.yi=n,s}}return null}Mv(){const t=this.diagram.model;this.Iv(t.linkDataArray),this.zC(t.nodeDataArray)}Iv(t){t.forEach(e=>{this.Nk(e)})}getLinkCategoryForData(t){return this.diagram.model.getCategoryForLinkData(t)}setLinkCategoryForData(t,e){return this.diagram.model.setCategoryForLinkData(t,e)}setFromNodeForLink(t,e,i){const s=this.diagram.model,n=e!==null?e.data:null;s.setFromKeyForLinkData(t.data,s.getKeyForNodeData(n))}setToNodeForLink(t,e,i){const s=this.diagram.model,n=e!==null?e.data:null;s.setToKeyForLinkData(t.data,s.getKeyForNodeData(n))}AC(t){this.diagram.model.removeLinkData(t.data)}findPartForKey(t){const e=super.findPartForKey(t);if(e===null){const s=this.diagram.model.findLinkDataForKey(t);if(s!==null)return this.findLinkForData(s)}return e}findLinkForKey(t){if(t==null)return null;const i=this.diagram.model.findLinkDataForKey(t);return i!==null?this.findLinkForData(i):null}doModelChanged(t){if(super.doModelChanged(t),!this.diagram)return;const e=this.diagram;if(t.model!==e.model)return;const i=t.change;if(e.G){e.G=!1;try{const s=t.modelChange;if(s!==""){if(i===2){if(s==="linkFromKey"){const n=t.object,o=this.findLinkForData(n);if(o!==null){const r=t.newValue,l=this.findNodeForKey(r);o.fromNode=l}}else if(s==="linkToKey"){const n=t.object,o=this.findLinkForData(n);if(o!==null){const r=t.newValue,l=this.findNodeForKey(r);o.toNode=l}}else if(s==="linkFromPortId"){const n=t.object,o=this.findLinkForData(n);if(o!==null){const r=t.newValue;typeof r=="string"&&(o.fromPortId=r)}}else if(s==="linkToPortId"){const n=t.object,o=this.findLinkForData(n);if(o!==null){const r=t.newValue;typeof r=="string"&&(o.toPortId=r)}}else if(s==="nodeGroupKey"){const n=t.object,o=this.findPartForData(n);if(o!==null){const r=t.newValue;if(r!==void 0){const l=this.findNodeForKey(r);l instanceof Group?o.containingGroup=l:o.containingGroup=null}else o.containingGroup=null}}else if(s==="linkLabelKeys"){const n=t.object,o=this.findLinkForData(n);if(o!==null){const r=t.oldValue,l=t.newValue;Array.isArray(r)&&r.forEach(a=>{if(l.indexOf(a)>=0)return;const h=this.findNodeForKey(a);h!==null&&(h.labeledLink=null)}),Array.isArray(l)&&l.forEach(a=>{const h=this.findNodeForKey(a);h!==null&&(h.labeledLink=o)})}}else if(s==="linkCategory"){const n=t.object,o=this.findLinkForData(n),r=t.newValue;o!==null&&typeof r=="string"&&(o.category=r)}else if(s==="linkDataArray"){const n=t.oldValue;this.Iv(n);const o=t.newValue;this.Rv(o)}e.isModified=!0}else if(i===3){const n=t.newValue;if(s==="linkDataArray"&&U.$(n))this.Ov(n);else if(s==="linkLabelKeys"&&t.model.isKeyType(n)){const o=t.object,r=this.findLinkForData(o),l=this.findNodeForKey(n);r!==null&&l!==null&&(l.labeledLink=r)}e.isModified=!0}else if(i===4){const n=t.oldValue;if(s==="linkDataArray"&&U.$(n))this.Nk(n);else if(s==="linkLabelKeys"&&t.model.isKeyType(n)){const o=this.findNodeForKey(n);o!==null&&(o.labeledLink=null)}e.isModified=!0}}else if(i===2){const n=t.propertyName,o=t.object,r=e.model;o===r&&(n==="linkFromKeyProperty"||n==="linkToKeyProperty"||n==="linkFromPortIdProperty"||n==="linkToPortIdProperty"||n==="linkLabelKeysProperty"||n==="nodeIsGroupProperty"||n==="nodeGroupKeyProperty"||n==="linkCategoryProperty")&&(e.undoManager.isUndoingRedoing||this.rebuildParts()),e.isModified=!0}}finally{e.G=!0}}}Fv(){const t=this.diagram.model,e=new Set,i=t.linkDataArray;i.forEach(n=>{e.add(n)});const s=[];this.links.each(n=>{n.data!==null&&!e.has(n.data)&&s.push(n.data)}),s.forEach(n=>{t.Ev(n,!1)}),i.forEach(n=>{this.findLinkForData(n)===null&&t.Uv(n,!1)})}updateRelationshipsFromData(t){const e=t.data;if(e===null)return;const i=t.diagram;if(i===null)return;const s=i.model;if(t instanceof Link){let n=s.Vi(e,!0),o=i.findNodeForKey(n);t.fromNode=o,n=s.Vi(e,!1),o=i.findNodeForKey(n),t.toNode=o;const r=s.getLabelKeysForLinkData(e);if(r.length>0||t.labelNodes.count>0){if(r.length===1&&t.labelNodes.count===1){const f=r[0],u=t.labelNodes.first();if(u!==null&&s.getKeyForNodeData(u.data)===f)return}const l=new GSet().addAll(r),a=new GSet;t.labelNodes.each(f=>{if(f.data!==null){const u=s.getKeyForNodeData(f.data);u!==void 0&&a.add(u)}});const h=a.copy();h.removeAll(l);const c=l.copy();if(c.removeAll(a),h.count>0||c.count>0){const f=t;h.each(u=>{const d=i.findNodeForKey(u);d!==null&&d.labeledLink===f&&(d.labeledLink=null)}),c.each(u=>{const d=i.findNodeForKey(u);d!==null&&d.labeledLink!==f&&(d.labeledLink=f)})}}}else if(!(t instanceof Adornment)){const n=s.getGroupKeyForNodeData(e),o=i.findPartForKey(n);(o===null||o instanceof Group)&&(t.containingGroup=o)}}Mk(t){const e=this.diagram.model,i=e.getKeyForNodeData(t);if(i!==void 0){const s=e.ow(i),n=this.findPartForData(t);if(s!==null&&n!==null){const r=s.iterator;for(;r.next();){const l=r.value;if(e.containsNodeData(l)){if(n instanceof Group&&e.getGroupKeyForNodeData(l)===i){const a=this.findPartForData(l);a!==null&&(a.containingGroup=n)}}else{const a=this.findLinkForData(l);if(a!==null&&n instanceof Node){e.Vi(l,!0)===i&&(a.fromNode=n),e.Vi(l,!1)===i&&(a.toNode=n);const h=e.getLabelKeysForLinkData(l);Array.isArray(h)&&h.some(c=>c===i?(n.labeledLink=a,!0):!1)}}}e.an(i)}const o=e.getGroupKeyForNodeData(t);if(o!==void 0){const r=this.findNodeForKey(o);n!==null&&r instanceof Group&&(n.containingGroup=r)}}}XC(t){const e=this.diagram.model;if(t instanceof Node){const i=e.getKeyForNodeData(t.data);if(i!==void 0){const s=t.linksConnected;for(;s.next();){const n=s.value;e.hn(i,n.data)}if(t.isLinkLabel){const n=t.labeledLink;n!==null&&e.hn(i,n.data)}if(t instanceof Group){const n=t.memberParts;for(;n.next();){const r=n.value.data;e.containsNodeData(r)&&e.hn(i,r)}}}}}KC(t,e){let i=super.KC(t,e);if(t instanceof Link){const s=t.data;if(s!==null&&e!==null){const n=e.model,o=n.copyLinkData(s);n.addLinkData(o),i=e.findLinkForData(o)}else if(i!==null){const n=this.diagram;if(s!==null&&n!==null&&n.commandHandler!==null&&n.commandHandler.copiesClipboardData){const r=n.model.copyLinkData(s);i.data=r}}}return i}insertLink(t,e,i,s){const n=this.diagram,o=n.model,r=n.toolManager.findTool("Linking");let l="";t!==null&&(e===null&&(e=t),l=e.portId,l===null&&(l=""));let a="";i!==null&&(s===null&&(s=i),a=s.portId,a===null&&(a=""));const h=r.archetypeLinkData;if(h instanceof Link){h.It();const c=h.copy();if(c!==null){c.fromNode=t,c.fromPortId=l,c.toNode=i,c.toPortId=a,n.add(c);const f=r.archetypeLabelNodeData;if(f instanceof Node){f.It();const u=f.copy();u!==null&&(u.labeledLink=c,n.add(u))}return c}}else if(h!==null){const c=o.copyLinkData(h);if(U.$(c)){t!==null&&o.wg(c,o.getKeyForNodeData(t.data),!0),o.xg(c,l,!0),i!==null&&o.wg(c,o.getKeyForNodeData(i.data),!1),o.xg(c,a,!1),o.addLinkData(c);const f=r.archetypeLabelNodeData;if(f!==null&&!(f instanceof Node)){const d=o.copyNodeData(f);o.addNodeData(d);const m=o.getKeyForNodeData(d);m!==void 0&&o.addLabelKeyForLinkData(c,m)}return n.findLinkForData(c)}}return null}}class TreePartManager extends PartManager{Ia=null;Ak(t,e){if(t===null||e===null||e.findTreeParentLink()!==null)return;const i=this.diagram.toolManager.findTool("Linking");let s=t,n=e;if(this.diagram.isTreePathToChildren){if(i!==null&&i.Vu(s,n,null,!0))return}else if(s=e,n=t,i!==null&&i.Vu(s,n,null,!0))return;const o=this.getLinkCategoryForData(e.data),r=this.findLinkTemplateForCategory(o);if(r!==null){r.It();const l=r.copy();if(l!==null){const a=this.diagram.yi;this.diagram.yi=!0,l._o=o,l.te=e.data,l.fromNode=s,l.toNode=n,this.diagram.add(l),l.te=null,l.data=e.data,this.diagram.yi=a}}}getLinkCategoryForData(t){return this.diagram.model.getParentLinkCategoryForNodeData(t)}setLinkCategoryForData(t,e){this.diagram.model.setParentLinkCategoryForNodeData(t,e)}setFromNodeForLink(t,e,i){const s=this.diagram.model;i===void 0&&(i=null);const n=e!==null?e.data:null;if(this.diagram.isTreePathToChildren)s.setParentKeyForNodeData(t.data,s.getKeyForNodeData(n));else{const o=this.Ia;this.Ia=t,i!==null&&s.setParentKeyForNodeData(i.data,void 0);const r=t.toNode!==null?t.toNode.data:null;s.setParentKeyForNodeData(n,s.getKeyForNodeData(r)),this.Ia=o}}setToNodeForLink(t,e,i){const s=this.diagram.model;i===void 0&&(i=null);const n=e!==null?e.data:null;if(this.diagram.isTreePathToChildren){const o=this.Ia;this.Ia=t,i!==null&&s.setParentKeyForNodeData(i.data,void 0);const r=t.fromNode!==null?t.fromNode.data:null;s.setParentKeyForNodeData(n,s.getKeyForNodeData(r)),this.Ia=o}else s.setParentKeyForNodeData(t.data,s.getKeyForNodeData(n))}AC(t){this.diagram.model.setParentKeyForNodeData(t.data,void 0)}findLinkForKey(t){if(t==null)return null;const i=this.diagram.model.findNodeDataForKey(t);return i!==null?this.findLinkForData(i):null}doModelChanged(t){if(super.doModelChanged(t),!this.diagram)return;const e=this.diagram;if(t.model!==e.model)return;const i=t.change;if(e.G){e.G=!1;try{const s=t.modelChange;if(s!==""){if(i===2){if(s==="nodeParentKey"){const n=t.object,o=n?this.findNodeForData(n):null,r=t.newValue,l=this.findNodeForKey(r);if(n&&this.Ia!==null)l!==null&&(this.Ia.data=n,this.Ia.category=this.getLinkCategoryForData(n));else if(o!==null){const a=o.findTreeParentLink();a!==null?l===null?e.remove(a):e.isTreePathToChildren?a.fromNode=l:a.toNode=l:this.Ak(l,o)}}else if(s==="parentLinkCategory"){const n=t.object,o=n?this.findNodeForData(n):null,r=t.newValue;if(o!==null&&typeof r=="string"){const l=o.findTreeParentLink();l!==null&&(l.category=r)}}e.isModified=!0}}else i===2&&(t.object===e.model&&t.propertyName==="nodeParentKeyProperty"&&(e.undoManager.isUndoingRedoing||this.rebuildParts()),e.isModified=!0)}finally{e.G=!0}}}updateRelationshipsFromData(t){const e=t.data;if(e===null)return;const i=t.diagram;if(i===null)return;const s=i.model;if(t instanceof Node){const n=s.getParentKeyForNodeData(e),o=i.findNodeForKey(n),r=t.findTreeParentNode();if(o!==r){const l=t.findTreeParentLink();o!==null?l!==null?i.isTreePathToChildren?l.fromNode=o:l.toNode=o:this.Ak(o,t):l!==null&&i.C2(l,!1)}}}nw(t,e){if(super.nw(t,e),typeof e=="string"&&this.findPartForData(t)!==null){const s=this.findLinkForData(t);s!==null&&s.updateTargetBindings(e)}}Mk(t){const e=this.diagram.model,i=e.getKeyForNodeData(t);if(i!==void 0){const s=e.ow(i),n=this.findPartForData(t);if(s!==null&&n!==null){const r=s.iterator;for(;r.next();){const l=r.value;if(e.containsNodeData(l)&&n instanceof Node&&e.getParentKeyForNodeData(l)===i){const a=this.findNodeForData(l);this.Ak(n,a)}}e.an(i)}const o=e.getParentKeyForNodeData(t);if(o!==void 0&&n instanceof Node){const r=this.findNodeForKey(o);this.Ak(r,n)}}}XC(t){const e=this.diagram.model;if(t instanceof Node){const i=e.getKeyForNodeData(t.data),s=this.findLinkForData(t.data);if(s!==null){s.isSelected=!1,s.isHighlighted=!1;const r=s.layer;if(r!==null){const l=r.ri(-1,s,!1);l>=0&&this.diagram.raiseChangedEvent(4,"parts",r,s,null,l,null);const a=s.layerChanged;a!==null&&a(s,r,null)}}const n=this.diagram.isTreePathToChildren,o=t.linksConnected;for(;o.next();){const r=o.value,l=n?r.toNode:r.fromNode;if(l!==null){const a=l.data;e.containsNodeData(a)&&e.hn(i,a)}}}}insertLink(t,e,i,s){const n=this.diagram.model;let o=t,r=i;if(this.diagram.isTreePathToChildren||(o=i,r=t),o!==null&&r!==null){const l=o.data,a=r.data;return n.setParentKeyForNodeData(a,n.getKeyForNodeData(l)),r.findTreeParentLink()}return null}}var BindingMode=(w=>(w[w.OneWay=1]="OneWay",w[w.TwoWay=2]="TwoWay",w))(BindingMode||{});class Binding{n;HC;nc;Hf;Ea;jf;qf;Wf;Tk;Ti;Od;Df;constructor(t,e,i,s){GSet.Je(this),t===void 0?t="":U.s(t,"string",Binding,"constructor:targetprop"),e===void 0?e=t:U.s(e,"string",Binding,"constructor:sourceprop"),i===void 0?i=null:i!==null&&U.S(i,Binding,"constructor:conv"),this.HC=-1,this.Ti=null,this.nc=t,this.Od=0,this.Df=0,this.Hf=null,this.Ea=e,this.jf=i,s===void 0?(this.qf=1,this.Wf=null):(this.qf=2,this.Wf=s),this.Tk=new GSet,this.n=2}copy(){const t=new this.constructor;return this.cloneProtected(t),t}cloneProtected(t){t.nc=this.nc,t.Od=this.Od,t.Df=this.Df,t.Hf=this.Hf,t.Ea=this.Ea,t.jf=this.jf,t.qf=this.qf,t.Wf=this.Wf,t.n=this.n&-2}static OneWay=1;static TwoWay=2;static parseEnum(t,e){return U.S(t,Binding,"parseEnum:ctor"),i=>{let s=parseInt(i);return isNaN(s)&&(s=U.Wa(t,i),s===null)?e:s}}fe(t){t in BindingMode?this.mode=t:U.dr(this,t)}static toString(t){return U.toString(t)}toString(){return"Binding("+this.targetProperty+":"+this.sourceProperty+(this.targetId!==-1?" "+this.targetId:"")+" "+BindingMode[this.mode]+")"}b(){return this.n=this.n|1,this}get targetId(){return this.HC}set targetId(t){this.f&&U.L(this),this.HC=t}get targetProperty(){return this.nc}set targetProperty(t){this.f&&U.L(this),U.s(t,"string",Binding,"targetProperty"),this.nc=t}get sourceProperty(){return this.Ea}set sourceProperty(t){this.f&&U.L(this),U.s(t,"string",Binding,"sourceProperty"),this.Ea=t}get f(){return(this.n&1)!==0}get isToData(){return(this.n&2)!==0}get isToObject(){return(this.n&4)!==0}get isToModel(){return(this.n&8)!==0}get isToTheme(){return(this.n&16)!==0}get jC(){return this.isToTheme&&!(this.isToData||this.isToObject||this.isToModel)}wd(){return!1}get sourceName(){return this.Hf}set sourceName(t){this.f&&U.L(this),t!==null&&U.s(t,"string",Binding,"sourceName"),this.Hf=t,t!==null?this.n=this.n&-3|4:this.n=this.n|2}get converter(){return this.jf}set converter(t){this.f&&U.L(this),t!==null&&U.S(t,Binding,"converter"),this.jf=t}get backConverter(){return this.Wf}set backConverter(t){this.f&&U.L(this),t!==null&&U.S(t,Binding,"backConverter"),this.Wf=t}get mode(){return this.qf}set mode(t){this.f&&U.L(this),this.isToTheme&&t===2&&U.o("Theme Bindings cannot be TwoWay."),this.qf=t}makeTwoWay(t){return this.isToTheme&&U.o("Theme Bindings cannot be TwoWay."),this.mode=2,t&&(U.S(t,Binding,"makeTwoWay"),this.backConverter=t),this}ofObject(t){return this.f&&U.L(this),t===void 0&&(t=""),this.sourceName=t,this}ofModel(){return this.f&&U.L(this),this.n=this.n&-3&-5|8,this.Hf=null,this}WT(t,e){const i=this.sourceName;let s=null;return i===null||i===""?s=t:i==="/"?s=e.part:i==="."?s=e:i===".."?s=e.panel:s=t.findObject(i),s}check(t){const e=this.nc,i=this.Ea,s=this.jf;(this.wd()&&s===null&&this.Ua===null&&e===""||s===null&&e==="")&&U.ne("Binding error: target property is the empty string: "+this.toString()),this.wd()&&this.jC&&i===""&&s===null&&this.Ua===null&&U.ne("Binding error: theme bindings require a source property when not using a converter: "+this.toString()),t&&typeof e=="string"&&(!U.nt(["setAttribute"])&&e.length>0&&e[0]!=="_"&&!U.Hw(t,e)?U.ne("Binding error: undefined target property: "+e+" on "+t.toString()):e==="name"&&t instanceof GraphObject&&U.ne("Binding error: cannot modify GraphObject.name on "+t.toString()))}updateTarget(t,e,i,s){const n=this.Ea;if(i!==void 0&&n!==""&&n!==i||this.isToTheme&&t.diagram===null)return;const o=this.nc,r=this.jf;let l=e;if(n!==""&&!this.jC&&(l=Model.Mt(e,n)),l!==void 0)if(r===null){if(o!==""){if(this.wd()){const a=t.diagram?.themeManager;if(l=this.Vv(a,l,t,o),l===void 0)return}s?s.et(t,o,l):(e instanceof GraphObject||e instanceof RowColumnDefinition)&&Model.et(t,o,l)}}else try{if(o!==""){let a=r(l,t);if(this.wd()){const h=t.diagram?.themeManager;if(a=this.Vv(h,a,t,o),a===void 0)return}s?s.et(t,o,a):(e instanceof GraphObject||e instanceof RowColumnDefinition)&&Model.et(t,o,a)}else r(l,t)}catch{}}updateSource(t,e,i,s){if(this.qf!==2)return;const n=this.nc;if(i!==void 0&&n!==i)return;const o=this.Ea,r=this.Wf,l=s!==null?s.diagram:null,a=l!==null?l.model:null;let h=t;if(n!==""&&(h=Model.Mt(t,n)),h!==void 0&&!this.Tk.has(t))try{if(this.Tk.add(t),r===null){if(o!=="")a!==null?a.setDataProperty(e,o,h):(e instanceof GraphObject||e instanceof RowColumnDefinition)&&(e[o]=h);else if(a!==null&&s!==null&&s.itemIndex>=0&&s.panel!==null&&Array.isArray(s.panel.itemArray)){const c=s.itemIndex,f=s.panel.itemArray;a.removeArrayItem(f,c),a.insertArrayItem(f,c,h)}}else try{if(o!==""){const c=r(h,e,a);a!==null?a.setDataProperty(e,o,c):(e instanceof GraphObject||e instanceof RowColumnDefinition)&&(e[o]=c)}else{const c=r(h,e,a);if(c!==void 0&&a!==null&&s!==null&&s.itemIndex>=0&&s.panel!==null&&Array.isArray(s.panel.itemArray)){const f=s.itemIndex,u=s.panel.itemArray;a.removeArrayItem(u,f),a.insertArrayItem(u,f,c)}}}catch{}}finally{this.Tk.delete(t)}}}class ThemeBinding extends Binding{lw;Ua;oc;constructor(t,e,i,s,n){super(t,e,s),i==null&&(i=""),n===void 0&&(n=null),this.lw=i,this.Ua=n,this.oc=null,this.n=16}cloneProtected(t){super.cloneProtected(t),t.lw=this.lw,t.Ua=this.Ua,t.oc=this.oc}wd(){return!0}get themeSource(){return this.lw}set themeSource(t){this.f&&U.L(this),t!==null&&U.s(t,"string",ThemeBinding,"themeSource"),this.lw=t,this.oc=null,t!==null?this.n=this.n|16:this.n=this.n&-17}get themeConverter(){return this.Ua}set themeConverter(t){this.f&&U.L(this),t!==null&&U.S(t,ThemeBinding,"themeConverter"),this.Ua=t}ofData(){return this.f&&U.L(this),this.n=this.n|2,this.Hf=null,this}Vv(t,e,i,s){if(!t||(this.jC&&(e=this.Ea),!e&&e!==0))return;let n=this.themeSource;this.oc!==null?n=this.oc:typeof n=="string"&&n.includes(".")&&(this.oc=n.split("."),n=this.oc);let o=t.findValue(e,n,s);if(o===void 0&&U.ne(`Theme warning: ${e} could not be found when setting target property ${s}.`),t.readsCssVariables&&typeof o=="string"&&o.startsWith("var(")){const r=o.match(this.r3);r&&(o=getComputedStyle(root.document.documentElement).getPropertyValue(r[1]))}return U.nt(this.Ua)&&(o=this.Ua(o,i)),o}r3=/var\((.*)\)/}class Model{Pt;bg;zo;qC;Bi;be;Va;Jf;$f;kg;Pg;Sg;Mg;aw;rc;lr;hw;Bo;Dk;constructor(t,e){if(GSet.Je(this),this.Pt="",this.bg="",this.zo=!1,this.qC={},this.Bi=[],this.be=new GMap,this.Va="key",this.Jf=null,this.$f=null,this.kg=!1,this.Pg=!1,this.Sg=!1,this.Mg=null,this.aw=100,this.rc="category",this.lr=new GMap,this.hw=[],this.Bo=!1,this.Dk=null,this.undoManager=new UndoManager,t!==void 0&&(Array.isArray(t)?this.nodeDataArray=t:e=t),e){Object.assign(this,e);const i=e.Changed;i&&(delete this.Changed,this.addChangedListener(i))}}cloneProtected(t){t.Pt=this.Pt,t.bg=this.bg,t.zo=this.zo,t.Va=this.Va,t.Jf=this.Jf,t.$f=this.$f,t.kg=this.kg,t.Pg=this.Pg,t.Sg=this.Sg,t.Mg=this.Mg,t.aw=this.aw,t.rc=this.rc}copy(){const t=new this.constructor;return this.cloneProtected(t),t}clear(){this.Bi=[],this.be.clear(),this.lr.clear(),this.undoManager.clear()}toString(t){if(t===void 0&&(t=0),t>1)return this.toJson();{let e=(this.name!==""?this.name:"")+" Model";if(t>0){e+=`
 node data:`;const i=this.nodeDataArray,s=i.length;for(let n=0;n<s;n++){const o=i[n];e+=" "+this.getKeyForNodeData(o)+":"+U.toString(o)}}return e}}toIncrementalData(t){t.change!==1&&U.o("Model.toIncrementalData argument is not a Transaction ChangedEvent:"+t.toString());const e=t.object;if(!t.isTransactionFinished||!(e instanceof Transaction))return null;const i=this.Bv(e);return this.WC(e,t.propertyName==="FinishedUndo",i)}WC(t,e,i){const s=this;let n=!1;const o=new GSet,r=new GSet,l=new GSet;t.changes.each(u=>{if(u.model===s){if(u.modelChange==="nodeDataArray")u.change===3?o.add(u.newValue):u.change===4&&l.add(u.oldValue);else if(s.containsNodeData(u.object))u.object!==null&&r.add(u.object);else if(u.change===2&&(s.modelData===u.object||u.propertyName==="modelData"))n=!0;else if(u.object!==null)if(i.has(u.object)){const d=i.get(u.object);d&&d.each(m=>{s.containsNodeData(m)&&r.add(m)})}else{if(u.object instanceof Model||s.jh()&&s.containsLinkData(u.object))return;s.zv(u.object).each(m=>{r.add(m)})}}});const a=new GSet;o.each(u=>{const d=s.getKeyForNodeData(u);d!==void 0&&a.add(d),e||r.add(u)});const h=new GSet;l.each(u=>{const d=s.getKeyForNodeData(u);d!==void 0&&h.add(d),e&&r.add(u)});const c=s.cloneDeep(r.toArray());let f=null;return n&&(f===null&&(f={}),f.modelData=this.cloneDeep(this.modelData)),a.count>0&&(f===null&&(f={}),e?f.removedNodeKeys=a.toArray():f.insertedNodeKeys=a.toArray()),c.length>0&&(f===null&&(f={}),f.modifiedNodeData=c),h.count>0&&(f===null&&(f={}),e?f.insertedNodeKeys=h.toArray():f.removedNodeKeys=h.toArray()),f}cloneDeep(t){return this.Ng(t,!0)}Ng(t,e,i,s){if(!U.$(t))return t;i||(i=new GMap);const n=i.get(t);if(n)return n;let o;if(Array.isArray(t)){o=[],i.set(t,o);for(let r=0;r<t.length;r++){const l=t[r];o.push(this.Ng(l,!1,i,s))}}else if(t instanceof Point||t instanceof Size||t instanceof Rect||t instanceof Margin||t instanceof Spot)o=t.copy(),i.set(t,o);else{if(t instanceof Brush||t instanceof Geometry)return t;if(t instanceof List)o=new List().addAll(this.Ng(t.toArray(),!1,i,s)),i.set(t,o);else if(t instanceof GSet)o=new GSet().addAll(this.Ng(t.toArray(),!1,i,s)),i.set(t,o);else if(t instanceof GMap)o=new GMap().addAll(this.Ng(t.toArray(),!1,i,s)),i.set(t,o);else if(t instanceof Date)o=new Date(t),i.set(t,o);else if(t instanceof RegExp)o=new RegExp(t),i.set(t,o),o.lastIndex=t.lastIndex;else if(Model.JC(null,"",t))o=t;else if(U.nt(t.copy))o=t.copy(),i.set(t,o);else{o={},i.set(t,o);for(const r in t){if(r==="__gohashid")continue;const l=t[r];o[r]=this.Ng(l,!1,i,s)}}}return o}zi(t){return JSON.stringify(t).replace(/[\u007F-\uFFFF]/g,i=>{const s="0000"+i.charCodeAt(0).toString(16);return"\\u"+s.substring(s.length-4)})}Cg(){let t="";return this.name!==""&&(t+=`,
  "name": `+this.zi(this.name)),this.dataFormat!==""&&(t+=`,
  "dataFormat": `+this.zi(this.dataFormat)),this.isReadOnly&&(t+=`,
  "isReadOnly": `+this.isReadOnly),this.nodeKeyProperty!=="key"&&typeof this.nodeKeyProperty=="string"&&(t+=`,
  "nodeKeyProperty": `+this.zi(this.nodeKeyProperty)),this.copiesArrays&&(t+=`,
  "copiesArrays": true`),this.copiesArrayObjects&&(t+=`,
  "copiesArrayObjects": true`),this.copiesKey&&(t+=`,
  "copiesKey": true`),this.pointsDigits!==100&&(t+=`,
  "pointsDigits": `+this.pointsDigits.toString()),this.nodeCategoryProperty!=="category"&&typeof this.nodeCategoryProperty=="string"&&(t+=`,
  "nodeCategoryProperty": `+this.zi(this.nodeCategoryProperty)),t}cw(t){t.name&&(this.name=t.name),t.dataFormat&&(this.dataFormat=t.dataFormat),t.isReadOnly&&(this.isReadOnly=!0),t.nodeKeyProperty&&(this.nodeKeyProperty=t.nodeKeyProperty),t.copiesArrays&&(this.copiesArrays=!0),t.copiesArrayObjects&&(this.copiesArrayObjects=!0),t.copiesKey!==void 0&&(this.copiesKey=t.copiesKey),t.pointsDigits!==void 0&&(this.pointsDigits=parseInt(t.pointsDigits)),t.nodeCategoryProperty&&(this.nodeCategoryProperty=t.nodeCategoryProperty)}Xv(){const t=this.modelData;return`,
  "modelData": `+this.Gv(t)}Yv(t){const e=t.modelData;U.$(e)&&(this.replaceJsonObjects(e),this.modelData=e)}$C(){const t=this.modelData;let e=!1;for(const s in t)if(!this.vk(t,s,t[s])){e=!0;break}let i="";return e&&(i=this.Xv()),i+`,
  "nodeDataArray": `+this.Ba(this.nodeDataArray,!0)}ZC(t){this.Yv(t);const e=t.nodeDataArray;Array.isArray(e)&&(this.replaceJsonObjects(e),this.nodeDataArray=e)}QC(t,e,i){if(t===e)return!0;if(typeof t!=typeof e||U.nt(t)||U.nt(e))return!1;if(Array.isArray(t)&&Array.isArray(e)){if(i.get(t)===e)return!0;if(i.set(t,e),t.length!==e.length)return!1;for(let s=0;s<t.length;s++)if(!this.QC(t[s],e[s],i))return!1;return!0}else if(U.$(t)&&U.$(e)){if(i.get(t)===e)return!0;i.set(t,e);for(const s in t){const n=t[s];if(this.vk(t,s,n))continue;const o=e[s];if(o===void 0||!this.QC(n,o,i))return!1}for(const s in e){const n=e[s];if(this.vk(e,s,n))continue;const o=t[s];if(o===void 0||!this.QC(o,n,i))return!1}return!0}return!1}static Kv=`,
  "insertedNodeKeys": `;static l3=`,
  "modifiedNodeData": `;static Hv=`,
  "removedNodeKeys": `;Bv(t){let e=new GMap;const i=(s,n)=>{const o=n.part;if(!o)return;const r=o.data;if(s===r)return;let l=e.get(s);l===null?(l=new GSet,l.add(r),e.set(s,l)):l.add(r)};return t.changes.each(s=>{if(s.diagram!==null){const n=s.change;if(n===2){if(s.object!==null){const o=s.object.panel;if(o){const r=o.data;r&&i(r,o)}}}else if(n===3||n===4){const o=s.object,r=o.itemArray;r&&i(r,o)}}}),e}zv(t){const e=new GSet;for(let i=0;i<this.nodeDataArray.length;i++){const s=this.nodeDataArray[i];this.Fk(t,s,s,e)}return e}Fk(t,e,i,s){if(Array.isArray(e))for(let n=0;n<e.length;n++){const o=e[n];if(o===t)return s.add(i),!0;if(this.Fk(t,o,i,s))return!0}else if(U.$(e)&&Object.getPrototypeOf(e)===Object.prototype)for(const n in e){const o=e[n];if(o===t)return s.add(i),!0;if(this.Fk(t,o,i,s))return!0}return!1}_C(t,e,i){const s=this;let n=!1;const o=new GSet,r=new GSet,l=new GSet;t.changes.each(f=>{if(f.model===s){if(f.modelChange==="nodeDataArray")f.change===3?o.add(f.newValue):f.change===4&&l.add(f.oldValue);else if(s.containsNodeData(f.object))f.object!==null&&r.add(f.object);else if(f.change===2&&(s.modelData===f.object||f.propertyName==="modelData"))n=!0;else if(f.object!==null)if(i.has(f.object)){const u=i.get(f.object);u&&u.each(d=>{s.containsNodeData(d)&&r.add(d)})}else{if(f.object instanceof Model||s.jh()&&s.containsLinkData(f.object))return;s.zv(f.object).each(d=>{r.add(d)})}}});const a=new GSet;o.each(f=>{const u=s.getKeyForNodeData(f);u!==void 0&&a.add(u),e||r.add(f)});const h=new GSet;l.each(f=>{const u=s.getKeyForNodeData(f);u!==void 0&&h.add(u),e&&r.add(f)});let c="";return n&&(c+=this.Xv()),a.count>0&&(c+=(e?Model.Hv:Model.Kv)+this.Ba(a.toArray(),!0)),r.count>0&&(c+=Model.l3+this.Ba(r.toArray(),!0)),h.count>0&&(c+=(e?Model.Kv:Model.Hv)+this.Ba(h.toArray(),!0)),c}fw(t){(t.name!==void 0&&t.name!==this.name||t.dataFormat!==void 0&&t.dataFormat!==this.dataFormat||t.isReadOnly!==void 0&&t.isReadOnly!==this.isReadOnly||t.nodeKeyProperty!==void 0&&t.nodeKeyProperty!==this.nodeKeyProperty||t.copiesArrays!==void 0&&t.copiesArrays!==this.copiesArrays||t.copiesArrayObjects!==void 0&&t.copiesArrayObjects!==this.copiesArrayObjects||t.copiesKey!==void 0&&t.copiesKey!==this.copiesKey||t.nodeCategoryProperty!==void 0&&t.nodeCategoryProperty!==this.nodeCategoryProperty)&&U.o("applyIncrementalJson cannot change Model properties"),this.Yv(t);const e=t.insertedNodeKeys,i=t.modifiedNodeData,s=new GMap;if(Array.isArray(i))for(let o=0;o<i.length;o++){const r=i[o],l=this.getKeyForNodeData(r);l!=null&&s.set(l,r)}if(Array.isArray(e)){const o=e.length;for(let r=0;r<o;r++){const l=e[r];let a=this.findNodeDataForKey(l);if(a===null){const h=s.get(l);a=h||this.copyNodeData({}),a!==null&&(this.setKeyForNodeData(a,l),this.addNodeData(a))}}}if(Array.isArray(i)){const o=i.length;for(let r=0;r<o;r++){const l=i[r],a=this.getKeyForNodeData(l),h=this.findNodeDataForKey(a);if(h!==null){for(const c in l)c==="__gohashid"||c===this.nodeKeyProperty||(this.Em()||this.l1())&&c===this.nodeIsGroupProperty||this.setDataProperty(h,c,l[c]);this.Lg(l,h)}}}const n=t.removedNodeKeys;if(Array.isArray(n)){const o=n.length;for(let r=0;r<o;r++){const l=n[r],a=this.findNodeDataForKey(l);a!==null&&this.removeNodeData(a)}}}toIncrementalJson(t,e){t.change!==1&&U.o("Model.toIncrementalJson argument is not a Transaction ChangedEvent:"+t.toString());const i=t.object;if(!t.isTransactionFinished||!(i instanceof Transaction))return'{ "incremental": 0 }';e===void 0&&(e=U.Hn(this));const s=this.Bv(i),n=this._C(i,t.propertyName==="FinishedUndo",s);return'{ "class": '+this.zi(e)+', "incremental": 1'+this.Cg()+n+"}"}toIncrementalJSON(t,e){return this.toIncrementalJson(t,e)}toJson(t){return t===void 0&&(t=U.Hn(this)),'{ "class": '+this.zi(t)+this.Cg()+this.$C()+"}"}toJSON(t){return this.toJson(t)}applyIncrementalJson(t){let e=null;if(typeof t=="string")try{e=root.JSON.parse(t)}catch{}else U.$(t)?e=t:U.o("Unable to modify a Model from: "+t);const i=e.incremental;typeof i!="number"&&U.o("Unable to apply non-incremental changes to Model: "+t),i!==0&&(this.startTransaction("applyIncrementalJson"),this.fw(e),this.commitTransaction("applyIncrementalJson"))}applyIncrementalJSON(t){return this.applyIncrementalJson(t)}static fromJson(t,e){e===void 0&&(e=null),e!==null&&U.se(e,Model,Model,"fromJson:model");let i=null;if(typeof t=="string")try{i=root.JSON.parse(t)}catch{}else U.$(t)?i=t:U.o("Unable to construct a Model from: "+t);if(e===null){const s=Model.a3(i);s===null||s instanceof Model?e=s:U.o("Unable to construct a Model of declared class: "+i.class)}return e===null&&(e=Model.jv()),e.cw(i),e.ZC(i),e}static fromJSON(t,e){return this.fromJson(t,e)}static jv(){return new Model}static a3(t){let e=null,i=t.class;if(typeof i=="string")try{let s=null;i.indexOf("go.")===0?s=Model.tL(i.substring(3)):(s=Model.tL(i),s===null&&(s=root[i])),U.nt(s)&&(e=new s)}catch{}return e}replaceJsonObjects(t){if(Array.isArray(t)){const e=t.length;for(let i=0;i<e;i++){const s=t[i];U.$(s)&&this.qv(t,i,this.replaceJsonObjects(s))}}else if(U.$(t)){for(const e in t){const i=t[e];if(U.$(i)){const s=this.replaceJsonObjects(i);t[e]=s,this.replaceJsonPropertyValue(t,e,s)}}return this.h3(t)}return t}replaceJsonPropertyValue(t,e,i){if(e==="points"&&Array.isArray(i)){let s=i.length%2===0;for(let n=0;n<i.length;n++)if(typeof i[n]!="number"){s=!1;break}if(s){const n=new List;for(let o=0;o<i.length/2;o++)n.add(new Point(i[o*2],i[o*2+1]));t[e]=n}}}writeJsonValue(t){return t===void 0?"undefined":t===null?"null":t===!0?"true":t===!1?"false":typeof t=="string"?this.zi(t):typeof t=="number"?t===1/0?"9e9999":t===-1/0?"-9e9999":isNaN(t)?'{"class":"NaN"}':t.toString():t instanceof Boolean?this.writeJsonValue(t.valueOf()):t instanceof String?this.writeJsonValue(t.valueOf()):t instanceof Number?this.writeJsonValue(t.valueOf()):t instanceof Date?'{"class":"Date", "value":"'+t.toJSON()+'"}':Array.isArray(t)?this.Ba(t):U.$(t)?this.Gv(t):U.nt(t)?"null":'"'+t.toString()+'"'}Ba(t,e){e===void 0&&(e=!1);const i=t.length;if(i<=0)return"[]";const s=new StringBuilder;s.add("["),e&&i>1&&s.add(`
`);for(let n=0;n<i;n++){const o=t[n];o!==void 0&&(n>0&&(s.add(","),e&&s.add(`
`)),s.add(this.writeJsonValue(o)))}return e&&i>1&&s.add(`
`),s.add("]"),s.toString()}vk(t,e,i){return!!(i===void 0||e==="__gohashid"||e[0]==="_"||U.nt(i))}je(t){return isNaN(t)?"NaN":t===1/0?"9e9999":t===-1/0?"-9e9999":t}Gv(t){const e=t;if(e instanceof Point)t={class:"go.Point",x:this.je(e.x),y:this.je(e.y)};else if(e instanceof Size)t={class:"go.Size",width:this.je(e.width),height:this.je(e.height)};else if(e instanceof Rect)t={class:"go.Rect",x:this.je(e.x),y:this.je(e.y),width:this.je(e.width),height:this.je(e.height)};else if(e instanceof Margin)t={class:"go.Margin",top:this.je(e.top),right:this.je(e.right),bottom:this.je(e.bottom),left:this.je(e.left)};else if(e instanceof Spot)e.isSpot()?t={class:"go.Spot",x:this.je(e.x),y:this.je(e.y),offsetX:this.je(e.offsetX),offsetY:this.je(e.offsetY)}:t={class:"go.Spot",enum:e.toString()};else if(e instanceof Brush){if(t={class:"go.Brush",type:BrushType[e.type]},e.type===1?t.color=e.color:(e.type===2||e.type===3)&&(t.start=e.start,t.end=e.end,e.type===3&&(e.startRadius!==0&&(t.startRadius=this.je(e.startRadius)),isNaN(e.endRadius)||(t.endRadius=this.je(e.endRadius)))),e.colorStops!==null){const n={},o=e.colorStops.iterator;for(;o.next();){const r=o.key,l=o.value;n[r]=l}t.colorStops=n}}else if(e instanceof Geometry)t={class:"go.Geometry",type:GeometryType[e.type]},e.startX!==0&&(t.startX=this.je(e.startX)),e.startY!==0&&(t.startY=this.je(e.startY)),e.endX!==0&&(t.endX=this.je(e.endX)),e.endY!==0&&(t.endY=this.je(e.endY)),e.spot1.equals(Spot.TopLeft)||(t.spot1=e.spot1),e.spot2.equals(Spot.BottomRight)||(t.spot2=e.spot2),e.type===4&&(t.path=Geometry.stringify(e));else if(Model.JC(null,"",e))return"{}";let i="{",s=!0;for(const n in t){const o=this.Mt(t,n);this.vk(t,n,o)||(s?s=!1:i+=",",i+=this.zi(n)+":"+this.writeJsonPropertyValue(n,o))}return i+="}",i}writeJsonPropertyValue(t,e){if(t==="points"&&e instanceof List){const i=e;let s="[";const n=i.iterator;for(;n.next();){const o=n.value;s.length>1&&(s+=","),s+=this.Wv(o.x),s+=",",s+=this.Wv(o.y)}return s+="]",s}else return this.writeJsonValue(e)}Wv(t){if(t===1/0)return"9e9999";if(t===-1/0)return"-9e9999";if(isNaN(t))return"0";const e=this.pointsDigits;return e>16?t.toString():t.toFixed(e)}get pointsDigits(){return this.aw}set pointsDigits(t){t<0?t=0:t>100&&(t=100),this.aw=t}qe(t){return typeof t=="number"?t:t==="NaN"?NaN:t==="9e9999"?1/0:t==="-9e9999"?-1/0:parseFloat(t)}h3(t){if(!U.$(t))return t;let e=t.class||"";if(typeof e!="string"||e==="")return t;if(e==="NaN")return NaN;if(e==="Date")return new Date(t.value);if(e.indexOf("go.")!==0)return t;e=e.substring(3);let i=t;if(e==="Point")i=new Point(this.qe(t.x),this.qe(t.y));else if(e==="Size")i=new Size(this.qe(t.width),this.qe(t.height));else if(e==="Rect")i=new Rect(this.qe(t.x),this.qe(t.y),this.qe(t.width),this.qe(t.height));else if(e==="Margin")i=new Margin(this.qe(t.top),this.qe(t.right),this.qe(t.bottom),this.qe(t.left));else if(e==="Spot")typeof t.enum=="string"?i=Spot.parse(t.enum):i=new Spot(this.qe(t.x),this.qe(t.y),this.qe(t.offsetX),this.qe(t.offsetY));else if(e==="Brush"){const s=new Brush;s.type=U.Wa(BrushType,t.type)??1,typeof t.color=="string"&&(s.color=t.color),t.start instanceof Spot&&(s.start=t.start),t.end instanceof Spot&&(s.end=t.end),typeof t.startRadius=="number"&&(s.startRadius=this.qe(t.startRadius)),typeof t.endRadius=="number"&&(s.endRadius=this.qe(t.endRadius));const n=t.colorStops;if(U.$(n))for(const o in n){const r=parseFloat(o);s.addColorStop(r,n[o])}i=s}else if(e==="Geometry"){let s=null;typeof t.path=="string"?s=Geometry.parse(t.path):s=new Geometry,s.type=U.Wa(GeometryType,t.type)??1,typeof t.startX=="number"&&(s.startX=this.qe(t.startX)),typeof t.startY=="number"&&(s.startY=this.qe(t.startY)),typeof t.endX=="number"&&(s.endX=this.qe(t.endX)),typeof t.endY=="number"&&(s.endY=this.qe(t.endY)),t.spot1 instanceof Spot&&(s.spot1=t.spot1),t.spot2 instanceof Spot&&(s.spot2=t.spot2),i=s}else if(e==="EnumValue"){let s=t.classType;s.indexOf("go.")===0&&(s=s.substring(3));const n=Model.tL(s);U.nt(n)&&(i=U.Wa(n,t.name))}return i}get name(){return this.Pt}set name(t){const e=this.Pt;e!==t&&(U.s(t,"string",Model,"name"),this.Pt=t,this.t("name",e,t))}get dataFormat(){return this.bg}set dataFormat(t){const e=this.bg;e!==t&&(U.s(t,"string",Model,"dataFormat"),this.bg=t,this.t("dataFormat",e,t))}get isReadOnly(){return this.zo}set isReadOnly(t){const e=this.zo;e!==t&&(U.s(t,"boolean",Model,"isReadOnly"),this.zo=t,this.t("isReadOnly",e,t))}get modelData(){return this.qC}set modelData(t){const e=this.modelData;e!==t&&(U.wc(t,Model,"modelData"),this.containsNodeData(t)&&U.o("Model.modelData Object must not be used by the rest of the model: "+t),this.qC=t,this.t("modelData",e,t),this.updateTargetBindings(t))}addChangedListener(t){return U.S(t,Model,"addChangedListener:listener"),this.hw.push(t),this}removeChangedListener(t){U.S(t,Model,"removeChangedListener:listener");const e=this.hw.indexOf(t);e>=0&&this.hw.splice(e,1)}A2(t){this.skipsUndoManager||this.undoManager.handleChanged(t),this.Jv(t)}Jv(t){this.hw.forEach(e=>e(t))}rR(t){this.Jv(t)}raiseChangedEvent(t,e,i,s,n,o,r){this.Ft("",t,e,i,s,n,o,r)}raiseChanged(t,e,i,s,n){this.Ft("",2,t,this,e,i,s,n)}t(t,e,i,s,n){this.Ft("",2,t,this,e,i,s,n)}raiseDataChanged(t,e,i,s,n,o){this.Ft("",2,e,t,i,s,n,o)}Ft(t,e,i,s,n,o,r,l){r===void 0&&(r=null),l===void 0&&(l=null);const a=new ChangedEvent;a.model=this,a.change=e,a.modelChange=t,a.propertyName=i,a.object=s,a.oldValue=n,a.oldParam=r,a.newValue=o,a.newParam=l,this.A2(a)}get undoManager(){return this.Dk}set undoManager(t){const e=this.Dk;e!==t&&(e&&e.removeModel(this),this.Dk=t,t.addModel(this))}get skipsUndoManager(){return this.Bo}set skipsUndoManager(t){U.s(t,"boolean",Model,"skipsUndoManager"),this.Bo=t}changeState(t,e){if(t!==null&&t.model===this)if(t.change===2){const i=t.object,s=t.propertyName,n=t.getValue(e);if(i!==null&&s===this.nodeKeyProperty&&this.containsNodeData(i)){const o=t.getValue(!e);o!==void 0&&this.be.delete(o),n!==void 0&&this.be.set(n,i)}this.et(i,s,n)}else if(t.change===3){const i=t.newParam;if(t.modelChange==="nodeDataArray"){const s=t.newValue;if(U.$(s)&&typeof i=="number"){const n=this.getKeyForNodeData(s);e?(this.Bi[i]===s&&this.Co(this.Bi,i),n!==void 0&&this.be.delete(n)):(this.Bi[i]!==s&&this.ar(this.Bi,i,s),n!==void 0&&this.be.set(n,s))}}else if(t.modelChange===""){let s=t.object;if(s&&!Array.isArray(s)&&t.propertyName&&(s=this.Mt(s,t.propertyName)),Array.isArray(s)&&typeof i=="number"){const n=t.newValue;e?this.Co(s,i):this.ar(s,i,n)}}else U.o("unknown ChangeType.Insert modelChange: "+t.toString())}else if(t.change===4){const i=t.oldParam;if(t.modelChange==="nodeDataArray"){const s=t.oldValue;if(U.$(s)&&typeof i=="number"){const n=this.getKeyForNodeData(s);e?(this.Bi[i]!==s&&this.ar(this.Bi,i,s),n!==void 0&&this.be.set(n,s)):(this.Bi[i]===s&&this.Co(this.Bi,i),n!==void 0&&this.be.delete(n))}}else if(t.modelChange===""){let s=t.object;if(s&&!Array.isArray(s)&&t.propertyName&&(s=this.Mt(s,t.propertyName)),Array.isArray(s)&&typeof i=="number"){const n=t.oldValue;e?this.ar(s,i,n):this.Co(s,i)}}else U.o("unknown ChangeType.Remove modelChange: "+t.toString())}else t.change===1||U.o("unknown ChangedEvent: "+t.toString())}startTransaction(t){return this.undoManager.startTransaction(t)}commitTransaction(t){return this.undoManager.commitTransaction(t)}rollbackTransaction(){return this.undoManager.rollbackTransaction()}commit(t,e){let i=e;i===void 0&&(i="");const s=this.skipsUndoManager;i===null&&(this.skipsUndoManager=!0,i=""),this.undoManager.startTransaction(i);let n=!1;try{t(this),n=!0}finally{n?this.undoManager.commitTransaction(i):this.undoManager.rollbackTransaction(),this.skipsUndoManager=s}}updateTargetBindings(t,e){e===void 0&&(e=""),this.Ft("SourceChanged",1,e,t,null,null)}get nodeKeyProperty(){return this.Va}set nodeKeyProperty(t){const e=this.Va;e!==t&&(this.Un(t,Model,"nodeKeyProperty"),t===""&&U.o("Model.nodeKeyProperty may not be the empty string"),this.be.count>0&&U.o("Cannot set Model.nodeKeyProperty when there is existing node data"),this.Va=t,this.t("nodeKeyProperty",e,t))}Un(t,e,i){typeof t!="string"&&!U.nt(t)&&U.si(t,"string or function",e,i)}getKeyForNodeData(t){if(t===null)return;const e=this.Va;if(e==="")return;const i=this.Mt(t,e);if(i!==void 0){if(this.isKeyType(i))return i;U.o("Key value for node data "+t+" is not a number or a string: "+i)}}setKeyForNodeData(t,e){if((e==null||!this.isKeyType(e))&&U.si(e,"number or string",Model,"setKeyForNodeData:key"),t===null)return;const i=this.Va;if(i==="")return;if(!this.containsNodeData(t)){this.et(t,i,e);return}const s=this.Mt(t,i);if(s!==e){if(this.findNodeDataForKey(e)!==null)return;this.et(t,i,e),s!==void 0&&this.be.delete(s),this.be.set(e,t),this.Ft("nodeKey",2,i,t,s,e),typeof i=="string"&&this.updateTargetBindings(t,i),this.uw(s,e)}}get makeUniqueKeyFunction(){return this.Jf}set makeUniqueKeyFunction(t){const e=this.Jf;e!==t&&(t!==null&&U.S(t,Model,"makeUniqueKeyFunction"),this.Jf=t,this.t("makeUniqueKeyFunction",e,t))}isKeyType(t){return typeof t=="number"||typeof t=="string"}containsNodeData(t){if(t===null)return!1;const e=this.getKeyForNodeData(t);return e===void 0?!1:this.be.get(e)===t}findNodeDataForKey(t){return t===null&&U.o("Model.findNodeDataForKey:key must not be null"),t===void 0||!this.isKeyType(t)?null:this.be.get(t)}get nodeDataArray(){return this.Bi}set nodeDataArray(t){const e=this.Bi;if(e!==t){this.eL(t,Model,"nodeDataArray"),this.be.clear(),this.iL();const i=t.length;for(let o=0;o<i;o++){const r=t[o];U.$(r)||U.o("Model.nodeDataArray must only contain Objects, not: "+r),r===this.modelData&&U.o("nodeDataArray Objects must not be the shared Model.modelData")}this.Bi=t;const s=new List;for(let o=0;o<i;o++){const r=t[o],l=this.getKeyForNodeData(r);l===void 0||this.be.get(l)!==null?s.add(r):this.be.set(l,r)}const n=s.iterator;for(;n.next();){const o=n.value;this.makeNodeDataKeyUnique(o);const r=this.getKeyForNodeData(o);r!==void 0&&this.be.set(r,o)}this.Ft("nodeDataArray",2,"nodeDataArray",this,e,t);for(let o=0;o<i;o++){const r=t[o];this.Ag(r),this.Tg(r)}}}Rk(t){return t===void 0?!1:this.be.has(t)}makeNodeDataKeyUnique(t){if(t===null)return;const e=this.Va;if(e==="")return;let i=this.getKeyForNodeData(t);if(i!==void 0&&!this.Rk(i))return;const s=this.Jf;if(s!==null&&(i=s(this,t),i!=null&&!this.Rk(i))){this.et(t,e,i);return}if(typeof i=="string"){let n=2;for(;this.Rk(i+n);)n++;this.et(t,e,i+n)}else if(i===void 0||typeof i=="number"){let n=-this.be.count-1;for(;this.Rk(n);)n--;this.et(t,e,n)}}addNodeData(t){t!==null&&(t===this.modelData&&U.o("Model.addNodeData cannot add the shared Model.modelData Object"),this.containsNodeData(t)||this.vv(t,!0))}vv(t,e){let i=this.getKeyForNodeData(t);if(i===void 0)this.makeNodeDataKeyUnique(t),i=this.getKeyForNodeData(t);else{if(this.be.get(i)===t)return;this.makeNodeDataKeyUnique(t),i=this.getKeyForNodeData(t)}i===void 0&&U.o("Model.makeNodeDataKeyUnique failed on "+t+".  Data not added to Model."),this.be.set(i,t);let s=null;e&&(s=this.Bi.length,this.ar(this.Bi,s,t)),this.Ft("nodeDataArray",3,"nodeDataArray",this,null,t,null,s),this.Ag(t),this.Tg(t)}addNodeDataCollection(t){if(Array.isArray(t)){const e=t.length;for(let i=0;i<e;i++)this.addNodeData(t[i])}else{const e=t.iterator;for(;e.next();){const i=e.value;this.addNodeData(i)}}}removeNodeData(t){t!==null&&this.Dv(t,!0)}Dv(t,e){const i=this.getKeyForNodeData(t);i!==void 0&&this.be.delete(i);let s=null;if(e){if(s=this.Bi.indexOf(t),s<0)return;this.Co(this.Bi,s)}this.Ft("nodeDataArray",4,"nodeDataArray",this,t,null,s,null),this.dw(t)}removeNodeDataCollection(t){if(Array.isArray(t)){const e=t.length;for(let i=0;i<e;i++)this.removeNodeData(t[i])}else{const e=t.iterator;for(;e.next();){const i=e.value;this.removeNodeData(i)}}}mergeNodeDataArray(t){if(t===this.nodeDataArray||!Array.isArray(t))return;const e=new GSet;e.addAll(this.be.iteratorKeys);const i=new GSet,s=t.length;for(let o=0;o<s;o++){const r=t[o],l=this.getKeyForNodeData(r);if(l!==void 0){i.add(l);const a=this.findNodeDataForKey(l);if(a===r)continue;if(a!==null)this.assignAllDataProperties(a,r),this.Lg(r,a);else{const h=this.cloneDeep(r);this.setKeyForNodeData(h,l),this.addNodeData(h)}}else{const a=this.cloneDeep(r);this.addNodeData(a);const h=this.getKeyForNodeData(a);h!==void 0&&i.add(h)}}const n=e.iterator;for(;n.next();){const o=n.value;if(!i.has(o)){const r=this.findNodeDataForKey(o);r&&this.removeNodeData(r)}}}uw(t,e){if(e===void 0)return;const i=this.ow(t);i instanceof GSet&&this.lr.set(e,i)}iL(){}Ag(t){}Tg(t){}dw(t){}hn(t,e){if(t===void 0)return;let i=this.lr.get(t);i===null&&(i=new GSet,this.lr.set(t,i)),i.add(e)}an(t,e){if(t===void 0)return;const i=this.lr.get(t);i instanceof GSet&&(e==null?this.lr.delete(t):(i.delete(e),i.count===0&&this.lr.delete(t)))}ow(t){if(t===void 0)return null;const e=this.lr.get(t);return e instanceof GSet?e:null}GU(t){t===void 0?this.lr.clear():this.lr.delete(t)}get copyNodeDataFunction(){return this.$f}set copyNodeDataFunction(t){const e=this.$f;e!==t&&(t!==null&&U.S(t,Model,"copyNodeDataFunction"),this.$f=t,this.t("copyNodeDataFunction",e,t))}get copiesArrays(){return this.kg}set copiesArrays(t){const e=this.kg;e!==t&&(t!==null&&U.s(t,"boolean",Model,"copiesArrays"),this.kg=t,this.t("copiesArrays",e,t))}get copiesArrayObjects(){return this.Pg}set copiesArrayObjects(t){const e=this.Pg;e!==t&&(t!==null&&U.s(t,"boolean",Model,"copiesArrayObjects"),this.Pg=t,this.t("copiesArrayObjects",e,t))}get copiesKey(){return this.Sg}set copiesKey(t){const e=this.Sg;e!==t&&(t!==null&&U.s(t,"boolean",Model,"copiesKey"),this.Sg=t,this.t("copiesKey",e,t))}copyNodeData(t){let e=null;const i=this.$f;return i!==null?e=i(t,this):e=this.Ok(t,!0),e}Ok(t,e){if(U.$(t))if(Array.isArray(t))if(this.copiesArrays){const i=t,s=[];for(let n=0;n<i.length;n++){const o=i[n],r=this.Ok(o,this.copiesArrayObjects);s.push(r)}return s}else return t;else{if(t instanceof Point||t instanceof Size||t instanceof Rect||t instanceof Margin||t instanceof Spot)return t.copy();if(e){const i=t,s=i.constructor,n=s?new s:{},o=!this.copiesKey&&typeof this.nodeKeyProperty=="string"?this.nodeKeyProperty:null;for(const r in i){if(r==="__gohashid"){n.__gohashid=void 0;continue}if(r===o){n[o]=void 0;continue}const l=this.Mt(i,r);if(!U.$(l))n[r]=l;else if(Model.JC(i,r,l))this.et(n,r,l);else{const a=this.Ok(l,!1);this.et(n,r,a)}}return n}else return t}else return t}get afterCopyFunction(){return this.Mg}set afterCopyFunction(t){const e=this.Mg;e!==t&&(t!==null&&U.S(t,Model,"afterCopyFunction"),this.Mg=t,this.t("afterCopyFunction",e,t))}static JC(t,e,i){const s=U.Hn(i);return i instanceof Model||i instanceof UndoManager||i instanceof Transaction||i instanceof ChangedEvent||i instanceof GraphObject||i instanceof RowColumnDefinition||i instanceof Diagram||i instanceof EventTarget||s==="Layer"||s==="RowColumnDefinition"||s.indexOf("Animation")>=0||s.indexOf("Tool")>=0||s.indexOf("CommandHandler")>=0||s.indexOf("Layout")>=0}static $v=!1;setDataProperty(t,e,i){if(this.containsNodeData(t)){if(e===this.nodeKeyProperty){this.setKeyForNodeData(t,i);return}else if(e===this.nodeCategoryProperty){this.setCategoryForNodeData(t,i);return}}else!Model.$v&&t instanceof GraphObject&&(Model.$v=!0,U.ne('Model.setDataProperty is modifying a GraphObject, "'+t.toString()+'"'),U.ne("  Is that really your intent?"));const s=this.Mt(t,e);s!==i&&(this.et(t,e,i),this.raiseDataChanged(t,e,s,i))}set(t,e,i){this.setDataProperty(t,e,i)}assignAllDataProperties(t,e){if(!e)return;const i=this.containsNodeData(t);for(const s in e)s!=="__gohashid"&&(i&&s===this.nodeKeyProperty||this.setDataProperty(t,s,e[s]))}addArrayItem(t,e){this.insertArrayItem(t,-1,e)}insertArrayItem(t,e,i){e<0&&(e=t.length),t=this.ar(t,e,i),this.Ft("",3,"",t,null,i,null,e)}removeArrayItem(t,e){e===void 0&&(e=-1),t===this.Bi&&U.o("Model.removeArrayItem should not be called on the Model.nodeDataArray"),e===-1&&(e=t.length-1);const i=t[e];t=this.Co(t,e),this.Ft("",4,"",t,i,null,e,null)}get nodeCategoryProperty(){return this.rc}set nodeCategoryProperty(t){const e=this.rc;e!==t&&(this.Un(t,Model,"nodeCategoryProperty"),this.rc=t,this.t("nodeCategoryProperty",e,t))}getCategoryForNodeData(t){if(t===null)return"";const e=this.rc;if(e==="")return"";const i=this.Mt(t,e);if(i===void 0)return"";if(typeof i=="string")return i;U.o("getCategoryForNodeData found a non-string category for "+t+": "+i)}setCategoryForNodeData(t,e){if(U.s(e,"string",Model,"setCategoryForNodeData:cat"),t===null)return;const i=this.rc;if(i==="")return;if(!this.containsNodeData(t)){this.et(t,i,e);return}let s=this.Mt(t,i);s===void 0&&(s=""),s!==e&&(this.et(t,i,e),this.Ft("nodeCategory",2,i,t,s,e))}Lg(t,e){this.setCategoryForNodeData(e,this.getCategoryForNodeData(t))}get type(){return"Model"}Um(){return!1}Em(){return!1}l1(){return!1}jh(){return!1}Lx(){return!1}ff(){return!1}static g2(){return new Model}Mt(t,e){return Model.Mt(t,e)}static Mt(t,e){if(!t||!e)return null;let i;try{U.nt(e)?i=e(t):U.nt(t.getAttribute)?(i=t.getAttribute(e),i===null&&(i=void 0)):i=t[e]}catch{}return i}et(t,e,i){Model.et(t,e,i)}static et(t,e,i){if(!(!t||!e)){try{U.nt(e)?e(t,i):U.nt(t.setAttribute)?t.setAttribute(e,i):t[e]=i}catch{}return t}}eL(t,e,i){Array.isArray(t)||U.si(t,"Array",e,i)}qv(t,e,i){return t[e]=i,t}ar(t,e,i){return e>=t.length?t.push(i):t.splice(e,0,i),t}Co(t,e){return e>=t.length?t.pop():t.splice(e,1),t}static tL(t){return Model.sL[t]?Model.sL[t]:root.go!==void 0&&root.go[t]?root.go[t]:null}static Sl(t,e){Model.sL[e]=t}static sL={}}Model.fromJSON=Model.fromJson=Model.fromJson;Model.Sl(Brush,"Brush"),Model.Sl(Geometry,"Geometry"),Model.Sl(Margin,"Margin"),Model.Sl(Point,"Point"),Model.Sl(Rect,"Rect"),Model.Sl(Size,"Size"),Model.Sl(Spot,"Spot"),Model.Sl(Model,"Model");class GraphLinksModel extends Model{Is;hr;Oe;za;Zf;Qf;Vl;Lo;Ao;lc;ac;hc;cn;_f;Vn;Dg;constructor(t,e,i){if(super(),this.Is=[],this.hr=new GSet,this.Oe=new GMap,this.za="",this.Zf=null,this.Qf=null,this.Vl=null,this.Lo="from",this.Ao="to",this.lc="",this.ac="",this.hc="category",this.cn="",this._f="isGroup",this.Vn="group",this.Dg=!1,e!==void 0&&(this.linkDataArray=e),t!==void 0&&(Array.isArray(t)?this.nodeDataArray=t:i=t),i){Object.assign(this,i);const s=i.Changed;s&&(delete this.Changed,this.addChangedListener(s))}}cloneProtected(t){super.cloneProtected(t),t.za=this.za,t.Zf=this.Zf,t.Qf=this.Qf,t.Lo=this.Lo,t.Ao=this.Ao,t.lc=this.lc,t.ac=this.ac,t.hc=this.hc,t.cn=this.cn,t._f=this._f,t.Vn=this.Vn,t.Dg=this.Dg}clear(){this.Is=[],this.Oe.clear(),this.hr.clear(),super.clear()}toString(t){if(t===void 0&&(t=0),t>=2)return this.toJson();{let e=(this.name!==""?this.name:"")+" GraphLinksModel";if(t>0){e+=`
 node data:`;let i=this.nodeDataArray,s=i.length,n=0;for(n=0;n<s;n++){const o=i[n];e+=" "+this.getKeyForNodeData(o)+":"+Binding.toString(o)}for(e+=`
 link data:`,i=this.linkDataArray,s=i.length,n=0;n<s;n++){const o=i[n];e+=" "+this.Vi(o,!0)+"-->"+this.Vi(o,!1)}}return e}}WC(t,e,i){if(this.linkKeyProperty===""){const f=this.skipsUndoManager;this.skipsUndoManager=!0,this.linkKeyProperty="key",this.skipsUndoManager=f}let s=super.WC(t,e,i);const n=this,o=new GSet,r=new GSet,l=new GSet;t.changes.each(f=>{if(f.model===n){if(f.modelChange==="linkDataArray")f.change===3?o.add(f.newValue):f.change===4&&l.add(f.oldValue);else if(n.containsLinkData(f.object))f.object!==null&&r.add(f.object);else if(f.object!==null)if(f.object!==null&&i.has(f.object)){const u=i.get(f.object);u&&u.each(d=>{n.containsLinkData(d)&&r.add(d)})}else{if(f.object instanceof Model||n.containsNodeData(f.object))return;n.Zv(f.object).each(d=>r.add(d))}}});const a=new GSet;o.each(f=>{const u=n.getKeyForLinkData(f);u!==void 0&&a.add(u),e||r.add(f)});const h=new GSet;l.each(f=>{const u=n.getKeyForLinkData(f);u!==void 0&&h.add(u),e&&r.add(f)});const c=n.cloneDeep(r.toArray());return a.count>0&&(s===null&&(s={}),e?s.removedLinkKeys=a.toArray():s.insertedLinkKeys=a.toArray()),c.length>0&&(s===null&&(s={}),s.modifiedLinkData=c),h.count>0&&(s===null&&(s={}),e?s.insertedLinkKeys=h.toArray():s.removedLinkKeys=h.toArray()),s}Cg(){const t=super.Cg();let e="";return this.linkCategoryProperty!=="category"&&typeof this.linkCategoryProperty=="string"&&(e+=`,
  "linkCategoryProperty": `+this.zi(this.linkCategoryProperty)),this.linkKeyProperty!==""&&typeof this.linkKeyProperty=="string"&&(e+=`,
  "linkKeyProperty": `+this.zi(this.linkKeyProperty)),this.linkFromKeyProperty!=="from"&&typeof this.linkFromKeyProperty=="string"&&(e+=`,
  "linkFromKeyProperty": `+this.zi(this.linkFromKeyProperty)),this.linkToKeyProperty!=="to"&&typeof this.linkToKeyProperty=="string"&&(e+=`,
  "linkToKeyProperty": `+this.zi(this.linkToKeyProperty)),this.linkFromPortIdProperty!==""&&typeof this.linkFromPortIdProperty=="string"&&(e+=`,
  "linkFromPortIdProperty": `+this.zi(this.linkFromPortIdProperty)),this.linkToPortIdProperty!==""&&typeof this.linkToPortIdProperty=="string"&&(e+=`,
  "linkToPortIdProperty": `+this.zi(this.linkToPortIdProperty)),this.linkLabelKeysProperty!==""&&typeof this.linkLabelKeysProperty=="string"&&(e+=`,
  "linkLabelKeysProperty": `+this.zi(this.linkLabelKeysProperty)),this.nodeIsGroupProperty!=="isGroup"&&typeof this.nodeIsGroupProperty=="string"&&(e+=`,
  "nodeIsGroupProperty": `+this.zi(this.nodeIsGroupProperty)),this.nodeGroupKeyProperty!=="group"&&typeof this.nodeGroupKeyProperty=="string"&&(e+=`,
  "nodeGroupKeyProperty": `+this.zi(this.nodeGroupKeyProperty)),t+e}cw(t){super.cw(t),t.linkKeyProperty&&(this.linkKeyProperty=t.linkKeyProperty),t.linkFromKeyProperty&&(this.linkFromKeyProperty=t.linkFromKeyProperty),t.linkToKeyProperty&&(this.linkToKeyProperty=t.linkToKeyProperty),t.linkFromPortIdProperty&&(this.linkFromPortIdProperty=t.linkFromPortIdProperty),t.linkToPortIdProperty&&(this.linkToPortIdProperty=t.linkToPortIdProperty),t.linkCategoryProperty&&(this.linkCategoryProperty=t.linkCategoryProperty),t.linkLabelKeysProperty&&(this.linkLabelKeysProperty=t.linkLabelKeysProperty),t.nodeIsGroupProperty&&(this.nodeIsGroupProperty=t.nodeIsGroupProperty),t.nodeGroupKeyProperty&&(this.nodeGroupKeyProperty=t.nodeGroupKeyProperty)}$C(){const t=super.$C(),e=`,
  "linkDataArray": `+this.Ba(this.linkDataArray,!0);return t+e}ZC(t){super.ZC(t);const e=t.linkDataArray;Array.isArray(e)&&(this.replaceJsonObjects(e),this.linkDataArray=e)}Qv=`,
  "insertedLinkKeys": `;c3=`,
  "modifiedLinkData": `;_v=`,
  "removedLinkKeys": `;Zv(t){const e=new GSet;for(let i=0;i<this.linkDataArray.length;i++){const s=this.linkDataArray[i];this.Fk(t,s,s,e)}return e}_C(t,e,i){if(this.linkKeyProperty===""){const f=this.skipsUndoManager;this.skipsUndoManager=!0,this.linkKeyProperty="key",this.skipsUndoManager=f}const s=super._C(t,e,i),n=this,o=new GSet,r=new GSet,l=new GSet;t.changes.each(f=>{if(f.model===n){if(f.modelChange==="linkDataArray")f.change===3?o.add(f.newValue):f.change===4&&l.add(f.oldValue);else if(n.containsLinkData(f.object))f.object!==null&&r.add(f.object);else if(f.object!==null)if(f.object!==null&&i.has(f.object)){const u=i.get(f.object);u&&u.each(d=>{n.containsLinkData(d)&&r.add(d)})}else{if(f.object instanceof Model||n.containsNodeData(f.object))return;n.Zv(f.object).each(d=>r.add(d))}}});const a=new GSet;o.each(f=>{const u=n.getKeyForLinkData(f);u!==void 0&&a.add(u),e||r.add(f)});const h=new GSet;l.each(f=>{const u=n.getKeyForLinkData(f);u!==void 0&&h.add(u),e&&r.add(f)});let c=s;return a.count>0&&(c+=(e?this._v:this.Qv)+this.Ba(a.toArray(),!0)),r.count>0&&(c+=this.c3+this.Ba(r.toArray(),!0)),h.count>0&&(c+=(e?this.Qv:this._v)+this.Ba(h.toArray(),!0)),c}fw(t){(t.linkCategoryProperty!==void 0&&t.linkCategoryProperty!==this.linkCategoryProperty||t.linkKeyProperty!==void 0&&t.linkKeyProperty!==this.linkKeyProperty||t.linkFromKeyProperty!==void 0&&t.linkFromKeyProperty!==this.linkFromKeyProperty||t.linkToKeyProperty!==void 0&&t.linkToKeyProperty!==this.linkToKeyProperty||t.linkFromPortIdProperty!==void 0&&t.linkFromPortIdProperty!==this.linkFromPortIdProperty||t.linkToPortIdProperty!==void 0&&t.linkToPortIdProperty!==this.linkToPortIdProperty||t.linkLabelKeysProperty!==void 0&&t.linkLabelKeysProperty!==this.linkLabelKeysProperty||t.nodeIsGroupProperty!==void 0&&t.nodeIsGroupProperty!==this.nodeIsGroupProperty||t.nodeGroupKeyProperty!==void 0&&t.nodeGroupKeyProperty!==this.nodeGroupKeyProperty)&&U.o("applyIncrementalJson cannot change Model properties"),super.fw(t);const e=t.insertedLinkKeys;if(Array.isArray(e)){const n=e.length;for(let o=0;o<n;o++){const r=e[o];let l=this.findLinkDataForKey(r);l===null&&(l=this.copyLinkData({}),this.setKeyForLinkData(l,r),this.addLinkData(l))}}const i=t.modifiedLinkData;if(Array.isArray(i)){const n=i.length;for(let o=0;o<n;o++){const r=i[o],l=this.getKeyForLinkData(r),a=this.findLinkDataForKey(l);if(a!==null){for(const h in r)h==="__gohashid"||h===this.linkKeyProperty||this.setDataProperty(a,h,r[h]);this.tF(r,a)}}}const s=t.removedLinkKeys;if(Array.isArray(s)){const n=s.length;for(let o=0;o<n;o++){const r=s[o],l=this.findLinkDataForKey(r);l!==null&&this.removeLinkData(l)}}}changeState(t,e){if(!(t===null||t.model!==this)){if(t.change===2){const i=t.object,s=t.propertyName;if(i!==null&&s===this.linkKeyProperty&&this.containsLinkData(i)){const n=t.getValue(e),o=t.getValue(!e);o!==void 0&&this.Oe.delete(o),n!==void 0&&this.Oe.set(n,i),this.et(i,s,n);return}}else if(t.change===3){let i=t.newParam;if(t.modelChange==="linkDataArray"){const s=t.newValue;if(U.$(s)&&typeof i=="number"){const n=this.getKeyForLinkData(s);e?(this.hr.delete(s),this.Is[i]===s&&this.Co(this.linkDataArray,i),n!==void 0&&this.Oe.delete(n)):(this.hr.add(s),this.Is[i]!==s&&this.ar(this.Is,i,s),n!==void 0&&this.Oe.set(n,s))}return}else if(t.modelChange==="linkLabelKeys"){const s=t.object,n=s!==null?this.getLabelKeysForLinkData(s):null;Array.isArray(n)&&typeof i=="number"&&(e?(i=n.indexOf(t.newValue),i>=0&&this.Co(n,i)):n.indexOf(t.newValue)<0&&this.ar(n,i,t.newValue));return}}else if(t.change===4){let i=t.oldParam;if(t.modelChange==="linkDataArray"){const s=t.oldValue;if(U.$(s)&&typeof i=="number"){const n=this.getKeyForLinkData(s);e?(this.hr.add(s),this.Is[i]!==s&&this.ar(this.Is,i,s),n!==void 0&&this.Oe.set(n,s)):(this.hr.delete(s),this.Is[i]===s&&this.Co(this.linkDataArray,i),n!==void 0&&this.Oe.delete(n))}return}else if(t.modelChange==="linkLabelKeys"){const s=t.object,n=s!==null?this.getLabelKeysForLinkData(s):null;Array.isArray(n)&&typeof i=="number"&&(e?n.indexOf(t.oldValue)<0&&this.ar(n,i,t.oldValue):(i=n.indexOf(t.oldValue),i>=0&&this.Co(n,i)));return}}super.changeState(t,e)}}get archetypeNodeData(){return this.Vl}set archetypeNodeData(t){const e=this.Vl;e!==t&&(t!==null&&U.wc(t,GraphLinksModel,"archetypeNodeData"),this.Vl=t,this.t("archetypeNodeData",e,t))}nL(t){if(t===void 0)return;const e=this.Vl;if(e!==null){let i=this.findNodeDataForKey(t);i===null&&(i=this.copyNodeData(e),this.et(i,this.nodeKeyProperty,t),this.addNodeData(i))}return t}get linkFromKeyProperty(){return this.Lo}set linkFromKeyProperty(t){const e=this.Lo;e!==t&&(this.Un(t,GraphLinksModel,"linkFromKeyProperty"),this.Lo=t,this.t("linkFromKeyProperty",e,t))}getFromKeyForLinkData(t){return this.Vi(t,!0)}setFromKeyForLinkData(t,e){this.wg(t,e,!0)}get linkToKeyProperty(){return this.Ao}set linkToKeyProperty(t){const e=this.Ao;e!==t&&(this.Un(t,GraphLinksModel,"linkToKeyProperty"),this.Ao=t,this.t("linkToKeyProperty",e,t))}getToKeyForLinkData(t){return this.Vi(t,!1)}setToKeyForLinkData(t,e){this.wg(t,e,!1)}Vi(t,e){if(t===null)return;const i=e?this.Lo:this.Ao;if(i==="")return;const s=this.Mt(t,i);if(s!==void 0){if(this.isKeyType(s))return s;U.o((e?"FromKey":"ToKey")+" value for link data "+t+" is not a number or a string: "+s)}}wg(t,e,i){if(e===null&&(e=void 0),e!==void 0&&!this.isKeyType(e)&&U.si(e,"number or string",GraphLinksModel,i?"setFromKeyForLinkData:key":"setToKeyForLinkData:key"),t===null)return;const s=i?this.Lo:this.Ao;if(s==="")return;if(e=this.nL(e),!this.containsLinkData(t)){this.et(t,s,e);return}const n=this.Mt(t,s);n!==e&&(this.an(n,t),this.et(t,s,e),this.findNodeDataForKey(e)===null&&this.hn(e,t),this.Ft(i?"linkFromKey":"linkToKey",2,s,t,n,e),typeof s=="string"&&this.updateTargetBindings(t,s))}get linkFromPortIdProperty(){return this.lc}set linkFromPortIdProperty(t){const e=this.lc;e!==t&&(this.Un(t,GraphLinksModel,"linkFromPortIdProperty"),this.lc=t,this.t("linkFromPortIdProperty",e,t))}getFromPortIdForLinkData(t){return this.Lk(t,!0)}setFromPortIdForLinkData(t,e){this.xg(t,e,!0)}get linkToPortIdProperty(){return this.ac}set linkToPortIdProperty(t){const e=this.ac;e!==t&&(this.Un(t,GraphLinksModel,"linkToPortIdProperty"),this.ac=t,this.t("linkToPortIdProperty",e,t))}getToPortIdForLinkData(t){return this.Lk(t,!1)}setToPortIdForLinkData(t,e){this.xg(t,e,!1)}Lk(t,e){if(t===null)return"";const i=e?this.lc:this.ac;if(i==="")return"";const s=this.Mt(t,i);return s===void 0?"":s}xg(t,e,i){if(U.s(e,"string",GraphLinksModel,i?"setFromPortIdForLinkData:portname":"setToPortIdForLinkData:portname"),t===null)return;const s=i?this.lc:this.ac;if(s==="")return;if(!this.containsLinkData(t)){this.et(t,s,e);return}let n=this.Mt(t,s);n===void 0&&(n=""),n!==e&&(this.et(t,s,e),this.Ft(i?"linkFromPortId":"linkToPortId",2,s,t,n,e),typeof s=="string"&&this.updateTargetBindings(t,s))}get linkLabelKeysProperty(){return this.cn}set linkLabelKeysProperty(t){const e=this.cn;e!==t&&(this.Un(t,GraphLinksModel,"linkLabelKeysProperty"),this.cn=t,this.t("linkLabelKeysProperty",e,t))}getLabelKeysForLinkData(t){if(t===null)return GraphLinksModel.EmptyArray;const e=this.cn;if(e==="")return GraphLinksModel.EmptyArray;const i=this.Mt(t,e);return i===void 0?GraphLinksModel.EmptyArray:i}setLabelKeysForLinkData(t,e){if(this.eL(e,GraphLinksModel,"setLabelKeysForLinkData:arr"),t===null)return;const i=this.cn;if(i==="")return;if(!this.containsLinkData(t)){this.et(t,i,e);return}let s=this.Mt(t,i);if(s===void 0&&(s=GraphLinksModel.EmptyArray),s!==e){if(Array.isArray(s)){const o=s.length;for(let r=0;r<o;r++){const l=s[r];this.an(l,t)}}this.et(t,i,e);const n=e.length;for(let o=0;o<n;o++){const r=e[o];this.findNodeDataForKey(r)===null&&this.hn(r,t)}this.Ft("linkLabelKeys",2,i,t,s,e),typeof i=="string"&&this.updateTargetBindings(t,i)}}addLabelKeyForLinkData(t,e){if(e==null||(this.isKeyType(e)||U.si(e,"number or string",GraphLinksModel,"addLabelKeyForLinkData:key"),t===null))return;const i=this.cn;if(i==="")return;const s=this.Mt(t,i);if(s===void 0){const n=[];n.push(e),this.setLabelKeysForLinkData(t,n)}else if(Array.isArray(s)){let n=s.indexOf(e);if(n>=0)return;n=s.length,s.push(e),this.containsLinkData(t)&&(this.findNodeDataForKey(e)===null&&this.hn(e,t),this.Ft("linkLabelKeys",3,i,t,null,e,null,n))}else U.o(i+" property is not an Array; cannot addLabelKeyForLinkData: "+t)}removeLabelKeyForLinkData(t,e){if(e==null||(this.isKeyType(e)||U.si(e,"number or string",GraphLinksModel,"removeLabelKeyForLinkData:key"),t===null))return;const i=this.cn;if(i==="")return;const s=this.Mt(t,i);if(Array.isArray(s)){const n=s.indexOf(e);if(n<0)return;this.Co(s,n),this.containsLinkData(t)&&(this.an(e,t),this.Ft("linkLabelKeys",4,i,t,e,null,n,null))}else s!==void 0&&U.o(i+" property is not an Array; cannot removeLabelKeyforLinkData: "+t)}get linkDataArray(){return this.Is}set linkDataArray(t){const e=this.Is;if(e!==t){this.eL(t,GraphLinksModel,"linkDataArray"),this.Oe.clear();const i=t.length;for(let n=0;n<i;n++){const o=t[n];U.$(o)||U.o("GraphLinksModel.linkDataArray must only contain Objects, not: "+o)}if(this.Is=t,this.linkKeyProperty!==""){const n=new List;for(let r=0;r<i;r++){const l=t[r],a=this.getKeyForLinkData(l);a===void 0||this.Oe.get(a)!==null?n.add(l):this.Oe.set(a,l)}const o=n.iterator;for(;o.next();){const r=o.value;this.makeLinkDataKeyUnique(r);const l=this.getKeyForLinkData(r);l!==void 0&&this.Oe.set(l,r)}}const s=new GSet;for(let n=0;n<i;n++){const o=t[n];s.add(o)}this.hr=s,this.Ft("linkDataArray",2,"linkDataArray",this,e,t);for(let n=0;n<i;n++){const o=t[n];this.oL(o)}}}get linkKeyProperty(){return this.za}set linkKeyProperty(t){const e=this.za;if(e!==t){this.Un(t,GraphLinksModel,"linkKeyProperty"),this.za=t,this.Oe.clear();const i=this.linkDataArray.length;for(let s=0;s<i;s++){const n=this.linkDataArray[s];let o=this.getKeyForLinkData(n);o===void 0&&(this.makeLinkDataKeyUnique(n),o=this.getKeyForLinkData(n)),o!==void 0&&this.Oe.set(o,n)}this.t("linkKeyProperty",e,t)}}getKeyForLinkData(t){if(t===null)return;const e=this.za;if(e==="")return;const i=this.Mt(t,e);if(i!==void 0){if(this.isKeyType(i))return i;U.o("Key value for link data "+t+" is not a number or a string: "+i)}}setKeyForLinkData(t,e){if((e==null||!this.isKeyType(e))&&U.si(e,"number or string",GraphLinksModel,"setKeyForLinkData:key"),t===null)return;const i=this.za;if(i==="")return;if(!this.containsLinkData(t)){this.et(t,i,e);return}const s=this.Mt(t,i);if(s!==e){if(this.findLinkDataForKey(e)!==null)return;this.et(t,i,e),s!==void 0&&this.Oe.delete(s),this.Oe.set(e,t),this.Ft("linkKey",2,i,t,s,e),typeof i=="string"&&this.updateTargetBindings(t,i)}}get makeUniqueLinkKeyFunction(){return this.Zf}set makeUniqueLinkKeyFunction(t){const e=this.Zf;e!==t&&(t!==null&&U.S(t,GraphLinksModel,"makeUniqueLinkKeyFunction"),this.Zf=t,this.t("makeUniqueLinkKeyFunction",e,t))}findLinkDataForKey(t){return t===null&&U.o("GraphLinksModel.findLinkDataForKey:key must not be null"),t===void 0||!this.isKeyType(t)?null:this.Oe.get(t)}Ik(t){return t===void 0?!1:this.Oe.has(t)}makeLinkDataKeyUnique(t){if(t===null)return;const e=this.za;if(e==="")return;let i=this.getKeyForLinkData(t);if(i!==void 0&&!this.Ik(i))return;const s=this.Zf;if(s!==null&&(i=s(this,t),i!=null&&!this.Ik(i))){this.et(t,e,i);return}if(typeof i=="string"){let n=2;for(;this.Ik(i+n);)n++;this.et(t,e,i+n)}else if(i===void 0||typeof i=="number"){let n=-this.Oe.count-1;for(;this.Ik(n);)n--;this.et(t,e,n)}}containsLinkData(t){return t===null?!1:this.hr.has(t)}addLinkData(t){t!==null&&(this.containsLinkData(t)||this.Uv(t,!0))}Uv(t,e){if(this.linkKeyProperty!==""){let s=this.getKeyForLinkData(t);if(s===void 0)this.makeLinkDataKeyUnique(t),s=this.getKeyForLinkData(t);else{if(this.Oe.get(s)===t)return;this.makeLinkDataKeyUnique(t),s=this.getKeyForLinkData(t)}s===void 0&&U.o("GraphLinksModel.makeLinkDataKeyUnique failed on "+t+". Data not added to model."),this.Oe.set(s,t)}this.hr.add(t);let i=null;e&&(i=this.Is.length,this.ar(this.Is,i,t)),this.Ft("linkDataArray",3,"linkDataArray",this,null,t,null,i),this.oL(t)}addLinkDataCollection(t){if(Array.isArray(t)){const e=t.length;for(let i=0;i<e;i++)this.addLinkData(t[i])}else{const e=t.iterator;for(;e.next();){const i=e.value;this.addLinkData(i)}}}removeLinkData(t){t!==null&&this.Ev(t,!0)}Ev(t,e){this.hr.delete(t);const i=this.getKeyForLinkData(t);i!==void 0&&this.Oe.delete(i);let s=null;if(e){if(s=this.Is.indexOf(t),s<0)return;this.Co(this.Is,s)}this.Ft("linkDataArray",4,"linkDataArray",this,t,null,s,null),this.f3(t)}removeLinkDataCollection(t){if(Array.isArray(t)){const e=t.length;for(let i=0;i<e;i++)this.removeLinkData(t[i])}else{const e=t.iterator;for(;e.next();){const i=e.value;this.removeLinkData(i)}}}mergeLinkDataArray(t){if(this.linkKeyProperty===""&&U.o("GraphLinksModel.linkKeyProperty must not be an empty string for .mergeLinkDataArray() to succeed."),t===this.linkDataArray||!Array.isArray(t))return;const e=new GSet;e.addAll(this.Oe.iteratorKeys);const i=new GSet,s=t.length;for(let o=0;o<s;o++){const r=t[o],l=this.getKeyForLinkData(r);if(l!==void 0){i.add(l);const a=this.findLinkDataForKey(l);if(a===r)continue;if(a!==null)this.assignAllDataProperties(a,r),this.tF(r,a);else{const h=this.cloneDeep(r);this.setKeyForLinkData(h,l),this.addLinkData(h)}}else{const a=this.cloneDeep(r);this.addLinkData(a);const h=this.getKeyForLinkData(a);h!==void 0&&i.add(h)}}const n=e.iterator;for(;n.next();){const o=n.value;if(!i.has(o)){const r=this.findLinkDataForKey(o);r&&this.removeLinkData(r)}}}oL(t){let e=this.Vi(t,!0);e=this.nL(e),this.findNodeDataForKey(e)===null&&this.hn(e,t),e=this.Vi(t,!1),e=this.nL(e),this.findNodeDataForKey(e)===null&&this.hn(e,t);const i=this.getLabelKeysForLinkData(t);if(Array.isArray(i)){const s=i.length;for(let n=0;n<s;n++)e=i[n],this.findNodeDataForKey(e)===null&&this.hn(e,t)}}f3(t){let e=this.Vi(t,!0);this.an(e,t),e=this.Vi(t,!1),this.an(e,t);const i=this.getLabelKeysForLinkData(t);if(Array.isArray(i)){const s=i.length;for(let n=0;n<s;n++)e=i[n],this.an(e,t)}}get copyLinkDataFunction(){return this.Qf}set copyLinkDataFunction(t){const e=this.Qf;e!==t&&(t!==null&&U.S(t,GraphLinksModel,"copyLinkDataFunction"),this.Qf=t,this.t("copyLinkDataFunction",e,t))}copyLinkData(t){let e=null;const i=this.Qf;return i!==null?e=i(t,this):e=this.Ok(t,!0),U.$(e)&&(this.Lo!==""&&this.et(e,this.Lo,void 0),this.Ao!==""&&this.et(e,this.Ao,void 0),this.cn!==""&&this.et(e,this.cn,[])),e}get nodeIsGroupProperty(){return this._f}set nodeIsGroupProperty(t){const e=this._f;e!==t&&(this.Un(t,GraphLinksModel,"nodeIsGroupProperty"),this._f=t,this.t("nodeIsGroupProperty",e,t))}isGroupForNodeData(t){if(t===null)return!1;const e=this._f;return e===""?!1:!!this.Mt(t,e)}isGroupForData(t){return this.isGroupForNodeData(t)}get nodeGroupKeyProperty(){return this.Vn}set nodeGroupKeyProperty(t){const e=this.Vn;e!==t&&(this.Un(t,GraphLinksModel,"nodeGroupKeyProperty"),this.Vn=t,this.t("nodeGroupKeyProperty",e,t))}get copiesGroupKeyOfNodeData(){return this.Dg}set copiesGroupKeyOfNodeData(t){this.Dg!==t&&(U.s(t,"boolean",GraphLinksModel,"copiesGroupKeyOfNodeData"),this.Dg=t)}getGroupKeyForNodeData(t){if(t===null)return;const e=this.Vn;if(e==="")return;const i=this.Mt(t,e);if(i!==void 0){if(this.isKeyType(i))return i;U.o("GroupKey value for node data "+t+" is not a number or a string: "+i)}}getGroupForData(t){return this.getGroupKeyForNodeData(t)}setGroupKeyForNodeData(t,e){if(e===null&&(e=void 0),e!==void 0&&!this.isKeyType(e)&&U.si(e,"number or string",GraphLinksModel,"setGroupKeyForNodeData:key"),t===null)return;const i=this.Vn;if(i==="")return;if(!this.containsNodeData(t)){this.et(t,i,e);return}const s=this.Mt(t,i);s!==e&&(this.an(s,t),this.et(t,i,e),this.findNodeDataForKey(e)===null&&this.hn(e,t),this.Ft("nodeGroupKey",2,i,t,s,e),typeof i=="string"&&this.updateTargetBindings(t,i))}setGroupForData(t,e){this.setGroupKeyForNodeData(t,e)}copyNodeData(t){const e=super.copyNodeData(t);return!this.copiesGroupKeyOfNodeData&&this.Vn!==""&&this.Mt(e,this.Vn)!==void 0&&this.et(e,this.Vn,void 0),e}setDataProperty(t,e,i){if(this.containsNodeData(t)){if(e===this.nodeKeyProperty){this.setKeyForNodeData(t,i);return}else if(e===this.nodeCategoryProperty){this.setCategoryForNodeData(t,i);return}else if(e===this.nodeGroupKeyProperty){this.setGroupKeyForNodeData(t,i);return}}else if(this.containsLinkData(t)){if(e===this.linkFromKeyProperty){this.wg(t,i,!0);return}else if(e===this.linkToKeyProperty){this.wg(t,i,!1);return}else if(e===this.linkFromPortIdProperty){this.xg(t,i,!0);return}else if(e===this.linkToPortIdProperty){this.xg(t,i,!1);return}else if(e===this.linkKeyProperty){this.setKeyForLinkData(t,i);return}else if(e===this.linkCategoryProperty){this.setCategoryForLinkData(t,i);return}else if(e===this.linkLabelKeysProperty){this.setLabelKeysForLinkData(t,i);return}}const s=this.Mt(t,e);s!==i&&(this.et(t,e,i),this.raiseDataChanged(t,e,s,i))}assignAllDataProperties(t,e){if(!e)return;const i=this.containsNodeData(t),s=this.containsLinkData(t);for(const n in e)if(n!=="__gohashid"&&!(i&&n===this.nodeKeyProperty)){{if(i&&n===this.nodeIsGroupProperty&&this.Mt(t,n)===e[n])continue;if(s&&n===this.linkKeyProperty)continue}this.setDataProperty(t,n,e[n])}}uw(t,e){super.uw(t,e);const i=this.be.iterator;for(;i.next();){const n=i.value;this.rL(n,t,e)}const s=this.hr.iterator;for(;s.next();){const n=s.value;this.u3(n,t,e)}}rL(t,e,i){if(this.getGroupKeyForNodeData(t)===e){const n=this.Vn;this.et(t,n,i),this.Ft("nodeGroupKey",2,n,t,e,i),typeof n=="string"&&this.updateTargetBindings(t,n)}}u3(t,e,i){if(this.Vi(t,!0)===e){const r=this.Lo;this.et(t,r,i),this.Ft("linkFromKey",2,r,t,e,i),typeof r=="string"&&this.updateTargetBindings(t,r)}if(this.Vi(t,!1)===e){const r=this.Ao;this.et(t,r,i),this.Ft("linkToKey",2,r,t,e,i),typeof r=="string"&&this.updateTargetBindings(t,r)}const o=this.getLabelKeysForLinkData(t);if(Array.isArray(o)){const r=o.length,l=this.cn;for(let a=0;a<r;a++)o[a]===e&&(this.qv(o,a,i),this.Ft("linkLabelKeys",3,l,t,e,i,a,a))}}iL(){super.iL();const t=this.linkDataArray,e=t.length;for(let i=0;i<e;i++){const s=t[i];this.oL(s)}}Ag(t){super.Ag(t);const e=this.getKeyForNodeData(t),i=this.ow(e);if(i!==null){const s=U.ot(),n=i.iterator;for(;n.next();){const o=n.value;if(this.containsNodeData(o)){if(this.getGroupKeyForNodeData(o)===e){const l=this.Vn;this.Ft("nodeGroupKey",2,l,o,e,e),typeof l=="string"&&this.updateTargetBindings(o,l),s.push(o)}}else{if(this.Vi(o,!0)===e){const h=this.Lo;this.Ft("linkFromKey",2,h,o,e,e),typeof h=="string"&&this.updateTargetBindings(o,h),s.push(o)}if(this.Vi(o,!1)===e){const h=this.Ao;this.Ft("linkToKey",2,h,o,e,e),typeof h=="string"&&this.updateTargetBindings(o,h),s.push(o)}const a=this.getLabelKeysForLinkData(o);if(Array.isArray(a)){const h=a.length,c=this.cn;for(let f=0;f<h;f++)a[f]===e&&(this.Ft("linkLabelKeys",3,c,o,e,e,f,f),s.push(o))}}}for(let o=0;o<s.length;o++)this.an(e,s[o]);U.Z(s)}}Tg(t){super.Tg(t);const e=this.getGroupKeyForNodeData(t);this.findNodeDataForKey(e)===null&&this.hn(e,t)}dw(t){super.dw(t);const e=this.getGroupKeyForNodeData(t);this.an(e,t)}get linkCategoryProperty(){return this.hc}set linkCategoryProperty(t){const e=this.hc;e!==t&&(this.Un(t,GraphLinksModel,"linkCategoryProperty"),this.hc=t,this.t("linkCategoryProperty",e,t))}getCategoryForLinkData(t){if(t===null)return"";const e=this.hc;if(e==="")return"";const i=this.Mt(t,e);if(i===void 0)return"";if(typeof i=="string")return i;U.o("getCategoryForLinkData found a non-string category for "+t+": "+i)}getLinkCategoryForData(t){return this.getCategoryForLinkData(t)}setCategoryForLinkData(t,e){if(U.s(e,"string",GraphLinksModel,"setCategoryForLinkData:cat"),t===null)return;const i=this.hc;if(i==="")return;if(!this.containsLinkData(t)){this.et(t,i,e);return}let s=this.Mt(t,i);s===void 0&&(s=""),s!==e&&(this.et(t,i,e),this.Ft("linkCategory",2,i,t,s,e),typeof i=="string"&&this.updateTargetBindings(t,i))}setLinkCategoryForData(t,e){this.setCategoryForLinkData(t,e)}Lg(t,e){super.Lg(t,e),this.setGroupKeyForNodeData(e,this.getGroupKeyForNodeData(t))}tF(t,e){this.setCategoryForLinkData(e,this.getCategoryForLinkData(t)),this.setFromKeyForLinkData(e,this.getFromKeyForLinkData(t)),this.setToKeyForLinkData(e,this.getToKeyForLinkData(t)),this.setLabelKeysForLinkData(e,this.getLabelKeysForLinkData(t)),this.setFromPortIdForLinkData(e,this.getFromPortIdForLinkData(t)),this.setToPortIdForLinkData(e,this.getToPortIdForLinkData(t))}get type(){return"GraphLinksModel"}Em(){return!0}jh(){return!0}Lx(){return!0}ff(){return!0}static EmptyArray=Object.freeze([])}Model.Sl(GraphLinksModel,"GraphLinksModel");Model.jv=()=>new GraphLinksModel;Model.g2=()=>new GraphLinksModel;class TreeModel extends Model{Bn;vg;cc;constructor(t,e){if(super(),this.Bn="parent",this.vg=!1,this.cc="parentLinkCategory",t!==void 0&&(Array.isArray(t)?this.nodeDataArray=t:e=t),e){Object.assign(this,e);const i=e.Changed;i&&(delete this.Changed,this.addChangedListener(i))}}cloneProtected(t){super.cloneProtected(t),t.Bn=this.Bn,t.vg=this.vg,t.cc=this.cc}toString(t){if(t===void 0&&(t=0),t>=2)return this.toJson();{let e=(this.name!==""?this.name:"")+" TreeModel";if(t>0){e+=`
 node data:`;const i=this.nodeDataArray,s=i.length;for(let n=0;n<s;n++){const o=i[n];e+=" "+this.getKeyForNodeData(o)+":"+Binding.toString(o)}}return e}}Cg(){const t=super.Cg();let e="";return this.nodeParentKeyProperty!=="parent"&&typeof this.nodeParentKeyProperty=="string"&&(e+=`,
  "nodeParentKeyProperty": `+this.zi(this.nodeParentKeyProperty)),t+e}cw(t){super.cw(t),t.nodeParentKeyProperty&&(this.nodeParentKeyProperty=t.nodeParentKeyProperty)}fw(t){t.nodeParentKeyProperty!==void 0&&t.nodeParentKeyProperty!==this.nodeParentKeyProperty&&U.o("applyIncrementalJson cannot change Model properties"),super.fw(t)}maybeEnsureLinkReference(t){return t}get nodeParentKeyProperty(){return this.Bn}set nodeParentKeyProperty(t){const e=this.Bn;e!==t&&(this.Un(t,TreeModel,"nodeParentKeyProperty"),this.Bn=t,this.t("nodeParentKeyProperty",e,t))}get copiesParentKeyOfNodeData(){return this.vg}set copiesParentKeyOfNodeData(t){this.vg!==t&&(U.s(t,"boolean",TreeModel,"copiesParentKeyOfNodeData"),this.vg=t)}getParentKeyForNodeData(t){if(t===null)return;const e=this.Bn;if(e==="")return;const i=this.Mt(t,e);if(i!==void 0){if(this.isKeyType(i))return i;U.o("ParentKey value for node data "+t+" is not a number or a string: "+i)}}setParentKeyForNodeData(t,e){if(e===null&&(e=void 0),e!==void 0&&!this.isKeyType(e)&&U.si(e,"number or string",TreeModel,"setParentKeyForNodeData:key"),t===null)return;const i=this.Bn;if(i==="")return;if(e=this.maybeEnsureLinkReference(e),!this.containsNodeData(t)){this.et(t,i,e);return}const s=this.Mt(t,i);s!==e&&(this.an(s,t),this.et(t,i,e),this.findNodeDataForKey(e)===null&&this.hn(e,t),this.Ft("nodeParentKey",2,i,t,s,e),typeof i=="string"&&this.updateTargetBindings(t,i))}get parentLinkCategoryProperty(){return this.cc}set parentLinkCategoryProperty(t){const e=this.cc;e!==t&&(this.Un(t,TreeModel,"parentLinkCategoryProperty"),this.cc=t,this.t("parentLinkCategoryProperty",e,t))}get linkCategoryProperty(){return this.parentLinkCategoryProperty}set linkCategoryProperty(t){this.parentLinkCategoryProperty=t}getParentLinkCategoryForNodeData(t){if(t===null)return"";const e=this.cc;if(e==="")return"";const i=this.Mt(t,e);if(i===void 0)return"";if(typeof i=="string")return i;U.o("getParentLinkCategoryForNodeData found a non-string category for "+t+": "+i)}getLinkCategoryForData(t){return this.getParentLinkCategoryForNodeData(t)}setParentLinkCategoryForNodeData(t,e){if(U.s(e,"string",TreeModel,"setParentLinkCategoryForNodeData:cat"),t===null)return;const i=this.cc;if(i==="")return;if(!this.containsNodeData(t)){this.et(t,i,e);return}let s=this.Mt(t,i);s===void 0&&(s=""),s!==e&&(this.et(t,i,e),this.Ft("parentLinkCategory",2,i,t,s,e),typeof i=="string"&&this.updateTargetBindings(t,i))}setLinkCategoryForData(t,e){this.setParentLinkCategoryForNodeData(t,e)}copyNodeData(t){const e=super.copyNodeData(t);return!this.copiesParentKeyOfNodeData&&this.Bn!==""&&this.Mt(e,this.Bn)!==void 0&&this.et(e,this.Bn,void 0),e}setDataProperty(t,e,i){if(this.containsNodeData(t)){if(e===this.nodeKeyProperty){this.setKeyForNodeData(t,i);return}else if(e===this.nodeCategoryProperty){this.setCategoryForNodeData(t,i);return}else if(e===this.nodeParentKeyProperty){this.setParentKeyForNodeData(t,i);return}else if(e===this.parentLinkCategoryProperty){this.setParentLinkCategoryForNodeData(t,i);return}}const s=this.Mt(t,e);s!==i&&(this.et(t,e,i),this.raiseDataChanged(t,e,s,i))}uw(t,e){super.uw(t,e);const i=this.be.iterator;for(;i.next();){const s=i.value;this.rL(s,t,e)}}rL(t,e,i){if(this.getParentKeyForNodeData(t)===e){const n=this.Bn;this.et(t,n,i),this.Ft("nodeParentKey",2,n,t,e,i),typeof n=="string"&&this.updateTargetBindings(t,n)}}Ag(t){super.Ag(t);const e=this.getKeyForNodeData(t),i=this.ow(e);if(i!==null){const s=U.ot(),n=i.iterator;for(;n.next();){const o=n.value;if(this.containsNodeData(o)&&this.getParentKeyForNodeData(o)===e){const l=this.Bn;this.Ft("nodeParentKey",2,l,o,e,e),typeof l=="string"&&this.updateTargetBindings(o,l),s.push(o)}}for(let o=0;o<s.length;o++)this.an(e,s[o]);U.Z(s)}}Tg(t){super.Tg(t);let e=this.getParentKeyForNodeData(t);e=this.maybeEnsureLinkReference(e),this.findNodeDataForKey(e)===null&&this.hn(e,t)}dw(t){super.dw(t);const e=this.getParentKeyForNodeData(t);this.an(e,t)}Lg(t,e){super.Lg(t,e),this.setParentLinkCategoryForNodeData(e,this.getParentLinkCategoryForNodeData(t)),this.setParentKeyForNodeData(e,this.getParentKeyForNodeData(t))}get type(){return"TreeModel"}Um(){return!0}Lx(){return!0}}Model.Sl(TreeModel,"TreeModel");var CircularArrangement=(w=>(w[w.ConstantSpacing=0]="ConstantSpacing",w[w.ConstantDistance=1]="ConstantDistance",w[w.ConstantAngle=2]="ConstantAngle",w[w.Packed=3]="Packed",w))(CircularArrangement||{}),CircularDirection=(w=>(w[w.Clockwise=10]="Clockwise",w[w.Counterclockwise=11]="Counterclockwise",w[w.BidirectionalLeft=12]="BidirectionalLeft",w[w.BidirectionalRight=13]="BidirectionalRight",w))(CircularDirection||{}),CircularSorting=(w=>(w[w.Forwards=20]="Forwards",w[w.Reverse=21]="Reverse",w[w.Ascending=22]="Ascending",w[w.Descending=23]="Descending",w[w.Optimized=24]="Optimized",w))(CircularSorting||{}),CircularNodeDiameterFormula=(w=>(w[w.Pythagorean=30]="Pythagorean",w[w.Circular=31]="Circular",w))(CircularNodeDiameterFormula||{});class CircularLayout extends Layout{di;tu;Ek;Fg;Uk;Xa;lL;aL;hL;Es;gw;mw;fc;pw;eF;Rg;Og;Ig;eu;He;P;Si;Mi;En;Eg;constructor(t){super(),this.di=0,this.tu=0,this.Ek=0,this.Fg=360,this.Uk=0,this.Xa=0,this.lL=new Point,this.aL=30,this.hL=0,this.Es=0,this.gw=0,this.mw=new VertexArrangement,this.fc=0,this.pw=0,this.eF=600,this.Rg=NaN,this.Og=1,this.Ig=0,this.eu=360,this.He=0,this.P=10,this.Si=24,this.Mi=LayoutVertex.standardComparer,this.En=6,this.Eg=30,t&&Object.assign(this,t)}cloneProtected(t){super.cloneProtected(t),t.Rg=this.Rg,t.Og=this.Og,t.Ig=this.Ig,t.eu=this.eu,t.He=this.He,t.P=this.P,t.Si=this.Si,t.Mi=this.Mi,t.En=this.En,t.Eg=this.Eg}fe(t){t in CircularSorting?this.sorting=t:t in CircularDirection?this.direction=t:t in CircularArrangement?this.arrangement=t:t in CircularNodeDiameterFormula?this.nodeDiameterFormula=t:super.fe(t)}createNetwork(){return new CircularNetwork(this)}d3(t,e,i){t=this.g3(t);let s=this.Uk,n=this.aL,o=this.di,r=this.tu,l=this.Ek,a=this.Fg,h=this.Xa,c=this.hL,f=this.Es,u=this.gw;if(s=this.arrangement,n=this.nodeDiameterFormula,o=this.radius,(!isFinite(o)||o<=0)&&(o=NaN),r=this.aspectRatio,(!isFinite(r)||r<=0)&&(r=1),l=this.startAngle,isFinite(l)||(l=0),a=this.sweepAngle,(!isFinite(a)||a>360||a<1)&&(a=360),h=this.spacing,isFinite(h)||(h=NaN),s===3&&n===31?s=0:s===3&&n!==31&&(n=31,s=this.arrangement),(this.direction===12||this.direction===13)&&this.sorting!==24){for(let g=0;!(g>=t.length||(e.add(t.elt(g)),g+1>=t.length));g+=2)i.add(t.elt(g+1));this.direction===12?(this.arrangement===3&&e.reverse(),t=new List,t.addAll(e),t.addAll(i)):(this.arrangement===3&&i.reverse(),t=new List,t.addAll(i),t.addAll(e))}const d=t.length;c=0;let m=0;for(let g=0;g<t.length;g++){const p=l+a*m*(this.direction===10?1:-1)/d;let y=t.elt(g).diameter;isNaN(y)&&(y=t.elt(g).Ga(p)),a<360&&(g===0||g===t.length-1)&&(y/=2),c+=y,m++}if(isNaN(o)||s===3){if(isNaN(h)&&(h=6),s!==0&&s!==3){let g=-1/0;for(let p=0;p<d;p++){const y=t.elt(p),x=t.elt(p===d-1?0:p+1);isNaN(y.diameter)&&y.Ga(0),isNaN(x.diameter)&&x.Ga(0),g=Math.max(g,(y.diameter+x.diameter)/2)}if(u=g+h,s===2){const p=2*Math.PI/d,y=(g+h)/p;r>1?(o=y,f=o*r):(f=y,o=f)}else o=this.Vk(u*(a>=360?d:d-1),r,l*Math.PI/180,a*Math.PI/180)}else o=this.Vk(c+(a>=360?d:d-1)*(s!==3?h:h*1.6),r,l*Math.PI/180,a*Math.PI/180);f=o*r}else{f=o*r;const g=this.cL(o,f,l*Math.PI/180,a*Math.PI/180);if(isNaN(h))s===0&&(h=(g-c)/(a>=360?d:d-1));else if(s===0){const p=(g-c)/(a>=360?d:d-1);p<h?(o=this.Vk(c+h*(a>=360?d:d-1),r,l*Math.PI/180,a*Math.PI/180),f=o*r):h=p}else{let p=-1/0;for(let k=0;k<d;k++){const b=t.elt(k),P=t.elt(k===d-1?0:k+1);isNaN(b.diameter)&&b.Ga(0),isNaN(P.diameter)&&P.Ga(0),p=Math.max(p,(b.diameter+P.diameter)/2)}const y=p+h,x=this.Vk(y*(a>=360?d:d-1),r,l*Math.PI/180,a*Math.PI/180);x>o?(o=x,f=o*r,u=y):u=g/(a>=360?d:d-1)}}return this.Uk=s,this.aL=n,this.di=o,this.tu=r,this.Ek=l,this.Fg=a,this.Xa=h,this.hL=c,this.Es=f,this.gw=u,t}doLayout(t){this.network===null&&(this.network=this.makeNetwork(t)),this.arrangementOrigin=this.initialOrigin(this.arrangementOrigin);const e=this.network.vertexes;if(e.count<=1){if(e.count===1){const u=e.first();u.centerX=0,u.centerY=0}this.updateParts(),this.network=null,this.isValidLayout=!0;return}let i=new List;i.addAll(e.iterator);const s=new List,n=new List;i=this.d3(i,s,n);const o=this.Uk,r=this.di,l=this.Ek,a=this.Fg,h=this.Xa,c=this.Es,f=this.gw;if((this.direction===12||this.direction===13)&&o===3)this.iF(i,a,l-a/2,10);else if(this.direction===12||this.direction===13){let u=0;switch(o){case 1:u=this.Bk(r,c,l,f)*180/Math.PI;break;case 0:{let d=0,m=0;const g=s.first();g!==null&&(d=g.Ga(Math.PI/2));const p=n.first();p!==null&&(m=p.Ga(Math.PI/2)),u=this.Bk(r,c,l,h+(d+m)/2)*180/Math.PI;break}case 2:u=a/i.length;break}if(this.direction===12){switch(o){case 1:this.yw(s,a/2,l,11);break;case 0:this.ww(s,a/2,l,11);break;case 2:this.xw(s,a/2,l,11);break}switch(o){case 1:this.yw(n,a/2,l+u,10);break;case 0:this.ww(n,a/2,l+u,10);break;case 2:this.xw(n,a/2,l+u,10);break}}else{switch(o){case 1:this.yw(n,a/2,l,11);break;case 0:this.ww(n,a/2,l,11);break;case 2:this.xw(n,a/2,l,11);break}switch(o){case 1:this.yw(s,a/2,l+u,10);break;case 0:this.ww(s,a/2,l+u,10);break;case 2:this.xw(s,a/2,l+u,10);break}}}else switch(o){case 1:this.yw(i,a,l,this.direction);break;case 0:this.ww(i,a,l,this.direction);break;case 2:this.xw(i,a,l,this.direction);break;case 3:this.iF(i,a,l,this.direction);break}this.updateParts(),this.network=null,this.isValidLayout=!0}xw(t,e,i,s){const n=this.Fg,o=this.di,r=this.Es,l=i*Math.PI/180,a=e*Math.PI/180,h=t.length;for(let c=0;c<h;c++){const f=l+(s===10?c*a/(n>=360?h:h-1):-(c*a)/h),u=t.elt(c),d=o*Math.tan(f)/r,m=Math.sqrt((o*o+r*r*d*d)/(1+d*d));u.centerX=m*Math.cos(f),u.centerY=m*Math.sin(f),u.actualAngle=f*180/Math.PI}}ww(t,e,i,s){const n=this.di,o=this.Es,r=this.Xa;let l=i*Math.PI/180;const a=t.length;for(let h=0;h<a;h++){const c=t.elt(h),f=t.elt(h===a-1?0:h+1),u=n*Math.cos(l),d=o*Math.sin(l);c.centerX=u,c.centerY=d,c.actualAngle=l*180/Math.PI,isNaN(c.diameter)&&c.Ga(0),isNaN(f.diameter)&&f.Ga(0);const m=(c.diameter+f.diameter)/2,g=this.Bk(n,o,s===10?l:-l,m+r);l+=s===10?g:-g}}yw(t,e,i,s){const n=this.di,o=this.Es,r=this.gw;let l=i*Math.PI/180;const a=t.length;for(let h=0;h<a;h++){const c=t.elt(h);c.centerX=n*Math.cos(l),c.centerY=o*Math.sin(l),c.actualAngle=l*180/Math.PI;const f=this.Bk(n,o,s===10?l:-l,r);l+=s===10?f:-f}}iF(t,e,i,s){let n=this.pw;const o=this.Fg;if(this.fc=0,this.mw=new VertexArrangement,e<360){for(n=i+(s===10?o:-o);n<0;)n+=360;n%=360,n>180&&(n-=360),n*=Math.PI/180,this.pw=n,this.sF(t,e,i,s)}else this.nF(t,e,i,s);this.mw.commit(t)}nF(t,e,i,s){const n=this.di,o=this.Es,r=this.Xa,l=this.tu;let a=n*Math.cos(i*Math.PI/180),h=o*Math.sin(i*Math.PI/180);const c=t.toArray();if(c.length===3){c[0].centerX=n,c[0].centerY=0,c[1].centerX=c[0].centerX-c[0].width/2-c[1].width/2-r,c[1].y=c[0].y,c[2].centerX=(c[0].centerX+c[1].centerX)/2,c[2].y=c[0].y-c[2].height-r;return}else if(c.length===4){c[0].centerX=n,c[0].centerY=0,c[2].centerX=-c[0].centerX,c[2].centerY=c[0].centerY,c[1].centerX=0,c[1].y=Math.min(c[0].y,c[2].y)-c[1].height-r,c[3].centerX=0,c[3].y=Math.max(c[0].y+c[0].height+r,c[2].y+c[2].height+r);return}const f=Point.l();for(let b=0;b<c.length&&(c[b].centerX=a,c[b].centerY=h,!(b>=c.length-1));b++)this.oF(a,h,c,b,s,f)||this.rF(a,h,c,b,s,f),a=f.x,h=f.y;if(Point.i(f),this.fc++,this.fc>23)return;const u=c[0].centerX,d=c[0].centerY,m=c[c.length-1].centerX,g=c[c.length-1].centerY;let p=Math.abs(u-m)-((c[0].width+c[c.length-1].width)/2+r);const y=Math.abs(d-g)-((c[0].height+c[c.length-1].height)/2+r);let x=0;if(Math.abs(y)<1){const b=Math.abs(u-m),P=(c[0].width+c[c.length-1].width)/2;b<P&&(x=0),p=b-P}else y>0?x=y:Math.abs(p)<1?x=0:x=p;let k=!1;Math.abs(m)>Math.abs(g)?k=m>0!=d>g:k=g>0!=u<m,k=s===10?k:!k,k&&(x=-Math.abs(x),x=Math.min(x,-c[c.length-1].width),x=Math.min(x,-c[c.length-1].height)),this.mw.m3(x,c),Math.abs(x)>1&&(this.fc<8?this.di-=x/(2*Math.PI):c.length<5&&x>10?this.di/=2:this.di-=x>0?1.7:-2.3,this.Es=this.di*l,this.nF(t,e,i,s))}sF(t,e,i,s){const n=this.di,o=this.Es,r=this.tu;let l=n*Math.cos(i*Math.PI/180),a=o*Math.sin(i*Math.PI/180);const h=Point.l(),c=t.toArray();for(let m=0;m<c.length&&(c[m].centerX=l,c[m].centerY=a,!(m>=c.length-1));m++)this.oF(l,a,c,m,s,h)||this.rF(l,a,c,m,s,h),l=h.x,a=h.y;if(Point.i(h),this.fc++,this.fc>23)return;const f=Math.atan2(a,l);let u=s===10?this.pw-f:f-this.pw;u=Math.abs(u)<Math.abs(u-2*Math.PI)?u:u-2*Math.PI;const d=u*(n+o)/2;this.mw.p3(d,c),Math.abs(d)>1&&(this.fc<8?this.di-=d/(2*Math.PI):this.di-=d>0?1.7:-2.3,this.Es=this.di*r,this.sF(t,e,i,s))}oF(t,e,i,s,n,o){const r=this.Xa,l=this.di,a=this.Es;let h=0,c=0;const f=(i[s].width+i[s+1].width)/2+r;let u=!1;if(e>=0!=(n===10)){if(h=t+f,h>l){if(h=t-f,h<-l)return o.x=h,o.y=c,!1;u=!0}}else if(h=t-f,h<-l){if(h=t+f,h>l)return o.x=h,o.y=c,!1;u=!0}return c=Math.sqrt(1-Math.min(1,h*h/(l*l)))*a,e<0!==u&&(c=-c),Math.abs(e-c)>(i[s].height+i[s+1].height)/2?(o.x=h,o.y=c,!1):(o.x=h,o.y=c,!0)}rF(t,e,i,s,n,o){const r=this.Xa,l=this.di,a=this.Es;let h=0,c=0;const f=(i[s].height+i[s+1].height)/2+r;let u=!1;if(t>=0!=(n===10)){if(c=e-f,c<-a){if(c=e+f,c>a)return o.x=h,o.y=c,!1;u=!0}}else if(c=e+f,c>a){if(c=e-f,c<-a)return o.x=h,o.y=c,!1;u=!0}return h=Math.sqrt(1-Math.min(1,c*c/(a*a)))*l,t<0!==u&&(h=-h),Math.abs(t-h)>(i[s].width+i[s+1].width)/2?(o.x=h,o.y=c,!1):(o.x=h,o.y=c,!0)}commitLayout(){this.commitNodes(),this.isRouting&&this.commitLinks()}commitNodes(){const t=this.group!==null&&this.group.hasPlaceholder(),e=t?this.group.location.copy():null;let i=this.actualCenter;if(t?i=new Point(0,0):(i.x=this.arrangementOrigin.x+this.di,i.y=this.arrangementOrigin.y+this.Es),this.network!==null){const s=this.network.vertexes.iterator;for(;s.next();){const n=s.value;n.x+=i.x,n.y+=i.y,n.commit()}}if(t&&this.group&&e){this.group.ensureBounds();const s=this.group.position.copy(),n=this.group.location.copy(),o=e.subtract(n.subtract(s));this.group.move(o),this.lL=o.subtract(s)}}commitLinks(){if(this.network!==null){const t=this.network.edges.iterator;for(;t.next();)t.value.commit()}}cL(t,e,i,s){const n=this.eF;if(Math.abs(this.tu-1)<.001)return i!==void 0&&s!==void 0?s*t:2*Math.PI*t;const o=t>e?Math.sqrt(t*t-e*e)/t:Math.sqrt(e*e-t*t)/e;let r=0,l=0;i!==void 0&&s!==void 0?l=s/(n+1):l=Math.PI/(2*(n+1));let a=0;for(let h=0;h<=n;h++){i!==void 0&&s!==void 0?a=i+h*s/n:a=h*Math.PI/(2*n);const c=Math.sin(a);r+=Math.sqrt(1-o*o*c*c)*l}return i!==void 0&&s!==void 0?(t>e?t:e)*r:4*(t>e?t:e)*r}Vk(t,e,i,s){let n=0;return i!==void 0&&s!==void 0?n=this.cL(1,e,i,s):n=this.cL(1,e),t/n}Bk(t,e,i,s){if(Math.abs(this.tu-1)<.001)return s/t;const n=t>e?Math.sqrt(t*t-e*e)/t:Math.sqrt(e*e-t*t)/e;let o=0;const r=2*Math.PI/(this.network.vertexes.count*700);t>e&&(i+=Math.PI/2);for(let l=0;;l++){const a=i+l*r,h=Math.sin(a);if(o+=(t>e?t:e)*Math.sqrt(1-n*n*h*h)*r,o>=s)return l*r}}g3(t){switch(this.sorting){case 20:break;case 21:t.reverse();break;case 22:t.sort(this.comparer);break;case 23:t.sort(this.comparer),t.reverse();break;case 24:return this.y3(this.w3(t));default:U.o("Invalid sorting type.")}return t}w3(t){const e=[];for(let s=0;s<t.length;s++)e.push(0);const i=new List;for(let s=0;s<t.length;s++){let n=-1,o=-1;if(s===0)for(let c=0;c<t.length;c++){const u=t.elt(c).edgesCount;u>n&&(n=u,o=c)}else for(let c=0;c<t.length;c++){const f=e[c];f>n&&(n=f,o=c)}i.add(t.elt(o)),e[o]=-1;const r=t.elt(o);let l=0;const a=r.sourceEdges;for(;a.next();){const f=a.value.fromVertex;l=t.indexOf(f),!(l<0)&&e[l]>=0&&e[l]++}const h=r.destinationEdges;for(;h.next();){const f=h.value.toVertex;l=t.indexOf(f),!(l<0)&&e[l]>=0&&e[l]++}}return i}y3(t){const e=[];for(let f=0;f<t.length;f++){const u=t.elt(f);e[f]=[];let d=0;const m=u.destinationEdges;for(;m.next();){const p=m.value.toVertex;d=t.indexOf(p),d!==f&&e[f].indexOf(d)<0&&e[f].push(d)}const g=u.sourceEdges;for(;g.next();){const p=g.value.fromVertex;d=t.indexOf(p),d!==f&&e[f].indexOf(d)<0&&e[f].push(d)}}const i=[];for(let f=0;f<e.length;f++)i[f]=0;const s=[],n=[],o=[],r=[],l=new List;let a=0;for(let f=0;f<e.length;f++){const u=e[f].length;if(u===1){r.push(f);continue}if(u===0){l.add(t.elt(f));continue}if(a===0){s.push(f),a++;continue}let d=1/0,m=1/0,g=-1;const p=[];for(let y=0;y<s.length;y++)e[s[y]].indexOf(s[y===s.length-1?0:y+1])<0&&p.push(y===s.length-1?0:y+1);if(p.length===0)for(let y=0;y<s.length;y++)p.push(y);for(let y=0;y<p.length;y++){const x=p[y],k=this.x3(e[f],n,o,i,x,s);let b=0;for(let P=0;P<e[f].length;P++){const S=e[f][P],L=s.indexOf(S);if(L>=0){const C=Math.abs(x-(L>=x?L+1:L));b+=C<s.length+1-C?C:s.length+1-C}}for(let P=0;P<n.length;P++){let S=i[n[P]],L=i[o[P]];if(S>=x&&S++,L>=x&&L++,S>L){const C=L;L=S,S=C}L-S<(s.length+2)/2==(S<x&&x<=L)&&b++}(k<d||k===d&&b<m)&&(d=k,m=b,g=x)}s.splice(g,0,f);for(let y=0;y<s.length;y++)i[s[y]]=y;for(let y=0;y<e[f].length;y++){const x=e[f][y];s.indexOf(x)>=0&&(n.push(f),o.push(x))}a++}let h=!1;const c=s.length;for(;;){h=!0;for(let f=0;f<r.length;f++){const u=r[f],d=e[u][0],m=s.indexOf(d);if(m>=0){let g=0;for(let p=0;p<e[d].length;p++){const y=e[d][p],x=s.indexOf(y);if(x<0||x===m)continue;const k=x>m?x-m:m-x,b=c-k;g+=x<m!=k>b?1:-1}s.splice(g<0?m:m+1,0,u),r.splice(f,1),f--}else h=!1}if(h)break;s.push(r[0]),r.splice(0,1)}for(let f=0;f<s.length;f++){const u=s[f];l.add(t.elt(u))}return l}x3(t,e,i,s,n,o){let r=0;for(let l=0;l<e.length;l++){const a=e[l],h=i[l],c=s[a],f=s[h];let u=0,d=0;if(c<f?(u=c,d=f):(u=f,d=c),u<n&&n<=d)for(let m=0;m<t.length;m++){const g=t[m];o.indexOf(g)<0||u<s[g]&&s[g]<d||u===s[g]||d===s[g]||r++}else for(let m=0;m<t.length;m++){const g=t[m];o.indexOf(g)<0||!(u<s[g]&&s[g]<d)||u===s[g]||d===s[g]||r++}}return r}get radius(){return this.Rg}set radius(t){this.Rg!==t&&(U.s(t,"number",CircularLayout,"radius"),(t>0||isNaN(t))&&(this.Rg=t,this.p()))}get aspectRatio(){return this.Og}set aspectRatio(t){this.Og!==t&&(U.s(t,"number",CircularLayout,"aspectRatio"),t>0&&(this.Og=t,this.p()))}get startAngle(){return this.Ig}set startAngle(t){this.Ig!==t&&(U.s(t,"number",CircularLayout,"startAngle"),this.Ig=t,this.p())}get sweepAngle(){return this.eu}set sweepAngle(t){this.eu!==t&&(U.s(t,"number",CircularLayout,"sweepAngle"),t>0&&t<=360?this.eu=t:this.eu=360,this.p())}get arrangement(){return this.He}set arrangement(t){this.He!==t&&(t===3||t===0||t===1||t===2)&&(this.He=t,this.p())}get direction(){return this.P}set direction(t){this.P!==t&&(t===10||t===11||t===12||t===13)&&(this.P=t,this.p())}get sorting(){return this.Si}set sorting(t){this.Si!==t&&(this.Si=t,this.p())}get comparer(){return this.Mi}set comparer(t){this.Mi!==t&&(U.S(t,CircularLayout,"comparer"),this.Mi=t,this.p())}get spacing(){return this.En}set spacing(t){this.En!==t&&(U.s(t,"number",CircularLayout,"spacing"),this.En=t,this.p())}get nodeDiameterFormula(){return this.Eg}set nodeDiameterFormula(t){this.Eg!==t&&(t===30||t===31)&&(this.Eg=t,this.p())}get actualXRadius(){return this.di}get actualYRadius(){return this.Es}get actualSpacing(){return this.Xa}get actualCenter(){return this.lL}static ConstantSpacing=0;static ConstantDistance=1;static ConstantAngle=2;static Packed=3;static Clockwise=10;static Counterclockwise=11;static BidirectionalLeft=12;static BidirectionalRight=13;static Forwards=20;static Reverse=21;static Ascending=22;static Descending=23;static Optimized=24;static Pythagorean=30;static Circular=31}class VertexArrangement{iu;uc;su;constructor(){this.iu=-1/0,this.uc=null,this.su=null}m3(t,e){if(t>0&&this.iu<0||Math.abs(t)<Math.abs(this.iu)&&!(t<0&&this.iu>0)){this.iu=t,this.uc=[],this.su=[];for(let i=0;i<e.length;i++)this.uc[i]=e[i].bounds.x,this.su[i]=e[i].bounds.y}}p3(t,e){if(Math.abs(t)<Math.abs(this.iu)){this.iu=t,this.uc=[],this.su=[];for(let i=0;i<e.length;i++)this.uc[i]=e[i].bounds.x,this.su[i]=e[i].bounds.y}}commit(t){if(!(this.uc===null||this.su===null))for(let e=0;e<this.uc.length;e++){const i=t.elt(e);i.x=this.uc[e],i.y=this.su[e]}}}class CircularNetwork extends LayoutNetwork{constructor(t){super(t)}createVertex(){return new CircularVertex(this)}createEdge(){return new CircularEdge(this)}}class CircularVertex extends LayoutVertex{To;zk;constructor(t){super(t),this.To=NaN,this.zk=NaN}Ga(t){const e=this.network;if(e===null)return NaN;const i=e.layout;if(i===null)return NaN;if(i.arrangement===3){if(i.nodeDiameterFormula===31)return this.To=Math.max(this.width,this.height),this.To;{const s=Math.abs(Math.sin(t)),n=Math.abs(Math.cos(t));return s===0?this.width:n===0?this.height:(this.To=Math.min(this.height/s,this.width/n),this.To)}}else return i.nodeDiameterFormula===31?(this.To=Math.max(this.width,this.height),this.To):(this.To=Math.sqrt(this.width*this.width+this.height*this.height),this.To)}get diameter(){return this.To}set diameter(t){this.To!==t&&(U.s(t,"number",CircularVertex,"diameter"),this.To=t)}get actualAngle(){return this.zk}set actualAngle(t){this.zk!==t&&(U.s(t,"number",CircularVertex,"actualAngle"),this.zk=t)}}class CircularEdge extends LayoutEdge{constructor(t){super(t)}}class ForceDirectedLayout extends Layout{bw;Ya;Us;Ug;zn;Xi;Vg;Bg;zg;nu;Xg;Gg;ou;ru;lu;au;Yg;Kg;hu;dc;constructor(t){super(),this.bw=0,this.Ya=0,this.Us=new Size(100,100).b(),this.Ug=!1,this.zn=!0,this.Xi=!1,this.Vg=100,this.Bg=300,this.zg=1,this.nu=1e3,this.Xg=10,this.Gg=Math,this.ou=.05,this.ru=50,this.lu=150,this.au=0,this.Yg=10,this.Kg=5,this.hu=NaN,this.dc=10,t&&Object.assign(this,t)}cloneProtected(t){super.cloneProtected(t),t.Us.h(this.Us),t.Ug=this.Ug,t.zn=this.zn,t.Xi=this.Xi,t.Vg=this.Vg,t.Bg=this.Bg,t.zg=this.zg,t.nu=this.nu,t.Xg=this.Xg,t.Gg=this.Gg,t.ou=this.ou,t.ru=this.ru,t.lu=this.lu,t.au=this.au,t.Yg=this.Yg,t.Kg=this.Kg,t.hu=this.hu,t.dc=this.dc}createNetwork(){return new ForceDirectedNetwork(this)}doLayout(t){this.network=this.makeNetwork(t);let e=this.network.vertexes.iterator;const i=this.maxIterations;if(this.network.vertexes.count>0){for(this.network.deleteSelfEdges(),e=this.network.vertexes.iterator;e.next();){const o=e.value;o.charge=this.electricalCharge(o),o.mass=this.gravitationalMass(o)}const s=this.network.edges.iterator;for(;s.next();){const o=s.value;o.stiffness=this.springStiffness(o),o.length=this.springLength(o)}if(this.fL(),this.Ya=0,this.needsPrelayout()){const o=this.network,r=o.splitIntoSubNetworks(!1);let l=r.iterator;for(;l.next();){const a=l.value;this.doConnectedSubnetLayout(a)}for(l=r.iterator,this.b3(l,o),l=r.iterator;l.next();){const a=l.value,h=a.vertexes.iterator;for(;h.next();){const f=h.value;o.addVertex(f)}const c=a.edges.iterator;for(;c.next();){const f=c.value;o.addEdge(f)}}}else this.lF(this.network,this.maxIterations);this.updateParts()}this.maxIterations=i,this.isValidLayout=!0}needsPrelayout(){if(this.network===null||this.network.vertexes.count<3)return!1;let t=0,e=0;const i=this.network.vertexes.first().bounds,s=this.network.vertexes.iterator;for(;s.next();){const n=s.value,o=n.bounds;if(isNaN(n.x)||isNaN(n.y)||o.intersectsRect(i)&&(t++,t>2))return!0;if(e>10)return!1;e++}return!1}doConnectedSubnetLayout(t){let e=t.vertexes.iterator;for(;e.next();){const l=e.value;l.hierarchicalVertexes.add(l)}let i=t,s=this.hu;if(isNaN(s)&&(s=t.edges.count/t.vertexes.count),s<t.vertexes.count)for(;i.vertexes.count>Math.max(100,Math.sqrt(s*t.vertexes.count));)i=this.coarsenNetwork(i);let n=0;e=i.vertexes.iterator;let o=this.randomNumberGenerator;for(o===null&&(this.randomNumberGenerator=o=new RandomNumberGenerator(0));e.next();){e.value.idInCluster=n++;const l=10*(o.random()-.5),a=10*(o.random()-.5);this.isFixed(e.value)||(e.value.x=l,e.value.y=a);const h=e.value.hierarchicalVertexes.iterator;for(;h.next();)this.isFixed(h.value)||(h.value.x=l,h.value.y=a)}const r=this.computePairwiseDistances(i);this.k3(i,r,this.maxPrelayoutIterations,t.vertexes.count),this.lF(t,this.maxIterations)}computePairwiseDistances(t){const e=t.vertexes.count,i=new Array(e);for(let r=0;r<e;r++)i[r]=new Array(e).fill(-1),i[r][r]=0;const s=t.vertexes.iterator;let n=new Map,o=[];for(;s.next();){const r=s.value;for(o=[r],n=new Map,n.set(r.idInCluster,0);o.length>0;){const l=o.shift(),a=l.vertexes.iterator;for(;a.next();){const h=a.value;n.has(h.idInCluster)||(n.set(h.idInCluster,n.get(l.idInCluster)+1),o.push(h))}}for(let l=0;l<e;l++){const a=Math.min(i[r.idInCluster][l],i[l][r.idInCluster]),h=n.get(l);(a<0||h<a)&&(i[r.idInCluster][l]=h,i[l][r.idInCluster]=h)}}return i}coarsenNetwork(t){const e=this.createNetwork(),i=new Map;let s=0,n=t.vertexes.iterator;for(;n.next();)n.value.idInCluster=s++;for(n=t.vertexes.iterator;n.next();){const r=n.value;if(i.has(r.idInCluster))continue;let l=Number.MAX_SAFE_INTEGER,a=null;const h=r.vertexes.iterator;for(;h.next();){const f=h.value;i.has(f.idInCluster)||f.hierarchicalVertexes.length<l&&(l=f.hierarchicalVertexes.length,a=f)}const c=e.createVertex();c.hierarchicalVertexes.addAll(r.hierarchicalVertexes),a!=null&&c.hierarchicalVertexes.addAll(a.hierarchicalVertexes),i.set(r.idInCluster,c),a!=null&&i.set(a.idInCluster,c),e.addVertex(c)}const o=t.edges.iterator;for(;o.next();){const r=o.value,l=i.get(r.fromVertex.idInCluster),a=i.get(r.toVertex.idInCluster);if(l===a)continue;const h=e.createEdge();h.fromVertex=l||null,h.toVertex=a||null,e.addEdge(h)}return e}hx(t,e){let i=!0;const s=t.vertexes.iterator;for(;s.next();){const n=s.value;i?(i=!1,e.set(n.bounds)):e.unionRect(n.bounds)}return e}b3(t,e){const i=this.arrangementSpacing,s=t.count;let n=!0,o=0,r=0;const l=U.ot();for(let f=0;f<s+e.vertexes.count+2;f++)l[f]=null;let a=0;t.reset();const h=Rect.l();let c;for(;t.next();){const f=t.value;if(this.hx(f,h),n)n=!1,o=h.x+h.width/2,r=h.y+h.height/2,l[0]=new Point(h.x+h.width+i.width,h.y),l[1]=new Point(h.x,h.y+h.height+i.height),a=2;else{const u=this.aF(l,a,o,r,h.width,h.height,i),d=l[u],m=new Point(d.x+h.width+i.width,d.y),g=new Point(d.x,d.y+h.height+i.height);u+1<a&&l.splice(u+1,0,null),l[u]=m,l[u+1]=g,a++;const p=d.x-h.x,y=d.y-h.y;for(c=f.vertexes.iterator;c.next();){const x=c.value;this.isFixed(x)||(x.centerX+=p,x.centerY+=y)}}}for(Rect.i(h),c=e.vertexes.iterator;c.next();){const f=c.value,u=f.bounds;if(a<2){o=u.x+u.width/2,r=u.y+u.height/2,l[0]=new Point(u.x+u.width+i.width,u.y),l[1]=new Point(u.x,u.y+u.height+i.height),a=2;continue}const d=this.aF(l,a,o,r,u.width,u.height,i),m=l[d],g=new Point(m.x+u.width+i.width,m.y),p=new Point(m.x,m.y+u.height+i.height);d+1<a&&l.splice(d+1,0,null),l[d]=g,l[d+1]=p,a++,this.isFixed(f)||(f.centerX=m.x+f.width/2,f.centerY=m.y+f.height/2)}U.Z(l)}aF(t,e,i,s,n,o,r){let l=9e19,a=-1;t:for(let h=0;h<e;h++){const c=t[h],f=c.x-i,u=c.y-s,d=f*f+u*u;if(d<l){for(let m=h-1;m>=0;m--)if(t[m].y>c.y&&t[m].x-c.x<n+r.width)continue t;for(let m=h+1;m<e;m++)if(t[m].x>c.x&&t[m].y-c.y<o+r.height)continue t;a=h,l=d}}return a}fL(){if(this.network===null||!this.comments)return;const t=this.network.vertexes.iterator;for(;t.next();){const e=t.value;this.addComments(e)}}addComments(t){if(this.network===null)return;const e=t.node;if(e!==null){const i=e.findNodesConnected();for(;i.next();){const s=i.value;if(s.category!=="Comment"||!s.isVisible())continue;let n=this.network.findVertex(s);n===null&&(n=this.network.addNode(s)),n.charge=this.defaultCommentElectricalCharge;let o=null;const r=n.destinationEdges;for(;r.next();){const l=r.value;if(l.toVertex===t){o=l;break}}if(o===null){const l=n.sourceEdges;for(;l.next();){const a=l.value;if(a.fromVertex===t){o=a;break}}}o===null&&(o=this.network.linkVertexes(t,n,null)),o.length=this.defaultCommentSpringLength}}}hF(t,e){const i=t.bounds,s=i.x,n=i.y,o=i.width,r=i.height,l=e.bounds,a=l.x,h=l.y,c=l.width,f=l.height;if(s+o<a)if(n>h+f){const u=s+o-a,d=n-h-f;return G.ex(u*u+d*d)}else if(n+r<h){const u=s+o-a,d=n+r-h;return G.ex(u*u+d*d)}else return a-(s+o);else if(s>a+c)if(n>h+f){const u=s-a-c,d=n-h-f;return G.ex(u*u+d*d)}else if(n+r<h){const u=s-a-c,d=n+r-h;return G.ex(u*u+d*d)}else return s-(a+c);else return n>h+f?n-(h+f):n+r<h?h-(n+r):.1}lF(t,e){const i=this.Ya+e;for(;this.Ya<i&&(this.Ya++,!!this.P3(t)););}P3(t){const e=t.vertexes.toArray();if(e.length<=0)return!1;const i=e[0];i.forceX=0,i.forceY=0;let s=i.centerX,n=s,o=i.centerY,r=o;for(let m=1;m<e.length;m++){const g=e[m];g.forceX=0,g.forceY=0;const p=g.centerX,y=g.centerY;s=Math.min(s,p),n=Math.max(n,p),o=Math.min(o,y),r=Math.max(r,y)}const l=n-s>r-o;l?e.sort((m,g)=>m===null||g===null||m===g?0:m.centerX-g.centerX):e.sort((m,g)=>m===null||g===null||m===g?0:m.centerY-g.centerY);const a=this.nu;let h=0,c=0,f=0;for(let m=0;m<e.length;m++){const g=e[m],p=g.bounds,y=g.focus,x=p.x+y.x,k=p.y+y.y;c=g.charge*this.electricalFieldX(x,k),f=g.charge*this.electricalFieldY(x,k),c+=g.mass*this.gravitationalFieldX(x,k),f+=g.mass*this.gravitationalFieldY(x,k),g.forceX+=c,g.forceY+=f;for(let b=m+1;b<e.length;b++){const P=e[b];if(!this.shouldInteract(g,P)||b===m)continue;const S=P.bounds,L=P.focus,C=S.x+L.x,M=S.y+L.y;if(x-C>a||C-x>a){if(l)break;continue}if(k-M>a||M-k>a){if(!l)break;continue}const N=this.hF(g,P),T=2*g.charge,A=2*P.charge;if(N>1)h=T*A/(N*N),c=h*(x-C)/N,f=h*(k-M)/N;else{let D=this.randomNumberGenerator;D===null&&(this.randomNumberGenerator=D=new RandomNumberGenerator(0));const v=D.random(),R=D.random();if(x>C)c=Math.abs(P.bounds.right-g.bounds.x),c=T*A*(1+c)*v;else if(x<C)c=Math.abs(P.bounds.x-g.bounds.right),c=-(T*A)*(1+c)*v;else{const F=Math.max(P.width,g.width);c=T*A*((1+F)*v-F/2)}if(k>M)f=Math.abs(P.bounds.bottom-g.bounds.y),f=T*A*(1+f)*R;else if(x<C)f=Math.abs(P.bounds.y-g.bounds.bottom),f=-(T*A)*(1+f)*R;else{const F=Math.max(P.height,g.height);f=T*A*((1+F)*R-F/2)}}g.forceX+=c,g.forceY+=f,P.forceX-=c,P.forceY-=f}}const u=t.edges.iterator;for(;u.next();){const m=u.value,g=m.fromVertex,p=m.toVertex,y=g.bounds,x=g.focus,k=y.x+x.x,b=y.y+x.y,P=p.bounds,S=p.focus,L=P.x+S.x,C=P.y+S.y,M=this.hF(g,p);M>1&&(h=.1*m.stiffness*(M-m.length),c=h*.5*(g.width+p.height)*(k-L)/M,f=h*.5*(g.width+p.height)*(b-C)/M),g.forceX-=c,g.forceY-=f,p.forceX+=c,p.forceY+=f}let d=0;for(let m=0;m<e.length;m++){const g=e[m];this.isFixed(g)?this.moveFixedVertex(g):d=Math.max(d,this.moveVertex(g)||0)}return d>this.epsilonDistance*this.epsilonDistance}k3(t,e,i,s){const n=this.Ya+i,o=Math.sqrt(s);this.bw=this.dc*t.vertexes.count;const r=t.vertexes.toArray();let l=0,a=0,h=0;for(;this.Ya<n;){this.Ya++,a=l,l=0;for(let c=0;c<r.length;c++){r[c].forceX=0,r[c].forceY=0;for(let u=0;u<r.length;u++){if(c===u)continue;const d=Math.sqrt((r[c].centerX-r[u].centerX)**2+(r[c].centerY-r[u].centerY)**2),m=e[r[c].idInCluster][r[u].idInCluster],g=(d-this.dc*o*m)/d;r[c].forceX+=g*(r[u].x-r[c].x),r[c].forceY+=g*(r[u].y-r[c].y)}const f=Math.sqrt(r[c].forceX*r[c].forceX+r[c].forceY*r[c].forceY);if(f>0){r[c].forceX=this.bw*r[c].forceX/f,r[c].forceY=this.bw*r[c].forceY/f,this.isFixed(r[c])||(r[c].x+=r[c].forceX,r[c].y+=r[c].forceY);const u=r[c].hierarchicalVertexes.iterator;for(;u.next();){const d=u.value;this.isFixed(d)||(d.centerX+=r[c].forceX,d.centerY+=r[c].forceY)}}l+=f*f}if(l>=a){if(h++,h>=5)break}else h=0;this.bw*=.95}}moveVertex(t){let e=t.forceX,i=t.forceY;const s=this.moveLimit;return e<-s?e=-s:e>s&&(e=s),i<-s?i=-s:i>s&&(i=s),t.centerX+=e,t.centerY+=i,e*e+i*i}shouldInteract(t,e){return!0}moveFixedVertex(t){}commitLayout(){this.kw(),this.commitNodes(),this.isRouting&&this.commitLinks()}kw(){if(this.network===null||!this.setsPortSpots)return;const t=this.network.edges.iterator;for(;t.next();){const i=t.value.link;i!==null&&(i.fromSpot=Spot.Default,i.toSpot=Spot.Default)}}commitNodes(){if(!this.network)return;let t=0,e=0;if(this.arrangesToOrigin){const n=Rect.l();this.hx(this.network,n);const o=this.arrangementOrigin;t=o.x-n.x,e=o.y-n.y,Rect.i(n)}const i=Rect.l(),s=this.network.vertexes.iterator;for(;s.next();){const n=s.value;(t!==0||e!==0)&&(i.h(n.bounds),i.x+=t,i.y+=e,n.bounds=i),n.commit()}Rect.i(i)}commitLinks(){if(!this.network)return;const t=this.network.edges.iterator;for(;t.next();)t.value.commit()}springStiffness(t){const e=t.stiffness;return isNaN(e)?this.ou:e}springLength(t){const e=t.length;return isNaN(e)?this.ru:e}electricalCharge(t){const e=t.charge;return isNaN(e)?this.lu:e}electricalFieldX(t,e){return 0}electricalFieldY(t,e){return 0}gravitationalMass(t){const e=t.mass;return isNaN(e)?this.au:e}gravitationalFieldX(t,e){return 0}gravitationalFieldY(t,e){return 0}isFixed(t){return t.isFixed}get currentIteration(){return this.Ya}get arrangementSpacing(){return this.Us}set arrangementSpacing(t){this.Us.equals(t)||(this.Us.h(t),this.p())}get arrangesToOrigin(){return this.Ug}set arrangesToOrigin(t){this.Ug!==t&&(U.s(t,"boolean",ForceDirectedLayout,"arrangesToOrigin"),this.Ug=t,this.p())}get setsPortSpots(){return this.zn}set setsPortSpots(t){this.zn!==t&&(U.s(t,"boolean",ForceDirectedLayout,"setsPortSpots"),this.zn=t,this.p())}get comments(){return this.Xi}set comments(t){this.Xi!==t&&(U.s(t,"boolean",ForceDirectedLayout,"comments"),this.Xi=t,this.p())}get maxPrelayoutIterations(){return this.Vg}set maxPrelayoutIterations(t){this.Vg!==t&&(U.s(t,"number",ForceDirectedLayout,"maxPrelayoutIterations"),t>=0&&(this.Vg=t,this.p()))}get maxIterations(){return this.Bg}set maxIterations(t){this.Bg!==t&&(U.s(t,"number",ForceDirectedLayout,"maxIterations"),t>=0&&(this.Bg=t,this.p()))}get epsilonDistance(){return this.zg}set epsilonDistance(t){this.zg!==t&&(U.s(t,"number",ForceDirectedLayout,"epsilonDistance"),t>0&&(this.zg=t,this.p()))}get infinityDistance(){return this.nu}set infinityDistance(t){this.nu!==t&&(U.s(t,"number",ForceDirectedLayout,"infinityDistance"),t>1&&(this.nu=t,this.p()))}get moveLimit(){return this.Xg}set moveLimit(t){this.Xg!==t&&(U.s(t,"number",ForceDirectedLayout,"moveLimit"),this.Xg=t,this.p())}get randomNumberGenerator(){return this.Gg}set randomNumberGenerator(t){this.Gg!==t&&(t!==null&&!U.nt(t.random)&&U.o('ForceDirectedLayout.randomNumberGenerator must have a "random()" function on it: '+t),this.Gg=t)}get defaultSpringStiffness(){return this.ou}set defaultSpringStiffness(t){this.ou!==t&&(U.s(t,"number",ForceDirectedLayout,"defaultSpringStiffness"),this.ou=t,this.p())}get defaultSpringLength(){return this.ru}set defaultSpringLength(t){this.ru!==t&&(U.s(t,"number",ForceDirectedLayout,"defaultSpringLength"),this.ru=t,this.p())}get defaultElectricalCharge(){return this.lu}set defaultElectricalCharge(t){this.lu!==t&&(U.s(t,"number",ForceDirectedLayout,"defaultElectricalCharge"),this.lu=t,this.p())}get defaultGravitationalMass(){return this.au}set defaultGravitationalMass(t){this.au!==t&&(U.s(t,"number",ForceDirectedLayout,"defaultGravitationalMass"),this.au=t,this.p())}get defaultCommentSpringLength(){return this.Yg}set defaultCommentSpringLength(t){this.Yg!==t&&(U.s(t,"number",ForceDirectedLayout,"defaultCommentSpringLength"),this.Yg=t,this.p())}get defaultCommentElectricalCharge(){return this.Kg}set defaultCommentElectricalCharge(t){this.Kg!==t&&(U.s(t,"number",ForceDirectedLayout,"defaultCommentElectricalCharge"),this.Kg=t,this.p())}get prelayoutQuality(){return this.hu}set prelayoutQuality(t){this.hu!==t&&(U.s(t,"number",ForceDirectedLayout,"prelayoutQuality"),this.hu=t,this.p())}get prelayoutSpread(){return this.dc}set prelayoutSpread(t){this.dc!==t&&(U.s(t,"number",ForceDirectedLayout,"prelayoutSpread"),this.dc=t,this.p())}}class ForceDirectedNetwork extends LayoutNetwork{constructor(t){super(t)}createVertex(){return new ForceDirectedVertex(this)}createEdge(){return new ForceDirectedEdge(this)}}class ForceDirectedVertex extends LayoutVertex{Xk;Gk;Yk;Kk;Hk;hierarchicalVertexes;idInCluster;constructor(t){super(t),this.Xk=!1,this.Gk=NaN,this.Yk=NaN,this.Kk=0,this.Hk=0,this.hierarchicalVertexes=new List,this.idInCluster=-1}get isFixed(){return this.Xk}set isFixed(t){this.Xk!==t&&(U.s(t,"boolean",ForceDirectedVertex,"isFixed"),this.Xk=t)}get charge(){return this.Gk}set charge(t){this.Gk!==t&&(U.s(t,"number",ForceDirectedVertex,"charge"),this.Gk=t)}get mass(){return this.Yk}set mass(t){this.Yk!==t&&(U.s(t,"number",ForceDirectedVertex,"mass"),this.Yk=t)}get forceX(){return this.Kk}set forceX(t){this.Kk!==t&&(U.s(t,"number",ForceDirectedVertex,"forceX"),this.Kk=t)}get forceY(){return this.Hk}set forceY(t){this.Hk!==t&&(U.s(t,"number",ForceDirectedVertex,"forceY"),this.Hk=t)}}class ForceDirectedEdge extends LayoutEdge{jk;qk;constructor(t){super(t),this.jk=NaN,this.qk=NaN}get stiffness(){return this.jk}set stiffness(t){this.jk!==t&&(U.s(t,"number",ForceDirectedEdge,"stiffness"),this.jk=t)}get length(){return this.qk}set length(t){this.qk!==t&&(U.s(t,"number",ForceDirectedEdge,"length"),this.qk=t)}}class RandomNumberGenerator{I;R;Q;M;A;seed;constructor(t){t===void 0&&(t=42),this.seed=t,this.A=48271,this.M=2147483647,this.Q=this.M/this.A,this.R=this.M%this.A,this.I=1/this.M,this.random()}random(){const t=this.seed/this.Q,e=this.seed%this.Q,i=this.A*e-this.R*t;return i>0?this.seed=i:this.seed=i+this.M,this.seed*this.I}}var LayeredDigraphCycleRemove=(w=>(w[w.DepthFirst=0]="DepthFirst",w[w.Greedy=1]="Greedy",w[w.FromLayers=2]="FromLayers",w))(LayeredDigraphCycleRemove||{}),LayeredDigraphLayering=(w=>(w[w.OptimalLinkLength=10]="OptimalLinkLength",w[w.LongestPathSink=11]="LongestPathSink",w[w.LongestPathSource=12]="LongestPathSource",w))(LayeredDigraphLayering||{}),LayeredDigraphInit=(w=>(w[w.DepthFirstOut=20]="DepthFirstOut",w[w.DepthFirstIn=21]="DepthFirstIn",w[w.Naive=22]="Naive",w))(LayeredDigraphInit||{}),LayeredDigraphAggressive=(w=>(w[w.None=30]="None",w[w.Less=31]="Less",w[w.More=32]="More",w))(LayeredDigraphAggressive||{}),LayeredDigraphPack=(w=>(w[w.None=0]="None",w[w.Expand=1]="Expand",w[w.Straighten=2]="Straighten",w[w.Median=4]="Median",w[w.MaybeExpand=8]="MaybeExpand",w[w.All=15]="All",w))(LayeredDigraphPack||{}),LayeredDigraphAlign=(w=>(w[w.None=0]="None",w[w.UpperLeft=1]="UpperLeft",w[w.UpperRight=2]="UpperRight",w[w.LowerLeft=4]="LowerLeft",w[w.LowerRight=8]="LowerRight",w[w.All=15]="All",w))(LayeredDigraphAlign||{});class LayeredDigraphLayout extends Layout{Vs;ti;P;cu;fu;uu;gc;du;cr;gu;zn;_;Pw;Bt;Hg;Bs;ie;zs;ms;ps;Rt;jg;qg;Wk;fn;mu;fr;Xn;Gn;uL;Ka;constructor(t){super(),this.Vs=25,this.ti=25,this.P=0,this.cu=0,this.fu=10,this.uu=20,this.gc=4,this.du=31,this.cr=15,this.gu=10,this.zn=!0,this._=-1,this.Pw=-1,this.Bt=-1,this.Hg=0,this.Bs=0,this.ie=new Int16Array(0),this.zs=new Float32Array(0),this.ms=new Float32Array(0),this.ps=new Float32Array(0),this.Rt=new Float32Array(0),this.jg=0,this.qg=new Int16Array(0),this.Wk=new Int16Array(0),this.fn=0,this.mu=null,this.fr=new Point,this.Xn=[],this.Xn.length=100,this.Gn=15,this.uL=0,this.Ka=!0,t&&Object.assign(this,t)}cloneProtected(t){super.cloneProtected(t),t.Vs=this.Vs,t.ti=this.ti,t.P=this.P,t.cu=this.cu,t.fu=this.fu,t.uu=this.uu,t.gc=this.gc,t.du=this.du,t.cr=this.cr,t.gu=this.gu,t.zn=this.zn,t.Gn=this.Gn,t.Ka=this.Ka}fe(t){t in LayeredDigraphAggressive?this.aggressiveOption=t:t in LayeredDigraphCycleRemove?this.cycleRemoveOption=t:t in LayeredDigraphInit?this.initializeOption=t:t in LayeredDigraphLayering?this.layeringOption=t:super.fe(t)}createNetwork(){return new LayeredDigraphNetwork(this)}doLayout(t){this.network===null&&(this.network=this.makeNetwork(t)),this.arrangementOrigin=this.initialOrigin(this.arrangementOrigin),this.S3(),this.network.vertexes.count>0&&(this.network.deleteSelfEdges(),this.cycleRemoveOption!==2&&this.removeCycles(),this.M3(),this.cycleRemoveOption===2&&this.removeCycles(),this.N3(),this.C3(),this.L3(),this.reduceCrossings(),this.straightenAndPack(),this.updateParts()),this.network=null,this.isValidLayout=!0}linkMinLength(t){return 1}linkLengthWeight(t){return 1}linkStraightenWeight(t){const e=t.fromVertex.node||t.fromVertex.data,i=t.toVertex.node||t.toVertex.data;return e===null&&i===null?8:e===null||i===null?4:1}nodeMinLayerSpace(t,e){return t.node===null&&t.data===null?0:this.P===90||this.P===270?e?t.focus.y+10:t.bounds.height-t.focus.y+10:e?t.focus.x+10:t.bounds.width-t.focus.x+10}nodeMinColumnSpace(t,e){if(t.node===null&&t.data===null)return 0;const i=e?t.Jk:t.$k;if(i!==null)return i;const s=this.P;return s===90||s===270?e?t.Jk=t.focus.x/this.ti+1|0:t.$k=(t.bounds.width-t.focus.x)/this.ti+1|0:e?t.Jk=t.focus.y/this.ti+1|0:t.$k=(t.bounds.height-t.focus.y)/this.ti+1|0}ei(){const t=this.network.vertexes.count;this.qg.length<t*2&&(this.qg=new Int16Array(t*2));let e=0;const i=this.network.vertexes.iterator;for(;i.next();){const s=i.value;this.qg[e]=s.column,e++,this.qg[e]=s.index,e++}return this.qg}os(t){let e=0;const i=this.network.vertexes.iterator;for(;i.next();){const s=i.value;s.column=t[e],e++,s.index=t[e],e++}}cF(t,e){const i=this.Ha(t),s=this.ie[t];this.Wk.length<s*s&&(this.Wk=new Int16Array(s*s));const n=this.Wk;for(let o=0;o<s;o++){let r=0;const l=i[o],a=l.near;let h=0;a!==null&&a!==l&&a.layer===l.layer&&(r+=Math.max(0,Math.abs(a.index-l.index)-1));let c,f=0,u,d=0,m=0,g=0,p,y=0,x,k=0,b=0,P=0,S;if(e>=0){for(c=i[o].Mo,f=0;f<c.length;f++)if(u=c[f],u.valid&&u.fromVertex.layer!==t)for(d=u.fromVertex.index,m=u.portToPos,g=u.portFromPos,y=f+1;y<c.length;y++)x=c[y],x.valid&&x.fromVertex.layer!==t&&(k=x.fromVertex.index,b=x.portToPos,P=x.portFromPos,m<b&&(d>k||d===k&&g>P)&&r++,b<m&&(k>d||k===d&&P>g)&&r++)}if(e<=0){for(c=i[o].rr,f=0;f<c.length;f++)if(u=c[f],u.valid&&u.toVertex.layer!==t)for(d=u.toVertex.index,m=u.portToPos,g=u.portFromPos,y=f+1;y<c.length;y++)x=c[y],x.valid&&x.toVertex.layer!==t&&(k=x.toVertex.index,b=x.portToPos,P=x.portFromPos,g<P&&(d>k||d===k&&m>b)&&r++,P<g&&(k>d||k===d&&b>m)&&r++)}for(n[o*s+o]=r,h=o+1;h<s;h++){let L=0,C=0;if(e>=0){for(p=i[o].Mo,S=i[h].Mo,f=0;f<p.length;f++)if(u=p[f],u.valid&&u.fromVertex.layer!==t)for(d=u.fromVertex.index,m=u.portToPos,g=u.portFromPos,y=0;y<S.length;y++)x=S[y],x.valid&&x.fromVertex.layer!==t&&(k=x.fromVertex.index,b=x.portToPos,P=x.portFromPos,(d<k||d===k&&g<P)&&C++,(k<d||k===d&&P<g)&&L++)}if(e<=0){for(p=i[o].rr,S=i[h].rr,f=0;f<p.length;f++)if(u=p[f],u.valid&&u.toVertex.layer!==t)for(d=u.toVertex.index,m=u.portToPos,g=u.portFromPos,y=0;y<S.length;y++)x=S[y],x.valid&&x.toVertex.layer!==t&&(k=x.toVertex.index,b=x.portToPos,P=x.portFromPos,(d<k||d===k&&m<b)&&C++,(k<d||k===d&&b<m)&&L++)}n[o*s+h]=L,n[h*s+o]=C}}return this.ja(t,i),n}countCrossings(){let t=0;for(let e=0;e<=this._;e++){const i=this.cF(e,1),s=this.ie[e];for(let n=0;n<s;n++)for(let o=n;o<s;o++)t+=i[n*s+o]}return t}A3(t,e,i){const s=this.Ha(t),n=this.ie[t];let o=0;for(let r=0;r<n;r++){let l=null;e<=0&&(l=s[r].Mo);let a=null;e>=0&&(a=s[r].rr);let h,c=0,f=0;if(l!==null)for(let u=0;u<l.length;u++)h=l[u],h.valid&&h.fromVertex.layer!==t&&(c=h.fromVertex.column+h.portFromColOffset,f=h.toVertex.column+h.portToColOffset,i?o+=Math.abs(c-f)*this.linkStraightenWeight(h):o+=Math.abs(c-f));if(a!==null)for(let u=0;u<a.length;u++)h=a[u],h.valid&&h.toVertex.layer!==t&&(c=h.fromVertex.column+h.portFromColOffset,f=h.toVertex.column+h.portToColOffset,i?o+=(Math.abs(c-f)+1)*this.linkStraightenWeight(h):o+=Math.abs(c-f))}return this.ja(t,s),o}Zk(t){let e=0;for(let i=0;i<=this._;i++)e+=this.A3(i,1,t);return e}Sw(){let t=1/0;this.Bt=-1;const e=this.network.vertexes.iterator;for(;e.next();){const i=e.value;t=Math.min(t,i.column-this.nodeMinColumnSpace(i,!0)),this.Bt=Math.max(this.Bt,i.column+this.nodeMinColumnSpace(i,!1))}for(e.reset();e.next();){const i=e.value;i.column-=t}this.Bt-=t}Mw(t,e){const i=this.Ha(t),s=this.ie[t],n=new Float32Array(s);for(let o=0;o<s;o++){const r=i[o];let l=null;e<=0&&(l=r.Mo);let a=null;e>=0&&(a=r.rr);let h=0,c=0;const f=r.near;f!==null&&f.layer===r.layer&&(h+=f.column-1,c++);let u;if(l!==null)for(let d=0;d<l.length;d++){u=l[d];const m=u.fromVertex;u.valid&&!u.rev&&m.layer!==t&&(h+=m.column,c++)}if(a!==null)for(let d=0;d<a.length;d++){u=a[d];const m=u.toVertex;u.valid&&!u.rev&&m.layer!==t&&(h+=m.column,c++)}c===0?n[o]=-1:n[o]=h/c}return this.ja(t,i),n}fF(t,e){const i=this.Ha(t),s=this.ie[t],n=new Int16Array(s);for(let o=0;o<s;o++){const r=i[o];let l=null;e<=0&&(l=r.Mo);let a=null;e>=0&&(a=r.rr);let h=0;const c=[],f=r.near;f!==null&&f.layer===r.layer&&(c[h]=f.column-1,h++);let u;if(l!==null)for(let d=0;d<l.length;d++){u=l[d];const m=u.fromVertex;u.valid&&!u.rev&&m.layer!==t&&(c[h]=m.column+u.portFromColOffset,h++)}if(a!==null)for(let d=0;d<a.length;d++){u=a[d];const m=u.toVertex;u.valid&&!u.rev&&m.layer!==t&&(c[h]=m.column+u.portToColOffset,h++)}if(h===0)n[o]=-1;else{c.sort((m,g)=>m-g);const d=h>>1;(h&1)!==0?n[o]=c[d]:n[o]=c[d-1]+c[d]>>1}}return this.ja(t,i),n}Nw(t,e,i,s,n){if(t.component===i){t.component=e;let o=0,r=0;if(s){const l=t.destinationEdges;for(;l.next();){const a=l.value,h=a.toVertex;o=t.layer-h.layer,r=this.linkMinLength(a),o===r&&this.Nw(h,e,i,s,n)}}if(n){const l=t.sourceEdges;for(;l.next();){const a=l.value,h=a.fromVertex;o=h.layer-t.layer,r=this.linkMinLength(a),o===r&&this.Nw(h,e,i,s,n)}}}}dL(t,e,i,s,n){if(t.component===i){if(t.component=e,s){const o=t.destinationEdges;for(;o.next();){const l=o.value.toVertex;this.dL(l,e,i,s,n)}}if(n){const o=t.sourceEdges;for(;o.next();){const l=o.value.fromVertex;this.dL(l,e,i,s,n)}}}}removeCycles(){const t=this.network.edges.iterator;for(;t.next();){const e=t.value;e.rev=!1}switch(this.cu){default:case 1:this.T3();break;case 0:this.D3();break;case 2:this.v3();break}}v3(){const t=this.network,e=t.vertexes.iterator;let i=1/0;for(;e.next();){const s=e.value;i=Math.min(i,s.layer)}if(i<1/0){if(i<0)for(e.reset();e.next();){const r=e.value;r.layer-=i}const s=[];for(e.reset();e.next();){const r=e.value,l=s[r.layer];l===void 0?s[r.layer]=[r]:l.push(r)}let n=0;for(let r=0;r<s.length;r++){const l=s[r];if(!l||l.length===0)n++;else if(r>0)for(let a=0;a<l.length;a++){const h=l[a];h.layer-=n}}const o=t.edges.iterator;for(;o.next();){const r=o.value,l=r.fromVertex,a=r.toVertex;l.layer<a.layer&&(t.reverseEdge(r),r.rev=!0)}}}T3(){const t=this.network;let e=0,i=t.vertexes.count-1;const s=[];s.length=i+1;const n=t.vertexes.iterator;for(;n.next();){const r=n.value;r.ii=!0}for(;this.F3(t)!==null;){let r;for(r=this.uF(t);r!==null;)s[i]=r,i--,r.ii=!1,r=this.uF(t);for(r=this.dF(t);r!==null;)s[e]=r,e++,r.ii=!1,r=this.dF(t);r=this.R3(t),r!==null&&(s[e]=r,e++,r.ii=!1)}for(let r=0;r<t.vertexes.count;r++)s[r].index=r;const o=t.edges.iterator;for(;o.next();){const r=o.value,l=r.fromVertex,a=r.toVertex;l.index>a.index&&(t.reverseEdge(r),r.rev=!0)}}F3(t){const e=t.vertexes.iterator;for(;e.next();){const i=e.value;if(i.ii)return i}return null}uF(t){const e=t.vertexes.iterator;for(;e.next();){const i=e.value;if(i.ii){let s=!0;const n=i.destinationEdges;for(;n.next();)if(n.value.toVertex.ii){s=!1;break}if(s)return i}}return null}dF(t){const e=t.vertexes.iterator;for(;e.next();){const i=e.value;if(i.ii){let s=!0;const n=i.sourceEdges;for(;n.next();)if(n.value.fromVertex.ii){s=!1;break}if(s)return i}}return null}R3(t){let e=null,i=0;const s=this.network.vertexes.iterator;for(;s.next();){const n=s.value;if(n.ii){let o=0;const r=n.destinationEdges;for(;r.next();)r.value.toVertex.ii&&o++;let l=0;const a=n.sourceEdges;for(;a.next();)a.value.fromVertex.ii&&l++;(e===null||i<o-l)&&(e=n,i=o-l)}}return e}D3(){const t=this.network.vertexes.iterator;for(;t.next();){const i=t.value;i.pu=-1,i.to=-1}const e=this.network.edges.iterator;for(;e.next();){const i=e.value;i.forest=!1}for(this.jg=0,t.reset();t.next();){const i=t.value;i.sourceEdges.count===0&&this.gL(i)}for(t.reset();t.next();){const i=t.value;i.pu===-1&&this.gL(i)}for(e.reset();e.next();){const i=e.value;if(!i.forest){const s=i.fromVertex,n=s.pu,o=s.to,r=i.toVertex,l=r.pu,a=r.to;l<n&&o<a&&(this.network.reverseEdge(i),i.rev=!0)}}}gL(t){t.pu=this.jg,this.jg++;const e=t.destinationEdges;for(;e.next();){const i=e.value,s=i.toVertex;s.pu===-1&&(i.forest=!0,this.gL(s))}t.to=this.jg,this.jg++}M3(){const t=this.network.vertexes.iterator;for(;t.next();){const s=t.value;s.layer=-1}for(this._=-1,this.assignLayers(),t.reset();t.next();){const s=t.value;this._=Math.max(this._,s.layer)}this._>=9999&&U.o("LayeredDigraphLayout, too many layers: "+this._);const e=this.direction==0||this.direction==180,i=[];for(const s=this.network.vertexes.iterator;s.next();){const n=s.value;if(n.node===null||n.centered)continue;const o=n.layer;let r=i[o];r===void 0&&(r=0);const l=e?n.width:n.height;l>r&&(i[o]=l)}for(const s=this.network.vertexes.iterator;s.next();){const n=s.value;if(n.node===null||n.centered)continue;const o=i[n.layer];e?(n.focusX=o/2,n.focusY=n.focus.y,n.width=o):(n.focusX=n.focus.x,n.focusY=o/2,n.height=o)}}assignLayers(){switch(this.fu){case 11:this.gF();break;case 12:this.O3();break;default:case 10:this.I3();break}}gF(){const t=this.network.vertexes.iterator;for(;t.next();){const e=t.value,i=this.mF(e);this._=Math.max(i,this._)}}mF(t){let e=0;if(t.layer===-1){const i=t.destinationEdges;for(;i.next();){const s=i.value,n=s.toVertex,o=this.linkMinLength(s);e=Math.max(e,this.mF(n)+o)}t.layer=e}else e=t.layer;return e}O3(){let t=0;const e=this.network.vertexes.iterator;for(;e.next();){const i=e.value;t=this.pF(i),this._=Math.max(t,this._)}for(e.reset();e.next();){const i=e.value;i.layer=this._-i.layer}}pF(t){let e=0;if(t.layer===-1){const i=t.sourceEdges;for(;i.next();){const s=i.value,n=s.fromVertex,o=this.linkMinLength(s);e=Math.max(e,this.pF(n)+o)}t.layer=e}else e=t.layer;return e}I3(){this.gF();const t=this.network.vertexes.iterator;for(;t.next();){const i=t.value;i.ii=!1}for(t.reset();t.next();){const i=t.value;i.sourceEdges.count===0&&this.yF(i)}let e=1/0;for(t.reset();t.next();){const i=t.value;e=Math.min(e,i.layer)}for(this._=-1,t.reset();t.next();){const i=t.value;i.layer-=e,this._=Math.max(this._,i.layer)}}yF(t){if(!t.ii){t.ii=!0;const e=t.destinationEdges;for(;e.next();){const s=e.value.toVertex;this.yF(s)}this.E3(t),this.U3(t)}}E3(t){const e=this.network.vertexes.iterator;for(;e.next();){const r=e.value;r.component=-1}const i=0,s=1,n=t.Mo;let o=n.length;for(let r=0;r<o;r++){const l=n[r],a=l.fromVertex,h=l.toVertex,c=this.linkMinLength(l);a.layer-h.layer>c&&this.Nw(a,i,-1,!0,!1)}for(this.Nw(t,s,-1,!0,!0);t.component!==i;){let r=0,l=1/0,a=0,h=null;const c=this.network.vertexes.iterator;for(;c.next();){const f=c.value;if(f.component===s){let u=0,d=!1;const m=f.Mo;o=m.length;for(let p=0;p<o;p++){const y=m[p],x=y.fromVertex;if(u+=this.linkLengthWeight(y),x.component!==s){r+=this.linkLengthWeight(y);const k=x.layer-f.layer,b=this.linkMinLength(y);l=Math.min(l,k-b)}}const g=f.rr;o=g.length;for(let p=0;p<o;p++){const y=g[p],x=y.toVertex;u-=this.linkLengthWeight(y),x.component!==s?r-=this.linkLengthWeight(y):d=!0}(h===null||u<a)&&!d&&(h=f,a=u)}}if(r>0){for(e.reset();e.next();){const f=e.value;f.component===s&&(f.layer+=l)}t.component=i}else h.component=i}}U3(t){const e=this.network.vertexes.iterator;for(;e.next();){const n=e.value;n.component=-1}const i=0,s=1;for(this.Nw(t,s,-1,!0,!1);t.component!==i;){let n=0,o=1/0,r=0,l=null;const a=this.network.vertexes.iterator;for(;a.next();){const h=a.value;if(h.component===s){let c=0,f=!1;const u=h.Mo;let d=u.length;for(let g=0;g<d;g++){const p=u[g],y=p.fromVertex;c+=this.linkLengthWeight(p),y.component!==s?n+=this.linkLengthWeight(p):f=!0}const m=h.rr;d=m.length;for(let g=0;g<d;g++){const p=m[g],y=p.toVertex;if(c-=this.linkLengthWeight(p),y.component!==s){n-=this.linkLengthWeight(p);const x=h.layer-y.layer,k=this.linkMinLength(p);o=Math.min(o,x-k)}}(l===null||c>r)&&!f&&(l=h,r=c)}}if(n<0){for(e.reset();e.next();){const h=e.value;h.component===s&&(h.layer-=o)}t.component=i}else l.component=i}}N3(){const t=this.network,e=[],i=t.edges.iterator;for(;i.next();){const s=i.value;s.valid=!1,e.push(s)}for(let s=0;s<e.length;s++){const n=e[s];let o=n.fromVertex;const r=n.toVertex;if(n.valid||(o.node===null&&o.data===null||r.node===null&&r.data===null)&&o.layer===r.layer)continue;let l=0,a=0,h=0,c=0;if(n.link!==null){const P=n.link;if(P===null)continue;const S=o.node,L=r.node;if(S===null||L===null)continue;let C=P.fromNode,M=P.toNode,N=P.fromPort;for(;N!==null&&!N.isVisibleObject();)N=N.panel;let T=P.toPort;for(;T!==null&&!T.isVisibleObject();)T=T.panel;if(n.rev){const z=C,Y=N;C=M,N=T,M=z,T=Y}const A=o.focus,D=r.focus,v=n.rev?r.bounds:o.bounds,R=Point.l();S!==C?v.isReal()&&C.isVisible()?C.actualBounds.isReal()?(C.getRelativePoint(N,Spot.Center,R),R.x+=C.actualBounds.x-v.x,R.y+=C.actualBounds.y-v.y):(C.getRelativePoint(N,Spot.Center,R),R.isReal()||R.h(A)):R.h(A):v.isReal()?(C.getRelativePoint(N,Spot.Center,R),R.isReal()||R.h(A)):R.h(A);const F=n.rev?o.bounds:r.bounds,O=Point.l();L!==M?F.isReal()&&M.isVisible()?M.actualBounds.isReal()?(M.getRelativePoint(T,Spot.Center,O),O.x+=M.actualBounds.x-F.x,O.y+=M.actualBounds.y-F.y):(M.getRelativePoint(T,Spot.Center,O),O.isReal()||O.h(D)):O.h(D):F.isReal()?(M.getRelativePoint(T,Spot.Center,O),O.isReal()||O.h(D)):O.h(D),this.P===90||this.P===270?(l=Math.round((R.x-A.x)/this.ti),h=R.x,a=Math.round((O.x-D.x)/this.ti),c=O.x):(l=Math.round((R.y-A.y)/this.ti),h=R.y,a=Math.round((O.y-D.y)/this.ti),c=O.y),Point.i(R),Point.i(O),n.portFromColOffset=l,n.portFromPos=h,n.portToColOffset=a,n.portToPos=c}else n.portFromColOffset=0,n.portFromPos=0,n.portToColOffset=0,n.portToPos=0;let f=o.layer;const u=r.layer,d=this.V3(n),m=d===1||d===3,g=d===2||d===3;let p,y,x=null,k;g&&(x=this.B3(o,r),k=1,y=t.createVertex(),y.node=null,y.Qk=1,y.layer=f,y.near=o,t.addVertex(y),p=t.linkVertexes(o,y,n.link),p.valid=!1,p.rev=n.rev,p.portFromColOffset=l,p.portToColOffset=0,p.portFromPos=h,p.portToPos=0,o=y);let b=1;if(m&&b--,f-u>b&&f>0){for(n.valid=!1,y=t.createVertex(),y.node=null,y.Qk=2,y.layer=f-1,x&&k<x.length&&y.layer===x[k].layer&&(y.near=x[k++]),t.addVertex(y),p=t.linkVertexes(o,y,n.link),p.valid=!0,p.rev=n.rev,p.portFromColOffset=g?0:l,p.portToColOffset=0,p.portFromPos=g?0:h,p.portToPos=0,o=y,f--;f-u>b&&f>0;)y=t.createVertex(),y.node=null,y.Qk=3,y.layer=f-1,x&&k<x.length&&y.layer===x[k].layer&&(y.near=x[k++]),t.addVertex(y),p=t.linkVertexes(o,y,n.link),p.valid=!0,p.rev=n.rev,p.portFromColOffset=0,p.portToColOffset=0,p.portFromPos=0,p.portToPos=0,o=y,f--;p=t.linkVertexes(y,r,n.link),p.valid=!m,m&&(y.near=r),p.rev=n.rev,p.portFromColOffset=0,p.portToColOffset=a,p.portFromPos=0,p.portToPos=c}else n.valid=!0}}V3(t){let e=0;const i=t.link;if(i!==null){const s=i.fromPort,n=i.toPort;if(s!==null&&n!==null){const o=i.fromNode,r=i.toNode;if(o!==null&&r!==null){const l=this._k(!0),a=this._k(!1),h=this.setsPortSpots?l:i.computeSpot(!0,s),c=this.setsPortSpots?a:i.computeSpot(!1,n),f=i.isOrthogonal;if(h.isSide()&&h.includesSide(a)&&c.isSide()&&c.includesSide(l))return 0;const u=i.getLinkPoint(o,s,h,!0,f,r,n,Point.l()),d=i.getLinkDirection(o,s,u,h,!0,f,r,n);Point.i(u),(!h.isNone()&&d===this.wF(t,!0)||this.setsPortSpots&&o!==null&&o.ports.count===1&&t.rev)&&(e+=1);const m=i.getLinkPoint(r,n,c,!1,f,o,s,Point.l()),g=i.getLinkDirection(r,n,m,c,!1,f,o,s);Point.i(m),(!c.isNone()&&g===this.wF(t,!1)||this.setsPortSpots&&r!==null&&r.ports.count===1&&t.rev)&&(e+=2)}}}return e}wF(t,e){return this.P===90?e&&!t.rev||!e&&t.rev?270:90:this.P===180?e&&!t.rev||!e&&t.rev?0:180:this.P===270?e&&!t.rev||!e&&t.rev?90:270:e&&!t.rev||!e&&t.rev?180:0}B3(t,e){const i=[];return i.push(e),this.xF(t,i)?i.reverse():[]}xF(t,e){const i=e[e.length-1].sourceEdges.iterator;for(;i.next();){const s=i.value;if(s.rev||!s.valid)continue;const n=s.fromVertex;if(e.push(n),n===t||this.xF(t,e))return!0;e.pop()}return!1}C3(){this.ie.length!==this._+1&&(this.ie=new Int16Array(this._+1));const t=this.ie;for(let i=0;i<=this._;i++)t[i]=0;const e=this.network.vertexes.iterator;for(;e.next();){const i=e.value;i.index=-1}this.initializeIndices(),this.Pw=-1,this.Hg=0,this.Bs=0;for(let i=0;i<=this._;i++)t[i]>t[this.Bs]&&(this.Pw=t[i]-1,this.Bs=i),t[i]<t[this.Hg]&&(this.Hg=i);this.mu=[];for(let i=0;i<t.length;i++)this.mu[i]=[];for(e.reset();e.next();){const i=e.value,s=i.layer,n=this.mu[s];n[i.index]=i}}initializeIndices(){switch(this.uu){default:case 22:this.z3();break;case 20:this.X3();break;case 21:this.G3();break}}z3(){let t=null;const e=this.network.vertexes.iterator;for(;e.next();){const i=e.value;if(i.near&&(t===null&&(t=new Map),i.layer===i.near.layer)){const s=t.get(i.near)||[];s.push(i),t.set(i.near,s)}}for(e.reset();e.next();){const i=e.value;if(i.near)continue;const s=i.layer;if(i.index=this.ie[s],this.ie[s]++,!t)continue;const n=t.get(i);Array.isArray(n)&&n.forEach(o=>{o.index=this.ie[s],this.ie[s]++})}}X3(){let t=null;const e=this.network.vertexes.iterator;for(;e.next();){const i=e.value;if(i.near&&(t===null&&(t=new Map),i.layer===i.near.layer)){const s=t.get(i.near)||[];s.push(i),t.set(i.near,s)}}for(let i=this._;i>=0;i--)for(e.reset();e.next();){const s=e.value;s.layer===i&&s.index===-1&&this.bF(s,t)}}bF(t,e){if(t.near)return;const i=t.layer;if(t.index=this.ie[i],this.ie[i]++,e){const o=e.get(t);Array.isArray(o)&&o.forEach(r=>{r.index=this.ie[i],this.ie[i]++})}const s=t.rr;let n=!0;for(;n;){n=!1;for(let o=0;o<s.length-1;o++){const r=s[o],l=s[o+1];r.portFromColOffset>l.portFromColOffset&&(n=!0,s[o]=l,s[o+1]=r)}}for(let o=0;o<s.length;o++){const r=s[o];if(r.valid){const l=r.toVertex;l.index===-1&&this.bF(l,e)}}}G3(){let t=null;const e=this.network.vertexes.iterator;for(;e.next();){const i=e.value;if(i.near&&(t===null&&(t=new Map),i.layer===i.near.layer)){const s=t.get(i.near)||[];s.push(i),t.set(i.near,s)}}for(let i=0;i<=this._;i++)for(e.reset();e.next();){const s=e.value;s.layer===i&&s.index===-1&&this.kF(s,t)}}kF(t,e){if(t.near)return;const i=t.layer;if(t.index=this.ie[i],this.ie[i]++,e){const a=e.get(t);Array.isArray(a)&&a.forEach(h=>{h.index=this.ie[i],this.ie[i]++})}const s=t.Mo;let n=!0,o=0;for(;n;)for(n=!1,o=0;o<s.length-1;o++){const a=s[o],h=s[o+1];a.portToColOffset>h.portToColOffset&&(n=!0,s[o]=h,s[o+1]=a)}let r,l;for(o=0;o<s.length;o++)l=s[o],l.valid&&(r=l.fromVertex,r.index===-1&&this.kF(r,e))}L3(){this.Bt=-1;for(let t=0;t<=this._;t++){const e=this.Ha(t);let i=0;const s=this.ie[t];for(let n=0;n<s;n++){const o=e[n];i+=this.nodeMinColumnSpace(o,!0),o.column=i,i+=1,i+=this.nodeMinColumnSpace(o,!1)}this.Bt=Math.max(this.Bt,i-1),this.ja(t,e)}}reduceCrossings(){let t=this.countCrossings(),e=this.ei(),i=0,s=0,n=0;for(i=0;i<this.gc;i++){for(s=0;s<=this._;s++)this.tP(s,1),this.ys(s,1,!1,1);for(n=this.countCrossings(),n<t&&(t=n,e=this.ei()),s=this._;s>=0;s--)this.tP(s,-1),this.ys(s,-1,!1,-1);n=this.countCrossings(),n<t&&(t=n,e=this.ei())}for(this.os(e),i=0;i<this.gc;i++){for(s=0;s<=this._;s++)this.tP(s,0),this.ys(s,0,!1,0);for(n=this.countCrossings(),n<t&&(t=n,e=this.ei()),s=this._;s>=0;s--)this.tP(s,0),this.ys(s,0,!1,0);n=this.countCrossings(),n<t&&(t=n,e=this.ei())}this.os(e);let o=!1,r=0,l=0,a=0,h=0;switch(this.du){case 30:break;case 32:for(a=t+1;(h=this.countCrossings())<a;)for(a=h,r=this._;r>=0;r--)for(l=0;l<=r;l++){for(o=!0;o;)for(o=!1,s=r;s>=l;s--)o=this.ys(s,-1,!1,-1)||o;for(n=this.countCrossings(),n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=r;s>=l;s--)o=this.ys(s,1,!1,1)||o;for(n=this.countCrossings(),n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=l;s<=r;s++)o=this.ys(s,1,!1,1)||o;for(n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=l;s<=r;s++)o=this.ys(s,-1,!1,-1)||o;for(n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=r;s>=l;s--)o=this.ys(s,0,!1,0)||o;for(n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=l;s<=r;s++)o=this.ys(s,0,!1,0)||o;n>=t?this.os(e):(t=n,e=this.ei())}break;default:case 31:for(r=this._,l=0,a=t+1;(h=this.countCrossings())<a;){for(a=h,o=!0;o;)for(o=!1,s=r;s>=l;s--)o=this.ys(s,-1,!1,-1)||o;for(n=this.countCrossings(),n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=r;s>=l;s--)o=this.ys(s,1,!1,1)||o;for(n=this.countCrossings(),n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=l;s<=r;s++)o=this.ys(s,1,!1,1)||o;for(n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=l;s<=r;s++)o=this.ys(s,-1,!1,-1)||o;for(n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=r;s>=l;s--)o=this.ys(s,0,!1,0)||o;for(n>=t?this.os(e):(t=n,e=this.ei()),o=!0;o;)for(o=!1,s=l;s<=r;s++)o=this.ys(s,0,!1,0)||o;n>=t?this.os(e):(t=n,e=this.ei())}break}this.os(e)}tP(t,e){let i=0,s=!1;const n=this.Ha(t),o=this.ie[t],r=this.fF(t,e),l=this.Mw(t,e);for(i=0;i<o;i++)l[i]===-1&&(l[i]=n[i].column),r[i]===-1&&(r[i]=n[i].column);let a=!0,h;for(;a;)for(a=!1,i=0;i<o-1;i++)if(r[i+1]<r[i]||r[i+1]===r[i]&&l[i+1]<l[i]){s=!0,a=!0;const f=r[i];r[i]=r[i+1],r[i+1]=f;const u=l[i];l[i]=l[i+1],l[i+1]=u,h=n[i],n[i]=n[i+1],n[i+1]=h}let c=0;for(i=0;i<o;i++)h=n[i],h.index=i,c+=this.nodeMinColumnSpace(h,!0),h.column=c,c+=1,c+=this.nodeMinColumnSpace(h,!1);return this.ja(t,n),s}ys(t,e,i,s){const n=this.Ha(t),o=this.ie[t],r=this.cF(t,e);let l=0,a;if(!i||s>0)for(a=new Float32Array(o),l=0;l<o;l++)a[l]=-1;else a=this.Mw(t,-1);let h;if(!i||s<0)for(h=new Float32Array(o),l=0;l<o;l++)h[l]=-1;else h=this.Mw(t,1);let c=!1,f=!0;for(;f;)for(f=!1,l=0;l<o-1;l++){const u=r[n[l].index*o+n[l+1].index],d=r[n[l+1].index*o+n[l].index];let m=0,g=0;const p=n[l].column,y=n[l+1].column,x=this.nodeMinColumnSpace(n[l],!0),k=this.nodeMinColumnSpace(n[l],!1),b=this.nodeMinColumnSpace(n[l+1],!0),P=this.nodeMinColumnSpace(n[l+1],!1),S=p-x+b,L=y-k+P;let C=0,M=0,N=0,T=0,A=0,D=0,v=0,R,F=0,O,z=0;const Y=n[l].sourceEdges.iterator;if(i&&s<=0)for(;Y.next();){const J=Y.value;R=J.fromVertex,J.valid&&R.layer!==t&&(N=this.linkStraightenWeight(J),T=J.portFromColOffset,A=J.portToColOffset,D=R.column,C+=(Math.abs(p+A-(D+T))+1)*N,M+=(Math.abs(L+A-(D+T))+1)*N)}for(Y.reset();Y.next();){const J=Y.value;if(R=J.fromVertex,J.valid&&R.layer===t){for(F=0;F<n.length&&n[F]!==R;)F++;F<l&&(m+=2*(l-F),g+=2*(l+1-F)),F===l+1&&(m+=1),F>l+1&&(m+=4*(F-l),g+=4*(F-(l+1)))}}const E=n[l].destinationEdges.iterator;if(i&&s>=0)for(;E.next();){const J=E.value;O=J.toVertex,J.valid&&O.layer!==t&&(N=this.linkStraightenWeight(J),T=J.portFromColOffset,A=J.portToColOffset,v=O.column,C+=(Math.abs(p+T-(v+A))+1)*N,M+=(Math.abs(L+T-(v+A))+1)*N)}for(E.reset();E.next();){const J=E.value;if(O=J.toVertex,J.valid&&O.layer===t){for(z=0;z<n.length&&n[z]!==O;)z++;z===l+1&&(g+=1)}}const X=n[l+1].sourceEdges.iterator;if(i&&s<=0)for(;X.next();){const J=X.value;R=J.fromVertex,J.valid&&R.layer!==t&&(N=this.linkStraightenWeight(J),T=J.portFromColOffset,A=J.portToColOffset,D=R.column,C+=(Math.abs(y+A-(D+T))+1)*N,M+=(Math.abs(S+A-(D+T))+1)*N)}for(X.reset();X.next();){const J=X.value;if(R=J.fromVertex,J.valid&&R.layer===t){for(F=0;F<n.length&&n[F]!==R;)F++;F<l&&(m+=2*(l+1-F),g+=2*(l-F)),F===l&&(g+=1),F>l+1&&(m+=4*(F-(l+1)),g+=4*(F-l))}}const B=n[l+1].destinationEdges.iterator;if(i&&s>=0)for(;B.next();){const J=B.value;O=J.toVertex,J.valid&&O.layer!==t&&(N=this.linkStraightenWeight(J),T=J.portFromColOffset,A=J.portToColOffset,v=O.column,C+=(Math.abs(y+T-(v+A))+1)*N,M+=(Math.abs(S+T-(v+A))+1)*N)}for(B.reset();B.next();){const J=B.value;if(O=J.toVertex,J.valid&&O.layer===t){for(z=0;z<n.length&&n[z]!==O;)z++;z===l&&(m+=1)}}let H=0,j=0;const W=a[n[l].index],Z=h[n[l].index],V=a[n[l+1].index],$=h[n[l+1].index];if(W!==-1&&(H+=Math.abs(W-p),j+=Math.abs(W-L)),Z!==-1&&(H+=Math.abs(Z-p),j+=Math.abs(Z-L)),V!==-1&&(H+=Math.abs(V-y),j+=Math.abs(V-S)),$!==-1&&(H+=Math.abs($-y),j+=Math.abs($-S)),g<m-.5||g===m&&d<u-.5||g===m&&d===u&&M<C-.5||g===m&&d===u&&M===C&&j<H-.5){c=!0,f=!0,n[l].column=L,n[l+1].column=S;const J=n[l];n[l]=n[l+1],n[l+1]=J}}for(l=0;l<o;l++)n[l].index=l;return this.ja(t,n),c}straightenAndPack(){if(this.Gn!==0){this.Y3();return}let t=0,e=!1,i=(this.cr&1)!==0;const s=(this.cr&8)!==0;if(this.network.edges.count>1e3&&s&&(i=!1),i){const n=[];let o=0;for(o=0;o<=this._;o++)n[o]=0;let r=0;const l=this.network.vertexes.iterator;for(;l.next();){const h=l.value;t=h.layer,r=h.column;const c=this.nodeMinColumnSpace(h,!1);n[t]=Math.max(n[t],r+c)}const a=8;for(l.reset();l.next();){const h=l.value;t=h.layer,r=h.column,h.column=((this.Bt-n[t])*a>>1)+r*a}this.Bt*=a}if((this.cr&2)!==0){e=!0;let n=0;for(;e&&n<this.gu;){for(e=!1,t=this.Bs+1;t<=this._;t++)e=this.Wg(t,1)||e;for(t=this.Bs-1;t>=0;t--)e=this.Wg(t,-1)||e;e=this.Wg(this.Bs,0)||e,n++}}if((this.cr&4)!==0){for(t=this.Bs+1;t<=this._;t++)this.mL(t,1);for(t=this.Bs-1;t>=0;t--)this.mL(t,-1);this.mL(this.Bs,0)}if(i&&(this.PF(-1),this.PF(1)),(this.cr&2)!==0){e=!0;let n=0;for(;e&&n<this.gu;){for(e=!1,e=this.Wg(this.Bs,0)||e,t=this.Bs+1;t<=this._;t++)e=this.Wg(t,0)||e;for(t=this.Bs-1;t>=0;t--)e=this.Wg(t,0)||e;n++}}}Wg(t,e){let i=!1;for(;this.K3(t,e);)i=!0;return i}K3(t,e){let i=0;const s=this.Ha(t),n=this.ie[t],o=this.Mw(t,-1);if(e>0)for(i=0;i<n;i++)o[i]=-1;const r=this.Mw(t,1);if(e<0)for(i=0;i<n;i++)r[i]=-1;let l=!1,a=!0;for(;a;)for(a=!1,i=0;i<n;i++){const h=s[i].column,c=this.nodeMinColumnSpace(s[i],!0),f=this.nodeMinColumnSpace(s[i],!1);let u=0;i-1<0||h-s[i-1].column-1>c+this.nodeMinColumnSpace(s[i-1],!1)?u=h-1:u=h;let d=0;i+1>=n||s[i+1].column-h-1>f+this.nodeMinColumnSpace(s[i+1],!0)?d=h+1:d=h;let m=0,g=0,p=0,y=0,x=0,k=0;if(e<=0){const M=s[i].sourceEdges.iterator;for(;M.next();){const N=M.value,T=N.fromVertex;if(N.valid&&T.layer!==t){y=this.linkStraightenWeight(N),x=N.portFromColOffset,k=N.portToColOffset;const A=T.column;m+=(Math.abs(h+k-(A+x))+1)*y,g+=(Math.abs(u+k-(A+x))+1)*y,p+=(Math.abs(d+k-(A+x))+1)*y}}}if(e>=0){const M=s[i].destinationEdges.iterator;for(;M.next();){const N=M.value,T=N.toVertex;if(N.valid&&T.layer!==t){y=this.linkStraightenWeight(N),x=N.portFromColOffset,k=N.portToColOffset;const A=T.column;m+=(Math.abs(h+x-(A+k))+1)*y,g+=(Math.abs(u+x-(A+k))+1)*y,p+=(Math.abs(d+x-(A+k))+1)*y}}}let b=0,P=0,S=0;const L=o[s[i].index],C=r[s[i].index];L!==-1&&(b+=Math.abs(L-h),P+=Math.abs(L-u),S+=Math.abs(L-d)),C!==-1&&(b+=Math.abs(C-h),P+=Math.abs(C-u),S+=Math.abs(C-d)),g<m||g===m&&P<b?(l=!0,a=!0,s[i].column=u):(p<m||p===m&&S<b)&&(l=!0,a=!0,s[i].column=d)}return this.ja(t,s),this.Sw(),l}mL(t,e){let i=0;const s=this.Ha(t),n=this.ie[t],o=this.fF(t,e),r=new Int16Array(o);let l=!1,a=!0;for(;a;)for(a=!1,i=0;i<n;i++){const h=s[i].column,c=this.nodeMinColumnSpace(s[i],!0),f=this.nodeMinColumnSpace(s[i],!1);let u=0,d=0,m=0,g=0,p=0;r[i]===-1?i===0&&i===n-1?u=h:i===0?(d=s[i+1].column,d-h===f+this.nodeMinColumnSpace(s[i+1],!0)?u=h-1:u=h):i===n-1?(m=s[i-1].column,h-m===c+this.nodeMinColumnSpace(s[i-1],!1)?u=h+1:u=h):(m=s[i-1].column,p=m+this.nodeMinColumnSpace(s[i-1],!1)+c+1,d=s[i+1].column,g=d-this.nodeMinColumnSpace(s[i+1],!0)-f-1,u=(p+g)/2|0):i===0&&i===n-1?u=r[i]:i===0?(d=s[i+1].column,g=d-this.nodeMinColumnSpace(s[i+1],!0)-f-1,u=Math.min(r[i],g)):i===n-1?(m=s[i-1].column,p=m+this.nodeMinColumnSpace(s[i-1],!1)+c+1,u=Math.max(r[i],p)):(m=s[i-1].column,p=m+this.nodeMinColumnSpace(s[i-1],!1)+c+1,d=s[i+1].column,g=d-this.nodeMinColumnSpace(s[i+1],!0)-f-1,p<r[i]&&r[i]<g?u=r[i]:p>=r[i]?u=p:g<=r[i]&&(u=g)),u!==h&&(l=!0,a=!0,s[i].column=u)}return this.ja(t,s),this.Sw(),l}H3(){for(let t=0;t<=this.Bt;t++)for(;this.j3(t,1););this.Sw()}j3(t,e){let i=!0;const s=this.network.vertexes.iterator;for(;s.next();){const o=s.value,r=this.nodeMinColumnSpace(o,!0),l=this.nodeMinColumnSpace(o,!1);if(o.column-r<=t&&o.column+l>=t){i=!1;break}}let n=!1;if(i){if(e>0)for(s.reset();s.next();){const o=s.value;o.column>t&&(o.column-=1,n=!0)}if(e<0)for(s.reset();s.next();){const o=s.value;o.column<t&&(o.column+=1,n=!0)}}return n}q3(){this.H3();for(let t=0;t<this.Bt;t++)for(;this.W3(t,1););this.Sw()}W3(t,e){let i=t;e>0&&(i=t+1),e<0&&(i=t-1);let s=0;const n=[],o=[];for(s=0;s<=this._;s++)n[s]=!1,o[s]=!1;const r=this.network.vertexes.iterator;for(;r.next();){const h=r.value,c=h.column-this.nodeMinColumnSpace(h,!0),f=h.column+this.nodeMinColumnSpace(h,!1);c<=t&&f>=t&&(n[h.layer]=!0),c<=i&&f>=i&&(o[h.layer]=!0)}let l=!0,a=!1;for(s=0;s<=this._;s++)l=l&&!(n[s]&&o[s]);if(l){if(e>0)for(r.reset();r.next();){const h=r.value;h.column>t&&(h.column-=1,a=!0)}if(e<0)for(r.reset();r.next();){const h=r.value;h.column<t&&(h.column+=1,a=!0)}}return a}PF(t){this.q3();let e=0,i,s=0,n=0,o=0;if(t>0)for(e=0;e<=this.Bt;e++)for(i=this.ei(),s=this.Zk(!0),n=s+1;s<n;)n=s,this.SF(e,1),o=this.Zk(!0),o>s?this.os(i):o<s&&(s=o,i=this.ei());if(t<0)for(e=this.Bt;e>=0;e--)for(i=this.ei(),s=this.Zk(!0),n=s+1;s<n;)n=s,this.SF(e,-1),o=this.Zk(!0),o>s?this.os(i):o<s&&(s=o,i=this.ei());this.Sw()}SF(t,e){this.fn=0;const i=this.network.vertexes.iterator;for(;i.next();){const c=i.value;c.component=-1}if(e>0)for(i.reset();i.next();){const c=i.value;c.column-this.nodeMinColumnSpace(c,!0)<=t&&(c.component=this.fn)}if(e<0)for(i.reset();i.next();){const c=i.value;c.column+this.nodeMinColumnSpace(c,!1)>=t&&(c.component=this.fn)}for(this.fn++,i.reset();i.next();){const c=i.value;c.component===-1&&(this.dL(c,this.fn,-1,!0,!0),this.fn++)}let s=0;const n=[];for(s=0;s<this.fn*this.fn;s++)n[s]=!1;const o=[];for(s=0;s<(this._+1)*(this.Bt+1);s++)o[s]=-1;for(i.reset();i.next();){const c=i.value,f=c.layer,u=Math.max(0,c.column-this.nodeMinColumnSpace(c,!0)),d=Math.min(this.Bt,c.column+this.nodeMinColumnSpace(c,!1));for(let m=u;m<=d;m++)o[f*(this.Bt+1)+m]=c.component}for(let c=0;c<=this._;c++){if(e>0)for(let f=0;f<this.Bt;f++)o[c*(this.Bt+1)+f]!==-1&&o[c*(this.Bt+1)+f+1]!==-1&&o[c*(this.Bt+1)+f]!==o[c*(this.Bt+1)+f+1]&&(n[o[c*(this.Bt+1)+f]*this.fn+o[c*(this.Bt+1)+f+1]]=!0);if(e<0)for(let f=this.Bt;f>0;f--)o[c*(this.Bt+1)+f]!==-1&&o[c*(this.Bt+1)+f-1]!==-1&&o[c*(this.Bt+1)+f]!==o[c*(this.Bt+1)+f-1]&&(n[o[c*(this.Bt+1)+f]*this.fn+o[c*(this.Bt+1)+f-1]]=!0)}const r=[];for(s=0;s<this.fn;s++)r[s]=!0;const l=[];l.push(0);let a=0;for(;l.length!==0;)if(a=l[l.length-1],l.pop(),r[a])for(r[a]=!1,s=0;s<this.fn;s++)n[a*this.fn+s]&&l.splice(0,0,s);let h=!1;if(e>0)for(i.reset();i.next();){const c=i.value;r[c.component]&&(c.column-=1,h=!0)}if(e<0)for(i.reset();i.next();){const c=i.value;r[c.component]&&(c.column+=1,h=!0)}return h}Y3(){const t=U.ot(),e=this.mu.length;for(let u=0;u<=e;u++)t[u]=[];const i=this.network.vertexes.iterator;for(;i.next();){const u=i.value,d=e-u.layer,m=t[d];m[u.index]=u}const s=new GSet;this.J3(t,s);let n=null,o=null,r=null,l=null;const a=(this.Gn&1)!==0,h=(this.Gn&2)!==0,c=(this.Gn&4)!==0,f=(this.Gn&8)!==0;a&&(this.hl(t,s,!0),n=this.eP(t,!0,!1)),t.reverse(),c&&(this.hl(t,s,!1),r=this.eP(t,!1,!1));for(const u of t)u.reverse();f&&(this.hl(t,s,!1),l=this.eP(t,!1,!0)),t.reverse(),h&&(this.hl(t,s,!0),o=this.eP(t,!0,!0)),U.Z(t),this.$3(n,o,r,l),this.network.vertexes.each(u=>{const d=u,m=U.ot();a&&m.push(n.get(d)),h&&m.push(o.get(d)),c&&m.push(r.get(d)),f&&m.push(l.get(d)),m.sort((k,b)=>k-b);const g=m.length,p=Math.floor((g-1)/2),y=Math.ceil((g-1)/2),x=(m[p]+m[y])/2;U.Z(m),d.gi=x})}J3(t,e){const i=t.length;for(let s=1;s<i-1;s++){let n=0,o=0;const r=t[s],l=t[s+1];for(let a=0;o<l.length;a++){const h=l[a],c=this.Z3(h);if(a===l.length-1||c){let f=r.length-1;for(c&&(f=h.getProperSourceVertexes()[0].index);o<=a;){const d=l[o].getProperSourceEdges();for(const m of d){const p=m.fromVertex.index;(p<n||p>f)&&e.add(m)}o++}n=f}}}}Z3(t){if(t.node===null){const e=t.getProperSourceVertexes();if(e.length>0)return e[0].node===null}return!1}hl(t,e,i){this.Q3(t);for(const s of t){let n=-1;for(const o of s){const r=i?o.getProperSourceVertexes():o.getProperDestinationVertexes(),l=r.length;if(l>0){r.sort((h,c)=>h.qa-c.qa);const a=(l-1)/2;for(let h=Math.floor(a),c=Math.ceil(a);h<=c;h++)if(o.Yn===o){const f=r[h];let u;i?u=f.getDestinationEdge(o):u=o.getDestinationEdge(f),!e.has(u)&&n<f.qa&&(f.Yn=o,o.mc=f.mc,o.Yn=f.mc,n=f.qa)}}}}}Q3(t){for(let e=0;e<t.length;e++){const i=t[e];for(let s=0;s<i.length;s++){const n=i[s];n.mc=n,n.Yn=n,n.MF=e,n.qa=s}}}eP(t,e,i){const s=this.P===90||this.P===270;for(const o of t)for(const r of o)r.rs=r,r.yu=1/0,r.gi=NaN,r.Kn=0;this._3(t,e,i);for(const o of t)for(const r of o)r.mc===r&&this.NF(r,t);for(let o=0;o<t.length;o++){if(t[o].length<=0)continue;const r=t[o][0];if(r.rs===r){r.rs.yu===1/0&&(r.rs.yu=0);let l=o,a=0,h;do{for(h=t[l][a];h.Yn!==h.mc;)if(h=h.Yn,l++,h.qa>0){const c=this.CF(h,t),f=s?c.width:c.height,u=h.rs.yu+h.gi+h.Kn-(c.gi+c.Kn+f+this.columnSpacing);c.rs.yu=Math.min(c.rs.yu,u)}a=h.qa+1}while(l<t.length&&a<t[l].length&&h.rs===t[l][a].rs)}}const n=new GMap;for(const o of t)for(const r of o){r.gi=r.gi+r.rs.yu+r.Kn;const l=s?r.width:r.height;n.set(r,i?-r.gi-l:r.gi)}return n}_3(t,e,i){const s=this.P===90||this.P===270;for(const n of t)for(const o of n)if(o.mc===o){let r=0,l=o;for(;l.Yn!==o;){const a=l.Yn,h=s?l.width:l.height,c=s?a.width:a.height;let f,u,d,m;e?(d=l.getDestinationEdge(a),f=d.portFromPos,u=d.portToPos,d.link!==null&&(l.node&&l.node!==d.link.fromNode&&(f=s?l.focusX:l.focusY),a.node&&a.node!==d.link.toNode&&(u=s?a.focusX:a.focusY)),i?m=l.Kn+(h-f)-(c-u):m=l.Kn+f-u):(d=a.getDestinationEdge(l),f=d.portToPos,u=d.portFromPos,d.link!==null&&(l.node&&l.node!==d.link.toNode&&(f=s?l.focusX:l.focusY),a.node&&a.node!==d.link.fromNode&&(u=s?a.focusX:a.focusY)),i?m=l.Kn+(h-f)-(c-u):m=l.Kn+f-u),a.Kn=m,r=Math.min(r,m),l=l.Yn}l=o;do l.Kn=l.Kn-r,l=l.Yn;while(l!==o)}}NF(t,e){if(!isNaN(t.gi))return;t.gi=0;let i=t;do{if(i.qa>0){const s=this.CF(i,e),n=s.mc;this.NF(n,e),t.rs===t&&(t.rs=n.rs);const o=this.P===90||this.P===270?s.width:s.height;if(t.rs===n.rs){const r=n.gi+s.Kn+o-i.Kn+this.columnSpacing;t.gi=Math.max(t.gi,r)}}i=i.Yn}while(i!==t);for(;i.Yn!==t;)i=i.Yn,i.gi=t.gi,i.rs=t.rs}CF(t,e){const i=t.MF,s=t.qa;return s<1&&U.o("Could not determine previous vertex in layer"),e[i][s-1]}$3(...t){let e=-1;const i=U.ot(),s=U.ot();let n=1/0;for(let o=0;o<4;o++){if(!t[o])continue;const r=this.tU(t[o],i,s,o);r<n&&(e=o,n=r)}for(let o=0;o<4;o++){const r=t[o];if(!r)continue;const l=o===0||o===2?i[e]-i[o]:s[e]-s[o];l!==0&&r.each(a=>{r.set(a.key,a.value+l)})}U.Z(i),U.Z(s)}tU(t,e,i,s){if(!t||t.count===0)return e[s]=0,i[s]=0,1/0;let n=1/0,o=-1/0;return t.each(r=>{const l=r.key,a=r.value,h=this.P===90||this.P===270?l.width:l.height;a<n&&(n=a),a+h>o&&(o=a+h)}),e[s]=n,i[s]=o,o-n}commitLayout(){this.kw(),this.commitNodes(),this.pL(),this.isRouting&&this.commitLinks()}kw(){if(!this.setsPortSpots)return;const t=this._k(!0),e=this._k(!1),i=this.network.edges.iterator;for(;i.next();){const n=i.value.link;n!==null&&(n.fromSpot=t,n.toSpot=e)}}_k(t){return this.P===270?t?Spot.MiddleTop:Spot.MiddleBottom:this.P===90?t?Spot.MiddleBottom:Spot.MiddleTop:this.P===180?t?Spot.MiddleLeft:Spot.MiddleRight:t?Spot.MiddleRight:Spot.MiddleLeft}commitNodes(){this.zs.length!==this._+1&&(this.zs=new Float32Array(this._+1)),this.ms.length!==this._+1&&(this.ms=new Float32Array(this._+1)),this.ps.length!==this._+1&&(this.ps=new Float32Array(this._+1)),this.Rt.length!==this._+1&&(this.Rt=new Float32Array(this._+1));for(let d=0;d<=this._;d++)this.zs[d]=0,this.ms[d]=0,this.ps[d]=0,this.Rt[d]=0;const t=this.network.vertexes.iterator;for(;t.next();){const d=t.value,m=d.layer;this.zs[m]=Math.max(this.zs[m],this.nodeMinLayerSpace(d,!0)),this.ms[m]=Math.max(this.ms[m],this.nodeMinLayerSpace(d,!1))}let e=0;const i=this.Vs;for(let d=0;d<=this._;d++){let m=i;this.zs[d]+this.ms[d]<=0&&(m=0),d>0&&(e+=m/2),this.P===90||this.P===0?(e+=this.ms[d],this.ps[d]=e,e+=this.zs[d]):(e+=this.zs[d],this.ps[d]=e,e+=this.ms[d]),d<this._&&(e+=m/2),this.Rt[d]=e}const s=e,n=this.arrangementOrigin;for(let d=0;d<=this._;d++)this.P===270?this.ps[d]=n.y+this.ps[d]:this.P===90?(this.ps[d]=n.y+s-this.ps[d],this.Rt[d]=s-this.Rt[d]):this.P===180?this.ps[d]=n.x+this.ps[d]:(this.ps[d]=n.x+s-this.ps[d],this.Rt[d]=s-this.Rt[d]);const o=this.Gn!==0;t.reset();const r=this.P===270||this.P===90;let l=1/0,a=1/0,h=1/0,c=-1/0;for(;t.next();){const d=t.value,m=d.layer,g=d.column|0;let p=0,y=0;r?(p=n.x+this.ti*g,y=this.ps[m]):(p=this.ps[m],y=n.y+this.ti*g),d.centerX=p,d.centerY=y,o&&isFinite(d.gi)&&(r?d.node?d.x=n.x+d.gi:d.centerX=n.x+d.gi:d.node?d.y=n.y+d.gi:d.centerY=n.y+d.gi),l=Math.min(d.x,l),a=Math.min(d.y,a),r?(h=l,c=Math.max(c,d.bounds.right)):(h=a,c=Math.max(c,d.bounds.bottom))}this.uL=c-h;const f=n.x-l,u=n.y-a;for(this.fr=new Point(o&&r?0:f,o&&!r?0:u),t.reset();t.next();){const d=t.value;d.x+=f,d.y+=u,d.commit()}}pL(){let t=0;const e=this.Vs;for(let n=0;n<=this._;n++)t+=this.zs[n],t+=this.ms[n];t+=this._*e;const i=[],s=this.Gn!==0?this.uL:this.ti*this.Bt;for(let n=this.maxLayer;n>=0;n--)this.P===270?n===0?i.push(new Rect(0,0,s,Math.abs(this.Rt[0]))):i.push(new Rect(0,this.Rt[n-1],s,Math.abs(this.Rt[n-1]-this.Rt[n]))):this.P===90?n===0?i.push(new Rect(0,this.Rt[0],s,Math.abs(this.Rt[0]-t))):i.push(new Rect(0,this.Rt[n],s,Math.abs(this.Rt[n-1]-this.Rt[n]))):this.P===180?n===0?i.push(new Rect(0,0,Math.abs(this.Rt[0]),s)):i.push(new Rect(this.Rt[n-1],0,Math.abs(this.Rt[n-1]-this.Rt[n]),s)):n===0?i.push(new Rect(this.Rt[0],0,Math.abs(this.Rt[0]-t),s)):i.push(new Rect(this.Rt[n],0,Math.abs(this.Rt[n-1]-this.Rt[n]),s));this.commitLayers(i,this.fr)}commitLayers(t,e){}commitLinks(){const t=this.network.edges.iterator;let e=null;for(;t.next();)e=t.value.link,e!==null&&e.pointsCount>0&&(e.startRoute(),e.clearPoints(),e.commitRoute());for(t.reset();t.next();)e=t.value.link,e!==null&&e.updateRoute();for(t.reset();t.next();){const i=t.value;if(e=i.link,e===null||e.pointsCount===0)continue;e.startRoute();const s=e;let n=s.fromNode,o=s.toNode,r=s.fromPort,l=s.toPort;if(n!==null){const N=n.findVisibleNode();N!==null&&N!==n&&(n=N,r=N.port)}if(o!==null){const N=o.findVisibleNode();N!==null&&N!==o&&(o=N,l=N.port)}const a=e.computeSpot(!0,r),h=e.computeSpot(!1,l);let c=i.fromVertex,f=i.toVertex;if(i.valid){if(e.curve===9&&e.pointsCount===4)if(c.column===f.column&&this.alignOption===0){const N=e.getLinkPoint(n,r,a,!0,!1,o,l),T=e.getLinkPoint(o,l,h,!1,!1,n,r);N.isReal()||N.set(n.actualBounds.center),T.isReal()||T.set(o.actualBounds.center),e.clearPoints(),e.addPointAt(N.x,N.y),e.addPointAt((2*N.x+T.x)/3,(2*N.y+T.y)/3),e.addPointAt((N.x+2*T.x)/3,(N.y+2*T.y)/3),e.addPointAt(T.x,T.y)}else{let N=!1,T=!1;if(r!==null&&a===Spot.None&&(N=!0),l!==null&&h===Spot.None&&(T=!0),N||T){let A=null;N&&(A=e.getLinkPointFromPoint(n,r,r.getDocumentPoint(Spot.Center),e.getPoint(3),!0),A.isReal()||A.set(n.actualBounds.center),e.setPointAt(0,A.x,A.y));let D=null;if(T&&(D=e.getLinkPointFromPoint(o,l,l.getDocumentPoint(Spot.Center),e.getPoint(0),!1),D.isReal()||D.set(o.actualBounds.center),e.setPointAt(3,D.x,D.y)),A){const v=e.getPoint(2);e.setPointAt(1,(A.x*2+v.x)/3,(A.y*2+v.y)/3)}if(D){const v=e.getPoint(1);e.setPointAt(2,(D.x*2+v.x)/3,(D.y*2+v.y)/3)}}}e.commitRoute();continue}if(c.layer===f.layer){e.commitRoute();continue}let u=!1,d=!1;const m=this.Vs;let g=0,p=e.firstPickIndex+1;if(e.isOrthogonal)d=!0,g=e.pointsCount,g>4&&e.points.removeRange(2,g-3);else if(e.curve===9)u=!0,g=e.pointsCount,g>4&&e.points.removeRange(2,g-3),g===4&&(p=2);else{g=e.pointsCount;const N=a===Spot.None,T=h===Spot.None;g>2&&N&&T?e.points.removeRange(1,g-2):g>3&&N&&!T?e.points.removeRange(1,g-3):g>3&&!N&&T?e.points.removeRange(2,g-2):g>4&&!N&&!T&&e.points.removeRange(2,g-3)}let y,x,k=0,b=0,P=0,S=0,L=0,C=0,M=0;if(i.rev){let N=0;for(;f!==null&&c!==f;){y=null,x=null;const T=f.sourceEdges.iterator;for(;T.next();){const A=T.value;if(A.link===i.link&&(y=A.fromVertex,x=A.toVertex,y.node===null))break}if(y===null)break;if(y!==c)if(k=e.getPoint(p-1).x,b=e.getPoint(p-1).y,P=y.centerX,S=y.centerY,d)this.P===180||this.P===0?p===e.firstPickIndex+1?(e.insertPointAt(p++,k,b),e.insertPointAt(p++,k,S)):(x!==null?x.centerY:b)!==S&&(L=this.Rt[y.layer-1]+this.fr.x,e.insertPointAt(p++,L,b),e.insertPointAt(p++,L,S)):p===e.firstPickIndex+1?(e.insertPointAt(p++,k,b),e.insertPointAt(p++,P,b)):(x!==null?x.centerX:k)!==P&&(L=this.Rt[y.layer-1]+this.fr.y,e.insertPointAt(p++,k,L),e.insertPointAt(p++,P,L));else if(p===e.firstPickIndex+1)if(C=Math.max(10,this.zs[f.layer]),M=Math.max(10,this.ms[f.layer]),u)this.P===180?P<=f.bounds.x?(N=f.bounds.x,e.insertPointAt(p++,N-C,S),e.insertPointAt(p++,N,S),e.insertPointAt(p++,N+M,S)):(e.insertPointAt(p++,P-C,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P+M,S)):this.P===90?S>=f.bounds.bottom?(N=f.bounds.y+f.bounds.height,e.insertPointAt(p++,P,N+M),e.insertPointAt(p++,P,N),e.insertPointAt(p++,P,N-C)):(e.insertPointAt(p++,P,S+M),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S-C)):this.P===270?S<=f.bounds.y?(N=f.bounds.y,e.insertPointAt(p++,P,N-C),e.insertPointAt(p++,P,N),e.insertPointAt(p++,P,N+M)):(e.insertPointAt(p++,P,S-C),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S+M)):this.P===0&&(P>=f.bounds.right?(N=f.bounds.x+f.bounds.width,e.insertPointAt(p++,N+M,S),e.insertPointAt(p++,N,S),e.insertPointAt(p++,N-C,S)):(e.insertPointAt(p++,P+M,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P-C,S)));else{e.insertPointAt(p++,k,b);let A=0;this.P===180||this.P===0?((this.P===180?P>=f.bounds.right:P<=f.bounds.x)&&(A=(this.P===0?-C:M)/2),e.insertPointAt(p++,k+A,S)):((this.P===270?S>=f.bounds.bottom:S<=f.bounds.y)&&(A=(this.P===90?-C:M)/2),e.insertPointAt(p++,P,b+A)),e.insertPointAt(p++,P,S)}else C=Math.max(10,this.zs[y.layer]),M=Math.max(10,this.ms[y.layer]),u?this.P===180?(e.insertPointAt(p++,P-C-Math.max(10,m),S),e.insertPointAt(p++,Math.min(P-C+m/2,P),S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,Math.max(P+M-m/2,P),S),e.insertPointAt(p++,P+M+m,S)):this.P===90?(e.insertPointAt(p++,P,S+M+Math.max(10,m)),e.insertPointAt(p++,P,Math.max(S+M-m/2,S)),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,Math.min(S-C+m/2,S)),e.insertPointAt(p++,P,S-C-m)):this.P===270?(e.insertPointAt(p++,P,S-C-Math.max(10,m)),e.insertPointAt(p++,P,Math.min(S-C+m/2,S)),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,Math.max(S+M-m/2,S)),e.insertPointAt(p++,P,S+M+m)):(e.insertPointAt(p++,P+M+Math.max(10,m),S),e.insertPointAt(p++,Math.max(P+M-m/2,P),S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,Math.min(P-C+m/2,P),S),e.insertPointAt(p++,P-C-m,S)):(this.P===180||this.P===90||this.P,e.insertPointAt(p++,P,S));f=y}if(l===null||a!==Spot.None||d)if(k=e.getPoint(p-1).x,b=e.getPoint(p-1).y,P=e.getPoint(p).x,S=e.getPoint(p).y,d){const T=this.ms[c.layer];let A=0;this.P===180||this.P===0?(A=b,A>=c.bounds.y&&A<=c.bounds.bottom&&(this.P===180?P>=c.bounds.x:P<=c.bounds.right)&&(N=c.centerX+(this.P===180?-T:T),A<c.bounds.y+c.bounds.height/2?A=c.bounds.y-this.ti/2:A=c.bounds.bottom+this.ti/2,e.insertPointAt(p++,N,b),e.insertPointAt(p++,N,A)),e.insertPointAt(p++,P,A),e.insertPointAt(p++,P,S)):(A=k,A>=c.bounds.x&&A<=c.bounds.right&&(this.P===270?S>=c.bounds.y:S<=c.bounds.bottom)&&(N=c.centerY+(this.P===270?-T:T),A<c.bounds.x+c.bounds.width/2?A=c.bounds.x-this.ti/2:A=c.bounds.right+this.ti/2,e.insertPointAt(p++,k,N),e.insertPointAt(p++,A,N)),e.insertPointAt(p++,A,S),e.insertPointAt(p++,P,S))}else if(u)C=Math.max(10,this.zs[c.layer]),M=Math.max(10,this.ms[c.layer]),this.P===180&&P>=c.bounds.x?(N=c.bounds.x+c.bounds.width,e.setPointAt(p-2,N,b),e.setPointAt(p-1,N+M,b)):this.P===90&&S<=c.bounds.bottom?(N=c.bounds.y,e.setPointAt(p-2,k,N),e.setPointAt(p-1,k,N-C)):this.P===270&&S>=c.bounds.y?(N=c.bounds.y+c.bounds.height,e.setPointAt(p-2,k,N),e.setPointAt(p-1,k,N+M)):this.P===0&&P<=c.bounds.right&&(N=c.bounds.x,e.setPointAt(p-2,N,b),e.setPointAt(p-1,N-C,b));else{C=Math.max(10,this.zs[c.layer]),M=Math.max(10,this.ms[c.layer]);let T=0;this.P===180||this.P===0?((this.P===180?P<=c.bounds.x:P>=c.bounds.right)&&(T=(this.P===0?M:-C)/2),e.insertPointAt(p++,P+T,b)):((this.P===270?S<=c.bounds.y:S>=c.bounds.bottom)&&(T=(this.P===90?M:-C)/2),e.insertPointAt(p++,k,S+T)),e.insertPointAt(p++,P,S)}}else{for(;c!==null&&c!==f;){y=null,x=null;const N=c.destinationEdges.iterator;for(;N.next();){const T=N.value;if(T.link===i.link&&(y=T.toVertex,x=T.fromVertex,x.node!==null&&(x=null),y.node===null))break}if(y===null)break;y!==f&&(k=e.getPoint(p-1).x,b=e.getPoint(p-1).y,P=y.centerX,S=y.centerY,d?this.P===180||this.P===0?(x!==null?x.centerY:b)!==S&&(L=this.Rt[y.layer]+this.fr.x,p===e.firstPickIndex+1&&(this.P===0?L=Math.max(L,k):L=Math.min(L,k)),e.insertPointAt(p++,L,b),e.insertPointAt(p++,L,S)):(x!==null?x.centerX:k)!==P&&(L=this.Rt[y.layer]+this.fr.y,p===e.firstPickIndex+1&&(this.P===90?L=Math.max(L,b):L=Math.min(L,b)),e.insertPointAt(p++,k,L),e.insertPointAt(p++,P,L)):(C=Math.max(10,this.zs[y.layer]),M=Math.max(10,this.ms[y.layer]),u?this.P===180?(e.insertPointAt(p++,P+M+Math.max(10,m),S),e.insertPointAt(p++,Math.max(P+M-m/2,P),S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,Math.min(P-C+m/2,P),S),e.insertPointAt(p++,P-C-m,S)):this.P===90?(e.insertPointAt(p++,P,S-C-Math.max(10,m)),e.insertPointAt(p++,P,Math.min(S-C+m/2,S)),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,Math.max(S+M-m/2,S)),e.insertPointAt(p++,P,S+M+m)):this.P===270?(e.insertPointAt(p++,P,S+M+Math.max(10,m)),e.insertPointAt(p++,P,Math.max(S+M-m/2,S)),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,Math.min(S-C+m/2,S)),e.insertPointAt(p++,P,S-C-m)):(e.insertPointAt(p++,P-C-Math.max(10,m),S),e.insertPointAt(p++,Math.min(P-C+m/2,P),S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,P,S),e.insertPointAt(p++,Math.max(P+M-m/2,P),S),e.insertPointAt(p++,P+M+m,S)):this.P===180?(e.insertPointAt(p++,P+M,S),e.insertPointAt(p++,P-C,S)):this.P===90?(e.insertPointAt(p++,P,S-C),e.insertPointAt(p++,P,S+M)):this.P===270?(e.insertPointAt(p++,P,S+M),e.insertPointAt(p++,P,S-C)):(e.insertPointAt(p++,P-C,S),e.insertPointAt(p++,P+M,S)))),c=y}d&&(k=e.getPoint(p-1).x,b=e.getPoint(p-1).y,P=e.getPoint(p).x,S=e.getPoint(p).y,this.P===180||this.P===0?b!==S&&(this.P===0?L=Math.min(Math.max((P+k)/2,this.Rt[f.layer]+this.fr.x),P):L=Math.max(Math.min((P+k)/2,this.Rt[f.layer]+this.fr.x),P),e.insertPointAt(p++,L,b),e.insertPointAt(p++,L,S)):k!==P&&(this.P===90?L=Math.min(Math.max((S+b)/2,this.Rt[f.layer]+this.fr.y),S):L=Math.max(Math.min((S+b)/2,this.Rt[f.layer]+this.fr.y),S),e.insertPointAt(p++,k,L),e.insertPointAt(p++,P,L)))}if(s!==null&&u&&e.pointsCount>=4){if(n!==null&&r!==null&&(a===Spot.None||s.Qh(a))){const N=r.getDocumentPoint(Spot.Center);N.isReal()||N.setTo(n.actualBounds.centerX,n.actualBounds.centerY);const T=e.getPoint(3),A=e.getLinkPointFromPoint(n,r,N,T,!0),D=e.getPoint(2);this.direction===90||this.direction===270?(e.setPointAt(1,(A.x+D.x)/2,D.y),e.setPointAt(2,T.x,(D.y+T.y)/2)):(e.setPointAt(1,D.x,(A.y+D.y)/2),e.setPointAt(2,(D.x+T.x)/2,T.y));const v=e.getLinkPointFromPoint(n,r,N,e.getPoint(1),!0);e.setPointAt(0,v.x,v.y)}if(o!==null&&l!==null&&(h===Spot.None||s.Qh(h))){const N=l.getDocumentPoint(Spot.Center);N.isReal()||N.setTo(o.actualBounds.centerX,o.actualBounds.centerY);const T=e.getPoint(e.pointsCount-4),A=e.getLinkPointFromPoint(o,l,N,T,!1),D=e.getPoint(e.pointsCount-3);this.direction===90||this.direction===270?(e.setPointAt(e.pointsCount-2,(A.x+D.x)/2,(D.y+A.y)/2),e.setPointAt(e.pointsCount-3,T.x,(D.y+A.y)/2)):(e.setPointAt(e.pointsCount-2,(D.x+A.x)/2,(A.y+D.y)/2),e.setPointAt(e.pointsCount-3,(D.x+A.x)/2,T.y));const v=e.getLinkPointFromPoint(o,l,N,e.getPoint(e.pointsCount-2),!1);e.setPointAt(e.pointsCount-1,v.x,v.y)}}e.commitRoute(),i.commit()}}S3(){this.Pw=-1,this.Hg=0,this.Bs=0,this.mu=null;for(let t=0;t<this.Xn.length;t++)this.Xn[t]=null}Ha(t){let e;const i=this.ie[t];if(i>=this.Xn.length){const n=[];for(let o=0;o<this.Xn.length;o++)n[o]=this.Xn[o];this.Xn=n}this.Xn[i]===void 0||this.Xn[i]===null?e=[]:(e=this.Xn[i],this.Xn[i]=null);const s=this.mu[t];for(let n=0;n<s.length;n++){const o=s[n];e[o.index]=o}return e}ja(t,e){this.Xn[this.ie[t]]=e}get layerSpacing(){return this.Vs}set layerSpacing(t){this.Vs!==t&&(U.s(t,"number",LayeredDigraphLayout,"layerSpacing"),t>=0&&(this.Vs=t,this.p()))}get columnSpacing(){return this.ti}set columnSpacing(t){this.ti!==t&&(U.s(t,"number",LayeredDigraphLayout,"columnSpacing"),t>0&&(this.ti=t,this.p()))}get direction(){return this.P}set direction(t){this.P!==t&&(U.s(t,"number",LayeredDigraphLayout,"direction"),t===0||t===90||t===180||t===270?(this.P=t,this.p()):U.o("LayeredDigraphLayout.direction must be 0, 90, 180, or 270"))}get cycleRemoveOption(){return this.cu}set cycleRemoveOption(t){this.cu!==t&&(t===1||t===0||t===2)&&(this.cu=t,this.p())}get layeringOption(){return this.fu}set layeringOption(t){this.fu!==t&&(t===10||t===11||t===12)&&(this.fu=t,this.p())}get initializeOption(){return this.uu}set initializeOption(t){this.uu!==t&&(t===20||t===21||t===22)&&(this.uu=t,this.p())}get iterations(){return this.gc}set iterations(t){this.gc!==t&&t>=0&&(this.gc=t,this.p())}get aggressiveOption(){return this.du}set aggressiveOption(t){this.du!==t&&(t===30||t===31||t===32)&&(this.du=t,this.p())}get packOption(){return this.cr}set packOption(t){this.cr!==t&&(U.s(t,"number",LayeredDigraphLayout,"packOption"),t>=0&&t<8&&(this.cr=t,this.p()))}get packIterations(){return this.gu}set packIterations(t){this.gu=t}get alignOption(){return this.Gn}set alignOption(t){this.Gn!==t&&(U.s(t,"number",LayeredDigraphLayout,"align"),t>=0&&t<16&&(this.Gn=t,this.p()))}get centered(){return this.Ka}set centered(t){this.centered!==t&&(U.s(t,"boolean",LayeredDigraphLayout,"centered"),this.Ka=t,this.p())}get setsPortSpots(){return this.zn}set setsPortSpots(t){this.zn!==t&&(U.s(t,"boolean",LayeredDigraphLayout,"setsPortSpots"),this.zn=t,this.p())}get maxLayer(){return this._}get maxIndex(){return this.Pw}get maxColumn(){return this.Bt}get minIndexLayer(){return this.Hg}get maxIndexLayer(){return this.Bs}static CycleDepthFirst=0;static CycleGreedy=1;static CycleFromLayers=2;static LayerOptimalLinkLength=10;static LayerLongestPathSink=11;static LayerLongestPathSource=12;static InitDepthFirstOut=20;static InitDepthFirstIn=21;static InitNaive=22;static AggressiveNone=30;static AggressiveLess=31;static AggressiveMore=32;static PackNone=0;static PackExpand=1;static PackStraighten=2;static PackMedian=4;static PackAll=15;static AlignNone=0;static AlignUpperLeft=1;static AlignUpperRight=2;static AlignLowerLeft=4;static AlignLowerRight=8;static AlignAll=15}class LayeredDigraphNetwork extends LayoutNetwork{constructor(t){super(t)}createVertex(){const t=new LayeredDigraphVertex(this);return t.centered=this.layout.centered,t}createEdge(){return new LayeredDigraphEdge(this)}}class LayeredDigraphVertex extends LayoutVertex{pl;pa;Tt;iP;sP;Ka;ii;pu;to;Qk;Jk;$k;mc;Yn;MF;qa;rs;yu;gi;Kn;Cw=null;Lw=null;Aw=null;Tw=null;constructor(t){super(t),this.pl=-1,this.pa=-1,this.Tt=-1,this.iP=NaN,this.sP=null,this.Ka=!0,this.ii=!1,this.pu=NaN,this.to=NaN,this.Qk=0,this.Jk=null,this.$k=null}static LF(t,e){return t.index-e.index}getProperSourceEdges(){if(!this.Aw){const t=[];for(const e of this.Mo){const i=e;i.valid&&t.push(i)}this.Aw=t}return this.Aw}getProperDestinationEdges(){if(!this.Tw){const t=[];for(const e of this.rr){const i=e;i.valid&&t.push(i)}this.Tw=t}return this.Tw}getDestinationEdge(t){const e=this.getProperDestinationEdges();for(const i of e)if(i.toVertex===t)return i;U.o("Unable to find destination edge to given vertex")}getProperSourceVertexes(){if(!this.Cw){const t=[];for(const e of this.Mo){const i=e;!i.valid||i.fromVertex.layer<=i.toVertex.layer||t.push(i.fromVertex)}t.sort(LayeredDigraphVertex.LF),this.Cw=t}return this.Cw}getProperDestinationVertexes(){if(!this.Lw){const t=[];for(const e of this.rr){const i=e;!i.valid||i.fromVertex.layer<=i.toVertex.layer||t.push(i.toVertex)}t.sort(LayeredDigraphVertex.LF),this.Lw=t}return this.Lw}addSourceEdge(t){super.addSourceEdge(t),this.Cw=null,this.Aw=null}deleteSourceEdge(t){super.deleteSourceEdge(t),this.Cw=null,this.Aw=null}addDestinationEdge(t){super.addDestinationEdge(t),this.Lw=null,this.Tw=null}deleteDestinationEdge(t){super.deleteDestinationEdge(t),this.Lw=null,this.Tw=null}commit(){if(this.centered)super.commit();else{const t=this.node;if(t!==null){const e=this.network.layout;if(!e)return;e.direction===180||e.direction===270?t.moveTo(this.bounds.right-t.actualBounds.width,this.bounds.bottom-t.actualBounds.height):t.moveTo(this.bounds.x,this.bounds.y)}}}get layer(){return this.pl}set layer(t){this.pl=t}get column(){return this.pa}set column(t){this.pa=t}get index(){return this.Tt}set index(t){this.Tt=t}get component(){return this.iP}set component(t){this.iP!==t&&(U.s(t,"number",LayeredDigraphVertex,"component"),this.iP=t)}get near(){return this.sP}set near(t){this.sP!==t&&(this.sP=t)}get centered(){return this.Ka}set centered(t){this.Ka=t}}class LayeredDigraphEdge extends LayoutEdge{ii;nP;oP;rP;lP;aP;hP;constructor(t){super(t),this.ii=!1,this.nP=!1,this.oP=!1,this.rP=NaN,this.lP=NaN,this.aP=0,this.hP=0}get fromVertex(){return this.ss}set fromVertex(t){this.ss!==t&&(this.ss=t)}get toVertex(){return this.ns}set toVertex(t){this.ns!==t&&(this.ns=t)}get valid(){return this.ii}set valid(t){this.ii!==t&&(U.s(t,"boolean",LayeredDigraphEdge,"valid"),this.ii=t)}get rev(){return this.nP}set rev(t){this.nP!==t&&(U.s(t,"boolean",LayeredDigraphEdge,"rev"),this.nP=t)}get forest(){return this.oP}set forest(t){this.oP!==t&&(U.s(t,"boolean",LayeredDigraphEdge,"forest"),this.oP=t)}get portFromPos(){return this.rP}set portFromPos(t){this.rP!==t&&(U.s(t,"number",LayeredDigraphEdge,"portFromPos"),this.rP=t)}get portToPos(){return this.lP}set portToPos(t){this.lP!==t&&(U.s(t,"number",LayeredDigraphEdge,"portToPos"),this.lP=t)}get portFromColOffset(){return this.aP}set portFromColOffset(t){this.aP!==t&&(U.s(t,"number",LayeredDigraphEdge,"portFromColOffset"),this.aP=t)}get portToColOffset(){return this.hP}set portToColOffset(t){this.hP!==t&&(U.s(t,"number",LayeredDigraphEdge,"portToColOffset"),this.hP=t)}}var TreePath=(w=>(w[w.Default=0]="Default",w[w.Destination=1]="Destination",w[w.Source=2]="Source",w))(TreePath||{}),TreeSorting=(w=>(w[w.Forwards=10]="Forwards",w[w.Reverse=11]="Reverse",w[w.Ascending=12]="Ascending",w[w.Descending=13]="Descending",w))(TreeSorting||{}),TreeAlignment=(w=>(w[w.CenterSubtrees=20]="CenterSubtrees",w[w.CenterChildren=21]="CenterChildren",w[w.Start=22]="Start",w[w.End=23]="End",w[w.Bus=24]="Bus",w[w.BusBranching=25]="BusBranching",w[w.TopLeftBus=26]="TopLeftBus",w[w.BottomRightBus=27]="BottomRightBus",w[w.Custom=28]="Custom",w))(TreeAlignment||{}),TreeCompaction=(w=>(w[w.None=30]="None",w[w.Block=31]="Block",w))(TreeCompaction||{}),TreeStyle=(w=>(w[w.Layered=40]="Layered",w[w.LastParents=41]="LastParents",w[w.Alternating=42]="Alternating",w[w.RootOnly=43]="RootOnly",w))(TreeStyle||{}),TreeArrangement=(w=>(w[w.Vertical=50]="Vertical",w[w.Horizontal=51]="Horizontal",w[w.FixedRoots=52]="FixedRoots",w))(TreeArrangement||{}),TreeLayerStyle=(w=>(w[w.Individual=60]="Individual",w[w.Siblings=61]="Siblings",w[w.Uniform=62]="Uniform",w))(TreeLayerStyle||{});class TreeLayout extends Layout{Ie;Fe;wu;Jg;yL;Xi;He;Us;V;B;cP;ws;constructor(t){super(),this.Ie=new GSet,this.Fe=0,this.ws=1,this.wu=40,this.Jg=60,this.yL=[],this.Xi=!0,this.He=50,this.Us=new Size(10,10).b();const e=new TreeNetwork(this);this.V=new TreeVertex(e),this.B=new TreeVertex(e),this.cP=[],t&&Object.assign(this,t)}cloneProtected(t){super.cloneProtected(t),t.Fe=this.Fe,t.wu=this.wu,t.Jg=this.Jg,t.Xi=this.Xi,t.He=this.He,t.Us.h(this.Us),t.V.copyInheritedPropertiesFrom(this.V),t.B.copyInheritedPropertiesFrom(this.B)}fe(t){t in TreeAlignment?this.alignment=t:t in TreeArrangement?this.arrangement=t:t in TreeCompaction?this.compaction=t:t in TreePath?this.path=t:t in TreeSorting?this.sorting=t:t in TreeStyle?this.treeStyle=t:super.fe(t)}createNetwork(){return new TreeNetwork(this)}makeNetwork(t){const e=this.createNetwork(),i=s=>{if(s instanceof Node)return!s.isLinkLabel&&s.category!=="Comment";if(s instanceof Link){const n=s.fromNode;if(n===null||n.isLinkLabel||n.category==="Comment")return!1;const o=s.toNode;return!(o===null||o.isLinkLabel||o.category==="Comment")}return!1};return t instanceof Diagram?(e.addParts(t.nodes,!0,i),e.addParts(t.links,!0,i)):t instanceof Group?e.addParts(t.memberParts,!1,i):e.addParts(t.iterator,!1,i),e}doLayout(t){this.network===null&&(this.network=this.makeNetwork(t)),this.arrangement!==52&&(this.arrangementOrigin=this.initialOrigin(this.arrangementOrigin));let e=this.diagram;e===null&&t instanceof Diagram&&(e=t),this.path===0&&e!==null?this.ws=e.isTreePathToChildren?1:2:this.ws=this.path===0?1:this.path,this.network.vertexes.count>0&&(this.oU(),this.rU(),this.lU(),this.aU(),this.fL(),this.hU(),this.arrangeTrees(),this.updateParts()),this.network=null,this.Ie=new GSet,this.isValidLayout=!0}oU(){if(this.network===null)return;this.network.deleteSelfEdges();const t=this.network.vertexes.iterator;for(;t.next();){const n=t.value;n.initialized=!1,n.level=0,n.parent=null,n.children=[]}if(this.Ie.count>0){const n=new GSet,o=this.Ie.iterator;for(;o.next();){const r=o.value;if(r instanceof Node){const l=this.network.findVertex(r);l!==null&&n.add(l)}else r instanceof TreeVertex&&n.add(r)}this.Ie=n}this.Ie.count===0&&this.findRoots();const e=this.Ie.copy().iterator;for(;e.next();){const n=e.value;n.initialized||(n.initialized=!0,this.wL(n))}let i=this.network.vertexes,s=null;for(;s=this.cU(i),s.count>0;){const n=this.AF(s);n!==null&&(this.Ie.add(n),n.initialized=!0,this.wL(n)),i=s}}cU(t){const e=new GSet,i=t.iterator;for(;i.next();){const s=i.value;s.initialized||e.add(s)}return e}findRoots(){if(this.network===null)return;const t=this.network.vertexes,e=t.iterator;for(;e.next();){const i=e.value;switch(this.ws){case 1:i.sourceEdges.count===0&&this.Ie.add(i);break;case 2:i.destinationEdges.count===0&&this.Ie.add(i);break;default:U.o("Unhandled path value "+this.ws.toString())}}if(this.Ie.count===0){const i=this.AF(t);i!==null&&this.Ie.add(i)}}AF(t){let e=999999,i=null;const s=t.iterator;for(;s.next();){const n=s.value;switch(this.ws){case 1:n.sourceEdges.count<e&&(e=n.sourceEdges.count,i=n);break;case 2:n.destinationEdges.count<e&&(e=n.destinationEdges.count,i=n);break;default:U.o("Unhandled path value "+this.ws.toString())}}return i}wL(t){if(t===null)return;switch(this.ws){case 1:if(t.destinationEdges.count>0){const s=new List,n=t.destinationVertexes;for(;n.next();){const o=n.value;this.TF(t,o)&&s.add(o)}s.count>0&&(t.children=s.toArray())}break;case 2:if(t.sourceEdges.count>0){const s=new List,n=t.sourceVertexes;for(;n.next();){const o=n.value;this.TF(t,o)&&s.add(o)}s.count>0&&(t.children=s.toArray())}break;default:U.o("Unhandled path value"+this.ws.toString())}const e=t.children,i=e.length;for(let s=0;s<i;s++){const n=e[s];n.initialized=!0,n.level=t.level+1,n.parent=t,this.Ie.delete(n)}for(let s=0;s<i;s++){const n=e[s];this.wL(n)}}TF(t,e){return e.initialized?this.fU(e,t)||e.level>t.level?!1:(this.uU(e.parent,e),!0):!0}fU(t,e){if(e===null)return!1;let i=e.parent;for(;i!==null&&i!==t;)i=i.parent;return i===t}uU(t,e){if(t===null||e===null)return;const i=t.children;let s=0;for(let n=0;n<i.length;n++)i[n]===e&&s++;if(s>0){const n=new Array(i.length-s);let o=0;for(let r=0;r<i.length;r++)i[r]!==e&&(n[o++]=i[r]);t.children=n}}rU(){const t=this.Ie.iterator;for(;t.next();){const e=t.value;e instanceof TreeVertex&&this.DF(e)}}DF(t){if(t===null)return;this.initializeTreeVertexValues(t),t.alignment===25&&this.sortTreeVertexChildren(t);let e=0,i=t.childrenCount,s=0;const n=t.children,o=n.length;for(let r=0;r<o;r++){const l=n[r];this.DF(l),e+=l.descendantCount+1,i=Math.max(i,l.maxChildrenCount),s=Math.max(s,l.maxGenerationCount)}t.descendantCount=e,t.maxChildrenCount=i,t.maxGenerationCount=i>0?s+1:0}dU(t){switch(this.wu){default:case 40:return t.parent!==null?t.parent:this.V;case 43:return t.parent===null?this.V:t.parent.parent===null?this.B:t.parent;case 42:return t.parent!==null?t.parent.parent!==null?t.parent.parent:this.B:this.V;case 41:{let e=!0;if(t.childrenCount===0)e=!1;else{const i=t.children,s=i.length;for(let n=0;n<s;n++)if(i[n].childrenCount>0){e=!1;break}}return e&&t.parent!==null?this.B:t.parent!==null?t.parent:this.V}}}initializeTreeVertexValues(t){const e=this.dU(t);if(t.copyInheritedPropertiesFrom(e),t.parent!==null&&t.parent.alignment===25){let i=t.angle;const s=t.parent.children;let n=0;for(;n<s.length&&t!==s[n];)n++;n%2===0?n!==s.length-1&&(i===90?i=180:i===180?i=270:i===270?i=180:i=270):i===90?i=0:i===180?i=90:i===270?i=0:i=90,t.angle=i}t.initialized=!0}lU(){const t=this.Ie.iterator;for(;t.next();){const e=t.value;e instanceof TreeVertex&&this.vF(e)}}vF(t){if(t===null)return;this.assignTreeVertexValues(t);const e=t.children,i=e.length;for(let s=0;s<i;s++){const n=e[s];this.vF(n)}}assignTreeVertexValues(t){}aU(){const t=this.Ie.iterator;for(;t.next();){const e=t.value;e instanceof TreeVertex&&this.FF(e)}}FF(t){if(t===null)return;t.alignment!==25&&this.sortTreeVertexChildren(t);const e=t.children,i=e.length;for(let s=0;s<i;s++){const n=e[s];this.FF(n)}}sortTreeVertexChildren(t){switch(t.sorting){default:case 10:break;case 11:t.children.reverse();break;case 12:t.children.sort(t.comparer);break;case 13:t.children.sort(t.comparer),t.children.reverse();break}}fL(){if(!this.comments||this.network===null)return;const t=this.network.vertexes.iterator;for(;t.next();){const e=t.value;this.addComments(e)}}addComments(t){const e=t.angle,i=t.parent;let s=0,n=21,o=!1;i!==null&&(s=i.angle,n=i.alignment,o=this.isBusAlignment(n));const r=e===90||e===270,l=s===90||s===270,a=t.childrenCount===0;let h=0,c=0,f=0;const u=t.commentSpacing;if(t.node!==null){const d=t.node.findNodesConnected();for(;d.next();){const m=d.value;if(m.category!=="Comment"||!m.canLayout())continue;t.comments===null&&(t.comments=[]),t.comments.push(m),m.ensureBounds();const g=m.measuredBounds;r&&!a||!o&&!l&&a||o&&l&&a?(h=Math.max(h,g.width),c+=g.height+Math.abs(f)):(h+=g.width+Math.abs(f),c=Math.max(c,g.height)),f=u}}if(t.comments!==null){r&&!a||!o&&!l&&a||o&&l&&a?(h+=Math.abs(t.commentMargin),c=Math.max(0,c-t.height)):(c+=Math.abs(t.commentMargin),h=Math.max(0,h-t.width));const d=Rect.z(0,0,t.bounds.width+h,t.bounds.height+c);t.bounds=d,Rect.i(d)}}isBusAlignment(t){return t===24||t===25||t===26||t===27}Dw(t){return t===24||t===25}xL(t){const e=t.parent;if(e!==null){const i=e.alignment;if(this.isBusAlignment(i))if(this.Dw(i)){const s=e.children;let n=0;for(;n<s.length&&t!==s[n];)n++;return n%2===0}else return i===26}return!1}layoutComments(t){if(t.comments!==null){const i=t.node.measuredBounds,s=t.parent,n=t.angle;let o=0,r=21,l=!1;s!==null&&(o=s.angle,r=s.alignment,l=this.isBusAlignment(r));const a=n===90||n===270,h=o===90||o===270,c=t.childrenCount===0,f=this.xL(t);let u=0;const d=t.comments,m=d.length,g=Point.l();for(let y=0;y<m;y++){const x=d[y],k=x.measuredBounds;if(a&&!c||!l&&!h&&c||l&&h&&c){if(o>135&&!l||h&&f)if(t.commentMargin>=0){g.e(t.bounds.x-t.commentMargin-k.width,t.bounds.y+u),x.move(g);const b=x.findLinksInto();for(;b.next();){const P=b.value;P.fromSpot=Spot.MiddleLeft,P.toSpot=Spot.MiddleRight}}else{g.e(t.bounds.x+t.focus.x*2-t.commentMargin,t.bounds.y+u),x.move(g);const b=x.findLinksInto();for(;b.next();){const P=b.value;P.fromSpot=Spot.MiddleRight,P.toSpot=Spot.MiddleLeft}}else if(t.commentMargin>=0){g.e(t.bounds.x+t.focus.x*2+t.commentMargin,t.bounds.y+u),x.move(g);const b=x.findLinksInto();for(;b.next();){const P=b.value;P.fromSpot=Spot.MiddleRight,P.toSpot=Spot.MiddleLeft}}else{g.e(t.bounds.x+t.commentMargin-k.width,t.bounds.y+u),x.move(g);const b=x.findLinksInto();for(;b.next();){const P=b.value;P.fromSpot=Spot.MiddleLeft,P.toSpot=Spot.MiddleRight}}t.commentSpacing>=0?u+=k.height+t.commentSpacing:u+=t.commentSpacing-k.height}else{if(o>135&&!l||!h&&f)if(t.commentMargin>=0){g.e(t.bounds.x+u,t.bounds.y-t.commentMargin-k.height),x.move(g);const b=x.findLinksInto();for(;b.next();){const P=b.value;P.fromSpot=Spot.MiddleTop,P.toSpot=Spot.MiddleBottom}}else{g.e(t.bounds.x+u,t.bounds.y+t.focus.y*2-t.commentMargin),x.move(g);const b=x.findLinksInto();for(;b.next();){const P=b.value;P.fromSpot=Spot.MiddleBottom,P.toSpot=Spot.MiddleTop}}else if(t.commentMargin>=0){g.e(t.bounds.x+u,t.bounds.y+t.focus.y*2+t.commentMargin),x.move(g);const b=x.findLinksInto();for(;b.next();){const P=b.value;P.fromSpot=Spot.MiddleBottom,P.toSpot=Spot.MiddleTop}}else{g.e(t.bounds.x+u,t.bounds.y+t.commentMargin-k.height),x.move(g);const b=x.findLinksInto();for(;b.next();){const P=b.value;P.fromSpot=Spot.MiddleTop,P.toSpot=Spot.MiddleBottom}}t.commentSpacing>=0?u+=k.width+t.commentSpacing:u+=t.commentSpacing-k.width}}Point.i(g);const p=u-t.commentSpacing-(a?i.height:i.width);if(this.ws===1){const y=t.destinationEdges;for(;y.next();){const k=y.value.link;k!==null&&!k.isAvoiding&&(k.fromEndSegmentLength=p>0?p:NaN)}}else{const y=t.sourceEdges;for(;y.next();){const k=y.value.link;k!==null&&!k.isAvoiding&&(k.toEndSegmentLength=p>0?p:NaN)}}}}hU(){if(this.network===null)return;if(this.layerStyle===62){const e=[];let i=this.network.vertexes.iterator;for(;i.next();){const s=i.value;let n=s.parent;n===null&&(n=s);const o=n.angle===0||n.angle===180;let r=e[s.level];r===void 0&&(r=0),e[s.level]=Math.max(r,o?s.width:s.height)}for(let s=0;s<e.length;s++)e[s]===void 0&&(e[s]=0);for(this.yL=e,i=this.network.vertexes.iterator;i.next();){const s=i.value;let n=s.parent;n===null&&(n=s),n.angle===0||n.angle===180?(n.angle===180&&(s.focusX+=e[s.level]-s.width),s.width=e[s.level]):(n.angle===270&&(s.focusY+=e[s.level]-s.height),s.height=e[s.level])}}else if(this.layerStyle===61){const e=this.network.vertexes.iterator;for(;e.next();){const i=e.value,s=i.angle===0||i.angle===180;let n=-1;for(let o=0;o<i.children.length;o++){const r=i.children[o];n=Math.max(n,s?r.width:r.height)}if(n>=0)for(let o=0;o<i.children.length;o++){const r=i.children[o];s?(i.angle===180&&(r.focusX+=n-r.width),r.width=n):(i.angle===270&&(r.focusY+=n-r.height),r.height=n)}}}const t=this.Ie.iterator;for(;t.next();){const e=t.value;e instanceof TreeVertex&&this.layoutTree(e)}}layoutTree(t){if(t===null)return;const e=t.children,i=e.length;for(let s=0;s<i;s++){const n=e[s];this.layoutTree(n)}switch(t.compaction){case 30:this.RF(t);break;default:case 31:t.alignment===25?this.RF(t):this.gU(t);break}}RF(t){if(t.childrenCount===0){let R=!1,F=0,O=21;t.parent!==null&&(F=t.parent.angle,O=t.parent.alignment,R=this.isBusAlignment(O));const z=this.xL(t);t.U.e(0,0),t.dt.e(t.width,t.height),t.parent!==null&&t.comments!==null&&((F===180||F===270)&&!R||z)?F===180&&!R||(F===90||F===270)&&z?t.at.e(t.width-t.focus.x*2,0):t.at.e(0,t.height-t.focus.y*2):t.at.e(0,0);return}const e=this.orthoAngle(t),i=e===90||e===270;let s=0;const n=t.children,o=n.length;for(let R=0;R<o;R++){const F=n[R];s=Math.max(s,i?F.dt.width:F.dt.height)}const r=t.alignment,l=r===22,a=r===23,h=this.isBusAlignment(r),c=Math.max(0,t.breadthLimit),f=this.computeLayerSpacing(t),u=t.nodeSpacing,d=this.computeNodeIndent(t),m=l||a?0:d/2,g=t.rowSpacing;let p=0;(l||a)&&(p=Math.max(0,t.rowIndent));const y=t.width,x=t.height;let k=0,b=0,P=0,S=0,L=0,C=0,M=0,N=0,T=0,A=0;if(h&&!this.Dw(r)&&e>135&&n.reverse(),this.Dw(r))if(o>1)for(let R=0;R<o;R++){const F=n[R],O=F.dt;R%2===0&&R!==o-1?T=Math.max(T,(i?O.width:O.height)+this.computeBusNodeSpacing(F)-u):R%2!==0&&(A=Math.max(A,(i?O.width:O.height)+this.computeBusNodeSpacing(F)-u))}else o===1&&(T=i?n[0].dt.width:n[0].dt.height);if(h)switch(r){case 24:case 25:const R=Rect.l();e<135?this.OF(t,n,T,A,k,b,R):this.IF(t,n,T,A,k,b,R),T=R.x,k=R.width,b=R.height,Rect.i(R);break;case 26:for(let F=0;F<o;F++){const O=n[F],z=O.dt,Y=M===0?0:g;i?(O.U.e(s-z.width,L+Y),k=Math.max(k,z.width),b=Math.max(b,L+Y+z.height),L+=Y+z.height):(O.U.e(S+Y,s-z.height),k=Math.max(k,S+Y+z.width),b=Math.max(b,z.height),S+=Y+z.width),M++}break;case 27:for(let F=0;F<o;F++){const O=n[F],z=O.dt,Y=M===0?0:g;i?(O.U.e(u/2+t.focus.x,L+Y),k=Math.max(k,z.width),b=Math.max(b,L+Y+z.height),L+=Y+z.height):(O.U.e(S+Y,u/2+t.focus.y),k=Math.max(k,S+Y+z.width),b=Math.max(b,z.height),S+=Y+z.width),M++}break}else for(let R=0;R<o;R++){const F=n[R],O=F.dt;if(i){c>0&&M>0&&S+u+O.width>c&&(S<s&&this.pc(t,r,s-S,0,N,R-1),C++,M=0,N=R,P=b,S=0,L=e>135?-b-g:b+g);const z=M===0?m:u;this.fP(F,0,L),F.U.e(S+z,L),k=Math.max(k,S+z+O.width),b=Math.max(b,P+(C===0?0:g)+O.height),S+=z+O.width}else{c>0&&M>0&&L+u+O.height>c&&(L<s&&this.pc(t,r,0,s-L,N,R-1),C++,M=0,N=R,P=k,L=0,S=e>135?-k-g:k+g);const z=M===0?m:u;this.fP(F,S,0),F.U.e(S,L+z),b=Math.max(b,L+z+O.height),k=Math.max(k,P+(C===0?0:g)+O.width),L+=z+O.height}M++}C>0&&(i?(b+=Math.max(0,f),S<k&&this.pc(t,r,k-S,0,N,o-1),p>0&&(a||this.xu(t,p,0,0,o-1),k+=p)):(k+=Math.max(0,f),L<b&&this.pc(t,r,0,b-L,N,o-1),p>0&&(a||this.xu(t,0,p,0,o-1),b+=p)));let D=0,v=0;switch(r){case 20:i?D+=k/2-t.focus.x-d/2:v+=b/2-t.focus.y-d/2;break;default:case 21:if(C>0)i?D+=k/2-t.focus.x-d/2:v+=b/2-t.focus.y-d/2;else{const F=o;if(i){const O=n[0].U.x+n[0].at.x,z=n[F-1].U.x+n[F-1].at.x+n[F-1].focus.x*2;D+=O+(z-O)/2-t.focus.x-d/2}else{const O=n[0].U.y+n[0].at.y,z=n[F-1].U.y+n[F-1].at.y+n[F-1].focus.y*2;v+=O+(z-O)/2-t.focus.y-d/2}}break;case 22:i?(D-=d,k+=d):(v-=d,b+=d);break;case 23:i?(D+=k-t.width+d,k+=d):(v+=b-t.height+d,b+=d);break;case 24:case 25:i?o>1?D+=T+u/2-t.focus.x:D+=n[0].focus.x-t.focus.x+n[0].at.x:o>1?v+=T+u/2-t.focus.y:v+=n[0].focus.y-t.focus.y+n[0].at.y;break;case 26:i?D+=k+u/2-t.focus.x:v+=b+u/2-t.focus.y;break;case 27:break;case 28:const R=this.customAlignment(t,D,v,k,b);D=R[0],v=R[1],k=R[2],b=R[3];break}for(let R=0;R<o;R++){const F=n[R];i?F.U.e(F.U.x+F.at.x-D,F.U.y+(e>135?(h?-b:-F.dt.height)+F.at.y-f:x+f+F.at.y)):F.U.e(F.U.x+(e>135?(h?-k:-F.dt.width)+F.at.x-f:y+f+F.at.x),F.U.y+F.at.y-v)}i?(k=this.bL(t,k,D),D<0&&(D=0),e>135&&(v+=b+f),b=Math.max(Math.max(b,x),b+x+f)):(e>135&&(D+=k+f),k=Math.max(Math.max(k,y),k+y+f),b=this.kL(t,b,v),v<0&&(v=0)),t.at.e(D,v),t.dt.e(k,b)}customAlignment(t,e,i,s,n){return[e,i,s,n]}OF(t,e,i,s,n,o,r){const l=e.length;if(l===0)return r.e(i,0,n,o),r;if(l===1){const y=e[0];return n=y.dt.width,o=y.dt.height,r.e(i,0,n,o),r}const a=t.nodeSpacing,h=t.rowSpacing,f=this.orthoAngle(t)===90;let u=0,d=0,m=0;for(let y=0;y<l;y++){if(y%2!==0||l>1&&y===l-1)continue;const x=e[y],k=x.dt,b=u===0?0:h;if(f){const P=this.computeBusNodeSpacing(x)-a;x.U.e(i-(k.width+P),m+b),n=Math.max(n,k.width+P),o=Math.max(o,m+b+k.height),m+=b+k.height}else{const P=this.computeBusNodeSpacing(x)-a;x.U.e(d+b,i-(k.height+P)),o=Math.max(o,k.height+P),n=Math.max(n,d+b+k.width),d+=b+k.width}u++}u=0;const g=d,p=m;f?(d=i+a,m=0):(d=0,m=i+a);for(let y=0;y<l;y++){if(y%2===0)continue;const x=e[y],k=x.dt,b=u===0?0:h;if(f){const P=this.computeBusNodeSpacing(x)-a;x.U.e(d+P,m+b),n=Math.max(n,d+k.width+P),o=Math.max(o,m+b+k.height),m+=b+k.height}else{const P=this.computeBusNodeSpacing(x)-a;x.U.e(d+b,m+P),n=Math.max(n,d+b+k.width),o=Math.max(o,m+k.height+P),d+=b+k.width}u++}if(l>1&&l%2===1){const y=e[l-1],x=y.dt,k=this.computeBusLastRowSpacing(y,f?Math.max(Math.abs(p),Math.abs(m)):Math.max(Math.abs(g),Math.abs(d)));if(f){y.U.e(i+a/2-y.focus.x-y.at.x,o+k);const b=i+a/2-y.focus.x-y.at.x;n=Math.max(n,b+x.width),b<0&&(n-=b),o=Math.max(o,Math.max(p,m)+k+x.height),y.U.x<0&&(i=this.uP(t,y.U.x,!1,i,a))}else{y.U.e(n+k,i+a/2-y.focus.y-y.at.y),n=Math.max(n,Math.max(g,d)+k+x.width);const b=i+a/2-y.focus.y-y.at.y;o=Math.max(o,b+x.height),b<0&&(o-=b),y.U.y<0&&(i=this.uP(t,y.U.y,!0,i,a))}}return r.e(i,0,n,o),r}IF(t,e,i,s,n,o,r){const l=e.length;if(l===0)return r.e(i,0,n,o),r;if(l===1){const y=e[0];return n=y.dt.width,o=y.dt.height,r.e(i,0,n,o),r}const a=t.nodeSpacing,h=t.rowSpacing,f=this.orthoAngle(t)===270;let u=0,d=0,m=0;for(let y=0;y<l;y++){if(y%2!==0||l>1&&y===l-1)continue;const x=e[y],k=x.dt,b=u===0?0:h;if(f){const P=this.computeBusNodeSpacing(x)-a;m-=b+k.height,x.U.e(i-(k.width+P),m),n=Math.max(n,k.width+P),o=Math.max(o,Math.abs(m))}else{const P=this.computeBusNodeSpacing(x)-a;d-=b+k.width,x.U.e(d,i-(k.height+P)),o=Math.max(o,k.height+P),n=Math.max(n,Math.abs(d))}u++}u=0;const g=d,p=m;f?(d=i+a,m=0):(d=0,m=i+a);for(let y=0;y<l;y++){if(y%2===0)continue;const x=e[y],k=x.dt,b=u===0?0:h;if(f){const P=this.computeBusNodeSpacing(x)-a;m-=b+k.height,x.U.e(d+P,m),n=Math.max(n,d+k.width+P),o=Math.max(o,Math.abs(m))}else{const P=this.computeBusNodeSpacing(x)-a;d-=b+k.width,x.U.e(d,m+P),o=Math.max(o,m+k.height+P),n=Math.max(n,Math.abs(d))}u++}if(l>1&&l%2===1){const y=e[l-1],x=y.dt,k=this.computeBusLastRowSpacing(y,f?Math.max(Math.abs(p),Math.abs(m)):Math.max(Math.abs(g),Math.abs(d)));if(f){y.U.e(i+a/2-y.focus.x-y.at.x,-o-x.height-k);const b=i+a/2-y.focus.x-y.at.x;n=Math.max(n,b+x.width),b<0&&(n-=b),o=Math.max(o,Math.abs(Math.min(p,m))+k+x.height),y.U.x<0&&(i=this.uP(t,y.U.x,!1,i,a))}else{y.U.e(-n-x.width-k,i+a/2-y.focus.y-y.at.y),n=Math.max(n,Math.abs(Math.min(g,d))+k+x.width);const b=i+a/2-y.focus.y-y.at.y;o=Math.max(o,b+x.height),b<0&&(o-=b),y.U.y<0&&(i=this.uP(t,y.U.y,!0,i,a))}}for(let y=0;y<l;y++){const x=e[y];f?x.U.e(x.U.x,x.U.y+o):x.U.e(x.U.x+n,x.U.y)}return r.e(i,0,n,o),r}computeBusNodeSpacing(t){return t.parent===null?0:t.parent.nodeSpacing}computeBusLastRowSpacing(t,e){return t.parent===null?0:t.parent.rowSpacing}uP(t,e,i,s,n){const o=t.children,r=o.length;for(let a=0;a<r;a++)i?o[a].U.e(o[a].U.x,o[a].U.y-e):o[a].U.e(o[a].U.x-e,o[a].U.y);const l=o[r-1];return Math.max(s,i?l.at.y+l.focus.y-n/2:l.at.x+l.focus.x-n/2)}bL(t,e,i){switch(t.alignment){case 21:case 20:let s=e;return i+t.width>s&&(s=i+t.width),i<0&&(s-=i),s;case 22:return t.width>e?t.width:e;case 23:return t.focus.x*2>e?t.width:e+t.width-t.focus.x*2;case 24:case 25:const n=Math.min(0,i),o=Math.max(e,i+t.width);return Math.max(t.width,o-n);case 26:return t.width-t.focus.x+t.nodeSpacing/2+e;case 27:return Math.max(t.width,t.focus.x+t.nodeSpacing/2+e);default:return e}}kL(t,e,i){switch(t.alignment){case 21:case 20:let s=e;return i+t.height>s&&(s=i+t.height),i<0&&(s-=i),s;case 22:return t.height>e?t.height:e;case 23:return t.focus.y*2>e?t.height:e+t.height-t.focus.y*2;case 24:case 25:const n=Math.min(0,i),o=Math.max(e,i+t.height);return Math.max(t.height,o-n);case 26:return t.height-t.focus.y+t.nodeSpacing/2+e;case 27:return Math.max(t.height,t.focus.y+t.nodeSpacing/2+e);default:return e}}PL(t,e,i){switch(t){case 20:e/=2,i/=2;break;case 21:e/=2,i/=2;break;case 22:e=0,i=0;break;case 23:break;default:U.o("Unhandled alignment value "+t.toString())}return new Point(e,i)}pc(t,e,i,s,n,o){const r=this.PL(e,i,s);this.xu(t,r.x,r.y,n,o)}xu(t,e,i,s,n){if(e===0&&i===0)return;const o=t.children;for(let r=s;r<=n;r++){const a=o[r].U;a.x+=e,a.y+=i}}fP(t,e,i){const s=t.parent;switch(this.ws){case 1:{const n=t.sourceEdges;for(;n.next();){const o=n.value;o.fromVertex===s&&o.relativePoint.e(e,i)}break}case 2:{const n=t.destinationEdges;for(;n.next();){const o=n.value;o.toVertex===s&&o.relativePoint.e(e,i)}break}default:U.o("Unhandled path value "+this.ws.toString())}}gU(t){if(t.childrenCount===0){const B=t.parent;let H=!1,j=0,W=21;B!==null&&(j=B.angle,W=B.alignment,H=this.isBusAlignment(W));const Z=this.xL(t);t.U.e(0,0),t.dt.e(t.width,t.height),t.parent!==null&&t.comments!==null&&((j===180||j===270)&&!H||Z)?j===180&&!H||(j===90||j===270)&&Z?t.at.e(t.width-t.focus.x*2,0):t.at.e(0,t.height-t.focus.y*2):t.at.e(0,0),t.$g=null,t.Zg=null;return}const e=this.orthoAngle(t),i=e===90||e===270;let s=0;const n=t.children,o=n.length;for(let B=0;B<o;B++){const H=n[B];s=Math.max(s,i?H.dt.width:H.dt.height)}const r=t.alignment,l=r===22,a=r===23,h=this.isBusAlignment(r),c=Math.max(0,t.breadthLimit),f=this.computeLayerSpacing(t),u=t.nodeSpacing,d=this.computeNodeIndent(t),m=t.rowSpacing;let g=0;(l||a)&&(g=Math.max(0,t.rowIndent));const p=t.width,y=t.height;let x=0,k=0,b=0,P=null,S=null,L=0,C=0,M=0,N=0,T=0,A=0,D=0,v=0,R=0;if(h&&!this.Dw(r)&&e>135&&n.reverse(),this.Dw(r))if(o>1)for(let B=0;B<o;B++)B%2===0&&B!==o-1?v=Math.max(v,i?n[B].dt.width:n[B].dt.height):B%2!==0&&(R=Math.max(R,i?n[B].dt.width:n[B].dt.height));else o===1&&(v=i?n[0].dt.width:n[0].dt.height);if(h){switch(r){case 24:const B=Rect.l();e<135?this.OF(t,n,v,R,x,k,B):this.IF(t,n,v,R,x,k,B),v=B.x,x=B.width,k=B.height,Rect.i(B);break;case 26:for(let H=0;H<o;H++){const j=n[H],W=j.dt,Z=A===0?0:m;i?(j.U.e(s-W.width,N+Z),x=Math.max(x,W.width),k=Math.max(k,N+Z+W.height),N+=Z+W.height):(j.U.e(M+Z,s-W.height),x=Math.max(x,M+Z+W.width),k=Math.max(k,W.height),M+=Z+W.width),A++}break;case 27:for(let H=0;H<o;H++){const j=n[H],W=j.dt,Z=A===0?0:m;i?(j.U.e(u/2+t.focus.x,N+Z),x=Math.max(x,W.width),k=Math.max(k,N+Z+W.height),N+=Z+W.height):(j.U.e(M+Z,u/2+t.focus.y),x=Math.max(x,M+Z+W.width),k=Math.max(k,W.height),M+=Z+W.width),A++}break}P=this.mi(2),S=this.mi(2),i?(P[0].e(0,0),P[1].e(0,k),S[0].e(x,0),S[1].e(x,k)):(P[0].e(0,0),P[1].e(x,0),S[0].e(0,k),S[1].e(x,k))}else for(let B=0;B<o;B++){const H=n[B],j=H.dt;if(i){c>0&&A>0&&M+u+j.width>c&&(M<s&&this.pc(t,r,s-M,0,D,B-1),T++,A=0,D=B,b=k,M=0,N=e>135?-k-m:k+m),this.fP(H,0,N);let W=0;if(A===0)P=H.$g,S=H.Zg,L=j.width,C=j.height,(P===null||S===null||e!==this.orthoAngle(H))&&(P=this.mi(2),S=this.mi(2),P[0].e(0,0),P[1].e(0,C),S[0].e(L,0),S[1].e(L,C));else{const Z=U.ot(),V=Rect.l();this.EF(t,H,P,S,L,C,Z,V),W=V.x,P=Z[0],S=Z[1],L=V.width,C=V.height,U.Z(Z),M<j.width&&W<0&&(this.xu(t,-W,0,D,B-1),this.dP(P,-W,0),this.dP(S,-W,0),W=0),Rect.i(V)}H.U.e(W,N),x=Math.max(x,L),k=Math.max(k,b+(T===0?0:m)+j.height),M=L}else{c>0&&A>0&&N+u+j.height>c&&(N<s&&this.pc(t,r,0,s-N,D,B-1),T++,A=0,D=B,b=x,N=0,M=e>135?-x-m:x+m),this.fP(H,M,0);let W=0;if(A===0)P=H.$g,S=H.Zg,L=j.width,C=j.height,(P===null||S===null||e!==this.orthoAngle(H))&&(P=this.mi(2),S=this.mi(2),P[0].e(0,0),P[1].e(L,0),S[0].e(0,C),S[1].e(L,C));else{const Z=U.ot(),V=Rect.l();this.EF(t,H,P,S,L,C,Z,V),W=V.x,P=Z[0],S=Z[1],L=V.width,C=V.height,U.Z(Z),N<j.height&&W<0&&(this.xu(t,0,-W,D,B-1),this.dP(P,0,-W),this.dP(S,0,-W),W=0),Rect.i(V)}H.U.e(M,W),k=Math.max(k,C),x=Math.max(x,b+(T===0?0:m)+j.width),N=C}A++}T>0&&(i?(k+=Math.max(0,f),M<x&&this.pc(t,r,x-M,0,D,o-1),g>0&&(a||this.xu(t,g,0,0,o-1),x+=g)):(x+=Math.max(0,f),N<k&&this.pc(t,r,0,k-N,D,o-1),g>0&&(a||this.xu(t,0,g,0,o-1),k+=g)));let F=0,O=0;switch(r){case 20:i?F+=x/2-t.focus.x-d/2:O+=k/2-t.focus.y-d/2;break;default:case 21:if(T>0)i?F+=x/2-t.focus.x-d/2:O+=k/2-t.focus.y-d/2;else{const H=o;if(i){const j=n[0].U.x+n[0].at.x,W=n[H-1].U.x+n[H-1].at.x+n[H-1].focus.x*2;F+=j+(W-j)/2-t.focus.x-d/2}else{const j=n[0].U.y+n[0].at.y,W=n[H-1].U.y+n[H-1].at.y+n[H-1].focus.y*2;O+=j+(W-j)/2-t.focus.y-d/2}}break;case 22:i?(F-=d,x+=d):(O-=d,k+=d);break;case 23:i?(F+=x-t.width+d,x+=d):(O+=k-t.height+d,k+=d);break;case 24:i?o>1?F+=v+u/2-t.focus.x:F+=n[0].focus.x-t.focus.x+n[0].at.x:o>1?O+=v+u/2-t.focus.y:O+=n[0].focus.y-t.focus.y+n[0].at.y;break;case 26:i?F+=x+u/2-t.focus.x:O+=k+u/2-t.focus.y;break;case 27:break;case 28:const B=this.customAlignment(t,F,O,x,k);F=B[0],O=B[1],x=B[2],k=B[3];break}for(let B=0;B<o;B++){const H=n[B];i?H.U.e(H.U.x+H.at.x-F,H.U.y+(e>135?(h?-k:-H.dt.height)+H.at.y-f:y+f+H.at.y)):H.U.e(H.U.x+(e>135?(h?-x:-H.dt.width)+H.at.x-f:p+f+H.at.x),H.U.y+H.at.y-O)}let z=0,Y=0;if(h)i?(x=this.bL(t,x,F),F<0&&(F=0),e>135&&(O+=k+f),k+=y+f,r===27&&(z+=u/2+t.focus.x),Y+=y+f):(e>135&&(F+=x+f),x+=p+f,k=this.kL(t,k,O),O<0&&(O=0),r===27&&(Y+=u/2+t.focus.y),z+=p+f);else if(i){if(t.comments===null){if(p>x){const B=this.PL(r,p-x,0);z=B.x,Y=B.y,x=p,F=0}}else x=this.bL(t,x,F);F<0&&(z-=F,F=0),e>135&&(O+=k+f),k=Math.max(Math.max(k,y),k+y+f),Y+=y+f}else{if(e>135&&(F+=x+f),x=Math.max(Math.max(x,p),x+p+f),t.comments===null){if(y>k){const B=this.PL(r,0,y-k);z=B.x,Y=B.y,k=y,O=0}}else k=this.kL(t,k,O);O<0&&(Y-=O,O=0),z+=p+f}let E,X;if(T>0)E=this.mi(4),X=this.mi(4),i?(E[2].e(0,y+f),E[3].e(E[2].x,k),X[2].e(x,E[2].y),X[3].e(X[2].x,E[3].y)):(E[2].e(p+f,0),E[3].e(x,E[2].y),X[2].e(E[2].x,k),X[3].e(E[3].x,X[2].y));else{E=this.mi(P.length+2),X=this.mi(S.length+2);for(let B=0;B<P.length;B++){const H=P[B];E[B+2].e(H.x+z,H.y+Y)}for(let B=0;B<S.length;B++){const H=S[B];X[B+2].e(H.x+z,H.y+Y)}}i?(E[0].e(F,0),E[1].e(E[0].x,y),E[2].y<E[1].y&&(E[2].x>E[0].x?E[2].h(E[1]):E[1].h(E[2])),E[3].y<E[2].y&&(E[3].x>E[0].x?E[3].h(E[2]):E[2].h(E[3])),X[0].e(F+p,0),X[1].e(X[0].x,y),X[2].y<X[1].y&&(X[2].x<X[0].x?X[2].h(X[1]):X[1].h(X[2])),X[3].y<X[2].y&&(X[3].x<X[0].x?X[3].h(X[2]):X[2].h(X[3])),E[2].y-=f/2,X[2].y-=f/2):(E[0].e(0,O),E[1].e(p,E[0].y),E[2].x<E[1].x&&(E[2].y>E[0].y?E[2].h(E[1]):E[1].h(E[2])),E[3].x<E[2].x&&(E[3].y>E[0].y?E[3].h(E[2]):E[2].h(E[3])),X[0].e(0,O+y),X[1].e(p,X[0].y),X[2].x<X[1].x&&(X[2].y<X[0].y?X[2].h(X[1]):X[1].h(X[2])),X[3].x<X[2].x&&(X[3].y<X[0].y?X[3].h(X[2]):X[2].h(X[3])),E[2].x-=f/2,X[2].x-=f/2),this.un(P),this.un(S),t.$g=E,t.Zg=X,t.at.e(F,O),t.dt.e(x,k)}dP(t,e,i){for(let s=0;s<t.length;s++){const n=t[s];n.x+=e,n.y+=i}}EF(t,e,i,s,n,o,r,l){const a=this.orthoAngle(t),h=a===90||a===270,c=t.nodeSpacing,f=i,u=s,d=n,m=o;let g=e.$g,p=e.Zg;const y=e.dt,x=h?Math.max(m,y.height):Math.max(d,y.width);if((g===null||a!==this.orthoAngle(e))&&(g=this.mi(2),p=this.mi(2),h?(g[0].e(0,0),g[1].e(0,y.height),p[0].e(y.width,0),p[1].e(p[0].x,g[1].y)):(g[0].e(0,0),g[1].e(y.width,0),p[0].e(0,y.height),p[1].e(g[1].x,p[0].y))),h){const k=d;let b=k-this.mU(u,g,k);return b+=c,i=this.pU(f,g,b),s=this.yU(u,p,b),n=Math.max(0,b)+y.width,o=x,this.un(f),this.un(g),this.un(u),this.un(p),r[0]=i,r[1]=s,l.e(b,0,n,o),l}else{const k=m;let b=k-this.wU(u,g,k);return b+=c,i=this.xU(f,g,b),s=this.bU(u,p,b),n=x,o=Math.max(0,b)+y.height,this.un(f),this.un(g),this.un(u),this.un(p),r[0]=i,r[1]=s,l.e(b,0,n,o),l}}xU(t,e,i){if(t===null||t.length<2||e===null||e.length<2)return null;const s=this.mi(t.length+e.length);let n=0,o=0,r=0;for(;o<e.length&&e[o].x<t[0].x;){const h=e[o++];s[r++].e(h.x,h.y+i)}for(;n<t.length;){const h=t[n++];s[r++].e(h.x,h.y)}const l=t[t.length-1].x;for(;o<e.length&&e[o].x<=l;)o++;for(;o<e.length&&e[o].x>l;){const h=e[o++];s[r++].e(h.x,h.y+i)}const a=this.mi(r);for(n=0;n<r;n++)a[n].h(s[n]);return this.un(s),a}pU(t,e,i){if(t===null||t.length<2||e===null||e.length<2)return null;const s=this.mi(t.length+e.length);let n=0,o=0,r=0;for(;o<e.length&&e[o].y<t[0].y;){const h=e[o++];s[r++].e(h.x+i,h.y)}for(;n<t.length;){const h=t[n++];s[r++].e(h.x,h.y)}const l=t[t.length-1].y;for(;o<e.length&&e[o].y<=l;)o++;for(;o<e.length&&e[o].y>l;){const h=e[o++];s[r++].e(h.x+i,h.y)}const a=this.mi(r);for(n=0;n<r;n++)a[n].h(s[n]);return this.un(s),a}bU(t,e,i){if(t===null||t.length<2||e===null||e.length<2)return null;const s=this.mi(t.length+e.length);let n=0,o=0,r=0;for(;n<t.length&&t[n].x<e[0].x;){const h=t[n++];s[r++].e(h.x,h.y)}for(;o<e.length;){const h=e[o++];s[r++].e(h.x,h.y+i)}const l=e[e.length-1].x;for(;n<t.length&&t[n].x<=l;)n++;for(;n<t.length&&t[n].x>l;){const h=t[n++];s[r++].e(h.x,h.y)}const a=this.mi(r);for(n=0;n<r;n++)a[n].h(s[n]);return this.un(s),a}yU(t,e,i){if(t===null||t.length<2||e===null||e.length<2)return null;const s=this.mi(t.length+e.length);let n=0,o=0,r=0;for(;n<t.length&&t[n].y<e[0].y;){const h=t[n++];s[r++].e(h.x,h.y)}for(;o<e.length;){const h=e[o++];s[r++].e(h.x+i,h.y)}const l=e[e.length-1].y;for(;n<t.length&&t[n].y<=l;)n++;for(;n<t.length&&t[n].y>l;){const h=t[n++];s[r++].e(h.x,h.y)}const a=this.mi(r);for(n=0;n<r;n++)a[n].h(s[n]);return this.un(s),a}wU(t,e,i){let s=9999999;if(t===null||t.length<2||e===null||e.length<2)return s;let n=0,o=0;for(;n<t.length&&o<e.length;){const r=t[n],l=e[o],a=l.x;let h=l.y;h+=i;let c=r;n+1<t.length&&(c=t[n+1]);let f=l,u=f.x,d=f.y;o+1<e.length&&(f=e[o+1],u=f.x,d=f.y,d+=i);let m=s;r.x===a?m=h-r.y:r.x>a&&r.x<u?m=h+(r.x-a)/(u-a)*(d-h)-r.y:a>r.x&&a<c.x&&(m=h-(r.y+(a-r.x)/(c.x-r.x)*(c.y-r.y))),m<s&&(s=m),c.x<=r.x?n++:u<=a?o++:(c.x<=u&&n++,u<=c.x&&o++)}return s}mU(t,e,i){let s=9999999;if(t===null||t.length<2||e===null||e.length<2)return s;let n=0,o=0;for(;n<t.length&&o<e.length;){const r=t[n],l=e[o];let a=l.x;const h=l.y;a+=i;let c=r;n+1<t.length&&(c=t[n+1]);let f=l,u=f.x,d=f.y;o+1<e.length&&(f=e[o+1],u=f.x,d=f.y,u+=i);let m=s;r.y===h?m=a-r.x:r.y>h&&r.y<d?m=a+(r.y-h)/(d-h)*(u-a)-r.x:h>r.y&&h<c.y&&(m=a-(r.x+(h-r.y)/(c.y-r.y)*(c.x-r.x))),m<s&&(s=m),c.y<=r.y?n++:d<=h?o++:(c.y<=d&&n++,d<=c.y&&o++)}return s}mi(t){const e=this.cP[t];if(e!==void 0){const s=e.pop();if(s!==void 0)return s}const i=[];for(let s=0;s<t;s++)i[s]=new Point;return i}un(t){if(!t)return;const e=t.length;let i=this.cP[e];i===void 0&&(i=[],this.cP[e]=i),i.push(t)}arrangeTrees(){if(this.He===52){const t=this.Ie.iterator;for(;t.next();){const e=t.value;if(!(e instanceof TreeVertex))continue;const i=e.node;if(i===null)continue;const s=i.position;let n=s.x,o=s.y;isFinite(n)||(n=0),isFinite(o)||(o=0),this.SL(e,n,o)}}else{const t=[],e=this.Ie.iterator;for(;e.next();){const o=e.value;o instanceof TreeVertex&&t.push(o)}switch(this.sorting){default:case 10:break;case 11:t.reverse();break;case 12:t.sort(this.comparer);break;case 13:t.sort(this.comparer),t.reverse();break}const i=this.arrangementOrigin;let s=i.x,n=i.y;for(let o=0;o<t.length;o++){const r=t[o];switch(this.SL(r,s+r.at.x,n+r.at.y),this.He){case 50:n+=r.dt.height+this.Us.height;break;default:case 51:s+=r.dt.width+this.Us.width;break}}}}SL(t,e,i){if(t===null)return;t.x=e,t.y=i;const s=t.children,n=s.length;for(let o=0;o<n;o++){const r=s[o];this.SL(r,e+r.U.x,i+r.U.y)}}commitLayout(){this.kw(),this.commitNodes(),this.pL(),this.isRouting&&this.commitLinks()}commitNodes(){if(this.network===null)return;const t=this.network.vertexes.iterator;for(;t.next();)t.value.commit();for(t.reset();t.next();){const e=t.value;this.layoutComments(e)}}pL(){if(this.network===null||this.layerStyle!==62)return;const t=this.yL,e=[];let i;const s=this.network.vertexes.iterator;for(;s.next();){const a=s.value;i===void 0?i=a.bounds.copy():i.unionRect(a.bounds);let h=e[a.level];h===void 0?h=this.computeLayerSpacing(a):h=Math.max(h,this.computeLayerSpacing(a)),e[a.level]=h}if(!i)return;for(let a=0;a<e.length;a++)e[a]===void 0&&(e[a]=0);let n;this.angle===90||this.angle===270?(i.inflate(this.nodeSpacing/2,this.layerSpacing),n=new Point(-this.nodeSpacing/2,-this.layerSpacing/2)):(i.inflate(this.layerSpacing,this.nodeSpacing/2),n=new Point(-this.layerSpacing/2,-this.nodeSpacing/2));const o=[],r=this.angle===90||this.angle===270?i.width:i.height;let l=0;if(this.angle===180||this.angle===270)for(let a=0;a<t.length;a++)l+=t[a]+e[a];for(let a=0;a<t.length;a++){const h=t[a]+e[a];this.angle===270?(l-=h,o.push(new Rect(0,l,r,h))):this.angle===90?(o.push(new Rect(0,l,r,h)),l+=h):this.angle===180?(l-=h,o.push(new Rect(l,0,h,r))):(o.push(new Rect(l,0,h,r)),l+=h)}this.commitLayers(o,n)}commitLayers(t,e){}commitLinks(){if(this.network===null)return;const t=this.network.edges.iterator;for(;t.next();)t.value.commit()}kw(){const t=this.Ie.iterator;for(;t.next();){const e=t.value;e instanceof TreeVertex&&this.UF(e)}}UF(t){if(t===null)return;this.setPortSpots(t);const e=t.children,i=e.length;for(let s=0;s<i;s++){const n=e[s];this.UF(n)}}setPortSpots(t){const e=t.alignment;if(this.isBusAlignment(e))this.kU(t,e);else{const i=this.orthoAngle(t);if(this.ws===1){const s=t.destinationEdges;for(;s.next();){const o=s.value.link;if(o!==null){if(t.setsPortSpot)if(t.portSpot.isDefault())switch(i){case 0:o.fromSpot=Spot.MiddleRight;break;case 90:o.fromSpot=Spot.MiddleBottom;break;case 180:o.fromSpot=Spot.MiddleLeft;break;default:o.fromSpot=Spot.MiddleTop;break}else o.fromSpot=t.portSpot;if(t.setsChildPortSpot)if(t.childPortSpot.isDefault())switch(i){case 0:o.toSpot=Spot.MiddleLeft;break;case 90:o.toSpot=Spot.MiddleTop;break;case 180:o.toSpot=Spot.MiddleRight;break;default:o.toSpot=Spot.MiddleBottom;break}else o.toSpot=t.childPortSpot}}}else{const s=t.sourceEdges;for(;s.next();){const o=s.value.link;if(o!==null){if(t.setsPortSpot)if(t.portSpot.isDefault())switch(i){case 0:o.toSpot=Spot.MiddleRight;break;case 90:o.toSpot=Spot.MiddleBottom;break;case 180:o.toSpot=Spot.MiddleLeft;break;default:o.toSpot=Spot.MiddleTop;break}else o.toSpot=t.portSpot;if(t.setsChildPortSpot)if(t.childPortSpot.isDefault())switch(i){case 0:o.fromSpot=Spot.MiddleLeft;break;case 90:o.fromSpot=Spot.MiddleTop;break;case 180:o.fromSpot=Spot.MiddleRight;break;default:o.fromSpot=Spot.MiddleBottom;break}else o.fromSpot=t.childPortSpot}}}}}kU(t,e){const i=this.ws===1,s=this.orthoAngle(t);let n;switch(s){case 0:n=Spot.MiddleRight;break;case 90:n=Spot.MiddleBottom;break;case 180:n=Spot.MiddleLeft;break;default:n=Spot.MiddleTop;break}const o=t.children,r=o.length;switch(e){case 24:case 25:{for(let l=0;l<r;l++){const a=o[l],h=(i?a.sourceEdges:a.destinationEdges).first();if(h===null)continue;const c=h.link;if(c!==null){let f=s===90||s===270?Spot.MiddleLeft:Spot.MiddleTop;if(r===1||l===r-1&&r%2===1)switch(s){case 0:f=Spot.MiddleLeft;break;case 90:f=Spot.MiddleTop;break;case 180:f=Spot.MiddleRight;break;default:f=Spot.MiddleBottom;break}else l%2===0&&(f=s===90||s===270?Spot.MiddleRight:Spot.MiddleBottom);i?(t.setsPortSpot&&(c.fromSpot=n),t.setsChildPortSpot&&(c.toSpot=f)):(t.setsPortSpot&&(c.fromSpot=f),t.setsChildPortSpot&&(c.toSpot=n))}}break}case 26:{const l=s===90||s===270?Spot.MiddleRight:Spot.MiddleBottom,a=i?t.destinationEdges:t.sourceEdges;for(;a.next();){const c=a.value.link;c!==null&&(i?(t.setsPortSpot&&(c.fromSpot=n),t.setsChildPortSpot&&(c.toSpot=l)):(t.setsPortSpot&&(c.fromSpot=l),t.setsChildPortSpot&&(c.toSpot=n)))}break}case 27:{const l=s===90||s===270?Spot.MiddleLeft:Spot.MiddleTop,a=i?t.destinationEdges:t.sourceEdges;for(;a.next();){const c=a.value.link;c!==null&&(i?(t.setsPortSpot&&(c.fromSpot=n),t.setsChildPortSpot&&(c.toSpot=l)):(t.setsPortSpot&&(c.fromSpot=l),t.setsChildPortSpot&&(c.toSpot=n)))}break}}}orthoAngle(t){const e=t.angle;return e<=45?0:e<=135?90:e<=225?180:e<=315?270:0}computeLayerSpacing(t){const e=this.orthoAngle(t),i=e===90||e===270;let s=t.layerSpacing;if(t.layerSpacingParentOverlap>0){const n=Math.min(1,t.layerSpacingParentOverlap);s-=i?t.height*n:t.width*n}return s<(i?-t.height:-t.width)&&(s=i?-t.height:-t.width),s}computeNodeIndent(t){const e=this.orthoAngle(t),i=e===90||e===270;let s=t.nodeIndent;if(t.nodeIndentPastParent>0){const n=Math.min(1,t.nodeIndentPastParent);s+=i?t.width*n:t.height*n}return s=Math.max(0,s),s}get roots(){return this.Ie}set roots(t){this.Ie!==t&&(this.Ie=t,this.p())}get path(){return this.Fe}set path(t){this.Fe!==t&&(this.Fe=t,this.p())}get treeStyle(){return this.wu}set treeStyle(t){this.wu!==t&&(t===40||t===42||t===41||t===43)&&(this.wu=t,this.p())}get layerStyle(){return this.Jg}set layerStyle(t){this.Jg!==t&&(t===60||t===61||t===62)&&(this.Jg=t,this.p())}get comments(){return this.Xi}set comments(t){this.Xi!==t&&(U.s(t,"boolean",TreeLayout,"comments"),this.Xi=t,this.p())}get arrangement(){return this.He}set arrangement(t){this.He!==t&&(t===50||t===51||t===52)&&(this.He=t,this.p())}get arrangementSpacing(){return this.Us}set arrangementSpacing(t){this.Us.equals(t)||(this.Us.h(t),this.p())}get rootDefaults(){return this.V}set rootDefaults(t){this.V!==t&&(this.V=t,this.p())}get alternateDefaults(){return this.B}set alternateDefaults(t){this.B!==t&&(this.B=t,this.p())}get sorting(){return this.V.sorting}set sorting(t){this.V.sorting!==t&&(this.V.sorting=t,this.p())}get comparer(){return this.V.comparer}set comparer(t){this.V.comparer!==t&&(U.S(t,TreeLayout,"comparer"),this.V.comparer=t,this.p())}get angle(){return this.V.angle}set angle(t){this.V.angle!==t&&(U.s(t,"number",TreeLayout,"angle"),t===0||t===90||t===180||t===270?(this.V.angle=t,this.p()):U.o("TreeLayout.angle must be 0, 90, 180, or 270"))}get alignment(){return this.V.alignment}set alignment(t){this.V.alignment!==t&&(this.V.alignment=t,this.p())}get nodeIndent(){return this.V.nodeIndent}set nodeIndent(t){this.V.nodeIndent!==t&&(U.s(t,"number",TreeLayout,"nodeIndent"),t>=0&&(this.V.nodeIndent=t,this.p()))}get nodeIndentPastParent(){return this.V.nodeIndentPastParent}set nodeIndentPastParent(t){this.V.nodeIndentPastParent!==t&&(U.s(t,"number",TreeLayout,"nodeIndentPastParent"),t>=0&&t<=1&&(this.V.nodeIndentPastParent=t,this.p()))}get nodeSpacing(){return this.V.nodeSpacing}set nodeSpacing(t){this.V.nodeSpacing!==t&&(U.s(t,"number",TreeLayout,"nodeSpacing"),this.V.nodeSpacing=t,this.p())}get layerSpacing(){return this.V.layerSpacing}set layerSpacing(t){this.V.layerSpacing!==t&&(U.s(t,"number",TreeLayout,"layerSpacing"),this.V.layerSpacing=t,this.p())}get layerSpacingParentOverlap(){return this.V.layerSpacingParentOverlap}set layerSpacingParentOverlap(t){this.V.layerSpacingParentOverlap!==t&&(U.s(t,"number",TreeLayout,"layerSpacingParentOverlap"),t>=0&&t<=1&&(this.V.layerSpacingParentOverlap=t,this.p()))}get compaction(){return this.V.compaction}set compaction(t){this.V.compaction!==t&&(t===30||t===31)&&(this.V.compaction=t,this.p())}get breadthLimit(){return this.V.breadthLimit}set breadthLimit(t){this.V.breadthLimit!==t&&(U.s(t,"number",TreeLayout,"breadthLimit"),t>=0&&(this.V.breadthLimit=t,this.p()))}get rowSpacing(){return this.V.rowSpacing}set rowSpacing(t){this.V.rowSpacing!==t&&(U.s(t,"number",TreeLayout,"rowSpacing"),this.V.rowSpacing=t,this.p())}get rowIndent(){return this.V.rowIndent}set rowIndent(t){this.V.rowIndent!==t&&(U.s(t,"number",TreeLayout,"rowIndent"),t>=0&&(this.V.rowIndent=t,this.p()))}get commentSpacing(){return this.V.commentSpacing}set commentSpacing(t){this.V.commentSpacing!==t&&(U.s(t,"number",TreeLayout,"commentSpacing"),this.V.commentSpacing=t,this.p())}get commentMargin(){return this.V.commentMargin}set commentMargin(t){this.V.commentMargin!==t&&(U.s(t,"number",TreeLayout,"commentMargin"),this.V.commentMargin=t,this.p())}get setsPortSpot(){return this.V.setsPortSpot}set setsPortSpot(t){this.V.setsPortSpot!==t&&(U.s(t,"boolean",TreeLayout,"setsPortSpot"),this.V.setsPortSpot=t,this.p())}get portSpot(){return this.V.portSpot}set portSpot(t){this.V.portSpot.equals(t)||(this.V.portSpot=t,this.p())}get setsChildPortSpot(){return this.V.setsChildPortSpot}set setsChildPortSpot(t){this.V.setsChildPortSpot!==t&&(U.s(t,"boolean",TreeLayout,"setsChildPortSpot"),this.V.setsChildPortSpot=t,this.p())}get childPortSpot(){return this.V.childPortSpot}set childPortSpot(t){this.V.childPortSpot.equals(t)||(this.V.childPortSpot=t,this.p())}get alternateSorting(){return this.B.sorting}set alternateSorting(t){this.B.sorting!==t&&(this.B.sorting=t,this.p())}get alternateComparer(){return this.B.comparer}set alternateComparer(t){this.B.comparer!==t&&(U.S(t,TreeLayout,"alternateComparer"),this.B.comparer=t,this.p())}get alternateAngle(){return this.B.angle}set alternateAngle(t){this.B.angle!==t&&(U.s(t,"number",TreeLayout,"alternateAngle"),(t===0||t===90||t===180||t===270)&&(this.B.angle=t,this.p()))}get alternateAlignment(){return this.B.alignment}set alternateAlignment(t){this.B.alignment!==t&&(this.B.alignment=t,this.p())}get alternateNodeIndent(){return this.B.nodeIndent}set alternateNodeIndent(t){this.B.nodeIndent!==t&&(U.s(t,"number",TreeLayout,"alternateNodeIndent"),t>=0&&(this.B.nodeIndent=t,this.p()))}get alternateNodeIndentPastParent(){return this.B.nodeIndentPastParent}set alternateNodeIndentPastParent(t){this.B.nodeIndentPastParent!==t&&(U.s(t,"number",TreeLayout,"alternateNodeIndentPastParent"),t>=0&&t<=1&&(this.B.nodeIndentPastParent=t,this.p()))}get alternateNodeSpacing(){return this.B.nodeSpacing}set alternateNodeSpacing(t){this.B.nodeSpacing!==t&&(U.s(t,"number",TreeLayout,"alternateNodeSpacing"),this.B.nodeSpacing=t,this.p())}get alternateLayerSpacing(){return this.B.layerSpacing}set alternateLayerSpacing(t){this.B.layerSpacing!==t&&(U.s(t,"number",TreeLayout,"alternateLayerSpacing"),this.B.layerSpacing=t,this.p())}get alternateLayerSpacingParentOverlap(){return this.B.layerSpacingParentOverlap}set alternateLayerSpacingParentOverlap(t){this.B.layerSpacingParentOverlap!==t&&(U.s(t,"number",TreeLayout,"alternateLayerSpacingParentOverlap"),t>=0&&t<=1&&(this.B.layerSpacingParentOverlap=t,this.p()))}get alternateCompaction(){return this.B.compaction}set alternateCompaction(t){this.B.compaction!==t&&(t===30||t===31)&&(this.B.compaction=t,this.p())}get alternateBreadthLimit(){return this.B.breadthLimit}set alternateBreadthLimit(t){this.B.breadthLimit!==t&&(U.s(t,"number",TreeLayout,"alternateBreadthLimit"),t>=0&&(this.B.breadthLimit=t,this.p()))}get alternateRowSpacing(){return this.B.rowSpacing}set alternateRowSpacing(t){this.B.rowSpacing!==t&&(U.s(t,"number",TreeLayout,"alternateRowSpacing"),this.B.rowSpacing=t,this.p())}get alternateRowIndent(){return this.B.rowIndent}set alternateRowIndent(t){this.B.rowIndent!==t&&(U.s(t,"number",TreeLayout,"alternateRowIndent"),t>=0&&(this.B.rowIndent=t,this.p()))}get alternateCommentSpacing(){return this.B.commentSpacing}set alternateCommentSpacing(t){this.B.commentSpacing!==t&&(U.s(t,"number",TreeLayout,"alternateCommentSpacing"),this.B.commentSpacing=t,this.p())}get alternateCommentMargin(){return this.B.commentMargin}set alternateCommentMargin(t){this.B.commentMargin!==t&&(U.s(t,"number",TreeLayout,"alternateCommentMargin"),this.B.commentMargin=t,this.p())}get alternateSetsPortSpot(){return this.B.setsPortSpot}set alternateSetsPortSpot(t){this.B.setsPortSpot!==t&&(U.s(t,"boolean",TreeLayout,"alternateSetsPortSpot"),this.B.setsPortSpot=t,this.p())}get alternatePortSpot(){return this.B.portSpot}set alternatePortSpot(t){this.B.portSpot.equals(t)||(this.B.portSpot=t,this.p())}get alternateSetsChildPortSpot(){return this.B.setsChildPortSpot}set alternateSetsChildPortSpot(t){this.B.setsChildPortSpot!==t&&(U.s(t,"boolean",TreeLayout,"alternateSetsChildPortSpot"),this.B.setsChildPortSpot=t,this.p())}get alternateChildPortSpot(){return this.B.childPortSpot}set alternateChildPortSpot(t){this.B.childPortSpot.equals(t)||(this.B.childPortSpot=t,this.p())}static PathDefault=0;static PathDestination=1;static PathSource=2;static SortingForwards=10;static SortingReverse=11;static SortingAscending=12;static SortingDescending=13;static AlignmentCenterSubtrees=20;static AlignmentCenterChildren=21;static AlignmentStart=22;static AlignmentEnd=23;static AlignmentBus=24;static AlignmentBusBranching=25;static AlignmentTopLeftBus=26;static AlignmentBottomRightBus=27;static CompactionNone=30;static CompactionBlock=31;static StyleLayered=40;static StyleLastParents=41;static StyleAlternating=42;static StyleRootOnly=43;static ArrangementVertical=50;static ArrangementHorizontal=51;static ArrangementFixedRoots=52;static LayerIndividual=60;static LayerSiblings=61;static LayerUniform=62}class TreeNetwork extends LayoutNetwork{constructor(t){super(t)}createVertex(){return new TreeVertex(this)}createEdge(){return new TreeEdge(this)}}class TreeVertex extends LayoutVertex{U;dt;at;gP;mP;pP;yP;wP;xP;bP;Xi;$g;Zg;Si;Mi;Xt;de;vw;Fw;Rw;Vs;Ow;Iw;Ew;Uw;Vw;Bw;zw;Xw;Gw;Yw;Kw;constructor(t){super(t),this.gP=!1,this.mP=null,this.pP=[],this.yP=0,this.wP=0,this.xP=0,this.bP=0,this.Xi=null,this.U=new Point(0,0),this.dt=new Size(0,0),this.at=new Point(0,0),this.$g=null,this.Zg=null,this.Si=10,this.Mi=LayoutVertex.standardComparer,this.Xt=0,this.de=21,this.vw=0,this.Fw=0,this.Rw=20,this.Vs=50,this.Ow=0,this.Iw=31,this.Ew=0,this.Uw=25,this.Vw=10,this.Bw=10,this.zw=20,this.Xw=!0,this.Gw=Spot.Default,this.Yw=!0,this.Kw=Spot.Default}copyInheritedPropertiesFrom(t){t!==null&&(this.Si=t.sorting,this.Mi=t.comparer,this.Xt=t.angle,this.de=t.alignment,this.vw=t.nodeIndent,this.Fw=t.nodeIndentPastParent,this.Rw=t.nodeSpacing,this.Vs=t.layerSpacing,this.Ow=t.layerSpacingParentOverlap,this.Iw=t.compaction,this.Ew=t.breadthLimit,this.Uw=t.rowSpacing,this.Vw=t.rowIndent,this.Bw=t.commentSpacing,this.zw=t.commentMargin,this.Xw=t.setsPortSpot,this.Gw=t.portSpot,this.Yw=t.setsChildPortSpot,this.Kw=t.childPortSpot)}get initialized(){return this.gP}set initialized(t){this.gP!==t&&(U.s(t,"boolean",TreeVertex,"initialized"),this.gP=t)}get parent(){return this.mP}set parent(t){this.mP!==t&&(this.mP=t)}get children(){return this.pP}set children(t){if(this.pP!==t){if(t!==null&&!Array.isArray(t)&&U.si(t,"Array",TreeVertex,"children:value"),t!==null){const e=t.length;for(let i=0;i<e;i++){const s=t[i]}}this.pP=t}}get level(){return this.yP}set level(t){this.yP!==t&&(U.s(t,"number",TreeVertex,"level"),this.yP=t)}get descendantCount(){return this.wP}set descendantCount(t){this.wP!==t&&(U.s(t,"number",TreeVertex,"descendantCount"),this.wP=t)}get maxChildrenCount(){return this.xP}set maxChildrenCount(t){this.xP!==t&&(U.s(t,"number",TreeVertex,"maxChildrenCount"),this.xP=t)}get maxGenerationCount(){return this.bP}set maxGenerationCount(t){this.bP!==t&&(U.s(t,"number",TreeVertex,"maxGenerationCount"),this.bP=t)}get comments(){return this.Xi}set comments(t){if(this.Xi!==t){if(t!==null&&!Array.isArray(t)&&U.si(t,"Array",TreeVertex,"comments:value"),t!==null){const e=t.length;for(let i=0;i<e;i++){const s=t[i]}}this.Xi=t}}get sorting(){return this.Si}set sorting(t){this.Si!==t&&(this.Si=t)}get comparer(){return this.Mi}set comparer(t){this.Mi!==t&&(U.S(t,TreeVertex,"comparer"),this.Mi=t)}get angle(){return this.Xt}set angle(t){this.Xt!==t&&(U.s(t,"number",TreeVertex,"angle"),this.Xt=t)}get alignment(){return this.de}set alignment(t){this.de!==t&&(this.de=t)}get nodeIndent(){return this.vw}set nodeIndent(t){this.vw!==t&&(U.s(t,"number",TreeVertex,"nodeIndent"),this.vw=t)}get nodeIndentPastParent(){return this.Fw}set nodeIndentPastParent(t){this.Fw!==t&&(U.s(t,"number",TreeVertex,"nodeIndentPastParent"),this.Fw=t)}get nodeSpacing(){return this.Rw}set nodeSpacing(t){this.Rw!==t&&(U.s(t,"number",TreeVertex,"nodeSpacing"),this.Rw=t)}get layerSpacing(){return this.Vs}set layerSpacing(t){this.Vs!==t&&(U.s(t,"number",TreeVertex,"layerSpacing"),this.Vs=t)}get layerSpacingParentOverlap(){return this.Ow}set layerSpacingParentOverlap(t){this.Ow!==t&&(U.s(t,"number",TreeVertex,"layerSpacingParentOverlap"),this.Ow=t)}get compaction(){return this.Iw}set compaction(t){this.Iw!==t&&(this.Iw=t)}get breadthLimit(){return this.Ew}set breadthLimit(t){this.Ew!==t&&(U.s(t,"number",TreeVertex,"breadthLimit"),this.Ew=t)}get rowSpacing(){return this.Uw}set rowSpacing(t){this.Uw!==t&&(U.s(t,"number",TreeVertex,"rowSpacing"),this.Uw=t)}get rowIndent(){return this.Vw}set rowIndent(t){this.Vw!==t&&(U.s(t,"number",TreeVertex,"rowIndent"),this.Vw=t)}get commentSpacing(){return this.Bw}set commentSpacing(t){this.Bw!==t&&(U.s(t,"number",TreeVertex,"commentSpacing"),this.Bw=t)}get commentMargin(){return this.zw}set commentMargin(t){this.zw!==t&&(U.s(t,"number",TreeVertex,"commentMargin"),this.zw=t)}get setsPortSpot(){return this.Xw}set setsPortSpot(t){this.Xw!==t&&(U.s(t,"boolean",TreeVertex,"setsPortSpot"),this.Xw=t)}get portSpot(){return this.Gw}set portSpot(t){this.Gw.equals(t)||(this.Gw=t)}get setsChildPortSpot(){return this.Yw}set setsChildPortSpot(t){this.Yw!==t&&(U.s(t,"boolean",TreeVertex,"setsChildPortSpot"),this.Yw=t)}get childPortSpot(){return this.Kw}set childPortSpot(t){this.Kw.equals(t)||(this.Kw=t)}get childrenCount(){return this.children.length}get relativePosition(){return this.U}set relativePosition(t){this.U.set(t)}get subtreeSize(){return this.dt}set subtreeSize(t){this.dt.set(t)}get subtreeOffset(){return this.at}set subtreeOffset(t){this.at.set(t)}}class TreeEdge extends LayoutEdge{kP;constructor(t){super(t),this.kP=new Point(0,0)}commit(){const t=this.link;if(t===null||t.isAvoiding)return;const e=this.network.layout;let i=null,s=null;switch(e.ws){case 1:i=this.fromVertex,s=this.toVertex;break;case 2:i=this.toVertex,s=this.fromVertex;break;default:U.o("Unhandled path value "+e.ws.toString())}if(i===null||s===null)return;const n=this.kP;if(n.x===0&&n.y===0){this.PU(i,s);return}const o=i.bounds,r=e.orthoAngle(i),l=e.computeLayerSpacing(i),a=i.rowSpacing;t.updateRoute();const h=t.curve===9,c=t.isOrthogonal;let f=0,u,d;if(t.startRoute(),c||h){for(f=2;t.pointsCount>4;)t.removePoint(2);u=t.getPoint(1),d=t.getPoint(2)}else{for(f=1;t.pointsCount>3;)t.removePoint(1);u=t.getPoint(0),d=t.getPoint(t.pointsCount-1)}const m=t.getPoint(t.pointsCount-1);let g=0;r===0?(i.alignment===23?(g=o.bottom+n.y,n.y===0&&u.y>m.y+i.rowIndent&&(g=Math.min(g,Math.max(u.y,g-e.computeNodeIndent(i))))):i.alignment===22?(g=o.top+n.y,n.y===0&&u.y<m.y-i.rowIndent&&(g=Math.max(g,Math.min(u.y,g+e.computeNodeIndent(i))))):g=o.y+o.height/2+n.y,h?(t.insertPointAt(f,u.x,g),f++,t.insertPointAt(f,o.right+l,g),f++,t.insertPointAt(f,o.right+l+(n.x-a)/3,g),f++,t.insertPointAt(f,o.right+l+(n.x-a)*2/3,g),f++,t.insertPointAt(f,o.right+l+(n.x-a),g),f++,t.insertPointAt(f,d.x,g),f++):(c&&(t.insertPointAt(f,o.right+l/2,u.y),f++),t.insertPointAt(f,o.right+l/2,g),f++,t.insertPointAt(f,o.right+l+n.x-(c?a/2:a),g),f++,c&&(t.insertPointAt(f,t.getPoint(f-1).x,d.y),f++))):r===90?(i.alignment===23?(g=o.right+n.x,n.x===0&&u.x>m.x+i.rowIndent&&(g=Math.min(g,Math.max(u.x,g-e.computeNodeIndent(i))))):i.alignment===22?(g=o.left+n.x,n.x===0&&u.x<m.x-i.rowIndent&&(g=Math.max(g,Math.min(u.x,g+e.computeNodeIndent(i))))):g=o.x+o.width/2+n.x,h?(t.insertPointAt(f,g,u.y),f++,t.insertPointAt(f,g,o.bottom+l),f++,t.insertPointAt(f,g,o.bottom+l+(n.y-a)/3),f++,t.insertPointAt(f,g,o.bottom+l+(n.y-a)*2/3),f++,t.insertPointAt(f,g,o.bottom+l+(n.y-a)),f++,t.insertPointAt(f,g,d.y),f++):(c&&(t.insertPointAt(f,u.x,o.bottom+l/2),f++),t.insertPointAt(f,g,o.bottom+l/2),f++,t.insertPointAt(f,g,o.bottom+l+n.y-(c?a/2:a)),f++,c&&(t.insertPointAt(f,d.x,t.getPoint(f-1).y),f++))):r===180?(i.alignment===23?(g=o.bottom+n.y,n.y===0&&u.y>m.y+i.rowIndent&&(g=Math.min(g,Math.max(u.y,g-e.computeNodeIndent(i))))):i.alignment===22?(g=o.top+n.y,n.y===0&&u.y<m.y-i.rowIndent&&(g=Math.max(g,Math.min(u.y,g+e.computeNodeIndent(i))))):g=o.y+o.height/2+n.y,h?(t.insertPointAt(f,u.x,g),f++,t.insertPointAt(f,o.left-l,g),f++,t.insertPointAt(f,o.left-l+(n.x+a)/3,g),f++,t.insertPointAt(f,o.left-l+(n.x+a)*2/3,g),f++,t.insertPointAt(f,o.left-l+(n.x+a),g),f++,t.insertPointAt(f,d.x,g),f++):(c&&(t.insertPointAt(f,o.left-l/2,u.y),f++),t.insertPointAt(f,o.left-l/2,g),f++,t.insertPointAt(f,o.left-l+n.x+(c?a/2:a),g),f++,c&&(t.insertPointAt(f,t.getPoint(f-1).x,d.y),f++))):r===270?(i.alignment===23?(g=o.right+n.x,n.x===0&&u.x>m.x+i.rowIndent&&(g=Math.min(g,Math.max(u.x,g-e.computeNodeIndent(i))))):i.alignment===22?(g=o.left+n.x,n.x===0&&u.x<m.x-i.rowIndent&&(g=Math.max(g,Math.min(u.x,g+e.computeNodeIndent(i))))):g=o.x+o.width/2+n.x,h?(t.insertPointAt(f,g,u.y),f++,t.insertPointAt(f,g,o.top-l),f++,t.insertPointAt(f,g,o.top-l+(n.y+a)/3),f++,t.insertPointAt(f,g,o.top-l+(n.y+a)*2/3),f++,t.insertPointAt(f,g,o.top-l+(n.y+a)),f++,t.insertPointAt(f,g,d.y),f++):(c&&(t.insertPointAt(f,u.x,o.top-l/2),f++),t.insertPointAt(f,g,o.top-l/2),f++,t.insertPointAt(f,g,o.top-l+n.y+(c?a/2:a)),f++,c&&(t.insertPointAt(f,d.x,t.getPoint(f-1).y),f++))):U.o("Invalid angle "+r),t.commitRoute()}PU(t,e){const i=this.link;if(i===null)return;const s=this.network.layout,n=s.orthoAngle(t),o=s.orthoAngle(e);if(n===o)return;const r=s.computeLayerSpacing(t),l=t.bounds,a=e.bounds;if(n===0&&a.left-l.right<r+1||n===90&&a.top-l.bottom<r+1||n===180&&l.left-a.right<r+1||n===270&&l.top-a.bottom<r+1)return;i.updateRoute();const h=i.curve===9,c=i.isOrthogonal,f=this.fromVertex,u=s.isBusAlignment(f.alignment);if(i.startRoute(),n===0){const d=l.right+r/2;if(h){if(i.pointsCount===4){const m=i.getPoint(3).y;i.setPointAt(1,d-20,i.getPoint(1).y),i.insertPointAt(2,d-20,m),i.insertPointAt(3,d,m),i.insertPointAt(4,d+20,m),i.setPointAt(5,i.getPoint(5).x,m)}}else c?u?i.setPointAt(3,i.getPoint(2).x,i.getPoint(4).y):i.pointsCount===6&&(i.setPointAt(2,d,i.getPoint(2).y),i.setPointAt(3,d,i.getPoint(3).y)):i.pointsCount===4?i.insertPointAt(2,d,i.getPoint(2).y):i.pointsCount===3?i.setPointAt(1,d,i.getPoint(2).y):i.pointsCount===2&&i.insertPointAt(1,d,i.getPoint(1).y)}else if(n===90){const d=l.bottom+r/2;if(h){if(i.pointsCount===4){const m=i.getPoint(3).x;i.setPointAt(1,i.getPoint(1).x,d-20),i.insertPointAt(2,m,d-20),i.insertPointAt(3,m,d),i.insertPointAt(4,m,d+20),i.setPointAt(5,m,i.getPoint(5).y)}}else c?u?i.setPointAt(3,i.getPoint(2).x,i.getPoint(4).y):i.pointsCount===6&&(i.setPointAt(2,i.getPoint(2).x,d),i.setPointAt(3,i.getPoint(3).x,d)):i.pointsCount===4?i.insertPointAt(2,i.getPoint(2).x,d):i.pointsCount===3?i.setPointAt(1,i.getPoint(2).x,d):i.pointsCount===2&&i.insertPointAt(1,i.getPoint(1).x,d)}else if(n===180){const d=l.left-r/2;if(h){if(i.pointsCount===4){const m=i.getPoint(3).y;i.setPointAt(1,d+20,i.getPoint(1).y),i.insertPointAt(2,d+20,m),i.insertPointAt(3,d,m),i.insertPointAt(4,d-20,m),i.setPointAt(5,i.getPoint(5).x,m)}}else c?u?i.setPointAt(3,i.getPoint(2).x,i.getPoint(4).y):i.pointsCount===6&&(i.setPointAt(2,d,i.getPoint(2).y),i.setPointAt(3,d,i.getPoint(3).y)):i.pointsCount===4?i.insertPointAt(2,d,i.getPoint(2).y):i.pointsCount===3?i.setPointAt(1,d,i.getPoint(2).y):i.pointsCount===2&&i.insertPointAt(1,d,i.getPoint(1).y)}else if(n===270){const d=l.top-r/2;if(h){if(i.pointsCount===4){const m=i.getPoint(3).x;i.setPointAt(1,i.getPoint(1).x,d+20),i.insertPointAt(2,m,d+20),i.insertPointAt(3,m,d),i.insertPointAt(4,m,d-20),i.setPointAt(5,m,i.getPoint(5).y)}}else c?u?i.setPointAt(3,i.getPoint(2).x,i.getPoint(4).y):i.pointsCount===6&&(i.setPointAt(2,i.getPoint(2).x,d),i.setPointAt(3,i.getPoint(3).x,d)):i.pointsCount===4?i.insertPointAt(2,i.getPoint(2).x,d):i.pointsCount===3?i.setPointAt(1,i.getPoint(2).x,d):i.pointsCount===2&&i.insertPointAt(1,i.getPoint(1).x,d)}i.commitRoute()}get fromVertex(){return this.ss}set fromVertex(t){this.ss!==t&&(this.ss=t)}get toVertex(){return this.ns}set toVertex(t){this.ns!==t&&(this.ns=t)}get relativePoint(){return this.kP}set relativePoint(t){this.kP.set(t)}}class Themes{constructor(){}static Light={colors:{text:"#0a0a0a",comment:"#ca8a04",link:"#0a0a0a",group:"#a3a3a344",outline:"#a3a3a3",selection:"#0ea5e9",div:"#fff",gridMinor:"#e5e5e5",gridMajor:"#a3a3a3",overviewBox:"#c026d3",tempLink:"#2563eb",tempPort:"#c026d3",adornmentFill:"#0ea5e9",adornmentStroke:"#1e40af",dragSelect:"#c026d3"},fonts:{normal:"10pt sans-serif",bold:"bold 12pt sans-serif"},numbers:{group:1,selection:3},margins:{group:new Margin(5)},arrowheads:{toArrow:"Standard"}};static Dark={colors:{text:"#f5f5f5",comment:"#facc15",link:"#f5f5f5",group:"#a3a3a388",outline:"#a3a3a3",selection:"#38bdf8",div:"#171717",gridMinor:"#262626",gridMajor:"#404040",overviewBox:"#e879f9",tempLink:"#60a5fa",tempPort:"#e879f9",adornmentFill:"#38bdf8",adornmentStroke:"#2563eb",dragSelect:"#e879f9"},fonts:{normal:"10pt sans-serif",bold:"bold 12pt sans-serif"},numbers:{group:1,selection:3},margins:{group:new Margin(5)},arrowheads:{toArrow:"Standard"}}}class ThemeManager{hs=new Set;bu=new GMap;PP="light";SP="light";MP=!1;ML=!0;Qg="light";VF=t=>{const e=t.matches?"dark":"light";e!==this.Qg&&(this.Qg=e,this.SP==="system"&&this.updateDiagrams())};constructor(t){t&&Object.assign(this,t),t?.themeMap||(this.bu.set("light",{colors:{...Themes.Light.colors},fonts:{...Themes.Light.fonts},numbers:{...Themes.Light.numbers},margins:{...Themes.Light.margins},arrowheads:{...Themes.Light.arrowheads}}),this.bu.set("dark",{colors:{...Themes.Dark.colors},fonts:{...Themes.Dark.fonts},numbers:{...Themes.Dark.numbers},margins:{...Themes.Dark.margins},arrowheads:{...Themes.Dark.arrowheads}})),root.matchMedia&&(this.Qg=root.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light")}get themeMap(){return this.bu}set themeMap(t){this.bu!==t&&(this.bu=t,this.updateDiagrams())}get defaultTheme(){return this.PP}set defaultTheme(t){this.PP!==t&&(U.s(t,"string",ThemeManager,"defaultTheme"),this.PP=t,this.updateDiagrams())}get currentTheme(){return this.SP}set currentTheme(t){this.SP!==t&&(U.s(t,"string",ThemeManager,"currentTheme"),this.SP=t,this.updateDiagrams())}get changesDivBackground(){return this.MP}set changesDivBackground(t){if(this.MP!==t&&(this.MP=t,t))for(const i of this.hs)i.setDivBackground(this.findValue("div","","fill")),i.T("ThemeChanged",this)}get readsCssVariables(){return this.ML}set readsCssVariables(t){this.ML!==t&&(this.ML=t,this.updateDiagrams())}get preferredColorScheme(){return this.Qg}addDiagram(t){return this.hs.add(t),this.NL(t),this}removeDiagram(t){return this.hs.delete(t),this.NL(t),this}tO(){this.hs.size===0&&root.matchMedia&&root.matchMedia("(prefers-color-scheme: dark)")?.addEventListener("change",this.VF)}eO(){this.hs.size===0&&root.matchMedia&&root.matchMedia("(prefers-color-scheme: dark)")?.removeEventListener("change",this.VF)}set(t,e){t===""&&(t=this.PP),t==="system"&&(t=this.Qg);let i=this.bu.get(t);return i?i=this.BF(i,e):i=e,this.bu.set(t,i),this.updateDiagrams(),this}findValue(t,e,i){return this.getValue(this.findTheme(this.currentTheme),t,e,i)||this.getValue(this.findTheme(this.defaultTheme),t,e,i)}getValue(t,e,i,s){if(!t)return;i==null&&(i="");let n=t;const o=l=>{if(n===void 0||l==="")return;if(typeof l=="number"||!(Array.isArray(l)||l.includes(".")))return n[l];const a=Array.isArray(l)?l:l.split(".");for(let h=0;h<a.length;h++){const c=a[h];if(c!==""&&(n=n[c],n===void 0))return}return n},r=()=>{if(!(i!==""&&(n=o(i),n===void 0)))return Array.isArray(n)&&typeof e=="number"?n=n[e%n.length]:n=o(e),n};if(n=r(),n===void 0&&typeof s=="string"&&s.length>0){let l=t.targetPropertyMap?.get(s);if(l?n=t[l]:(l=ThemeManager.SU.get(s),n=l?t[l]:t.colors),n=r(),n!==void 0)return n}return n}findTheme(t){return this.themeMap.get(t==="system"?this.Qg:t)}updateDiagrams(){for(const t of this.hs)this.NL(t)}NL(t){const e=t.skipsUndoManager;t.skipsUndoManager=!0,t.updateAllThemeBindings(),this.MP&&t.setDivBackground(this.findValue("div","","fill")),t.skipsUndoManager=e,t.T("ThemeChanged",this)}BF(t,e){for(const i in e)if(U.Hw(e,i))try{e[i]?.constructor===Object?t[i]=this.BF(t[i]??{},e[i]):t[i]=e[i]}catch{delete t[i]}return t}static SU=new Map([["background","colors"],["defaultColumnSeparatorStroke","colors"],["defaultRowSeparatorStroke","colors"],["shadowColor","colors"],["fill","colors"],["stroke","colors"],["font","fonts"],["angle","numbers"],["fromEndSegmentLength","numbers"],["fromShortLength","numbers"],["height","numbers"],["opacity","numbers"],["scale","numbers"],["toEndSegmentLength","numbers"],["toShortLength","numbers"],["width","numbers"],["defaultColumnSeparatorStrokeWidth","numbers"],["defaultRowSeparatorStrokeWidth","numbers"],["shadowBlur","numbers"],["corner","numbers"],["curviness","numbers"],["smoothness","numbers"],["parameter1","numbers"],["parameter2","numbers"],["strokeWidth","numbers"],["strokeDashOffset","numbers"],["maxLines","numbers"],["spacingAbove","numbers"],["spacingBelow","numbers"],["position","points"],["shadowOffset","points"],["desiredSize","sizes"],["maxSize","sizes"],["minSize","sizes"],["margin","margins"],["defaultSeparatorPadding","margins"],["padding","margins"],["alignment","spots"],["alignmentFocus","spots"],["fromSpot","spots"],["toSpot","spots"],["defaultAlignment","spots"],["spot1","spots"],["spot2","spots"],["verticalAlignment","spots"],["imageAlignment","spots"],["fromArrow","arrowheads"],["toArrow","arrowheads"]])}class Router{Pt;a;Be;Pl;constructor(){this.a=Diagram.Rm(),this.Pt="",this.Be=!0,this.Pl=!0}get name(){return this.Pt}set name(t){this.Pt=t}get isEnabled(){return this.Be}set isEnabled(t){this.Be=t}get isRealtime(){return this.Pl}set isRealtime(t){this.Pl=t}get diagram(){return this.a}set diagram(t){this.a!==t&&(this.a=t,t.Fl=!0,t.requestUpdate())}invalidateRouter(){this.a!==null&&(this.a.Fl=!0,this.a.requestUpdate())}canRoute(t){if(!this.isEnabled)return!1;const e=this.diagram;return!(e&&(!this.isRealtime&&e.Iu||e.animationManager.isTicking))}isRoutable(t,e){return!0}routeLinks(t,e){}toString(){return this.name!==""?this.name+" Router":U.Hn(this.constructor)}}class AvoidsNodesRouter extends Router{constructor(t){super(),this.name="AvoidsNodes",t&&Object.assign(this,t)}canRoute(t){return(t instanceof Diagram?t.rp:t.diagram?.rp)?super.canRoute(t):!1}isRoutable(t,e){return!(!t.isAvoiding||t.containingGroup!==(e instanceof Group?e:null)||t.toNode===null||t.fromNode===null||t.pointsCount<4)}routeLinks(t,e){const i=e instanceof Diagram?null:e,s=t.iterator,n=this.diagram.getPositions(!0,i,null);for(;s.next();){const o=s.value;if(!this.isRoutable(o,e))continue;o.startRoute();const r=o.pointsCount,l=o.getPoint(1),a=o.getPoint(r-2),h=o.fromNode.actualBounds.copy();h.inflate(Link.va,Link.va),h.unionPoint(o.getPoint(0));const c=o.toNode.actualBounds.copy();c.inflate(Link.va,Link.va),c.unionPoint(o.getPoint(r-1)),this.MU(o,h,c,n)&&this.NU(o,l,o.PC,a,o.SC,h,c,n),o.commitRoute()}}MU(t,e,i,s){const n=t.diagram,o=t.pointsCount;if(n===null||!t.fromNode||!t.toNode||t.fromNode===t.toNode||!t.layer||t.layer.isTemporary||e.containsPoint(t.getPoint(o-1))&&!t.toNode.isMemberOf(t.fromNode)||i.containsPoint(t.getPoint(0))&&!t.fromNode.isMemberOf(t.toNode)||!t.isOrthogonal)return!1;if(t.segmentIndex===17)return!0;const r=t.getPoint(1),l=t.getPoint(o-2),a=t.getPoint(2);if(!s.isUnoccupied(Math.min(r.x,a.x),Math.min(r.y,a.y),Math.abs(r.x-a.x),Math.abs(r.y-a.y)))return!0;for(let c=2;c<o-3;c++){const f=t.getPoint(c),u=t.getPoint(c+1);if(!s.isUnoccupied(Math.min(f.x,u.x),Math.min(f.y,u.y),Math.abs(f.x-u.x),Math.abs(f.y-u.y)))return!0}const h=t.getPoint(o-3);return!s.isUnoccupied(Math.min(h.x,l.x),Math.min(h.y,l.y),Math.abs(h.x-l.x),Math.abs(h.y-l.y))}NU(t,e,i,s,n,o,r,l){const a=t.diagram;if(a===null)return;const h=e,c=s;let f=Point.mn,u=Point.mn;if(a.isVirtualized){const g=l.bounds.copy(),p=t.getPoint(2),y=t.getPoint(t.pointsCount-3);g.inflate(-l.cellWidth,-l.cellHeight);const x=Point.l();l.sg(e.x,e.y)||(G.Cl(g.x,g.y,g.x+g.width,g.y+g.height,e.x,e.y,p.x,p.y,x)?(f=e=x.copy(),i=x.directionPoint(p)):G.Cl(g.x,g.y,g.x+g.width,g.y+g.height,p.x,p.y,y.x,y.y,x)?(f=e=x.copy(),i=x.directionPoint(y)):G.Cl(g.x,g.y,g.x+g.width,g.y+g.height,y.x,y.y,s.x,s.y,x)&&(f=e=x.copy(),i=x.directionPoint(s))),l.sg(s.x,s.y)||(G.Cl(g.x,g.y,g.x+g.width,g.y+g.height,s.x,s.y,y.x,y.y,x)?(u=s=x.copy(),n=y.directionPoint(x)):G.Cl(g.x,g.y,g.x+g.width,g.y+g.height,y.x,y.y,p.x,p.y,x)?(u=s=x.copy(),n=p.directionPoint(x)):G.Cl(g.x,g.y,g.x+g.width,g.y+g.height,p.x,p.y,e.x,e.y,x)&&(u=s=x.copy(),n=e.directionPoint(x))),Point.i(x)}const d=o.copy().unionRect(r);d.inflate(l.cellWidth*l.af,l.cellHeight*l.af),l.yv(e,i,s,n,d,!0);let m=l.bo(s.x,s.y);if(!l._y&&m>=PositionArray.ig&&(l.TT(),d.inflate(l.cellWidth*l.I2,l.cellHeight*l.E2),l.yv(e,i,s,n,d,!1),m=l.bo(s.x,s.y)),!l._y&&m<PositionArray.ig&&!l.GE(s.x,s.y)){t.points.removeRange(2,t.pointsCount-3),this.CL(t,l,s.x,s.y,n,!0);const g=0,p=90,y=180,x=270,k=t.getPoint(2);if(t.pointsCount<4)i===g||i===y?(k.x=e.x,k.y=s.y):(k.x=s.x,k.y=e.y),t.setPointAt(2,k.x,k.y),t.insertPointAt(3,k.x,k.y);else{const b=t.getPoint(3);if(i===g||i===y)if(G.u(k.x,b.x)){const P=i===g?Math.max(k.x,e.x):Math.min(k.x,e.x);t.setPointAt(2,P,e.y),t.setPointAt(3,P,b.y)}else G.u(k.y,b.y)?(Math.abs(e.y-k.y)<=l.cellHeight/2&&(t.setPointAt(2,k.x,e.y),t.setPointAt(3,b.x,e.y)),t.insertPointAt(2,k.x,e.y)):t.setPointAt(2,e.x,k.y);else if(i===p||i===x)if(G.u(k.y,b.y)){const P=i===p?Math.max(k.y,e.y):Math.min(k.y,e.y);t.setPointAt(2,e.x,P),t.setPointAt(3,b.x,P)}else G.u(k.x,b.x)?(Math.abs(e.x-k.x)<=l.cellWidth/2&&(t.setPointAt(2,e.x,k.y),t.setPointAt(3,e.x,b.y)),t.insertPointAt(2,e.x,k.y)):t.setPointAt(2,k.x,e.y)}if(f.isReal()){const b=t.getPoint(1),P=t.getPoint(2);b.x!==P.x&&b.y!==P.y?i===g||i===y?t.insertPointAt(2,b.x,P.y):t.insertPointAt(2,P.x,b.y):i===g||i===y?t.insertPointAt(2,h.x,f.y):t.insertPointAt(2,f.x,h.y)}u.isReal()&&(n===g||n===y?t.insertPointAt(t.pointsCount-2,c.x,u.y):t.insertPointAt(t.pointsCount-2,u.x,c.y))}}CL(t,e,i,s,n,o){const c=e.cellWidth,f=e.cellHeight;let u=e.bo(i,s),d=i,m=s,g=d,p=m;for(n===0?g+=c:n===90?p+=f:n===180?g-=c:p-=f,t.TC&&u>PositionArray.sc&&e.bo(g,p)!==u-1&&(e.bo(d-c,m)===u-1?(n=180,g=d-c,p=m):e.bo(d+c,m)===u-1?(n=0,g=d+c,p=m):e.bo(d,m-f)===u-1?(n=270,g=d,p=m-f):e.bo(d,m+f)===u-1&&(n=90,g=d,p=m+f));u>PositionArray.sc&&e.bo(g,p)===u-1;)d=g,m=p,n===0?g+=c:n===90?p+=f:n===180?g-=c:p-=f,u-=1;if(o?u>PositionArray.sc&&(n===180||n===0?d=Math.floor(d/c)*c+c/2:(n===90||n===270)&&(m=Math.floor(m/f)*f+f/2)):(d=Math.floor(d/c)*c+c/2,m=Math.floor(m/f)*f+f/2),u>PositionArray.sc){let y=n,x=d,k=m;if(n===0?(y=90,k+=f):n===90?(y=180,x-=c):n===180?(y=270,k-=f):n===270&&(y=0,x+=c),e.bo(x,k)===u-1)this.CL(t,e,x,k,y,!1);else{let P=d,S=m;n===0?(y=270,S-=f):n===90?(y=0,P+=c):n===180?(y=90,S+=f):n===270&&(y=180,P-=c),e.bo(P,S)===u-1&&this.CL(t,e,P,S,y,!1)}}t.insertPointAt(t.pointsCount-2,d,m)}}ToolManager.prototype.initializeStandardTools=function(){this.Jt("Action",new ActionTool,this.mouseDownTools),this.Jt("Relinking",new RelinkingTool,this.mouseDownTools),this.Jt("LinkReshaping",new LinkReshapingTool,this.mouseDownTools),this.Jt("Rotating",new RotatingTool,this.mouseDownTools),this.Jt("Resizing",new ResizingTool,this.mouseDownTools),this.Jt("Linking",new LinkingTool,this.mouseMoveTools),this.Jt("Dragging",new DraggingTool,this.mouseMoveTools),this.Jt("DragSelecting",new DragSelectingTool,this.mouseMoveTools),this.Jt("Panning",new PanningTool,this.mouseMoveTools),this.Jt("ContextMenu",new ContextMenuTool,this.mouseUpTools),this.Jt("TextEditing",new TextEditingTool,this.mouseUpTools),this.Jt("ClickCreating",new ClickCreatingTool,this.mouseUpTools),this.Jt("ClickSelecting",new ClickSelectingTool,this.mouseUpTools)};Diagram.d2("GraphLinksModel",GraphLinksPartManager);Diagram.d2("TreeModel",TreePartManager);const oldGo=root.go,go={get version(){return Diagram.version},Group,List,Set:GSet,Map:GMap,Point,Size,Rect,Margin,Spot,Geometry,PathFigure,PathSegment,InputEvent,DiagramEvent,ChangedEvent,Model,GraphLinksModel,TreeModel,Binding,ThemeBinding,Transaction,UndoManager,CommandHandler,Tool,DraggingTool,DraggingInfo,DraggingOptions,LinkingBaseTool,LinkingTool,RelinkingTool,LinkReshapingTool,ResizingTool,RotatingTool,ClickSelectingTool,ActionTool,ClickCreatingTool,HTMLInfo,ContextMenuTool,DragSelectingTool,PanningTool,TextEditingTool,ToolManager,Animation,AnimationManager,AnimationTrigger,Layer,Diagram,Palette,Overview,Brush,GraphObject,Panel,RowColumnDefinition,Shape,TextBlock,Picture,Part,Adornment,Node,Link,Placeholder,Layout,LayoutNetwork,LayoutVertex,LayoutEdge,GridLayout,PanelLayout,CircularLayout,CircularNetwork,CircularVertex,CircularEdge,ForceDirectedLayout,ForceDirectedNetwork,ForceDirectedVertex,ForceDirectedEdge,LayeredDigraphLayout,LayeredDigraphNetwork,LayeredDigraphVertex,LayeredDigraphEdge,TreeLayout,TreeNetwork,TreeVertex,TreeEdge,Themes,ThemeManager,Router,AnimationStyle,AutoScale,CycleMode,Flip,TextFormat,ImageStretch,LayoutConditions,LinkAdjusting,Curve,Routing,Orientation,TextOverflow,PortSpreading,ScrollMode,CollapsePolicy,Sizing,TriggerStart,Stretch,ViewboxStretch,Wrap,BrushType,ColorSpace,GeometryStretch,GeometryType,SegmentType,BindingMode,ChangeType,CircularArrangement,CircularDirection,CircularNodeDiameterFormula,CircularSorting,GridAlignment,GridArrangement,GridSorting,LayeredDigraphAggressive,LayeredDigraphAlign,LayeredDigraphCycleRemove,LayeredDigraphInit,LayeredDigraphLayering,LayeredDigraphPack,TreeAlignment,TreeArrangement,TreeCompaction,TreeLayerStyle,TreePath,TreeSorting,TreeStyle,GestureMode,LinkingDirection,ReshapingBehavior,TextEditingAccept,TextEditingStarting,TextEditingState,WheelMode};for(const w in go){const t=go[w];U.nt(t)&&t!==TextFormat&&(t.className=w)}U.$(oldGo)&&oldGo.version&&U.ne("WARNING: a `go` object on the root object is already defined.  "+("Debug"in oldGo?"debug ":"")+"version: "+oldGo.version+", replaced with version: "+go.version);Diagram.prototype.go=go;root.go=go;
})();


        export default (typeof global !== "undefined") ? global.go : self.go;
  export const go = (typeof global !== "undefined") ? global.go : self.go;
  export const Group = go.Group;
  export const List = go.List;
  const GSet = go.Set;
  export { GSet as Set };
  const GMap = go.Map;
  export { GMap as Map };
  export const Point = go.Point;
  export const Size = go.Size;
  export const Rect = go.Rect;
  export const Margin = go.Margin;
  export const Spot = go.Spot;
  export const Geometry = go.Geometry;
  export const PathFigure = go.PathFigure;
  export const PathSegment = go.PathSegment;
  export const InputEvent = go.InputEvent;
  export const DiagramEvent = go.DiagramEvent;
  export const ChangedEvent = go.ChangedEvent;
  export const Model = go.Model;
  export const GraphLinksModel = go.GraphLinksModel;
  export const TreeModel = go.TreeModel;
  export const Binding = go.Binding;
  export const ThemeBinding = go.ThemeBinding;
  export const Transaction = go.Transaction;
  export const UndoManager = go.UndoManager;
  export const CommandHandler = go.CommandHandler;
  export const Tool = go.Tool;
  export const DraggingTool = go.DraggingTool;
  export const DraggingInfo = go.DraggingInfo;
  export const DraggingOptions = go.DraggingOptions;
  export const LinkingBaseTool = go.LinkingBaseTool;
  export const LinkingTool = go.LinkingTool;
  export const RelinkingTool = go.RelinkingTool;
  export const LinkReshapingTool = go.LinkReshapingTool;
  export const ResizingTool = go.ResizingTool;
  export const RotatingTool = go.RotatingTool;
  export const ClickSelectingTool = go.ClickSelectingTool;
  export const ActionTool = go.ActionTool;
  export const ClickCreatingTool = go.ClickCreatingTool;
  export const HTMLInfo = go.HTMLInfo;
  export const ContextMenuTool = go.ContextMenuTool;
  export const DragSelectingTool = go.DragSelectingTool;
  export const PanningTool = go.PanningTool;
  export const TextEditingTool = go.TextEditingTool;
  export const ToolManager = go.ToolManager;
  export const Animation = go.Animation;
  export const AnimationManager = go.AnimationManager;
  export const AnimationTrigger = go.AnimationTrigger;
  export const Layer = go.Layer;
  export const Diagram = go.Diagram;
  export const Palette = go.Palette;
  export const Overview = go.Overview;
  export const Brush = go.Brush;
  export const GraphObject = go.GraphObject;
  export const Panel = go.Panel;
  export const RowColumnDefinition = go.RowColumnDefinition;
  export const Shape = go.Shape;
  export const TextBlock = go.TextBlock;
  export const Picture = go.Picture;
  export const Part = go.Part;
  export const Adornment = go.Adornment;
  export const Node = go.Node;
  export const Link = go.Link;
  export const Placeholder = go.Placeholder;
  export const Layout = go.Layout;
  export const LayoutNetwork = go.LayoutNetwork;
  export const LayoutVertex = go.LayoutVertex;
  export const LayoutEdge = go.LayoutEdge;
  export const GridLayout = go.GridLayout;
  export const PanelLayout = go.PanelLayout;
  export const CircularLayout = go.CircularLayout;
  export const CircularNetwork = go.CircularNetwork;
  export const CircularVertex = go.CircularVertex;
  export const CircularEdge = go.CircularEdge;
  export const ForceDirectedLayout = go.ForceDirectedLayout;
  export const ForceDirectedNetwork = go.ForceDirectedNetwork;
  export const ForceDirectedVertex = go.ForceDirectedVertex;
  export const ForceDirectedEdge = go.ForceDirectedEdge;
  export const LayeredDigraphLayout = go.LayeredDigraphLayout;
  export const LayeredDigraphNetwork = go.LayeredDigraphNetwork;
  export const LayeredDigraphVertex = go.LayeredDigraphVertex;
  export const LayeredDigraphEdge = go.LayeredDigraphEdge;
  export const TreeLayout = go.TreeLayout;
  export const TreeNetwork = go.TreeNetwork;
  export const TreeVertex = go.TreeVertex;
  export const TreeEdge = go.TreeEdge;
  export const Themes = go.Themes;
  export const ThemeManager = go.ThemeManager;
  export const Router = go.Router;
  export const version = go.version;

  export const AnimationStyle = go.AnimationStyle;
  export const AutoScale = go.AutoScale;
  export const Curve = go.Curve;
  export const CycleMode = go.CycleMode;
  export const Flip = go.Flip;
  export const ImageStretch = go.ImageStretch;
  export const LayoutConditions = go.LayoutConditions;
  export const LinkAdjusting = go.LinkAdjusting;
  export const Orientation = go.Orientation;
  export const PortSpreading = go.PortSpreading;
  export const Routing = go.Routing;
  export const ScrollMode = go.ScrollMode;
  export const CollapsePolicy = go.CollapsePolicy;
  export const Sizing = go.Sizing;
  export const TriggerStart = go.TriggerStart;
  export const Stretch = go.Stretch;
  export const TextFormat = go.TextFormat;
  export const TextOverflow = go.TextOverflow;
  export const ViewboxStretch = go.ViewboxStretch;
  export const Wrap = go.Wrap;
  export const BrushType = go.BrushType;
  export const ColorSpace = go.ColorSpace;
  export const GeometryStretch = go.GeometryStretch;
  export const GeometryType = go.GeometryType;
  export const SegmentType = go.SegmentType;
  export const BindingMode = go.BindingMode;
  export const ChangeType = go.ChangeType;
  export const CircularArrangement = go.CircularArrangement;
  export const CircularDirection = go.CircularDirection;
  export const CircularNodeDiameterFormula = go.CircularNodeDiameterFormula;
  export const CircularSorting = go.CircularSorting;
  export const GridAlignment = go.GridAlignment;
  export const GridArrangement = go.GridArrangement;
  export const GridSorting = go.GridSorting;
  export const LayeredDigraphAggressive = go.LayeredDigraphAggressive;
  export const LayeredDigraphAlign = go.LayeredDigraphAlign;
  export const LayeredDigraphCycleRemove = go.LayeredDigraphCycleRemove;
  export const LayeredDigraphInit = go.LayeredDigraphInit;
  export const LayeredDigraphLayering = go.LayeredDigraphLayering;
  export const LayeredDigraphPack = go.LayeredDigraphPack;
  export const TreeAlignment = go.TreeAlignment;
  export const TreeArrangement = go.TreeArrangement;
  export const TreeCompaction = go.TreeCompaction;
  export const TreeLayerStyle = go.TreeLayerStyle;
  export const TreePath = go.TreePath;
  export const TreeSorting = go.TreeSorting;
  export const TreeStyle = go.TreeStyle;
  export const GestureMode = go.GestureMode;
  export const LinkingDirection = go.LinkingDirection;
  export const ReshapingBehavior = go.ReshapingBehavior;
  export const TextEditingAccept = go.TextEditingAccept;
  export const TextEditingStarting = go.TextEditingStarting;
  export const TextEditingState = go.TextEditingState;
  export const WheelMode = go.WheelMode;
  