@gkd-kit/inspect 0.0.1763020669783 → 0.0.1768900570874
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/404.html +3 -5
- package/dist/assets/ActionCard.vue_vue_type_script_setup_true_lang-BKq24yyT.js +17 -0
- package/dist/assets/{ActionCard.vue_vue_type_script_setup_true_lang-c4Bz1EAG.js.map → ActionCard.vue_vue_type_script_setup_true_lang-BKq24yyT.js.map} +1 -1
- package/dist/assets/DevicePage-LsTFe71m.js +49 -0
- package/dist/assets/DevicePage-LsTFe71m.js.map +1 -0
- package/dist/assets/{HomePage-E0mzXM61.js → HomePage-Csw7C8jF.js} +6 -6
- package/dist/assets/HomePage-Csw7C8jF.js.map +1 -0
- package/dist/assets/ImportPage-RGB4LPNf.js +2 -0
- package/dist/assets/ImportPage-RGB4LPNf.js.map +1 -0
- package/dist/assets/{Input-CphJuG1P.js → Input-ByXBRWmO.js} +3 -3
- package/dist/assets/Input-ByXBRWmO.js.map +1 -0
- package/dist/assets/SelectorPage-17Z-Jk1F.js +2 -0
- package/dist/assets/SelectorPage-17Z-Jk1F.js.map +1 -0
- package/dist/assets/SnapshotPage-DTOyvcpZ.css +1 -0
- package/dist/assets/SnapshotPage-gqLV0Ajt.js +278 -0
- package/dist/assets/SnapshotPage-gqLV0Ajt.js.map +1 -0
- package/dist/assets/SvgPage-CGTHxB9M.js +2 -0
- package/dist/assets/SvgPage-CGTHxB9M.js.map +1 -0
- package/dist/assets/TrackGraph-S8eceX9R.js +134 -0
- package/dist/assets/TrackGraph-S8eceX9R.js.map +1 -0
- package/dist/assets/_404Page-9FO_quL4.js +2 -0
- package/dist/assets/_404Page-9FO_quL4.js.map +1 -0
- package/dist/assets/chunk-Cg4L9mG4.js +3 -0
- package/dist/assets/{chunk-BAaEznD1.js.map → chunk-Cg4L9mG4.js.map} +1 -1
- package/dist/assets/{dayjs.min-DuNYJr0r.js → dayjs.min-CSVABQRJ.js} +27 -27
- package/dist/assets/dayjs.min-CSVABQRJ.js.map +1 -0
- package/dist/assets/{error-_RWs3m0D.js → error-np4WIvmm.js} +7 -7
- package/dist/assets/{error-_RWs3m0D.js.map → error-np4WIvmm.js.map} +1 -1
- package/dist/assets/import-C0XCCThd.js +2 -0
- package/dist/assets/{import-DrACbIiM.js.map → import-C0XCCThd.js.map} +1 -1
- package/dist/assets/index-Br8FJwQH.css +1 -0
- package/dist/assets/index-jqB-Fx47.js +1002 -0
- package/dist/assets/index-jqB-Fx47.js.map +1 -0
- package/dist/assets/{index-B-Xsa1QT.js → index-xkPltE-0.js} +3 -3
- package/dist/assets/{index-B-Xsa1QT.js.map → index-xkPltE-0.js.map} +1 -1
- package/dist/assets/jszip.min-MMSrEo5_.js +3 -0
- package/dist/assets/{jszip.min-BhNhLAdm.js.map → jszip.min-MMSrEo5_.js.map} +1 -1
- package/dist/assets/{node-CmMmyrOc.js → node-CUVTs-TZ.js} +17 -17
- package/dist/assets/node-CUVTs-TZ.js.map +1 -0
- package/dist/assets/{snapshot-D3v3rjHS.js → snapshot-BR91A-ol.js} +3 -3
- package/dist/assets/snapshot-BR91A-ol.js.map +1 -0
- package/dist/assets/{table-Bw5_wWdT.js → table-Cd44ejmV.js} +2 -2
- package/dist/assets/{table-Bw5_wWdT.js.map → table-Cd44ejmV.js.map} +1 -1
- package/dist/assets/worker-NxeETyFs.js +10 -0
- package/dist/assets/{worker-DFsORLo-.js.map → worker-NxeETyFs.js.map} +1 -1
- package/dist/index.html +3 -5
- package/package.json +36 -35
- package/dist/assets/ActionCard.vue_vue_type_script_setup_true_lang-c4Bz1EAG.js +0 -17
- package/dist/assets/DevicePage-Ige4Guqi.js +0 -49
- package/dist/assets/DevicePage-Ige4Guqi.js.map +0 -1
- package/dist/assets/HomePage-E0mzXM61.js.map +0 -1
- package/dist/assets/ImportPage-g2umoobr.js +0 -2
- package/dist/assets/ImportPage-g2umoobr.js.map +0 -1
- package/dist/assets/Input-CphJuG1P.js.map +0 -1
- package/dist/assets/SelectorPage-CzhVFSr6.js +0 -2
- package/dist/assets/SelectorPage-CzhVFSr6.js.map +0 -1
- package/dist/assets/SnapshotPage-BP3BeJts.js +0 -278
- package/dist/assets/SnapshotPage-BP3BeJts.js.map +0 -1
- package/dist/assets/SnapshotPage-BrBfbf_-.css +0 -1
- package/dist/assets/SvgPage-CXP8w7TF.js +0 -2
- package/dist/assets/SvgPage-CXP8w7TF.js.map +0 -1
- package/dist/assets/TrackGraph-D9kV-p_-.js +0 -134
- package/dist/assets/TrackGraph-D9kV-p_-.js.map +0 -1
- package/dist/assets/_404Page-DedPS7Hc.js +0 -2
- package/dist/assets/_404Page-DedPS7Hc.js.map +0 -1
- package/dist/assets/chunk-BAaEznD1.js +0 -3
- package/dist/assets/dayjs.min-DuNYJr0r.js.map +0 -1
- package/dist/assets/import-DrACbIiM.js +0 -2
- package/dist/assets/index-CqH0IuEk.css +0 -1
- package/dist/assets/index-DGsSqDmi.js +0 -982
- package/dist/assets/index-DGsSqDmi.js.map +0 -1
- package/dist/assets/jszip.min-BhNhLAdm.js +0 -3
- package/dist/assets/node-CmMmyrOc.js.map +0 -1
- package/dist/assets/snapshot-D3v3rjHS.js.map +0 -1
- package/dist/assets/worker-DFsORLo-.js +0 -10
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import{S as Sf,y as d_,z as HU,A as GU,C as KU,D as zU,E as VU}from"./node-CUVTs-TZ.js";import{bP as Qh,cG as f_,b9 as nc,cF as H1,h as jU,av as WU,F as qU,D as pb,o as $U,s as uA,H as YU,Q as XU,aY as yb}from"./index-jqB-Fx47.js";import{t as ZU}from"./index-xkPltE-0.js";function JU(){}function eP(r,e,t,n){for(var i=r.length,a=t+-1;++a<i;)if(e(r[a],a,r))return a;return-1}function tP(r){return r!==r}function nP(r,e,t){for(var n=t-1,i=r.length;++n<i;)if(r[n]===e)return n;return-1}function rP(r,e,t){return e===e?nP(r,e,t):eP(r,tP,t)}function iP(r,e){var t=r==null?0:r.length;return!!t&&rP(r,e,0)>-1}var aP=1/0,sP=Sf&&1/d_(new Sf([,-0]))[1]==aP?function(r){return new Sf(r)}:JU,oP=200;function AP(r,e,t){var n=-1,i=iP,a=r.length,s=!0,o=[],A=o;if(a>=oP){var l=e?null:sP(r);if(l)return d_(l);s=!1,i=GU,A=new HU}else A=e?[]:o;e:for(;++n<a;){var c=r[n],u=e?e(c):c;if(c=c!==0?c:0,s&&u===u){for(var h=A.length;h--;)if(A[h]===u)continue e;e&&A.push(u),o.push(c)}else i(A,u,t)||(A!==o&&A.push(u),o.push(c))}return o}function lP(r,e){return r&&r.length?AP(r,KU(e)):[]}function Ya(r){"@babel/helpers - typeof";return Ya=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(e){return typeof e}:function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},Ya(r)}function cP(r,e){if(Ya(r)!="object"||!r)return r;var t=r[Symbol.toPrimitive];if(t!==void 0){var n=t.call(r,e);if(Ya(n)!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(r)}function g_(r){var e=cP(r,"string");return Ya(e)=="symbol"?e:e+""}function Ee(r,e,t){return(e=g_(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}function mb(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter(function(i){return Object.getOwnPropertyDescriptor(r,i).enumerable})),t.push.apply(t,n)}return t}function De(r){for(var e=1;e<arguments.length;e++){var t=arguments[e]!=null?arguments[e]:{};e%2?mb(Object(t),!0).forEach(function(n){Ee(r,n,t[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):mb(Object(t)).forEach(function(n){Object.defineProperty(r,n,Object.getOwnPropertyDescriptor(t,n))})}return r}function ue(r,e){if(!(r instanceof e))throw new TypeError("Cannot call a class as a function")}function wb(r,e){for(var t=0;t<e.length;t++){var n=e[t];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(r,g_(n.key),n)}}function he(r,e,t){return e&&wb(r.prototype,e),t&&wb(r,t),Object.defineProperty(r,"prototype",{writable:!1}),r}function Hu(r,e){(e==null||e>r.length)&&(e=r.length);for(var t=0,n=Array(e);t<e;t++)n[t]=r[t];return n}function uP(r){if(Array.isArray(r))return Hu(r)}function hP(r){if(typeof Symbol<"u"&&r[Symbol.iterator]!=null||r["@@iterator"]!=null)return Array.from(r)}function G1(r,e){if(r){if(typeof r=="string")return Hu(r,e);var t={}.toString.call(r).slice(8,-1);return t==="Object"&&r.constructor&&(t=r.constructor.name),t==="Map"||t==="Set"?Array.from(r):t==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?Hu(r,e):void 0}}function dP(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
|
|
2
|
+
In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function tt(r){return uP(r)||hP(r)||G1(r)||dP()}function Ho(r){return Ho=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(e){return e.__proto__||Object.getPrototypeOf(e)},Ho(r)}function v_(){try{var r=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch{}return(v_=function(){return!!r})()}function fP(r){if(r===void 0)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return r}function gP(r,e){if(e&&(Ya(e)=="object"||typeof e=="function"))return e;if(e!==void 0)throw new TypeError("Derived constructors may only return object or undefined");return fP(r)}function qe(r,e,t){return e=Ho(e),gP(r,v_()?Reflect.construct(e,t||[],Ho(r).constructor):e.apply(r,t))}function hw(r,e){return hw=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,n){return t.__proto__=n,t},hw(r,e)}function $e(r,e){if(typeof e!="function"&&e!==null)throw new TypeError("Super expression must either be null or a function");r.prototype=Object.create(e&&e.prototype,{constructor:{value:r,writable:!0,configurable:!0}}),Object.defineProperty(r,"prototype",{writable:!1}),e&&hw(r,e)}function vP(r){if(Array.isArray(r))return r}function pP(r,e){var t=r==null?null:typeof Symbol<"u"&&r[Symbol.iterator]||r["@@iterator"];if(t!=null){var n,i,a,s,o=[],A=!0,l=!1;try{if(a=(t=t.call(r)).next,e===0){if(Object(t)!==t)return;A=!1}else for(;!(A=(n=a.call(t)).done)&&(o.push(n.value),o.length!==e);A=!0);}catch(c){l=!0,i=c}finally{try{if(!A&&t.return!=null&&(s=t.return(),Object(s)!==s))return}finally{if(l)throw i}}return o}}function yP(){throw new TypeError(`Invalid attempt to destructure non-iterable instance.
|
|
3
|
+
In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function We(r,e){return vP(r)||pP(r,e)||G1(r,e)||yP()}var Ff={exports:{}},Bb;function mP(){return Bb||(Bb=1,(function(r){var e=Object.prototype.hasOwnProperty,t="~";function n(){}Object.create&&(n.prototype=Object.create(null),new n().__proto__||(t=!1));function i(A,l,c){this.fn=A,this.context=l,this.once=c||!1}function a(A,l,c,u,h){if(typeof c!="function")throw new TypeError("The listener must be a function");var d=new i(c,u||A,h),f=t?t+l:l;return A._events[f]?A._events[f].fn?A._events[f]=[A._events[f],d]:A._events[f].push(d):(A._events[f]=d,A._eventsCount++),A}function s(A,l){--A._eventsCount===0?A._events=new n:delete A._events[l]}function o(){this._events=new n,this._eventsCount=0}o.prototype.eventNames=function(){var l=[],c,u;if(this._eventsCount===0)return l;for(u in c=this._events)e.call(c,u)&&l.push(t?u.slice(1):u);return Object.getOwnPropertySymbols?l.concat(Object.getOwnPropertySymbols(c)):l},o.prototype.listeners=function(l){var c=t?t+l:l,u=this._events[c];if(!u)return[];if(u.fn)return[u.fn];for(var h=0,d=u.length,f=new Array(d);h<d;h++)f[h]=u[h].fn;return f},o.prototype.listenerCount=function(l){var c=t?t+l:l,u=this._events[c];return u?u.fn?1:u.length:0},o.prototype.emit=function(l,c,u,h,d,f){var g=t?t+l:l;if(!this._events[g])return!1;var v=this._events[g],p=arguments.length,y,m;if(v.fn){switch(v.once&&this.removeListener(l,v.fn,void 0,!0),p){case 1:return v.fn.call(v.context),!0;case 2:return v.fn.call(v.context,c),!0;case 3:return v.fn.call(v.context,c,u),!0;case 4:return v.fn.call(v.context,c,u,h),!0;case 5:return v.fn.call(v.context,c,u,h,d),!0;case 6:return v.fn.call(v.context,c,u,h,d,f),!0}for(m=1,y=new Array(p-1);m<p;m++)y[m-1]=arguments[m];v.fn.apply(v.context,y)}else{var B=v.length,C;for(m=0;m<B;m++)switch(v[m].once&&this.removeListener(l,v[m].fn,void 0,!0),p){case 1:v[m].fn.call(v[m].context);break;case 2:v[m].fn.call(v[m].context,c);break;case 3:v[m].fn.call(v[m].context,c,u);break;case 4:v[m].fn.call(v[m].context,c,u,h);break;default:if(!y)for(C=1,y=new Array(p-1);C<p;C++)y[C-1]=arguments[C];v[m].fn.apply(v[m].context,y)}}return!0},o.prototype.on=function(l,c,u){return a(this,l,c,u,!1)},o.prototype.once=function(l,c,u){return a(this,l,c,u,!0)},o.prototype.removeListener=function(l,c,u,h){var d=t?t+l:l;if(!this._events[d])return this;if(!c)return s(this,d),this;var f=this._events[d];if(f.fn)f.fn===c&&(!h||f.once)&&(!u||f.context===u)&&s(this,d);else{for(var g=0,v=[],p=f.length;g<p;g++)(f[g].fn!==c||h&&!f[g].once||u&&f[g].context!==u)&&v.push(f[g]);v.length?this._events[d]=v.length===1?v[0]:v:s(this,d)}return this},o.prototype.removeAllListeners=function(l){var c;return l?(c=t?t+l:l,this._events[c]&&s(this,c)):(this._events=new n,this._eventsCount=0),this},o.prototype.off=o.prototype.removeListener,o.prototype.addListener=o.prototype.on,o.prefixed=t,o.EventEmitter=o,r.exports=o})(Ff)),Ff.exports}var wP=mP();const p_=Qh(wP);var Pt=1e-6,mn=typeof Float32Array<"u"?Float32Array:Array;Math.hypot||(Math.hypot=function(){for(var r=0,e=arguments.length;e--;)r+=arguments[e]*arguments[e];return Math.sqrt(r)});function y_(){var r=new mn(9);return mn!=Float32Array&&(r[1]=0,r[2]=0,r[3]=0,r[5]=0,r[6]=0,r[7]=0),r[0]=1,r[4]=1,r[8]=1,r}function BP(r,e){return r[0]=e[0],r[1]=e[1],r[2]=e[2],r[3]=e[4],r[4]=e[5],r[5]=e[6],r[6]=e[8],r[7]=e[9],r[8]=e[10],r}function bP(r,e,t,n,i,a,s,o,A){var l=new mn(9);return l[0]=r,l[1]=e,l[2]=t,l[3]=n,l[4]=i,l[5]=a,l[6]=s,l[7]=o,l[8]=A,l}function xt(){var r=new mn(16);return mn!=Float32Array&&(r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[11]=0,r[12]=0,r[13]=0,r[14]=0),r[0]=1,r[5]=1,r[10]=1,r[15]=1,r}function m_(r){var e=new mn(16);return e[0]=r[0],e[1]=r[1],e[2]=r[2],e[3]=r[3],e[4]=r[4],e[5]=r[5],e[6]=r[6],e[7]=r[7],e[8]=r[8],e[9]=r[9],e[10]=r[10],e[11]=r[11],e[12]=r[12],e[13]=r[13],e[14]=r[14],e[15]=r[15],e}function Go(r,e){return r[0]=e[0],r[1]=e[1],r[2]=e[2],r[3]=e[3],r[4]=e[4],r[5]=e[5],r[6]=e[6],r[7]=e[7],r[8]=e[8],r[9]=e[9],r[10]=e[10],r[11]=e[11],r[12]=e[12],r[13]=e[13],r[14]=e[14],r[15]=e[15],r}function w_(r,e,t,n,i,a,s,o,A,l,c,u,h,d,f,g){var v=new mn(16);return v[0]=r,v[1]=e,v[2]=t,v[3]=n,v[4]=i,v[5]=a,v[6]=s,v[7]=o,v[8]=A,v[9]=l,v[10]=c,v[11]=u,v[12]=h,v[13]=d,v[14]=f,v[15]=g,v}function dw(r,e,t,n,i,a,s,o,A,l,c,u,h,d,f,g,v){return r[0]=e,r[1]=t,r[2]=n,r[3]=i,r[4]=a,r[5]=s,r[6]=o,r[7]=A,r[8]=l,r[9]=c,r[10]=u,r[11]=h,r[12]=d,r[13]=f,r[14]=g,r[15]=v,r}function Xa(r){return r[0]=1,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=1,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[10]=1,r[11]=0,r[12]=0,r[13]=0,r[14]=0,r[15]=1,r}function B_(r,e){if(r===e){var t=e[1],n=e[2],i=e[3],a=e[6],s=e[7],o=e[11];r[1]=e[4],r[2]=e[8],r[3]=e[12],r[4]=t,r[6]=e[9],r[7]=e[13],r[8]=n,r[9]=a,r[11]=e[14],r[12]=i,r[13]=s,r[14]=o}else r[0]=e[0],r[1]=e[4],r[2]=e[8],r[3]=e[12],r[4]=e[1],r[5]=e[5],r[6]=e[9],r[7]=e[13],r[8]=e[2],r[9]=e[6],r[10]=e[10],r[11]=e[14],r[12]=e[3],r[13]=e[7],r[14]=e[11],r[15]=e[15];return r}function Ni(r,e){var t=e[0],n=e[1],i=e[2],a=e[3],s=e[4],o=e[5],A=e[6],l=e[7],c=e[8],u=e[9],h=e[10],d=e[11],f=e[12],g=e[13],v=e[14],p=e[15],y=t*o-n*s,m=t*A-i*s,B=t*l-a*s,C=n*A-i*o,S=n*l-a*o,F=i*l-a*A,T=c*g-u*f,O=c*v-h*f,_=c*p-d*f,k=u*v-h*g,L=u*p-d*g,U=h*p-d*v,G=y*U-m*L+B*k+C*_-S*O+F*T;return G?(G=1/G,r[0]=(o*U-A*L+l*k)*G,r[1]=(i*L-n*U-a*k)*G,r[2]=(g*F-v*S+p*C)*G,r[3]=(h*S-u*F-d*C)*G,r[4]=(A*_-s*U-l*O)*G,r[5]=(t*U-i*_+a*O)*G,r[6]=(v*B-f*F-p*m)*G,r[7]=(c*F-h*B+d*m)*G,r[8]=(s*L-o*_+l*T)*G,r[9]=(n*_-t*L-a*T)*G,r[10]=(f*S-g*B+p*y)*G,r[11]=(u*B-c*S-d*y)*G,r[12]=(o*O-s*k-A*T)*G,r[13]=(t*k-n*O+i*T)*G,r[14]=(g*m-f*C-v*y)*G,r[15]=(c*C-u*m+h*y)*G,r):null}function EP(r,e){var t=e[0],n=e[1],i=e[2],a=e[3],s=e[4],o=e[5],A=e[6],l=e[7],c=e[8],u=e[9],h=e[10],d=e[11],f=e[12],g=e[13],v=e[14],p=e[15];return r[0]=o*(h*p-d*v)-u*(A*p-l*v)+g*(A*d-l*h),r[1]=-(n*(h*p-d*v)-u*(i*p-a*v)+g*(i*d-a*h)),r[2]=n*(A*p-l*v)-o*(i*p-a*v)+g*(i*l-a*A),r[3]=-(n*(A*d-l*h)-o*(i*d-a*h)+u*(i*l-a*A)),r[4]=-(s*(h*p-d*v)-c*(A*p-l*v)+f*(A*d-l*h)),r[5]=t*(h*p-d*v)-c*(i*p-a*v)+f*(i*d-a*h),r[6]=-(t*(A*p-l*v)-s*(i*p-a*v)+f*(i*l-a*A)),r[7]=t*(A*d-l*h)-s*(i*d-a*h)+c*(i*l-a*A),r[8]=s*(u*p-d*g)-c*(o*p-l*g)+f*(o*d-l*u),r[9]=-(t*(u*p-d*g)-c*(n*p-a*g)+f*(n*d-a*u)),r[10]=t*(o*p-l*g)-s*(n*p-a*g)+f*(n*l-a*o),r[11]=-(t*(o*d-l*u)-s*(n*d-a*u)+c*(n*l-a*o)),r[12]=-(s*(u*v-h*g)-c*(o*v-A*g)+f*(o*h-A*u)),r[13]=t*(u*v-h*g)-c*(n*v-i*g)+f*(n*h-i*u),r[14]=-(t*(o*v-A*g)-s*(n*v-i*g)+f*(n*A-i*o)),r[15]=t*(o*h-A*u)-s*(n*h-i*u)+c*(n*A-i*o),r}function b_(r){var e=r[0],t=r[1],n=r[2],i=r[3],a=r[4],s=r[5],o=r[6],A=r[7],l=r[8],c=r[9],u=r[10],h=r[11],d=r[12],f=r[13],g=r[14],v=r[15],p=e*s-t*a,y=e*o-n*a,m=e*A-i*a,B=t*o-n*s,C=t*A-i*s,S=n*A-i*o,F=l*f-c*d,T=l*g-u*d,O=l*v-h*d,_=c*g-u*f,k=c*v-h*f,L=u*v-h*g;return p*L-y*k+m*_+B*O-C*T+S*F}function tr(r,e,t){var n=e[0],i=e[1],a=e[2],s=e[3],o=e[4],A=e[5],l=e[6],c=e[7],u=e[8],h=e[9],d=e[10],f=e[11],g=e[12],v=e[13],p=e[14],y=e[15],m=t[0],B=t[1],C=t[2],S=t[3];return r[0]=m*n+B*o+C*u+S*g,r[1]=m*i+B*A+C*h+S*v,r[2]=m*a+B*l+C*d+S*p,r[3]=m*s+B*c+C*f+S*y,m=t[4],B=t[5],C=t[6],S=t[7],r[4]=m*n+B*o+C*u+S*g,r[5]=m*i+B*A+C*h+S*v,r[6]=m*a+B*l+C*d+S*p,r[7]=m*s+B*c+C*f+S*y,m=t[8],B=t[9],C=t[10],S=t[11],r[8]=m*n+B*o+C*u+S*g,r[9]=m*i+B*A+C*h+S*v,r[10]=m*a+B*l+C*d+S*p,r[11]=m*s+B*c+C*f+S*y,m=t[12],B=t[13],C=t[14],S=t[15],r[12]=m*n+B*o+C*u+S*g,r[13]=m*i+B*A+C*h+S*v,r[14]=m*a+B*l+C*d+S*p,r[15]=m*s+B*c+C*f+S*y,r}function ko(r,e,t){var n=t[0],i=t[1],a=t[2],s,o,A,l,c,u,h,d,f,g,v,p;return e===r?(r[12]=e[0]*n+e[4]*i+e[8]*a+e[12],r[13]=e[1]*n+e[5]*i+e[9]*a+e[13],r[14]=e[2]*n+e[6]*i+e[10]*a+e[14],r[15]=e[3]*n+e[7]*i+e[11]*a+e[15]):(s=e[0],o=e[1],A=e[2],l=e[3],c=e[4],u=e[5],h=e[6],d=e[7],f=e[8],g=e[9],v=e[10],p=e[11],r[0]=s,r[1]=o,r[2]=A,r[3]=l,r[4]=c,r[5]=u,r[6]=h,r[7]=d,r[8]=f,r[9]=g,r[10]=v,r[11]=p,r[12]=s*n+c*i+f*a+e[12],r[13]=o*n+u*i+g*a+e[13],r[14]=A*n+h*i+v*a+e[14],r[15]=l*n+d*i+p*a+e[15]),r}function E_(r,e,t){var n=t[0],i=t[1],a=t[2];return r[0]=e[0]*n,r[1]=e[1]*n,r[2]=e[2]*n,r[3]=e[3]*n,r[4]=e[4]*i,r[5]=e[5]*i,r[6]=e[6]*i,r[7]=e[7]*i,r[8]=e[8]*a,r[9]=e[9]*a,r[10]=e[10]*a,r[11]=e[11]*a,r[12]=e[12],r[13]=e[13],r[14]=e[14],r[15]=e[15],r}function xP(r,e,t,n){var i=n[0],a=n[1],s=n[2],o=Math.hypot(i,a,s),A,l,c,u,h,d,f,g,v,p,y,m,B,C,S,F,T,O,_,k,L,U,G,W;return o<Pt?null:(o=1/o,i*=o,a*=o,s*=o,A=Math.sin(t),l=Math.cos(t),c=1-l,u=e[0],h=e[1],d=e[2],f=e[3],g=e[4],v=e[5],p=e[6],y=e[7],m=e[8],B=e[9],C=e[10],S=e[11],F=i*i*c+l,T=a*i*c+s*A,O=s*i*c-a*A,_=i*a*c-s*A,k=a*a*c+l,L=s*a*c+i*A,U=i*s*c+a*A,G=a*s*c-i*A,W=s*s*c+l,r[0]=u*F+g*T+m*O,r[1]=h*F+v*T+B*O,r[2]=d*F+p*T+C*O,r[3]=f*F+y*T+S*O,r[4]=u*_+g*k+m*L,r[5]=h*_+v*k+B*L,r[6]=d*_+p*k+C*L,r[7]=f*_+y*k+S*L,r[8]=u*U+g*G+m*W,r[9]=h*U+v*G+B*W,r[10]=d*U+p*G+C*W,r[11]=f*U+y*G+S*W,e!==r&&(r[12]=e[12],r[13]=e[13],r[14]=e[14],r[15]=e[15]),r)}function x_(r,e,t){var n=Math.sin(t),i=Math.cos(t),a=e[4],s=e[5],o=e[6],A=e[7],l=e[8],c=e[9],u=e[10],h=e[11];return e!==r&&(r[0]=e[0],r[1]=e[1],r[2]=e[2],r[3]=e[3],r[12]=e[12],r[13]=e[13],r[14]=e[14],r[15]=e[15]),r[4]=a*i+l*n,r[5]=s*i+c*n,r[6]=o*i+u*n,r[7]=A*i+h*n,r[8]=l*i-a*n,r[9]=c*i-s*n,r[10]=u*i-o*n,r[11]=h*i-A*n,r}function C_(r,e,t){var n=Math.sin(t),i=Math.cos(t),a=e[0],s=e[1],o=e[2],A=e[3],l=e[8],c=e[9],u=e[10],h=e[11];return e!==r&&(r[4]=e[4],r[5]=e[5],r[6]=e[6],r[7]=e[7],r[12]=e[12],r[13]=e[13],r[14]=e[14],r[15]=e[15]),r[0]=a*i-l*n,r[1]=s*i-c*n,r[2]=o*i-u*n,r[3]=A*i-h*n,r[8]=a*n+l*i,r[9]=s*n+c*i,r[10]=o*n+u*i,r[11]=A*n+h*i,r}function CP(r,e,t){var n=Math.sin(t),i=Math.cos(t),a=e[0],s=e[1],o=e[2],A=e[3],l=e[4],c=e[5],u=e[6],h=e[7];return e!==r&&(r[8]=e[8],r[9]=e[9],r[10]=e[10],r[11]=e[11],r[12]=e[12],r[13]=e[13],r[14]=e[14],r[15]=e[15]),r[0]=a*i+l*n,r[1]=s*i+c*n,r[2]=o*i+u*n,r[3]=A*i+h*n,r[4]=l*i-a*n,r[5]=c*i-s*n,r[6]=u*i-o*n,r[7]=h*i-A*n,r}function Ia(r,e){return r[0]=1,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=1,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[10]=1,r[11]=0,r[12]=e[0],r[13]=e[1],r[14]=e[2],r[15]=1,r}function bs(r,e){return r[0]=e[0],r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=e[1],r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[10]=e[2],r[11]=0,r[12]=0,r[13]=0,r[14]=0,r[15]=1,r}function S_(r,e,t){var n=t[0],i=t[1],a=t[2],s=Math.hypot(n,i,a),o,A,l;return s<Pt?null:(s=1/s,n*=s,i*=s,a*=s,o=Math.sin(e),A=Math.cos(e),l=1-A,r[0]=n*n*l+A,r[1]=i*n*l+a*o,r[2]=a*n*l-i*o,r[3]=0,r[4]=n*i*l-a*o,r[5]=i*i*l+A,r[6]=a*i*l+n*o,r[7]=0,r[8]=n*a*l+i*o,r[9]=i*a*l-n*o,r[10]=a*a*l+A,r[11]=0,r[12]=0,r[13]=0,r[14]=0,r[15]=1,r)}function F_(r,e){var t=Math.sin(e),n=Math.cos(e);return r[0]=1,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=n,r[6]=t,r[7]=0,r[8]=0,r[9]=-t,r[10]=n,r[11]=0,r[12]=0,r[13]=0,r[14]=0,r[15]=1,r}function T_(r,e){var t=Math.sin(e),n=Math.cos(e);return r[0]=n,r[1]=0,r[2]=-t,r[3]=0,r[4]=0,r[5]=1,r[6]=0,r[7]=0,r[8]=t,r[9]=0,r[10]=n,r[11]=0,r[12]=0,r[13]=0,r[14]=0,r[15]=1,r}function fw(r,e){var t=Math.sin(e),n=Math.cos(e);return r[0]=n,r[1]=t,r[2]=0,r[3]=0,r[4]=-t,r[5]=n,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[10]=1,r[11]=0,r[12]=0,r[13]=0,r[14]=0,r[15]=1,r}function M_(r,e,t){var n=e[0],i=e[1],a=e[2],s=e[3],o=n+n,A=i+i,l=a+a,c=n*o,u=n*A,h=n*l,d=i*A,f=i*l,g=a*l,v=s*o,p=s*A,y=s*l;return r[0]=1-(d+g),r[1]=u+y,r[2]=h-p,r[3]=0,r[4]=u-y,r[5]=1-(c+g),r[6]=f+v,r[7]=0,r[8]=h+p,r[9]=f-v,r[10]=1-(c+d),r[11]=0,r[12]=t[0],r[13]=t[1],r[14]=t[2],r[15]=1,r}function SP(r,e){var t=new mn(3),n=-e[0],i=-e[1],a=-e[2],s=e[3],o=e[4],A=e[5],l=e[6],c=e[7],u=n*n+i*i+a*a+s*s;return u>0?(t[0]=(o*s+c*n+A*a-l*i)*2/u,t[1]=(A*s+c*i+l*n-o*a)*2/u,t[2]=(l*s+c*a+o*i-A*n)*2/u):(t[0]=(o*s+c*n+A*a-l*i)*2,t[1]=(A*s+c*i+l*n-o*a)*2,t[2]=(l*s+c*a+o*i-A*n)*2),M_(r,e,t),r}function Gu(r,e){return r[0]=e[12],r[1]=e[13],r[2]=e[14],r}function Ko(r,e){var t=e[0],n=e[1],i=e[2],a=e[4],s=e[5],o=e[6],A=e[8],l=e[9],c=e[10];return r[0]=Math.hypot(t,n,i),r[1]=Math.hypot(a,s,o),r[2]=Math.hypot(A,l,c),r}function Ku(r,e){var t=new mn(3);Ko(t,e);var n=1/t[0],i=1/t[1],a=1/t[2],s=e[0]*n,o=e[1]*i,A=e[2]*a,l=e[4]*n,c=e[5]*i,u=e[6]*a,h=e[8]*n,d=e[9]*i,f=e[10]*a,g=s+c+f,v=0;return g>0?(v=Math.sqrt(g+1)*2,r[3]=.25*v,r[0]=(u-d)/v,r[1]=(h-A)/v,r[2]=(o-l)/v):s>c&&s>f?(v=Math.sqrt(1+s-c-f)*2,r[3]=(u-d)/v,r[0]=.25*v,r[1]=(o+l)/v,r[2]=(h+A)/v):c>f?(v=Math.sqrt(1+c-s-f)*2,r[3]=(h-A)/v,r[0]=(o+l)/v,r[1]=.25*v,r[2]=(u+d)/v):(v=Math.sqrt(1+f-s-c)*2,r[3]=(o-l)/v,r[0]=(h+A)/v,r[1]=(u+d)/v,r[2]=.25*v),r}function FP(r,e,t,n){var i=e[0],a=e[1],s=e[2],o=e[3],A=i+i,l=a+a,c=s+s,u=i*A,h=i*l,d=i*c,f=a*l,g=a*c,v=s*c,p=o*A,y=o*l,m=o*c,B=n[0],C=n[1],S=n[2];return r[0]=(1-(f+v))*B,r[1]=(h+m)*B,r[2]=(d-y)*B,r[3]=0,r[4]=(h-m)*C,r[5]=(1-(u+v))*C,r[6]=(g+p)*C,r[7]=0,r[8]=(d+y)*S,r[9]=(g-p)*S,r[10]=(1-(u+f))*S,r[11]=0,r[12]=t[0],r[13]=t[1],r[14]=t[2],r[15]=1,r}function qA(r,e,t,n,i){var a=e[0],s=e[1],o=e[2],A=e[3],l=a+a,c=s+s,u=o+o,h=a*l,d=a*c,f=a*u,g=s*c,v=s*u,p=o*u,y=A*l,m=A*c,B=A*u,C=n[0],S=n[1],F=n[2],T=i[0],O=i[1],_=i[2],k=(1-(g+p))*C,L=(d+B)*C,U=(f-m)*C,G=(d-B)*S,W=(1-(h+p))*S,V=(v+y)*S,K=(f+m)*F,D=(v-y)*F,X=(1-(h+g))*F;return r[0]=k,r[1]=L,r[2]=U,r[3]=0,r[4]=G,r[5]=W,r[6]=V,r[7]=0,r[8]=K,r[9]=D,r[10]=X,r[11]=0,r[12]=t[0]+T-(k*T+G*O+K*_),r[13]=t[1]+O-(L*T+W*O+D*_),r[14]=t[2]+_-(U*T+V*O+X*_),r[15]=1,r}function K1(r,e){var t=e[0],n=e[1],i=e[2],a=e[3],s=t+t,o=n+n,A=i+i,l=t*s,c=n*s,u=n*o,h=i*s,d=i*o,f=i*A,g=a*s,v=a*o,p=a*A;return r[0]=1-u-f,r[1]=c+p,r[2]=h-v,r[3]=0,r[4]=c-p,r[5]=1-l-f,r[6]=d+g,r[7]=0,r[8]=h+v,r[9]=d-g,r[10]=1-l-u,r[11]=0,r[12]=0,r[13]=0,r[14]=0,r[15]=1,r}function TP(r,e,t,n,i,a,s){var o=1/(t-e),A=1/(i-n),l=1/(a-s);return r[0]=a*2*o,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=a*2*A,r[6]=0,r[7]=0,r[8]=(t+e)*o,r[9]=(i+n)*A,r[10]=(s+a)*l,r[11]=-1,r[12]=0,r[13]=0,r[14]=s*a*2*l,r[15]=0,r}function O_(r,e,t,n,i){var a=1/Math.tan(e/2),s;return r[0]=a/t,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=a,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[11]=-1,r[12]=0,r[13]=0,r[15]=0,i!=null&&i!==1/0?(s=1/(n-i),r[10]=(i+n)*s,r[14]=2*i*n*s):(r[10]=-1,r[14]=-2*n),r}var MP=O_;function OP(r,e,t,n,i){var a=1/Math.tan(e/2),s;return r[0]=a/t,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=a,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[11]=-1,r[12]=0,r[13]=0,r[15]=0,i!=null&&i!==1/0?(s=1/(n-i),r[10]=i*s,r[14]=i*n*s):(r[10]=-1,r[14]=-n),r}function _P(r,e,t,n){var i=Math.tan(e.upDegrees*Math.PI/180),a=Math.tan(e.downDegrees*Math.PI/180),s=Math.tan(e.leftDegrees*Math.PI/180),o=Math.tan(e.rightDegrees*Math.PI/180),A=2/(s+o),l=2/(i+a);return r[0]=A,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=l,r[6]=0,r[7]=0,r[8]=-((s-o)*A*.5),r[9]=(i-a)*l*.5,r[10]=n/(t-n),r[11]=-1,r[12]=0,r[13]=0,r[14]=n*t/(t-n),r[15]=0,r}function __(r,e,t,n,i,a,s){var o=1/(e-t),A=1/(n-i),l=1/(a-s);return r[0]=-2*o,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=-2*A,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[10]=2*l,r[11]=0,r[12]=(e+t)*o,r[13]=(i+n)*A,r[14]=(s+a)*l,r[15]=1,r}var I_=__;function k_(r,e,t,n,i,a,s){var o=1/(e-t),A=1/(n-i),l=1/(a-s);return r[0]=-2*o,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=-2*A,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[10]=l,r[11]=0,r[12]=(e+t)*o,r[13]=(i+n)*A,r[14]=a*l,r[15]=1,r}function L_(r,e,t,n){var i,a,s,o,A,l,c,u,h,d,f=e[0],g=e[1],v=e[2],p=n[0],y=n[1],m=n[2],B=t[0],C=t[1],S=t[2];return Math.abs(f-B)<Pt&&Math.abs(g-C)<Pt&&Math.abs(v-S)<Pt?Xa(r):(c=f-B,u=g-C,h=v-S,d=1/Math.hypot(c,u,h),c*=d,u*=d,h*=d,i=y*h-m*u,a=m*c-p*h,s=p*u-y*c,d=Math.hypot(i,a,s),d?(d=1/d,i*=d,a*=d,s*=d):(i=0,a=0,s=0),o=u*s-h*a,A=h*i-c*s,l=c*a-u*i,d=Math.hypot(o,A,l),d?(d=1/d,o*=d,A*=d,l*=d):(o=0,A=0,l=0),r[0]=i,r[1]=o,r[2]=c,r[3]=0,r[4]=a,r[5]=A,r[6]=u,r[7]=0,r[8]=s,r[9]=l,r[10]=h,r[11]=0,r[12]=-(i*f+a*g+s*v),r[13]=-(o*f+A*g+l*v),r[14]=-(c*f+u*g+h*v),r[15]=1,r)}function IP(r,e,t,n){var i=e[0],a=e[1],s=e[2],o=n[0],A=n[1],l=n[2],c=i-t[0],u=a-t[1],h=s-t[2],d=c*c+u*u+h*h;d>0&&(d=1/Math.sqrt(d),c*=d,u*=d,h*=d);var f=A*h-l*u,g=l*c-o*h,v=o*u-A*c;return d=f*f+g*g+v*v,d>0&&(d=1/Math.sqrt(d),f*=d,g*=d,v*=d),r[0]=f,r[1]=g,r[2]=v,r[3]=0,r[4]=u*v-h*g,r[5]=h*f-c*v,r[6]=c*g-u*f,r[7]=0,r[8]=c,r[9]=u,r[10]=h,r[11]=0,r[12]=i,r[13]=a,r[14]=s,r[15]=1,r}function kP(r){return"mat4("+r[0]+", "+r[1]+", "+r[2]+", "+r[3]+", "+r[4]+", "+r[5]+", "+r[6]+", "+r[7]+", "+r[8]+", "+r[9]+", "+r[10]+", "+r[11]+", "+r[12]+", "+r[13]+", "+r[14]+", "+r[15]+")"}function LP(r){return Math.hypot(r[0],r[1],r[2],r[3],r[4],r[5],r[6],r[7],r[8],r[9],r[10],r[11],r[12],r[13],r[14],r[15])}function QP(r,e,t){return r[0]=e[0]+t[0],r[1]=e[1]+t[1],r[2]=e[2]+t[2],r[3]=e[3]+t[3],r[4]=e[4]+t[4],r[5]=e[5]+t[5],r[6]=e[6]+t[6],r[7]=e[7]+t[7],r[8]=e[8]+t[8],r[9]=e[9]+t[9],r[10]=e[10]+t[10],r[11]=e[11]+t[11],r[12]=e[12]+t[12],r[13]=e[13]+t[13],r[14]=e[14]+t[14],r[15]=e[15]+t[15],r}function Q_(r,e,t){return r[0]=e[0]-t[0],r[1]=e[1]-t[1],r[2]=e[2]-t[2],r[3]=e[3]-t[3],r[4]=e[4]-t[4],r[5]=e[5]-t[5],r[6]=e[6]-t[6],r[7]=e[7]-t[7],r[8]=e[8]-t[8],r[9]=e[9]-t[9],r[10]=e[10]-t[10],r[11]=e[11]-t[11],r[12]=e[12]-t[12],r[13]=e[13]-t[13],r[14]=e[14]-t[14],r[15]=e[15]-t[15],r}function NP(r,e,t){return r[0]=e[0]*t,r[1]=e[1]*t,r[2]=e[2]*t,r[3]=e[3]*t,r[4]=e[4]*t,r[5]=e[5]*t,r[6]=e[6]*t,r[7]=e[7]*t,r[8]=e[8]*t,r[9]=e[9]*t,r[10]=e[10]*t,r[11]=e[11]*t,r[12]=e[12]*t,r[13]=e[13]*t,r[14]=e[14]*t,r[15]=e[15]*t,r}function UP(r,e,t,n){return r[0]=e[0]+t[0]*n,r[1]=e[1]+t[1]*n,r[2]=e[2]+t[2]*n,r[3]=e[3]+t[3]*n,r[4]=e[4]+t[4]*n,r[5]=e[5]+t[5]*n,r[6]=e[6]+t[6]*n,r[7]=e[7]+t[7]*n,r[8]=e[8]+t[8]*n,r[9]=e[9]+t[9]*n,r[10]=e[10]+t[10]*n,r[11]=e[11]+t[11]*n,r[12]=e[12]+t[12]*n,r[13]=e[13]+t[13]*n,r[14]=e[14]+t[14]*n,r[15]=e[15]+t[15]*n,r}function gw(r,e){return r[0]===e[0]&&r[1]===e[1]&&r[2]===e[2]&&r[3]===e[3]&&r[4]===e[4]&&r[5]===e[5]&&r[6]===e[6]&&r[7]===e[7]&&r[8]===e[8]&&r[9]===e[9]&&r[10]===e[10]&&r[11]===e[11]&&r[12]===e[12]&&r[13]===e[13]&&r[14]===e[14]&&r[15]===e[15]}function PP(r,e){var t=r[0],n=r[1],i=r[2],a=r[3],s=r[4],o=r[5],A=r[6],l=r[7],c=r[8],u=r[9],h=r[10],d=r[11],f=r[12],g=r[13],v=r[14],p=r[15],y=e[0],m=e[1],B=e[2],C=e[3],S=e[4],F=e[5],T=e[6],O=e[7],_=e[8],k=e[9],L=e[10],U=e[11],G=e[12],W=e[13],V=e[14],K=e[15];return Math.abs(t-y)<=Pt*Math.max(1,Math.abs(t),Math.abs(y))&&Math.abs(n-m)<=Pt*Math.max(1,Math.abs(n),Math.abs(m))&&Math.abs(i-B)<=Pt*Math.max(1,Math.abs(i),Math.abs(B))&&Math.abs(a-C)<=Pt*Math.max(1,Math.abs(a),Math.abs(C))&&Math.abs(s-S)<=Pt*Math.max(1,Math.abs(s),Math.abs(S))&&Math.abs(o-F)<=Pt*Math.max(1,Math.abs(o),Math.abs(F))&&Math.abs(A-T)<=Pt*Math.max(1,Math.abs(A),Math.abs(T))&&Math.abs(l-O)<=Pt*Math.max(1,Math.abs(l),Math.abs(O))&&Math.abs(c-_)<=Pt*Math.max(1,Math.abs(c),Math.abs(_))&&Math.abs(u-k)<=Pt*Math.max(1,Math.abs(u),Math.abs(k))&&Math.abs(h-L)<=Pt*Math.max(1,Math.abs(h),Math.abs(L))&&Math.abs(d-U)<=Pt*Math.max(1,Math.abs(d),Math.abs(U))&&Math.abs(f-G)<=Pt*Math.max(1,Math.abs(f),Math.abs(G))&&Math.abs(g-W)<=Pt*Math.max(1,Math.abs(g),Math.abs(W))&&Math.abs(v-V)<=Pt*Math.max(1,Math.abs(v),Math.abs(V))&&Math.abs(p-K)<=Pt*Math.max(1,Math.abs(p),Math.abs(K))}var N_=tr,RP=Q_;const DP=Object.freeze(Object.defineProperty({__proto__:null,add:QP,adjoint:EP,clone:m_,copy:Go,create:xt,determinant:b_,equals:PP,exactEquals:gw,frob:LP,fromQuat:K1,fromQuat2:SP,fromRotation:S_,fromRotationTranslation:M_,fromRotationTranslationScale:FP,fromRotationTranslationScaleOrigin:qA,fromScaling:bs,fromTranslation:Ia,fromValues:w_,fromXRotation:F_,fromYRotation:T_,fromZRotation:fw,frustum:TP,getRotation:Ku,getScaling:Ko,getTranslation:Gu,identity:Xa,invert:Ni,lookAt:L_,mul:N_,multiply:tr,multiplyScalar:NP,multiplyScalarAndAdd:UP,ortho:I_,orthoNO:__,orthoZO:k_,perspective:MP,perspectiveFromFieldOfView:_P,perspectiveNO:O_,perspectiveZO:OP,rotate:xP,rotateX:x_,rotateY:C_,rotateZ:CP,scale:E_,set:dw,str:kP,sub:RP,subtract:Q_,targetTo:IP,translate:ko,transpose:B_},Symbol.toStringTag,{value:"Module"}));function Ze(){var r=new mn(3);return mn!=Float32Array&&(r[0]=0,r[1]=0,r[2]=0),r}function aa(r){var e=new mn(3);return e[0]=r[0],e[1]=r[1],e[2]=r[2],e}function oa(r){var e=r[0],t=r[1],n=r[2];return Math.hypot(e,t,n)}function Ct(r,e,t){var n=new mn(3);return n[0]=r,n[1]=e,n[2]=t,n}function Ui(r,e){return r[0]=e[0],r[1]=e[1],r[2]=e[2],r}function er(r,e,t,n){return r[0]=e,r[1]=t,r[2]=n,r}function Va(r,e,t){return r[0]=e[0]+t[0],r[1]=e[1]+t[1],r[2]=e[2]+t[2],r}function vw(r,e,t){return r[0]=e[0]-t[0],r[1]=e[1]-t[1],r[2]=e[2]-t[2],r}function HP(r,e,t){return r[0]=e[0]*t[0],r[1]=e[1]*t[1],r[2]=e[2]*t[2],r}function GP(r,e,t){return r[0]=Math.min(e[0],t[0]),r[1]=Math.min(e[1],t[1]),r[2]=Math.min(e[2],t[2]),r}function KP(r,e,t){return r[0]=Math.max(e[0],t[0]),r[1]=Math.max(e[1],t[1]),r[2]=Math.max(e[2],t[2]),r}function zu(r,e,t){return r[0]=e[0]*t,r[1]=e[1]*t,r[2]=e[2]*t,r}function zP(r,e){var t=e[0]-r[0],n=e[1]-r[1],i=e[2]-r[2];return Math.hypot(t,n,i)}function _s(r,e){var t=e[0],n=e[1],i=e[2],a=t*t+n*n+i*i;return a>0&&(a=1/Math.sqrt(a)),r[0]=e[0]*a,r[1]=e[1]*a,r[2]=e[2]*a,r}function Pi(r,e){return r[0]*e[0]+r[1]*e[1]+r[2]*e[2]}function Cu(r,e,t){var n=e[0],i=e[1],a=e[2],s=t[0],o=t[1],A=t[2];return r[0]=i*A-a*o,r[1]=a*s-n*A,r[2]=n*o-i*s,r}function pw(r,e,t,n){var i=e[0],a=e[1],s=e[2];return r[0]=i+n*(t[0]-i),r[1]=a+n*(t[1]-a),r[2]=s+n*(t[2]-s),r}function nr(r,e,t){var n=e[0],i=e[1],a=e[2],s=t[3]*n+t[7]*i+t[11]*a+t[15];return s=s||1,r[0]=(t[0]*n+t[4]*i+t[8]*a+t[12])/s,r[1]=(t[1]*n+t[5]*i+t[9]*a+t[13])/s,r[2]=(t[2]*n+t[6]*i+t[10]*a+t[14])/s,r}function VP(r,e,t){var n=e[0],i=e[1],a=e[2];return r[0]=n*t[0]+i*t[3]+a*t[6],r[1]=n*t[1]+i*t[4]+a*t[7],r[2]=n*t[2]+i*t[5]+a*t[8],r}function jP(r,e,t){var n=t[0],i=t[1],a=t[2],s=t[3],o=e[0],A=e[1],l=e[2],c=i*l-a*A,u=a*o-n*l,h=n*A-i*o,d=i*h-a*u,f=a*c-n*h,g=n*u-i*c,v=s*2;return c*=v,u*=v,h*=v,d*=2,f*=2,g*=2,r[0]=o+c+d,r[1]=A+u+f,r[2]=l+h+g,r}function hA(r,e){var t=r[0],n=r[1],i=r[2],a=e[0],s=e[1],o=e[2];return Math.abs(t-a)<=Pt*Math.max(1,Math.abs(t),Math.abs(a))&&Math.abs(n-s)<=Pt*Math.max(1,Math.abs(n),Math.abs(s))&&Math.abs(i-o)<=Pt*Math.max(1,Math.abs(i),Math.abs(o))}var U_=vw,bb=zP,P_=oa;(function(){var r=Ze();return function(e,t,n,i,a,s){var o,A;for(t||(t=3),n||(n=0),i?A=Math.min(i*t+n,e.length):A=e.length,o=n;o<A;o+=t)r[0]=e[o],r[1]=e[o+1],r[2]=e[o+2],a(r,r,s),e[o]=r[0],e[o+1]=r[1],e[o+2]=r[2];return e}})();function Ri(){var r=new mn(4);return mn!=Float32Array&&(r[0]=0,r[1]=0,r[2]=0,r[3]=0),r}function TA(r,e,t,n){var i=new mn(4);return i[0]=r,i[1]=e,i[2]=t,i[3]=n,i}function WP(r,e){return r[0]=e[0],r[1]=e[1],r[2]=e[2],r[3]=e[3],r}function qP(r,e,t,n,i){return r[0]=e,r[1]=t,r[2]=n,r[3]=i,r}function $P(r,e){var t=e[0],n=e[1],i=e[2],a=e[3],s=t*t+n*n+i*i+a*a;return s>0&&(s=1/Math.sqrt(s)),r[0]=t*s,r[1]=n*s,r[2]=i*s,r[3]=a*s,r}function ua(r,e,t){var n=e[0],i=e[1],a=e[2],s=e[3];return r[0]=t[0]*n+t[4]*i+t[8]*a+t[12]*s,r[1]=t[1]*n+t[5]*i+t[9]*a+t[13]*s,r[2]=t[2]*n+t[6]*i+t[10]*a+t[14]*s,r[3]=t[3]*n+t[7]*i+t[11]*a+t[15]*s,r}(function(){var r=Ri();return function(e,t,n,i,a,s){var o,A;for(t||(t=4),n||(n=0),i?A=Math.min(i*t+n,e.length):A=e.length,o=n;o<A;o+=t)r[0]=e[o],r[1]=e[o+1],r[2]=e[o+2],r[3]=e[o+3],a(r,r,s),e[o]=r[0],e[o+1]=r[1],e[o+2]=r[2],e[o+3]=r[3];return e}})();function gn(){var r=new mn(4);return mn!=Float32Array&&(r[0]=0,r[1]=0,r[2]=0),r[3]=1,r}function La(r,e,t){t=t*.5;var n=Math.sin(t);return r[0]=n*e[0],r[1]=n*e[1],r[2]=n*e[2],r[3]=Math.cos(t),r}function ja(r,e,t){var n=e[0],i=e[1],a=e[2],s=e[3],o=t[0],A=t[1],l=t[2],c=t[3];return r[0]=n*c+s*o+i*l-a*A,r[1]=i*c+s*A+a*o-n*l,r[2]=a*c+s*l+n*A-i*o,r[3]=s*c-n*o-i*A-a*l,r}function Tf(r,e,t,n){var i=e[0],a=e[1],s=e[2],o=e[3],A=t[0],l=t[1],c=t[2],u=t[3],h,d,f,g,v;return d=i*A+a*l+s*c+o*u,d<0&&(d=-d,A=-A,l=-l,c=-c,u=-u),1-d>Pt?(h=Math.acos(d),f=Math.sin(h),g=Math.sin((1-n)*h)/f,v=Math.sin(n*h)/f):(g=1-n,v=n),r[0]=g*i+v*A,r[1]=g*a+v*l,r[2]=g*s+v*c,r[3]=g*o+v*u,r}function Mf(r,e){var t=e[0],n=e[1],i=e[2],a=e[3],s=t*t+n*n+i*i+a*a,o=s?1/s:0;return r[0]=-t*o,r[1]=-n*o,r[2]=-i*o,r[3]=a*o,r}function YP(r,e){var t=e[0]+e[4]+e[8],n;if(t>0)n=Math.sqrt(t+1),r[3]=.5*n,n=.5/n,r[0]=(e[5]-e[7])*n,r[1]=(e[6]-e[2])*n,r[2]=(e[1]-e[3])*n;else{var i=0;e[4]>e[0]&&(i=1),e[8]>e[i*3+i]&&(i=2);var a=(i+1)%3,s=(i+2)%3;n=Math.sqrt(e[i*3+i]-e[a*3+a]-e[s*3+s]+1),r[i]=.5*n,n=.5/n,r[3]=(e[a*3+s]-e[s*3+a])*n,r[a]=(e[a*3+i]+e[i*3+a])*n,r[s]=(e[s*3+i]+e[i*3+s])*n}return r}function rc(r,e,t,n){var i=.5*Math.PI/180;e*=i,t*=i,n*=i;var a=Math.sin(e),s=Math.cos(e),o=Math.sin(t),A=Math.cos(t),l=Math.sin(n),c=Math.cos(n);return r[0]=a*A*c-s*o*l,r[1]=s*o*c+a*A*l,r[2]=s*A*l-a*o*c,r[3]=s*A*c+a*o*l,r}var XP=TA,ic=WP,R_=qP,Eb=ja,Vu=$P;(function(){var r=Ze(),e=Ct(1,0,0),t=Ct(0,1,0);return function(n,i,a){var s=Pi(i,a);return s<-.999999?(Cu(r,e,i),P_(r)<1e-6&&Cu(r,t,i),_s(r,r),La(n,r,Math.PI),n):s>.999999?(n[0]=0,n[1]=0,n[2]=0,n[3]=1,n):(Cu(r,i,a),n[0]=r[0],n[1]=r[1],n[2]=r[2],n[3]=1+s,Vu(n,n))}})();(function(){var r=gn(),e=gn();return function(t,n,i,a,s,o){return Tf(r,n,s,o),Tf(e,i,a,o),Tf(t,r,e,2*o*(1-o)),t}})();(function(){var r=y_();return function(e,t,n,i){return r[0]=n[0],r[3]=n[1],r[6]=n[2],r[1]=i[0],r[4]=i[1],r[7]=i[2],r[2]=-t[0],r[5]=-t[1],r[8]=-t[2],Vu(e,YP(e,r))}})();function z1(){var r=new mn(2);return mn!=Float32Array&&(r[0]=0,r[1]=0),r}function ZP(r,e){return r[0]=e[0],r[1]=e[1],r}function JP(r,e,t){return r[0]=e,r[1]=t,r}function eR(r,e){var t=e[0],n=e[1],i=t*t+n*n;return i>0&&(i=1/Math.sqrt(i)),r[0]=e[0]*i,r[1]=e[1]*i,r}function tR(r,e){return r[0]*e[0]+r[1]*e[1]}function nR(r,e){return r[0]===e[0]&&r[1]===e[1]}(function(){var r=z1();return function(e,t,n,i,a,s){var o,A;for(t||(t=2),n||(n=0),i?A=Math.min(i*t+n,e.length):A=e.length,o=n;o<A;o+=t)r[0]=e[o],r[1]=e[o+1],a(r,r,s),e[o]=r[0],e[o+1]=r[1];return e}})();var al=function(r){return r!==null&&typeof r!="function"&&isFinite(r.length)},rR=function(r,e){return al(r)?r.indexOf(e)>-1:!1},iR=function(r,e){if(!al(r))return r;for(var t=[],n=0;n<r.length;n++){var i=r[n];e(i,n)&&t.push(i)}return t},aR=function(r,e){return e===void 0&&(e=[]),iR(r,function(t){return!rR(e,t)})};function Te(r){return typeof r=="function"}function ke(r){return r==null}function Mr(r){return Array.isArray(r)}const un=(function(r){var e=typeof r;return r!==null&&e==="object"||e==="function"});function D_(r,e){if(r){var t;if(Mr(r))for(var n=0,i=r.length;n<i&&(t=e(r[n],n),t!==!1);n++);else if(un(r)){for(var a in r)if(r.hasOwnProperty(a)&&(t=e(r[a],a),t===!1))break}}}var yw=function(r){return typeof r=="object"&&r!==null},sR={}.toString,H_=function(r,e){return sR.call(r)==="[object "+e+"]"},zo=function(r){if(!yw(r)||!H_(r,"Object"))return!1;if(Object.getPrototypeOf(r)===null)return!0;for(var e=r;Object.getPrototypeOf(e)!==null;)e=Object.getPrototypeOf(e);return Object.getPrototypeOf(r)===e},oR=function(r){if(!Mr(r))return[];for(var e=[],t=0;t<r.length;t++)e=e.concat(r[t]);return e};function ju(r){if(!Array.isArray(r))return-1/0;var e=r.length;if(!e)return-1/0;for(var t=r[0],n=1;n<e;n++)t=Math.max(t,r[n]);return t}const Wu=(function(r){if(Mr(r))return r.reduce(function(e,t){return Math.min(e,t)},r[0])});var AR=function(r,e,t){if(!Mr(r)&&!zo(r))return r;var n=t;return D_(r,function(i,a){n=e(n,i,a)}),n};function At(r){return typeof r=="string"}function lR(r,e){e===void 0&&(e=new Map);var t=[];if(Array.isArray(r))for(var n=0,i=r.length;n<i;n++){var a=r[n];e.has(a)||(t.push(a),e.set(a,!0))}return t}var cR=Object.prototype.hasOwnProperty;function Nh(r,e){if(!e||!Mr(r))return{};for(var t={},n=Te(e)?e:function(o){return o[e]},i,a=0;a<r.length;a++){var s=r[a];i=n(s),cR.call(t,i)?t[i].push(s):t[i]=[s]}return t}var Yt=function(r,e,t){return r<e?e:r>t?t:r};function Be(r){return typeof r=="number"}var uR=1e-5;function Lo(r,e,t){return t===void 0&&(t=uR),r===e||Math.abs(r-e)<t}const hR=(function(r,e){if(Mr(r)){for(var t,n=-1/0,i=0;i<r.length;i++){var a=r[i],s=Te(e)?e(a):a[e];s>n&&(t=a,n=s)}return t}}),dR=(function(r,e){if(Mr(r)){for(var t,n=1/0,i=0;i<r.length;i++){var a=r[i],s=Te(e)?e(a):a[e];s<n&&(t=a,n=s)}return t}});var G_=function(r,e){return(r%e+e)%e};const K_=(function(r){return ke(r)?"":r.toString()});var fR=function(r){var e=K_(r);return e.charAt(0).toLowerCase()+e.substring(1)};function gR(r,e){return!r||!e?r:r.replace(/\\?\{([^{}]+)\}/g,function(t,n){return t.charAt(0)==="\\"?t.slice(1):e[n]===void 0?"":e[n]})}var qu=function(r){var e=K_(r);return e.charAt(0).toUpperCase()+e.substring(1)},vR={}.toString,pR=function(r){return vR.call(r).replace(/^\[object /,"").replace(/]$/,"")},sl=function(r){return H_(r,"Boolean")};function yR(r){return r instanceof Date}function mR(r){return r===null}var wR=Object.prototype,BR=function(r){var e=r&&r.constructor,t=typeof e=="function"&&e.prototype||wR;return r===t},He=function(r){return r===void 0};function bR(r){return r instanceof Element||r instanceof Document}function xb(r,e){for(var t in e)e.hasOwnProperty(t)&&t!=="constructor"&&e[t]!==void 0&&(r[t]=e[t])}function ER(r,e,t,n){return e&&xb(r,e),t&&xb(r,t),r}var Za=function(r){if(typeof r!="object"||r===null)return r;var e;if(Mr(r)){e=[];for(var t=0,n=r.length;t<n;t++)typeof r[t]=="object"&&r[t]!=null?e[t]=Za(r[t]):e[t]=r[t]}else{e={};for(var i in r)typeof r[i]=="object"&&r[i]!=null?e[i]=Za(r[i]):e[i]=r[i]}return e};function Sl(r,e,t){var n;return function(){var i=this,a=arguments,s=function(){n=null,r.apply(i,a)};clearTimeout(n),n=setTimeout(s,e)}}function xR(r){var e,t,n,i=r||1;function a(o,A){++e>i&&(n=t,s(1),++e),t[o]=A}function s(o){e=0,t=Object.create(null),o||(n=Object.create(null))}return s(),{clear:s,has:function(o){return t[o]!==void 0||n[o]!==void 0},get:function(o){var A=t[o];if(A!==void 0)return A;if((A=n[o])!==void 0)return a(o,A),A},set:function(o,A){t[o]!==void 0?t[o]=A:a(o,A)}}}var Of=new Map;function mw(r,e,t){t===void 0&&(t=128);var n=function(){for(var i=[],a=0;a<arguments.length;a++)i[a]=arguments[a];var s=e?e.apply(this,i):i[0];Of.has(r)||Of.set(r,xR(t));var o=Of.get(r);if(o.has(s))return o.get(s);var A=r.apply(this,i);return o.set(s,A),A};return n}var CR=5;function SR(r,e){if(Object.hasOwn)return Object.hasOwn(r,e);if(r==null)throw new TypeError("Cannot convert undefined or null to object");return Object.prototype.hasOwnProperty.call(Object(r),e)}function z_(r,e,t,n){t=t||0,n=n||CR;for(var i in e)if(SR(e,i)){var a=e[i];a!==null&&zo(a)?(zo(r[i])||(r[i]={}),t<n?z_(r[i],a,t+1,n):r[i]=e[i]):Mr(a)?(r[i]=[],r[i]=r[i].concat(a)):a!==void 0&&(r[i]=a)}}var zn=function(r){for(var e=[],t=1;t<arguments.length;t++)e[t-1]=arguments[t];for(var n=0;n<e.length;n+=1)z_(r,e[n]);return r},FR=Object.prototype.hasOwnProperty;function Qi(r){if(ke(r))return!0;if(al(r))return!r.length;var e=pR(r);if(e==="Map"||e==="Set")return!r.size;if(BR(r))return!Object.keys(r).length;for(var t in r)if(FR.call(r,t))return!1;return!0}var Xt=function(r,e){if(r===e)return!0;if(!r||!e||At(r)||At(e))return!1;if(al(r)||al(e)){if(r.length!==e.length)return!1;for(var t=!0,n=0;n<r.length&&(t=Xt(r[n],e[n]),!!t);n++);return t}if(yw(r)||yw(e)){var i=Object.keys(r),a=Object.keys(e);if(i.length!==a.length)return!1;for(var t=!0,n=0;n<i.length&&(t=Xt(r[i[n]],e[i[n]]),!!t);n++);return t}return!1};const Rn=(function(r,e,t){for(var n=0,i=At(e)?e.split("."):e;r&&n<i.length;)r=r[i[n++]];return r===void 0||n<i.length?t:r}),ol=(function(r,e,t){var n=r,i=At(e)?e.split("."):e;return i.forEach(function(a,s){s<i.length-1?(un(n[a])||(n[a]=Be(i[s+1])?[]:{}),n=n[a]):n[a]=t}),r});var TR=Object.prototype.hasOwnProperty;const Ds=(function(r,e){if(r===null||!zo(r))return{};var t={};return D_(e,function(n){TR.call(r,n)&&(t[n]=r[n])}),t}),V1=(function(r,e){return AR(r,function(t,n,i){return e.includes(i)||(t[i]=n),t},{})}),V_=(function(r,e,t){var n,i,a,s,o=0;t||(t={});var A=function(){o=t.leading===!1?0:Date.now(),n=null,s=r.apply(i,a),n||(i=a=null)},l=function(){var c=Date.now();!o&&t.leading===!1&&(o=c);var u=e-(c-o);return i=this,a=arguments,u<=0||u>e?(n&&(clearTimeout(n),n=null),o=c,s=r.apply(i,a),n||(i=a=null)):!n&&t.trailing!==!1&&(n=setTimeout(A,u)),s};return l.cancel=function(){clearTimeout(n),o=0,n=i=a=null},l});var ac={};const MR=(function(r){return r=r||"g",ac[r]?ac[r]+=1:ac[r]=1,r+ac[r]}),_f=(function(){}),ww=(function(r){return r});var Bw=function(r,e){return Bw=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,n){t.__proto__=n}||function(t,n){for(var i in n)Object.prototype.hasOwnProperty.call(n,i)&&(t[i]=n[i])},Bw(r,e)};function Xe(r,e){if(typeof e!="function"&&e!==null)throw new TypeError("Class extends value "+String(e)+" is not a constructor or null");Bw(r,e);function t(){this.constructor=r}r.prototype=e===null?Object.create(e):(t.prototype=e.prototype,new t)}var le=function(){return le=Object.assign||function(e){for(var t,n=1,i=arguments.length;n<i;n++){t=arguments[n];for(var a in t)Object.prototype.hasOwnProperty.call(t,a)&&(e[a]=t[a])}return e},le.apply(this,arguments)};function Dt(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t}function Je(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})}function Fl(r){var e=typeof Symbol=="function"&&Symbol.iterator,t=e&&r[e],n=0;if(t)return t.call(r);if(r&&typeof r.length=="number")return{next:function(){return r&&n>=r.length&&(r=void 0),{value:r&&r[n++],done:!r}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}function H(r,e){var t=typeof Symbol=="function"&&r[Symbol.iterator];if(!t)return r;var n=t.call(r),i,a=[],s;try{for(;(e===void 0||e-- >0)&&!(i=n.next()).done;)a.push(i.value)}catch(o){s={error:o}}finally{try{i&&!i.done&&(t=n.return)&&t.call(n)}finally{if(s)throw s.error}}return a}function OR(){for(var r=0,e=0,t=arguments.length;e<t;e++)r+=arguments[e].length;for(var n=Array(r),i=0,e=0;e<t;e++)for(var a=arguments[e],s=0,o=a.length;s<o;s++,i++)n[i]=a[s];return n}function _e(r,e,t){if(t||arguments.length===2)for(var n=0,i=e.length,a;n<i;n++)(a||!(n in e))&&(a||(a=Array.prototype.slice.call(e,0,n)),a[n]=e[n]);return r.concat(a||Array.prototype.slice.call(e))}function If(r,e,t,n){if(t==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?r!==e||!n:!e.has(r))throw new TypeError("Cannot read private member from an object whose class did not declare it");return t==="m"?n:t==="a"?n.call(r):n?n.value:e.get(r)}var j_={x1:0,y1:0,x2:0,y2:0,x:0,y:0,qx:null,qy:null};function _R(r,e,t){if(r[t].length>7){r[t].shift();for(var n=r[t],i=t;n.length;)e[t]="A",r.splice(i+=1,0,["C"].concat(n.splice(0,6)));r.splice(t,1)}}var $A={a:7,c:6,h:1,l:2,m:2,r:4,q:4,s:4,t:2,v:1,z:0};function W_(r){return Array.isArray(r)&&r.every(function(e){var t=e[0].toLowerCase();return $A[t]===e.length-1&&"achlmqstvz".includes(t)})}function q_(r){return W_(r)&&r.every(function(e){var t=e[0];return t===t.toUpperCase()})}function $_(r){return q_(r)&&r.every(function(e){var t=e[0];return"ACLMQZ".includes(t)})}function Cb(r){for(var e=r.pathValue[r.segmentStart],t=e.toLowerCase(),n=r.data;n.length>=$A[t]&&(t==="m"&&n.length>2?(r.segments.push([e].concat(n.splice(0,2))),t="l",e=e==="m"?"l":"L"):r.segments.push([e].concat(n.splice(0,$A[t]))),!!$A[t]););}function IR(r){var e=r.index,t=r.pathValue,n=t.charCodeAt(e);if(n===48){r.param=0,r.index+=1;return}if(n===49){r.param=1,r.index+=1;return}r.err='[path-util]: invalid Arc flag "'.concat(t[e],'", expecting 0 or 1 at index ').concat(e)}function kR(r){return r>=48&&r<=57||r===43||r===45||r===46}function so(r){return r>=48&&r<=57}function LR(r){var e=r.max,t=r.pathValue,n=r.index,i=n,a=!1,s=!1,o=!1,A=!1,l;if(i>=e){r.err="[path-util]: Invalid path value at index ".concat(i,', "pathValue" is missing param');return}if(l=t.charCodeAt(i),(l===43||l===45)&&(i+=1,l=t.charCodeAt(i)),!so(l)&&l!==46){r.err="[path-util]: Invalid path value at index ".concat(i,', "').concat(t[i],'" is not a number');return}if(l!==46){if(a=l===48,i+=1,l=t.charCodeAt(i),a&&i<e&&l&&so(l)){r.err="[path-util]: Invalid path value at index ".concat(n,', "').concat(t[n],'" illegal number');return}for(;i<e&&so(t.charCodeAt(i));)i+=1,s=!0;l=t.charCodeAt(i)}if(l===46){for(A=!0,i+=1;so(t.charCodeAt(i));)i+=1,o=!0;l=t.charCodeAt(i)}if(l===101||l===69){if(A&&!s&&!o){r.err="[path-util]: Invalid path value at index ".concat(i,', "').concat(t[i],'" invalid float exponent');return}if(i+=1,l=t.charCodeAt(i),(l===43||l===45)&&(i+=1),i<e&&so(t.charCodeAt(i)))for(;i<e&&so(t.charCodeAt(i));)i+=1;else{r.err="[path-util]: Invalid path value at index ".concat(i,', "').concat(t[i],'" invalid integer exponent');return}}r.index=i,r.param=+r.pathValue.slice(n,i)}function QR(r){var e=[5760,6158,8192,8193,8194,8195,8196,8197,8198,8199,8200,8201,8202,8239,8287,12288,65279];return r===10||r===13||r===8232||r===8233||r===32||r===9||r===11||r===12||r===160||r>=5760&&e.includes(r)}function Su(r){for(var e=r.pathValue,t=r.max;r.index<t&&QR(e.charCodeAt(r.index));)r.index+=1}function NR(r){switch(r|32){case 109:case 122:case 108:case 104:case 118:case 99:case 115:case 113:case 116:case 97:return!0;default:return!1}}function UR(r){return(r|32)===97}function PR(r){var e=r.max,t=r.pathValue,n=r.index,i=t.charCodeAt(n),a=$A[t[n].toLowerCase()];if(r.segmentStart=n,!NR(i)){r.err='[path-util]: Invalid path value "'.concat(t[n],'" is not a path command');return}if(r.index+=1,Su(r),r.data=[],!a){Cb(r);return}for(;;){for(var s=a;s>0;s-=1){if(UR(i)&&(s===3||s===4)?IR(r):LR(r),r.err.length)return;r.data.push(r.param),Su(r),r.index<e&&t.charCodeAt(r.index)===44&&(r.index+=1,Su(r))}if(r.index>=r.max||!kR(t.charCodeAt(r.index)))break}Cb(r)}var RR=(function(){function r(e){this.pathValue=e,this.segments=[],this.max=e.length,this.index=0,this.param=0,this.segmentStart=0,this.data=[],this.err=""}return r})();function DR(r){if(W_(r))return[].concat(r);var e=new RR(r);for(Su(e);e.index<e.max&&!e.err.length;)PR(e);return e.err?e.err:e.segments}function HR(r){if(q_(r))return[].concat(r);var e=DR(r),t=0,n=0,i=0,a=0;return e.map(function(s){var o=s.slice(1).map(Number),A=s[0],l=A.toUpperCase();if(A==="M")return t=o[0],n=o[1],i=t,a=n,["M",t,n];var c;if(A!==l)switch(l){case"A":c=[l,o[0],o[1],o[2],o[3],o[4],o[5]+t,o[6]+n];break;case"V":c=[l,o[0]+n];break;case"H":c=[l,o[0]+t];break;default:{var u=o.map(function(d,f){return d+(f%2?n:t)});c=[l].concat(u)}}else c=[l].concat(o);var h=c.length;switch(l){case"Z":t=i,n=a;break;case"H":t=c[1];break;case"V":n=c[1];break;default:t=c[h-2],n=c[h-1],l==="M"&&(i=t,a=n)}return c})}function GR(r,e){var t=r[0],n=e.x1,i=e.y1,a=e.x2,s=e.y2,o=r.slice(1).map(Number),A=r;if("TQ".includes(t)||(e.qx=null,e.qy=null),t==="H")A=["L",r[1],i];else if(t==="V")A=["L",n,r[1]];else if(t==="S"){var l=n*2-a,c=i*2-s;e.x1=l,e.y1=c,A=["C",l,c].concat(o)}else if(t==="T"){var u=n*2-e.qx,h=i*2-e.qy;e.qx=u,e.qy=h,A=["Q",u,h].concat(o)}else if(t==="Q"){var d=o[0],f=o[1];e.qx=d,e.qy=f}return A}function $u(r){if($_(r))return[].concat(r);for(var e=HR(r),t=le({},j_),n=0;n<e.length;n+=1){e[n]=GR(e[n],t);var i=e[n],a=i.length;t.x1=+i[a-2],t.y1=+i[a-1],t.x2=+i[a-4]||t.x1,t.y2=+i[a-3]||t.y1}return e}function KR(r){return $_(r)&&r.every(function(e){var t=e[0];return"MC".includes(t)})}function sc(r,e,t){var n=r*Math.cos(t)-e*Math.sin(t),i=r*Math.sin(t)+e*Math.cos(t);return{x:n,y:i}}function j1(r,e,t,n,i,a,s,o,A,l){var c=r,u=e,h=t,d=n,f=o,g=A,v=Math.PI*120/180,p=Math.PI/180*(+i||0),y=[],m,B,C,S,F;if(l)B=l[0],C=l[1],S=l[2],F=l[3];else{m=sc(c,u,-p),c=m.x,u=m.y,m=sc(f,g,-p),f=m.x,g=m.y;var T=(c-f)/2,O=(u-g)/2,_=T*T/(h*h)+O*O/(d*d);_>1&&(_=Math.sqrt(_),h*=_,d*=_);var k=h*h,L=d*d,U=(a===s?-1:1)*Math.sqrt(Math.abs((k*L-k*O*O-L*T*T)/(k*O*O+L*T*T)));S=U*h*O/d+(c+f)/2,F=U*-d*T/h+(u+g)/2,B=Math.asin(((u-F)/d*Math.pow(10,9)>>0)/Math.pow(10,9)),C=Math.asin(((g-F)/d*Math.pow(10,9)>>0)/Math.pow(10,9)),B=c<S?Math.PI-B:B,C=f<S?Math.PI-C:C,B<0&&(B=Math.PI*2+B),C<0&&(C=Math.PI*2+C),s&&B>C&&(B-=Math.PI*2),!s&&C>B&&(C-=Math.PI*2)}var G=C-B;if(Math.abs(G)>v){var W=C,V=f,K=g;C=B+v*(s&&C>B?1:-1),f=S+h*Math.cos(C),g=F+d*Math.sin(C),y=j1(f,g,h,d,i,0,s,V,K,[C,W,S,F])}G=C-B;var D=Math.cos(B),X=Math.sin(B),te=Math.cos(C),ie=Math.sin(C),re=Math.tan(G/4),xe=4/3*h*re,$=4/3*d*re,z=[c,u],ee=[c+xe*X,u-$*D],Ae=[f+xe*ie,g-$*te],be=[f,g];if(ee[0]=2*z[0]-ee[0],ee[1]=2*z[1]-ee[1],l)return ee.concat(Ae,be,y);y=ee.concat(Ae,be,y);for(var Le=[],Ue=0,at=y.length;Ue<at;Ue+=1)Le[Ue]=Ue%2?sc(y[Ue-1],y[Ue],p).y:sc(y[Ue],y[Ue+1],p).x;return Le}function zR(r,e,t,n,i,a){var s=.3333333333333333,o=2/3;return[s*r+o*t,s*e+o*n,s*i+o*t,s*a+o*n,i,a]}function Ma(r,e,t){var n=r[0],i=r[1],a=e[0],s=e[1];return[n+(a-n)*t,i+(s-i)*t]}var Sb=function(r,e,t,n){var i=.5,a=Ma([r,e],[t,n],i);return _e(_e([],a,!0),[t,n,t,n],!1)};function VR(r,e){var t=r[0],n=r.slice(1).map(Number),i=n[0],a=n[1],s,o=e.x1,A=e.y1,l=e.x,c=e.y;switch("TQ".includes(t)||(e.qx=null,e.qy=null),t){case"M":return e.x=i,e.y=a,r;case"A":return s=[o,A].concat(n),["C"].concat(j1(s[0],s[1],s[2],s[3],s[4],s[5],s[6],s[7],s[8],s[9]));case"Q":return e.qx=i,e.qy=a,s=[o,A].concat(n),["C"].concat(zR(s[0],s[1],s[2],s[3],s[4],s[5]));case"L":return["C"].concat(Sb(o,A,i,a));case"Z":return o===l&&A===c?["C",o,A,l,c,l,c]:["C"].concat(Sb(o,A,l,c))}return r}function bw(r,e){if(e===void 0&&(e=!1),KR(r)){var t=[].concat(r);return e?[t,[]]:t}for(var n=$u(r),i=le({},j_),a=[],s="",o=n.length,A,l,c=[],u=0;u<o;u+=1){n[u]&&(s=n[u][0]),a[u]=s;var h=VR(n[u],i);n[u]=h,_R(n,a,u),o=n.length,s==="Z"&&c.push(u),A=n[u],l=A.length,i.x1=+A[l-2],i.y1=+A[l-1],i.x2=+A[l-4]||i.x1,i.y2=+A[l-3]||i.y1}return e?[n,c]:n}function jR(r){return r.map(function(e){return Array.isArray(e)?[].concat(e):e})}function WR(r){var e=r.slice(1).map(function(t,n,i){return n?i[n-1].slice(-2).concat(t.slice(1)):r[0].slice(1).concat(t.slice(1))}).map(function(t){return t.map(function(n,i){return t[t.length-i-2*(1-i%2)]})}).reverse();return[["M"].concat(e[0].slice(0,2))].concat(e.map(function(t){return["C"].concat(t.slice(2))}))}function wr(r,e){return Math.sqrt((r[0]-e[0])*(r[0]-e[0])+(r[1]-e[1])*(r[1]-e[1]))}function Ew(r,e,t,n,i){var a=wr([r,e],[t,n]),s={x:0,y:0};if(typeof i=="number")if(i<=0)s={x:r,y:e};else if(i>=a)s={x:t,y:n};else{var o=Ma([r,e],[t,n],i/a),A=o[0],l=o[1];s={x:A,y:l}}return{length:a,point:s,min:{x:Math.min(r,t),y:Math.min(e,n)},max:{x:Math.max(r,t),y:Math.max(e,n)}}}function Fb(r,e){var t=r.x,n=r.y,i=e.x,a=e.y,s=t*i+n*a,o=Math.sqrt((Math.pow(t,2)+Math.pow(n,2))*(Math.pow(i,2)+Math.pow(a,2))),A=t*a-n*i<0?-1:1,l=A*Math.acos(s/o);return l}function qR(r,e,t,n,i,a,s,o,A,l){var c=Math.abs,u=Math.sin,h=Math.cos,d=Math.sqrt,f=Math.PI,g=c(t),v=c(n),p=(i%360+360)%360,y=p*(f/180);if(r===o&&e===A)return{x:r,y:e};if(g===0||v===0)return Ew(r,e,o,A,l).point;var m=(r-o)/2,B=(e-A)/2,C={x:h(y)*m+u(y)*B,y:-u(y)*m+h(y)*B},S=Math.pow(C.x,2)/Math.pow(g,2)+Math.pow(C.y,2)/Math.pow(v,2);S>1&&(g*=d(S),v*=d(S));var F=Math.pow(g,2)*Math.pow(v,2)-Math.pow(g,2)*Math.pow(C.y,2)-Math.pow(v,2)*Math.pow(C.x,2),T=Math.pow(g,2)*Math.pow(C.y,2)+Math.pow(v,2)*Math.pow(C.x,2),O=F/T;O=O<0?0:O;var _=(a!==s?1:-1)*d(O),k={x:_*(g*C.y/v),y:_*(-(v*C.x)/g)},L={x:h(y)*k.x-u(y)*k.y+(r+o)/2,y:u(y)*k.x+h(y)*k.y+(e+A)/2},U={x:(C.x-k.x)/g,y:(C.y-k.y)/v},G=Fb({x:1,y:0},U),W={x:(-C.x-k.x)/g,y:(-C.y-k.y)/v},V=Fb(U,W);!s&&V>0?V-=2*f:s&&V<0&&(V+=2*f),V%=2*f;var K=G+V*l,D=g*h(K),X=v*u(K),te={x:h(y)*D-u(y)*X+L.x,y:u(y)*D+h(y)*X+L.y};return te}function $R(r,e,t,n,i,a,s,o,A,l,c){var u,h=c.bbox,d=h===void 0?!0:h,f=c.length,g=f===void 0?!0:f,v=c.sampleSize,p=v===void 0?30:v,y=typeof l=="number",m=r,B=e,C=0,S=[m,B,C],F=[m,B],T=0,O={x:0,y:0},_=[{x:m,y:B}];y&&l<=0&&(O={x:m,y:B});for(var k=0;k<=p;k+=1){if(T=k/p,u=qR(r,e,t,n,i,a,s,o,A,T),m=u.x,B=u.y,d&&_.push({x:m,y:B}),g&&(C+=wr(F,[m,B])),F=[m,B],y&&C>=l&&l>S[2]){var L=(C-l)/(C-S[2]);O={x:F[0]*(1-L)+S[0]*L,y:F[1]*(1-L)+S[1]*L}}S=[m,B,C]}return y&&l>=C&&(O={x:o,y:A}),{length:C,point:O,min:{x:Math.min.apply(null,_.map(function(U){return U.x})),y:Math.min.apply(null,_.map(function(U){return U.y}))},max:{x:Math.max.apply(null,_.map(function(U){return U.x})),y:Math.max.apply(null,_.map(function(U){return U.y}))}}}function YR(r,e,t,n,i,a,s,o,A){var l=1-A;return{x:Math.pow(l,3)*r+3*Math.pow(l,2)*A*t+3*l*Math.pow(A,2)*i+Math.pow(A,3)*s,y:Math.pow(l,3)*e+3*Math.pow(l,2)*A*n+3*l*Math.pow(A,2)*a+Math.pow(A,3)*o}}function Y_(r,e,t,n,i,a,s,o,A,l){var c,u=l.bbox,h=u===void 0?!0:u,d=l.length,f=d===void 0?!0:d,g=l.sampleSize,v=g===void 0?10:g,p=typeof A=="number",y=r,m=e,B=0,C=[y,m,B],S=[y,m],F=0,T={x:0,y:0},O=[{x:y,y:m}];p&&A<=0&&(T={x:y,y:m});for(var _=0;_<=v;_+=1){if(F=_/v,c=YR(r,e,t,n,i,a,s,o,F),y=c.x,m=c.y,h&&O.push({x:y,y:m}),f&&(B+=wr(S,[y,m])),S=[y,m],p&&B>=A&&A>C[2]){var k=(B-A)/(B-C[2]);T={x:S[0]*(1-k)+C[0]*k,y:S[1]*(1-k)+C[1]*k}}C=[y,m,B]}return p&&A>=B&&(T={x:s,y:o}),{length:B,point:T,min:{x:Math.min.apply(null,O.map(function(L){return L.x})),y:Math.min.apply(null,O.map(function(L){return L.y}))},max:{x:Math.max.apply(null,O.map(function(L){return L.x})),y:Math.max.apply(null,O.map(function(L){return L.y}))}}}function XR(r,e,t,n,i,a,s){var o=1-s;return{x:Math.pow(o,2)*r+2*o*s*t+Math.pow(s,2)*i,y:Math.pow(o,2)*e+2*o*s*n+Math.pow(s,2)*a}}function ZR(r,e,t,n,i,a,s,o){var A,l=o.bbox,c=l===void 0?!0:l,u=o.length,h=u===void 0?!0:u,d=o.sampleSize,f=d===void 0?10:d,g=typeof s=="number",v=r,p=e,y=0,m=[v,p,y],B=[v,p],C=0,S={x:0,y:0},F=[{x:v,y:p}];g&&s<=0&&(S={x:v,y:p});for(var T=0;T<=f;T+=1){if(C=T/f,A=XR(r,e,t,n,i,a,C),v=A.x,p=A.y,c&&F.push({x:v,y:p}),h&&(y+=wr(B,[v,p])),B=[v,p],g&&y>=s&&s>m[2]){var O=(y-s)/(y-m[2]);S={x:B[0]*(1-O)+m[0]*O,y:B[1]*(1-O)+m[1]*O}}m=[v,p,y]}return g&&s>=y&&(S={x:i,y:a}),{length:y,point:S,min:{x:Math.min.apply(null,F.map(function(_){return _.x})),y:Math.min.apply(null,F.map(function(_){return _.y}))},max:{x:Math.max.apply(null,F.map(function(_){return _.x})),y:Math.max.apply(null,F.map(function(_){return _.y}))}}}function X_(r,e,t){for(var n,i,a,s,o,A,l=$u(r),c=typeof e=="number",u,h=[],d,f=0,g=0,v=0,p=0,y,m=[],B=[],C=0,S={x:0,y:0},F=S,T=S,O=S,_=0,k=0,L=l.length;k<L;k+=1)y=l[k],d=y[0],u=d==="M",h=u?h:[f,g].concat(y.slice(1)),u?(v=y[1],p=y[2],S={x:v,y:p},F=S,C=0,c&&e<.001&&(O=S)):d==="L"?(n=Ew(h[0],h[1],h[2],h[3],(e||0)-_),C=n.length,S=n.min,F=n.max,T=n.point):d==="A"?(i=$R(h[0],h[1],h[2],h[3],h[4],h[5],h[6],h[7],h[8],(e||0)-_,t||{}),C=i.length,S=i.min,F=i.max,T=i.point):d==="C"?(a=Y_(h[0],h[1],h[2],h[3],h[4],h[5],h[6],h[7],(e||0)-_,t||{}),C=a.length,S=a.min,F=a.max,T=a.point):d==="Q"?(s=ZR(h[0],h[1],h[2],h[3],h[4],h[5],(e||0)-_,t||{}),C=s.length,S=s.min,F=s.max,T=s.point):d==="Z"&&(h=[f,g,v,p],o=Ew(h[0],h[1],h[2],h[3],(e||0)-_),C=o.length,S=o.min,F=o.max,T=o.point),c&&_<e&&_+C>=e&&(O=T),B.push(F),m.push(S),_+=C,A=d!=="Z"?y.slice(-2):[v,p],f=A[0],g=A[1];return c&&e>=_&&(O={x:f,y:g}),{length:_,point:O,min:{x:Math.min.apply(null,m.map(function(U){return U.x})),y:Math.min.apply(null,m.map(function(U){return U.y}))},max:{x:Math.max.apply(null,B.map(function(U){return U.x})),y:Math.max.apply(null,B.map(function(U){return U.y}))}}}function JR(r,e){return X_(r,void 0,le(le({},e),{bbox:!1,length:!0})).length}function eD(r){var e=r.length,t=e-1;return r.map(function(n,i){return r.map(function(a,s){var o=i+s,A;return s===0||r[o]&&r[o][0]==="M"?(A=r[o],["M"].concat(A.slice(-2))):(o>=e&&(o-=t),r[o])})})}function tD(r,e){var t=r.length-1,n=[],i=0,a=0,s=eD(r);return s.forEach(function(o,A){r.slice(1).forEach(function(l,c){a+=wr(r[(A+c)%t].slice(-2),e[c%t].slice(-2))}),n[A]=a,a=0}),i=n.indexOf(Math.min.apply(null,n)),s[i]}function nD(r,e,t,n,i,a,s,o){return 3*((o-e)*(t+i)-(s-r)*(n+a)+n*(r-i)-t*(e-a)+o*(i+r/3)-s*(a+e/3))/20}function rD(r){var e=0,t=0,n=0;return bw(r).map(function(i){var a;if(i[0]==="M")return e=i[1],t=i[2],0;var s=i.slice(1),o=s[0],A=s[1],l=s[2],c=s[3],u=s[4],h=s[5];return n=nD(e,t,o,A,l,c,u,h),a=i.slice(-2),e=a[0],t=a[1],n}).reduce(function(i,a){return i+a},0)}function Tb(r){return rD(r)>=0}function iD(r,e,t){return X_(r,e,le(le({},t),{bbox:!1,length:!0})).point}var aD=50;function sD(r,e){e===void 0&&(e=.5);var t=r.slice(0,2),n=r.slice(2,4),i=r.slice(4,6),a=r.slice(6,8),s=Ma(t,n,e),o=Ma(n,i,e),A=Ma(i,a,e),l=Ma(s,o,e),c=Ma(o,A,e),u=Ma(l,c,e);return[["C"].concat(s,l,u),["C"].concat(c,A,a)]}function Mb(r){return r.map(function(e,t,n){var i=t&&n[t-1].slice(-2).concat(e.slice(1)),a=t?Y_(i[0],i[1],i[2],i[3],i[4],i[5],i[6],i[7],i[8],{bbox:!1}).length:0,s;return t?s=a?sD(i):[e,e]:s=[e],{s:e,ss:s,l:a}})}function Z_(r,e,t,n){if(n===void 0&&(n=0),n>aD)return console.warn("Maximum recursion depth reached in equalizeSegments"),[r,e];var i=Mb(r),a=Mb(e),s=i.length,o=a.length,A=i.filter(function(p){return p.l}).length,l=a.filter(function(p){return p.l}).length,c=i.filter(function(p){return p.l}).reduce(function(p,y){var m=y.l;return p+m},0)/A||0,u=a.filter(function(p){return p.l}).reduce(function(p,y){var m=y.l;return p+m},0)/l||0,h=t||Math.max(s,o),d=[c,u],f=[h-s,h-o],g=0,v=[i,a].map(function(p,y){return p.l===h?p.map(function(m){return m.s}):p.map(function(m,B){return g=B&&f[y]&&m.l>=d[y],f[y]-=g?1:0,g?m.ss:[m.s]}).flat()});return v[0].length===v[1].length?v:Z_(v[0],v[1],h,n+1)}function xw(r){var e=document.createElement("div");e.innerHTML=r;var t=e.childNodes[0];return t&&e.contains(t)&&e.removeChild(t),t}function oD(r,e){for(;!{}.hasOwnProperty.call(r,e)&&(r=Ho(r))!==null;);return r}function Cw(){return Cw=typeof Reflect<"u"&&Reflect.get?Reflect.get.bind():function(r,e,t){var n=oD(r,e);if(n){var i=Object.getOwnPropertyDescriptor(n,e);return i.get?i.get.call(arguments.length<3?r:t):i.value}},Cw.apply(null,arguments)}function Yu(r,e,t,n){var i=Cw(Ho(r.prototype),e,t);return typeof i=="function"?function(a){return i.apply(t,a)}:i}function da(r,e,t,n){var i=r-t,a=e-n;return Math.sqrt(i*i+a*a)}function J_(r,e){var t=Math.min.apply(Math,tt(r)),n=Math.min.apply(Math,tt(e)),i=Math.max.apply(Math,tt(r)),a=Math.max.apply(Math,tt(e));return{x:t,y:n,width:i-t,height:a-n}}function AD(r,e,t){return Math.atan(-e/r*Math.tan(t))}function lD(r,e,t){return Math.atan(e/(r*Math.tan(t)))}function cD(r,e,t,n,i,a){return t*Math.cos(i)*Math.cos(a)-n*Math.sin(i)*Math.sin(a)+r}function uD(r,e,t,n,i,a){return t*Math.sin(i)*Math.cos(a)+n*Math.cos(i)*Math.sin(a)+e}function hD(r,e,t,n,i,a,s){for(var o=AD(t,n,i),A=1/0,l=-1/0,c=[a,s],u=-Math.PI*2;u<=Math.PI*2;u+=Math.PI){var h=o+u;a<s?a<h&&h<s&&c.push(h):s<h&&h<a&&c.push(h)}for(var d=0;d<c.length;d++){var f=cD(r,e,t,n,i,c[d]);f<A&&(A=f),f>l&&(l=f)}for(var g=lD(t,n,i),v=1/0,p=-1/0,y=[a,s],m=-Math.PI*2;m<=Math.PI*2;m+=Math.PI){var B=g+m;a<s?a<B&&B<s&&y.push(B):s<B&&B<a&&y.push(B)}for(var C=0;C<y.length;C++){var S=uD(r,e,t,n,i,y[C]);S<v&&(v=S),S>p&&(p=S)}return{x:A,y:v,width:l-A,height:p-v}}var dD=1e-4;function eI(r,e,t,n,i,a){var s=-1,o=1/0,A=[t,n],l=20;a&&a>200&&(l=a/10);for(var c=1/l,u=c/10,h=0;h<=l;h++){var d=h*c,f=[i.apply(void 0,tt(r.concat([d]))),i.apply(void 0,tt(e.concat([d])))],g=da(A[0],A[1],f[0],f[1]);g<o&&(s=d,o=g)}if(s===0)return{x:r[0],y:e[0]};if(s===1){var v=r.length;return{x:r[v-1],y:e[v-1]}}o=1/0;for(var p=0;p<32&&!(u<dD);p++){var y=s-u,m=s+u,B=[i.apply(void 0,tt(r.concat([y]))),i.apply(void 0,tt(e.concat([y])))],C=da(A[0],A[1],B[0],B[1]);if(y>=0&&C<o)s=y,o=C;else{var S=[i.apply(void 0,tt(r.concat([m]))),i.apply(void 0,tt(e.concat([m])))],F=da(A[0],A[1],S[0],S[1]);m<=1&&F<o?(s=m,o=F):u*=.5}}return{x:i.apply(void 0,tt(r.concat([s]))),y:i.apply(void 0,tt(e.concat([s])))}}function tI(r,e,t,n){return da(r,e,t,n)}function nI(r,e,t,n,i){return{x:(1-i)*r+i*t,y:(1-i)*e+i*n}}function fD(r,e,t,n,i,a){var s=[t-r,n-e];if(nR(s,[0,0]))return Math.sqrt((i-r)*(i-r)+(a-e)*(a-e));var o=[-s[1],s[0]];eR(o,o);var A=[i-r,a-e];return Math.abs(tR(A,o))}function Sw(r,e,t,n,i){var a=1-i;return a*a*a*r+3*e*i*a*a+3*t*i*i*a+n*i*i*i}function Ob(r,e,t,n){var i=-3*r+9*e-9*t+3*n,a=6*r-12*e+6*t,s=3*e-3*r,o=[],A,l,c;if(Lo(i,0))Lo(a,0)||(A=-s/a,A>=0&&A<=1&&o.push(A));else{var u=a*a-4*i*s;Lo(u,0)?o.push(-a/(2*i)):u>0&&(c=Math.sqrt(u),A=(-a+c)/(2*i),l=(-a-c)/(2*i),A>=0&&A<=1&&o.push(A),l>=0&&l<=1&&o.push(l))}return o}function gD(r,e,t,n,i,a,s,o){for(var A=[r,s],l=[e,o],c=Ob(r,t,i,s),u=Ob(e,n,a,o),h=0;h<c.length;h++)A.push(Sw(r,t,i,s,c[h]));for(var d=0;d<u.length;d++)l.push(Sw(e,n,a,o,u[d]));return J_(A,l)}function vD(r,e,t,n,i,a,s,o,A,l,c){return eI([r,t,i,s],[e,n,a,o],A,l,Sw,c)}function _b(r,e,t,n,i,a,s,o,A,l,c){var u=vD(r,e,t,n,i,a,s,o,A,l,c);return da(u.x,u.y,A,l)}function pD(r){if(r.length<2)return 0;for(var e=0,t=0;t<r.length-1;t++){var n=r[t],i=r[t+1];e+=da(n[0],n[1],i[0],i[1])}return e}function yD(r){return pD(r)}function Fw(r,e,t,n){var i=1-n;return i*i*r+2*n*i*e+n*n*t}function Ib(r,e,t){var n=r+t-2*e;if(Lo(n,0))return[.5];var i=(r-e)/n;return i<=1&&i>=0?[i]:[]}function mD(r,e,t,n,i,a){var s=Ib(r,t,i)[0],o=Ib(e,n,a)[0],A=[r,i],l=[e,a];return s!==void 0&&A.push(Fw(r,t,i,s)),o!==void 0&&l.push(Fw(e,n,a,o)),J_(A,l)}function wD(r,e,t,n,i,a,s,o){return eI([r,t,i],[e,n,a],s,o,Fw)}function BD(r,e,t,n,i,a,s,o){var A=wD(r,e,t,n,i,a,s,o);return da(A.x,A.y,s,o)}function Gn(){Gn=function(){return e};var r,e={},t=Object.prototype,n=t.hasOwnProperty,i=Object.defineProperty||function(V,K,D){V[K]=D.value},a=typeof Symbol=="function"?Symbol:{},s=a.iterator||"@@iterator",o=a.asyncIterator||"@@asyncIterator",A=a.toStringTag||"@@toStringTag";function l(V,K,D){return Object.defineProperty(V,K,{value:D,enumerable:!0,configurable:!0,writable:!0}),V[K]}try{l({},"")}catch{l=function(D,X,te){return D[X]=te}}function c(V,K,D,X){var te=K&&K.prototype instanceof p?K:p,ie=Object.create(te.prototype),re=new G(X||[]);return i(ie,"_invoke",{value:_(V,D,re)}),ie}function u(V,K,D){try{return{type:"normal",arg:V.call(K,D)}}catch(X){return{type:"throw",arg:X}}}e.wrap=c;var h="suspendedStart",d="suspendedYield",f="executing",g="completed",v={};function p(){}function y(){}function m(){}var B={};l(B,s,function(){return this});var C=Object.getPrototypeOf,S=C&&C(C(W([])));S&&S!==t&&n.call(S,s)&&(B=S);var F=m.prototype=p.prototype=Object.create(B);function T(V){["next","throw","return"].forEach(function(K){l(V,K,function(D){return this._invoke(K,D)})})}function O(V,K){function D(te,ie,re,xe){var $=u(V[te],V,ie);if($.type!=="throw"){var z=$.arg,ee=z.value;return ee&&Ya(ee)=="object"&&n.call(ee,"__await")?K.resolve(ee.__await).then(function(Ae){D("next",Ae,re,xe)},function(Ae){D("throw",Ae,re,xe)}):K.resolve(ee).then(function(Ae){z.value=Ae,re(z)},function(Ae){return D("throw",Ae,re,xe)})}xe($.arg)}var X;i(this,"_invoke",{value:function(ie,re){function xe(){return new K(function($,z){D(ie,re,$,z)})}return X=X?X.then(xe,xe):xe()}})}function _(V,K,D){var X=h;return function(te,ie){if(X===f)throw Error("Generator is already running");if(X===g){if(te==="throw")throw ie;return{value:r,done:!0}}for(D.method=te,D.arg=ie;;){var re=D.delegate;if(re){var xe=k(re,D);if(xe){if(xe===v)continue;return xe}}if(D.method==="next")D.sent=D._sent=D.arg;else if(D.method==="throw"){if(X===h)throw X=g,D.arg;D.dispatchException(D.arg)}else D.method==="return"&&D.abrupt("return",D.arg);X=f;var $=u(V,K,D);if($.type==="normal"){if(X=D.done?g:d,$.arg===v)continue;return{value:$.arg,done:D.done}}$.type==="throw"&&(X=g,D.method="throw",D.arg=$.arg)}}}function k(V,K){var D=K.method,X=V.iterator[D];if(X===r)return K.delegate=null,D==="throw"&&V.iterator.return&&(K.method="return",K.arg=r,k(V,K),K.method==="throw")||D!=="return"&&(K.method="throw",K.arg=new TypeError("The iterator does not provide a '"+D+"' method")),v;var te=u(X,V.iterator,K.arg);if(te.type==="throw")return K.method="throw",K.arg=te.arg,K.delegate=null,v;var ie=te.arg;return ie?ie.done?(K[V.resultName]=ie.value,K.next=V.nextLoc,K.method!=="return"&&(K.method="next",K.arg=r),K.delegate=null,v):ie:(K.method="throw",K.arg=new TypeError("iterator result is not an object"),K.delegate=null,v)}function L(V){var K={tryLoc:V[0]};1 in V&&(K.catchLoc=V[1]),2 in V&&(K.finallyLoc=V[2],K.afterLoc=V[3]),this.tryEntries.push(K)}function U(V){var K=V.completion||{};K.type="normal",delete K.arg,V.completion=K}function G(V){this.tryEntries=[{tryLoc:"root"}],V.forEach(L,this),this.reset(!0)}function W(V){if(V||V===""){var K=V[s];if(K)return K.call(V);if(typeof V.next=="function")return V;if(!isNaN(V.length)){var D=-1,X=function te(){for(;++D<V.length;)if(n.call(V,D))return te.value=V[D],te.done=!1,te;return te.value=r,te.done=!0,te};return X.next=X}}throw new TypeError(Ya(V)+" is not iterable")}return y.prototype=m,i(F,"constructor",{value:m,configurable:!0}),i(m,"constructor",{value:y,configurable:!0}),y.displayName=l(m,A,"GeneratorFunction"),e.isGeneratorFunction=function(V){var K=typeof V=="function"&&V.constructor;return!!K&&(K===y||(K.displayName||K.name)==="GeneratorFunction")},e.mark=function(V){return Object.setPrototypeOf?Object.setPrototypeOf(V,m):(V.__proto__=m,l(V,A,"GeneratorFunction")),V.prototype=Object.create(F),V},e.awrap=function(V){return{__await:V}},T(O.prototype),l(O.prototype,o,function(){return this}),e.AsyncIterator=O,e.async=function(V,K,D,X,te){te===void 0&&(te=Promise);var ie=new O(c(V,K,D,X),te);return e.isGeneratorFunction(K)?ie:ie.next().then(function(re){return re.done?re.value:ie.next()})},T(F),l(F,A,"Generator"),l(F,s,function(){return this}),l(F,"toString",function(){return"[object Generator]"}),e.keys=function(V){var K=Object(V),D=[];for(var X in K)D.push(X);return D.reverse(),function te(){for(;D.length;){var ie=D.pop();if(ie in K)return te.value=ie,te.done=!1,te}return te.done=!0,te}},e.values=W,G.prototype={constructor:G,reset:function(K){if(this.prev=0,this.next=0,this.sent=this._sent=r,this.done=!1,this.delegate=null,this.method="next",this.arg=r,this.tryEntries.forEach(U),!K)for(var D in this)D.charAt(0)==="t"&&n.call(this,D)&&!isNaN(+D.slice(1))&&(this[D]=r)},stop:function(){this.done=!0;var K=this.tryEntries[0].completion;if(K.type==="throw")throw K.arg;return this.rval},dispatchException:function(K){if(this.done)throw K;var D=this;function X(z,ee){return re.type="throw",re.arg=K,D.next=z,ee&&(D.method="next",D.arg=r),!!ee}for(var te=this.tryEntries.length-1;te>=0;--te){var ie=this.tryEntries[te],re=ie.completion;if(ie.tryLoc==="root")return X("end");if(ie.tryLoc<=this.prev){var xe=n.call(ie,"catchLoc"),$=n.call(ie,"finallyLoc");if(xe&&$){if(this.prev<ie.catchLoc)return X(ie.catchLoc,!0);if(this.prev<ie.finallyLoc)return X(ie.finallyLoc)}else if(xe){if(this.prev<ie.catchLoc)return X(ie.catchLoc,!0)}else{if(!$)throw Error("try statement without catch or finally");if(this.prev<ie.finallyLoc)return X(ie.finallyLoc)}}}},abrupt:function(K,D){for(var X=this.tryEntries.length-1;X>=0;--X){var te=this.tryEntries[X];if(te.tryLoc<=this.prev&&n.call(te,"finallyLoc")&&this.prev<te.finallyLoc){var ie=te;break}}ie&&(K==="break"||K==="continue")&&ie.tryLoc<=D&&D<=ie.finallyLoc&&(ie=null);var re=ie?ie.completion:{};return re.type=K,re.arg=D,ie?(this.method="next",this.next=ie.finallyLoc,v):this.complete(re)},complete:function(K,D){if(K.type==="throw")throw K.arg;return K.type==="break"||K.type==="continue"?this.next=K.arg:K.type==="return"?(this.rval=this.arg=K.arg,this.method="return",this.next="end"):K.type==="normal"&&D&&(this.next=D),v},finish:function(K){for(var D=this.tryEntries.length-1;D>=0;--D){var X=this.tryEntries[D];if(X.finallyLoc===K)return this.complete(X.completion,X.afterLoc),U(X),v}},catch:function(K){for(var D=this.tryEntries.length-1;D>=0;--D){var X=this.tryEntries[D];if(X.tryLoc===K){var te=X.completion;if(te.type==="throw"){var ie=te.arg;U(X)}return ie}}throw Error("illegal catch attempt")},delegateYield:function(K,D,X){return this.delegate={iterator:W(K),resultName:D,nextLoc:X},this.method==="next"&&(this.arg=r),v}},e}function kb(r,e,t,n,i,a,s){try{var o=r[a](s),A=o.value}catch(l){return void t(l)}o.done?e(A):Promise.resolve(A).then(n,i)}function Ja(r){return function(){var e=this,t=arguments;return new Promise(function(n,i){var a=r.apply(e,t);function s(A){kb(a,n,i,s,o,"next",A)}function o(A){kb(a,n,i,s,o,"throw",A)}s(void 0)})}}function ka(r,e){var t=typeof Symbol<"u"&&r[Symbol.iterator]||r["@@iterator"];if(!t){if(Array.isArray(r)||(t=G1(r))||e){t&&(r=t);var n=0,i=function(){};return{s:i,n:function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}},e:function(l){throw l},f:i}}throw new TypeError(`Invalid attempt to iterate non-iterable instance.
|
|
4
|
+
In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}var a,s=!0,o=!1;return{s:function(){t=t.call(r)},n:function(){var l=t.next();return s=l.done,l},e:function(l){o=!0,a=l},f:function(){try{s||t.return==null||t.return()}finally{if(o)throw a}}}}function bD(r,e){if(r==null)return{};var t={};for(var n in r)if({}.hasOwnProperty.call(r,n)){if(e.indexOf(n)!==-1)continue;t[n]=r[n]}return t}function Di(r,e){if(r==null)return{};var t,n,i=bD(r,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(r);for(n=0;n<a.length;n++)t=a[n],e.indexOf(t)===-1&&{}.propertyIsEnumerable.call(r,t)&&(i[t]=r[t])}return i}var ae=(function(r){return r.GROUP="g",r.FRAGMENT="fragment",r.CIRCLE="circle",r.ELLIPSE="ellipse",r.IMAGE="image",r.RECT="rect",r.LINE="line",r.POLYLINE="polyline",r.POLYGON="polygon",r.TEXT="text",r.PATH="path",r.HTML="html",r.MESH="mesh",r})({}),Fu=(function(r){return r[r.ZERO=0]="ZERO",r[r.NEGATIVE_ONE=1]="NEGATIVE_ONE",r})({}),rs=(function(){function r(){ue(this,r),this.plugins=[]}return he(r,[{key:"addRenderingPlugin",value:function(t){this.plugins.push(t),this.context.renderingPlugins.push(t)}},{key:"removeAllRenderingPlugins",value:function(){var t=this;this.plugins.forEach(function(n){var i=t.context.renderingPlugins.indexOf(n);i>=0&&t.context.renderingPlugins.splice(i,1)})}}])})(),ED=(function(){function r(e){ue(this,r),this.clipSpaceNearZ=Fu.NEGATIVE_ONE,this.plugins=[],this.config=De({enableDirtyCheck:!0,enableCulling:!1,enableAutoRendering:!0,enableDirtyRectangleRendering:!0,enableDirtyRectangleRenderingDebug:!1,enableSizeAttenuation:!0,enableRenderingOptimization:!1},e)}return he(r,[{key:"registerPlugin",value:function(t){var n=this.plugins.findIndex(function(i){return i===t});n===-1&&this.plugins.push(t)}},{key:"unregisterPlugin",value:function(t){var n=this.plugins.findIndex(function(i){return i===t});n>-1&&this.plugins.splice(n,1)}},{key:"getPlugins",value:function(){return this.plugins}},{key:"getPlugin",value:function(t){return this.plugins.find(function(n){return n.name===t})}},{key:"getConfig",value:function(){return this.config}},{key:"setConfig",value:function(t){Object.assign(this.config,t)}}])})(),kf=Va,oo=Ui,xD=KP,CD=GP,Lb=zu,Lf=U_,It=(function(){function r(){ue(this,r),this.center=[0,0,0],this.halfExtents=[0,0,0],this.min=[0,0,0],this.max=[0,0,0]}return he(r,[{key:"update",value:function(t,n){oo(this.center,t),oo(this.halfExtents,n),Lf(this.min,this.center,this.halfExtents),kf(this.max,this.center,this.halfExtents)}},{key:"setMinMax",value:function(t,n){kf(this.center,n,t),Lb(this.center,this.center,.5),Lf(this.halfExtents,n,t),Lb(this.halfExtents,this.halfExtents,.5),oo(this.min,t),oo(this.max,n)}},{key:"getMin",value:function(){return this.min}},{key:"getMax",value:function(){return this.max}},{key:"add",value:function(t){if(!r.isEmpty(t)){if(r.isEmpty(this)){this.setMinMax(t.getMin(),t.getMax());return}var n=this.center,i=n[0],a=n[1],s=n[2],o=this.halfExtents,A=o[0],l=o[1],c=o[2],u=i-A,h=i+A,d=a-l,f=a+l,g=s-c,v=s+c,p=t.center,y=p[0],m=p[1],B=p[2],C=t.halfExtents,S=C[0],F=C[1],T=C[2],O=y-S,_=y+S,k=m-F,L=m+F,U=B-T,G=B+T;O<u&&(u=O),_>h&&(h=_),k<d&&(d=k),L>f&&(f=L),U<g&&(g=U),G>v&&(v=G),n[0]=(u+h)*.5,n[1]=(d+f)*.5,n[2]=(g+v)*.5,o[0]=(h-u)*.5,o[1]=(f-d)*.5,o[2]=(v-g)*.5,this.min[0]=u,this.min[1]=d,this.min[2]=g,this.max[0]=h,this.max[1]=f,this.max[2]=v}}},{key:"setFromTransformedAABB",value:function(t,n){var i=this.center,a=this.halfExtents,s=t.center,o=t.halfExtents,A=n[0],l=n[4],c=n[8],u=n[1],h=n[5],d=n[9],f=n[2],g=n[6],v=n[10],p=Math.abs(A),y=Math.abs(l),m=Math.abs(c),B=Math.abs(u),C=Math.abs(h),S=Math.abs(d),F=Math.abs(f),T=Math.abs(g),O=Math.abs(v);i[0]=n[12]+A*s[0]+l*s[1]+c*s[2],i[1]=n[13]+u*s[0]+h*s[1]+d*s[2],i[2]=n[14]+f*s[0]+g*s[1]+v*s[2],a[0]=p*o[0]+y*o[1]+m*o[2],a[1]=B*o[0]+C*o[1]+S*o[2],a[2]=F*o[0]+T*o[1]+O*o[2],Lf(this.min,i,a),kf(this.max,i,a)}},{key:"intersects",value:function(t){var n=this.getMax(),i=this.getMin(),a=t.getMax(),s=t.getMin();return i[0]<=a[0]&&n[0]>=s[0]&&i[1]<=a[1]&&n[1]>=s[1]&&i[2]<=a[2]&&n[2]>=s[2]}},{key:"intersection",value:function(t){if(!this.intersects(t))return null;var n=new r,i=xD([0,0,0],this.getMin(),t.getMin()),a=CD([0,0,0],this.getMax(),t.getMax());return n.setMinMax(i,a),n}},{key:"getNegativeFarPoint",value:function(t){return t.pnVertexFlag===273?oo([0,0,0],this.min):t.pnVertexFlag===272?[this.min[0],this.min[1],this.max[2]]:t.pnVertexFlag===257?[this.min[0],this.max[1],this.min[2]]:t.pnVertexFlag===256?[this.min[0],this.max[1],this.max[2]]:t.pnVertexFlag===17?[this.max[0],this.min[1],this.min[2]]:t.pnVertexFlag===16?[this.max[0],this.min[1],this.max[2]]:t.pnVertexFlag===1?[this.max[0],this.max[1],this.min[2]]:[this.max[0],this.max[1],this.max[2]]}},{key:"getPositiveFarPoint",value:function(t){return t.pnVertexFlag===273?oo([0,0,0],this.max):t.pnVertexFlag===272?[this.max[0],this.max[1],this.min[2]]:t.pnVertexFlag===257?[this.max[0],this.min[1],this.max[2]]:t.pnVertexFlag===256?[this.max[0],this.min[1],this.min[2]]:t.pnVertexFlag===17?[this.min[0],this.max[1],this.max[2]]:t.pnVertexFlag===16?[this.min[0],this.max[1],this.min[2]]:t.pnVertexFlag===1?[this.min[0],this.min[1],this.max[2]]:[this.min[0],this.min[1],this.min[2]]}}],[{key:"isEmpty",value:function(t){return!t||t.halfExtents[0]===0&&t.halfExtents[1]===0&&t.halfExtents[2]===0}}])})(),SD=(function(){function r(e,t){ue(this,r),this.distance=e||0,this.normal=t||Ct(0,1,0),this.updatePNVertexFlag()}return he(r,[{key:"updatePNVertexFlag",value:function(){this.pnVertexFlag=(+(this.normal[0]>=0)<<8)+(+(this.normal[1]>=0)<<4)+ +(this.normal[2]>=0)}},{key:"distanceToPoint",value:function(t){return Pi(t,this.normal)-this.distance}},{key:"normalize",value:function(){var t=1/P_(this.normal);zu(this.normal,this.normal,t),this.distance*=t}},{key:"intersectsLine",value:function(t,n,i){var a=this.distanceToPoint(t),s=this.distanceToPoint(n),o=a/(a-s),A=o>=0&&o<=1;return A&&i&&pw(i,t,n,o),A}}])})(),Ao=(function(r){return r[r.OUTSIDE=4294967295]="OUTSIDE",r[r.INSIDE=0]="INSIDE",r[r.INDETERMINATE=2147483647]="INDETERMINATE",r})({}),FD=(function(){function r(e){if(ue(this,r),this.planes=[],e)this.planes=e;else for(var t=0;t<6;t++)this.planes.push(new SD)}return he(r,[{key:"extractFromVPMatrix",value:function(t){var n=We(t,16),i=n[0],a=n[1],s=n[2],o=n[3],A=n[4],l=n[5],c=n[6],u=n[7],h=n[8],d=n[9],f=n[10],g=n[11],v=n[12],p=n[13],y=n[14],m=n[15];er(this.planes[0].normal,o-i,u-A,g-h),this.planes[0].distance=m-v,er(this.planes[1].normal,o+i,u+A,g+h),this.planes[1].distance=m+v,er(this.planes[2].normal,o+a,u+l,g+d),this.planes[2].distance=m+p,er(this.planes[3].normal,o-a,u-l,g-d),this.planes[3].distance=m-p,er(this.planes[4].normal,o-s,u-c,g-f),this.planes[4].distance=m-y,er(this.planes[5].normal,o+s,u+c,g+f),this.planes[5].distance=m+y,this.planes.forEach(function(B){B.normalize(),B.updatePNVertexFlag()})}}])})(),Dn=(function(){function r(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:0,t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0;ue(this,r),this.x=0,this.y=0,this.x=e,this.y=t}return he(r,[{key:"clone",value:function(){return new r(this.x,this.y)}},{key:"copyFrom",value:function(t){this.x=t.x,this.y=t.y}}])})(),Vo=(function(){function r(e,t,n,i){ue(this,r),this.x=e,this.y=t,this.width=n,this.height=i,this.left=e,this.right=e+n,this.top=t,this.bottom=t+i}return he(r,[{key:"toJSON",value:function(){}}],[{key:"fromRect",value:function(t){return new r(t.x,t.y,t.width,t.height)}},{key:"applyTransform",value:function(t,n){var i=TA(t.x,t.y,0,1),a=TA(t.x+t.width,t.y,0,1),s=TA(t.x,t.y+t.height,0,1),o=TA(t.x+t.width,t.y+t.height,0,1),A=Ri(),l=Ri(),c=Ri(),u=Ri();ua(A,i,n),ua(l,a,n),ua(c,s,n),ua(u,o,n);var h=Math.min(A[0],l[0],c[0],u[0]),d=Math.min(A[1],l[1],c[1],u[1]),f=Math.max(A[0],l[0],c[0],u[0]),g=Math.max(A[1],l[1],c[1],u[1]);return r.fromRect({x:h,y:d,width:f-h,height:g-d})}}])})(),wt="Method not implemented.",lo="Use document.documentElement instead.",TD="Cannot append a destroyed element.";function Qo(r){return r===void 0?0:r>360||r<-360?r%360:r}var Qf=Ze();function Ar(r){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0,n=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!0;return Array.isArray(r)&&r.length===3?n?aa(r):Ui(Qf,r):Be(r)?n?Ct(r,e,t):er(Qf,r,e,t):n?Ct(r[0],r[1]||e,r[2]||t):er(Qf,r[0],r[1]||e,r[2]||t)}var MD=Math.PI/180;function ft(r){return r*MD}var OD=180/Math.PI;function Br(r){return r*OD}function _D(r){return 360*r}var Xu=Math.PI/2;function ID(r,e){var t=e[0],n=e[1],i=e[2],a=e[3],s=t*t,o=n*n,A=i*i,l=a*a,c=s+o+A+l,u=t*a-n*i;return u>.499995*c?(r[0]=Xu,r[1]=2*Math.atan2(n,t),r[2]=0):u<-.499995*c?(r[0]=-Xu,r[1]=2*Math.atan2(n,t),r[2]=0):(r[0]=Math.asin(2*(t*i-a*n)),r[1]=Math.atan2(2*(t*a+n*i),1-2*(A+l)),r[2]=Math.atan2(2*(t*n+i*a),1-2*(o+A))),r}function kD(r,e){var t,n,i=Ko(Ze(),e),a=We(i,3),s=a[0],o=a[1],A=a[2],l=Math.asin(-e[2]/s);return l<Xu?l>-Xu?(t=Math.atan2(e[6]/o,e[10]/A),n=Math.atan2(e[1]/s,e[0]/s)):(n=0,t=-Math.atan2(e[4]/o,e[5]/o)):(n=0,t=Math.atan2(e[4]/o,e[5]/o)),r[0]=t,r[1]=l,r[2]=n,r}function Nf(r,e){return e.length===16?kD(r,e):ID(r,e)}function LD(r,e,t,n,i){var a=Math.cos(r),s=Math.sin(r);return bP(n*a,i*s,0,-n*s,i*a,0,e,t,1)}function QD(r,e,t,n,i,a,s){var o=arguments.length>7&&arguments[7]!==void 0?arguments[7]:!1,A=2*a,l=t-e,c=n-i,u=A/l,h=A/c,d=(t+e)/l,f=(n+i)/c,g,v,p=s-a,y=s*a;return o?(g=-s/p,v=-y/p):(g=-(s+a)/p,v=-2*y/p),r[0]=u,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=h,r[6]=0,r[7]=0,r[8]=d,r[9]=f,r[10]=g,r[11]=-1,r[12]=0,r[13]=0,r[14]=v,r[15]=0,r}function Qb(r){var e=r[0],t=r[1],n=r[3],i=r[4],a=Math.sqrt(e*e+t*t),s=Math.sqrt(n*n+i*i),o=e*i-t*n;if(o<0&&(e<i?a=-a:s=-s),a){var A=1/a;e*=A,t*=A}if(s){var l=1/s;n*=l,i*=l}var c=Math.atan2(t,e),u=Br(c);return[r[6],r[7],a,s,u]}var Mi=xt(),li=xt(),dA=Ri(),Re=[Ze(),Ze(),Ze()],Nb=Ze();function ND(r,e,t,n,i,a){if(!UD(Mi,r)||(Go(li,Mi),li[3]=0,li[7]=0,li[11]=0,li[15]=1,Math.abs(b_(li))<1e-8))return!1;var s=Mi[3],o=Mi[7],A=Mi[11],l=Mi[12],c=Mi[13],u=Mi[14],h=Mi[15];if(s!==0||o!==0||A!==0){dA[0]=s,dA[1]=o,dA[2]=A,dA[3]=h;var d=Ni(li,li);if(!d)return!1;B_(li,li),ua(i,dA,li)}else i[0]=i[1]=i[2]=0,i[3]=1;if(e[0]=l,e[1]=c,e[2]=u,PD(Re,Mi),t[0]=oa(Re[0]),_s(Re[0],Re[0]),n[0]=Pi(Re[0],Re[1]),Uf(Re[1],Re[1],Re[0],1,-n[0]),t[1]=oa(Re[1]),_s(Re[1],Re[1]),n[0]/=t[1],n[1]=Pi(Re[0],Re[2]),Uf(Re[2],Re[2],Re[0],1,-n[1]),n[2]=Pi(Re[1],Re[2]),Uf(Re[2],Re[2],Re[1],1,-n[2]),t[2]=oa(Re[2]),_s(Re[2],Re[2]),n[1]/=t[2],n[2]/=t[2],Cu(Nb,Re[1],Re[2]),Pi(Re[0],Nb)<0)for(var f=0;f<3;f++)t[f]*=-1,Re[f][0]*=-1,Re[f][1]*=-1,Re[f][2]*=-1;return a[0]=.5*Math.sqrt(Math.max(1+Re[0][0]-Re[1][1]-Re[2][2],0)),a[1]=.5*Math.sqrt(Math.max(1-Re[0][0]+Re[1][1]-Re[2][2],0)),a[2]=.5*Math.sqrt(Math.max(1-Re[0][0]-Re[1][1]+Re[2][2],0)),a[3]=.5*Math.sqrt(Math.max(1+Re[0][0]+Re[1][1]+Re[2][2],0)),Re[2][1]>Re[1][2]&&(a[0]=-a[0]),Re[0][2]>Re[2][0]&&(a[1]=-a[1]),Re[1][0]>Re[0][1]&&(a[2]=-a[2]),!0}function UD(r,e){var t=e[15];if(t===0)return!1;for(var n=1/t,i=0;i<16;i++)r[i]=e[i]*n;return!0}function PD(r,e){r[0][0]=e[0],r[0][1]=e[1],r[0][2]=e[2],r[1][0]=e[4],r[1][1]=e[5],r[1][2]=e[6],r[2][0]=e[8],r[2][1]=e[9],r[2][2]=e[10]}function Uf(r,e,t,n,i){r[0]=e[0]*n+t[0]*i,r[1]=e[1]*n+t[1]*i,r[2]=e[2]*n+t[2]*i}var mt=(function(r){return r[r.ORBITING=0]="ORBITING",r[r.EXPLORING=1]="EXPLORING",r[r.TRACKING=2]="TRACKING",r})({}),Tw=(function(r){return r[r.DEFAULT=0]="DEFAULT",r[r.ROTATIONAL=1]="ROTATIONAL",r[r.TRANSLATIONAL=2]="TRANSLATIONAL",r[r.CINEMATIC=3]="CINEMATIC",r})({}),$r=(function(r){return r[r.ORTHOGRAPHIC=0]="ORTHOGRAPHIC",r[r.PERSPECTIVE=1]="PERSPECTIVE",r})({}),rI={UPDATED:"updated"},Ub=2e-4,iI=(function(){function r(){ue(this,r),this.clipSpaceNearZ=Fu.NEGATIVE_ONE,this.eventEmitter=new p_,this.matrix=xt(),this.right=Ct(1,0,0),this.up=Ct(0,1,0),this.forward=Ct(0,0,1),this.position=Ct(0,0,1),this.focalPoint=Ct(0,0,0),this.distanceVector=Ct(0,0,-1),this.distance=1,this.azimuth=0,this.elevation=0,this.roll=0,this.relAzimuth=0,this.relElevation=0,this.relRoll=0,this.dollyingStep=0,this.maxDistance=1/0,this.minDistance=-1/0,this.zoom=1,this.rotateWorld=!1,this.fov=30,this.near=.1,this.far=1e3,this.aspect=1,this.projectionMatrix=xt(),this.projectionMatrixInverse=xt(),this.jitteredProjectionMatrix=void 0,this.enableUpdate=!0,this.type=mt.EXPLORING,this.trackingMode=Tw.DEFAULT,this.projectionMode=$r.PERSPECTIVE,this.frustum=new FD,this.orthoMatrix=xt()}return he(r,[{key:"isOrtho",value:function(){return this.projectionMode===$r.ORTHOGRAPHIC}},{key:"getProjectionMode",value:function(){return this.projectionMode}},{key:"getPerspective",value:function(){return this.jitteredProjectionMatrix||this.projectionMatrix}},{key:"getPerspectiveInverse",value:function(){return this.projectionMatrixInverse}},{key:"getFrustum",value:function(){return this.frustum}},{key:"getPosition",value:function(){return this.position}},{key:"getFocalPoint",value:function(){return this.focalPoint}},{key:"getDollyingStep",value:function(){return this.dollyingStep}},{key:"getNear",value:function(){return this.near}},{key:"getFar",value:function(){return this.far}},{key:"getZoom",value:function(){return this.zoom}},{key:"getOrthoMatrix",value:function(){return this.orthoMatrix}},{key:"getView",value:function(){return this.view}},{key:"setEnableUpdate",value:function(t){this.enableUpdate=t}},{key:"setType",value:function(t,n){return this.type=t,this.type===mt.EXPLORING?this.setWorldRotation(!0):this.setWorldRotation(!1),this._getAngles(),this.type===mt.TRACKING&&n!==void 0&&this.setTrackingMode(n),this}},{key:"setProjectionMode",value:function(t){return this.projectionMode=t,this}},{key:"setTrackingMode",value:function(t){if(this.type!==mt.TRACKING)throw new Error("Impossible to set a tracking mode if the camera is not of tracking type");return this.trackingMode=t,this}},{key:"setWorldRotation",value:function(t){return this.rotateWorld=t,this._getAngles(),this}},{key:"getViewTransform",value:function(){return Ni(xt(),this.matrix)}},{key:"getWorldTransform",value:function(){return this.matrix}},{key:"jitterProjectionMatrix",value:function(t,n){var i=Ia(xt(),[t,n,0]);this.jitteredProjectionMatrix=tr(xt(),i,this.projectionMatrix)}},{key:"clearJitterProjectionMatrix",value:function(){this.jitteredProjectionMatrix=void 0}},{key:"setMatrix",value:function(t){return this.matrix=t,this._update(),this}},{key:"setProjectionMatrix",value:function(t){this.projectionMatrix=t}},{key:"setFov",value:function(t){return this.setPerspective(this.near,this.far,t,this.aspect),this}},{key:"setAspect",value:function(t){return this.setPerspective(this.near,this.far,this.fov,t),this}},{key:"setNear",value:function(t){return this.projectionMode===$r.PERSPECTIVE?this.setPerspective(t,this.far,this.fov,this.aspect):this.setOrthographic(this.left,this.rright,this.top,this.bottom,t,this.far),this}},{key:"setFar",value:function(t){return this.projectionMode===$r.PERSPECTIVE?this.setPerspective(this.near,t,this.fov,this.aspect):this.setOrthographic(this.left,this.rright,this.top,this.bottom,this.near,t),this}},{key:"setViewOffset",value:function(t,n,i,a,s,o){return this.aspect=t/n,this.view===void 0&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1}),this.view.enabled=!0,this.view.fullWidth=t,this.view.fullHeight=n,this.view.offsetX=i,this.view.offsetY=a,this.view.width=s,this.view.height=o,this.projectionMode===$r.PERSPECTIVE?this.setPerspective(this.near,this.far,this.fov,this.aspect):this.setOrthographic(this.left,this.rright,this.top,this.bottom,this.near,this.far),this}},{key:"clearViewOffset",value:function(){return this.view!==void 0&&(this.view.enabled=!1),this.projectionMode===$r.PERSPECTIVE?this.setPerspective(this.near,this.far,this.fov,this.aspect):this.setOrthographic(this.left,this.rright,this.top,this.bottom,this.near,this.far),this}},{key:"setZoom",value:function(t){return this.zoom=t,this.projectionMode===$r.ORTHOGRAPHIC?this.setOrthographic(this.left,this.rright,this.top,this.bottom,this.near,this.far):this.projectionMode===$r.PERSPECTIVE&&this.setPerspective(this.near,this.far,this.fov,this.aspect),this}},{key:"setZoomByViewportPoint",value:function(t,n){var i=this.canvas.viewport2Canvas({x:n[0],y:n[1]}),a=i.x,s=i.y,o=this.roll;this.rotate(0,0,-o),this.setPosition(a,s),this.setFocalPoint(a,s),this.setZoom(t),this.rotate(0,0,o);var A=this.canvas.viewport2Canvas({x:n[0],y:n[1]}),l=A.x,c=A.y,u=Ct(l-a,c-s,0),h=Pi(u,this.right)/oa(this.right),d=Pi(u,this.up)/oa(this.up),f=this.getPosition(),g=We(f,2),v=g[0],p=g[1],y=this.getFocalPoint(),m=We(y,2),B=m[0],C=m[1];return this.setPosition(v-h,p-d),this.setFocalPoint(B-h,C-d),this}},{key:"setPerspective",value:function(t,n,i,a){var s;this.projectionMode=$r.PERSPECTIVE,this.fov=i,this.near=t,this.far=n,this.aspect=a;var o=this.near*Math.tan(ft(.5*this.fov))/this.zoom,A=2*o,l=this.aspect*A,c=-.5*l;if((s=this.view)!==null&&s!==void 0&&s.enabled){var u=this.view.fullWidth,h=this.view.fullHeight;c+=this.view.offsetX*l/u,o-=this.view.offsetY*A/h,l*=this.view.width/u,A*=this.view.height/h}return QD(this.projectionMatrix,c,c+l,o-A,o,t,this.far,this.clipSpaceNearZ===Fu.ZERO),Ni(this.projectionMatrixInverse,this.projectionMatrix),this.triggerUpdate(),this}},{key:"setOrthographic",value:function(t,n,i,a,s,o){var A;this.projectionMode=$r.ORTHOGRAPHIC,this.rright=n,this.left=t,this.top=i,this.bottom=a,this.near=s,this.far=o;var l=(this.rright-this.left)/(2*this.zoom),c=(this.top-this.bottom)/(2*this.zoom),u=(this.rright+this.left)/2,h=(this.top+this.bottom)/2,d=u-l,f=u+l,g=h+c,v=h-c;if((A=this.view)!==null&&A!==void 0&&A.enabled){var p=(this.rright-this.left)/this.view.fullWidth/this.zoom,y=(this.top-this.bottom)/this.view.fullHeight/this.zoom;d+=p*this.view.offsetX,f=d+p*this.view.width,g-=y*this.view.offsetY,v=g-y*this.view.height}return this.clipSpaceNearZ===Fu.NEGATIVE_ONE?I_(this.projectionMatrix,d,f,g,v,s,o):k_(this.projectionMatrix,d,f,g,v,s,o),Ni(this.projectionMatrixInverse,this.projectionMatrix),this._getOrthoMatrix(),this.triggerUpdate(),this}},{key:"setPosition",value:function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.position[1],i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.position[2],a=Ar(t,n,i);return this._setPosition(a),this.setFocalPoint(this.focalPoint),this.triggerUpdate(),this}},{key:"setFocalPoint",value:function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:this.focalPoint[1],i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:this.focalPoint[2],a=Ct(0,1,0);if(this.focalPoint=Ar(t,n,i),this.trackingMode===Tw.CINEMATIC){var s=vw(Ze(),this.focalPoint,this.position);t=s[0],n=s[1],i=s[2];var o=oa(s),A=Br(Math.asin(n/o)),l=90+Br(Math.atan2(i,t)),c=xt();C_(c,c,ft(l)),x_(c,c,ft(A)),a=nr(Ze(),[0,1,0],c)}return Ni(this.matrix,L_(xt(),this.position,this.focalPoint,a)),this._getAxes(),this._getDistance(),this._getAngles(),this.triggerUpdate(),this}},{key:"getDistance",value:function(){return this.distance}},{key:"getDistanceVector",value:function(){return this.distanceVector}},{key:"setDistance",value:function(t){if(this.distance===t||t<0)return this;this.distance=t,this.distance<Ub&&(this.distance=Ub),this.dollyingStep=this.distance/100;var n=Ze();t=this.distance;var i=this.forward,a=this.focalPoint;return n[0]=t*i[0]+a[0],n[1]=t*i[1]+a[1],n[2]=t*i[2]+a[2],this._setPosition(n),this.triggerUpdate(),this}},{key:"setMaxDistance",value:function(t){return this.maxDistance=t,this}},{key:"setMinDistance",value:function(t){return this.minDistance=t,this}},{key:"setAzimuth",value:function(t){return this.azimuth=Qo(t),this.computeMatrix(),this._getAxes(),this.type===mt.ORBITING||this.type===mt.EXPLORING?this._getPosition():this.type===mt.TRACKING&&this._getFocalPoint(),this.triggerUpdate(),this}},{key:"getAzimuth",value:function(){return this.azimuth}},{key:"setElevation",value:function(t){return this.elevation=Qo(t),this.computeMatrix(),this._getAxes(),this.type===mt.ORBITING||this.type===mt.EXPLORING?this._getPosition():this.type===mt.TRACKING&&this._getFocalPoint(),this.triggerUpdate(),this}},{key:"getElevation",value:function(){return this.elevation}},{key:"setRoll",value:function(t){return this.roll=Qo(t),this.computeMatrix(),this._getAxes(),this.type===mt.ORBITING||this.type===mt.EXPLORING?this._getPosition():this.type===mt.TRACKING&&this._getFocalPoint(),this.triggerUpdate(),this}},{key:"getRoll",value:function(){return this.roll}},{key:"_update",value:function(){this._getAxes(),this._getPosition(),this._getDistance(),this._getAngles(),this._getOrthoMatrix(),this.triggerUpdate()}},{key:"computeMatrix",value:function(){var t=La(gn(),[0,0,1],ft(this.roll));Xa(this.matrix);var n=La(gn(),[1,0,0],ft((this.rotateWorld&&this.type!==mt.TRACKING||this.type===mt.TRACKING?1:-1)*this.elevation)),i=La(gn(),[0,1,0],ft((this.rotateWorld&&this.type!==mt.TRACKING||this.type===mt.TRACKING?1:-1)*this.azimuth)),a=ja(gn(),i,n);a=ja(gn(),a,t);var s=K1(xt(),a);this.type===mt.ORBITING||this.type===mt.EXPLORING?(ko(this.matrix,this.matrix,this.focalPoint),tr(this.matrix,this.matrix,s),ko(this.matrix,this.matrix,[0,0,this.distance])):this.type===mt.TRACKING&&(ko(this.matrix,this.matrix,this.position),tr(this.matrix,this.matrix,s))}},{key:"_setPosition",value:function(t,n,i){this.position=Ar(t,n,i);var a=this.matrix;a[12]=this.position[0],a[13]=this.position[1],a[14]=this.position[2],a[15]=1,this._getOrthoMatrix()}},{key:"_getAxes",value:function(){Ui(this.right,Ar(ua(Ri(),[1,0,0,0],this.matrix))),Ui(this.up,Ar(ua(Ri(),[0,1,0,0],this.matrix))),Ui(this.forward,Ar(ua(Ri(),[0,0,1,0],this.matrix))),_s(this.right,this.right),_s(this.up,this.up),_s(this.forward,this.forward)}},{key:"_getAngles",value:function(){var t=this.distanceVector[0],n=this.distanceVector[1],i=this.distanceVector[2],a=oa(this.distanceVector);if(a===0){this.elevation=0,this.azimuth=0;return}this.type===mt.TRACKING?(this.elevation=Br(Math.asin(n/a)),this.azimuth=Br(Math.atan2(-t,-i))):this.rotateWorld?(this.elevation=Br(Math.asin(n/a)),this.azimuth=Br(Math.atan2(-t,-i))):(this.elevation=-Br(Math.asin(n/a)),this.azimuth=-Br(Math.atan2(-t,-i)))}},{key:"_getPosition",value:function(){Ui(this.position,Ar(ua(Ri(),[0,0,0,1],this.matrix))),this._getDistance()}},{key:"_getFocalPoint",value:function(){VP(this.distanceVector,[0,0,-this.distance],BP(y_(),this.matrix)),Va(this.focalPoint,this.position,this.distanceVector),this._getDistance()}},{key:"_getDistance",value:function(){this.distanceVector=vw(Ze(),this.focalPoint,this.position),this.distance=oa(this.distanceVector),this.dollyingStep=this.distance/100}},{key:"_getOrthoMatrix",value:function(){if(this.projectionMode===$r.ORTHOGRAPHIC){var t=this.position,n=La(gn(),[0,0,1],-this.roll*Math.PI/180);qA(this.orthoMatrix,n,Ct((this.rright-this.left)/2-t[0],(this.top-this.bottom)/2-t[1],0),Ct(this.zoom,this.zoom,1),t)}}},{key:"triggerUpdate",value:function(){if(this.enableUpdate){var t=this.getViewTransform(),n=tr(xt(),this.getPerspective(),t);this.getFrustum().extractFromVPMatrix(n),this.eventEmitter.emit(rI.UPDATED)}}},{key:"rotate",value:function(t,n,i){throw new Error(wt)}},{key:"pan",value:function(t,n){throw new Error(wt)}},{key:"dolly",value:function(t){throw new Error(wt)}},{key:"createLandmark",value:function(t,n){throw new Error(wt)}},{key:"gotoLandmark",value:function(t,n){throw new Error(wt)}},{key:"cancelLandmarkAnimation",value:function(){throw new Error(wt)}}])})(),RD=(function(r){return r[r.Standard=0]="Standard",r})({}),Zu=(function(r){return r[r.ADDED=0]="ADDED",r[r.REMOVED=1]="REMOVED",r[r.Z_INDEX_CHANGED=2]="Z_INDEX_CHANGED",r})({}),DD=Ze(),fA=xt(),HD=gn();function Pb(r){if(r.localDirtyFlag){var e=r.localSkew[0]!==0||r.localSkew[1]!==0;if(e){qA(r.localTransform,r.localRotation,r.localPosition,Ct(1,1,1),r.origin),(r.localSkew[0]!==0||r.localSkew[1]!==0)&&(Xa(fA),fA[4]=Math.tan(r.localSkew[0]),fA[1]=Math.tan(r.localSkew[1]),tr(r.localTransform,r.localTransform,fA));var t=qA(fA,R_(HD,0,0,0,1),er(DD,1,1,1),r.localScale,r.origin);tr(r.localTransform,r.localTransform,t)}else{var n=r.localTransform,i=r.localPosition,a=r.localRotation,s=r.localScale,o=r.origin,A=i[0]!==0||i[1]!==0||i[2]!==0,l=a[3]!==1||a[0]!==0||a[1]!==0||a[2]!==0,c=s[0]!==1||s[1]!==1||s[2]!==1,u=o[0]!==0||o[1]!==0||o[2]!==0;!l&&!c&&!u?A?Ia(n,i):Xa(n):qA(n,a,i,s,o)}r.localDirtyFlag=!1}}function GD(r,e){r.dirtyFlag&&(e?tr(r.worldTransform,e.worldTransform,r.localTransform):Go(r.worldTransform,r.localTransform),r.dirtyFlag=!1)}var aI={absolutePath:[],hasArc:!1,segments:[],polygons:[],polylines:[],curve:null,totalLength:0,rect:new Vo(0,0,0,0)},pe=(function(r){return r.COORDINATE="<coordinate>",r.COLOR="<color>",r.PAINT="<paint>",r.NUMBER="<number>",r.ANGLE="<angle>",r.OPACITY_VALUE="<opacity-value>",r.SHADOW_BLUR="<shadow-blur>",r.LENGTH="<length>",r.PERCENTAGE="<percentage>",r.LENGTH_PERCENTAGE="<length> | <percentage>",r.LENGTH_PERCENTAGE_12="[<length> | <percentage>]{1,2}",r.LENGTH_PERCENTAGE_14="[<length> | <percentage>]{1,4}",r.LIST_OF_POINTS="<list-of-points>",r.PATH="<path>",r.FILTER="<filter>",r.Z_INDEX="<z-index>",r.OFFSET_DISTANCE="<offset-distance>",r.DEFINED_PATH="<defined-path>",r.MARKER="<marker>",r.TRANSFORM="<transform>",r.TRANSFORM_ORIGIN="<transform-origin>",r.TEXT="<text>",r.TEXT_TRANSFORM="<text-transform>",r})({});function W1(r,e,t){r.prototype=e.prototype=t,t.constructor=r}function sI(r,e){var t=Object.create(r.prototype);for(var n in e)t[n]=e[n];return t}function Tl(){}var Al=.7,Ju=1/Al,No="\\s*([+-]?\\d+)\\s*",ll="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",Hi="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",KD=/^#([0-9a-f]{3,8})$/,zD=new RegExp(`^rgb\\(${No},${No},${No}\\)$`),VD=new RegExp(`^rgb\\(${Hi},${Hi},${Hi}\\)$`),jD=new RegExp(`^rgba\\(${No},${No},${No},${ll}\\)$`),WD=new RegExp(`^rgba\\(${Hi},${Hi},${Hi},${ll}\\)$`),qD=new RegExp(`^hsl\\(${ll},${Hi},${Hi}\\)$`),$D=new RegExp(`^hsla\\(${ll},${Hi},${Hi},${ll}\\)$`),Rb={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};W1(Tl,Uh,{copy(r){return Object.assign(new this.constructor,this,r)},displayable(){return this.rgb().displayable()},hex:Db,formatHex:Db,formatHex8:YD,formatHsl:XD,formatRgb:Hb,toString:Hb});function Db(){return this.rgb().formatHex()}function YD(){return this.rgb().formatHex8()}function XD(){return oI(this).formatHsl()}function Hb(){return this.rgb().formatRgb()}function Uh(r){var e,t;return r=(r+"").trim().toLowerCase(),(e=KD.exec(r))?(t=e[1].length,e=parseInt(e[1],16),t===6?Gb(e):t===3?new Cr(e>>8&15|e>>4&240,e>>4&15|e&240,(e&15)<<4|e&15,1):t===8?oc(e>>24&255,e>>16&255,e>>8&255,(e&255)/255):t===4?oc(e>>12&15|e>>8&240,e>>8&15|e>>4&240,e>>4&15|e&240,((e&15)<<4|e&15)/255):null):(e=zD.exec(r))?new Cr(e[1],e[2],e[3],1):(e=VD.exec(r))?new Cr(e[1]*255/100,e[2]*255/100,e[3]*255/100,1):(e=jD.exec(r))?oc(e[1],e[2],e[3],e[4]):(e=WD.exec(r))?oc(e[1]*255/100,e[2]*255/100,e[3]*255/100,e[4]):(e=qD.exec(r))?Vb(e[1],e[2]/100,e[3]/100,1):(e=$D.exec(r))?Vb(e[1],e[2]/100,e[3]/100,e[4]):Rb.hasOwnProperty(r)?Gb(Rb[r]):r==="transparent"?new Cr(NaN,NaN,NaN,0):null}function Gb(r){return new Cr(r>>16&255,r>>8&255,r&255,1)}function oc(r,e,t,n){return n<=0&&(r=e=t=NaN),new Cr(r,e,t,n)}function ZD(r){return r instanceof Tl||(r=Uh(r)),r?(r=r.rgb(),new Cr(r.r,r.g,r.b,r.opacity)):new Cr}function JD(r,e,t,n){return arguments.length===1?ZD(r):new Cr(r,e,t,n??1)}function Cr(r,e,t,n){this.r=+r,this.g=+e,this.b=+t,this.opacity=+n}W1(Cr,JD,sI(Tl,{brighter(r){return r=r==null?Ju:Math.pow(Ju,r),new Cr(this.r*r,this.g*r,this.b*r,this.opacity)},darker(r){return r=r==null?Al:Math.pow(Al,r),new Cr(this.r*r,this.g*r,this.b*r,this.opacity)},rgb(){return this},clamp(){return new Cr(Is(this.r),Is(this.g),Is(this.b),eh(this.opacity))},displayable(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:Kb,formatHex:Kb,formatHex8:e3,formatRgb:zb,toString:zb}));function Kb(){return`#${Ss(this.r)}${Ss(this.g)}${Ss(this.b)}`}function e3(){return`#${Ss(this.r)}${Ss(this.g)}${Ss(this.b)}${Ss((isNaN(this.opacity)?1:this.opacity)*255)}`}function zb(){const r=eh(this.opacity);return`${r===1?"rgb(":"rgba("}${Is(this.r)}, ${Is(this.g)}, ${Is(this.b)}${r===1?")":`, ${r})`}`}function eh(r){return isNaN(r)?1:Math.max(0,Math.min(1,r))}function Is(r){return Math.max(0,Math.min(255,Math.round(r)||0))}function Ss(r){return r=Is(r),(r<16?"0":"")+r.toString(16)}function Vb(r,e,t,n){return n<=0?r=e=t=NaN:t<=0||t>=1?r=e=NaN:e<=0&&(r=NaN),new gi(r,e,t,n)}function oI(r){if(r instanceof gi)return new gi(r.h,r.s,r.l,r.opacity);if(r instanceof Tl||(r=Uh(r)),!r)return new gi;if(r instanceof gi)return r;r=r.rgb();var e=r.r/255,t=r.g/255,n=r.b/255,i=Math.min(e,t,n),a=Math.max(e,t,n),s=NaN,o=a-i,A=(a+i)/2;return o?(e===a?s=(t-n)/o+(t<n)*6:t===a?s=(n-e)/o+2:s=(e-t)/o+4,o/=A<.5?a+i:2-a-i,s*=60):o=A>0&&A<1?0:s,new gi(s,o,A,r.opacity)}function t3(r,e,t,n){return arguments.length===1?oI(r):new gi(r,e,t,n??1)}function gi(r,e,t,n){this.h=+r,this.s=+e,this.l=+t,this.opacity=+n}W1(gi,t3,sI(Tl,{brighter(r){return r=r==null?Ju:Math.pow(Ju,r),new gi(this.h,this.s,this.l*r,this.opacity)},darker(r){return r=r==null?Al:Math.pow(Al,r),new gi(this.h,this.s,this.l*r,this.opacity)},rgb(){var r=this.h%360+(this.h<0)*360,e=isNaN(r)||isNaN(this.s)?0:this.s,t=this.l,n=t+(t<.5?t:1-t)*e,i=2*t-n;return new Cr(Pf(r>=240?r-240:r+120,i,n),Pf(r,i,n),Pf(r<120?r+240:r-120,i,n),this.opacity)},clamp(){return new gi(jb(this.h),Ac(this.s),Ac(this.l),eh(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){const r=eh(this.opacity);return`${r===1?"hsl(":"hsla("}${jb(this.h)}, ${Ac(this.s)*100}%, ${Ac(this.l)*100}%${r===1?")":`, ${r})`}`}}));function jb(r){return r=(r||0)%360,r<0?r+360:r}function Ac(r){return Math.max(0,Math.min(1,r||0))}function Pf(r,e,t){return(r<60?e+(t-e)*r/60:r<180?t:r<240?e+(t-e)*(240-r)/60:e)*255}function hn(r,e){if(typeof r!="function"||e!=null&&typeof e!="function")throw new TypeError("Expected a function");var t=function(){for(var i=arguments.length,a=new Array(i),s=0;s<i;s++)a[s]=arguments[s];var o=e?e.apply(this,a):a[0],A=t.cache;if(A.has(o))return A.get(o);var l=r.apply(this,a);return t.cache=A.set(o,l)||A,l};return t.cache=new(hn.Cache||Map),hn.cacheList.push(t.cache),t}hn.Cache=Map;hn.cacheList=[];hn.clearCache=function(){hn.cacheList.forEach(function(r){return r.clear()})};var we=(function(r){return r[r.kUnknown=0]="kUnknown",r[r.kNumber=1]="kNumber",r[r.kPercentage=2]="kPercentage",r[r.kEms=3]="kEms",r[r.kPixels=4]="kPixels",r[r.kRems=5]="kRems",r[r.kDegrees=6]="kDegrees",r[r.kRadians=7]="kRadians",r[r.kGradians=8]="kGradians",r[r.kTurns=9]="kTurns",r[r.kMilliseconds=10]="kMilliseconds",r[r.kSeconds=11]="kSeconds",r[r.kInteger=12]="kInteger",r})({}),fi=(function(r){return r[r.kUNumber=0]="kUNumber",r[r.kUPercent=1]="kUPercent",r[r.kULength=2]="kULength",r[r.kUAngle=3]="kUAngle",r[r.kUTime=4]="kUTime",r[r.kUOther=5]="kUOther",r})({}),n3=(function(r){return r[r.kYes=0]="kYes",r[r.kNo=1]="kNo",r})({}),r3=(function(r){return r[r.kYes=0]="kYes",r[r.kNo=1]="kNo",r})({}),i3=[{name:"em",unit_type:we.kEms},{name:"px",unit_type:we.kPixels},{name:"deg",unit_type:we.kDegrees},{name:"rad",unit_type:we.kRadians},{name:"grad",unit_type:we.kGradians},{name:"ms",unit_type:we.kMilliseconds},{name:"s",unit_type:we.kSeconds},{name:"rem",unit_type:we.kRems},{name:"turn",unit_type:we.kTurns}],jo=(function(r){return r[r.kUnknownType=0]="kUnknownType",r[r.kUnparsedType=1]="kUnparsedType",r[r.kKeywordType=2]="kKeywordType",r[r.kUnitType=3]="kUnitType",r[r.kSumType=4]="kSumType",r[r.kProductType=5]="kProductType",r[r.kNegateType=6]="kNegateType",r[r.kInvertType=7]="kInvertType",r[r.kMinType=8]="kMinType",r[r.kMaxType=9]="kMaxType",r[r.kClampType=10]="kClampType",r[r.kTransformType=11]="kTransformType",r[r.kPositionType=12]="kPositionType",r[r.kURLImageType=13]="kURLImageType",r[r.kColorType=14]="kColorType",r[r.kUnsupportedColorType=15]="kUnsupportedColorType",r})({}),a3=function(e){return i3.find(function(t){return t.name===e}).unit_type},s3=function(e){return e?e==="number"?we.kNumber:e==="percent"||e==="%"?we.kPercentage:a3(e):we.kUnknown},o3=function(e){switch(e){case we.kNumber:case we.kInteger:return fi.kUNumber;case we.kPercentage:return fi.kUPercent;case we.kPixels:return fi.kULength;case we.kMilliseconds:case we.kSeconds:return fi.kUTime;case we.kDegrees:case we.kRadians:case we.kGradians:case we.kTurns:return fi.kUAngle;default:return fi.kUOther}},A3=function(e){switch(e){case fi.kUNumber:return we.kNumber;case fi.kULength:return we.kPixels;case fi.kUPercent:return we.kPercentage;case fi.kUTime:return we.kSeconds;case fi.kUAngle:return we.kDegrees;default:return we.kUnknown}},Wb=function(e){var t=1;switch(e){case we.kPixels:case we.kDegrees:case we.kSeconds:break;case we.kMilliseconds:t=.001;break;case we.kRadians:t=180/Math.PI;break;case we.kGradians:t=.9;break;case we.kTurns:t=360;break}return t},Mw=function(e){switch(e){case we.kNumber:case we.kInteger:return"";case we.kPercentage:return"%";case we.kEms:return"em";case we.kRems:return"rem";case we.kPixels:return"px";case we.kDegrees:return"deg";case we.kRadians:return"rad";case we.kGradians:return"grad";case we.kMilliseconds:return"ms";case we.kSeconds:return"s";case we.kTurns:return"turn"}return""},Ph=(function(){function r(){ue(this,r)}return he(r,[{key:"toString",value:function(){return this.buildCSSText(n3.kNo,r3.kNo,"")}},{key:"isNumericValue",value:function(){return this.getType()>=jo.kUnitType&&this.getType()<=jo.kClampType}}],[{key:"isAngle",value:function(t){return t===we.kDegrees||t===we.kRadians||t===we.kGradians||t===we.kTurns}},{key:"isLength",value:function(t){return t>=we.kEms&&t<we.kDegrees}},{key:"isRelativeUnit",value:function(t){return t===we.kPercentage||t===we.kEms||t===we.kRems}},{key:"isTime",value:function(t){return t===we.kSeconds||t===we.kMilliseconds}}])})(),l3=(function(r){function e(t){var n;return ue(this,e),n=qe(this,e),n.colorSpace=t,n}return $e(e,r),he(e,[{key:"getType",value:function(){return jo.kColorType}},{key:"to",value:function(n){return this}}])})(Ph),Qa=(function(r){return r[r.Constant=0]="Constant",r[r.LinearGradient=1]="LinearGradient",r[r.RadialGradient=2]="RadialGradient",r})({}),lc=(function(r){function e(t,n){var i;return ue(this,e),i=qe(this,e),i.type=t,i.value=n,i}return $e(e,r),he(e,[{key:"clone",value:function(){return new e(this.type,this.value)}},{key:"buildCSSText",value:function(n,i,a){return a}},{key:"getType",value:function(){return jo.kColorType}}])})(Ph),ii=(function(r){function e(t){var n;return ue(this,e),n=qe(this,e),n.value=t,n}return $e(e,r),he(e,[{key:"clone",value:function(){return new e(this.value)}},{key:"getType",value:function(){return jo.kKeywordType}},{key:"buildCSSText",value:function(n,i,a){return a+this.value}}])})(Ph),c3=function(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"",n="";return Number.isFinite(e)?n="NaN":e>0?n="infinity":n="-infinity",n+=t},Ow=function(e){return A3(o3(e))},Bt=(function(r){function e(t){var n,i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:we.kNumber;ue(this,e),n=qe(this,e);var a;return typeof i=="string"?a=s3(i):a=i,n.unit=a,n.value=t,n}return $e(e,r),he(e,[{key:"clone",value:function(){return new e(this.value,this.unit)}},{key:"equals",value:function(n){var i=n;return this.value===i.value&&this.unit===i.unit}},{key:"getType",value:function(){return jo.kUnitType}},{key:"convertTo",value:function(n){if(this.unit===n)return new e(this.value,this.unit);var i=Ow(this.unit);if(i!==Ow(n)||i===we.kUnknown)return null;var a=Wb(this.unit)/Wb(n);return new e(this.value*a,n)}},{key:"buildCSSText",value:function(n,i,a){var s;switch(this.unit){case we.kUnknown:break;case we.kInteger:s=Number(this.value).toFixed(0);break;case we.kNumber:case we.kPercentage:case we.kEms:case we.kRems:case we.kPixels:case we.kDegrees:case we.kRadians:case we.kGradians:case we.kMilliseconds:case we.kSeconds:case we.kTurns:{var o=-999999,A=999999,l=this.value,c=Mw(this.unit);if(l<o||l>A){var u=Mw(this.unit);!Number.isFinite(l)||Number.isNaN(l)?s=c3(l,u):s=l+(u||"")}else s="".concat(l).concat(c)}}return a+=s,a}}])})(Ph),hi=new Bt(0,"px");new Bt(1,"px");var Hs=new Bt(0,"deg"),q1=(function(r){function e(t,n,i){var a,s=arguments.length>3&&arguments[3]!==void 0?arguments[3]:1,o=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!1;return ue(this,e),a=qe(this,e,["rgb"]),a.r=t,a.g=n,a.b=i,a.alpha=s,a.isNone=o,a}return $e(e,r),he(e,[{key:"clone",value:function(){return new e(this.r,this.g,this.b,this.alpha)}},{key:"buildCSSText",value:function(n,i,a){return"".concat(a,"rgba(").concat(this.r,",").concat(this.g,",").concat(this.b,",").concat(this.alpha,")")}}])})(l3),qb=new ii("unset"),u3=new ii("initial"),h3=new ii("inherit"),Rf={"":qb,unset:qb,initial:u3,inherit:h3},d3=function(e){return Rf[e]||(Rf[e]=new ii(e)),Rf[e]},AI=new q1(0,0,0,0,!0),lI=new q1(0,0,0,0),f3=hn(function(r,e,t,n){return new q1(r,e,t,n)},function(r,e,t,n){return"rgba(".concat(r,",").concat(e,",").concat(t,",").concat(n,")")}),Rt=function(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:we.kNumber;return new Bt(e,t)};new Bt(50,"%");function g3(r){var e=r.type,t=r.value;return e==="hex"?"#".concat(t):e==="literal"?t:e==="rgb"?"rgb(".concat(t.join(","),")"):"rgba(".concat(t.join(","),")")}var v3=(function(){var r={linearGradient:/^(linear\-gradient)/i,repeatingLinearGradient:/^(repeating\-linear\-gradient)/i,radialGradient:/^(radial\-gradient)/i,repeatingRadialGradient:/^(repeating\-radial\-gradient)/i,conicGradient:/^(conic\-gradient)/i,sideOrCorner:/^to (left (top|bottom)|right (top|bottom)|top (left|right)|bottom (left|right)|left|right|top|bottom)/i,extentKeywords:/^(closest\-side|closest\-corner|farthest\-side|farthest\-corner|contain|cover)/,positionKeywords:/^(left|center|right|top|bottom)/i,pixelValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))px/,percentageValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))\%/,emValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))em/,angleValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))deg/,startCall:/^\(/,endCall:/^\)/,comma:/^,/,hexColor:/^\#([0-9a-fA-F]+)/,literalColor:/^([a-zA-Z]+)/,rgbColor:/^rgb/i,rgbaColor:/^rgba/i,number:/^(([0-9]*\.[0-9]+)|([0-9]+\.?))/},e="";function t(K){throw new Error("".concat(e,": ").concat(K))}function n(){var K=i();return e.length>0&&t("Invalid input not EOF"),K}function i(){return m(a)}function a(){return s("linear-gradient",r.linearGradient,A)||s("repeating-linear-gradient",r.repeatingLinearGradient,A)||s("radial-gradient",r.radialGradient,u)||s("repeating-radial-gradient",r.repeatingRadialGradient,u)||s("conic-gradient",r.conicGradient,u)}function s(K,D,X){return o(D,function(te){var ie=X();return ie&&(W(r.comma)||t("Missing comma before color stops")),{type:K,orientation:ie,colorStops:m(B)}})}function o(K,D){var X=W(K);if(X){W(r.startCall)||t("Missing (");var te=D(X);return W(r.endCall)||t("Missing )"),te}}function A(){return l()||c()}function l(){return G("directional",r.sideOrCorner,1)}function c(){return G("angular",r.angleValue,1)}function u(){var K,D=h(),X;return D&&(K=[],K.push(D),X=e,W(r.comma)&&(D=h(),D?K.push(D):e=X)),K}function h(){var K=d()||f();if(K)K.at=v();else{var D=g();if(D){K=D;var X=v();X&&(K.at=X)}else{var te=p();te&&(K={type:"default-radial",at:te})}}return K}function d(){var K=G("shape",/^(circle)/i,0);return K&&(K.style=U()||g()),K}function f(){var K=G("shape",/^(ellipse)/i,0);return K&&(K.style=k()||g()),K}function g(){return G("extent-keyword",r.extentKeywords,1)}function v(){if(G("position",/^at/,0)){var K=p();return K||t("Missing positioning value"),K}}function p(){var K=y();if(K.x||K.y)return{type:"position",value:K}}function y(){return{x:k(),y:k()}}function m(K){var D=K(),X=[];if(D)for(X.push(D);W(r.comma);)D=K(),D?X.push(D):t("One extra comma");return X}function B(){var K=C();return K||t("Expected color definition"),K.length=k(),K}function C(){return F()||O()||T()||S()}function S(){return G("literal",r.literalColor,0)}function F(){return G("hex",r.hexColor,1)}function T(){return o(r.rgbColor,function(){return{type:"rgb",value:m(_)}})}function O(){return o(r.rgbaColor,function(){return{type:"rgba",value:m(_)}})}function _(){return W(r.number)[1]}function k(){return G("%",r.percentageValue,1)||L()||U()}function L(){return G("position-keyword",r.positionKeywords,1)}function U(){return G("px",r.pixelValue,1)||G("em",r.emValue,1)}function G(K,D,X){var te=W(D);if(te)return{type:K,value:te[X]}}function W(K){var D=/^[\n\r\t\s]+/.exec(e);D&&V(D[0].length);var X=K.exec(e);return X&&V(X[0].length),X}function V(K){e=e.substring(K)}return function(K){return e=K,n()}})();function p3(r,e,t,n){var i=ft(n.value),a=0,s=0,o=a+e/2,A=s+t/2,l=Math.abs(e*Math.cos(i))+Math.abs(t*Math.sin(i)),c=r[0]+o-Math.cos(i)*l/2,u=r[1]+A-Math.sin(i)*l/2,h=r[0]+o+Math.cos(i)*l/2,d=r[1]+A+Math.sin(i)*l/2;return{x1:c,y1:u,x2:h,y2:d}}function y3(r,e,t,n,i,a){var s=n.value,o=i.value;n.unit===we.kPercentage&&(s=n.value/100*e),i.unit===we.kPercentage&&(o=i.value/100*t);var A=Math.max(wr([0,0],[s,o]),wr([0,t],[s,o]),wr([e,t],[s,o]),wr([e,0],[s,o]));return a&&(a instanceof Bt?A=a.value:a instanceof ii&&(a.value==="closest-side"?A=Math.min(s,e-s,o,t-o):a.value==="farthest-side"?A=Math.max(s,e-s,o,t-o):a.value==="closest-corner"&&(A=Math.min(wr([0,0],[s,o]),wr([0,t],[s,o]),wr([e,t],[s,o]),wr([e,0],[s,o]))))),{x:s+r[0],y:o+r[1],r:A}}var m3=/^l\s*\(\s*([\d.]+)\s*\)\s*(.*)/i,w3=/^r\s*\(\s*([\d.]+)\s*,\s*([\d.]+)\s*,\s*([\d.]+)\s*\)\s*(.*)/i,B3=/^p\s*\(\s*([axyn])\s*\)\s*(.*)/i,cI=/[\d.]+:(#[^\s]+|[^\)]+\))/gi;function b3(r){var e,t=r.length;if(r[t-1].length=(e=r[t-1].length)!==null&&e!==void 0?e:{type:"%",value:"100"},t>1){var n;r[0].length=(n=r[0].length)!==null&&n!==void 0?n:{type:"%",value:"0"}}for(var i=0,a=Number(r[0].length.value),s=1;s<t;s++){var o,A=(o=r[s].length)===null||o===void 0?void 0:o.value;if(!ke(A)&&!ke(a)){for(var l=1;l<s-i;l++)r[i+l].length={type:"%",value:"".concat(a+(Number(A)-a)*l/(s-i))};i=s,a=Number(A)}}}var E3={left:180,top:-90,bottom:90,right:0,"left top":225,"top left":225,"left bottom":135,"bottom left":135,"right top":-45,"top right":-45,"right bottom":45,"bottom right":45},x3=hn(function(r){var e;return r.type==="angular"?e=Number(r.value):e=E3[r.value]||0,Rt(e,"deg")}),C3=hn(function(r){var e=50,t=50,n="%",i="%";if((r==null?void 0:r.type)==="position"){var a=r.value,s=a.x,o=a.y;(s==null?void 0:s.type)==="position-keyword"&&(s.value==="left"?e=0:s.value==="center"?e=50:s.value==="right"?e=100:s.value==="top"?t=0:s.value==="bottom"&&(t=100)),(o==null?void 0:o.type)==="position-keyword"&&(o.value==="left"?e=0:o.value==="center"?t=50:o.value==="right"?e=100:o.value==="top"?t=0:o.value==="bottom"&&(t=100)),((s==null?void 0:s.type)==="px"||(s==null?void 0:s.type)==="%"||(s==null?void 0:s.type)==="em")&&(n=s==null?void 0:s.type,e=Number(s.value)),((o==null?void 0:o.type)==="px"||(o==null?void 0:o.type)==="%"||(o==null?void 0:o.type)==="em")&&(i=o==null?void 0:o.type,t=Number(o.value))}return{cx:Rt(e,n),cy:Rt(t,i)}}),S3=hn(function(r){if(r.indexOf("linear")>-1||r.indexOf("radial")>-1){var e=v3(r);return e.map(function(o){var A=o.type,l=o.orientation,c=o.colorStops;b3(c);var u=c.map(function(m){return{offset:Rt(Number(m.length.value),"%"),color:g3(m)}});if(A==="linear-gradient")return new lc(Qa.LinearGradient,{angle:l?x3(l):Hs,steps:u});if(A==="radial-gradient"&&(l||(l=[{type:"shape",value:"circle"}]),l[0].type==="shape"&&l[0].value==="circle")){var h=C3(l[0].at),d=h.cx,f=h.cy,g;if(l[0].style){var v=l[0].style,p=v.type,y=v.value;p==="extent-keyword"?g=d3(y):g=Rt(y,p)}return new lc(Qa.RadialGradient,{cx:d,cy:f,size:g,steps:u})}})}var t=r[0];if(r[1]==="("||r[2]==="("){if(t==="l"){var n=m3.exec(r);if(n){var i,a=((i=n[2].match(cI))===null||i===void 0?void 0:i.map(function(o){return o.split(":")}))||[];return[new lc(Qa.LinearGradient,{angle:Rt(parseFloat(n[1]),"deg"),steps:a.map(function(o){var A=We(o,2),l=A[0],c=A[1];return{offset:Rt(Number(l)*100,"%"),color:c}})})]}}else if(t==="r"){var s=F3(r);if(s)if(At(s))r=s;else return[new lc(Qa.RadialGradient,s)]}else if(t==="p")return T3(r)}});function F3(r){var e=w3.exec(r);if(e){var t,n=((t=e[4].match(cI))===null||t===void 0?void 0:t.map(function(i){return i.split(":")}))||[];return{cx:Rt(50,"%"),cy:Rt(50,"%"),steps:n.map(function(i){var a=We(i,2),s=a[0],o=a[1];return{offset:Rt(Number(s)*100,"%"),color:o}})}}return null}function T3(r){var e=B3.exec(r);if(e){var t=e[1],n=e[2];switch(t){case"a":t="repeat";break;case"x":t="repeat-x";break;case"y":t="repeat-y";break;case"n":t="no-repeat";break;default:t="no-repeat"}return{image:n,repetition:t}}return null}function Gs(r){return r&&!!r.image}function th(r){return r&&!ke(r.r)&&!ke(r.g)&&!ke(r.b)}var YA=hn(function(r){if(Gs(r))return De({repetition:"repeat"},r);if(ke(r)&&(r=""),r==="transparent")return lI;if(r==="currentColor")r="black";else if(r==="none")return AI;var e=S3(r);if(e)return e;var t=Uh(r),n=[0,0,0,0];return t!==null&&(n[0]=t.r||0,n[1]=t.g||0,n[2]=t.b||0,n[3]=t.opacity),f3.apply(void 0,n)});function M3(r,e){if(!(!th(r)||!th(e)))return[[Number(r.r),Number(r.g),Number(r.b),Number(r.alpha)],[Number(e.r),Number(e.g),Number(e.b),Number(e.alpha)],function(t){var n=t.slice();if(n[3])for(var i=0;i<3;i++)n[i]=Math.round(Yt(n[i],0,255));return n[3]=Yt(n[3],0,1),"rgba(".concat(n.join(","),")")}]}function Ml(r,e){if(ke(e))return Rt(0,"px");if(e="".concat(e).trim().toLowerCase(),isFinite(Number(e))){if("px".search(r)>=0)return Rt(Number(e),"px");if("deg".search(r)>=0)return Rt(Number(e),"deg")}var t=[];e=e.replace(r,function(i){return t.push(i),"U".concat(i)});var n="U(".concat(r.source,")");return t.map(function(i){return Rt(Number(e.replace(new RegExp("U".concat(i),"g"),"").replace(new RegExp(n,"g"),"*0")),i)})[0]}var uI=function(e){return Ml(new RegExp("px","g"),e)},O3=hn(uI),_3=function(e){return Ml(new RegExp("%","g"),e)};hn(_3);var hI=function(e){return Be(e)||isFinite(Number(e))?Rt(Number(e)||0,"px"):Ml(new RegExp("px|%|em|rem","g"),e)},_w=hn(hI),dI=function(e){return Ml(new RegExp("deg|rad|grad|turn","g"),e)},I3=hn(dI);function k3(r,e,t,n){var i=arguments.length>4&&arguments[4]!==void 0?arguments[4]:0,a="",s=r.value||0,o=e.value||0,A=Ow(r.unit),l=r.convertTo(A),c=e.convertTo(A);return l&&c?(s=l.value,o=c.value,a=Mw(r.unit)):(Bt.isLength(r.unit)||Bt.isLength(e.unit))&&(s=Nr(r,i,t),o=Nr(e,i,t),a="px"),[s,o,function(u){return u+a}]}function br(r){var e=0;return r.unit===we.kDegrees?e=r.value:r.unit===we.kRadians?e=Br(Number(r.value)):r.unit===we.kTurns?e=_D(Number(r.value)):r.value&&(e=r.value),e}function $b(r,e){var t;return Array.isArray(r)?t=r.map(function(n){return Number(n)}):At(r)?t=r.split(" ").map(function(n){return Number(n)}):Be(r)&&(t=[r]),e===2?t.length===1?[t[0],t[0]]:[t[0],t[1]]:e===4?t.length===1?[t[0],t[0],t[0],t[0]]:t.length===2?[t[0],t[1],t[0],t[1]]:t.length===3?[t[0],t[1],t[2],t[1]]:[t[0],t[1],t[2],t[3]]:e==="even"&&t.length%2===1?[].concat(tt(t),tt(t)):t}function Nr(r,e,t){var n=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!1;if(r.unit===we.kPixels)return Number(r.value);if(r.unit===we.kPercentage&&t){var i=t.nodeName===ae.GROUP?t.getLocalBounds():t.getGeometryBounds();return(n?i.min[e]:0)+r.value/100*i.halfExtents[e]*2}return 0}var L3=function(e){return Ml(/deg|rad|grad|turn|px|%/g,e)},Q3=["blur","brightness","drop-shadow","contrast","grayscale","sepia","saturate","hue-rotate","invert"];function N3(){var r=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"";if(r=r.toLowerCase().trim(),r==="none")return[];for(var e=/\s*([\w-]+)\(([^)]*)\)/g,t=[],n,i=0;n=e.exec(r);){if(n.index!==i)return[];if(i=n.index+n[0].length,Q3.indexOf(n[1])>-1&&t.push({name:n[1],params:n[2].split(" ").map(function(a){return L3(a)||YA(a)})}),e.lastIndex===r.length)return t}return[]}function fI(r){return r.toString()}var gI=function(e){return typeof e=="number"?Rt(e):/^\s*[-+]?(\d*\.)?\d+\s*$/.test(e)?Rt(Number(e)):Rt(0)},Iw=hn(gI);hn(function(r){return At(r)?r.split(" ").map(Iw):r.map(Iw)});function $1(r,e){return[r,e,fI]}function Y1(r,e){return function(t,n){return[t,n,function(i){return fI(Yt(i,r,e))}]}}function vI(r,e){if(r.length===e.length)return[r,e,function(t){return t}]}function kw(r){return r.parsedStyle.d.totalLength===0&&(r.parsedStyle.d.totalLength=JR(r.parsedStyle.d.absolutePath)),r.parsedStyle.d.totalLength}function U3(r){return r.parsedStyle.points.totalLength===0&&(r.parsedStyle.points.totalLength=yD(r.parsedStyle.points.points)),r.parsedStyle.points.totalLength}function P3(r){for(var e=0;e<r.length;e++){var t=r[e-1],n=r[e],i=n[0];if(i==="M"&&t){var a=t[0],s=[n[1],n[2]],o=void 0;a==="L"||a==="M"?o=[t[1],t[2]]:(a==="C"||a==="A"||a==="Q")&&(o=[t[t.length-2],t[t.length-1]]),o&&nh(s,o)&&(r.splice(e,1),e--)}}}function R3(r){for(var e=!1,t=r.length,n=0;n<t;n++){var i=r[n],a=i[0];if(a==="C"||a==="A"||a==="Q"){e=!0;break}}return e}function D3(r){for(var e=[],t=[],n=[],i=0;i<r.length;i++){var a=r[i],s=a[0];s==="M"?(n.length&&(t.push(n),n=[]),n.push([a[1],a[2]])):s==="Z"?n.length&&(e.push(n),n=[]):n.push([a[1],a[2]])}return n.length>0&&t.push(n),{polygons:e,polylines:t}}function nh(r,e){return r[0]===e[0]&&r[1]===e[1]}function H3(r,e){for(var t=[],n=[],i=[],a=0;a<r.length;a++){var s=r[a],o=s.currentPoint,A=s.params,l=s.prePoint,c=void 0;switch(s.command){case"Q":c=mD(l[0],l[1],A[1],A[2],A[3],A[4]);break;case"C":c=gD(l[0],l[1],A[1],A[2],A[3],A[4],A[5],A[6]);break;case"A":var u=s.arcParams;c=hD(u.cx,u.cy,u.rx,u.ry,u.xRotation,u.startAngle,u.endAngle);break;default:t.push(o[0]),n.push(o[1]);break}c&&(s.box=c,t.push(c.x,c.x+c.width),n.push(c.y,c.y+c.height))}t=t.filter(function(B){return!Number.isNaN(B)&&B!==1/0&&B!==-1/0}),n=n.filter(function(B){return!Number.isNaN(B)&&B!==1/0&&B!==-1/0});var h=Wu(t),d=Wu(n),f=ju(t),g=ju(n);if(i.length===0)return{x:h,y:d,width:f-h,height:g-d};for(var v=0;v<i.length;v++){var p=i[v],y=p.currentPoint,m=void 0;y[0]===h?(m=cc(p,e),h-=m.xExtra):y[0]===f&&(m=cc(p,e),f+=m.xExtra),y[1]===d?(m=cc(p,e),d-=m.yExtra):y[1]===g&&(m=cc(p,e),g+=m.yExtra)}return{x:h,y:d,width:f-h,height:g-d}}function cc(r,e){var t=r.prePoint,n=r.currentPoint,i=r.nextPoint,a=Math.pow(n[0]-t[0],2)+Math.pow(n[1]-t[1],2),s=Math.pow(n[0]-i[0],2)+Math.pow(n[1]-i[1],2),o=Math.pow(t[0]-i[0],2)+Math.pow(t[1]-i[1],2),A=Math.acos((a+s-o)/(2*Math.sqrt(a)*Math.sqrt(s)));if(!A||Math.sin(A)===0||Lo(A,0))return{xExtra:0,yExtra:0};var l=Math.abs(Math.atan2(i[1]-n[1],i[0]-n[0])),c=Math.abs(Math.atan2(i[0]-n[0],i[1]-n[1]));l=l>Math.PI/2?Math.PI-l:l,c=c>Math.PI/2?Math.PI-c:c;var u={xExtra:Math.cos(A/2-l)*(e/2*(1/Math.sin(A/2)))-e/2||0,yExtra:Math.cos(c-A/2)*(e/2*(1/Math.sin(A/2)))-e/2||0};return u}function Yb(r,e){return[e[0]+(e[0]-r[0]),e[1]+(e[1]-r[1])]}var Xb=function(e,t){var n=e.x*t.x+e.y*t.y,i=Math.sqrt((Math.pow(e.x,2)+Math.pow(e.y,2))*(Math.pow(t.x,2)+Math.pow(t.y,2))),a=e.x*t.y-e.y*t.x<0?-1:1,s=a*Math.acos(n/i);return s},Zb=function(e,t,n,i,a,s,o,A){t=Math.abs(t),n=Math.abs(n),i=G_(i,360);var l=ft(i);if(e.x===o.x&&e.y===o.y)return{x:e.x,y:e.y,ellipticalArcAngle:0};if(t===0||n===0)return{x:0,y:0,ellipticalArcAngle:0};var c=(e.x-o.x)/2,u=(e.y-o.y)/2,h={x:Math.cos(l)*c+Math.sin(l)*u,y:-Math.sin(l)*c+Math.cos(l)*u},d=Math.pow(h.x,2)/Math.pow(t,2)+Math.pow(h.y,2)/Math.pow(n,2);d>1&&(t*=Math.sqrt(d),n*=Math.sqrt(d));var f=Math.pow(t,2)*Math.pow(n,2)-Math.pow(t,2)*Math.pow(h.y,2)-Math.pow(n,2)*Math.pow(h.x,2),g=Math.pow(t,2)*Math.pow(h.y,2)+Math.pow(n,2)*Math.pow(h.x,2),v=f/g;v=v<0?0:v;var p=(a!==s?1:-1)*Math.sqrt(v),y={x:p*(t*h.y/n),y:p*(-(n*h.x)/t)},m={x:Math.cos(l)*y.x-Math.sin(l)*y.y+(e.x+o.x)/2,y:Math.sin(l)*y.x+Math.cos(l)*y.y+(e.y+o.y)/2},B={x:(h.x-y.x)/t,y:(h.y-y.y)/n},C=Xb({x:1,y:0},B),S={x:(-h.x-y.x)/t,y:(-h.y-y.y)/n},F=Xb(B,S);!s&&F>0?F-=2*Math.PI:s&&F<0&&(F+=2*Math.PI),F%=2*Math.PI;var T=C+F*A,O=t*Math.cos(T),_=n*Math.sin(T),k={x:Math.cos(l)*O-Math.sin(l)*_+m.x,y:Math.sin(l)*O+Math.cos(l)*_+m.y,ellipticalArcStartAngle:C,ellipticalArcEndAngle:C+F,ellipticalArcAngle:T,ellipticalArcCenter:m,resultantRx:t,resultantRy:n};return k};function G3(r){for(var e=[],t=null,n=null,i=null,a=0,s=r.length,o=0;o<s;o++){var A=r[o];n=r[o+1];var l=A[0],c={command:l,prePoint:t,params:A,startTangent:null,endTangent:null,currentPoint:null,nextPoint:null,arcParams:null,box:null,cubicParams:null};switch(l){case"M":i=[A[1],A[2]],a=o;break;case"A":var u=K3(t,A);c.arcParams=u;break}if(l==="Z")t=i,n=r[a+1];else{var h=A.length;t=[A[h-2],A[h-1]]}n&&n[0]==="Z"&&(n=r[a],e[a]&&(e[a].prePoint=t)),c.currentPoint=t,e[a]&&nh(t,e[a].currentPoint)&&(e[a].prePoint=c.prePoint);var d=n?[n[n.length-2],n[n.length-1]]:null;c.nextPoint=d;var f=c.prePoint;if(["L","H","V"].includes(l))c.startTangent=[f[0]-t[0],f[1]-t[1]],c.endTangent=[t[0]-f[0],t[1]-f[1]];else if(l==="Q"){var g=[A[1],A[2]];c.startTangent=[f[0]-g[0],f[1]-g[1]],c.endTangent=[t[0]-g[0],t[1]-g[1]]}else if(l==="T"){var v=e[o-1],p=Yb(v.currentPoint,f);v.command==="Q"?(c.command="Q",c.startTangent=[f[0]-p[0],f[1]-p[1]],c.endTangent=[t[0]-p[0],t[1]-p[1]]):(c.command="TL",c.startTangent=[f[0]-t[0],f[1]-t[1]],c.endTangent=[t[0]-f[0],t[1]-f[1]])}else if(l==="C"){var y=[A[1],A[2]],m=[A[3],A[4]];c.startTangent=[f[0]-y[0],f[1]-y[1]],c.endTangent=[t[0]-m[0],t[1]-m[1]],c.startTangent[0]===0&&c.startTangent[1]===0&&(c.startTangent=[y[0]-m[0],y[1]-m[1]]),c.endTangent[0]===0&&c.endTangent[1]===0&&(c.endTangent=[m[0]-y[0],m[1]-y[1]])}else if(l==="S"){var B=e[o-1],C=Yb(B.currentPoint,f),S=[A[1],A[2]];B.command==="C"?(c.command="C",c.startTangent=[f[0]-C[0],f[1]-C[1]],c.endTangent=[t[0]-S[0],t[1]-S[1]]):(c.command="SQ",c.startTangent=[f[0]-S[0],f[1]-S[1]],c.endTangent=[t[0]-S[0],t[1]-S[1]])}else if(l==="A"){var F=Jb(c,0),T=F.x,O=F.y,_=Jb(c,1,!1),k=_.x,L=_.y;c.startTangent=[T,O],c.endTangent=[k,L]}e.push(c)}return e}function Jb(r,e){var t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0,n=r.arcParams,i=n.rx,a=i===void 0?0:i,s=n.ry,o=s===void 0?0:s,A=n.xRotation,l=n.arcFlag,c=n.sweepFlag,u=Zb({x:r.prePoint[0],y:r.prePoint[1]},a,o,A,!!l,!!c,{x:r.currentPoint[0],y:r.currentPoint[1]},e),h=Zb({x:r.prePoint[0],y:r.prePoint[1]},a,o,A,!!l,!!c,{x:r.currentPoint[0],y:r.currentPoint[1]},t?e+.005:e-.005),d=h.x-u.x,f=h.y-u.y,g=Math.sqrt(d*d+f*f);return{x:-d/g,y:-f/g}}function uc(r){return Math.sqrt(r[0]*r[0]+r[1]*r[1])}function Lw(r,e){return uc(r)*uc(e)?(r[0]*e[0]+r[1]*e[1])/(uc(r)*uc(e)):1}function eE(r,e){return(r[0]*e[1]<r[1]*e[0]?-1:1)*Math.acos(Lw(r,e))}function K3(r,e){var t=e[1],n=e[2],i=G_(ft(e[3]),Math.PI*2),a=e[4],s=e[5],o=r[0],A=r[1],l=e[6],c=e[7],u=Math.cos(i)*(o-l)/2+Math.sin(i)*(A-c)/2,h=-1*Math.sin(i)*(o-l)/2+Math.cos(i)*(A-c)/2,d=u*u/(t*t)+h*h/(n*n);d>1&&(t*=Math.sqrt(d),n*=Math.sqrt(d));var f=t*t*(h*h)+n*n*(u*u),g=f?Math.sqrt((t*t*(n*n)-f)/f):1;a===s&&(g*=-1),isNaN(g)&&(g=0);var v=n?g*t*h/n:0,p=t?g*-n*u/t:0,y=(o+l)/2+Math.cos(i)*v-Math.sin(i)*p,m=(A+c)/2+Math.sin(i)*v+Math.cos(i)*p,B=[(u-v)/t,(h-p)/n],C=[(-1*u-v)/t,(-1*h-p)/n],S=eE([1,0],B),F=eE(B,C);return Lw(B,C)<=-1&&(F=Math.PI),Lw(B,C)>=1&&(F=0),s===0&&F>0&&(F-=2*Math.PI),s===1&&F<0&&(F+=2*Math.PI),{cx:y,cy:m,rx:nh(r,[l,c])?0:t,ry:nh(r,[l,c])?0:n,startAngle:S,endAngle:S+F,xRotation:i,arcFlag:a,sweepFlag:s}}var pI=function(e){if(e===""||Array.isArray(e)&&e.length===0)return{absolutePath:[],hasArc:!1,segments:[],polygons:[],polylines:[],curve:null,totalLength:0,rect:{x:0,y:0,width:0,height:0}};var t;try{t=$u(e)}catch{t=$u(""),console.error("[g]: Invalid SVG Path definition: ".concat(e))}P3(t);var n=R3(t),i=D3(t),a=i.polygons,s=i.polylines,o=G3(t),A=H3(o,0),l=A.x,c=A.y,u=A.width,h=A.height;return{absolutePath:t,hasArc:n,segments:o,polygons:a,polylines:s,totalLength:0,rect:{x:Number.isFinite(l)?l:0,y:Number.isFinite(c)?c:0,width:Number.isFinite(u)?u:0,height:Number.isFinite(h)?h:0}}},z3=hn(pI);function yI(r){return At(r)?z3(r):pI(r)}function V3(r,e,t){var n=r.curve,i=e.curve;(!n||n.length===0)&&(n=bw(r.absolutePath,!1),r.curve=n),(!i||i.length===0)&&(i=bw(e.absolutePath,!1),e.curve=i);var a=[n,i];n.length!==i.length&&(a=Z_(n,i));var s=Tb(a[0])!==Tb(a[1])?WR(a[0]):jR(a[0]);return[s,tD(a[1],s),function(o){return o}]}function j3(r,e){var t;return At(r)?t=r.split(" ").map(function(n){var i=n.split(","),a=We(i,2),s=a[0],o=a[1];return[Number(s),Number(o)]}):t=r,{points:t,totalLength:0,segments:[]}}function W3(r,e){return[r.points,e.points,function(t){return t}]}var $t=null,Uo=/\s*(\w+)\(([^)]*)\)/g;function pr(r){return function(e){var t=0;return r.map(function(n){return n===$t?e[t++]:n})}}function us(r){return r}var cl={matrix:["NNNNNN",[$t,$t,0,0,$t,$t,0,0,0,0,1,0,$t,$t,0,1],us],matrix3d:["NNNNNNNNNNNNNNNN",us],rotate:["A"],rotateX:["A"],rotateY:["A"],rotateZ:["A"],rotate3d:["NNNA"],perspective:["L"],scale:["Nn",pr([$t,$t,new Bt(1)]),us],scaleX:["N",pr([$t,new Bt(1),new Bt(1)]),pr([$t,new Bt(1)])],scaleY:["N",pr([new Bt(1),$t,new Bt(1)]),pr([new Bt(1),$t])],scaleZ:["N",pr([new Bt(1),new Bt(1),$t])],scale3d:["NNN",us],skew:["Aa",null,us],skewX:["A",null,pr([$t,Hs])],skewY:["A",null,pr([Hs,$t])],translate:["Tt",pr([$t,$t,hi]),us],translateX:["T",pr([$t,hi,hi]),pr([$t,hi])],translateY:["T",pr([hi,$t,hi]),pr([hi,$t])],translateZ:["L",pr([hi,hi,$t])],translate3d:["TTL",us]};function mI(r){for(var e=[],t=r.length,n=0;n<t;n++){var i=r[n],a=i[0],s=i.slice(1);a==="translate"||a==="skew"?s.length===1&&s.push(0):a==="scale"&&s.length===1&&s.push(s[0]);var o=cl[a];if(!o)return[];var A=s.map(function(l){return Rt(l)});e.push({t:a,d:A})}return e}function wI(r){if(Array.isArray(r))return mI(r);if(r=(r||"none").trim(),r==="none")return[];var e=[],t,n=0;for(Uo.lastIndex=0;t=Uo.exec(r);){if(t.index!==n)return[];n=t.index+t[0].length;var i=t[1],a=cl[i];if(!a)return[];var s=t[2].split(","),o=a[0];if(o.length<s.length)return[];for(var A=[],l=0;l<o.length;l++){var c=s[l],u=o[l],h=void 0;if(c?h={A:function(f){return f.trim()==="0"?Hs:I3(f)},N:Iw,T:_w,L:O3}[u.toUpperCase()](c):h={a:Hs,n:A[0],t:hi}[u],h===void 0)return[];A.push(h)}if(e.push({t:i,d:A}),Uo.lastIndex===r.length)return e}return[]}function q3(r){if(Array.isArray(r))return mI(r);if(r=(r||"none").trim(),r==="none")return[];var e=[],t,n=0;for(Uo.lastIndex=0;t=Uo.exec(r);){if(t.index!==n)return[];n=t.index+t[0].length;var i=t[1],a=cl[i];if(!a)return[];var s=t[2].split(","),o=a[0];if(o.length<s.length)return[];for(var A=[],l=0;l<o.length;l++){var c=s[l],u=o[l],h=void 0;if(c?h={A:function(f){return f.trim()==="0"?Hs:dI(f)},N:gI,T:hI,L:uI}[u.toUpperCase()](c):h={a:Hs,n:A[0],t:hi}[u],h===void 0)return[];A.push(h)}if(e.push({t:i,d:A}),Uo.lastIndex===r.length)return e}return[]}function $3(r){var e,t,n,i;switch(r.t){case"rotateX":return i=ft(br(r.d[0])),[1,0,0,0,0,Math.cos(i),Math.sin(i),0,0,-Math.sin(i),Math.cos(i),0,0,0,0,1];case"rotateY":return i=ft(br(r.d[0])),[Math.cos(i),0,-Math.sin(i),0,0,1,0,0,Math.sin(i),0,Math.cos(i),0,0,0,0,1];case"rotate":case"rotateZ":return i=ft(br(r.d[0])),[Math.cos(i),Math.sin(i),0,0,-Math.sin(i),Math.cos(i),0,0,0,0,1,0,0,0,0,1];case"rotate3d":e=r.d[0].value,t=r.d[1].value,n=r.d[2].value,i=ft(br(r.d[3]));var a=e*e+t*t+n*n;if(a===0)e=1,t=0,n=0;else if(a!==1){var s=Math.sqrt(a);e/=s,t/=s,n/=s}var o=Math.sin(i/2),A=o*Math.cos(i/2),l=o*o;return[1-2*(t*t+n*n)*l,2*(e*t*l+n*A),2*(e*n*l-t*A),0,2*(e*t*l-n*A),1-2*(e*e+n*n)*l,2*(t*n*l+e*A),0,2*(e*n*l+t*A),2*(t*n*l-e*A),1-2*(e*e+t*t)*l,0,0,0,0,1];case"scale":return[r.d[0].value,0,0,0,0,r.d[1].value,0,0,0,0,1,0,0,0,0,1];case"scaleX":return[r.d[0].value,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];case"scaleY":return[1,0,0,0,0,r.d[0].value,0,0,0,0,1,0,0,0,0,1];case"scaleZ":return[1,0,0,0,0,1,0,0,0,0,r.d[0].value,0,0,0,0,1];case"scale3d":return[r.d[0].value,0,0,0,0,r.d[1].value,0,0,0,0,r.d[2].value,0,0,0,0,1];case"skew":var c=ft(br(r.d[0])),u=ft(br(r.d[1]));return[1,Math.tan(u),0,0,Math.tan(c),1,0,0,0,0,1,0,0,0,0,1];case"skewX":return i=ft(br(r.d[0])),[1,0,0,0,Math.tan(i),1,0,0,0,0,1,0,0,0,0,1];case"skewY":return i=ft(br(r.d[0])),[1,Math.tan(i),0,0,0,1,0,0,0,0,1,0,0,0,0,1];case"translate":return e=Nr(r.d[0],0,null)||0,t=Nr(r.d[1],0,null)||0,[1,0,0,0,0,1,0,0,0,0,1,0,e,t,0,1];case"translateX":return e=Nr(r.d[0],0,null)||0,[1,0,0,0,0,1,0,0,0,0,1,0,e,0,0,1];case"translateY":return t=Nr(r.d[0],0,null)||0,[1,0,0,0,0,1,0,0,0,0,1,0,0,t,0,1];case"translateZ":return n=Nr(r.d[0],0,null)||0,[1,0,0,0,0,1,0,0,0,0,1,0,0,0,n,1];case"translate3d":return e=Nr(r.d[0],0,null)||0,t=Nr(r.d[1],0,null)||0,n=Nr(r.d[2],0,null)||0,[1,0,0,0,0,1,0,0,0,0,1,0,e,t,n,1];case"perspective":var h=Nr(r.d[0],0,null)||0,d=h?-1/h:0;return[1,0,0,0,0,1,0,0,0,0,1,d,0,0,0,1];case"matrix":return[r.d[0].value,r.d[1].value,0,0,r.d[2].value,r.d[3].value,0,0,0,0,1,0,r.d[4].value,r.d[5].value,0,1];case"matrix3d":return r.d.map(function(f){return f.value})}}function Y3(r,e){return[r[0]*e[0]+r[4]*e[1]+r[8]*e[2]+r[12]*e[3],r[1]*e[0]+r[5]*e[1]+r[9]*e[2]+r[13]*e[3],r[2]*e[0]+r[6]*e[1]+r[10]*e[2]+r[14]*e[3],r[3]*e[0]+r[7]*e[1]+r[11]*e[2]+r[15]*e[3],r[0]*e[4]+r[4]*e[5]+r[8]*e[6]+r[12]*e[7],r[1]*e[4]+r[5]*e[5]+r[9]*e[6]+r[13]*e[7],r[2]*e[4]+r[6]*e[5]+r[10]*e[6]+r[14]*e[7],r[3]*e[4]+r[7]*e[5]+r[11]*e[6]+r[15]*e[7],r[0]*e[8]+r[4]*e[9]+r[8]*e[10]+r[12]*e[11],r[1]*e[8]+r[5]*e[9]+r[9]*e[10]+r[13]*e[11],r[2]*e[8]+r[6]*e[9]+r[10]*e[10]+r[14]*e[11],r[3]*e[8]+r[7]*e[9]+r[11]*e[10]+r[15]*e[11],r[0]*e[12]+r[4]*e[13]+r[8]*e[14]+r[12]*e[15],r[1]*e[12]+r[5]*e[13]+r[9]*e[14]+r[13]*e[15],r[2]*e[12]+r[6]*e[13]+r[10]*e[14]+r[14]*e[15],r[3]*e[12]+r[7]*e[13]+r[11]*e[14]+r[15]*e[15]]}function X3(r){return r.length===0?[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]:r.map($3).reduce(Y3)}function tE(r){var e=[0,0,0],t=[1,1,1],n=[0,0,0],i=[0,0,0,1],a=[0,0,0,1];return ND(X3(r),e,t,n,i,a),[[e,t,n,a,i]]}var Z3=(function(){function r(n,i){for(var a=[[0,0,0,0],[0,0,0,0],[0,0,0,0],[0,0,0,0]],s=0;s<4;s++)for(var o=0;o<4;o++)for(var A=0;A<4;A++)a[s][o]+=i[s][A]*n[A][o];return a}function e(n){return n[0][2]===0&&n[0][3]===0&&n[1][2]===0&&n[1][3]===0&&n[2][0]===0&&n[2][1]===0&&n[2][2]===1&&n[2][3]===0&&n[3][2]===0&&n[3][3]===1}function t(n,i,a,s,o){for(var A=[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],l=0;l<4;l++)A[l][3]=o[l];for(var c=0;c<3;c++)for(var u=0;u<3;u++)A[3][c]+=n[u]*A[u][c];var h=s[0],d=s[1],f=s[2],g=s[3],v=[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]];v[0][0]=1-2*(d*d+f*f),v[0][1]=2*(h*d-f*g),v[0][2]=2*(h*f+d*g),v[1][0]=2*(h*d+f*g),v[1][1]=1-2*(h*h+f*f),v[1][2]=2*(d*f-h*g),v[2][0]=2*(h*f-d*g),v[2][1]=2*(d*f+h*g),v[2][2]=1-2*(h*h+d*d),A=r(A,v);var p=[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]];a[2]&&(p[2][1]=a[2],A=r(A,p)),a[1]&&(p[2][1]=0,p[2][0]=a[0],A=r(A,p)),a[0]&&(p[2][0]=0,p[1][0]=a[0],A=r(A,p));for(var y=0;y<3;y++)for(var m=0;m<3;m++)A[y][m]*=i[y];return e(A)?[A[0][0],A[0][1],A[1][0],A[1][1],A[3][0],A[3][1]]:A[0].concat(A[1],A[2],A[3])}return t})();function J3(r){return r.toFixed(6).replace(".000000","")}function Df(r,e){var t,n;return r.decompositionPair!==e&&(r.decompositionPair=e,t=tE(r)),e.decompositionPair!==r&&(e.decompositionPair=r,n=tE(e)),t[0]===null||n[0]===null?[[!1],[!0],function(i){return i?e[0].d:r[0].d}]:(t[0].push(0),n[0].push(1),[t,n,function(i){var a=t4(t[0][3],n[0][3],i[5]),s=Z3(i[0],i[1],i[2],a,i[4]),o=s.map(J3).join(",");return o}])}function e4(r,e){for(var t=0,n=0;n<r.length;n++)t+=r[n]*e[n];return t}function t4(r,e,t){var n=e4(r,e);n=Yt(n,-1,1);var i=[];if(n===1)i=r;else for(var a=Math.acos(n),s=Math.sin(t*a)*1/Math.sqrt(1-n*n),o=0;o<4;o++)i.push(r[o]*(Math.cos(t*a)-n*s)+e[o]*s);return i}function Hf(r){return r.replace(/[XY]/,"")}function Gf(r){return r.replace(/(X|Y|Z|3d)?$/,"3d")}var n4=function(e,t){return e==="perspective"&&t==="perspective"||(e==="matrix"||e==="matrix3d")&&(t==="matrix"||t==="matrix3d")};function r4(r,e,t){var n=!1;if(!r.length||!e.length){r.length||(n=!0,r=e,e=[]);for(var i=function(){var k=r[a],L=k.t,U=k.d,G=L.substring(0,5)==="scale"?1:0;e.push({t:L,d:U.map(function(W){return typeof W=="number"?Rt(G):Rt(G,W.unit)})})},a=0;a<r.length;a++)i()}var s=[],o=[],A=[];if(r.length!==e.length){var l=Df(r,e);s=[l[0]],o=[l[1]],A=[["matrix",[l[2]]]]}else for(var c=0;c<r.length;c++){var u=r[c].t,h=e[c].t,d=r[c].d,f=e[c].d,g=cl[u],v=cl[h],p=void 0;if(n4(u,h)){var y=Df([r[c]],[e[c]]);s.push(y[0]),o.push(y[1]),A.push(["matrix",[y[2]]]);continue}else if(u===h)p=u;else if(g[2]&&v[2]&&Hf(u)===Hf(h))p=Hf(u),d=g[2](d),f=v[2](f);else if(g[1]&&v[1]&&Gf(u)===Gf(h))p=Gf(u),d=g[1](d),f=v[1](f);else{var m=Df(r,e);s=[m[0]],o=[m[1]],A=[["matrix",[m[2]]]];break}for(var B=[],C=[],S=[],F=0;F<d.length;F++){var T=k3(d[F],f[F],t,!1,F);B[F]=T[0],C[F]=T[1],S.push(T[2])}s.push(B),o.push(C),A.push([p,S])}if(n){var O=s;s=o,o=O}return[s,o,function(_){return _.map(function(k,L){var U=k.map(function(G,W){return A[L][1][W](G)}).join(",");return A[L][0]==="matrix"&&U.split(",").length===16&&(A[L][0]="matrix3d"),A[L][0]==="matrix3d"&&U.split(",").length===6&&(A[L][0]="matrix"),"".concat(A[L][0],"(").concat(U,")")}).join(" ")}]}var i4=hn(function(r){if(At(r)){if(r==="text-anchor")return[Rt(0,"px"),Rt(0,"px")];var e=r.split(" ");return e.length===1&&(e[0]==="top"||e[0]==="bottom"?(e[1]=e[0],e[0]="center"):e[1]="center"),e.length!==2?null:[_w(nE(e[0])),_w(nE(e[1]))]}return[Rt(r[0]||0,"px"),Rt(r[1]||0,"px")]});function nE(r){return r==="center"?"50%":r==="left"||r==="top"?"0%":r==="right"||r==="bottom"?"100%":r}var X1=[{n:"display",k:["none"]},{n:"opacity",int:!0,inh:!0,d:"1",syntax:pe.OPACITY_VALUE},{n:"fillOpacity",int:!0,inh:!0,d:"1",syntax:pe.OPACITY_VALUE},{n:"strokeOpacity",int:!0,inh:!0,d:"1",syntax:pe.OPACITY_VALUE},{n:"fill",int:!0,k:["none"],d:"none",syntax:pe.PAINT},{n:"fillRule",k:["nonzero","evenodd"],d:"nonzero"},{n:"stroke",int:!0,k:["none"],d:"none",syntax:pe.PAINT,l:!0},{n:"shadowType",k:["inner","outer","both"],d:"outer",l:!0},{n:"shadowColor",int:!0,syntax:pe.COLOR},{n:"shadowOffsetX",int:!0,l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"shadowOffsetY",int:!0,l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"shadowBlur",int:!0,l:!0,d:"0",syntax:pe.SHADOW_BLUR},{n:"lineWidth",int:!0,inh:!0,d:"1",l:!0,a:["strokeWidth"],syntax:pe.LENGTH_PERCENTAGE},{n:"increasedLineWidthForHitTesting",inh:!0,d:"0",l:!0,syntax:pe.LENGTH_PERCENTAGE},{n:"lineJoin",inh:!0,l:!0,a:["strokeLinejoin"],k:["miter","bevel","round"],d:"miter"},{n:"lineCap",inh:!0,l:!0,a:["strokeLinecap"],k:["butt","round","square"],d:"butt"},{n:"lineDash",int:!0,inh:!0,k:["none"],a:["strokeDasharray"],syntax:pe.LENGTH_PERCENTAGE_12},{n:"lineDashOffset",int:!0,inh:!0,d:"0",a:["strokeDashoffset"],syntax:pe.LENGTH_PERCENTAGE},{n:"offsetPath",syntax:pe.DEFINED_PATH},{n:"offsetDistance",int:!0,syntax:pe.OFFSET_DISTANCE},{n:"dx",int:!0,l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"dy",int:!0,l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"zIndex",ind:!0,int:!0,d:"0",k:["auto"],syntax:pe.Z_INDEX},{n:"visibility",k:["visible","hidden"],ind:!0,inh:!0,int:!0,d:"visible"},{n:"pointerEvents",inh:!0,k:["none","auto","stroke","fill","painted","visible","visiblestroke","visiblefill","visiblepainted","all"],d:"auto"},{n:"filter",ind:!0,l:!0,k:["none"],d:"none",syntax:pe.FILTER},{n:"clipPath",syntax:pe.DEFINED_PATH},{n:"textPath",syntax:pe.DEFINED_PATH},{n:"textPathSide",k:["left","right"],d:"left"},{n:"textPathStartOffset",l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"transform",p:100,int:!0,k:["none"],d:"none",syntax:pe.TRANSFORM},{n:"transformOrigin",p:100,d:"0 0",l:!0,syntax:pe.TRANSFORM_ORIGIN},{n:"cx",int:!0,l:!0,d:"0",syntax:pe.COORDINATE},{n:"cy",int:!0,l:!0,d:"0",syntax:pe.COORDINATE},{n:"cz",int:!0,l:!0,d:"0",syntax:pe.COORDINATE},{n:"r",int:!0,l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"rx",int:!0,l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"ry",int:!0,l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"x",int:!0,l:!0,d:"0",syntax:pe.COORDINATE},{n:"y",int:!0,l:!0,d:"0",syntax:pe.COORDINATE},{n:"z",int:!0,l:!0,d:"0",syntax:pe.COORDINATE},{n:"width",int:!0,l:!0,k:["auto","fit-content","min-content","max-content"],d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"height",int:!0,l:!0,k:["auto","fit-content","min-content","max-content"],d:"0",syntax:pe.LENGTH_PERCENTAGE},{n:"radius",int:!0,l:!0,d:"0",syntax:pe.LENGTH_PERCENTAGE_14},{n:"x1",int:!0,l:!0,syntax:pe.COORDINATE},{n:"y1",int:!0,l:!0,syntax:pe.COORDINATE},{n:"z1",int:!0,l:!0,syntax:pe.COORDINATE},{n:"x2",int:!0,l:!0,syntax:pe.COORDINATE},{n:"y2",int:!0,l:!0,syntax:pe.COORDINATE},{n:"z2",int:!0,l:!0,syntax:pe.COORDINATE},{n:"d",int:!0,l:!0,d:"",syntax:pe.PATH,p:50},{n:"points",int:!0,l:!0,syntax:pe.LIST_OF_POINTS,p:50},{n:"text",l:!0,d:"",syntax:pe.TEXT,p:50},{n:"textTransform",l:!0,inh:!0,k:["capitalize","uppercase","lowercase","none"],d:"none",syntax:pe.TEXT_TRANSFORM,p:51},{n:"font",l:!0},{n:"fontSize",int:!0,inh:!0,d:"16px",l:!0,syntax:pe.LENGTH_PERCENTAGE},{n:"fontFamily",l:!0,inh:!0,d:"sans-serif"},{n:"fontStyle",l:!0,inh:!0,k:["normal","italic","oblique"],d:"normal"},{n:"fontWeight",l:!0,inh:!0,k:["normal","bold","bolder","lighter"],d:"normal"},{n:"fontVariant",l:!0,inh:!0,k:["normal","small-caps"],d:"normal"},{n:"lineHeight",l:!0,syntax:pe.LENGTH,int:!0,d:"0"},{n:"letterSpacing",l:!0,syntax:pe.LENGTH,int:!0,d:"0"},{n:"miterLimit",l:!0,syntax:pe.NUMBER,d:function(e){return e===ae.PATH||e===ae.POLYGON||e===ae.POLYLINE?"4":"10"}},{n:"wordWrap",l:!0},{n:"wordWrapWidth",l:!0},{n:"maxLines",l:!0},{n:"textOverflow",l:!0,d:"clip"},{n:"leading",l:!0},{n:"textBaseline",l:!0,inh:!0,k:["top","hanging","middle","alphabetic","ideographic","bottom"],d:"alphabetic"},{n:"textAlign",l:!0,inh:!0,k:["start","center","middle","end","left","right"],d:"start"},{n:"markerStart",syntax:pe.MARKER},{n:"markerEnd",syntax:pe.MARKER},{n:"markerMid",syntax:pe.MARKER},{n:"markerStartOffset",syntax:pe.LENGTH,l:!0,int:!0,d:"0"},{n:"markerEndOffset",syntax:pe.LENGTH,l:!0,int:!0,d:"0"}],a4=new Set(X1.filter(function(r){return!!r.l}).map(function(r){return r.n})),BI={},s4=(function(){function r(e){var t=this;ue(this,r),this.runtime=e,X1.forEach(function(n){t.registerMetadata(n)})}return he(r,[{key:"registerMetadata",value:function(t){[t.n].concat(tt(t.a||[])).forEach(function(n){BI[n]=t})}},{key:"getPropertySyntax",value:function(t){return this.runtime.CSSPropertySyntaxFactory[t]}},{key:"processProperties",value:function(t,n){var i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{forceUpdateGeometry:!1};Object.assign(t.attributes,n);var a=t.parsedStyle.clipPath,s=t.parsedStyle.offsetPath;o4(t,n);var o=!!i.forceUpdateGeometry;if(!o){for(var A in n)if(a4.has(A)){o=!0;break}}var l=bI(t);l.has("fill")&&n.fill&&(t.parsedStyle.fill=YA(n.fill)),l.has("stroke")&&n.stroke&&(t.parsedStyle.stroke=YA(n.stroke)),l.has("shadowColor")&&n.shadowColor&&(t.parsedStyle.shadowColor=YA(n.shadowColor)),l.has("filter")&&n.filter&&(t.parsedStyle.filter=N3(n.filter)),l.has("radius")&&!ke(n.radius)&&(t.parsedStyle.radius=$b(n.radius,4)),l.has("lineDash")&&!ke(n.lineDash)&&(t.parsedStyle.lineDash=$b(n.lineDash,"even")),l.has("points")&&n.points&&(t.parsedStyle.points=j3(n.points)),l.has("d")&&n.d===""&&(t.parsedStyle.d=De({},aI)),l.has("d")&&n.d&&(t.parsedStyle.d=yI(n.d)),l.has("textTransform")&&n.textTransform&&this.runtime.CSSPropertySyntaxFactory[pe.TEXT_TRANSFORM].calculator(null,null,{value:n.textTransform},t,null),l.has("clipPath")&&!He(n.clipPath)&&this.runtime.CSSPropertySyntaxFactory[pe.DEFINED_PATH].calculator("clipPath",a,n.clipPath,t,this.runtime),l.has("offsetPath")&&n.offsetPath&&this.runtime.CSSPropertySyntaxFactory[pe.DEFINED_PATH].calculator("offsetPath",s,n.offsetPath,t,this.runtime),l.has("transform")&&n.transform&&(t.parsedStyle.transform=wI(n.transform)),l.has("transformOrigin")&&n.transformOrigin&&(t.parsedStyle.transformOrigin=i4(n.transformOrigin)),l.has("markerStart")&&n.markerStart&&(t.parsedStyle.markerStart=this.runtime.CSSPropertySyntaxFactory[pe.MARKER].calculator(null,n.markerStart,n.markerStart,null,null)),l.has("markerEnd")&&n.markerEnd&&(t.parsedStyle.markerEnd=this.runtime.CSSPropertySyntaxFactory[pe.MARKER].calculator(null,n.markerEnd,n.markerEnd,null,null)),l.has("markerMid")&&n.markerMid&&(t.parsedStyle.markerMid=this.runtime.CSSPropertySyntaxFactory[pe.MARKER].calculator("",n.markerMid,n.markerMid,null,null)),l.has("zIndex")&&!ke(n.zIndex)&&this.runtime.CSSPropertySyntaxFactory[pe.Z_INDEX].postProcessor(t),l.has("offsetDistance")&&!ke(n.offsetDistance)&&this.runtime.CSSPropertySyntaxFactory[pe.OFFSET_DISTANCE].postProcessor(t),l.has("transform")&&n.transform&&this.runtime.CSSPropertySyntaxFactory[pe.TRANSFORM].postProcessor(t),l.has("transformOrigin")&&n.transformOrigin&&this.runtime.CSSPropertySyntaxFactory[pe.TRANSFORM_ORIGIN].postProcessor(t),o&&(t.dirty(!0,!0),i.forceUpdateGeometry||this.runtime.sceneGraphService.dirtyToRoot(t))}},{key:"updateGeometry",value:function(t){var n=t.nodeName,i=this.runtime.geometryUpdaterFactory[n];if(i){var a=t.geometry;a.contentBounds||(a.contentBounds=new It),a.renderBounds||(a.renderBounds=new It);var s=t.parsedStyle,o=i.update(s,t),A=o.cx,l=A===void 0?0:A,c=o.cy,u=c===void 0?0:c,h=o.cz,d=h===void 0?0:h,f=o.hwidth,g=f===void 0?0:f,v=o.hheight,p=v===void 0?0:v,y=o.hdepth,m=y===void 0?0:y,B=[Math.abs(g),Math.abs(p),m],C=s.stroke,S=s.lineWidth,F=S===void 0?1:S,T=s.increasedLineWidthForHitTesting,O=T===void 0?0:T,_=s.shadowType,k=_===void 0?"outer":_,L=s.shadowColor,U=s.filter,G=U===void 0?[]:U,W=s.transformOrigin,V=[l,u,d];a.contentBounds.update(V,B);var K=n===ae.POLYLINE||n===ae.POLYGON||n===ae.PATH?Math.SQRT2:.5,D=C&&!C.isNone;if(D){var X=((F||0)+(O||0))*K;B[0]+=X,B[1]+=X}if(a.renderBounds.update(V,B),L&&k&&k!=="inner"){var te=a.renderBounds,ie=te.min,re=te.max,xe=s.shadowBlur,$=s.shadowOffsetX,z=s.shadowOffsetY,ee=xe||0,Ae=$||0,be=z||0,Le=ie[0]-ee+Ae,Ue=re[0]+ee+Ae,at=ie[1]-ee+be,lt=re[1]+ee+be;ie[0]=Math.min(ie[0],Le),re[0]=Math.max(re[0],Ue),ie[1]=Math.min(ie[1],at),re[1]=Math.max(re[1],lt),a.renderBounds.setMinMax(ie,re)}G.forEach(function(nt){var gr=nt.name,St=nt.params;if(gr==="blur"){var Ji=St[0].value;a.renderBounds.update(a.renderBounds.center,Va(a.renderBounds.halfExtents,a.renderBounds.halfExtents,[Ji,Ji,0]))}else if(gr==="drop-shadow"){var ir=St[0].value,Wt=St[1].value,_t=St[2].value,Qn=a.renderBounds,qn=Qn.min,vr=Qn.max,ar=qn[0]-_t+ir,$n=vr[0]+_t+ir,rn=qn[1]-_t+Wt,an=vr[1]+_t+Wt;qn[0]=Math.min(qn[0],ar),vr[0]=Math.max(vr[0],$n),qn[1]=Math.min(qn[1],rn),vr[1]=Math.max(vr[1],an),a.renderBounds.setMinMax(qn,vr)}}),t.geometry.dirty=!1;var ct=g<0,pt=p<0,Ne=(ct?-1:1)*(W?Nr(W[0],0,t,!0):0),ht=(pt?-1:1)*(W?Nr(W[1],1,t,!0):0);(Ne||ht)&&t.setOrigin(Ne,ht)}}},{key:"updateSizeAttenuation",value:function(t,n){t.style.isSizeAttenuation?(t.style.rawLineWidth||(t.style.rawLineWidth=t.style.lineWidth),t.style.lineWidth=(t.style.rawLineWidth||1)/n,t.nodeName===ae.CIRCLE&&(t.style.rawR||(t.style.rawR=t.style.r),t.style.r=(t.style.rawR||1)/n)):(t.style.rawLineWidth&&(t.style.lineWidth=t.style.rawLineWidth,delete t.style.rawLineWidth),t.nodeName===ae.CIRCLE&&t.style.rawR&&(t.style.r=t.style.rawR,delete t.style.rawR))}}])})();function o4(r,e){var t=bI(r);for(var n in e)t.has(n)&&(r.parsedStyle[n]=e[n])}function bI(r){return r.constructor.PARSED_STYLE_LIST}var A4=(function(){function r(){ue(this,r),this.mixer=$1}return he(r,[{key:"calculator",value:function(t,n,i,a){return br(i)}}])})(),l4=(function(){function r(){ue(this,r)}return he(r,[{key:"calculator",value:function(t,n,i,a,s){return i instanceof ii&&(i=null),s.sceneGraphService.updateDisplayObjectDependency(t,n,i,a),t==="clipPath"&&a.forEach(function(o){o.childNodes.length===0&&s.sceneGraphService.dirtyToRoot(o)}),i}}])})(),c4=(function(){function r(){ue(this,r),this.parser=YA,this.mixer=M3}return he(r,[{key:"calculator",value:function(t,n,i,a){return i instanceof ii?i.value==="none"?AI:lI:i}}])})(),u4=(function(){function r(){ue(this,r)}return he(r,[{key:"calculator",value:function(t,n,i){return i instanceof ii?[]:i}}])})();function rE(r){var e=r.parsedStyle,t=e.fontSize;return ke(t)?null:t}var Qw=(function(){function r(){ue(this,r),this.mixer=$1}return he(r,[{key:"calculator",value:function(t,n,i,a,s){if(Be(i))return i;if(Bt.isRelativeUnit(i.unit)){if(i.unit===we.kPercentage)return 0;if(i.unit===we.kEms){if(a.parentNode){var o=rE(a.parentNode);if(o)return o*=i.value,o}return 0}if(i.unit===we.kRems){var A;if(a!=null&&(A=a.ownerDocument)!==null&&A!==void 0&&A.documentElement){var l=rE(a.ownerDocument.documentElement);if(l)return l*=i.value,l}return 0}}else return i.value}}])})(),h4=(function(){function r(){ue(this,r),this.mixer=vI}return he(r,[{key:"calculator",value:function(t,n,i){return i.map(function(a){return a.value})}}])})(),d4=(function(){function r(){ue(this,r),this.mixer=vI}return he(r,[{key:"calculator",value:function(t,n,i){return i.map(function(a){return a.value})}}])})(),f4=(function(){function r(){ue(this,r)}return he(r,[{key:"calculator",value:function(t,n,i,a){var s;i instanceof ii&&(i=null);var o=(s=i)===null||s===void 0?void 0:s.cloneNode(!0);return o&&(o.style.isMarker=!0),o}}])})(),g4=(function(){function r(){ue(this,r),this.mixer=$1}return he(r,[{key:"calculator",value:function(t,n,i){return i.value}}])})(),v4=(function(){function r(){ue(this,r),this.mixer=Y1(0,1)}return he(r,[{key:"calculator",value:function(t,n,i){return i.value}},{key:"postProcessor",value:function(t){var n=t.parsedStyle,i=n.offsetPath,a=n.offsetDistance;if(i){var s=i.nodeName;if(s===ae.LINE||s===ae.PATH||s===ae.POLYLINE){var o=i.getPoint(a);o&&t.setLocalPosition(o.x,o.y)}}}}])})(),p4=(function(){function r(){ue(this,r),this.mixer=Y1(0,1)}return he(r,[{key:"calculator",value:function(t,n,i){return i.value}}])})(),y4=(function(){function r(){ue(this,r),this.parser=yI,this.mixer=V3}return he(r,[{key:"calculator",value:function(t,n,i){return i instanceof ii&&i.value==="unset"?{absolutePath:[],hasArc:!1,segments:[],polygons:[],polylines:[],curve:null,totalLength:0,rect:new Vo(0,0,0,0)}:i}}])})(),m4=he(function r(){ue(this,r),this.mixer=W3}),w4=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.mixer=Y1(0,1/0),t}return $e(e,r),he(e)})(Qw),B4=(function(){function r(){ue(this,r)}return he(r,[{key:"calculator",value:function(t,n,i,a){return i instanceof ii?i.value==="unset"?"":i.value:"".concat(i)}},{key:"postProcessor",value:function(t){t.nodeValue="".concat(t.parsedStyle.text)||""}}])})(),b4=(function(){function r(){ue(this,r)}return he(r,[{key:"calculator",value:function(t,n,i,a){var s=a.getAttribute("text");if(s){var o=s;i.value==="capitalize"?o=s.charAt(0).toUpperCase()+s.slice(1):i.value==="lowercase"?o=s.toLowerCase():i.value==="uppercase"&&(o=s.toUpperCase()),a.parsedStyle.text=o}return i.value}}])})(),Kf=new WeakMap;function E4(r,e,t){if(r){var n=typeof r=="string"?document.getElementById(r):r;Kf.has(n)&&Kf.get(n).destroy(t),Kf.set(n,e)}}var Z1=typeof window<"u"&&typeof window.document<"u";function x4(r){return!!r.getAttribute}function C4(r,e){for(var t=0,n=r.length;t<n;){var i=t+n>>>1;EI(r[i],e)<0?t=i+1:n=i}return t}function EI(r,e){var t=Number(r.parsedStyle.zIndex||0),n=Number(e.parsedStyle.zIndex||0);if(t===n){var i=r.parentNode;if(i){var a=i.childNodes||[];return a.indexOf(r)-a.indexOf(e)}}return t-n}function xI(r){var e=r;do{var t,n=(t=e.parsedStyle)===null||t===void 0?void 0:t.clipPath;if(n)return e;e=e.parentElement}while(e!==null);return null}var iE="px";function S4(r,e,t){Z1&&r.style&&(r.style.width=e+iE,r.style.height=t+iE)}function CI(r,e){if(Z1)return document.defaultView.getComputedStyle(r,null).getPropertyValue(e)}function F4(r){var e=CI(r,"width");return e==="auto"?r.offsetWidth:parseFloat(e)}function T4(r){var e=CI(r,"height");return e==="auto"?r.offsetHeight:parseFloat(e)}var M4=1,O4={touchstart:"pointerdown",touchend:"pointerup",touchendoutside:"pointerupoutside",touchmove:"pointermove",touchcancel:"pointercancel"},Nw=typeof performance=="object"&&performance.now?performance:Date;function rh(r){return r.nodeName===ae.FRAGMENT?!0:r.getRootNode().nodeName===ae.FRAGMENT}function $s(){var r=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"auto",e=arguments.length>1?arguments[1]:void 0,t=arguments.length>2?arguments[2]:void 0,n=!1,i=!1,a=!!e&&!e.isNone,s=!!t&&!t.isNone;return r==="visiblepainted"||r==="painted"||r==="auto"?(n=a,i=s):r==="visiblefill"||r==="fill"?n=!0:r==="visiblestroke"||r==="stroke"?i=!0:(r==="visible"||r==="all")&&(n=!0,i=!0),[n,i]}var _4=1,I4=function(){return _4++},Gi=typeof self=="object"&&self.self===self?self:typeof global=="object"&&global.global===global?global:{},k4=Date.now(),L4=function(){return Gi.performance&&typeof Gi.performance.now=="function"?Gi.performance.now():Date.now()-k4},MA={},aE=Date.now(),Q4=function(e){if(typeof e!="function")throw new TypeError("".concat(e," is not a function"));var t=Date.now(),n=t-aE,i=n>16?0:16-n,a=I4();return MA[a]=e,Object.keys(MA).length>1||setTimeout(function(){aE=t;var s=MA;MA={},Object.keys(s).forEach(function(o){return s[o](L4())})},i),a},N4=function(e){delete MA[e]},U4=["","webkit","moz","ms","o"],SI=function(e){return typeof e!="string"?Q4:e===""?Gi.requestAnimationFrame:Gi["".concat(e,"RequestAnimationFrame")]},P4=function(e){return typeof e!="string"?N4:e===""?Gi.cancelAnimationFrame:Gi["".concat(e,"CancelAnimationFrame")]||Gi["".concat(e,"CancelRequestAnimationFrame")]},R4=function(e,t){for(var n=0;e[n]!==void 0;){if(t(e[n]))return e[n];n+=1}},FI=R4(U4,function(r){return!!SI(r)}),J1=SI(FI),TI=P4(FI);Gi.requestAnimationFrame=J1;Gi.cancelAnimationFrame=TI;var D4=(function(){function r(){ue(this,r),this.callbacks=[]}return he(r,[{key:"getCallbacksNum",value:function(){return this.callbacks.length}},{key:"tapPromise",value:function(t,n){this.callbacks.push(n)}},{key:"promise",value:function(){for(var t=arguments.length,n=new Array(t),i=0;i<t;i++)n[i]=arguments[i];return Promise.all(this.callbacks.map(function(a){return a.apply(void 0,n)}))}}])})(),H4=(function(){function r(){ue(this,r),this.callbacks=[]}return he(r,[{key:"tapPromise",value:function(t,n){this.callbacks.push(n)}},{key:"promise",value:(function(){var e=Ja(Gn().mark(function n(){var i,a,s,o,A=arguments;return Gn().wrap(function(l){for(;;)switch(l.prev=l.next){case 0:if(!this.callbacks.length){l.next=6;break}return l.next=1,(i=this.callbacks)[0].apply(i,A);case 1:a=l.sent,s=1;case 2:if(!(s<this.callbacks.length)){l.next=5;break}return o=this.callbacks[s],l.next=3,o(a);case 3:a=l.sent;case 4:s++,l.next=2;break;case 5:return l.abrupt("return",a);case 6:return l.abrupt("return",null);case 7:case"end":return l.stop()}},n,this)}));function t(){return e.apply(this,arguments)}return t})()}])})(),sr=(function(){function r(){ue(this,r),this.callbacks=[]}return he(r,[{key:"tap",value:function(t,n){this.callbacks.push(n)}},{key:"call",value:function(){for(var t=arguments.length,n=new Array(t),i=0;i<t;i++)n[i]=arguments[i];var a=arguments;this.callbacks.forEach(function(s){s.apply(void 0,a)})}}])})(),zf=(function(){function r(){ue(this,r),this.callbacks=[]}return he(r,[{key:"tap",value:function(t,n){this.callbacks.push(n)}},{key:"call",value:function(){for(var t=arguments.length,n=new Array(t),i=0;i<t;i++)n[i]=arguments[i];if(this.callbacks.length){for(var a=arguments,s=this.callbacks[0].apply(void 0,a),o=1;o<this.callbacks.length;o++){var A=this.callbacks[o];s=A(s)}return s}return null}}])})(),G4=["serif","sans-serif","monospace","cursive","fantasy","system-ui"],K4=/([\"\'])[^\'\"]+\1/;function sE(r){var e=r.fontSize,t=e===void 0?16:e,n=r.fontFamily,i=n===void 0?"sans-serif":n,a=r.fontStyle,s=a===void 0?"normal":a,o=r.fontVariant,A=o===void 0?"normal":o,l=r.fontWeight,c=l===void 0?"normal":l;return{fontSize:t,fontFamily:i,fontStyle:s,fontVariant:A,fontWeight:c}}var oE=hn(function(e){for(var t=sE(e),n=t.fontSize,i=t.fontFamily,a=t.fontStyle,s=t.fontVariant,o=t.fontWeight,A=Be(n)&&"".concat(n,"px")||"16px",l=i.split(","),c=l.length-1;c>=0;c--){var u=l[c].trim();!K4.test(u)&&G4.indexOf(u)<0&&(u='"'.concat(u,'"')),l[c]=u}return"".concat(a," ").concat(s," ").concat(o," ").concat(A," ").concat(l.join(","))},function(r){var e=sE(r),t=e.fontSize,n=e.fontFamily,i=e.fontStyle,a=e.fontVariant,s=e.fontWeight;return"".concat(i,"_").concat(a,"_").concat(s,"_").concat(t,"_").concat(n)}),z4=1e-6,gA=function(e){return Math.max(e,z4)};function Vf(r,e,t){return Xa(r),r[4]=Math.tan(e),r[1]=Math.tan(t),r}var An=xt(),V4=xt(),j4={scale:function(e){bs(An,[e[0].value,e[1].value,1].map(function(t){return gA(t)}))},scaleX:function(e){bs(An,[e[0].value,1,1].map(function(t){return gA(t)}))},scaleY:function(e){bs(An,[1,e[0].value,1].map(function(t){return gA(t)}))},scaleZ:function(e){bs(An,[1,1,e[0].value].map(function(t){return gA(t)}))},scale3d:function(e){bs(An,[e[0].value,e[1].value,e[2].value].map(function(t){return gA(t)}))},translate:function(e){Ia(An,[e[0].value,e[1].value,0])},translateX:function(e){Ia(An,[e[0].value,0,0])},translateY:function(e){Ia(An,[0,e[0].value,0])},translateZ:function(e){Ia(An,[0,0,e[0].value])},translate3d:function(e){Ia(An,[e[0].value,e[1].value,e[2].value])},rotate:function(e){fw(An,ft(br(e[0])))},rotateX:function(e){F_(An,ft(br(e[0])))},rotateY:function(e){T_(An,ft(br(e[0])))},rotateZ:function(e){fw(An,ft(br(e[0])))},rotate3d:function(e){S_(An,ft(br(e[3])),[e[0].value,e[1].value,e[2].value])},skew:function(e){Vf(An,ft(e[0].value),ft(e[1].value))},skewX:function(e){Vf(An,ft(e[0].value),0)},skewY:function(e){Vf(An,0,ft(e[0].value))},matrix:function(e){dw(An,e[0].value,e[1].value,0,0,e[2].value,e[3].value,0,0,0,0,1,0,e[4].value,e[5].value,0,1)},matrix3d:function(e){dw.apply(DP,[An].concat(tt(e.map(function(t){return t.value}))))}},W4=Ct(1,1,1),q4=Ze(),AE={translate:function(e,t){de.sceneGraphService.setLocalScale(e,W4,!1),de.sceneGraphService.setLocalEulerAngles(e,q4,void 0,void 0,!1),de.sceneGraphService.setLocalPosition(e,[t[0].value,t[1].value,0],!1),de.sceneGraphService.dirtyLocalTransform(e,e.transformable)}};function MI(r,e){if(r.length){if(r.length===1&&AE[r[0].t]){AE[r[0].t](e,r[0].d);return}for(var t=Xa(V4),n=0;n<r.length;n++){var i=r[n],a=i.t,s=i.d,o=j4[a];o&&(o(s),N_(t,t,An))}e.setLocalTransform(t)}else e.resetLocalTransform();return e.getLocalTransform()}var $4=(function(){function r(){ue(this,r),this.parser=q3,this.mixer=r4}return he(r,[{key:"calculator",value:function(t,n,i,a){return i instanceof ii?[]:i}},{key:"postProcessor",value:function(t){MI(t.parsedStyle.transform,t)}}])})(),Y4=(function(){function r(){ue(this,r)}return he(r,[{key:"postProcessor",value:function(t){var n=t.parsedStyle.transformOrigin;n[0].unit===we.kPixels&&n[1].unit===we.kPixels?t.setOrigin(n[0].value,n[1].value):t.getGeometryBounds()}}])})(),X4=(function(){function r(){ue(this,r)}return he(r,[{key:"calculator",value:function(t,n,i,a){return i.value}},{key:"postProcessor",value:function(t){if(t.parentNode){var n=t.parentNode,i=n.renderable,a=n.sortable;i&&n.dirty(),a&&(a.dirty=!0,a.dirtyReason=Zu.Z_INDEX_CHANGED)}}}])})(),Z4=(function(){function r(){ue(this,r)}return he(r,[{key:"update",value:function(t,n){var i=t.cx,a=i===void 0?0:i,s=t.cy,o=s===void 0?0:s,A=t.r,l=A===void 0?0:A;return{cx:a,cy:o,hwidth:l,hheight:l}}}])})(),J4=(function(){function r(){ue(this,r)}return he(r,[{key:"update",value:function(t,n){var i=t.cx,a=i===void 0?0:i,s=t.cy,o=s===void 0?0:s,A=t.rx,l=A===void 0?0:A,c=t.ry,u=c===void 0?0:c;return{cx:a,cy:o,hwidth:l,hheight:u}}}])})(),eH=(function(){function r(){ue(this,r)}return he(r,[{key:"update",value:function(t){var n=t.x1,i=t.y1,a=t.x2,s=t.y2,o=Math.min(n,a),A=Math.max(n,a),l=Math.min(i,s),c=Math.max(i,s),u=A-o,h=c-l,d=u/2,f=h/2;return{cx:o+d,cy:l+f,hwidth:d,hheight:f}}}])})(),tH=(function(){function r(){ue(this,r)}return he(r,[{key:"update",value:function(t){var n=t.d,i=n.rect,a=i.x,s=i.y,o=i.width,A=i.height,l=o/2,c=A/2;return{cx:a+l,cy:s+c,hwidth:l,hheight:c}}}])})(),nH=(function(){function r(){ue(this,r)}return he(r,[{key:"update",value:function(t){if(t.points&&Mr(t.points.points)){var n=t.points.points,i=Math.min.apply(Math,tt(n.map(function(h){return h[0]}))),a=Math.max.apply(Math,tt(n.map(function(h){return h[0]}))),s=Math.min.apply(Math,tt(n.map(function(h){return h[1]}))),o=Math.max.apply(Math,tt(n.map(function(h){return h[1]}))),A=a-i,l=o-s,c=A/2,u=l/2;return{cx:i+c,cy:s+u,hwidth:c,hheight:u}}return{cx:0,cy:0,hwidth:0,hheight:0}}}])})(),rH=(function(){function r(){ue(this,r)}return he(r,[{key:"update",value:function(t,n){var i=t.x,a=i===void 0?0:i,s=t.y,o=s===void 0?0:s,A=t.src,l=t.width,c=l===void 0?0:l,u=t.height,h=u===void 0?0:u,d=c,f=h;return A&&!At(A)&&(d||(d=A.width,t.width=d),f||(f=A.height,t.height=f)),{cx:a+d/2,cy:o+f/2,hwidth:d/2,hheight:f/2}}}])})(),iH=(function(){function r(e){ue(this,r),this.globalRuntime=e}return he(r,[{key:"isReadyToMeasure",value:function(t,n){var i=t.text;return i}},{key:"update",value:function(t,n){var i,a=t.text,s=t.textAlign,o=s===void 0?"start":s,A=t.lineWidth,l=A===void 0?1:A,c=t.textBaseline,u=c===void 0?"alphabetic":c,h=t.dx,d=h===void 0?0:h,f=t.dy,g=f===void 0?0:f,v=t.x,p=v===void 0?0:v,y=t.y,m=y===void 0?0:y;if(!this.isReadyToMeasure(t,n))return t.metrics={font:"",width:0,height:0,lines:[],lineWidths:[],lineHeight:0,maxLineWidth:0,fontProperties:{ascent:0,descent:0,fontSize:0},lineMetrics:[]},{hwidth:0,hheight:0,cx:0,cy:0};var B=(n==null||(i=n.ownerDocument)===null||i===void 0||(i=i.defaultView)===null||i===void 0?void 0:i.getConfig())||{},C=B.offscreenCanvas,S=this.globalRuntime.textService.measureText(a,t,C);t.metrics=S;var F=S.width,T=S.height,O=F/2,_=T/2,k=p+O;o==="center"||o==="middle"?k+=l/2-O:(o==="right"||o==="end")&&(k+=l-O*2);var L=m-_;return u==="middle"?L+=_:u==="top"||u==="hanging"?L+=_*2:u==="alphabetic"||(u==="bottom"||u==="ideographic")&&(L+=0),d&&(k+=d),g&&(L+=g),{cx:k,cy:L,hwidth:O,hheight:_}}}])})(),aH=(function(){function r(){ue(this,r)}return he(r,[{key:"update",value:function(t,n){return{cx:0,cy:0,hwidth:0,hheight:0}}}])})(),sH=(function(){function r(){ue(this,r)}return he(r,[{key:"update",value:function(t,n){var i=t.x,a=i===void 0?0:i,s=t.y,o=s===void 0?0:s,A=t.width,l=A===void 0?0:A,c=t.height,u=c===void 0?0:c;return{cx:a+l/2,cy:o+u/2,hwidth:l/2,hheight:u/2}}}])})(),Rh=(function(){function r(e){ue(this,r),this.eventPhase=r.prototype.NONE,this.bubbles=!0,this.cancelBubble=!0,this.cancelable=!1,this.defaultPrevented=!1,this.propagationStopped=!1,this.propagationImmediatelyStopped=!1,this.layer=new Dn,this.page=new Dn,this.canvas=new Dn,this.viewport=new Dn,this.composed=!1,this.NONE=0,this.CAPTURING_PHASE=1,this.AT_TARGET=2,this.BUBBLING_PHASE=3,this.manager=e}return he(r,[{key:"name",get:function(){return this.type}},{key:"layerX",get:function(){return this.layer.x}},{key:"layerY",get:function(){return this.layer.y}},{key:"pageX",get:function(){return this.page.x}},{key:"pageY",get:function(){return this.page.y}},{key:"x",get:function(){return this.canvas.x}},{key:"y",get:function(){return this.canvas.y}},{key:"canvasX",get:function(){return this.canvas.x}},{key:"canvasY",get:function(){return this.canvas.y}},{key:"viewportX",get:function(){return this.viewport.x}},{key:"viewportY",get:function(){return this.viewport.y}},{key:"composedPath",value:function(){return this.manager&&(!this.path||this.path[0]!==this.target)&&(this.path=this.target?this.manager.propagationPath(this.target):[]),this.path}},{key:"propagationPath",get:function(){return this.composedPath()}},{key:"preventDefault",value:function(){this.nativeEvent instanceof Event&&this.nativeEvent.cancelable&&this.nativeEvent.preventDefault(),this.defaultPrevented=!0}},{key:"stopImmediatePropagation",value:function(){this.propagationImmediatelyStopped=!0}},{key:"stopPropagation",value:function(){this.propagationStopped=!0}},{key:"initEvent",value:function(){}},{key:"initUIEvent",value:function(){}},{key:"clone",value:function(){throw new Error(wt)}}])})(),OI=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.client=new Dn,t.movement=new Dn,t.offset=new Dn,t.global=new Dn,t.screen=new Dn,t}return $e(e,r),he(e,[{key:"clientX",get:function(){return this.client.x}},{key:"clientY",get:function(){return this.client.y}},{key:"movementX",get:function(){return this.movement.x}},{key:"movementY",get:function(){return this.movement.y}},{key:"offsetX",get:function(){return this.offset.x}},{key:"offsetY",get:function(){return this.offset.y}},{key:"globalX",get:function(){return this.global.x}},{key:"globalY",get:function(){return this.global.y}},{key:"screenX",get:function(){return this.screen.x}},{key:"screenY",get:function(){return this.screen.y}},{key:"getModifierState",value:function(n){return"getModifierState"in this.nativeEvent&&this.nativeEvent.getModifierState(n)}},{key:"initMouseEvent",value:function(){throw new Error(wt)}}])})(Rh),ih=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.width=0,t.height=0,t.isPrimary=!1,t}return $e(e,r),he(e,[{key:"getCoalescedEvents",value:function(){return this.type==="pointermove"||this.type==="mousemove"||this.type==="touchmove"?[this]:[]}},{key:"getPredictedEvents",value:function(){throw new Error("getPredictedEvents is not supported!")}},{key:"clone",value:function(){return this.manager.clonePointerEvent(this)}}])})(OI),Uw=(function(r){function e(){return ue(this,e),qe(this,e,arguments)}return $e(e,r),he(e,[{key:"clone",value:function(){return this.manager.cloneWheelEvent(this)}}])})(OI),vn=(function(r){function e(t,n){var i;return ue(this,e),i=qe(this,e,[null]),i.type=t,i.detail=n==null?void 0:n.detail,n&&!("detail"in n)&&(i.detail=n),Object.assign(i,n),i}return $e(e,r),he(e)})(Rh),_I=(function(){function r(){ue(this,r),this.emitter=new p_}return he(r,[{key:"on",value:function(t,n,i){return this.addEventListener(t,n,i),this}},{key:"addEventListener",value:function(t,n,i){var a=!1,s=!1;if(sl(i))a=i;else if(i){var o=i.capture;a=o===void 0?!1:o;var A=i.once;s=A===void 0?!1:A}a&&(t+="capture"),n=Te(n)?n:n.handleEvent;var l=Te(n)?void 0:n;return s?this.emitter.once(t,n,l):this.emitter.on(t,n,l),this}},{key:"off",value:function(t,n,i){return t?this.removeEventListener(t,n,i):this.removeAllEventListeners(),this}},{key:"removeAllEventListeners",value:function(){var t;(t=this.emitter)===null||t===void 0||t.removeAllListeners()}},{key:"removeEventListener",value:function(t,n,i){var a;if(!this.emitter)return this;var s=sl(i)?i:i==null?void 0:i.capture;s&&(t+="capture"),n=Te(n)?n:(a=n)===null||a===void 0?void 0:a.handleEvent;var o=Te(n)?void 0:n;return this.emitter.off(t,n,o),this}},{key:"emit",value:function(t,n){this.dispatchEvent(new vn(t,n))}},{key:"dispatchEventToSelf",value:function(t){t.target||(t.target=this),t.currentTarget=this,this.emitter.emit(t.type,t)}},{key:"dispatchEvent",value:function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,i=arguments.length>2?arguments[2]:void 0;if(i)return this.dispatchEventToSelf(t),!0;var a;if(this.document)a=this;else if(this.defaultView)a=this.defaultView;else{var s;a=(s=this.ownerDocument)===null||s===void 0?void 0:s.defaultView}if(a){if(t.manager=a.getEventService(),!t.manager)return!1;t.defaultPrevented=!1,t.path?t.path.length=0:t.page=[],n||(t.target=this),t.manager.dispatchEvent(t,t.type,n)}else this.dispatchEventToSelf(t);return!t.defaultPrevented}}])})(),Vt=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.shadow=!1,t.ownerDocument=null,t.isConnected=!1,t.baseURI="",t.childNodes=[],t.nodeType=0,t.nodeName="",t.nodeValue=null,t.mutations=void 0,t.parentNode=null,t.destroyed=!1,t}return $e(e,r),he(e,[{key:"textContent",get:function(){var n="";this.nodeName===ae.TEXT&&(n+=this.style.text);var i=ka(this.childNodes),a;try{for(i.s();!(a=i.n()).done;){var s=a.value;s.nodeName===ae.TEXT?n+=s.nodeValue:n+=s.textContent}}catch(o){i.e(o)}finally{i.f()}return n},set:function(n){var i=this;this.childNodes.slice().forEach(function(a){i.removeChild(a)}),this.nodeName===ae.TEXT&&(this.style.text="".concat(n))}},{key:"getRootNode",value:function(){var n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return this.parentNode?this.parentNode.getRootNode(n):n.composed&&this.host?this.host.getRootNode(n):this}},{key:"hasChildNodes",value:function(){return this.childNodes.length>0}},{key:"isDefaultNamespace",value:function(n){throw new Error(wt)}},{key:"lookupNamespaceURI",value:function(n){throw new Error(wt)}},{key:"lookupPrefix",value:function(n){throw new Error(wt)}},{key:"normalize",value:function(){throw new Error(wt)}},{key:"isEqualNode",value:function(n){return this===n}},{key:"isSameNode",value:function(n){return this.isEqualNode(n)}},{key:"parent",get:function(){return this.parentNode}},{key:"parentElement",get:function(){return null}},{key:"nextSibling",get:function(){return null}},{key:"previousSibling",get:function(){return null}},{key:"firstChild",get:function(){return this.childNodes.length>0?this.childNodes[0]:null}},{key:"lastChild",get:function(){return this.childNodes.length>0?this.childNodes[this.childNodes.length-1]:null}},{key:"compareDocumentPosition",value:function(n){if(n===this)return 0;for(var i=n,a=this,s=[i],o=[a];(A=i.parentNode)!==null&&A!==void 0?A:a.parentNode;){var A;i=i.parentNode?(s.push(i.parentNode),i.parentNode):i,a=a.parentNode?(o.push(a.parentNode),a.parentNode):a}if(i!==a)return e.DOCUMENT_POSITION_DISCONNECTED|e.DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC|e.DOCUMENT_POSITION_PRECEDING;var l=s.length>o.length?s:o,c=l===s?o:s;if(l[l.length-c.length]===c[0])return l===s?e.DOCUMENT_POSITION_CONTAINED_BY|e.DOCUMENT_POSITION_FOLLOWING:e.DOCUMENT_POSITION_CONTAINS|e.DOCUMENT_POSITION_PRECEDING;for(var u=l.length-c.length,h=c.length-1;h>=0;h--){var d=c[h],f=l[u+h];if(f!==d){var g=d.parentNode.childNodes;return g.indexOf(d)<g.indexOf(f)?c===s?e.DOCUMENT_POSITION_PRECEDING:e.DOCUMENT_POSITION_FOLLOWING:l===s?e.DOCUMENT_POSITION_PRECEDING:e.DOCUMENT_POSITION_FOLLOWING}}return e.DOCUMENT_POSITION_FOLLOWING}},{key:"contain",value:function(n){return this.contains(n)}},{key:"contains",value:function(n){for(var i=n;i&&this!==i;)i=i.parentNode;return!!i}},{key:"getAncestor",value:function(n){for(var i=this;n>0&&i;)i=i.parentNode,n--;return i}},{key:"forEach",value:function(n){for(var i=[this];i.length>0;){var a=i.pop(),s=n(a);if(s===!1)break;for(var o=a.childNodes.length-1;o>=0;o--)i.push(a.childNodes[o])}}}],[{key:"isNode",value:function(n){return!!n.childNodes}}])})(_I);Vt.DOCUMENT_POSITION_DISCONNECTED=1;Vt.DOCUMENT_POSITION_PRECEDING=2;Vt.DOCUMENT_POSITION_FOLLOWING=4;Vt.DOCUMENT_POSITION_CONTAINS=8;Vt.DOCUMENT_POSITION_CONTAINED_BY=16;Vt.DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC=32;var oH=2048,AH=(function(){function r(e,t){var n=this;ue(this,r),this.nativeHTMLMap=new WeakMap,this.cursor="default",this.mappingTable={},this.mappingState={trackingData:{}},this.eventPool=new Map,this.tmpMatrix=xt(),this.tmpVec3=Ze(),this.onPointerDown=function(i){var a=n.createPointerEvent(i);if(n.dispatchEvent(a,"pointerdown"),a.pointerType==="touch")n.dispatchEvent(a,"touchstart");else if(a.pointerType==="mouse"||a.pointerType==="pen"){var s=a.button===2;n.dispatchEvent(a,s?"rightdown":"mousedown")}var o=n.trackingData(i.pointerId);o.pressTargetsByButton[i.button]=a.composedPath(),n.freeEvent(a)},this.onPointerUp=function(i){var a=Nw.now(),s=n.createPointerEvent(i,void 0,void 0,n.context.config.alwaysTriggerPointerEventOnCanvas?n.rootTarget:void 0);if(n.dispatchEvent(s,"pointerup"),s.pointerType==="touch")n.dispatchEvent(s,"touchend");else if(s.pointerType==="mouse"||s.pointerType==="pen"){var o=s.button===2;n.dispatchEvent(s,o?"rightup":"mouseup")}var A=n.trackingData(i.pointerId),l=n.findMountedTarget(A.pressTargetsByButton[i.button]),c=l;if(l&&!s.composedPath().includes(l)){for(var u=l;u&&!s.composedPath().includes(u);){if(s.currentTarget=u,n.notifyTarget(s,"pointerupoutside"),s.pointerType==="touch")n.notifyTarget(s,"touchendoutside");else if(s.pointerType==="mouse"||s.pointerType==="pen"){var h=s.button===2;n.notifyTarget(s,h?"rightupoutside":"mouseupoutside")}Vt.isNode(u)&&(u=u.parentNode)}delete A.pressTargetsByButton[i.button],c=u}if(c){var d,f=n.clonePointerEvent(s,"click");f.target=c,f.path=[],A.clicksByButton[i.button]||(A.clicksByButton[i.button]={clickCount:0,target:f.target,timeStamp:a});var g=n.context.renderingContext.root.ownerDocument.defaultView,v=A.clicksByButton[i.button];v.target===f.target&&a-v.timeStamp<g.getConfig().dblClickSpeed?++v.clickCount:v.clickCount=1,v.target=f.target,v.timeStamp=a,f.detail=v.clickCount,(d=s.detail)!==null&&d!==void 0&&d.preventClick||(!n.context.config.useNativeClickEvent&&(f.pointerType==="mouse"||f.pointerType==="touch")&&n.dispatchEvent(f,"click"),n.dispatchEvent(f,"pointertap")),n.freeEvent(f)}n.freeEvent(s)},this.onPointerMove=function(i){var a=n.createPointerEvent(i,void 0,void 0,n.context.config.alwaysTriggerPointerEventOnCanvas?n.rootTarget:void 0),s=a.pointerType==="mouse"||a.pointerType==="pen",o=n.trackingData(i.pointerId),A=n.findMountedTarget(o.overTargets);if(o.overTargets&&A!==a.target){var l=i.type==="mousemove"?"mouseout":"pointerout",c=n.createPointerEvent(i,l,A||void 0);if(n.dispatchEvent(c,"pointerout"),s&&n.dispatchEvent(c,"mouseout"),!a.composedPath().includes(A)){var u=n.createPointerEvent(i,"pointerleave",A||void 0);for(u.eventPhase=u.AT_TARGET;u.target&&!a.composedPath().includes(u.target);)u.currentTarget=u.target,n.notifyTarget(u),s&&n.notifyTarget(u,"mouseleave"),Vt.isNode(u.target)&&(u.target=u.target.parentNode);n.freeEvent(u)}n.freeEvent(c)}if(A!==a.target){var h=i.type==="mousemove"?"mouseover":"pointerover",d=n.clonePointerEvent(a,h);n.dispatchEvent(d,"pointerover"),s&&n.dispatchEvent(d,"mouseover");for(var f=A&&Vt.isNode(A)&&A.parentNode;f&&f!==(Vt.isNode(n.rootTarget)&&n.rootTarget.parentNode)&&f!==a.target;)f=f.parentNode;var g=!f||f===(Vt.isNode(n.rootTarget)&&n.rootTarget.parentNode);if(g){var v=n.clonePointerEvent(a,"pointerenter");for(v.eventPhase=v.AT_TARGET;v.target&&v.target!==A&&v.target!==(Vt.isNode(n.rootTarget)&&n.rootTarget.parentNode);)v.currentTarget=v.target,n.notifyTarget(v),s&&n.notifyTarget(v,"mouseenter"),Vt.isNode(v.target)&&(v.target=v.target.parentNode);n.freeEvent(v)}n.freeEvent(d)}n.dispatchEvent(a,"pointermove"),a.pointerType==="touch"&&n.dispatchEvent(a,"touchmove"),s&&(n.dispatchEvent(a,"mousemove"),n.cursor=n.getCursor(a.target)),o.overTargets=a.composedPath(),n.freeEvent(a)},this.onPointerOut=function(i){var a=n.trackingData(i.pointerId);if(a.overTargets){var s=i.pointerType==="mouse"||i.pointerType==="pen",o=n.findMountedTarget(a.overTargets),A=n.createPointerEvent(i,"pointerout",o||void 0);n.dispatchEvent(A),s&&n.dispatchEvent(A,"mouseout");var l=n.createPointerEvent(i,"pointerleave",o||void 0);for(l.eventPhase=l.AT_TARGET;l.target&&l.target!==(Vt.isNode(n.rootTarget)&&n.rootTarget.parentNode);)l.currentTarget=l.target,n.notifyTarget(l),s&&n.notifyTarget(l,"mouseleave"),Vt.isNode(l.target)&&(l.target=l.target.parentNode);a.overTargets=null,n.freeEvent(A),n.freeEvent(l)}n.cursor=null},this.onPointerOver=function(i){var a=n.trackingData(i.pointerId),s=n.createPointerEvent(i),o=s.pointerType==="mouse"||s.pointerType==="pen";n.dispatchEvent(s,"pointerover"),o&&n.dispatchEvent(s,"mouseover"),s.pointerType==="mouse"&&(n.cursor=n.getCursor(s.target));var A=n.clonePointerEvent(s,"pointerenter");for(A.eventPhase=A.AT_TARGET;A.target&&A.target!==(Vt.isNode(n.rootTarget)&&n.rootTarget.parentNode);)A.currentTarget=A.target,n.notifyTarget(A),o&&n.notifyTarget(A,"mouseenter"),Vt.isNode(A.target)&&(A.target=A.target.parentNode);a.overTargets=s.composedPath(),n.freeEvent(s),n.freeEvent(A)},this.onPointerUpOutside=function(i){var a=n.trackingData(i.pointerId),s=n.findMountedTarget(a.pressTargetsByButton[i.button]),o=n.createPointerEvent(i);if(s){for(var A=s;A;)o.currentTarget=A,n.notifyTarget(o,"pointerupoutside"),o.pointerType==="touch"||(o.pointerType==="mouse"||o.pointerType==="pen")&&n.notifyTarget(o,o.button===2?"rightupoutside":"mouseupoutside"),Vt.isNode(A)&&(A=A.parentNode);delete a.pressTargetsByButton[i.button]}n.freeEvent(o)},this.onWheel=function(i){var a=n.createWheelEvent(i);n.dispatchEvent(a),n.freeEvent(a)},this.onClick=function(i){if(n.context.config.useNativeClickEvent){var a=n.createPointerEvent(i);n.dispatchEvent(a),n.freeEvent(a)}},this.onPointerCancel=function(i){var a=n.createPointerEvent(i,void 0,void 0,n.context.config.alwaysTriggerPointerEventOnCanvas?n.rootTarget:void 0);n.dispatchEvent(a),n.freeEvent(a)},this.globalRuntime=e,this.context=t}return he(r,[{key:"init",value:function(){this.rootTarget=this.context.renderingContext.root.parentNode,this.addEventMapping("pointerdown",this.onPointerDown),this.addEventMapping("pointerup",this.onPointerUp),this.addEventMapping("pointermove",this.onPointerMove),this.addEventMapping("pointerout",this.onPointerOut),this.addEventMapping("pointerleave",this.onPointerOut),this.addEventMapping("pointercancel",this.onPointerCancel),this.addEventMapping("pointerover",this.onPointerOver),this.addEventMapping("pointerupoutside",this.onPointerUpOutside),this.addEventMapping("wheel",this.onWheel),this.addEventMapping("click",this.onClick)}},{key:"destroy",value:function(){this.mappingTable={},this.mappingState={},this.eventPool.clear()}},{key:"getScale",value:function(){var t=this.context.contextService.getBoundingClientRect(),n=1,i=1,a=this.context.contextService.getDomElement();if(a&&t){var s=a.offsetWidth,o=a.offsetHeight;s&&o&&(n=t.width/s,i=t.height/o)}return{scaleX:n,scaleY:i,bbox:t}}},{key:"client2Viewport",value:function(t){var n=this.getScale(),i=n.scaleX,a=n.scaleY,s=n.bbox;return new Dn((t.x-((s==null?void 0:s.left)||0))/i,(t.y-((s==null?void 0:s.top)||0))/a)}},{key:"viewport2Client",value:function(t){var n=this.getScale(),i=n.scaleX,a=n.scaleY,s=n.bbox;return new Dn((t.x+((s==null?void 0:s.left)||0))*i,(t.y+((s==null?void 0:s.top)||0))*a)}},{key:"viewport2Canvas",value:function(t){var n=t.x,i=t.y,a=this.rootTarget.defaultView,s=a.getCamera(),o=this.context.config,A=o.width,l=o.height,c=s.getPerspectiveInverse(),u=s.getWorldTransform(),h=tr(this.tmpMatrix,u,c),d=er(this.tmpVec3,n/A*2-1,(1-i/l)*2-1,0);return nr(d,d,h),new Dn(d[0],d[1])}},{key:"canvas2Viewport",value:function(t){var n=this.rootTarget.defaultView,i=n.getCamera(),a=i.getPerspective(),s=i.getViewTransform(),o=tr(this.tmpMatrix,a,s),A=er(this.tmpVec3,t.x,t.y,0);nr(this.tmpVec3,this.tmpVec3,o);var l=this.context.config,c=l.width,u=l.height;return new Dn((A[0]+1)/2*c,(1-(A[1]+1)/2)*u)}},{key:"setPickHandler",value:function(t){this.pickHandler=t}},{key:"addEventMapping",value:function(t,n){this.mappingTable[t]||(this.mappingTable[t]=[]),this.mappingTable[t].push({fn:n,priority:0}),this.mappingTable[t].sort(function(i,a){return i.priority-a.priority})}},{key:"mapEvent",value:function(t){if(this.rootTarget){var n=this.mappingTable[t.type];if(n)for(var i=0,a=n.length;i<a;i++)n[i].fn(t);else console.warn("[EventService]: Event mapping not defined for ".concat(t.type))}}},{key:"dispatchEvent",value:function(t,n,i){if(!i)t.propagationStopped=!1,t.propagationImmediatelyStopped=!1,this.propagate(t,n);else{t.eventPhase=t.AT_TARGET;var a=this.rootTarget.defaultView||null;t.currentTarget=a,this.notifyListeners(t,n)}}},{key:"propagate",value:function(t,n){if(t.target){var i=t.composedPath();t.eventPhase=t.CAPTURING_PHASE;for(var a=i.length-1;a>=1;a--)if(t.currentTarget=i[a],this.notifyTarget(t,n),t.propagationStopped||t.propagationImmediatelyStopped)return;if(t.eventPhase=t.AT_TARGET,t.currentTarget=t.target,this.notifyTarget(t,n),!(t.propagationStopped||t.propagationImmediatelyStopped)){var s=i.indexOf(t.currentTarget);t.eventPhase=t.BUBBLING_PHASE;for(var o=s+1;o<i.length;o++)if(t.currentTarget=i[o],this.notifyTarget(t,n),t.propagationStopped||t.propagationImmediatelyStopped)return}}}},{key:"propagationPath",value:function(t){var n=[t],i=this.rootTarget.defaultView||null;if(i&&i===t)return n.unshift(i.document),n;for(var a=0;a<oH&&t!==this.rootTarget;a++)Vt.isNode(t)&&t.parentNode&&(n.push(t.parentNode),t=t.parentNode);return i&&n.push(i),n}},{key:"hitTest",value:function(t){var n=t.viewportX,i=t.viewportY,a=this.context.config,s=a.width,o=a.height,A=a.disableHitTesting;return n<0||i<0||n>s||i>o?null:!A&&this.pickHandler(t)||this.rootTarget||null}},{key:"isNativeEventFromCanvas",value:function(t,n){var i,a=n==null?void 0:n.target;if((i=a)!==null&&i!==void 0&&i.shadowRoot&&(a=n.composedPath()[0]),a){if(a===t)return!0;if(t&&t.contains)return t.contains(a)}return n!=null&&n.composedPath?n.composedPath().indexOf(t)>-1:!1}},{key:"getExistedHTML",value:function(t){if(t.nativeEvent.composedPath)for(var n=0,i=t.nativeEvent.composedPath();n<i.length;n++){var a=i[n],s=this.nativeHTMLMap.get(a);if(s)return s}return null}},{key:"pickTarget",value:function(t){return this.hitTest({clientX:t.clientX,clientY:t.clientY,viewportX:t.viewportX,viewportY:t.viewportY,x:t.canvasX,y:t.canvasY})}},{key:"createPointerEvent",value:function(t,n,i,a){var s=this.allocateEvent(ih);this.copyPointerData(t,s),this.copyMouseData(t,s),this.copyData(t,s),s.nativeEvent=t.nativeEvent,s.originalEvent=t;var o=this.getExistedHTML(s),A=this.context.contextService.getDomElement();return s.target=i??(o||this.isNativeEventFromCanvas(A,s.nativeEvent)&&this.pickTarget(s)||a),typeof n=="string"&&(s.type=n),s}},{key:"createWheelEvent",value:function(t){var n=this.allocateEvent(Uw);this.copyWheelData(t,n),this.copyMouseData(t,n),this.copyData(t,n),n.nativeEvent=t.nativeEvent,n.originalEvent=t;var i=this.getExistedHTML(n),a=this.context.contextService.getDomElement();return n.target=i||this.isNativeEventFromCanvas(a,n.nativeEvent)&&this.pickTarget(n),n}},{key:"trackingData",value:function(t){return this.mappingState.trackingData[t]||(this.mappingState.trackingData[t]={pressTargetsByButton:{},clicksByButton:{},overTarget:null}),this.mappingState.trackingData[t]}},{key:"cloneWheelEvent",value:function(t){var n=this.allocateEvent(Uw);return n.nativeEvent=t.nativeEvent,n.originalEvent=t.originalEvent,this.copyWheelData(t,n),this.copyMouseData(t,n),this.copyData(t,n),n.target=t.target,n.path=t.composedPath().slice(),n.type=t.type,n}},{key:"clonePointerEvent",value:function(t,n){var i=this.allocateEvent(ih);return i.nativeEvent=t.nativeEvent,i.originalEvent=t.originalEvent,this.copyPointerData(t,i),this.copyMouseData(t,i),this.copyData(t,i),i.target=t.target,i.path=t.composedPath().slice(),i.type=n??i.type,i}},{key:"copyPointerData",value:function(t,n){n.pointerId=t.pointerId,n.width=t.width,n.height=t.height,n.isPrimary=t.isPrimary,n.pointerType=t.pointerType,n.pressure=t.pressure,n.tangentialPressure=t.tangentialPressure,n.tiltX=t.tiltX,n.tiltY=t.tiltY,n.twist=t.twist}},{key:"copyMouseData",value:function(t,n){n.altKey=t.altKey,n.button=t.button,n.buttons=t.buttons,n.ctrlKey=t.ctrlKey,n.metaKey=t.metaKey,n.shiftKey=t.shiftKey,n.client.copyFrom(t.client),n.movement.copyFrom(t.movement),n.canvas.copyFrom(t.canvas),n.screen.copyFrom(t.screen),n.global.copyFrom(t.global),n.offset.copyFrom(t.offset)}},{key:"copyWheelData",value:function(t,n){n.deltaMode=t.deltaMode,n.deltaX=t.deltaX,n.deltaY=t.deltaY,n.deltaZ=t.deltaZ}},{key:"copyData",value:function(t,n){n.isTrusted=t.isTrusted,n.timeStamp=Nw.now(),n.type=t.type,n.detail=t.detail,n.view=t.view,n.page.copyFrom(t.page),n.viewport.copyFrom(t.viewport)}},{key:"allocateEvent",value:function(t){this.eventPool.has(t)||this.eventPool.set(t,[]);var n=this.eventPool.get(t).pop()||new t(this);return n.eventPhase=n.NONE,n.currentTarget=null,n.path=[],n.target=null,n}},{key:"freeEvent",value:function(t){if(t.manager!==this)throw new Error("It is illegal to free an event not managed by this EventBoundary!");var n=t.constructor;this.eventPool.has(n)||this.eventPool.set(n,[]),this.eventPool.get(n).push(t)}},{key:"notifyTarget",value:function(t,n){n=n??t.type;var i=t.eventPhase===t.CAPTURING_PHASE||t.eventPhase===t.AT_TARGET?"".concat(n,"capture"):n;this.notifyListeners(t,i),t.eventPhase===t.AT_TARGET&&this.notifyListeners(t,n)}},{key:"notifyListeners",value:function(t,n){var i=t.currentTarget.emitter,a=i._events[n];if(a)if("fn"in a)a.once&&i.removeListener(n,a.fn,void 0,!0),a.fn.call(t.currentTarget||a.context,t);else for(var s=0;s<a.length&&!t.propagationImmediatelyStopped;s++)a[s].once&&i.removeListener(n,a[s].fn,void 0,!0),a[s].fn.call(t.currentTarget||a[s].context,t)}},{key:"findMountedTarget",value:function(t){if(!t)return null;for(var n=t[t.length-1],i=t.length-2;i>=0;i--){var a=t[i];if(a===this.rootTarget||Vt.isNode(a)&&a.parentNode===n)n=t[i];else break}return n}},{key:"getCursor",value:function(t){for(var n=t;n;){var i=x4(n)&&n.getAttribute("cursor");if(i)return i;n=Vt.isNode(n)&&n.parentNode}}}])})(),eB=(function(){function r(){ue(this,r)}return he(r,[{key:"getOrCreateCanvas",value:function(t,n){if(this.canvas)return this.canvas;if(t||de.offscreenCanvas)this.canvas=t||de.offscreenCanvas,this.context=this.canvas.getContext("2d",De({willReadFrequently:!0},n));else try{this.canvas=new window.OffscreenCanvas(0,0),this.context=this.canvas.getContext("2d",De({willReadFrequently:!0},n)),(!this.context||!this.context.measureText)&&(this.canvas=document.createElement("canvas"),this.context=this.canvas.getContext("2d"))}catch{this.canvas=document.createElement("canvas"),this.context=this.canvas.getContext("2d",De({willReadFrequently:!0},n))}return this.canvas.width=10,this.canvas.height=10,this.canvas}},{key:"getOrCreateContext",value:function(t,n){return this.context?this.context:(this.getOrCreateCanvas(t,n),this.context)}}],[{key:"createCanvas",value:function(){try{return new window.OffscreenCanvas(0,0)}catch{}try{return document.createElement("canvas")}catch{}return null}}])})(),Po=(function(r){return r[r.CAMERA_CHANGED=0]="CAMERA_CHANGED",r[r.DISPLAY_OBJECT_CHANGED=1]="DISPLAY_OBJECT_CHANGED",r[r.NONE=2]="NONE",r})({}),lH=(function(){function r(e,t){ue(this,r),this.inited=!1,this.stats={total:0,rendered:0},this.zIndexCounter=0,this.hooks={init:new sr,initAsync:new D4,dirtycheck:new zf,cull:new zf,beginFrame:new sr,beforeRender:new sr,render:new sr,afterRender:new sr,endFrame:new sr,destroy:new sr,pick:new H4,pickSync:new zf,pointerDown:new sr,pointerUp:new sr,pointerMove:new sr,pointerOut:new sr,pointerOver:new sr,pointerWheel:new sr,pointerCancel:new sr,click:new sr},this.globalRuntime=e,this.context=t}return he(r,[{key:"init",value:function(t){var n=this,i=De(De({},this.globalRuntime),this.context);this.context.renderingPlugins.forEach(function(a){a.apply(i,n.globalRuntime)}),this.hooks.init.call(),this.hooks.initAsync.getCallbacksNum()===0?(this.inited=!0,t()):this.hooks.initAsync.promise().then(function(){n.inited=!0,t()}).catch(function(a){})}},{key:"getStats",value:function(){return this.stats}},{key:"disableDirtyRectangleRendering",value:function(){var t=this.context.config.renderer,n=t.getConfig(),i=n.enableDirtyRectangleRendering;return!i||this.context.renderingContext.renderReasons.has(Po.CAMERA_CHANGED)}},{key:"render",value:function(t,n,i){var a=this,s=t.getConfig(),o=this.context.renderingContext;if(this.stats.total=0,this.stats.rendered=0,this.zIndexCounter=0,this.globalRuntime.sceneGraphService.syncHierarchy(o.root),this.globalRuntime.sceneGraphService.notifyMutationObservers(t),o.renderReasons.size&&this.inited){o.dirtyRectangleRenderingDisabled=this.disableDirtyRectangleRendering();var A=o.renderReasons.size===1&&o.renderReasons.has(Po.CAMERA_CHANGED),l=!s.disableRenderHooks||!A;l&&this.renderDisplayObject(o.root,s,o),this.hooks.beginFrame.call(n),l&&o.renderListCurrentFrame.forEach(function(c){a.hooks.beforeRender.call(c),a.hooks.render.call(c),a.hooks.afterRender.call(c)}),this.hooks.endFrame.call(n),o.renderListCurrentFrame=[],o.renderReasons.clear(),i()}}},{key:"renderDisplayObject",value:function(t,n,i){var a=this,s=n.renderer.getConfig(),o=s.enableDirtyCheck,A=s.enableCulling;function l(g){var v=g.renderable,p=g.sortable,y=o?v.dirty||i.dirtyRectangleRenderingDisabled?g:null:g,m=null;y&&(m=A?a.hooks.cull.call(y,a.context.camera):y,m&&(a.stats.rendered+=1,i.renderListCurrentFrame.push(m))),g.dirty(!1),p.renderOrder=a.zIndexCounter,a.zIndexCounter+=1,a.stats.total+=1,p.dirty&&(a.sort(g,p),p.dirty=!1,p.dirtyChildren=[],p.dirtyReason=void 0)}for(var c=[t];c.length>0;){var u,h=c.pop();l(h);for(var d=((u=h.sortable)===null||u===void 0||(u=u.sorted)===null||u===void 0?void 0:u.length)>0?h.sortable.sorted:h.childNodes,f=d.length-1;f>=0;f--)c.push(d[f])}}},{key:"sort",value:function(t,n){var i,a;(n==null||(i=n.sorted)===null||i===void 0?void 0:i.length)>0&&n.dirtyReason!==Zu.Z_INDEX_CHANGED?n.dirtyChildren.forEach(function(s){var o=n.sorted.indexOf(s);o>-1&&n.sorted.splice(o,1);var A=t.childNodes.indexOf(s);if(A>-1)if(n.sorted.length===0)n.sorted.push(s);else{var l=C4(n.sorted,s);n.sorted.splice(l,0,s)}}):n.sorted=t.childNodes.slice().sort(EI),((a=n.sorted)===null||a===void 0?void 0:a.length)>0&&t.childNodes.filter(function(s){return s.parsedStyle.zIndex}).length===0&&(n.sorted=[])}},{key:"destroy",value:function(){this.inited=!1,this.hooks.destroy.call()}},{key:"dirty",value:function(){this.context.renderingContext.renderReasons.add(Po.DISPLAY_OBJECT_CHANGED)}}])})(),cH=/\[\s*(.*)=(.*)\s*\]/,uH=(function(){function r(){ue(this,r)}return he(r,[{key:"selectOne",value:function(t,n){var i=this;if(t.startsWith("."))return n.find(function(A){return((A==null?void 0:A.classList)||[]).indexOf(i.getIdOrClassname(t))>-1});if(t.startsWith("#"))return n.find(function(A){return A.id===i.getIdOrClassname(t)});if(t.startsWith("[")){var a=this.getAttribute(t),s=a.name,o=a.value;return s?n.find(function(A){return n!==A&&(s==="name"?A.name===o:i.attributeToString(A,s)===o)}):null}return n.find(function(A){return n!==A&&A.nodeName===t})}},{key:"selectAll",value:function(t,n){var i=this;if(t.startsWith("."))return n.findAll(function(A){return n!==A&&((A==null?void 0:A.classList)||[]).indexOf(i.getIdOrClassname(t))>-1});if(t.startsWith("#"))return n.findAll(function(A){return n!==A&&A.id===i.getIdOrClassname(t)});if(t.startsWith("[")){var a=this.getAttribute(t),s=a.name,o=a.value;return s?n.findAll(function(A){return n!==A&&(s==="name"?A.name===o:i.attributeToString(A,s)===o)}):[]}return n.findAll(function(A){return n!==A&&A.nodeName===t})}},{key:"is",value:function(t,n){if(t.startsWith("."))return n.className===this.getIdOrClassname(t);if(t.startsWith("#"))return n.id===this.getIdOrClassname(t);if(t.startsWith("[")){var i=this.getAttribute(t),a=i.name,s=i.value;return a==="name"?n.name===s:this.attributeToString(n,a)===s}return n.nodeName===t}},{key:"getIdOrClassname",value:function(t){return t.substring(1)}},{key:"getAttribute",value:function(t){var n=t.match(cH),i="",a="";return n&&n.length>2&&(i=n[1].replace(/"/g,""),a=n[2].replace(/"/g,"")),{name:i,value:a}}},{key:"attributeToString",value:function(t,n){if(!t.getAttribute)return"";var i=t.getAttribute(n);return ke(i)?"":i.toString?i.toString():""}}])})(),it=(function(r){return r.ATTR_MODIFIED="DOMAttrModified",r.INSERTED="DOMNodeInserted",r.MOUNTED="DOMNodeInsertedIntoDocument",r.REMOVED="removed",r.UNMOUNTED="DOMNodeRemovedFromDocument",r.REPARENT="reparent",r.DESTROY="destroy",r.BOUNDS_CHANGED="bounds-changed",r.CULLED="culled",r})({}),Ki=(function(r){function e(t,n,i,a,s,o,A,l){var c;return ue(this,e),c=qe(this,e,[null]),c.relatedNode=n,c.prevValue=i,c.newValue=a,c.attrName=s,c.attrChange=o,c.prevParsedValue=A,c.newParsedValue=l,c.type=t,c}return $e(e,r),he(e)})(Rh);Ki.ADDITION=2;Ki.MODIFICATION=1;Ki.REMOVAL=3;var hH=new Ki(it.REPARENT,null,"","","",0,"",""),dH=z1(),hc=Ze(),fH=Ct(1,1,1),gH=xt(),vH=z1(),hs=Ze(),pH=xt(),ds=gn(),yH=Ze(),mH=gn(),wH=Ze(),vA=Ze(),fs=Ze(),dc=xt(),lE=gn(),cE=gn(),fc=gn(),BH=(function(){function r(e){ue(this,r),this.displayObjectDependencyMap=new WeakMap,this.runtime=e}return he(r,[{key:"matches",value:function(t,n){return this.runtime.sceneGraphSelector.is(t,n)}},{key:"querySelector",value:function(t,n){return this.runtime.sceneGraphSelector.selectOne(t,n)}},{key:"querySelectorAll",value:function(t,n){return this.runtime.sceneGraphSelector.selectAll(t,n)}},{key:"attach",value:function(t,n,i){var a,s=!1;t.parentNode&&(s=t.parentNode!==n,this.detach(t));var o=t.nodeName===ae.FRAGMENT,A=rh(n);t.parentNode=n;var l=o?t.childNodes:[t];Be(i)?l.forEach(function(g){n.childNodes.splice(i,0,g),g.parentNode=n}):l.forEach(function(g){n.childNodes.push(g),g.parentNode=n});var c=n,u=c.sortable;if((u!=null&&(a=u.sorted)!==null&&a!==void 0&&a.length||u.dirty||t.parsedStyle.zIndex)&&(u.dirtyChildren.indexOf(t)===-1&&u.dirtyChildren.push(t),u.dirty=!0,u.dirtyReason=Zu.ADDED),!A){if(o)this.dirtyFragment(t);else{var h=t.transformable;h&&this.dirtyWorldTransform(t,h)}if(s){var d,f=((d=n.ownerDocument)===null||d===void 0||(d=d.defaultView)===null||d===void 0||(d=d.getConfig())===null||d===void 0||(d=d.future)===null||d===void 0?void 0:d.experimentalCancelEventPropagation)===!0;t.dispatchEvent(hH,f,f)}}}},{key:"detach",value:function(t){var n,i;if(t.parentNode){var a=t.transformable,s=t.parentNode,o=s.sortable;(o!=null&&(n=o.sorted)!==null&&n!==void 0&&n.length||(i=t.style)!==null&&i!==void 0&&i.zIndex)&&(o.dirtyChildren.indexOf(t)===-1&&o.dirtyChildren.push(t),o.dirty=!0,o.dirtyReason=Zu.REMOVED);var A=t.parentNode.childNodes.indexOf(t);A>-1&&t.parentNode.childNodes.splice(A,1),a&&this.dirtyWorldTransform(t,a),t.parentNode=null}}},{key:"getLocalPosition",value:function(t){return t.transformable.localPosition}},{key:"getLocalRotation",value:function(t){return t.transformable.localRotation}},{key:"getLocalScale",value:function(t){return t.transformable.localScale}},{key:"getLocalSkew",value:function(t){return t.transformable.localSkew}},{key:"getLocalTransform",value:function(t){var n=t.transformable;return Pb(n),n.localTransform}},{key:"setLocalPosition",value:function(t,n){var i,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0,s=t.transformable;vA[0]=n[0],vA[1]=n[1],vA[2]=(i=n[2])!==null&&i!==void 0?i:0,!hA(s.localPosition,vA)&&(Ui(s.localPosition,vA),a&&this.dirtyLocalTransform(t,s))}},{key:"translateLocal",value:function(t,n){var i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0,a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0;typeof n=="number"&&(n=Ct(n,i,a));var s=t.transformable;hA(n,hc)||(jP(n,n,s.localRotation),Va(s.localPosition,s.localPosition,n),this.dirtyLocalTransform(t,s))}},{key:"setLocalRotation",value:function(t,n,i,a,s){var o=arguments.length>5&&arguments[5]!==void 0?arguments[5]:!0;typeof n=="number"&&(n=R_(ds,n,i,a,s));var A=t.transformable;ic(A.localRotation,n),o&&this.dirtyLocalTransform(t,A)}},{key:"rotateLocal",value:function(t,n){var i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0,a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0;typeof n=="number"&&(n=Ct(n,i,a));var s=t.transformable;rc(cE,n[0],n[1],n[2]),Eb(s.localRotation,s.localRotation,cE),this.dirtyLocalTransform(t,s)}},{key:"setLocalScale",value:function(t,n){var i,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!0,s=t.transformable;er(hs,n[0],n[1],(i=n[2])!==null&&i!==void 0?i:s.localScale[2]),!hA(hs,s.localScale)&&(Ui(s.localScale,hs),a&&this.dirtyLocalTransform(t,s))}},{key:"scaleLocal",value:function(t,n){var i,a=t.transformable;HP(a.localScale,a.localScale,er(hs,n[0],n[1],(i=n[2])!==null&&i!==void 0?i:1)),this.dirtyLocalTransform(t,a)}},{key:"setLocalSkew",value:function(t,n,i){var a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!0;typeof n=="number"&&(n=JP(vH,n,i));var s=t.transformable;ZP(s.localSkew,n),a&&this.dirtyLocalTransform(t,s)}},{key:"setLocalEulerAngles",value:function(t,n){var i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0,a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0,s=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!0;typeof n=="number"&&(n=Ct(n,i,a));var o=t.transformable;rc(o.localRotation,n[0],n[1],n[2]),s&&this.dirtyLocalTransform(t,o)}},{key:"setLocalTransform",value:function(t,n){var i=Gu(yH,n),a=Ku(mH,n),s=Ko(wH,n);this.setLocalScale(t,s,!1),this.setLocalPosition(t,i,!1),this.setLocalRotation(t,a,void 0,void 0,void 0,!1),this.dirtyLocalTransform(t,t.transformable)}},{key:"resetLocalTransform",value:function(t){this.setLocalScale(t,fH,!1),this.setLocalPosition(t,hc,!1),this.setLocalEulerAngles(t,hc,void 0,void 0,!1),this.setLocalSkew(t,dH,void 0,!1),this.dirtyLocalTransform(t,t.transformable)}},{key:"getPosition",value:function(t){var n=t.transformable;return Gu(n.position,this.getWorldTransform(t,n))}},{key:"getRotation",value:function(t){var n=t.transformable;return Ku(n.rotation,this.getWorldTransform(t,n))}},{key:"getScale",value:function(t){var n=t.transformable;return Ko(n.scaling,this.getWorldTransform(t,n))}},{key:"getOrigin",value:function(t){return t.getGeometryBounds(),t.transformable.origin}},{key:"getWorldTransform",value:function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:t.transformable;return!n.localDirtyFlag&&!n.dirtyFlag||(t.parentNode&&t.parentNode.transformable&&this.getWorldTransform(t.parentNode),this.internalUpdateTransform(t)),n.worldTransform}},{key:"setPosition",value:function(t,n){var i,a=t.transformable;if(fs[0]=n[0],fs[1]=n[1],fs[2]=(i=n[2])!==null&&i!==void 0?i:0,!hA(this.getPosition(t),fs)){if(Ui(a.position,fs),t.parentNode===null||!t.parentNode.transformable)Ui(a.localPosition,fs);else{var s=t.parentNode.transformable;Go(dc,s.worldTransform),Ni(dc,dc),nr(a.localPosition,fs,dc)}this.dirtyLocalTransform(t,a)}}},{key:"translate",value:function(t,n){var i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0,a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0;typeof n=="number"&&(n=er(hs,n,i,a)),!hA(n,hc)&&(Va(hs,this.getPosition(t),n),this.setPosition(t,hs))}},{key:"setRotation",value:function(t,n,i,a,s){var o=t.transformable;if(typeof n=="number"&&(n=XP(n,i,a,s)),t.parentNode===null||!t.parentNode.transformable)this.setLocalRotation(t,n);else{var A=this.getRotation(t.parentNode);ic(ds,A),Mf(ds,ds),ja(o.localRotation,ds,n),Vu(o.localRotation,o.localRotation),this.dirtyLocalTransform(t,o)}}},{key:"rotate",value:function(t,n){var i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0,a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0;typeof n=="number"&&(n=Ct(n,i,a));var s=t.transformable;if(t.parentNode===null||!t.parentNode.transformable)this.rotateLocal(t,n);else{var o=ds;rc(o,n[0],n[1],n[2]);var A=this.getRotation(t),l=this.getRotation(t.parentNode);ic(fc,l),Mf(fc,fc),ja(o,fc,o),ja(s.localRotation,o,A),Vu(s.localRotation,s.localRotation),this.dirtyLocalTransform(t,s)}}},{key:"setOrigin",value:function(t,n){var i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0,a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0;typeof n=="number"&&(n=[n,i,a]);var s=t.transformable;if(!(n[0]===s.origin[0]&&n[1]===s.origin[1]&&n[2]===s.origin[2])){var o=s.origin;o[0]=n[0],o[1]=n[1],o[2]=n[2]||0,this.dirtyLocalTransform(t,s)}}},{key:"setEulerAngles",value:function(t,n){var i=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0,a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0;typeof n=="number"&&(n=Ct(n,i,a));var s=t.transformable;if(t.parentNode===null||!t.parentNode.transformable)this.setLocalEulerAngles(t,n);else{rc(s.localRotation,n[0],n[1],n[2]);var o=this.getRotation(t.parentNode);ic(lE,Mf(ds,o)),Eb(s.localRotation,s.localRotation,lE),this.dirtyLocalTransform(t,s)}}},{key:"getGeometryBounds",value:function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,i=t,a=i.geometry;a.dirty&&de.styleValueRegistry.updateGeometry(t);var s=n?a.renderBounds:a.contentBounds||null;return s||new It}},{key:"getTransformedGeometryBounds",value:function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,i=arguments.length>2?arguments[2]:void 0,a=this.getGeometryBounds(t,n);if(!It.isEmpty(a)){var s=i||new It;return s.setFromTransformedAABB(a,this.getWorldTransform(t)),s}return null}},{key:"getBounds",value:function(t){var n=this,i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,a=t,s=a.renderable;if(!s.boundsDirty&&!i&&s.bounds)return s.bounds;if(!s.renderBoundsDirty&&i&&s.renderBounds)return s.renderBounds;var o=i?s.renderBounds:s.bounds,A=this.getTransformedGeometryBounds(t,i,o),l=t.childNodes;if(l.forEach(function(h){var d=n.getBounds(h,i);d&&(A?A.add(d):(A=o||new It,A.update(d.center,d.halfExtents)))}),A||(A=new It),i){var c=xI(t);if(c){var u=c.parsedStyle.clipPath.getBounds(i);A?u&&(A=u.intersection(A)):A.update(u.center,u.halfExtents)}}return i?(s.renderBounds=A,s.renderBoundsDirty=!1):(s.bounds=A,s.boundsDirty=!1),A}},{key:"getLocalBounds",value:function(t){if(t.parentNode){var n=gH;t.parentNode.transformable&&(n=Ni(pH,this.getWorldTransform(t.parentNode)));var i=this.getBounds(t);if(!It.isEmpty(i)){var a=new It;return a.setFromTransformedAABB(i,n),a}}return this.getBounds(t)}},{key:"getBoundingClientRect",value:function(t){var n,i,a=this.getGeometryBounds(t);It.isEmpty(a)||(i=new It,i.setFromTransformedAABB(a,this.getWorldTransform(t)));var s=(n=t.ownerDocument)===null||n===void 0||(n=n.defaultView)===null||n===void 0?void 0:n.getContextService().getBoundingClientRect();if(i){var o=i.getMin(),A=We(o,2),l=A[0],c=A[1],u=i.getMax(),h=We(u,2),d=h[0],f=h[1];return new Vo(l+((s==null?void 0:s.left)||0),c+((s==null?void 0:s.top)||0),d-l,f-c)}return new Vo((s==null?void 0:s.left)||0,(s==null?void 0:s.top)||0,0,0)}},{key:"internalUpdateTransform",value:function(t){var n,i=(n=t.parentNode)===null||n===void 0?void 0:n.transformable;Pb(t.transformable),GD(t.transformable,i)}},{key:"internalUpdateElement",value:function(t,n){var i,a,s,o,A=((i=t.ownerDocument)===null||i===void 0||(i=i.defaultView)===null||i===void 0||(i=i.getConfig())===null||i===void 0||(i=i.future)===null||i===void 0?void 0:i.experimentalAttributeUpdateOptimization)===!0,l=n[n.length-1],c=(l==null?void 0:l.transformDirty)||((a=t.transformable)===null||a===void 0?void 0:a.localDirtyFlag);if(t.transformable){var u;(u=t.transformable).dirtyFlag||(u.dirtyFlag=c)}if(this.internalUpdateTransform(t),c){var h;(h=t.dirty)===null||h===void 0||h.call(t,!0,!0)}var d=((s=t.renderable)===null||s===void 0?void 0:s.boundsDirty)||((o=t.renderable)===null||o===void 0?void 0:o.renderBoundsDirty);if((c||d)&&(l==null?void 0:l.shapeUpdated)===!1&&A)for(var f=n.length-1;f>=0;){var g,v,p=n[f];if(p.shapeUpdated)break;(g=(v=p.node).dirty)===null||g===void 0||g.call(v,!0,!0),p.shapeUpdated=!0,f-=1}return c}},{key:"syncHierarchy",value:function(t){for(var n,i,a=[t],s=t.parentNode?[{node:t.parentNode,transformDirty:((n=t.parentNode.transformable)===null||n===void 0?void 0:n.localDirtyFlag)||((i=t.parentNode.transformable)===null||i===void 0?void 0:i.dirtyFlag),shapeUpdated:!1}]:[];a.length>0;){for(var o=a.pop(),A=s[s.length-1];s.length>0&&o.parentNode!==A.node;)A=s.pop();var l=this.internalUpdateElement(o,s);if(o.childNodes.length>0){for(var c=o.childNodes.length-1;c>=0;c--)a.push(o.childNodes[c]);s.push({node:o,transformDirty:l,shapeUpdated:!1})}}}},{key:"dirtyLocalTransform",value:function(t,n){rh(t)||n.localDirtyFlag||(n.localDirtyFlag=!0,n.dirtyFlag||this.dirtyWorldTransform(t,n))}},{key:"dirtyWorldTransform",value:function(t,n){this.dirtyWorldInternal(t,n),this.dirtyToRoot(t,!0)}},{key:"dirtyWorldInternal",value:function(t,n){var i,a=this,s=((i=t.ownerDocument)===null||i===void 0||(i=i.defaultView)===null||i===void 0||(i=i.getConfig())===null||i===void 0||(i=i.future)===null||i===void 0?void 0:i.experimentalAttributeUpdateOptimization)===!0;n.dirtyFlag||(n.dirtyFlag=!0,t.dirty(!0,!0),s||t.childNodes.forEach(function(o){var A=o.transformable;a.dirtyWorldInternal(o,A)}))}},{key:"dirtyToRoot",value:function(t){for(var n,i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,a=t,s=((n=t.ownerDocument)===null||n===void 0||(n=n.defaultView)===null||n===void 0||(n=n.getConfig())===null||n===void 0||(n=n.future)===null||n===void 0?void 0:n.experimentalAttributeUpdateOptimization)===!0;a;){var o,A;if((o=(A=a).dirty)===null||o===void 0||o.call(A,!0,!0),s)break;a=a.parentNode}i&&t.forEach(function(u){var h;(h=u.dirty)===null||h===void 0||h.call(u,!0,!0)}),this.informDependentDisplayObjects(t);var l=t.mutations||[],c=l.find(function(u){return u.type==="attributes"&&u._boundsChangeData});c?c._boundsChangeData={affectChildren:c._boundsChangeData.affectChildren||i}:(c={type:"attributes",target:t,_boundsChangeData:{affectChildren:i}},l.push(c)),t.mutations=l}},{key:"dirtyFragment",value:function(t){var n,i,a=t.transformable;a&&(a.dirtyFlag=!0,a.localDirtyFlag=!0),(n=(i=t).dirty)===null||n===void 0||n.call(i,!0,!0);for(var s=t.childNodes.length,o=0;o<s;o++)this.dirtyFragment(t.childNodes[o])}},{key:"notifyMutationObservers",value:function(t){var n=new Set;if(t.getRoot().forEach(function(a){(a.mutations||[]).forEach(function(s){s.type==="attributes"&&s._boundsChangeData&&(s._boundsChangeData.affectChildren?a.forEach(function(o){var A=De({},s);A.target=o,n.add(A)}):n.add(s))}),a.mutations=void 0}),n.size>0){var i=new vn(it.BOUNDS_CHANGED,{detail:Array.from(n)});t.dispatchEvent(i,!0,!0)}}},{key:"updateDisplayObjectDependency",value:function(t,n,i,a){if(n&&n!==i){var s=this.displayObjectDependencyMap.get(n);if(s&&s[t]){var o=s[t].indexOf(a);s[t].splice(o,1)}}if(i){var A=this.displayObjectDependencyMap.get(i);A||(this.displayObjectDependencyMap.set(i,{}),A=this.displayObjectDependencyMap.get(i)),A[t]||(A[t]=[]),A[t].push(a)}}},{key:"informDependentDisplayObjects",value:function(t){var n,i=this,a=this.displayObjectDependencyMap.get(t);if(a){var s=(n=t.ownerDocument)===null||n===void 0||(n=n.defaultView)===null||n===void 0||(n=n.getConfig())===null||n===void 0||(n=n.future)===null||n===void 0?void 0:n.experimentalCancelEventPropagation;Object.keys(a).forEach(function(o){a[o].forEach(function(A){i.dirtyToRoot(A,!0),A.dispatchEvent(new Ki(it.ATTR_MODIFIED,A,i,i,o,Ki.MODIFICATION,i,i),s,s),A.isCustomElement&&A.isConnected&&A.attributeChangedCallback&&A.attributeChangedCallback(o,i,i)})})}}}])})(),uE=(function(){function r(e){if(ue(this,r),e<=0)throw new Error("LRU capacity must be a positive number.");this.capacity=e,this.cache=new Map}return he(r,[{key:"get",value:function(t){if(this.cache.has(t)){var n=this.cache.get(t);return this.cache.delete(t),this.cache.set(t,n),n}}},{key:"put",value:function(t,n){if(this.cache.has(t)&&this.cache.delete(t),this.cache.set(t,n),this.cache.size>this.capacity){var i=this.cache.keys().next().value;this.cache.delete(i)}}},{key:"len",value:function(){return this.cache.size}},{key:"clear",value:function(){this.cache.clear()}}])})(),gs={MetricsString:"|ÉqÅ",BaselineSymbol:"M",BaselineMultiplier:1.4,HeightMultiplier:2,Newlines:[10,13],BreakingSpaces:[9,32,8192,8193,8194,8195,8196,8197,8198,8200,8201,8202,8287,12288]},hE=/[a-zA-Z0-9\u00C0-\u00D6\u00D8-\u00f6\u00f8-\u00ff!"#$%&'()*+,-./:;]/,bH=/[!%),.:;?\]}¢°·'""†‡›℃∶、。〃〆〕〗〞﹚﹜!"%'),.:;?!]}~]/,EH=/[$(£¥·'"〈《「『【〔〖〝﹙﹛$(.[{£¥]/,xH=/[!),.:;?\]}¢·–—'"•"、。〆〞〕〉》」︰︱︲︳﹐﹑﹒﹔﹕﹖﹘﹚﹜!),.:;?︶︸︺︼︾﹀﹂﹗]|}、]/,CH=/[([{£¥'"‵〈《「『〔〝︴﹙﹛({︵︷︹︻︽︿﹁﹃﹏]/,SH=/[)\]}〕〉》」』】〙〗〟'"⦆»ヽヾーァィゥェォッャュョヮヵヶぁぃぅぇぉっゃゅょゎゕゖㇰㇱㇲㇳㇴㇵㇶㇷㇸㇹㇺㇻㇼㇽㇾㇿ々〻‐゠–〜?!‼⁇⁈⁉・、:;,。.]/,FH=/[([{〔〈《「『【〘〖〝'"⦅«—...‥〳〴〵]/,TH=/[!%),.:;?\]}¢°'"†‡℃〆〈《「『〕!%),.:;?]}]/,MH=/[$([{£¥'"々〇〉》」〔$([{⦆¥₩#]/,OH=new RegExp("".concat(bH.source,"|").concat(xH.source,"|").concat(SH.source,"|").concat(TH.source)),_H=new RegExp("".concat(EH.source,"|").concat(CH.source,"|").concat(FH.source,"|").concat(MH.source)),IH=(function(){function r(e){var t=this;ue(this,r),this.fontMetricsCache={},this.shouldBreakByKinsokuShorui=function(n,i){return t.isBreakingSpace(i)?!1:!!(n&&(_H.exec(i)||OH.exec(n)))},this.trimByKinsokuShorui=function(n){var i=tt(n),a=i[i.length-2];if(!a)return n;var s=a[a.length-1];return i[i.length-2]=a.slice(0,-1),i[i.length-1]=s+i[i.length-1],i},this.runtime=e,this.charWidthCache=new uE(100)}return he(r,[{key:"measureFont",value:function(t,n){if(this.fontMetricsCache[t])return this.fontMetricsCache[t];var i={ascent:0,descent:0,fontSize:0},a=this.runtime.offscreenCanvasCreator.getOrCreateCanvas(n),s=this.runtime.offscreenCanvasCreator.getOrCreateContext(n,{willReadFrequently:!0});s.font=t;var o=gs.MetricsString+gs.BaselineSymbol,A=Math.ceil(s.measureText(o).width),l=Math.ceil(s.measureText(gs.BaselineSymbol).width),c=gs.HeightMultiplier*l;l=l*gs.BaselineMultiplier|0,a.width=A,a.height=c,s.fillStyle="#f00",s.fillRect(0,0,A,c),s.font=t,s.textBaseline="alphabetic",s.fillStyle="#000",s.fillText(o,0,l);var u=s.getImageData(0,0,A||1,c||1).data,h=u.length,d=A*4,f=0,g=0,v=!1;for(f=0;f<l;++f){for(var p=0;p<d;p+=4)if(u[g+p]!==255){v=!0;break}if(!v)g+=d;else break}for(i.ascent=l-f,g=h-d,v=!1,f=c;f>l;--f){for(var y=0;y<d;y+=4)if(u[g+y]!==255){v=!0;break}if(!v)g-=d;else break}return i.descent=f-l,i.fontSize=i.ascent+i.descent,this.fontMetricsCache[t]=i,i}},{key:"measureText",value:function(t,n,i){var a=n.fontSize,s=a===void 0?16:a,o=n.wordWrap,A=o===void 0?!1:o,l=n.lineHeight,c=n.lineWidth,u=c===void 0?1:c,h=n.textBaseline,d=h===void 0?"alphabetic":h,f=n.textAlign,g=f===void 0?"start":f,v=n.letterSpacing,p=v===void 0?0:v,y=n.textPath;n.textPathSide,n.textPathStartOffset;var m=n.leading,B=m===void 0?0:m,C=oE(n),S=this.measureFont(C,i);S.fontSize===0&&(S.fontSize=s,S.ascent=s);var F=this.runtime.offscreenCanvasCreator.getOrCreateContext(i);F.font=C,n.isOverflowing=!1;var T=A?this.wordWrap(t,n,i):t,O=T.split(/(?:\r\n|\r|\n)/),_=new Array(O.length),k=0;if(y){y.getTotalLength();for(var L=0;L<O.length;L++)F.measureText(O[L]).width+(O[L].length-1)*p}else{for(var U=0;U<O.length;U++){var G=F.measureText(O[U]).width+(O[U].length-1)*p;_[U]=G,k=Math.max(k,G)}var W=k+u,V=l||S.fontSize+u,K=Math.max(V,S.fontSize+u)+(O.length-1)*(V+B);V+=B;var D=0;return d==="middle"?D=-K/2:d==="bottom"||d==="alphabetic"||d==="ideographic"?D=-K:(d==="top"||d==="hanging")&&(D=0),{font:C,width:W,height:K,lines:O,lineWidths:_,lineHeight:V,maxLineWidth:k,fontProperties:S,lineMetrics:_.map(function(X,te){var ie=0;return g==="center"||g==="middle"?ie-=X/2:(g==="right"||g==="end")&&(ie-=X),new Vo(ie-u/2,D+te*V,X+u,V)})}}}},{key:"wordWrap",value:function(t,n,i){var a=this,s=Array.from(t);if(s.length===0)return"";var o=this,A=n.wordWrapWidth,l=A===void 0?0:A,c=n.letterSpacing,u=c===void 0?0:c,h=n.maxLines,d=h===void 0?1/0:h,f=n.textOverflow,g=this.runtime.offscreenCanvasCreator.getOrCreateContext(i),v=l+u,p="";f==="ellipsis"?p="...":f&&f!=="clip"&&(p=f);var y=[""],m=0,B=0,C=-1,S=oE(n),F=this.charWidthCache.get(S);F||(F=new uE(500),this.charWidthCache.put(S,F));var T=function(X){return a.getFromCache(X,u,F,g)},O=T(p);function _(D,X,te,ie){for(;T(D)<ie&&X<s.length-1&&!o.isNewline(s[X+1]);)X+=1,D+=s[X];for(;T(D)>ie&&X>=te;)X-=1,D=D.slice(0,-1);return{lineTxt:D,txtLastCharIndex:X}}function k(D,X){if(!(O<=0||O>v)){if(!y[D]){y[D]=p;return}var te=_(y[D],X,C+1,v-O);y[D]=te.lineTxt+p}}for(var L=0;L<s.length;L++){var U=s[L],G=s[L-1],W=s[L+1],V=T(U);if(this.isNewline(U)){if(m+1>=d){L<s.length-1&&k(m,L-1),n.isOverflowing=!0;break}C=L-1,m+=1,B=0,y[m]="";continue}if(V>v){k(m,L-1),n.isOverflowing=!0;break}if(B>0&&B+V>v){var K=_(y[m],L-1,C+1,v);if(K.txtLastCharIndex!==L-1){if(y[m]=K.lineTxt,K.txtLastCharIndex===s.length-1)break;L=K.txtLastCharIndex+1,U=s[L],G=s[L-1],W=s[L+1],V=T(U)}if(m+1>=d){k(m,L-1),n.isOverflowing=!0;break}if(C=L-1,m+=1,B=0,y[m]="",this.isBreakingSpace(U))continue;this.canBreakInLastChar(U)||(y=this.trimToBreakable(y),B=this.sumTextWidthByCache(y[m]||"",T)),this.shouldBreakByKinsokuShorui(U,W)&&(y=this.trimByKinsokuShorui(y),B+=T(G||""))}B+=V,y[m]+=U}return y.join(`
|
|
5
|
+
`)}},{key:"isBreakingSpace",value:function(t){return typeof t!="string"?!1:gs.BreakingSpaces.indexOf(t.charCodeAt(0))>=0}},{key:"isNewline",value:function(t){return typeof t!="string"?!1:gs.Newlines.indexOf(t.charCodeAt(0))>=0}},{key:"trimToBreakable",value:function(t){var n=tt(t),i=n[n.length-2],a=this.findBreakableIndex(i);if(a===-1||!i)return n;var s=i.slice(a,a+1),o=this.isBreakingSpace(s),A=a+1,l=a+(o?0:1);return n[n.length-1]+=i.slice(A,i.length),n[n.length-2]=i.slice(0,l),n}},{key:"canBreakInLastChar",value:function(t){return!(t&&hE.test(t))}},{key:"sumTextWidthByCache",value:function(t,n){return t.split("").reduce(function(i,a){return i+n(a)},0)}},{key:"findBreakableIndex",value:function(t){for(var n=t.length-1;n>=0;n--)if(!hE.test(t[n]))return n;return-1}},{key:"getFromCache",value:function(t,n,i,a){var s=i.get(t);if(typeof s!="number"){var o=t.length*n,A=a.measureText(t);s=A.width+o,i.put(t,s)}return s}},{key:"clearCache",value:function(){this.fontMetricsCache={},this.charWidthCache.clear()}}])})(),de={},kH=(function(r){var e=new rH,t=new nH;return r={},Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(r,ae.FRAGMENT,null),ae.CIRCLE,new Z4),ae.ELLIPSE,new J4),ae.RECT,e),ae.IMAGE,e),ae.GROUP,new aH),ae.LINE,new eH),ae.TEXT,new iH(de)),ae.POLYLINE,t),ae.POLYGON,t),Ee(Ee(Ee(r,ae.PATH,new tH),ae.HTML,new sH),ae.MESH,null)})(),LH=(function(r){var e=new c4,t=new Qw;return r={},Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(r,pe.PERCENTAGE,null),pe.NUMBER,new g4),pe.ANGLE,new A4),pe.DEFINED_PATH,new l4),pe.PAINT,e),pe.COLOR,e),pe.FILTER,new u4),pe.LENGTH,t),pe.LENGTH_PERCENTAGE,t),pe.LENGTH_PERCENTAGE_12,new h4),Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(r,pe.LENGTH_PERCENTAGE_14,new d4),pe.COORDINATE,new Qw),pe.OFFSET_DISTANCE,new v4),pe.OPACITY_VALUE,new p4),pe.PATH,new y4),pe.LIST_OF_POINTS,new m4),pe.SHADOW_BLUR,new w4),pe.TEXT,new B4),pe.TEXT_TRANSFORM,new b4),pe.TRANSFORM,new $4),Ee(Ee(Ee(r,pe.TRANSFORM_ORIGIN,new Y4),pe.Z_INDEX,new X4),pe.MARKER,new f4)})(),QH=function(){return typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:typeof global<"u"?global:{}};de.CameraContribution=iI;de.AnimationTimeline=null;de.EasingFunction=null;de.offscreenCanvasCreator=new eB;de.sceneGraphSelector=new uH;de.sceneGraphService=new BH(de);de.textService=new IH(de);de.geometryUpdaterFactory=kH;de.CSSPropertySyntaxFactory=LH;de.styleValueRegistry=new s4(de);de.layoutRegistry=null;de.globalThis=QH();de.enableStyleSyntax=!0;de.enableSizeAttenuation=!1;var NH=0,Pw=new Ki(it.INSERTED,null,"","","",0,"",""),Rw=new Ki(it.REMOVED,null,"","","",0,"",""),II=new vn(it.DESTROY),UH=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.entity=NH++,t.transformable={dirtyFlag:!1,localDirtyFlag:!1,localPosition:[0,0,0],localRotation:[0,0,0,1],localScale:[1,1,1],localTransform:[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],localSkew:[0,0],position:[0,0,0],rotation:[0,0,0,1],scaling:[1,1,1],worldTransform:[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],origin:[0,0,0]},t.renderable={bounds:void 0,boundsDirty:!0,renderBounds:void 0,renderBoundsDirty:!0,dirtyRenderBounds:void 0,dirty:!1},t.geometry={contentBounds:void 0,renderBounds:void 0,dirty:!0},t.cullable={strategy:RD.Standard,visibilityPlaneMask:-1,visible:!0,enable:!0},t.sortable={dirty:!1,sorted:void 0,renderOrder:0,dirtyChildren:[],dirtyReason:void 0},t.namespaceURI="g",t.scrollLeft=0,t.scrollTop=0,t.clientTop=0,t.clientLeft=0,t.style={},t.computedStyle={},t.parsedStyle={},t.attributes={},t}return $e(e,r),he(e,[{key:"dirty",value:function(){var n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!0,i=arguments.length>1?arguments[1]:void 0;this.renderable.dirty=n,i!==void 0&&(this.renderable.boundsDirty=i,this.renderable.renderBoundsDirty=i,this.geometry.dirty=i)}},{key:"className",get:function(){return this.getAttribute("class")||""},set:function(n){this.setAttribute("class",n)}},{key:"classList",get:function(){return this.className.split(" ").filter(function(n){return n!==""})}},{key:"tagName",get:function(){return this.nodeName}},{key:"children",get:function(){return this.childNodes}},{key:"childElementCount",get:function(){return this.childNodes.length}},{key:"firstElementChild",get:function(){return this.firstChild}},{key:"lastElementChild",get:function(){return this.lastChild}},{key:"parentElement",get:function(){return this.parentNode}},{key:"nextSibling",get:function(){if(this.parentNode){var n=this.parentNode.childNodes.indexOf(this);return this.parentNode.childNodes[n+1]||null}return null}},{key:"previousSibling",get:function(){if(this.parentNode){var n=this.parentNode.childNodes.indexOf(this);return this.parentNode.childNodes[n-1]||null}return null}},{key:"cloneNode",value:function(n){throw new Error(wt)}},{key:"appendChild",value:function(n,i){var a;if(n.destroyed)throw new Error(TD);return de.sceneGraphService.attach(n,this,i),(a=this.ownerDocument)!==null&&a!==void 0&&a.defaultView&&(!rh(this)&&n.nodeName===ae.FRAGMENT?this.ownerDocument.defaultView.mountFragment(n):this.ownerDocument.defaultView.mountChildren(n)),this.isMutationObserved&&(Pw.relatedNode=this,n.dispatchEvent(Pw)),n}},{key:"insertBefore",value:function(n,i){if(!i)this.appendChild(n);else{n.parentElement&&n.parentElement.removeChild(n);var a=this.childNodes.indexOf(i);a===-1?this.appendChild(n):this.appendChild(n,a)}return n}},{key:"replaceChild",value:function(n,i){var a=this.childNodes.indexOf(i);return this.removeChild(i),this.appendChild(n,a),i}},{key:"removeChild",value:function(n){var i,a,s=((i=this.ownerDocument)===null||i===void 0||(i=i.defaultView)===null||i===void 0||(i=i.getConfig().future)===null||i===void 0?void 0:i.experimentalCancelEventPropagation)===!0;return Rw.relatedNode=this,n.dispatchEvent(Rw,s,s),(a=n.ownerDocument)!==null&&a!==void 0&&a.defaultView&&n.ownerDocument.defaultView.unmountChildren(n),de.sceneGraphService.detach(n),n}},{key:"removeChildren",value:function(){for(var n=this.childNodes.length-1;n>=0;n--){var i=this.childNodes[n];this.removeChild(i)}}},{key:"destroyChildren",value:function(){for(var n=this.childNodes.length-1;n>=0;n--){var i=this.childNodes[n];i.childNodes.length>0&&i.destroyChildren(),i.destroy()}}},{key:"matches",value:function(n){return de.sceneGraphService.matches(n,this)}},{key:"getElementById",value:function(n){return de.sceneGraphService.querySelector("#".concat(n),this)}},{key:"getElementsByName",value:function(n){return de.sceneGraphService.querySelectorAll('[name="'.concat(n,'"]'),this)}},{key:"getElementsByClassName",value:function(n){return de.sceneGraphService.querySelectorAll(".".concat(n),this)}},{key:"getElementsByTagName",value:function(n){return de.sceneGraphService.querySelectorAll(n,this)}},{key:"querySelector",value:function(n){return de.sceneGraphService.querySelector(n,this)}},{key:"querySelectorAll",value:function(n){return de.sceneGraphService.querySelectorAll(n,this)}},{key:"closest",value:function(n){var i=this;do{if(de.sceneGraphService.matches(n,i))return i;i=i.parentElement}while(i!==null);return null}},{key:"find",value:function(n){var i=this,a=null;return this.forEach(function(s){return s!==i&&n(s)?(a=s,!1):!0}),a}},{key:"findAll",value:function(n){var i=this,a=[];return this.forEach(function(s){s!==i&&n(s)&&a.push(s)}),a}},{key:"after",value:function(){var n=this;if(this.parentNode){for(var i=this.parentNode.childNodes.indexOf(this),a=arguments.length,s=new Array(a),o=0;o<a;o++)s[o]=arguments[o];s.forEach(function(A,l){var c;return(c=n.parentNode)===null||c===void 0?void 0:c.appendChild(A,i+l+1)})}}},{key:"before",value:function(){if(this.parentNode){for(var n,i=this.parentNode.childNodes.indexOf(this),a=arguments.length,s=new Array(a),o=0;o<a;o++)s[o]=arguments[o];var A=s[0],l=Hu(s).slice(1);this.parentNode.appendChild(A,i),(n=A).after.apply(n,tt(l))}}},{key:"replaceWith",value:function(){this.after.apply(this,arguments),this.remove()}},{key:"append",value:function(){for(var n=this,i=arguments.length,a=new Array(i),s=0;s<i;s++)a[s]=arguments[s];a.forEach(function(o){return n.appendChild(o)})}},{key:"prepend",value:function(){for(var n=this,i=arguments.length,a=new Array(i),s=0;s<i;s++)a[s]=arguments[s];a.forEach(function(o,A){return n.appendChild(o,A)})}},{key:"replaceChildren",value:function(){for(;this.childNodes.length&&this.firstChild;)this.removeChild(this.firstChild);this.append.apply(this,arguments)}},{key:"remove",value:function(){return this.parentNode?this.parentNode.removeChild(this):this}},{key:"destroy",value:function(){var n,i=((n=this.ownerDocument)===null||n===void 0||(n=n.defaultView)===null||n===void 0||(n=n.getConfig().future)===null||n===void 0?void 0:n.experimentalCancelEventPropagation)===!0;this.destroyChildren(),this.dispatchEvent(II,i,i),this.remove(),this.emitter.removeAllListeners(),this.destroyed=!0}},{key:"getGeometryBounds",value:function(){var n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;return de.sceneGraphService.getGeometryBounds(this,n)}},{key:"getTransformedGeometryBounds",value:function(){var n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;return de.sceneGraphService.getTransformedGeometryBounds(this,n)}},{key:"getBounds",value:function(){return de.sceneGraphService.getBounds(this)}},{key:"getRenderBounds",value:function(){return de.sceneGraphService.getBounds(this,!0)}},{key:"getLocalBounds",value:function(){return de.sceneGraphService.getLocalBounds(this)}},{key:"getBoundingClientRect",value:function(){return de.sceneGraphService.getBoundingClientRect(this)}},{key:"getClientRects",value:function(){return[this.getBoundingClientRect()]}},{key:"computedStyleMap",value:function(){return new Map(Object.entries(this.computedStyle))}},{key:"getAttributeNames",value:function(){return Object.keys(this.attributes)}},{key:"getAttribute",value:function(n){if(typeof n!="symbol"){var i=this.attributes[n];return i}}},{key:"hasAttribute",value:function(n){return this.getAttributeNames().includes(n)}},{key:"hasAttributes",value:function(){return!!this.getAttributeNames().length}},{key:"removeAttribute",value:function(n){this.setAttribute(n,null),delete this.attributes[n]}},{key:"setAttribute",value:function(n,i){this.attributes[n]=i}},{key:"getAttributeNS",value:function(n,i){throw new Error(wt)}},{key:"getAttributeNode",value:function(n){throw new Error(wt)}},{key:"getAttributeNodeNS",value:function(n,i){throw new Error(wt)}},{key:"hasAttributeNS",value:function(n,i){throw new Error(wt)}},{key:"removeAttributeNS",value:function(n,i){throw new Error(wt)}},{key:"removeAttributeNode",value:function(n){throw new Error(wt)}},{key:"setAttributeNS",value:function(n,i,a){throw new Error(wt)}},{key:"setAttributeNode",value:function(n){throw new Error(wt)}},{key:"setAttributeNodeNS",value:function(n){throw new Error(wt)}},{key:"toggleAttribute",value:function(n,i){throw new Error(wt)}}])})(Vt);function ut(r){return!!(r!=null&&r.nodeName)}var PH=de.globalThis.Proxy?de.globalThis.Proxy:function(){},Li=new Ki(it.ATTR_MODIFIED,null,null,null,null,Ki.MODIFICATION,null,null),pA=Ze(),RH=gn(),Ot=(function(r){function e(t){var n;return ue(this,e),n=qe(this,e),n.isCustomElement=!1,n.isMutationObserved=!1,n.activeAnimations=[],n.config=t,n.id=t.id||"",n.name=t.name||"",(t.className||t.class)&&(n.className=t.className||t.class),n.nodeName=t.type||ae.GROUP,t.initialParsedStyle&&Object.assign(n.parsedStyle,t.initialParsedStyle),n.initAttributes(t.style),de.enableStyleSyntax&&(n.style=new PH({setProperty:function(a,s){n.setAttribute(a,s)},getPropertyValue:function(a){return n.getAttribute(a)},removeProperty:function(a){n.removeAttribute(a)},item:function(){return""}},{get:function(a,s){return a[s]!==void 0?a[s]:n.getAttribute(s)},set:function(a,s,o){return n.setAttribute(s,o),!0}})),n}return $e(e,r),he(e,[{key:"destroy",value:function(){Yu(e,"destroy",this)([]),this.getAnimations().forEach(function(n){n.cancel()})}},{key:"cloneNode",value:function(n,i){var a=De({},this.attributes);for(var s in a){var o=a[s];ut(o)&&s!=="clipPath"&&s!=="offsetPath"&&s!=="textPath"&&(a[s]=o.cloneNode(n)),i&&(a[s]=i(s,o))}var A=new this.constructor(De(De({},this.config),{},{style:a}));return A.setLocalTransform(this.getLocalTransform()),n&&this.children.forEach(function(l){if(!l.style.isMarker){var c=l.cloneNode(n);A.appendChild(c)}}),A}},{key:"initAttributes",value:function(){var n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},i={forceUpdateGeometry:!0};de.styleValueRegistry.processProperties(this,n,i),this.dirty()}},{key:"setAttribute",value:function(n,i){var a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1,s=arguments.length>3&&arguments[3]!==void 0?arguments[3]:!0;He(i)||(a||i!==this.attributes[n])&&(this.internalSetAttribute(n,i,{memoize:s}),Yu(e,"setAttribute",this)([n,i]))}},{key:"setAttributes",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},a=i.skipDispatchAttrModifiedEvent,s=a===void 0?!1:a,o,A;if(s||(o=De({},this.attributes),A=De({},this.parsedStyle)),de.styleValueRegistry.processProperties(this,n,i),this.dirty(),!s)for(var l in n)this.dispatchAttrModifiedEvent(l,o[l],n[l],A[l])}},{key:"internalSetAttribute",value:function(n,i){var a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},s=this.attributes[n],o=this.parsedStyle[n];de.styleValueRegistry.processProperties(this,Ee({},n,i),a),this.dirty(),this.dispatchAttrModifiedEvent(n,s,i,o)}},{key:"dispatchAttrModifiedEvent",value:function(n,i,a,s){var o=this.parsedStyle[n];if(this.isConnected)if(Li.relatedNode=this,Li.prevValue=i,Li.newValue=a,Li.attrName=n,Li.prevParsedValue=s,Li.newParsedValue=o,this.isMutationObserved)this.dispatchEvent(Li);else{var A,l=((A=this.ownerDocument.defaultView.getConfig().future)===null||A===void 0?void 0:A.experimentalCancelEventPropagation)===!0;Li.target=this,this.ownerDocument.defaultView.dispatchEvent(Li,!0,l)}if(this.isCustomElement&&this.isConnected||!this.isCustomElement){var c,u;(c=(u=this).attributeChangedCallback)===null||c===void 0||c.call(u,n,i,a,s,o)}}},{key:"getBBox",value:function(){var n=this.getBounds(),i=n.getMin(),a=We(i,2),s=a[0],o=a[1],A=n.getMax(),l=We(A,2),c=l[0],u=l[1];return new Vo(s,o,c-s,u-o)}},{key:"setOrigin",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0;return de.sceneGraphService.setOrigin(this,Ar(n,i,a,!1)),this}},{key:"getOrigin",value:function(){return de.sceneGraphService.getOrigin(this)}},{key:"setPosition",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0;return de.sceneGraphService.setPosition(this,Ar(n,i,a,!1)),this}},{key:"setLocalPosition",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0;return de.sceneGraphService.setLocalPosition(this,Ar(n,i,a,!1)),this}},{key:"translate",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0;return de.sceneGraphService.translate(this,Ar(n,i,a,!1)),this}},{key:"translateLocal",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0;return de.sceneGraphService.translateLocal(this,Ar(n,i,a,!1)),this}},{key:"getPosition",value:function(){return de.sceneGraphService.getPosition(this)}},{key:"getLocalPosition",value:function(){return de.sceneGraphService.getLocalPosition(this)}},{key:"scale",value:function(n,i,a){return this.scaleLocal(n,i,a)}},{key:"scaleLocal",value:function(n,i,a){return typeof n=="number"&&(i=i||n,a=a||n,n=Ar(n,i,a,!1)),de.sceneGraphService.scaleLocal(this,n),this}},{key:"setLocalScale",value:function(n,i,a){return typeof n=="number"&&(i=i||n,a=a||n,n=Ar(n,i,a,!1)),de.sceneGraphService.setLocalScale(this,n),this}},{key:"getLocalScale",value:function(){return de.sceneGraphService.getLocalScale(this)}},{key:"getScale",value:function(){return de.sceneGraphService.getScale(this)}},{key:"getEulerAngles",value:function(){var n=Nf(pA,de.sceneGraphService.getWorldTransform(this)),i=We(n,3),a=i[2];return Br(a)}},{key:"getLocalEulerAngles",value:function(){var n=Nf(pA,de.sceneGraphService.getLocalRotation(this)),i=We(n,3),a=i[2];return Br(a)}},{key:"setEulerAngles",value:function(n){return de.sceneGraphService.setEulerAngles(this,0,0,n),this}},{key:"setLocalEulerAngles",value:function(n){return de.sceneGraphService.setLocalEulerAngles(this,0,0,n),this}},{key:"rotateLocal",value:function(n,i,a){return ke(i)&&ke(a)?de.sceneGraphService.rotateLocal(this,0,0,n):de.sceneGraphService.rotateLocal(this,n,i,a),this}},{key:"rotate",value:function(n,i,a){return ke(i)&&ke(a)?de.sceneGraphService.rotate(this,0,0,n):de.sceneGraphService.rotate(this,n,i,a),this}},{key:"setRotation",value:function(n,i,a,s){return de.sceneGraphService.setRotation(this,n,i,a,s),this}},{key:"setLocalRotation",value:function(n,i,a,s){return de.sceneGraphService.setLocalRotation(this,n,i,a,s),this}},{key:"setLocalSkew",value:function(n,i){return de.sceneGraphService.setLocalSkew(this,n,i),this}},{key:"getRotation",value:function(){return de.sceneGraphService.getRotation(this)}},{key:"getLocalRotation",value:function(){return de.sceneGraphService.getLocalRotation(this)}},{key:"getLocalSkew",value:function(){return de.sceneGraphService.getLocalSkew(this)}},{key:"getLocalTransform",value:function(){return de.sceneGraphService.getLocalTransform(this)}},{key:"getWorldTransform",value:function(){return de.sceneGraphService.getWorldTransform(this)}},{key:"setLocalTransform",value:function(n){return de.sceneGraphService.setLocalTransform(this,n),this}},{key:"resetLocalTransform",value:function(){de.sceneGraphService.resetLocalTransform(this)}},{key:"getAnimations",value:function(){return this.activeAnimations}},{key:"animate",value:function(n,i){var a,s=(a=this.ownerDocument)===null||a===void 0?void 0:a.timeline;return s?s.play(this,n,i):null}},{key:"isVisible",value:function(){var n;return((n=this.parsedStyle)===null||n===void 0?void 0:n.visibility)!=="hidden"}},{key:"interactive",get:function(){return this.isInteractive()},set:function(n){this.style.pointerEvents=n?"auto":"none"}},{key:"isInteractive",value:function(){var n;return((n=this.parsedStyle)===null||n===void 0?void 0:n.pointerEvents)!=="none"}},{key:"isCulled",value:function(){return!!(this.cullable&&this.cullable.enable&&!this.cullable.visible)}},{key:"toFront",value:function(){return this.parentNode&&(this.style.zIndex=Math.max.apply(Math,tt(this.parentNode.children.map(function(n){return Number(n.style.zIndex)})))+1),this}},{key:"toBack",value:function(){return this.parentNode&&(this.style.zIndex=Math.min.apply(Math,tt(this.parentNode.children.map(function(n){return Number(n.style.zIndex)})))-1),this}},{key:"getConfig",value:function(){return this.config}},{key:"attr",value:function(){for(var n=this,i=arguments.length,a=new Array(i),s=0;s<i;s++)a[s]=arguments[s];var o=a[0],A=a[1];return o?un(o)?(Object.keys(o).forEach(function(l){n.setAttribute(l,o[l])}),this):a.length===2?(this.setAttribute(o,A),this):this.attributes[o]:this.attributes}},{key:"getMatrix",value:function(n){var i=n||this.getWorldTransform(),a=Gu(pA,i),s=We(a,2),o=s[0],A=s[1],l=Ko(pA,i),c=We(l,2),u=c[0],h=c[1],d=Ku(RH,i),f=Nf(pA,d),g=We(f,3),v=g[0],p=g[2];return LD(v||p,o,A,u,h)}},{key:"getLocalMatrix",value:function(){return this.getMatrix(this.getLocalTransform())}},{key:"setMatrix",value:function(n){var i=Qb(n),a=We(i,5),s=a[0],o=a[1],A=a[2],l=a[3],c=a[4];this.setEulerAngles(c).setPosition(s,o).setLocalScale(A,l)}},{key:"setLocalMatrix",value:function(n){var i=Qb(n),a=We(i,5),s=a[0],o=a[1],A=a[2],l=a[3],c=a[4];this.setLocalEulerAngles(c).setLocalPosition(s,o).setLocalScale(A,l)}},{key:"show",value:function(){this.forEach(function(n){n.style.visibility="visible"})}},{key:"hide",value:function(){this.forEach(function(n){n.style.visibility="hidden"})}},{key:"getCount",value:function(){return this.childElementCount}},{key:"getParent",value:function(){return this.parentElement}},{key:"getChildren",value:function(){return this.children}},{key:"getFirst",value:function(){return this.firstElementChild}},{key:"getLast",value:function(){return this.lastElementChild}},{key:"getChildByIndex",value:function(n){return this.children[n]||null}},{key:"add",value:function(n,i){return this.appendChild(n,i)}},{key:"set",value:function(n,i){this.config[n]=i}},{key:"get",value:function(n){return this.config[n]}},{key:"moveTo",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0;return this.setPosition(n,i,a),this}},{key:"move",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,a=arguments.length>2&&arguments[2]!==void 0?arguments[2]:0;return this.setPosition(n,i,a),this}},{key:"setZIndex",value:function(n){return this.style.zIndex=n,this}}])})(UH);Ot.PARSED_STYLE_LIST=new Set(["class","className","clipPath","cursor","display","draggable","droppable","fill","fillOpacity","fillRule","filter","increasedLineWidthForHitTesting","lineCap","lineDash","lineDashOffset","lineJoin","lineWidth","miterLimit","hitArea","offsetDistance","offsetPath","offsetX","offsetY","opacity","pointerEvents","shadowColor","shadowType","shadowBlur","shadowOffsetX","shadowOffsetY","stroke","strokeOpacity","strokeWidth","strokeLinecap","strokeLineJoin","strokeDasharray","strokeDashoffset","transform","transformOrigin","textTransform","visibility","zIndex"]);var zi=(function(r){function e(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return ue(this,e),qe(this,e,[De({type:ae.CIRCLE},t)])}return $e(e,r),he(e)})(Ot);zi.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["cx","cy","cz","r","isBillboard","isSizeAttenuation"]));var DH=["style"],Ol=(function(r){function e(){var t,n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},i=n.style,a=Di(n,DH);return ue(this,e),t=qe(this,e,[De({style:i},a)]),t.isCustomElement=!0,t}return $e(e,r),he(e)})(Ot);Ol.PARSED_STYLE_LIST=new Set(["class","className","clipPath","cursor","draggable","droppable","opacity","pointerEvents","transform","transformOrigin","zIndex","visibility"]);var _l=(function(r){function e(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return ue(this,e),qe(this,e,[De({type:ae.ELLIPSE},t)])}return $e(e,r),he(e)})(Ot);_l.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["cx","cy","cz","rx","ry","isBillboard","isSizeAttenuation"]));var HH=(function(r){function e(){return ue(this,e),qe(this,e,[{type:ae.FRAGMENT}])}return $e(e,r),he(e)})(Ot);HH.PARSED_STYLE_LIST=new Set(["class","className"]);var Tn=(function(r){function e(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return ue(this,e),qe(this,e,[De({type:ae.GROUP},t)])}return $e(e,r),he(e)})(Ot);Tn.PARSED_STYLE_LIST=new Set(["class","className","clipPath","cursor","draggable","droppable","opacity","pointerEvents","transform","transformOrigin","zIndex","visibility"]);var GH=["style"],Ys=(function(r){function e(){var t,n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},i=n.style,a=Di(n,GH);return ue(this,e),t=qe(this,e,[De({type:ae.HTML,style:i},a)]),t.cullable.enable=!1,t}return $e(e,r),he(e,[{key:"getDomElement",value:function(){return this.parsedStyle.$el}},{key:"getClientRects",value:function(){return[this.getBoundingClientRect()]}},{key:"getLocalBounds",value:function(){if(this.parentNode){var n=Ni(xt(),this.parentNode.getWorldTransform()),i=this.getBounds();if(!It.isEmpty(i)){var a=new It;return a.setFromTransformedAABB(i,n),a}}return this.getBounds()}}])})(Ot);Ys.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["x","y","$el","innerHTML","width","height"]));var Il=(function(r){function e(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return ue(this,e),qe(this,e,[De({type:ae.IMAGE},t)])}return $e(e,r),he(e)})(Ot);Il.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["x","y","z","src","width","height","isBillboard","billboardRotation","isSizeAttenuation","keepAspectRatio"]));var KH=["style"],Ks=(function(r){function e(){var t,n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},i=n.style,a=Di(n,KH);ue(this,e),t=qe(this,e,[De({type:ae.LINE,style:De({x1:0,y1:0,x2:0,y2:0,z1:0,z2:0},i)},a)]),t.markerStartAngle=0,t.markerEndAngle=0;var s=t.parsedStyle,o=s.markerStart,A=s.markerEnd;return o&&ut(o)&&(t.markerStartAngle=o.getLocalEulerAngles(),t.appendChild(o)),A&&ut(A)&&(t.markerEndAngle=A.getLocalEulerAngles(),t.appendChild(A)),t.transformMarker(!0),t.transformMarker(!1),t}return $e(e,r),he(e,[{key:"attributeChangedCallback",value:function(n,i,a,s,o){n==="x1"||n==="y1"||n==="x2"||n==="y2"||n==="markerStartOffset"||n==="markerEndOffset"?(this.transformMarker(!0),this.transformMarker(!1)):n==="markerStart"?(s&&ut(s)&&(this.markerStartAngle=0,s.remove()),o&&ut(o)&&(this.markerStartAngle=o.getLocalEulerAngles(),this.appendChild(o),this.transformMarker(!0))):n==="markerEnd"&&(s&&ut(s)&&(this.markerEndAngle=0,s.remove()),o&&ut(o)&&(this.markerEndAngle=o.getLocalEulerAngles(),this.appendChild(o),this.transformMarker(!1)))}},{key:"transformMarker",value:function(n){var i=this.parsedStyle,a=i.markerStart,s=i.markerEnd,o=i.markerStartOffset,A=i.markerEndOffset,l=i.x1,c=i.x2,u=i.y1,h=i.y2,d=n?a:s;if(!(!d||!ut(d))){var f=0,g,v,p,y,m,B;n?(p=l,y=u,g=c-l,v=h-u,m=o||0,B=this.markerStartAngle):(p=c,y=h,g=l-c,v=u-h,m=A||0,B=this.markerEndAngle),f=Math.atan2(v,g),d.setLocalEulerAngles(f*180/Math.PI+B),d.setLocalPosition(p+Math.cos(f)*m,y+Math.sin(f)*m)}}},{key:"getPoint",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,a=this.parsedStyle,s=a.x1,o=a.y1,A=a.x2,l=a.y2,c=nI(s,o,A,l,n),u=c.x,h=c.y,d=nr(Ze(),Ct(u,h,0),i?this.getWorldTransform():this.getLocalTransform());return new Dn(d[0],d[1])}},{key:"getPointAtLength",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;return this.getPoint(n/this.getTotalLength(),i)}},{key:"getTotalLength",value:function(){var n=this.parsedStyle,i=n.x1,a=n.y1,s=n.x2,o=n.y2;return tI(i,a,s,o)}}])})(Ot);Ks.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["x1","y1","x2","y2","z1","z2","isBillboard","isSizeAttenuation","markerStart","markerEnd","markerStartOffset","markerEndOffset"]));var zH=["style"],rr=(function(r){function e(){var t,n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},i=n.style,a=Di(n,zH);ue(this,e),t=qe(this,e,[De({type:ae.PATH,style:i,initialParsedStyle:{miterLimit:4,d:De({},aI)}},a)]),t.markerStartAngle=0,t.markerEndAngle=0,t.markerMidList=[];var s=t.parsedStyle,o=s.markerStart,A=s.markerEnd,l=s.markerMid;return o&&ut(o)&&(t.markerStartAngle=o.getLocalEulerAngles(),t.appendChild(o)),l&&ut(l)&&t.placeMarkerMid(l),A&&ut(A)&&(t.markerEndAngle=A.getLocalEulerAngles(),t.appendChild(A)),t.transformMarker(!0),t.transformMarker(!1),t}return $e(e,r),he(e,[{key:"attributeChangedCallback",value:function(n,i,a,s,o){n==="d"?(this.transformMarker(!0),this.transformMarker(!1),this.placeMarkerMid(this.parsedStyle.markerMid)):n==="markerStartOffset"||n==="markerEndOffset"?(this.transformMarker(!0),this.transformMarker(!1)):n==="markerStart"?(s&&ut(s)&&(this.markerStartAngle=0,s.remove()),o&&ut(o)&&(this.markerStartAngle=o.getLocalEulerAngles(),this.appendChild(o),this.transformMarker(!0))):n==="markerEnd"?(s&&ut(s)&&(this.markerEndAngle=0,s.remove()),o&&ut(o)&&(this.markerEndAngle=o.getLocalEulerAngles(),this.appendChild(o),this.transformMarker(!1))):n==="markerMid"&&this.placeMarkerMid(o)}},{key:"transformMarker",value:function(n){var i=this.parsedStyle,a=i.markerStart,s=i.markerEnd,o=i.markerStartOffset,A=i.markerEndOffset,l=n?a:s;if(!(!l||!ut(l))){var c=0,u,h,d,f,g,v;if(n){var p=this.getStartTangent(),y=We(p,2),m=y[0],B=y[1];d=B[0],f=B[1],u=m[0]-B[0],h=m[1]-B[1],g=o||0,v=this.markerStartAngle}else{var C=this.getEndTangent(),S=We(C,2),F=S[0],T=S[1];d=T[0],f=T[1],u=F[0]-T[0],h=F[1]-T[1],g=A||0,v=this.markerEndAngle}c=Math.atan2(h,u),l.setLocalEulerAngles(c*180/Math.PI+v),l.setLocalPosition(d+Math.cos(c)*g,f+Math.sin(c)*g)}}},{key:"placeMarkerMid",value:function(n){var i=this.parsedStyle.d.segments;if(this.markerMidList.forEach(function(c){c.remove()}),n&&ut(n))for(var a=1;a<i.length-1;a++){var s=We(i[a].currentPoint,2),o=s[0],A=s[1],l=a===1?n:n.cloneNode(!0);this.markerMidList.push(l),this.appendChild(l),l.setLocalPosition(o,A)}}},{key:"getTotalLength",value:function(){return kw(this)}},{key:"getPointAtLength",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,a=this.parsedStyle.d.absolutePath,s=iD(a,n),o=s.x,A=s.y,l=nr(Ze(),Ct(o,A,0),i?this.getWorldTransform():this.getLocalTransform());return new Dn(l[0],l[1])}},{key:"getPoint",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;return this.getPointAtLength(n*kw(this),i)}},{key:"getStartTangent",value:function(){var n=this.parsedStyle.d.segments,i=[];if(n.length>1){var a=n[0].currentPoint,s=n[1].currentPoint,o=n[1].startTangent;i=[],o?(i.push([a[0]-o[0],a[1]-o[1]]),i.push([a[0],a[1]])):(i.push([s[0],s[1]]),i.push([a[0],a[1]]))}return i}},{key:"getEndTangent",value:function(){var n=this.parsedStyle.d.segments,i=n.length,a=[];if(i>1){var s=n[i-2].currentPoint,o=n[i-1].currentPoint,A=n[i-1].endTangent;a=[],A?(a.push([o[0]-A[0],o[1]-A[1]]),a.push([o[0],o[1]])):(a.push([s[0],s[1]]),a.push([o[0],o[1]]))}return a}}])})(Ot);rr.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["d","markerStart","markerMid","markerEnd","markerStartOffset","markerEndOffset","isBillboard","isSizeAttenuation"]));var VH=["style"],Xs=(function(r){function e(){var t,n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},i=n.style,a=Di(n,VH);ue(this,e),t=qe(this,e,[De({type:ae.POLYGON,style:i,initialParsedStyle:{points:{points:[],totalLength:0,segments:[]},miterLimit:4,isClosed:!0}},a)]),t.markerStartAngle=0,t.markerEndAngle=0,t.markerMidList=[];var s=t.parsedStyle,o=s.markerStart,A=s.markerEnd,l=s.markerMid;return o&&ut(o)&&(t.markerStartAngle=o.getLocalEulerAngles(),t.appendChild(o)),l&&ut(l)&&t.placeMarkerMid(l),A&&ut(A)&&(t.markerEndAngle=A.getLocalEulerAngles(),t.appendChild(A)),t.transformMarker(!0),t.transformMarker(!1),t}return $e(e,r),he(e,[{key:"attributeChangedCallback",value:function(n,i,a,s,o){n==="points"?(this.transformMarker(!0),this.transformMarker(!1),this.placeMarkerMid(this.parsedStyle.markerMid)):n==="markerStartOffset"||n==="markerEndOffset"?(this.transformMarker(!0),this.transformMarker(!1)):n==="markerStart"?(s&&ut(s)&&(this.markerStartAngle=0,s.remove()),o&&ut(o)&&(this.markerStartAngle=o.getLocalEulerAngles(),this.appendChild(o),this.transformMarker(!0))):n==="markerEnd"?(s&&ut(s)&&(this.markerEndAngle=0,s.remove()),o&&ut(o)&&(this.markerEndAngle=o.getLocalEulerAngles(),this.appendChild(o),this.transformMarker(!1))):n==="markerMid"&&this.placeMarkerMid(o)}},{key:"transformMarker",value:function(n){var i=this.parsedStyle,a=i.markerStart,s=i.markerEnd,o=i.markerStartOffset,A=i.markerEndOffset,l=i.points,c=l||{},u=c.points,h=n?a:s;if(!(!h||!ut(h)||!u)){var d=0,f,g,v,p,y,m;if(v=u[0][0],p=u[0][1],n)f=u[1][0]-u[0][0],g=u[1][1]-u[0][1],y=o||0,m=this.markerStartAngle;else{var B=u.length;this.parsedStyle.isClosed?(f=u[B-1][0]-u[0][0],g=u[B-1][1]-u[0][1]):(v=u[B-1][0],p=u[B-1][1],f=u[B-2][0]-u[B-1][0],g=u[B-2][1]-u[B-1][1]),y=A||0,m=this.markerEndAngle}d=Math.atan2(g,f),h.setLocalEulerAngles(d*180/Math.PI+m),h.setLocalPosition(v+Math.cos(d)*y,p+Math.sin(d)*y)}}},{key:"placeMarkerMid",value:function(n){var i=this.parsedStyle.points,a=i||{},s=a.points;if(this.markerMidList.forEach(function(u){u.remove()}),this.markerMidList=[],n&&ut(n)&&s)for(var o=1;o<(this.parsedStyle.isClosed?s.length:s.length-1);o++){var A=s[o][0],l=s[o][1],c=o===1?n:n.cloneNode(!0);this.markerMidList.push(c),this.appendChild(c),c.setLocalPosition(A,l)}}}])})(Ot);Xs.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["points","markerStart","markerMid","markerEnd","markerStartOffset","markerEndOffset","isClosed","isBillboard","isSizeAttenuation"]));var jH=["style"],Dh=(function(r){function e(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},n=t.style,i=Di(t,jH);return ue(this,e),qe(this,e,[De({type:ae.POLYLINE,style:n,initialParsedStyle:{points:{points:[],totalLength:0,segments:[]},miterLimit:4,isClosed:!1}},i)])}return $e(e,r),he(e,[{key:"getTotalLength",value:function(){return U3(this)}},{key:"getPointAtLength",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;return this.getPoint(n/this.getTotalLength(),i)}},{key:"getPoint",value:function(n){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,a=this.parsedStyle.points.points;if(this.parsedStyle.points.segments.length===0){var s=[],o=0,A,l,c=this.getTotalLength();a.forEach(function(p,y){a[y+1]&&(A=[0,0],A[0]=o/c,l=tI(p[0],p[1],a[y+1][0],a[y+1][1]),o+=l,A[1]=o/c,s.push(A))}),this.parsedStyle.points.segments=s}var u=0,h=0;this.parsedStyle.points.segments.forEach(function(p,y){n>=p[0]&&n<=p[1]&&(u=(n-p[0])/(p[1]-p[0]),h=y)});var d=nI(a[h][0],a[h][1],a[h+1][0],a[h+1][1],u),f=d.x,g=d.y,v=nr(Ze(),Ct(f,g,0),i?this.getWorldTransform():this.getLocalTransform());return new Dn(v[0],v[1])}},{key:"getStartTangent",value:function(){var n=this.parsedStyle.points.points,i=[];return i.push([n[1][0],n[1][1]]),i.push([n[0][0],n[0][1]]),i}},{key:"getEndTangent",value:function(){var n=this.parsedStyle.points.points,i=n.length-1,a=[];return a.push([n[i-1][0],n[i-1][1]]),a.push([n[i][0],n[i][1]]),a}}])})(Xs);Dh.PARSED_STYLE_LIST=new Set([].concat(tt(Xs.PARSED_STYLE_LIST),["points","markerStart","markerMid","markerEnd","markerStartOffset","markerEndOffset","isBillboard"]));var Vn=(function(r){function e(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return ue(this,e),qe(this,e,[De({type:ae.RECT},t)])}return $e(e,r),he(e)})(Ot);Vn.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["x","y","z","width","height","isBillboard","isSizeAttenuation","radius"]));var WH=["style"],Zs=(function(r){function e(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},n=t.style,i=Di(t,WH);return ue(this,e),qe(this,e,[De({type:ae.TEXT,style:De({fill:"black"},n)},i)])}return $e(e,r),he(e,[{key:"getComputedTextLength",value:function(){var n;return this.getGeometryBounds(),((n=this.parsedStyle.metrics)===null||n===void 0?void 0:n.maxLineWidth)||0}},{key:"getLineBoundingRects",value:function(){var n;return this.getGeometryBounds(),((n=this.parsedStyle.metrics)===null||n===void 0?void 0:n.lineMetrics)||[]}},{key:"isOverflowing",value:function(){return this.getGeometryBounds(),!!this.parsedStyle.isOverflowing}}])})(Ot);Zs.PARSED_STYLE_LIST=new Set([].concat(tt(Ot.PARSED_STYLE_LIST),["x","y","z","isBillboard","billboardRotation","isSizeAttenuation","text","textAlign","textBaseline","fontStyle","fontSize","fontFamily","fontWeight","fontVariant","lineHeight","letterSpacing","leading","wordWrap","wordWrapWidth","maxLines","textOverflow","isOverflowing","textPath","textDecorationLine","textDecorationColor","textDecorationStyle","textDecorationThickness","textPathSide","textPathStartOffset","metrics","dx","dy"]));var qH=(function(){function r(){ue(this,r),this.registry={},this.define(ae.CIRCLE,zi),this.define(ae.ELLIPSE,_l),this.define(ae.RECT,Vn),this.define(ae.IMAGE,Il),this.define(ae.LINE,Ks),this.define(ae.GROUP,Tn),this.define(ae.PATH,rr),this.define(ae.POLYGON,Xs),this.define(ae.POLYLINE,Dh),this.define(ae.TEXT,Zs),this.define(ae.HTML,Ys)}return he(r,[{key:"define",value:function(t,n){this.registry[t]=n}},{key:"get",value:function(t){return this.registry[t]}}])})(),$H={number:function(e){return new Bt(e)},percent:function(e){return new Bt(e,"%")},px:function(e){return new Bt(e,"px")},em:function(e){return new Bt(e,"em")},rem:function(e){return new Bt(e,"rem")},deg:function(e){return new Bt(e,"deg")},grad:function(e){return new Bt(e,"grad")},rad:function(e){return new Bt(e,"rad")},turn:function(e){return new Bt(e,"turn")},s:function(e){return new Bt(e,"s")},ms:function(e){return new Bt(e,"ms")},registerProperty:function(e){var t=e.name,n=e.inherits,i=e.interpolable,a=e.initialValue,s=e.syntax;de.styleValueRegistry.registerMetadata({n:t,inh:n,int:i,d:a,syntax:s})},registerLayout:function(e,t){de.layoutRegistry.registerLayout(e,t)}},kI=(function(r){function e(){var t;ue(this,e),t=qe(this,e),t.defaultView=null,t.ownerDocument=null,t.nodeName="document";try{t.timeline=new de.AnimationTimeline(t)}catch{}var n={};return X1.forEach(function(i){var a=i.n,s=i.inh,o=i.d;s&&o&&(n[a]=Te(o)?o(ae.GROUP):o)}),t.documentElement=new Tn({id:"g-root",style:n}),t.documentElement.ownerDocument=t,t.documentElement.parentNode=t,t.childNodes=[t.documentElement],t}return $e(e,r),he(e,[{key:"children",get:function(){return this.childNodes}},{key:"childElementCount",get:function(){return this.childNodes.length}},{key:"firstElementChild",get:function(){return this.firstChild}},{key:"lastElementChild",get:function(){return this.lastChild}},{key:"createElement",value:function(n,i){if(n==="svg")return this.documentElement;var a=this.defaultView.customElements.get(n);a||(console.warn("Unsupported tagName: ",n),a=n==="tspan"?Zs:Tn);var s=new a(i);return s.ownerDocument=this,s}},{key:"createElementNS",value:function(n,i,a){return this.createElement(i,a)}},{key:"cloneNode",value:function(n){throw new Error(wt)}},{key:"destroy",value:function(){try{this.documentElement.destroyChildren(),this.timeline.destroy()}catch{}}},{key:"elementsFromBBox",value:function(n,i,a,s){var o=[],A=function(c){if(!(!c.isInteractive()||c.isCulled())){var u=c.parsedStyle.pointerEvents,h=u===void 0?"auto":u,d=["auto","visiblepainted","visiblefill","visiblestroke","visible"].includes(h);if(!d||c.isVisible()){var f=c.getTransformedGeometryBounds(!0);f&&!It.isEmpty(f)&&f.max[0]>=n&&f.min[0]<=a&&f.max[1]>=i&&f.min[1]<=s&&o.push(c)}c.childNodes&&c.childNodes.forEach(function(g){g instanceof Ot&&A(g)})}};return A(this.documentElement),o.sort(function(l,c){return c.sortable.renderOrder-l.sortable.renderOrder}),o}},{key:"elementFromPointSync",value:function(n,i){var a=this.defaultView.canvas2Viewport({x:n,y:i}),s=a.x,o=a.y,A=this.defaultView.getConfig(),l=A.width,c=A.height;if(s<0||o<0||s>l||o>c)return null;var u=this.defaultView.viewport2Client({x:s,y:o}),h=u.x,d=u.y,f=this.defaultView.getRenderingService().hooks.pickSync.call({topmost:!0,position:{x:n,y:i,viewportX:s,viewportY:o,clientX:h,clientY:d},picked:[]}),g=f.picked;return g&&g[0]||this.documentElement}},{key:"elementFromPoint",value:(function(){var t=Ja(Gn().mark(function i(a,s){var o,A,l,c,u,h,d,f,g,v,p;return Gn().wrap(function(y){for(;;)switch(y.prev=y.next){case 0:if(o=this.defaultView.canvas2Viewport({x:a,y:s}),A=o.x,l=o.y,c=this.defaultView.getConfig(),u=c.width,h=c.height,!(A<0||l<0||A>u||l>h)){y.next=1;break}return y.abrupt("return",null);case 1:return d=this.defaultView.viewport2Client({x:A,y:l}),f=d.x,g=d.y,y.next=2,this.defaultView.getRenderingService().hooks.pick.promise({topmost:!0,position:{x:a,y:s,viewportX:A,viewportY:l,clientX:f,clientY:g},picked:[]});case 2:return v=y.sent,p=v.picked,y.abrupt("return",p&&p[0]||this.documentElement);case 3:case"end":return y.stop()}},i,this)}));function n(i,a){return t.apply(this,arguments)}return n})()},{key:"elementsFromPointSync",value:function(n,i){var a=this.defaultView.canvas2Viewport({x:n,y:i}),s=a.x,o=a.y,A=this.defaultView.getConfig(),l=A.width,c=A.height;if(s<0||o<0||s>l||o>c)return[];var u=this.defaultView.viewport2Client({x:s,y:o}),h=u.x,d=u.y,f=this.defaultView.getRenderingService().hooks.pickSync.call({topmost:!1,position:{x:n,y:i,viewportX:s,viewportY:o,clientX:h,clientY:d},picked:[]}),g=f.picked;return g[g.length-1]!==this.documentElement&&g.push(this.documentElement),g}},{key:"elementsFromPoint",value:(function(){var t=Ja(Gn().mark(function i(a,s){var o,A,l,c,u,h,d,f,g,v,p;return Gn().wrap(function(y){for(;;)switch(y.prev=y.next){case 0:if(o=this.defaultView.canvas2Viewport({x:a,y:s}),A=o.x,l=o.y,c=this.defaultView.getConfig(),u=c.width,h=c.height,!(A<0||l<0||A>u||l>h)){y.next=1;break}return y.abrupt("return",[]);case 1:return d=this.defaultView.viewport2Client({x:A,y:l}),f=d.x,g=d.y,y.next=2,this.defaultView.getRenderingService().hooks.pick.promise({topmost:!1,position:{x:a,y:s,viewportX:A,viewportY:l,clientX:f,clientY:g},picked:[]});case 2:return v=y.sent,p=v.picked,p[p.length-1]!==this.documentElement&&p.push(this.documentElement),y.abrupt("return",p);case 3:case"end":return y.stop()}},i,this)}));function n(i,a){return t.apply(this,arguments)}return n})()},{key:"appendChild",value:function(n,i){throw new Error(lo)}},{key:"insertBefore",value:function(n,i){throw new Error(lo)}},{key:"removeChild",value:function(n,i){throw new Error(lo)}},{key:"replaceChild",value:function(n,i,a){throw new Error(lo)}},{key:"append",value:function(){throw new Error(lo)}},{key:"prepend",value:function(){throw new Error(lo)}},{key:"getElementById",value:function(n){return this.documentElement.getElementById(n)}},{key:"getElementsByName",value:function(n){return this.documentElement.getElementsByName(n)}},{key:"getElementsByTagName",value:function(n){return this.documentElement.getElementsByTagName(n)}},{key:"getElementsByClassName",value:function(n){return this.documentElement.getElementsByClassName(n)}},{key:"querySelector",value:function(n){return this.documentElement.querySelector(n)}},{key:"querySelectorAll",value:function(n){return this.documentElement.querySelectorAll(n)}},{key:"find",value:function(n){return this.documentElement.find(n)}},{key:"findAll",value:function(n){return this.documentElement.findAll(n)}}])})(Vt),LI=(function(){function r(e){ue(this,r),this.strategies=e}return he(r,[{key:"apply",value:function(t){var n=t.config,i=t.camera,a=t.renderingService,s=t.renderingContext,o=this.strategies;a.hooks.cull.tap(r.tag,function(A){if(A){var l,c=A.cullable;if(o.length===0?c.visible=s.unculledEntities.indexOf(A.entity)>-1:c.visible=o.every(function(h){return h.isVisible(i,A)}),!A.isCulled()&&A.isVisible())return A;var u=((l=n.future)===null||l===void 0?void 0:l.experimentalCancelEventPropagation)===!0;return A.dispatchEvent(new vn(it.CULLED),u,u),null}return A}),a.hooks.afterRender.tap(r.tag,function(A){A.cullable.visibilityPlaneMask=-1})}}])})();LI.tag="Culling";var QI=(function(){function r(){var e=this;ue(this,r),this.autoPreventDefault=!1,this.rootPointerEvent=new ih(null),this.rootWheelEvent=new Uw(null),this.onPointerMove=function(t){var n,i=(n=e.context.renderingContext.root)===null||n===void 0||(n=n.ownerDocument)===null||n===void 0?void 0:n.defaultView;if(!(i.supportsTouchEvents&&t.pointerType==="touch")){var a=e.normalizeToPointerEvent(t,i),s=ka(a),o;try{for(s.s();!(o=s.n()).done;){var A=o.value,l=e.bootstrapEvent(e.rootPointerEvent,A,i,t);e.context.eventService.mapEvent(l)}}catch(c){s.e(c)}finally{s.f()}e.setCursor(e.context.eventService.cursor)}},this.onClick=function(t){var n,i=(n=e.context.renderingContext.root)===null||n===void 0||(n=n.ownerDocument)===null||n===void 0?void 0:n.defaultView,a=e.normalizeToPointerEvent(t,i),s=ka(a),o;try{for(s.s();!(o=s.n()).done;){var A=o.value,l=e.bootstrapEvent(e.rootPointerEvent,A,i,t);e.context.eventService.mapEvent(l)}}catch(c){s.e(c)}finally{s.f()}e.setCursor(e.context.eventService.cursor)}}return he(r,[{key:"apply",value:function(t){var n=this;this.context=t;var i=t.renderingService,a=this.context.renderingContext.root.ownerDocument.defaultView;this.context.eventService.setPickHandler(function(s){var o=n.context.renderingService.hooks.pickSync.call({position:s,picked:[],topmost:!0}),A=o.picked;return A[0]||null}),i.hooks.pointerWheel.tap(r.tag,function(s){var o=n.normalizeWheelEvent(s);n.context.eventService.mapEvent(o)}),i.hooks.pointerDown.tap(r.tag,function(s){if(!(a.supportsTouchEvents&&s.pointerType==="touch")){var o=n.normalizeToPointerEvent(s,a);if(n.autoPreventDefault&&o[0].isNormalized){var A=s.cancelable||!("cancelable"in s);A&&s.preventDefault()}var l=ka(o),c;try{for(l.s();!(c=l.n()).done;){var u=c.value,h=n.bootstrapEvent(n.rootPointerEvent,u,a,s);n.context.eventService.mapEvent(h)}}catch(d){l.e(d)}finally{l.f()}n.setCursor(n.context.eventService.cursor)}}),i.hooks.pointerUp.tap(r.tag,function(s){if(!(a.supportsTouchEvents&&s.pointerType==="touch")){var o=n.context.contextService.getDomElement(),A=n.context.eventService.isNativeEventFromCanvas(o,s),l=A?"":"outside",c=n.normalizeToPointerEvent(s,a),u=ka(c),h;try{for(u.s();!(h=u.n()).done;){var d=h.value,f=n.bootstrapEvent(n.rootPointerEvent,d,a,s);f.type+=l,n.context.eventService.mapEvent(f)}}catch(g){u.e(g)}finally{u.f()}n.setCursor(n.context.eventService.cursor)}}),i.hooks.pointerMove.tap(r.tag,this.onPointerMove),i.hooks.pointerOver.tap(r.tag,this.onPointerMove),i.hooks.pointerOut.tap(r.tag,this.onPointerMove),i.hooks.click.tap(r.tag,this.onClick),i.hooks.pointerCancel.tap(r.tag,function(s){var o=n.normalizeToPointerEvent(s,a),A=ka(o),l;try{for(A.s();!(l=A.n()).done;){var c=l.value,u=n.bootstrapEvent(n.rootPointerEvent,c,a,s);n.context.eventService.mapEvent(u)}}catch(h){A.e(h)}finally{A.f()}n.setCursor(n.context.eventService.cursor)})}},{key:"bootstrapEvent",value:function(t,n,i,a){t.view=i,t.originalEvent=null,t.nativeEvent=a,t.pointerId=n.pointerId,t.width=n.width,t.height=n.height,t.isPrimary=n.isPrimary,t.pointerType=n.pointerType,t.pressure=n.pressure,t.tangentialPressure=n.tangentialPressure,t.tiltX=n.tiltX,t.tiltY=n.tiltY,t.twist=n.twist,this.transferMouseData(t,n);var s=this.context.eventService.client2Viewport({x:n.clientX,y:n.clientY}),o=s.x,A=s.y;t.viewport.x=o,t.viewport.y=A;var l=this.context.eventService.viewport2Canvas(t.viewport),c=l.x,u=l.y;return t.canvas.x=c,t.canvas.y=u,t.global.copyFrom(t.canvas),t.offset.copyFrom(t.canvas),t.isTrusted=a.isTrusted,t.type==="pointerleave"&&(t.type="pointerout"),t.type.startsWith("mouse")&&(t.type=t.type.replace("mouse","pointer")),t.type.startsWith("touch")&&(t.type=O4[t.type]||t.type),t}},{key:"normalizeWheelEvent",value:function(t){var n=this.rootWheelEvent;this.transferMouseData(n,t),n.deltaMode=t.deltaMode,n.deltaX=t.deltaX,n.deltaY=t.deltaY,n.deltaZ=t.deltaZ;var i=this.context.eventService.client2Viewport({x:t.clientX,y:t.clientY}),a=i.x,s=i.y;n.viewport.x=a,n.viewport.y=s;var o=this.context.eventService.viewport2Canvas(n.viewport),A=o.x,l=o.y;return n.canvas.x=A,n.canvas.y=l,n.global.copyFrom(n.canvas),n.offset.copyFrom(n.canvas),n.nativeEvent=t,n.type=t.type,n}},{key:"transferMouseData",value:function(t,n){t.isTrusted=n.isTrusted,t.srcElement=n.srcElement,t.timeStamp=Nw.now(),t.type=n.type,t.altKey=n.altKey,t.metaKey=n.metaKey,t.shiftKey=n.shiftKey,t.ctrlKey=n.ctrlKey,t.button=n.button,t.buttons=n.buttons,t.client.x=n.clientX,t.client.y=n.clientY,t.movement.x=n.movementX,t.movement.y=n.movementY,t.page.x=n.pageX,t.page.y=n.pageY,t.screen.x=n.screenX,t.screen.y=n.screenY,t.relatedTarget=null}},{key:"setCursor",value:function(t){this.context.contextService.applyCursorStyle(t||this.context.config.cursor||"default")}},{key:"normalizeToPointerEvent",value:function(t,n){var i=[];if(n.isTouchEvent(t))for(var a=0;a<t.changedTouches.length;a++){var s=t.changedTouches[a];He(s.button)&&(s.button=0),He(s.buttons)&&(s.buttons=1),He(s.isPrimary)&&(s.isPrimary=t.touches.length===1&&t.type==="touchstart"),He(s.width)&&(s.width=s.radiusX||1),He(s.height)&&(s.height=s.radiusY||1),He(s.tiltX)&&(s.tiltX=0),He(s.tiltY)&&(s.tiltY=0),He(s.pointerType)&&(s.pointerType="touch"),He(s.pointerId)&&(s.pointerId=s.identifier||0),He(s.pressure)&&(s.pressure=s.force||.5),He(s.twist)&&(s.twist=0),He(s.tangentialPressure)&&(s.tangentialPressure=0),s.isNormalized=!0,s.type=t.type,i.push(s)}else if(n.isMouseEvent(t)){var o=t;He(o.isPrimary)&&(o.isPrimary=!0),He(o.width)&&(o.width=1),He(o.height)&&(o.height=1),He(o.tiltX)&&(o.tiltX=0),He(o.tiltY)&&(o.tiltY=0),He(o.pointerType)&&(o.pointerType="mouse"),He(o.pointerId)&&(o.pointerId=M4),He(o.pressure)&&(o.pressure=.5),He(o.twist)&&(o.twist=0),He(o.tangentialPressure)&&(o.tangentialPressure=0),o.isNormalized=!0,i.push(o)}else i.push(t);return i}}])})();QI.tag="Event";var YH=[ae.CIRCLE,ae.ELLIPSE,ae.IMAGE,ae.RECT,ae.LINE,ae.POLYLINE,ae.POLYGON,ae.TEXT,ae.PATH,ae.HTML],XH=(function(){function r(){ue(this,r)}return he(r,[{key:"isVisible",value:function(t,n){var i,a=n.cullable;if(!a.enable)return!0;var s=n.getRenderBounds();if(It.isEmpty(s))return!1;var o=t.getFrustum(),A=(i=n.parentNode)===null||i===void 0||(i=i.cullable)===null||i===void 0?void 0:i.visibilityPlaneMask;return a.visibilityPlaneMask=this.computeVisibilityWithPlaneMask(n,s,A||Ao.INDETERMINATE,o.planes),a.visible=a.visibilityPlaneMask!==Ao.OUTSIDE,a.visible}},{key:"computeVisibilityWithPlaneMask",value:function(t,n,i,a){if(i===Ao.OUTSIDE||i===Ao.INSIDE)return i;for(var s=Ao.INSIDE,o=YH.indexOf(t.nodeName)>-1,A=0,l=a.length;A<l;++A){var c=1<<A;if((i&c)!==0&&!(o&&(A===4||A===5))){var u=a[A],h=u.normal,d=u.distance;if(Pi(h,n.getPositiveFarPoint(a[A]))+d<0)return Ao.OUTSIDE;Pi(h,n.getNegativeFarPoint(a[A]))+d<0&&(s|=c)}}return s}}])})(),NI=(function(){function r(){ue(this,r),this.mutationRecords=[],this.isFirstTimeRendering=!0,this.isFirstTimeRenderingFinished=!1}return he(r,[{key:"apply",value:function(t){var n=this,i,a=t.renderingService,s=t.renderingContext,o=s.root.ownerDocument.defaultView,A=function(f){a.dirty()},l=function(f){var g,v=f.detail;(g=n.mutationRecords).push.apply(g,tt(v)),a.dirty()},c=function(f){var g=f.target;de.enableSizeAttenuation&&de.styleValueRegistry.updateSizeAttenuation(g,o.getCamera().getZoom())},u=function(f){var g=f.target;de.sceneGraphService.dirtyToRoot(g),a.dirty()};a.hooks.init.tap(r.tag,function(){o.addEventListener(it.MOUNTED,c),o.addEventListener(it.UNMOUNTED,u),o.addEventListener(it.ATTR_MODIFIED,A),o.addEventListener(it.BOUNDS_CHANGED,l)}),a.hooks.destroy.tap(r.tag,function(){o.removeEventListener(it.MOUNTED,c),o.removeEventListener(it.UNMOUNTED,u),o.removeEventListener(it.ATTR_MODIFIED,A),o.removeEventListener(it.BOUNDS_CHANGED,l),n.mutationRecords=[]});var h=(i=de.globalThis.requestIdleCallback)!==null&&i!==void 0?i:J1.bind(de.globalThis);a.hooks.endFrame.tap(r.tag,function(){n.isFirstTimeRendering&&(n.isFirstTimeRendering=!1,h(function(){n.isFirstTimeRenderingFinished=!0})),n.mutationRecords=[]})}}])})();NI.tag="Prepare";var Pr=(function(r){return r.READY="ready",r.BEFORE_RENDER="beforerender",r.RERENDER="rerender",r.AFTER_RENDER="afterrender",r.BEFORE_DESTROY="beforedestroy",r.AFTER_DESTROY="afterdestroy",r.RESIZE="resize",r.DIRTY_RECTANGLE="dirtyrectangle",r.RENDERER_CHANGED="rendererchanged",r})({}),dE=500,ZH=.1,JH=1e3,gc=new vn(it.MOUNTED),vc=new vn(it.UNMOUNTED),jf=new vn(Pr.BEFORE_RENDER),fE=new vn(Pr.RERENDER),Wf=new vn(Pr.AFTER_RENDER),Dw=(function(r){function e(t){var n;ue(this,e),n=qe(this,e),n.Element=Ot,n.inited=!1,n.context={};var i=t.container,a=t.canvas,s=t.renderer,o=t.width,A=t.height,l=t.background,c=t.cursor,u=t.supportsMutipleCanvasesInOneContainer,h=t.cleanUpOnDestroy,d=h===void 0?!0:h,f=t.offscreenCanvas,g=t.devicePixelRatio,v=t.requestAnimationFrame,p=t.cancelAnimationFrame,y=t.createImage,m=t.supportsTouchEvents,B=t.supportsPointerEvents,C=t.isTouchEvent,S=t.isMouseEvent,F=t.dblClickSpeed,T=o,O=A,_=g||Z1&&window.devicePixelRatio||1;return _=_>=1?Math.ceil(_):1,a&&(T=o||F4(a)||a.width/_,O=A||T4(a)||a.height/_),n.customElements=new qH,n.devicePixelRatio=_,n.requestAnimationFrame=v??J1.bind(de.globalThis),n.cancelAnimationFrame=p??TI.bind(de.globalThis),n.createImage=y??function(){return new window.Image},n.supportsTouchEvents=m??"ontouchstart"in de.globalThis,n.supportsPointerEvents=B??!!de.globalThis.PointerEvent,n.isTouchEvent=C??function(k){return n.supportsTouchEvents&&k instanceof de.globalThis.TouchEvent},n.isMouseEvent=S??function(k){return!de.globalThis.MouseEvent||k instanceof de.globalThis.MouseEvent&&(!n.supportsPointerEvents||!(k instanceof de.globalThis.PointerEvent))},f&&(de.offscreenCanvas=f),n.document=new kI,n.document.defaultView=n,u||E4(i,n,d),n.initRenderingContext(De(De({},t),{},{width:T,height:O,background:l??"transparent",cursor:c??"default",cleanUpOnDestroy:d,devicePixelRatio:_,requestAnimationFrame:n.requestAnimationFrame,cancelAnimationFrame:n.cancelAnimationFrame,createImage:n.createImage,supportsTouchEvents:n.supportsTouchEvents,supportsPointerEvents:n.supportsPointerEvents,isTouchEvent:n.isTouchEvent,isMouseEvent:n.isMouseEvent,dblClickSpeed:F??200})),n.initDefaultCamera(T,O,s.clipSpaceNearZ),n.initRenderer(s,!0),n}return $e(e,r),he(e,[{key:"initRenderingContext",value:function(n){this.context.config=n,this.context.renderingContext={root:this.document.documentElement,unculledEntities:[],renderListCurrentFrame:[],renderReasons:new Set,force:!1,dirty:!1}}},{key:"initDefaultCamera",value:function(n,i,a){var s=this,o=new de.CameraContribution;o.clipSpaceNearZ=a,o.setType(mt.EXPLORING,Tw.DEFAULT).setPosition(n/2,i/2,dE).setFocalPoint(n/2,i/2,0).setOrthographic(n/-2,n/2,i/2,i/-2,ZH,JH),o.canvas=this,o.eventEmitter.on(rI.UPDATED,function(){s.context.renderingContext.renderReasons.add(Po.CAMERA_CHANGED),de.enableSizeAttenuation&&s.getConfig().renderer.getConfig().enableSizeAttenuation&&s.updateSizeAttenuation()}),this.context.camera=o}},{key:"updateSizeAttenuation",value:function(){var n=this.getCamera().getZoom();this.document.documentElement.forEach(function(i){de.styleValueRegistry.updateSizeAttenuation(i,n)})}},{key:"getConfig",value:function(){return this.context.config}},{key:"getRoot",value:function(){return this.document.documentElement}},{key:"getCamera",value:function(){return this.context.camera}},{key:"getContextService",value:function(){return this.context.contextService}},{key:"getEventService",value:function(){return this.context.eventService}},{key:"getRenderingService",value:function(){return this.context.renderingService}},{key:"getRenderingContext",value:function(){return this.context.renderingContext}},{key:"getStats",value:function(){return this.getRenderingService().getStats()}},{key:"ready",get:function(){var n=this;return this.readyPromise||(this.readyPromise=new Promise(function(i){n.resolveReadyPromise=function(){i(n)}}),this.inited&&this.resolveReadyPromise()),this.readyPromise}},{key:"destroy",value:function(){var n,i=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!0,a=arguments.length>1?arguments[1]:void 0;hn.clearCache();var s=((n=this.getConfig().future)===null||n===void 0?void 0:n.experimentalCancelEventPropagation)===!0;a||this.dispatchEvent(new vn(Pr.BEFORE_DESTROY),s,s),this.frameId&&this.cancelAnimationFrame(this.frameId);var o=this.getRoot();i&&(this.unmountChildren(o),this.document.destroy(),this.getEventService().destroy()),this.getRenderingService().destroy(),this.getContextService().destroy(),a||this.dispatchEvent(new vn(Pr.AFTER_DESTROY),s,s);var A=function(c){c.currentTarget=null,c.manager=null,c.target=null,c.relatedNode=null};A(gc),A(vc),A(jf),A(fE),A(Wf),A(Li),A(Pw),A(Rw),A(II),de.textService.clearCache()}},{key:"changeSize",value:function(n,i){this.resize(n,i)}},{key:"resize",value:function(n,i){var a,s=this.context.config;s.width=n,s.height=i,this.getContextService().resize(n,i);var o=this.context.camera,A=o.getProjectionMode();o.setPosition(n/2,i/2,dE).setFocalPoint(n/2,i/2,0),A===$r.ORTHOGRAPHIC?o.setOrthographic(n/-2,n/2,i/2,i/-2,o.getNear(),o.getFar()):o.setAspect(n/i);var l=((a=s.future)===null||a===void 0?void 0:a.experimentalCancelEventPropagation)===!0;this.dispatchEvent(new vn(Pr.RESIZE,{width:n,height:i}),l,l)}},{key:"appendChild",value:function(n,i){return this.document.documentElement.appendChild(n,i)}},{key:"insertBefore",value:function(n,i){return this.document.documentElement.insertBefore(n,i)}},{key:"removeChild",value:function(n){return this.document.documentElement.removeChild(n)}},{key:"removeChildren",value:function(){this.document.documentElement.removeChildren()}},{key:"destroyChildren",value:function(){this.document.documentElement.destroyChildren()}},{key:"render",value:function(n){var i,a=this;n&&(jf.detail=n,Wf.detail=n);var s=((i=this.getConfig().future)===null||i===void 0?void 0:i.experimentalCancelEventPropagation)===!0;this.dispatchEvent(jf,s,s);var o=this.getRenderingService();o.render(this,n,function(){a.dispatchEvent(fE,s,s)}),this.dispatchEvent(Wf,s,s)}},{key:"run",value:function(){var n=this,i=function(s,o){n.render(o),n.frameId=n.requestAnimationFrame(i)};i()}},{key:"initRenderer",value:function(n){var i=this,a=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1;if(!n)throw new Error("Renderer is required.");this.inited=!1,this.readyPromise=void 0,this.context.renderingPlugins=[],this.context.renderingPlugins.push(new QI,new NI,new LI([new XH])),this.loadRendererContainerModule(n),this.context.contextService=new this.context.ContextService(De(De({},de),this.context)),this.context.renderingService=new lH(de,this.context),this.context.eventService=new AH(de,this.context),this.context.eventService.init(),this.context.contextService.init?(this.context.contextService.init(),this.initRenderingService(n,a,!0)):this.context.contextService.initAsync().then(function(){i.initRenderingService(n,a)}).catch(function(s){console.error(s)})}},{key:"initRenderingService",value:function(n){var i=this,a=arguments.length>1&&arguments[1]!==void 0?arguments[1]:!1,s=arguments.length>2&&arguments[2]!==void 0?arguments[2]:!1;this.context.renderingService.init(function(){var o;i.inited=!0;var A=((o=i.getConfig().future)===null||o===void 0?void 0:o.experimentalCancelEventPropagation)===!0;a?s?i.requestAnimationFrame(function(){i.dispatchEvent(new vn(Pr.READY),A,A)}):i.dispatchEvent(new vn(Pr.READY),A,A):i.dispatchEvent(new vn(Pr.RENDERER_CHANGED),A,A),i.readyPromise&&i.resolveReadyPromise(),a||i.getRoot().forEach(function(l){var c,u;(c=(u=l).dirty)===null||c===void 0||c.call(u,!0,!0)}),i.mountChildren(i.getRoot()),n.getConfig().enableAutoRendering&&i.run()})}},{key:"loadRendererContainerModule",value:function(n){var i=this,a=n.getPlugins();a.forEach(function(s){s.context=i.context,s.init(de)})}},{key:"setRenderer",value:function(n){var i=this.getConfig();if(i.renderer!==n){var a=i.renderer;i.renderer=n,this.destroy(!1,!0),tt((a==null?void 0:a.getPlugins())||[]).reverse().forEach(function(s){s.destroy(de)}),this.initRenderer(n)}}},{key:"setCursor",value:function(n){var i=this.getConfig();i.cursor=n,this.getContextService().applyCursorStyle(n)}},{key:"unmountChildren",value:function(n){var i=this;if(n.childNodes.forEach(function(o){i.unmountChildren(o)}),this.inited){if(n.isMutationObserved)n.dispatchEvent(vc);else{var a,s=((a=this.getConfig().future)===null||a===void 0?void 0:a.experimentalCancelEventPropagation)===!0;vc.target=n,this.dispatchEvent(vc,!0,s)}n!==this.document.documentElement&&(n.ownerDocument=null),n.isConnected=!1}n.isCustomElement&&n.disconnectedCallback&&n.disconnectedCallback()}},{key:"mountChildren",value:function(n){var i=this,a=arguments.length>1&&arguments[1]!==void 0?arguments[1]:rh(n);if(this.inited){if(!n.isConnected&&(n.ownerDocument=this.document,n.isConnected=!0,!a))if(n.isMutationObserved)n.dispatchEvent(gc);else{var s,o=((s=this.getConfig().future)===null||s===void 0?void 0:s.experimentalCancelEventPropagation)===!0;gc.target=n,this.dispatchEvent(gc,!0,o)}}else console.warn("[g]: You are trying to call `canvas.appendChild` before canvas' initialization finished. You can either await `canvas.ready` or listen to `CanvasEvent.READY` manually.","appended child: ",n.nodeName);n.childNodes.forEach(function(A){i.mountChildren(A,a)}),n.isCustomElement&&n.connectedCallback&&n.connectedCallback()}},{key:"mountFragment",value:function(n){this.mountChildren(n,!1)}},{key:"client2Viewport",value:function(n){return this.getEventService().client2Viewport(n)}},{key:"viewport2Client",value:function(n){return this.getEventService().viewport2Client(n)}},{key:"viewport2Canvas",value:function(n){return this.getEventService().viewport2Canvas(n)}},{key:"canvas2Viewport",value:function(n){return this.getEventService().canvas2Viewport(n)}},{key:"getPointByClient",value:function(n,i){return this.client2Viewport({x:n,y:i})}},{key:"getClientByPoint",value:function(n,i){return this.viewport2Client({x:n,y:i})}}])})(_I),e6=(function(){function r(){ue(this,r),this.cacheStore=new Map}return he(r,[{key:"onRefAdded",value:function(t){}},{key:"has",value:function(t){return this.cacheStore.has(t)}},{key:"put",value:function(t,n,i){return this.cacheStore.has(t)?!1:(this.cacheStore.set(t,{value:n,counter:new Set([i.entity])}),this.onRefAdded(i),!0)}},{key:"get",value:function(t,n){var i=this.cacheStore.get(t);return i?(i.counter.has(n.entity)||(i.counter.add(n.entity),this.onRefAdded(n)),i.value):null}},{key:"update",value:function(t,n,i){var a=this.cacheStore.get(t);return a?(a.value=De(De({},a.value),n),a.counter.has(i.entity)||(a.counter.add(i.entity),this.onRefAdded(i)),!0):!1}},{key:"release",value:function(t,n){var i=this.cacheStore.get(t);return i?(i.counter.delete(n.entity),i.counter.size<=0&&this.cacheStore.delete(t),!0):!1}},{key:"releaseRef",value:function(t){var n=this;Array.from(this.cacheStore.keys()).forEach(function(i){n.release(i,t)})}},{key:"getSize",value:function(){return this.cacheStore.size}},{key:"clear",value:function(){this.cacheStore.clear()}}])})(),qf=[],$f=[],Hw=(function(){function r(){ue(this,r)}return he(r,null,[{key:"stop",value:function(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:r.api;r.rafId&&(t.cancelAnimationFrame(r.rafId),r.rafId=null)}},{key:"executeTask",value:function(){var t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:r.api;qf.length<=0&&$f.length<=0||($f.forEach(function(n){return n()}),$f=qf.splice(0,r.TASK_NUM_PER_FRAME),r.rafId=t.requestAnimationFrame(function(){r.executeTask(t)}))}},{key:"sliceImage",value:function(t,n,i,a){for(var s=arguments.length>4&&arguments[4]!==void 0?arguments[4]:0,o=arguments.length>5&&arguments[5]!==void 0?arguments[5]:r.api,A=t.naturalWidth||t.width,l=t.naturalHeight||t.height,c=n-s,u=i-s,h=Math.ceil(A/c),d=Math.ceil(l/u),f={tileSize:[n,i],gridSize:[d,h],tiles:Array(d).fill(null).map(function(){return Array(h).fill(null)})},g=function(y){for(var m=function(S){qf.push(function(){var F=S*c,T=y*u,O=[Math.min(n,A-F),Math.min(i,l-T)],_=O[0],k=O[1],L=o.createCanvas();L.width=n,L.height=i;var U=L.getContext("2d");U.drawImage(t,F,T,_,k,0,0,_,k),f.tiles[y][S]={x:F,y:T,tileX:S,tileY:y,data:L},a()})},B=0;B<h;B++)m(B)},v=0;v<d;v++)g(v);return r.stop(),r.executeTask(),f}}])})();Hw.TASK_NUM_PER_FRAME=10;var kr=new e6;kr.onRefAdded=function(e){var t=this;e.addEventListener(it.DESTROY,function(){t.releaseRef(e)},{once:!0})};var tB=(function(){function r(e,t){ue(this,r),this.gradientCache={},this.patternCache={},this.context=e,this.runtime=t}return he(r,[{key:"getImageSync",value:function(t,n,i){var a=At(t)?t:t.src;if(kr.has(a)){var s=kr.get(a,n);if(s.img.complete)return i==null||i(s),s}return this.getOrCreateImage(t,n).then(function(o){i==null||i(o)}).catch(function(o){console.error(o)}),null}},{key:"getOrCreateImage",value:function(t,n){var i=this,a=At(t)?t:t.src;if(!At(t)&&!kr.has(a)){var s={img:t,size:[t.naturalWidth||t.width,t.naturalHeight||t.height],tileSize:pc(t)};kr.put(a,s,n)}if(kr.has(a)){var o=kr.get(a,n);return o.img.complete?Promise.resolve(o):new Promise(function(A,l){o.img.addEventListener("load",function(){o.size=[o.img.naturalWidth||o.img.width,o.img.naturalHeight||o.img.height],o.tileSize=pc(o.img),A(o)}),o.img.addEventListener("error",function(c){l(c)})})}return new Promise(function(A,l){var c=i.context.config.createImage();if(c){var u={img:c,size:[0,0],tileSize:pc(c)};kr.put(a,u,n),c.onload=function(){u.size=[c.naturalWidth||c.width,c.naturalHeight||c.height],u.tileSize=pc(u.img),A(u)},c.onerror=function(h){l(h)},c.crossOrigin="Anonymous",c.src=a}})}},{key:"createDownSampledImage",value:(function(){var e=Ja(Gn().mark(function n(i,a){var s,o,A,l,c,u,h,d,f,g,v,p,y,m;return Gn().wrap(function(B){for(;;)switch(B.prev=B.next){case 0:return B.next=1,this.getOrCreateImage(i,a);case 1:if(s=B.sent,!(typeof s.downSamplingRate<"u")){B.next=2;break}return B.abrupt("return",s);case 2:if(o=this.context.config.enableLargeImageOptimization,A=typeof o=="boolean"?{}:o,l=A.maxDownSampledImageSize,c=l===void 0?2048:l,u=A.downSamplingRateThreshold,h=u===void 0?.5:u,d=this.runtime.globalThis.createImageBitmap,f=We(s.size,2),g=f[0],v=f[1],p=s.img,y=Math.min((c+c)/(g+v),Math.max(.01,Math.min(h,.5))),m=De(De({},s),{},{downSamplingRate:y}),kr.update(s.img.src,m,a),!d){B.next=7;break}return B.prev=3,B.next=4,d(s.img,{resizeWidth:g*y,resizeHeight:v*y});case 4:p=B.sent,B.next=6;break;case 5:B.prev=5,B.catch(3),y=1;case 6:B.next=8;break;case 7:y=1;case 8:return m=De(De({},this.getImageSync(i,a)),{},{downSampled:p,downSamplingRate:y}),kr.update(s.img.src,m,a),B.abrupt("return",m);case 9:case"end":return B.stop()}},n,this,[[3,5]])}));function t(n,i){return e.apply(this,arguments)}return t})()},{key:"createImageTiles",value:(function(){var e=Ja(Gn().mark(function n(i,a,s,o){var A,l,c,u,h;return Gn().wrap(function(d){for(;;)switch(d.prev=d.next){case 0:return d.next=1,this.getOrCreateImage(i,o);case 1:return A=d.sent,l=o.ownerDocument.defaultView,c=l.requestAnimationFrame,u=l.cancelAnimationFrame,Hw.api={requestAnimationFrame:c,cancelAnimationFrame:u,createCanvas:function(){return eB.createCanvas()}},h=De(De({},A),Hw.sliceImage(A.img,A.tileSize[0],A.tileSize[0],s)),kr.update(A.img.src,h,o),d.abrupt("return",h);case 2:case"end":return d.stop()}},n,this)}));function t(n,i,a,s){return e.apply(this,arguments)}return t})()},{key:"releaseImage",value:function(t,n){kr.release(At(t)?t:t.src,n)}},{key:"releaseImageRef",value:function(t){kr.releaseRef(t)}},{key:"getOrCreatePatternSync",value:function(t,n,i,a,s,o,A){var l=this.generatePatternKey(n);if(l&&this.patternCache[l])return this.patternCache[l];var c=n.image,u=n.repetition,h=n.transform,d,f=!1;if(At(c)){var g=this.getImageSync(c,t,A);d=g==null?void 0:g.img}else a?(d=a,f=!0):d=c;var v=d&&i.createPattern(d,u);if(v){var p;h?p=MI(wI(h),new Ot({})):p=Xa(xt()),f&&E_(p,p,[1/s,1/s,1]),v.setTransform({a:p[0],b:p[1],c:p[4],d:p[5],e:p[12]+o[0],f:p[13]+o[1]})}return l&&v&&(this.patternCache[l]=v),v}},{key:"getOrCreateGradient",value:function(t,n){var i=this.generateGradientKey(t),a=t.type,s=t.steps,o=t.min,A=t.width,l=t.height,c=t.angle,u=t.cx,h=t.cy,d=t.size;if(this.gradientCache[i])return this.gradientCache[i];var f=null;if(a===Qa.LinearGradient){var g=p3(o,A,l,c),v=g.x1,p=g.y1,y=g.x2,m=g.y2;f=n.createLinearGradient(v,p,y,m)}else if(a===Qa.RadialGradient){var B=y3(o,A,l,u,h,d),C=B.x,S=B.y,F=B.r;f=n.createRadialGradient(C,S,0,C,S,F)}return f&&(s.forEach(function(T){var O=T.offset,_=T.color;if(O.unit===we.kPercentage){var k;(k=f)===null||k===void 0||k.addColorStop(O.value/100,_.toString())}}),this.gradientCache[i]=f),this.gradientCache[i]}},{key:"generateGradientKey",value:function(t){var n=t.type,i=t.min,a=t.width,s=t.height,o=t.steps,A=t.angle,l=t.cx,c=t.cy,u=t.size;return"gradient-".concat(n,"-").concat((A==null?void 0:A.toString())||0,"-").concat((l==null?void 0:l.toString())||0,"-").concat((c==null?void 0:c.toString())||0,"-").concat((u==null?void 0:u.toString())||0,"-").concat(i[0],"-").concat(i[1],"-").concat(a,"-").concat(s,"-").concat(o.map(function(h){var d=h.offset,f=h.color;return"".concat(d).concat(f)}).join("-"))}},{key:"generatePatternKey",value:function(t){var n=t.image,i=t.repetition;if(At(n))return"pattern-".concat(n,"-").concat(i);if(n.nodeName==="rect")return"pattern-".concat(n.entity,"-").concat(i)}}])})();tB.isSupportTile=!!eB.createCanvas();function pc(r){if(!r.complete)return[0,0];var e=r.naturalWidth||r.width,t=r.naturalHeight||r.height,n=256;return[256,512].forEach(function(i){var a=Math.ceil(t/i),s=Math.ceil(e/i);a*s<1e3&&(n=i)}),[n,n]}var UI=(function(){function r(){ue(this,r)}return he(r,[{key:"apply",value:function(t){var n=t.renderingService,i=t.renderingContext,a=t.imagePool,s=i.root.ownerDocument.defaultView,o=function(u,h,d){var f=u.parsedStyle,g=f.width,v=f.height;g&&!v?u.setAttribute("height",d/h*g):!g&&v&&u.setAttribute("width",h/d*v)},A=function(u){var h=u.target,d=h.nodeName,f=h.attributes;if(d===ae.IMAGE){var g=f.src,v=f.keepAspectRatio;a.getImageSync(g,h,function(p){var y=p.img,m=y.width,B=y.height;v&&o(h,m,B),h.dirty(),n.dirty()})}},l=function(u){var h=u.target,d=u.attrName,f=u.prevValue,g=u.newValue;h.nodeName!==ae.IMAGE||d!=="src"||(f!==g&&a.releaseImage(f,h),At(g)&&a.getOrCreateImage(g,h).then(function(v){var p=v.img,y=p.width,m=p.height;h.attributes.keepAspectRatio&&o(h,y,m),h.dirty(),n.dirty()}).catch(function(){}))};n.hooks.init.tap(r.tag,function(){s.addEventListener(it.MOUNTED,A),s.addEventListener(it.ATTR_MODIFIED,l)}),n.hooks.destroy.tap(r.tag,function(){s.removeEventListener(it.MOUNTED,A),s.removeEventListener(it.ATTR_MODIFIED,l)})}}])})();UI.tag="LoadImage";var t6=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.name="image-loader",t}return $e(e,r),he(e,[{key:"init",value:function(n){this.context.imagePool=new tB(this.context,n),this.addRenderingPlugin(new UI)}},{key:"destroy",value:function(){this.removeAllRenderingPlugins()}}])})(rs),n6=Object.freeze({__proto__:null,ImagePool:tB,Plugin:t6}),r6="g-canvas-camera",PI=(function(){function r(){ue(this,r),this.displayObjectHTMLElementMap=new WeakMap}return he(r,[{key:"joinTransformMatrix",value:function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[0,0,0];return"matrix(".concat([t[0],t[1],t[4],t[5],t[12]+n[0],t[13]+n[1]].join(","),")")}},{key:"apply",value:function(t,n){var i=this,a=t.camera,s=t.renderingContext,o=t.renderingService;this.context=t;var A=s.root.ownerDocument.defaultView,l=A.context.eventService.nativeHTMLMap,c=function(p,y){y.style.transform=i.joinTransformMatrix(p.getWorldTransform(),p.getOrigin())},u=function(p){var y=p.target;if(y.nodeName===ae.HTML){i.$camera||(i.$camera=i.createCamera(a));var m=i.getOrCreateEl(y);i.$camera.appendChild(m),Object.keys(y.attributes).forEach(function(B){i.updateAttribute(B,y)}),c(y,m),l.set(m,y)}},h=function(p){var y=p.target;if(y.nodeName===ae.HTML&&i.$camera){var m=i.getOrCreateEl(y);m&&(m.remove(),l.delete(m))}},d=function(p){var y=p.target;if(y.nodeName===ae.HTML){var m=p.attrName;i.updateAttribute(m,y)}},f=function(p){for(var y=p.detail,m=0;m<y.length;m++){var B=y[m],C=B.target,S=C.nodeName===ae.FRAGMENT?C.childNodes:[C];S.forEach(function(F){if(F.nodeName===ae.HTML){var T=i.getOrCreateEl(F);c(F,T)}})}},g=function(){if(i.$camera){var p=i.context.config,y=p.width,m=p.height;i.$camera.parentElement.style.width="".concat(y||0,"px"),i.$camera.parentElement.style.height="".concat(m||0,"px")}};o.hooks.init.tap(r.tag,function(){A.addEventListener(Pr.RESIZE,g),A.addEventListener(it.MOUNTED,u),A.addEventListener(it.UNMOUNTED,h),A.addEventListener(it.ATTR_MODIFIED,d),A.addEventListener(it.BOUNDS_CHANGED,f)}),o.hooks.endFrame.tap(r.tag,function(){i.$camera&&s.renderReasons.has(Po.CAMERA_CHANGED)&&(i.$camera.style.transform=i.joinTransformMatrix(a.getOrthoMatrix()))}),o.hooks.destroy.tap(r.tag,function(){i.$camera&&i.$camera.remove(),A.removeEventListener(Pr.RESIZE,g),A.removeEventListener(it.MOUNTED,u),A.removeEventListener(it.UNMOUNTED,h),A.removeEventListener(it.ATTR_MODIFIED,d),A.removeEventListener(it.BOUNDS_CHANGED,f)})}},{key:"createCamera",value:function(t){var n=this.context.config,i=n.document,a=n.width,s=n.height,o=this.context.contextService.getDomElement(),A=o.parentNode;if(A){var l=r6,c=A.querySelector("#".concat(l));if(!c){var u=(i||document).createElement("div");u.style.overflow="hidden",u.style.pointerEvents="none",u.style.position="absolute",u.style.left="0px",u.style.top="0px",u.style.width="".concat(a||0,"px"),u.style.height="".concat(s||0,"px");var h=(i||document).createElement("div");c=h,h.id=l,h.style.position="absolute",h.style.left="".concat(o.offsetLeft||0,"px"),h.style.top="".concat(o.offsetTop||0,"px"),h.style.transformOrigin="left top",h.style.transform=this.joinTransformMatrix(t.getOrthoMatrix()),h.style.pointerEvents="none",h.style.width="100%",h.style.height="100%",u.appendChild(h),A.appendChild(u)}return c}return null}},{key:"getOrCreateEl",value:function(t){var n=this.context.config.document,i=this.displayObjectHTMLElementMap.get(t);return i||(i=(n||document).createElement("div"),t.parsedStyle.$el=i,this.displayObjectHTMLElementMap.set(t,i),t.id&&(i.id=t.id),t.name&&i.setAttribute("name",t.name),t.className&&(i.className=t.className),i.style.position="absolute",i.style["will-change"]="transform",i.style.transform=this.joinTransformMatrix(t.getWorldTransform(),t.getOrigin())),i}},{key:"updateAttribute",value:function(t,n){var i=this.getOrCreateEl(n);switch(t){case"innerHTML":var a=n.parsedStyle.innerHTML;At(a)?i.innerHTML=a:(i.innerHTML="",i.appendChild(a));break;case"x":i.style.left="".concat(n.parsedStyle.x,"px");break;case"y":i.style.top="".concat(n.parsedStyle.y,"px");break;case"transformOrigin":var s=n.parsedStyle.transformOrigin;i.style["transform-origin"]="".concat(s[0].buildCSSText(null,null,"")," ").concat(s[1].buildCSSText(null,null,""));break;case"width":var o=n.parsedStyle.width;i.style.width=Be(o)?"".concat(o,"px"):o.toString();break;case"height":var A=n.parsedStyle.height;i.style.height=Be(A)?"".concat(A,"px"):A.toString();break;case"zIndex":var l=n.parsedStyle.zIndex;i.style["z-index"]="".concat(l);break;case"visibility":var c=n.parsedStyle.visibility;i.style.visibility=c;break;case"pointerEvents":var u=n.parsedStyle.pointerEvents,h=u===void 0?"auto":u;i.style.pointerEvents=h;break;case"opacity":var d=n.parsedStyle.opacity;i.style.opacity="".concat(d);break;case"fill":var f=n.parsedStyle.fill,g="";th(f)?f.isNone?g="transparent":g=n.getAttribute("fill"):Array.isArray(f)?g=n.getAttribute("fill"):Gs(f),i.style.background=g;break;case"stroke":var v=n.parsedStyle.stroke,p="";th(v)?v.isNone?p="transparent":p=n.getAttribute("stroke"):Array.isArray(v)?p=n.getAttribute("stroke"):Gs(v),i.style["border-color"]=p,i.style["border-style"]="solid";break;case"lineWidth":var y=n.parsedStyle.lineWidth;i.style["border-width"]="".concat(y||0,"px");break;case"lineDash":i.style["border-style"]="dashed";break;case"filter":var m=n.style.filter;i.style.filter=m;break;default:!ke(n.style[t])&&n.style[t]!==""&&(i.style[t]=n.style[t])}}}])})();PI.tag="HTMLRendering";var i6=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.name="html-renderer",t}return $e(e,r),he(e,[{key:"init",value:function(){this.addRenderingPlugin(new PI)}},{key:"destroy",value:function(){this.removeAllRenderingPlugins()}}])})(rs),a6=Object.freeze({__proto__:null,Plugin:i6}),RI=(function(){function r(){ue(this,r)}return he(r,[{key:"apply",value:function(t,n){var i=this,a=t.renderingService,s=t.renderingContext,o=t.config;this.context=t;var A=s.root.ownerDocument.defaultView,l=function(T){a.hooks.pointerMove.call(T)},c=function(T){a.hooks.pointerUp.call(T)},u=function(T){a.hooks.pointerDown.call(T)},h=function(T){a.hooks.pointerOver.call(T)},d=function(T){a.hooks.pointerOut.call(T)},f=function(T){a.hooks.pointerCancel.call(T)},g=function(T){a.hooks.pointerWheel.call(T)},v=function(T){a.hooks.click.call(T)},p=function(T){n.globalThis.document.addEventListener("pointermove",l,!0),T.addEventListener("pointerdown",u,!0),T.addEventListener("pointerleave",d,!0),T.addEventListener("pointerover",h,!0),n.globalThis.addEventListener("pointerup",c,!0),n.globalThis.addEventListener("pointercancel",f,!0)},y=function(T){T.addEventListener("touchstart",u,!0),T.addEventListener("touchend",c,!0),T.addEventListener("touchmove",l,!0),T.addEventListener("touchcancel",f,!0)},m=function(T){n.globalThis.document.addEventListener("mousemove",l,!0),T.addEventListener("mousedown",u,!0),T.addEventListener("mouseout",d,!0),T.addEventListener("mouseover",h,!0),n.globalThis.addEventListener("mouseup",c,!0)},B=function(T){n.globalThis.document.removeEventListener("pointermove",l,!0),T.removeEventListener("pointerdown",u,!0),T.removeEventListener("pointerleave",d,!0),T.removeEventListener("pointerover",h,!0),n.globalThis.removeEventListener("pointerup",c,!0),n.globalThis.removeEventListener("pointercancel",f,!0)},C=function(T){T.removeEventListener("touchstart",u,!0),T.removeEventListener("touchend",c,!0),T.removeEventListener("touchmove",l,!0),T.removeEventListener("touchcancel",f,!0)},S=function(T){n.globalThis.document.removeEventListener("mousemove",l,!0),T.removeEventListener("mousedown",u,!0),T.removeEventListener("mouseout",d,!0),T.removeEventListener("mouseover",h,!0),n.globalThis.removeEventListener("mouseup",c,!0)};a.hooks.init.tap(r.tag,function(){var F=i.context.contextService.getDomElement();n.globalThis.navigator.msPointerEnabled?(F.style.msContentZooming="none",F.style.msTouchAction="none"):A.supportsPointerEvents&&(F.style.touchAction="none"),A.supportsPointerEvents?p(F):m(F),A.supportsTouchEvents&&y(F),o.useNativeClickEvent&&F.addEventListener("click",v,!0),F.addEventListener("wheel",g,{passive:!0,capture:!0})}),a.hooks.destroy.tap(r.tag,function(){var F=i.context.contextService.getDomElement();n.globalThis.navigator.msPointerEnabled?(F.style.msContentZooming="",F.style.msTouchAction=""):A.supportsPointerEvents&&(F.style.touchAction=""),A.supportsPointerEvents?B(F):S(F),A.supportsTouchEvents&&C(F),o.useNativeClickEvent&&F.removeEventListener("click",v,!0),F.removeEventListener("wheel",g,!0)})}}])})();RI.tag="DOMInteraction";var s6=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.name="dom-interaction",t}return $e(e,r),he(e,[{key:"init",value:function(){this.addRenderingPlugin(new RI)}},{key:"destroy",value:function(){this.removeAllRenderingPlugins()}}])})(rs),o6=Object.freeze({__proto__:null,Plugin:s6}),A6=(function(){function r(){ue(this,r)}return he(r,[{key:"apply",value:function(t){var n=t.renderingService,i=t.contextService,a=t.config,s=i.getDomElement(),o=function(g){n.hooks.pointerDown.call(g)},A=function(g){n.hooks.pointerUp.call(g)},l=function(g){n.hooks.pointerMove.call(g)},c=function(g){n.hooks.pointerOver.call(g)},u=function(g){n.hooks.pointerOut.call(g)},h=function(g){n.hooks.click.call(g)},d=function(g){n.hooks.pointerCancel.call(g)};n.hooks.init.tap(r.tag,function(){s.addEventListener("touchstart",o,!0),s.addEventListener("touchend",A,!0),s.addEventListener("touchmove",l,!0),s.addEventListener("touchcancel",d,!0),s.addEventListener("mouseout",u,!0),s.addEventListener("mouseover",c,!0),a.useNativeClickEvent&&s.addEventListener("click",h,!0)}),n.hooks.destroy.tap(r.tag,function(){s.removeEventListener("touchstart",o,!0),s.removeEventListener("touchend",A,!0),s.removeEventListener("touchmove",l,!0),s.removeEventListener("touchcancel",d,!0),s.removeEventListener("mouseout",u,!0),s.removeEventListener("mouseover",c,!0),a.useNativeClickEvent&&s.removeEventListener("click",h,!0)})}}])})();A6.tag="MobileInteraction";var Gw=function(r,e){return Gw=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,n){t.__proto__=n}||function(t,n){for(var i in n)Object.prototype.hasOwnProperty.call(n,i)&&(t[i]=n[i])},Gw(r,e)};function Ei(r,e){if(typeof e!="function"&&e!==null)throw new TypeError("Class extends value "+String(e)+" is not a constructor or null");Gw(r,e);function t(){this.constructor=r}r.prototype=e===null?Object.create(e):(t.prototype=e.prototype,new t)}function Yr(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,[])).next())})}function Lr(r,e){var t={label:0,sent:function(){if(a[0]&1)throw a[1];return a[1]},trys:[],ops:[]},n,i,a,s;return s={next:o(0),throw:o(1),return:o(2)},typeof Symbol=="function"&&(s[Symbol.iterator]=function(){return this}),s;function o(l){return function(c){return A([l,c])}}function A(l){if(n)throw new TypeError("Generator is already executing.");for(;t;)try{if(n=1,i&&(a=l[0]&2?i.return:l[0]?i.throw||((a=i.return)&&a.call(i),0):i.next)&&!(a=a.call(i,l[1])).done)return a;switch(i=0,a&&(l=[l[0]&2,a.value]),l[0]){case 0:case 1:a=l;break;case 4:return t.label++,{value:l[1],done:!1};case 5:t.label++,i=l[1],l=[0];continue;case 7:l=t.ops.pop(),t.trys.pop();continue;default:if(a=t.trys,!(a=a.length>0&&a[a.length-1])&&(l[0]===6||l[0]===2)){t=0;continue}if(l[0]===3&&(!a||l[1]>a[0]&&l[1]<a[3])){t.label=l[1];break}if(l[0]===6&&t.label<a[1]){t.label=a[1],a=l;break}if(a&&t.label<a[2]){t.label=a[2],t.ops.push(l);break}a[2]&&t.ops.pop(),t.trys.pop();continue}l=e.call(r,t)}catch(c){l=[6,c],i=0}finally{n=a=0}if(l[0]&5)throw l[1];return{value:l[0]?l[1]:void 0,done:!0}}}var zs=(function(){function r(e,t,n,i){this.left=e,this.top=t,this.width=n,this.height=i}return r.prototype.add=function(e,t,n,i){return new r(this.left+e,this.top+t,this.width+n,this.height+i)},r.fromClientRect=function(e,t){return new r(t.left+e.windowBounds.left,t.top+e.windowBounds.top,t.width,t.height)},r.fromDOMRectList=function(e,t){var n=Array.from(t).find(function(i){return i.width!==0});return n?new r(n.left+e.windowBounds.left,n.top+e.windowBounds.top,n.width,n.height):r.EMPTY},r.EMPTY=new r(0,0,0,0),r})(),nB=function(r,e){return zs.fromClientRect(r,e.getBoundingClientRect())},Hh=function(r){for(var e=[],t=0,n=r.length;t<n;){var i=r.charCodeAt(t++);if(i>=55296&&i<=56319&&t<n){var a=r.charCodeAt(t++);(a&64512)===56320?e.push(((i&1023)<<10)+(a&1023)+65536):(e.push(i),t--)}else e.push(i)}return e},cn=function(){for(var r=[],e=0;e<arguments.length;e++)r[e]=arguments[e];if(String.fromCodePoint)return String.fromCodePoint.apply(String,r);var t=r.length;if(!t)return"";for(var n=[],i=-1,a="";++i<t;){var s=r[i];s<=65535?n.push(s):(s-=65536,n.push((s>>10)+55296,s%1024+56320)),(i+1===t||n.length>16384)&&(a+=String.fromCharCode.apply(String,n),n.length=0)}return a},gE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",l6=typeof Uint8Array>"u"?[]:new Uint8Array(256);for(var yc=0;yc<gE.length;yc++)l6[gE.charCodeAt(yc)]=yc;var vE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",OA=typeof Uint8Array>"u"?[]:new Uint8Array(256);for(var mc=0;mc<vE.length;mc++)OA[vE.charCodeAt(mc)]=mc;var c6=function(r){var e=r.length*.75,t=r.length,n,i=0,a,s,o,A;r[r.length-1]==="="&&(e--,r[r.length-2]==="="&&e--);var l=typeof ArrayBuffer<"u"&&typeof Uint8Array<"u"&&typeof Uint8Array.prototype.slice<"u"?new ArrayBuffer(e):new Array(e),c=Array.isArray(l)?l:new Uint8Array(l);for(n=0;n<t;n+=4)a=OA[r.charCodeAt(n)],s=OA[r.charCodeAt(n+1)],o=OA[r.charCodeAt(n+2)],A=OA[r.charCodeAt(n+3)],c[i++]=a<<2|s>>4,c[i++]=(s&15)<<4|o>>2,c[i++]=(o&3)<<6|A&63;return l},u6=function(r){for(var e=r.length,t=[],n=0;n<e;n+=2)t.push(r[n+1]<<8|r[n]);return t},h6=function(r){for(var e=r.length,t=[],n=0;n<e;n+=4)t.push(r[n+3]<<24|r[n+2]<<16|r[n+1]<<8|r[n]);return t},ks=5,rB=11,Yf=2,d6=rB-ks,DI=65536>>ks,f6=1<<ks,Xf=f6-1,g6=1024>>ks,v6=DI+g6,p6=v6,y6=32,m6=p6+y6,w6=65536>>rB,B6=1<<d6,b6=B6-1,pE=function(r,e,t){return r.slice?r.slice(e,t):new Uint16Array(Array.prototype.slice.call(r,e,t))},E6=function(r,e,t){return r.slice?r.slice(e,t):new Uint32Array(Array.prototype.slice.call(r,e,t))},x6=function(r,e){var t=c6(r),n=Array.isArray(t)?h6(t):new Uint32Array(t),i=Array.isArray(t)?u6(t):new Uint16Array(t),a=24,s=pE(i,a/2,n[4]/2),o=n[5]===2?pE(i,(a+n[4])/2):E6(n,Math.ceil((a+n[4])/4));return new C6(n[0],n[1],n[2],n[3],s,o)},C6=(function(){function r(e,t,n,i,a,s){this.initialValue=e,this.errorValue=t,this.highStart=n,this.highValueIndex=i,this.index=a,this.data=s}return r.prototype.get=function(e){var t;if(e>=0){if(e<55296||e>56319&&e<=65535)return t=this.index[e>>ks],t=(t<<Yf)+(e&Xf),this.data[t];if(e<=65535)return t=this.index[DI+(e-55296>>ks)],t=(t<<Yf)+(e&Xf),this.data[t];if(e<this.highStart)return t=m6-w6+(e>>rB),t=this.index[t],t+=e>>ks&b6,t=this.index[t],t=(t<<Yf)+(e&Xf),this.data[t];if(e<=1114111)return this.data[this.highValueIndex]}return this.errorValue},r})(),yE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",S6=typeof Uint8Array>"u"?[]:new Uint8Array(256);for(var wc=0;wc<yE.length;wc++)S6[yE.charCodeAt(wc)]=wc;var F6="KwAAAAAAAAAACA4AUD0AADAgAAACAAAAAAAIABAAGABAAEgAUABYAGAAaABgAGgAYgBqAF8AZwBgAGgAcQB5AHUAfQCFAI0AlQCdAKIAqgCyALoAYABoAGAAaABgAGgAwgDKAGAAaADGAM4A0wDbAOEA6QDxAPkAAQEJAQ8BFwF1AH0AHAEkASwBNAE6AUIBQQFJAVEBWQFhAWgBcAF4ATAAgAGGAY4BlQGXAZ8BpwGvAbUBvQHFAc0B0wHbAeMB6wHxAfkBAQIJAvEBEQIZAiECKQIxAjgCQAJGAk4CVgJeAmQCbAJ0AnwCgQKJApECmQKgAqgCsAK4ArwCxAIwAMwC0wLbAjAA4wLrAvMC+AIAAwcDDwMwABcDHQMlAy0DNQN1AD0DQQNJA0kDSQNRA1EDVwNZA1kDdQB1AGEDdQBpA20DdQN1AHsDdQCBA4kDkQN1AHUAmQOhA3UAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AKYDrgN1AHUAtgO+A8YDzgPWAxcD3gPjA+sD8wN1AHUA+wMDBAkEdQANBBUEHQQlBCoEFwMyBDgEYABABBcDSARQBFgEYARoBDAAcAQzAXgEgASIBJAEdQCXBHUAnwSnBK4EtgS6BMIEyAR1AHUAdQB1AHUAdQCVANAEYABgAGAAYABgAGAAYABgANgEYADcBOQEYADsBPQE/AQEBQwFFAUcBSQFLAU0BWQEPAVEBUsFUwVbBWAAYgVgAGoFcgV6BYIFigWRBWAAmQWfBaYFYABgAGAAYABgAKoFYACxBbAFuQW6BcEFwQXHBcEFwQXPBdMF2wXjBeoF8gX6BQIGCgYSBhoGIgYqBjIGOgZgAD4GRgZMBmAAUwZaBmAAYABgAGAAYABgAGAAYABgAGAAYABgAGIGYABpBnAGYABgAGAAYABgAGAAYABgAGAAYAB4Bn8GhQZgAGAAYAB1AHcDFQSLBmAAYABgAJMGdQA9A3UAmwajBqsGqwaVALMGuwbDBjAAywbSBtIG1QbSBtIG0gbSBtIG0gbdBuMG6wbzBvsGAwcLBxMHAwcbByMHJwcsBywHMQcsB9IGOAdAB0gHTgfSBkgHVgfSBtIG0gbSBtIG0gbSBtIG0gbSBiwHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAdgAGAALAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAdbB2MHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsB2kH0gZwB64EdQB1AHUAdQB1AHUAdQB1AHUHfQdgAIUHjQd1AHUAlQedB2AAYAClB6sHYACzB7YHvgfGB3UAzgfWBzMB3gfmB1EB7gf1B/0HlQENAQUIDQh1ABUIHQglCBcDLQg1CD0IRQhNCEEDUwh1AHUAdQBbCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIaQhjCGQIZQhmCGcIaAhpCGMIZAhlCGYIZwhoCGkIYwhkCGUIZghnCGgIcAh3CHoIMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwAIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIgggwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAALAcsBywHLAcsBywHLAcsBywHLAcsB4oILAcsB44I0gaWCJ4Ipgh1AHUAqgiyCHUAdQB1AHUAdQB1AHUAdQB1AHUAtwh8AXUAvwh1AMUIyQjRCNkI4AjoCHUAdQB1AO4I9gj+CAYJDgkTCS0HGwkjCYIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiCCIIIggiAAIAAAAFAAYABgAGIAXwBgAHEAdQBFAJUAogCyAKAAYABgAEIA4ABGANMA4QDxAMEBDwE1AFwBLAE6AQEBUQF4QkhCmEKoQrhCgAHIQsAB0MLAAcABwAHAAeDC6ABoAHDCwMMAAcABwAHAAdDDGMMAAcAB6MM4wwjDWMNow3jDaABoAGgAaABoAGgAaABoAGgAaABoAGgAaABoAGgAaABoAGgAaABoAEjDqABWw6bDqABpg6gAaABoAHcDvwOPA+gAaABfA/8DvwO/A78DvwO/A78DvwO/A78DvwO/A78DvwO/A78DvwO/A78DvwO/A78DvwO/A78DvwO/A78DpcPAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcAB9cPKwkyCToJMAB1AHUAdQBCCUoJTQl1AFUJXAljCWcJawkwADAAMAAwAHMJdQB2CX4JdQCECYoJjgmWCXUAngkwAGAAYABxAHUApgn3A64JtAl1ALkJdQDACTAAMAAwADAAdQB1AHUAdQB1AHUAdQB1AHUAowYNBMUIMAAwADAAMADICcsJ0wnZCRUE4QkwAOkJ8An4CTAAMAB1AAAKvwh1AAgKDwoXCh8KdQAwACcKLgp1ADYKqAmICT4KRgowADAAdQB1AE4KMAB1AFYKdQBeCnUAZQowADAAMAAwADAAMAAwADAAMAAVBHUAbQowADAAdQC5CXUKMAAwAHwBxAijBogEMgF9CoQKiASMCpQKmgqIBKIKqgquCogEDQG2Cr4KxgrLCjAAMADTCtsKCgHjCusK8Qr5CgELMAAwADAAMAB1AIsECQsRC3UANAEZCzAAMAAwADAAMAB1ACELKQswAHUANAExCzkLdQBBC0kLMABRC1kLMAAwADAAMAAwADAAdQBhCzAAMAAwAGAAYABpC3ELdwt/CzAAMACHC4sLkwubC58Lpwt1AK4Ltgt1APsDMAAwADAAMAAwADAAMAAwAL4LwwvLC9IL1wvdCzAAMADlC+kL8Qv5C/8LSQswADAAMAAwADAAMAAwADAAMAAHDDAAMAAwADAAMAAODBYMHgx1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1ACYMMAAwADAAdQB1AHUALgx1AHUAdQB1AHUAdQA2DDAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwAHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AD4MdQBGDHUAdQB1AHUAdQB1AEkMdQB1AHUAdQB1AFAMMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwAHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQBYDHUAdQB1AF8MMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUA+wMVBGcMMAAwAHwBbwx1AHcMfwyHDI8MMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAYABgAJcMMAAwADAAdQB1AJ8MlQClDDAAMACtDCwHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsB7UMLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHdQB1AHUAdQB1AHUAdQB1AHUAdQB1AHUAdQB1AA0EMAC9DDAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAsBywHLAcsBywHLAcsBywHLQcwAMEMyAwsBywHLAcsBywHLAcsBywHLAcsBywHzAwwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwAHUAdQB1ANQM2QzhDDAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMABgAGAAYABgAGAAYABgAOkMYADxDGAA+AwADQYNYABhCWAAYAAODTAAMAAwADAAFg1gAGAAHg37AzAAMAAwADAAYABgACYNYAAsDTQNPA1gAEMNPg1LDWAAYABgAGAAYABgAGAAYABgAGAAUg1aDYsGVglhDV0NcQBnDW0NdQ15DWAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAlQCBDZUAiA2PDZcNMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAnw2nDTAAMAAwADAAMAAwAHUArw23DTAAMAAwADAAMAAwADAAMAAwADAAMAB1AL8NMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAB1AHUAdQB1AHUAdQDHDTAAYABgAM8NMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAA1w11ANwNMAAwAD0B5A0wADAAMAAwADAAMADsDfQN/A0EDgwOFA4wABsOMAAwADAAMAAwADAAMAAwANIG0gbSBtIG0gbSBtIG0gYjDigOwQUuDsEFMw7SBjoO0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIGQg5KDlIOVg7SBtIGXg5lDm0OdQ7SBtIGfQ6EDooOjQ6UDtIGmg6hDtIG0gaoDqwO0ga0DrwO0gZgAGAAYADEDmAAYAAkBtIGzA5gANIOYADaDokO0gbSBt8O5w7SBu8O0gb1DvwO0gZgAGAAxA7SBtIG0gbSBtIGYABgAGAAYAAED2AAsAUMD9IG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIGFA8sBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAccD9IGLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHJA8sBywHLAcsBywHLAccDywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywPLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAc0D9IG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIGLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAccD9IG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIGFA8sBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHLAcsBywHPA/SBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gbSBtIG0gYUD0QPlQCVAJUAMAAwADAAMACVAJUAlQCVAJUAlQCVAEwPMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAA//8EAAQABAAEAAQABAAEAAQABAANAAMAAQABAAIABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQACgATABcAHgAbABoAHgAXABYAEgAeABsAGAAPABgAHABLAEsASwBLAEsASwBLAEsASwBLABgAGAAeAB4AHgATAB4AUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQABYAGwASAB4AHgAeAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAWAA0AEQAeAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAAQABAAEAAQABAAFAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAJABYAGgAbABsAGwAeAB0AHQAeAE8AFwAeAA0AHgAeABoAGwBPAE8ADgBQAB0AHQAdAE8ATwAXAE8ATwBPABYAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAB0AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAdAFAAUABQAFAAUABQAFAAUAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAFAAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAeAB4AHgAeAFAATwBAAE8ATwBPAEAATwBQAFAATwBQAB4AHgAeAB4AHgAeAB0AHQAdAB0AHgAdAB4ADgBQAFAAUABQAFAAHgAeAB4AHgAeAB4AHgBQAB4AUAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4ABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAJAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAkACQAJAAkACQAJAAkABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAeAB4AHgAeAFAAHgAeAB4AKwArAFAAUABQAFAAGABQACsAKwArACsAHgAeAFAAHgBQAFAAUAArAFAAKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4ABAAEAAQABAAEAAQABAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAUAAeAB4AHgAeAB4AHgBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAYAA0AKwArAB4AHgAbACsABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQADQAEAB4ABAAEAB4ABAAEABMABAArACsAKwArACsAKwArACsAVgBWAFYAVgBWAFYAVgBWAFYAVgBWAFYAVgBWAFYAVgBWAFYAVgBWAFYAVgBWAFYAVgBWAFYAKwArACsAKwBWAFYAVgBWAB4AHgArACsAKwArACsAKwArACsAKwArACsAHgAeAB4AHgAeAB4AHgAeAB4AGgAaABoAGAAYAB4AHgAEAAQABAAEAAQABAAEAAQABAAEAAQAEwAEACsAEwATAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABABLAEsASwBLAEsASwBLAEsASwBLABoAGQAZAB4AUABQAAQAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQABMAUAAEAAQABAAEAAQABAAEAB4AHgAEAAQABAAEAAQABABQAFAABAAEAB4ABAAEAAQABABQAFAASwBLAEsASwBLAEsASwBLAEsASwBQAFAAUAAeAB4AUAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwAeAFAABABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAAEAAQABAAEAFAAKwArACsAKwArACsAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAAEAAQAUABQAB4AHgAYABMAUAArACsABAAbABsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAFAABAAEAAQABAAEAFAABAAEAAQAUAAEAAQABAAEAAQAKwArAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAArACsAHgArAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAKwArACsAKwArACsAKwArAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAB4ABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAEAFAABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAUAAEAAQABAAEAAQABAAEAFAAUABQAFAAUABQAFAAUABQAFAABAAEAA0ADQBLAEsASwBLAEsASwBLAEsASwBLAB4AUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAArAFAAUABQAFAAUABQAFAAUAArACsAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQACsAUAArACsAKwBQAFAAUABQACsAKwAEAFAABAAEAAQABAAEAAQABAArACsABAAEACsAKwAEAAQABABQACsAKwArACsAKwArACsAKwAEACsAKwArACsAUABQACsAUABQAFAABAAEACsAKwBLAEsASwBLAEsASwBLAEsASwBLAFAAUAAaABoAUABQAFAAUABQAEwAHgAbAFAAHgAEACsAKwAEAAQABAArAFAAUABQAFAAUABQACsAKwArACsAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQACsAUABQACsAUABQACsAUABQACsAKwAEACsABAAEAAQABAAEACsAKwArACsABAAEACsAKwAEAAQABAArACsAKwAEACsAKwArACsAKwArACsAUABQAFAAUAArAFAAKwArACsAKwArACsAKwBLAEsASwBLAEsASwBLAEsASwBLAAQABABQAFAAUAAEAB4AKwArACsAKwArACsAKwArACsAKwAEAAQABAArAFAAUABQAFAAUABQAFAAUABQACsAUABQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQACsAUABQACsAUABQAFAAUABQACsAKwAEAFAABAAEAAQABAAEAAQABAAEACsABAAEAAQAKwAEAAQABAArACsAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwBQAFAABAAEACsAKwBLAEsASwBLAEsASwBLAEsASwBLAB4AGwArACsAKwArACsAKwArAFAABAAEAAQABAAEAAQAKwAEAAQABAArAFAAUABQAFAAUABQAFAAUAArACsAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAEAAQABAArACsABAAEACsAKwAEAAQABAArACsAKwArACsAKwArAAQABAAEACsAKwArACsAUABQACsAUABQAFAABAAEACsAKwBLAEsASwBLAEsASwBLAEsASwBLAB4AUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArAAQAUAArAFAAUABQAFAAUABQACsAKwArAFAAUABQACsAUABQAFAAUAArACsAKwBQAFAAKwBQACsAUABQACsAKwArAFAAUAArACsAKwBQAFAAUAArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArAAQABAAEAAQABAArACsAKwAEAAQABAArAAQABAAEAAQAKwArAFAAKwArACsAKwArACsABAArACsAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAUABQAFAAHgAeAB4AHgAeAB4AGwAeACsAKwArACsAKwAEAAQABAAEAAQAUABQAFAAUABQAFAAUABQACsAUABQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAUAAEAAQABAAEAAQABAAEACsABAAEAAQAKwAEAAQABAAEACsAKwArACsAKwArACsABAAEACsAUABQAFAAKwArACsAKwArAFAAUAAEAAQAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAKwAOAFAAUABQAFAAUABQAFAAHgBQAAQABAAEAA4AUABQAFAAUABQAFAAUABQACsAUABQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAKwArAAQAUAAEAAQABAAEAAQABAAEACsABAAEAAQAKwAEAAQABAAEACsAKwArACsAKwArACsABAAEACsAKwArACsAKwArACsAUAArAFAAUAAEAAQAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwBQAFAAKwArACsAKwArACsAKwArACsAKwArACsAKwAEAAQABAAEAFAAUABQAFAAUABQAFAAUABQACsAUABQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAFAABAAEAAQABAAEAAQABAArAAQABAAEACsABAAEAAQABABQAB4AKwArACsAKwBQAFAAUAAEAFAAUABQAFAAUABQAFAAUABQAFAABAAEACsAKwBLAEsASwBLAEsASwBLAEsASwBLAFAAUABQAFAAUABQAFAAUABQABoAUABQAFAAUABQAFAAKwAEAAQABAArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAUABQACsAUAArACsAUABQAFAAUABQAFAAUAArACsAKwAEACsAKwArACsABAAEAAQABAAEAAQAKwAEACsABAAEAAQABAAEAAQABAAEACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArAAQABAAeACsAKwArACsAKwArACsAKwArACsAKwArAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXAAqAFwAXAAqACoAKgAqACoAKgAqACsAKwArACsAGwBcAFwAXABcAFwAXABcACoAKgAqACoAKgAqACoAKgAeAEsASwBLAEsASwBLAEsASwBLAEsADQANACsAKwArACsAKwBcAFwAKwBcACsAXABcAFwAXABcACsAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcACsAXAArAFwAXABcAFwAXABcAFwAXABcAFwAKgBcAFwAKgAqACoAKgAqACoAKgAqACoAXAArACsAXABcAFwAXABcACsAXAArACoAKgAqACoAKgAqACsAKwBLAEsASwBLAEsASwBLAEsASwBLACsAKwBcAFwAXABcAFAADgAOAA4ADgAeAA4ADgAJAA4ADgANAAkAEwATABMAEwATAAkAHgATAB4AHgAeAAQABAAeAB4AHgAeAB4AHgBLAEsASwBLAEsASwBLAEsASwBLAFAAUABQAFAAUABQAFAAUABQAFAADQAEAB4ABAAeAAQAFgARABYAEQAEAAQAUABQAFAAUABQAFAAUABQACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAKwAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQADQAEAAQABAAEAAQADQAEAAQAUABQAFAAUABQAAQABAAEAAQABAAEAAQABAAEAAQABAArAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAArAA0ADQAeAB4AHgAeAB4AHgAEAB4AHgAeAB4AHgAeACsAHgAeAA4ADgANAA4AHgAeAB4AHgAeAAkACQArACsAKwArACsAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgBcAEsASwBLAEsASwBLAEsASwBLAEsADQANAB4AHgAeAB4AXABcAFwAXABcAFwAKgAqACoAKgBcAFwAXABcACoAKgAqAFwAKgAqACoAXABcACoAKgAqACoAKgAqACoAXABcAFwAKgAqACoAKgBcAFwAXABcAFwAXABcAFwAXABcAFwAXABcACoAKgAqACoAKgAqACoAKgAqACoAKgAqAFwAKgBLAEsASwBLAEsASwBLAEsASwBLACoAKgAqACoAKgAqAFAAUABQAFAAUABQACsAUAArACsAKwArACsAUAArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAHgBQAFAAUABQAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFAAUABQAFAAUABQAFAAUABQACsAUABQAFAAUAArACsAUABQAFAAUABQAFAAUAArAFAAKwBQAFAAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAKwArAFAAUABQAFAAUABQAFAAKwBQACsAUABQAFAAUAArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsABAAEAAQAHgANAB4AHgAeAB4AHgAeAB4AUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAHgAeAB4AHgAeAB4AHgAeAB4AHgArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwBQAFAAUABQAFAAUAArACsADQBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAHgAeAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAANAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAWABEAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAA0ADQANAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAAQABAAEACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAANAA0AKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEACsAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUAArAAQABAArACsAKwArACsAKwArACsAKwArACsAKwBcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqAA0ADQAVAFwADQAeAA0AGwBcACoAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwAeAB4AEwATAA0ADQAOAB4AEwATAB4ABAAEAAQACQArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArAFAAUABQAFAAUAAEAAQAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQAUAArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwAEAAQABAAEAAQABAAEAAQABAAEAAQABAArACsAKwArAAQABAAEAAQABAAEAAQABAAEAAQABAAEACsAKwArACsAHgArACsAKwATABMASwBLAEsASwBLAEsASwBLAEsASwBcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXAArACsAXABcAFwAXABcACsAKwArACsAKwArACsAKwArACsAKwBcAFwAXABcAFwAXABcAFwAXABcAFwAXAArACsAKwArAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAXAArACsAKwAqACoAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAEAAQABAArACsAHgAeAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcACoAKgAqACoAKgAqACoAKgAqACoAKwAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKwArAAQASwBLAEsASwBLAEsASwBLAEsASwArACsAKwArACsAKwBLAEsASwBLAEsASwBLAEsASwBLACsAKwArACsAKwArACoAKgAqACoAKgAqACoAXAAqACoAKgAqACoAKgArACsABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsABAAEAAQABAAEAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAEAAQABABQAFAAUABQAFAAUABQACsAKwArACsASwBLAEsASwBLAEsASwBLAEsASwANAA0AHgANAA0ADQANAB4AHgAeAB4AHgAeAB4AHgAeAB4ABAAEAAQABAAEAAQABAAEAAQAHgAeAB4AHgAeAB4AHgAeAB4AKwArACsABAAEAAQAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAAEAAQABAAEAAQABABQAFAASwBLAEsASwBLAEsASwBLAEsASwBQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACsAKwArACsAKwArACsAKwAeAB4AHgAeAFAAUABQAFAABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACsAKwArAA0ADQANAA0ADQBLAEsASwBLAEsASwBLAEsASwBLACsAKwArAFAAUABQAEsASwBLAEsASwBLAEsASwBLAEsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAA0ADQBQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwBQAFAAUAAeAB4AHgAeAB4AHgAeAB4AKwArACsAKwArACsAKwArAAQABAAEAB4ABAAEAAQABAAEAAQABAAEAAQABAAEAAQABABQAFAAUABQAAQAUABQAFAAUABQAFAABABQAFAABAAEAAQAUAArACsAKwArACsABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACsABAAEAAQABAAEAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwArAFAAUABQAFAAUABQACsAKwBQAFAAUABQAFAAUABQAFAAKwBQACsAUAArAFAAKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeACsAKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArAB4AHgAeAB4AHgAeAB4AHgBQAB4AHgAeAFAAUABQACsAHgAeAB4AHgAeAB4AHgAeAB4AHgBQAFAAUABQACsAKwAeAB4AHgAeAB4AHgArAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwArAFAAUABQACsAHgAeAB4AHgAeAB4AHgAOAB4AKwANAA0ADQANAA0ADQANAAkADQANAA0ACAAEAAsABAAEAA0ACQANAA0ADAAdAB0AHgAXABcAFgAXABcAFwAWABcAHQAdAB4AHgAUABQAFAANAAEAAQAEAAQABAAEAAQACQAaABoAGgAaABoAGgAaABoAHgAXABcAHQAVABUAHgAeAB4AHgAeAB4AGAAWABEAFQAVABUAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4ADQAeAA0ADQANAA0AHgANAA0ADQAHAB4AHgAeAB4AKwAEAAQABAAEAAQABAAEAAQABAAEAFAAUAArACsATwBQAFAAUABQAFAAHgAeAB4AFgARAE8AUABPAE8ATwBPAFAAUABQAFAAUAAeAB4AHgAWABEAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArABsAGwAbABsAGwAbABsAGgAbABsAGwAbABsAGwAbABsAGwAbABsAGwAbABsAGgAbABsAGwAbABoAGwAbABoAGwAbABsAGwAbABsAGwAbABsAGwAbABsAGwAbABsAGwAbAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAHgAeAFAAGgAeAB0AHgBQAB4AGgAeAB4AHgAeAB4AHgAeAB4AHgBPAB4AUAAbAB4AHgBQAFAAUABQAFAAHgAeAB4AHQAdAB4AUAAeAFAAHgBQAB4AUABPAFAAUAAeAB4AHgAeAB4AHgAeAFAAUABQAFAAUAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAFAAHgBQAFAAUABQAE8ATwBQAFAAUABQAFAATwBQAFAATwBQAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAFAAUABQAFAATwBPAE8ATwBPAE8ATwBPAE8ATwBQAFAAUABQAFAAUABQAFAAUAAeAB4AUABQAFAAUABPAB4AHgArACsAKwArAB0AHQAdAB0AHQAdAB0AHQAdAB0AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB0AHgAdAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAdAB4AHQAdAB4AHgAeAB0AHQAeAB4AHQAeAB4AHgAdAB4AHQAbABsAHgAdAB4AHgAeAB4AHQAeAB4AHQAdAB0AHQAeAB4AHQAeAB0AHgAdAB0AHQAdAB0AHQAeAB0AHgAeAB4AHgAeAB0AHQAdAB0AHgAeAB4AHgAdAB0AHgAeAB4AHgAeAB4AHgAeAB4AHgAdAB4AHgAeAB0AHgAeAB4AHgAeAB0AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAdAB0AHgAeAB0AHQAdAB0AHgAeAB0AHQAeAB4AHQAdAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB0AHQAeAB4AHQAdAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHQAeAB4AHgAdAB4AHgAeAB4AHgAeAB4AHQAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB0AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AFAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeABYAEQAWABEAHgAeAB4AHgAeAB4AHQAeAB4AHgAeAB4AHgAeACUAJQAeAB4AHgAeAB4AHgAeAB4AHgAWABEAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AJQAlACUAJQAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAFAAHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHgAeAB4AHgAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAeAB4AHQAdAB0AHQAeAB4AHgAeAB4AHgAeAB4AHgAeAB0AHQAeAB0AHQAdAB0AHQAdAB0AHgAeAB4AHgAeAB4AHgAeAB0AHQAeAB4AHQAdAB4AHgAeAB4AHQAdAB4AHgAeAB4AHQAdAB0AHgAeAB0AHgAeAB0AHQAdAB0AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAdAB0AHQAdAB4AHgAeAB4AHgAeAB4AHgAeAB0AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAlACUAJQAlAB4AHQAdAB4AHgAdAB4AHgAeAB4AHQAdAB4AHgAeAB4AJQAlAB0AHQAlAB4AJQAlACUAIAAlACUAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAlACUAJQAeAB4AHgAeAB0AHgAdAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAdAB0AHgAdAB0AHQAeAB0AJQAdAB0AHgAdAB0AHgAdAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeACUAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHQAdAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAlACUAJQAlACUAJQAlACUAJQAlACUAJQAdAB0AHQAdACUAHgAlACUAJQAdACUAJQAdAB0AHQAlACUAHQAdACUAHQAdACUAJQAlAB4AHQAeAB4AHgAeAB0AHQAlAB0AHQAdAB0AHQAdACUAJQAlACUAJQAdACUAJQAgACUAHQAdACUAJQAlACUAJQAlACUAJQAeAB4AHgAlACUAIAAgACAAIAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB0AHgAeAB4AFwAXABcAFwAXABcAHgATABMAJQAeAB4AHgAWABEAFgARABYAEQAWABEAFgARABYAEQAWABEATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeABYAEQAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAWABEAFgARABYAEQAWABEAFgARAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AFgARABYAEQAWABEAFgARABYAEQAWABEAFgARABYAEQAWABEAFgARABYAEQAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAWABEAFgARAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AFgARAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAdAB0AHQAdAB0AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArACsAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AUABQAFAAUAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAEAAQABAAeAB4AKwArACsAKwArABMADQANAA0AUAATAA0AUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAUAANACsAKwArACsAKwArACsAKwArACsAKwArACsAKwAEAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQACsAUABQAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQACsAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXAA0ADQANAA0ADQANAA0ADQAeAA0AFgANAB4AHgAXABcAHgAeABcAFwAWABEAFgARABYAEQAWABEADQANAA0ADQATAFAADQANAB4ADQANAB4AHgAeAB4AHgAMAAwADQANAA0AHgANAA0AFgANAA0ADQANAA0ADQANAA0AHgANAB4ADQANAB4AHgAeACsAKwArACsAKwArACsAKwArACsAKwArACsAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACsAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAKwArACsAKwArACsAKwArACsAKwArACsAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwAlACUAJQAlACUAJQAlACUAJQAlACUAJQArACsAKwArAA0AEQARACUAJQBHAFcAVwAWABEAFgARABYAEQAWABEAFgARACUAJQAWABEAFgARABYAEQAWABEAFQAWABEAEQAlAFcAVwBXAFcAVwBXAFcAVwBXAAQABAAEAAQABAAEACUAVwBXAFcAVwA2ACUAJQBXAFcAVwBHAEcAJQAlACUAKwBRAFcAUQBXAFEAVwBRAFcAUQBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFEAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBRAFcAUQBXAFEAVwBXAFcAVwBXAFcAUQBXAFcAVwBXAFcAVwBRAFEAKwArAAQABAAVABUARwBHAFcAFQBRAFcAUQBXAFEAVwBRAFcAUQBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFEAVwBRAFcAUQBXAFcAVwBXAFcAVwBRAFcAVwBXAFcAVwBXAFEAUQBXAFcAVwBXABUAUQBHAEcAVwArACsAKwArACsAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAKwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAKwAlACUAVwBXAFcAVwAlACUAJQAlACUAJQAlACUAJQAlACsAKwArACsAKwArACsAKwArACsAKwArAFEAUQBRAFEAUQBRAFEAUQBRAFEAUQBRAFEAUQBRAFEAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQArAFcAVwBXAFcAVwBXAFcAVwBXAFcAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQBPAE8ATwBPAE8ATwBPAE8AJQBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXACUAJQAlAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAEcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAKwArACsAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAADQATAA0AUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABLAEsASwBLAEsASwBLAEsASwBLAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAFAABAAEAAQABAAeAAQABAAEAAQABAAEAAQABAAEAAQAHgBQAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AUABQAAQABABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAeAA0ADQANAA0ADQArACsAKwArACsAKwArACsAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAFAAUABQAFAAUABQAFAAUABQAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AUAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgBQAB4AHgAeAB4AHgAeAFAAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArACsAHgAeAB4AHgAeAB4AHgAeAB4AKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwAeAB4AUABQAFAAUABQAFAAUABQAFAAUABQAAQAUABQAFAABABQAFAAUABQAAQAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAEAAQABAAeAB4AHgAeAAQAKwArACsAUABQAFAAUABQAFAAHgAeABoAHgArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAADgAOABMAEwArACsAKwArACsAKwArACsABAAEAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAEAAQABAAEACsAKwArACsAKwArACsAKwANAA0ASwBLAEsASwBLAEsASwBLAEsASwArACsAKwArACsAKwAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABABQAFAAUABQAFAAUAAeAB4AHgBQAA4AUABQAAQAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAAEAA0ADQBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAKwArACsAKwArACsAKwArACsAKwArAB4AWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYAFgAWABYACsAKwArAAQAHgAeAB4AHgAeAB4ADQANAA0AHgAeAB4AHgArAFAASwBLAEsASwBLAEsASwBLAEsASwArACsAKwArAB4AHgBcAFwAXABcAFwAKgBcAFwAXABcAFwAXABcAFwAXABcAEsASwBLAEsASwBLAEsASwBLAEsAXABcAFwAXABcACsAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACsAKwArACsAKwArACsAKwArAFAAUABQAAQAUABQAFAAUABQAFAAUABQAAQABAArACsASwBLAEsASwBLAEsASwBLAEsASwArACsAHgANAA0ADQBcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAKgAqACoAXAAqACoAKgBcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXAAqAFwAKgAqACoAXABcACoAKgBcAFwAXABcAFwAKgAqAFwAKgBcACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFwAXABcACoAKgBQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAA0ADQBQAFAAUAAEAAQAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUAArACsAUABQAFAAUABQAFAAKwArAFAAUABQAFAAUABQACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAHgAeACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAAQADQAEAAQAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAVABVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBUAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVAFUAVQBVACsAKwArACsAKwArACsAKwArACsAKwArAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAWQBZAFkAKwArACsAKwBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAWgBaAFoAKwArACsAKwAGAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAYABgAGAAYAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXACUAJQBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAJQAlACUAJQAlACUAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAKwArACsAKwArAFYABABWAFYAVgBWAFYAVgBWAFYAVgBWAB4AVgBWAFYAVgBWAFYAVgBWAFYAVgBWAFYAVgArAFYAVgBWAFYAVgArAFYAKwBWAFYAKwBWAFYAKwBWAFYAVgBWAFYAVgBWAFYAVgBWAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAEQAWAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUAAaAB4AKwArAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAGAARABEAGAAYABMAEwAWABEAFAArACsAKwArACsAKwAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACUAJQAlACUAJQAWABEAFgARABYAEQAWABEAFgARABYAEQAlACUAFgARACUAJQAlACUAJQAlACUAEQAlABEAKwAVABUAEwATACUAFgARABYAEQAWABEAJQAlACUAJQAlACUAJQAlACsAJQAbABoAJQArACsAKwArAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArAAcAKwATACUAJQAbABoAJQAlABYAEQAlACUAEQAlABEAJQBXAFcAVwBXAFcAVwBXAFcAVwBXABUAFQAlACUAJQATACUAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXABYAJQARACUAJQAlAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwAWACUAEQAlABYAEQARABYAEQARABUAVwBRAFEAUQBRAFEAUQBRAFEAUQBRAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAEcARwArACsAVwBXAFcAVwBXAFcAKwArAFcAVwBXAFcAVwBXACsAKwBXAFcAVwBXAFcAVwArACsAVwBXAFcAKwArACsAGgAbACUAJQAlABsAGwArAB4AHgAeAB4AHgAeAB4AKwArACsAKwArACsAKwArACsAKwAEAAQABAAQAB0AKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsADQANAA0AKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArAB4AHgAeAB4AHgAeAB4AHgAeAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgBQAFAAHgAeAB4AKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAAQAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwAEAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAA0AUABQAFAAUAArACsAKwArAFAAUABQAFAAUABQAFAAUAANAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAKwArACsAKwAeACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAKwArAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUAArACsAKwBQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwANAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAeAB4AUABQAFAAUABQAFAAUAArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUAArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArAA0AUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwAeAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAUABQAFAAUABQAAQABAAEACsABAAEACsAKwArACsAKwAEAAQABAAEAFAAUABQAFAAKwBQAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArAAQABAAEACsAKwArACsABABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArAA0ADQANAA0ADQANAA0ADQAeACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAeAFAAUABQAFAAUABQAFAAUAAeAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAArACsAKwArAFAAUABQAFAAUAANAA0ADQANAA0ADQAUACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsADQANAA0ADQANAA0ADQBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArAB4AHgAeAB4AKwArACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArAFAAUABQAFAAUABQAAQABAAEAAQAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUAArAAQABAANACsAKwBQAFAAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAAQABAAEAAQABAAEAAQABAAEAAQABABQAFAAUABQAB4AHgAeAB4AHgArACsAKwArACsAKwAEAAQABAAEAAQABAAEAA0ADQAeAB4AHgAeAB4AKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsABABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAQABAAEAAQABAAEAAQABAAEAAQABAAeAB4AHgANAA0ADQANACsAKwArACsAKwArACsAKwArACsAKwAeACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAKwArACsAKwBLAEsASwBLAEsASwBLAEsASwBLACsAKwArACsAKwArAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACsASwBLAEsASwBLAEsASwBLAEsASwANAA0ADQANAFAABAAEAFAAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAeAA4AUAArACsAKwArACsAKwArACsAKwAEAFAAUABQAFAADQANAB4ADQAEAAQABAAEAB4ABAAEAEsASwBLAEsASwBLAEsASwBLAEsAUAAOAFAADQANAA0AKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAAQABAAEAAQABAANAA0AHgANAA0AHgAEACsAUABQAFAAUABQAFAAUAArAFAAKwBQAFAAUABQACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAA0AKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAAQABAAEAAQAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsABAAEAAQABAArAFAAUABQAFAAUABQAFAAUAArACsAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQACsAUABQACsAUABQAFAAUABQACsABAAEAFAABAAEAAQABAAEAAQABAArACsABAAEACsAKwAEAAQABAArACsAUAArACsAKwArACsAKwAEACsAKwArACsAKwBQAFAAUABQAFAABAAEACsAKwAEAAQABAAEAAQABAAEACsAKwArAAQABAAEAAQABAArACsAKwArACsAKwArACsAKwArACsABAAEAAQABAAEAAQABABQAFAAUABQAA0ADQANAA0AHgBLAEsASwBLAEsASwBLAEsASwBLAA0ADQArAB4ABABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwAEAAQABAAEAFAAUAAeAFAAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAArACsABAAEAAQABAAEAAQABAAEAAQADgANAA0AEwATAB4AHgAeAA0ADQANAA0ADQANAA0ADQANAA0ADQANAA0ADQANAFAAUABQAFAABAAEACsAKwAEAA0ADQAeAFAAKwArACsAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAFAAKwArACsAKwArACsAKwBLAEsASwBLAEsASwBLAEsASwBLACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAXABcAFwAKwArACoAKgAqACoAKgAqACoAKgAqACoAKgAqACoAKgAqACsAKwArACsASwBLAEsASwBLAEsASwBLAEsASwBcAFwADQANAA0AKgBQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAeACsAKwArACsASwBLAEsASwBLAEsASwBLAEsASwBQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAKwArAFAAKwArAFAAUABQAFAAUABQAFAAUAArAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQAKwAEAAQAKwArAAQABAAEAAQAUAAEAFAABAAEAA0ADQANACsAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAArACsABAAEAAQABAAEAAQABABQAA4AUAAEACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFAABAAEAAQABAAEAAQABAAEAAQABABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAFAABAAEAAQABAAOAB4ADQANAA0ADQAOAB4ABAArACsAKwArACsAKwArACsAUAAEAAQABAAEAAQABAAEAAQABAAEAAQAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAA0ADQANAFAADgAOAA4ADQANACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAEAAQABAAEACsABAAEAAQABAAEAAQABAAEAFAADQANAA0ADQANACsAKwArACsAKwArACsAKwArACsASwBLAEsASwBLAEsASwBLAEsASwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwAOABMAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAArAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQACsAUABQACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAArACsAKwAEACsABAAEACsABAAEAAQABAAEAAQABABQAAQAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAUABQAFAAUABQAFAAKwBQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQAKwAEAAQAKwAEAAQABAAEAAQAUAArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAABAAEAAQABAAeAB4AKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwBQACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAB4AHgAeAB4AHgAeAB4AHgAaABoAGgAaAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArACsAKwArACsAKwArACsAKwArACsAKwArAA0AUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsADQANAA0ADQANACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAASABIAEgAQwBDAEMAUABQAFAAUABDAFAAUABQAEgAQwBIAEMAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAASABDAEMAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwAJAAkACQAJAAkACQAJABYAEQArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABIAEMAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwANAA0AKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArAAQABAAEAAQABAANACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEAA0ADQANAB4AHgAeAB4AHgAeAFAAUABQAFAADQAeACsAKwArACsAKwArACsAKwArACsASwBLAEsASwBLAEsASwBLAEsASwArAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAANAA0AHgAeACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAKwAEAFAABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAKwArACsAKwArACsAKwAEAAQABAAEAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAARwBHABUARwAJACsAKwArACsAKwArACsAKwArACsAKwAEAAQAKwArACsAKwArACsAKwArACsAKwArACsAKwArAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXACsAKwArACsAKwArACsAKwBXAFcAVwBXAFcAVwBXAFcAVwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAUQBRAFEAKwArACsAKwArACsAKwArACsAKwArACsAKwBRAFEAUQBRACsAKwArACsAKwArACsAKwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUAArACsAHgAEAAQADQAEAAQABAAEACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArACsAKwArACsAKwArACsAKwArAB4AHgAeAB4AHgAeAB4AKwArAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAAQABAAEAAQABAAeAB4AHgAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAB4AHgAEAAQABAAEAAQABAAEAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4ABAAEAAQABAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4ABAAEAAQAHgArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwArACsAKwArACsAKwArACsAKwArAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArACsAKwArACsAKwArACsAKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwBQAFAAKwArAFAAKwArAFAAUAArACsAUABQAFAAUAArAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeACsAUAArAFAAUABQAFAAUABQAFAAKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwBQAFAAUABQACsAKwBQAFAAUABQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQACsAHgAeAFAAUABQAFAAUAArAFAAKwArACsAUABQAFAAUABQAFAAUAArAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAHgBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgBQAFAAUABQAFAAUABQAFAAUABQAFAAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAB4AHgAeAB4AHgAeAB4AHgAeACsAKwBLAEsASwBLAEsASwBLAEsASwBLAEsASwBLAEsASwBLAEsASwBLAEsASwBLAEsASwBLAEsASwBLAEsASwBLAEsASwBLAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAeAB4AHgAeAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAeAB4AHgAeAB4AHgAeAB4ABAAeAB4AHgAeAB4AHgAeAB4AHgAeAAQAHgAeAA0ADQANAA0AHgArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwAEAAQABAAEAAQAKwAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAAQABAAEAAQABAAEAAQAKwAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAKwArAAQABAAEAAQABAAEAAQAKwAEAAQAKwAEAAQABAAEAAQAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwAEAAQABAAEAAQABAAEAFAAUABQAFAAUABQAFAAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwBQAB4AKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArABsAUABQAFAAUABQACsAKwBQAFAAUABQAFAAUABQAFAAUAAEAAQABAAEAAQABAAEACsAKwArACsAKwArACsAKwArAB4AHgAeAB4ABAAEAAQABAAEAAQABABQACsAKwArACsASwBLAEsASwBLAEsASwBLAEsASwArACsAKwArABYAFgArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAGgBQAFAAUAAaAFAAUABQAFAAKwArACsAKwArACsAKwArACsAKwArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAeAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQACsAKwBQAFAAUABQACsAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwBQAFAAKwBQACsAKwBQACsAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAKwBQACsAUAArACsAKwArACsAKwBQACsAKwArACsAUAArAFAAKwBQACsAUABQAFAAKwBQAFAAKwBQACsAKwBQACsAUAArAFAAKwBQACsAUAArAFAAUAArAFAAKwArAFAAUABQAFAAKwBQAFAAUABQAFAAUABQACsAUABQAFAAUAArAFAAUABQAFAAKwBQACsAUABQAFAAUABQAFAAUABQAFAAUAArAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAArACsAKwArACsAUABQAFAAKwBQAFAAUABQAFAAKwBQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwAeAB4AKwArACsAKwArACsAKwArACsAKwArACsAKwArAE8ATwBPAE8ATwBPAE8ATwBPAE8ATwBPAE8AJQAlACUAHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHgAeAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB4AHgAeACUAJQAlAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAdAB0AHQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQApACkAKQApACkAKQApACkAKQApACkAKQApACkAKQApACkAKQApACkAKQApACkAKQApACkAJQAlACUAJQAlACAAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAeAB4AJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlAB4AHgAlACUAJQAlACUAHgAlACUAJQAlACUAIAAgACAAJQAlACAAJQAlACAAIAAgACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACEAIQAhACEAIQAlACUAIAAgACUAJQAgACAAIAAgACAAIAAgACAAIAAgACAAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAJQAlACUAIAAlACUAJQAlACAAIAAgACUAIAAgACAAJQAlACUAJQAlACUAJQAgACUAIAAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAHgAlAB4AJQAeACUAJQAlACUAJQAgACUAJQAlACUAHgAlAB4AHgAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlAB4AHgAeAB4AHgAeAB4AJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAeAB4AHgAeAB4AHgAeAB4AHgAeACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACAAIAAlACUAJQAlACAAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACAAJQAlACUAJQAgACAAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAHgAeAB4AHgAeAB4AHgAeACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAeAB4AHgAeAB4AHgAlACUAJQAlACUAJQAlACAAIAAgACUAJQAlACAAIAAgACAAIAAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeABcAFwAXABUAFQAVAB4AHgAeAB4AJQAlACUAIAAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACAAIAAgACUAJQAlACUAJQAlACUAJQAlACAAJQAlACUAJQAlACUAJQAlACUAJQAlACAAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AJQAlACUAJQAlACUAJQAlACUAJQAlACUAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AJQAlACUAJQAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeACUAJQAlACUAJQAlACUAJQAeAB4AHgAeAB4AHgAeAB4AHgAeACUAJQAlACUAJQAlAB4AHgAeAB4AHgAeAB4AHgAlACUAJQAlACUAJQAlACUAHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAgACUAJQAgACUAJQAlACUAJQAlACUAJQAgACAAIAAgACAAIAAgACAAJQAlACUAJQAlACUAIAAlACUAJQAlACUAJQAlACUAJQAgACAAIAAgACAAIAAgACAAIAAgACUAJQAgACAAIAAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAgACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACAAIAAlACAAIAAlACAAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAgACAAIAAlACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAJQAlAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AKwAeAB4AHgAeAB4AHgAeAB4AHgAeAB4AHgArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAEsASwBLAEsASwBLAEsASwBLAEsAKwArACsAKwArACsAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAKwArAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXACUAJQBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwAlACUAJQAlACUAJQAlACUAJQAlACUAVwBXACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQBXAFcAVwBXAFcAVwBXAFcAVwBXAFcAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAJQAlACUAKwAEACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArACsAKwArAA==",mE=50,T6=1,HI=2,GI=3,M6=4,O6=5,wE=7,KI=8,BE=9,Na=10,Kw=11,bE=12,zw=13,_6=14,_A=15,Vw=16,Bc=17,yA=18,I6=19,EE=20,jw=21,mA=22,Zf=23,co=24,Qr=25,IA=26,kA=27,uo=28,k6=29,Es=30,L6=31,bc=32,Ec=33,Ww=34,qw=35,$w=36,ul=37,Yw=38,Tu=39,Mu=40,Jf=41,zI=42,Q6=43,N6=[9001,65288],VI="!",ot="×",xc="÷",Xw=x6(F6),na=[Es,$w],Zw=[T6,HI,GI,O6],jI=[Na,KI],xE=[kA,IA],U6=Zw.concat(jI),CE=[Yw,Tu,Mu,Ww,qw],P6=[_A,zw],R6=function(r,e){e===void 0&&(e="strict");var t=[],n=[],i=[];return r.forEach(function(a,s){var o=Xw.get(a);if(o>mE?(i.push(!0),o-=mE):i.push(!1),["normal","auto","loose"].indexOf(e)!==-1&&[8208,8211,12316,12448].indexOf(a)!==-1)return n.push(s),t.push(Vw);if(o===M6||o===Kw){if(s===0)return n.push(s),t.push(Es);var A=t[s-1];return U6.indexOf(A)===-1?(n.push(n[s-1]),t.push(A)):(n.push(s),t.push(Es))}if(n.push(s),o===L6)return t.push(e==="strict"?jw:ul);if(o===zI||o===k6)return t.push(Es);if(o===Q6)return a>=131072&&a<=196605||a>=196608&&a<=262141?t.push(ul):t.push(Es);t.push(o)}),[n,t,i]},eg=function(r,e,t,n){var i=n[t];if(Array.isArray(r)?r.indexOf(i)!==-1:r===i)for(var a=t;a<=n.length;){a++;var s=n[a];if(s===e)return!0;if(s!==Na)break}if(i===Na)for(var a=t;a>0;){a--;var o=n[a];if(Array.isArray(r)?r.indexOf(o)!==-1:r===o)for(var A=t;A<=n.length;){A++;var s=n[A];if(s===e)return!0;if(s!==Na)break}if(o!==Na)break}return!1},SE=function(r,e){for(var t=r;t>=0;){var n=e[t];if(n===Na)t--;else return n}return 0},D6=function(r,e,t,n,i){if(t[n]===0)return ot;var a=n-1;if(Array.isArray(i)&&i[a]===!0)return ot;var s=a-1,o=a+1,A=e[a],l=s>=0?e[s]:0,c=e[o];if(A===HI&&c===GI)return ot;if(Zw.indexOf(A)!==-1)return VI;if(Zw.indexOf(c)!==-1||jI.indexOf(c)!==-1)return ot;if(SE(a,e)===KI)return xc;if(Xw.get(r[a])===Kw||(A===bc||A===Ec)&&Xw.get(r[o])===Kw||A===wE||c===wE||A===BE||[Na,zw,_A].indexOf(A)===-1&&c===BE||[Bc,yA,I6,co,uo].indexOf(c)!==-1||SE(a,e)===mA||eg(Zf,mA,a,e)||eg([Bc,yA],jw,a,e)||eg(bE,bE,a,e))return ot;if(A===Na)return xc;if(A===Zf||c===Zf)return ot;if(c===Vw||A===Vw)return xc;if([zw,_A,jw].indexOf(c)!==-1||A===_6||l===$w&&P6.indexOf(A)!==-1||A===uo&&c===$w||c===EE||na.indexOf(c)!==-1&&A===Qr||na.indexOf(A)!==-1&&c===Qr||A===kA&&[ul,bc,Ec].indexOf(c)!==-1||[ul,bc,Ec].indexOf(A)!==-1&&c===IA||na.indexOf(A)!==-1&&xE.indexOf(c)!==-1||xE.indexOf(A)!==-1&&na.indexOf(c)!==-1||[kA,IA].indexOf(A)!==-1&&(c===Qr||[mA,_A].indexOf(c)!==-1&&e[o+1]===Qr)||[mA,_A].indexOf(A)!==-1&&c===Qr||A===Qr&&[Qr,uo,co].indexOf(c)!==-1)return ot;if([Qr,uo,co,Bc,yA].indexOf(c)!==-1)for(var u=a;u>=0;){var h=e[u];if(h===Qr)return ot;if([uo,co].indexOf(h)!==-1)u--;else break}if([kA,IA].indexOf(c)!==-1)for(var u=[Bc,yA].indexOf(A)!==-1?s:a;u>=0;){var h=e[u];if(h===Qr)return ot;if([uo,co].indexOf(h)!==-1)u--;else break}if(Yw===A&&[Yw,Tu,Ww,qw].indexOf(c)!==-1||[Tu,Ww].indexOf(A)!==-1&&[Tu,Mu].indexOf(c)!==-1||[Mu,qw].indexOf(A)!==-1&&c===Mu||CE.indexOf(A)!==-1&&[EE,IA].indexOf(c)!==-1||CE.indexOf(c)!==-1&&A===kA||na.indexOf(A)!==-1&&na.indexOf(c)!==-1||A===co&&na.indexOf(c)!==-1||na.concat(Qr).indexOf(A)!==-1&&c===mA&&N6.indexOf(r[o])===-1||na.concat(Qr).indexOf(c)!==-1&&A===yA)return ot;if(A===Jf&&c===Jf){for(var d=t[a],f=1;d>0&&(d--,e[d]===Jf);)f++;if(f%2!==0)return ot}return A===bc&&c===Ec?ot:xc},H6=function(r,e){e||(e={lineBreak:"normal",wordBreak:"normal"});var t=R6(r,e.lineBreak),n=t[0],i=t[1],a=t[2];(e.wordBreak==="break-all"||e.wordBreak==="break-word")&&(i=i.map(function(o){return[Qr,Es,zI].indexOf(o)!==-1?ul:o}));var s=e.wordBreak==="keep-all"?a.map(function(o,A){return o&&r[A]>=19968&&r[A]<=40959}):void 0;return[n,i,s]},G6=(function(){function r(e,t,n,i){this.codePoints=e,this.required=t===VI,this.start=n,this.end=i}return r.prototype.slice=function(){return cn.apply(void 0,this.codePoints.slice(this.start,this.end))},r})(),K6=function(r,e){var t=Hh(r),n=H6(t,e),i=n[0],a=n[1],s=n[2],o=t.length,A=0,l=0;return{next:function(){if(l>=o)return{done:!0,value:null};for(var c=ot;l<o&&(c=D6(t,a,i,++l,s))===ot;);if(c!==ot||l===o){var u=new G6(t,c,A,l);return A=l,{value:u,done:!1}}return{done:!0,value:null}}}},z6=1,V6=2,kl=4,FE=8,ah=10,TE=47,XA=92,j6=9,W6=32,Cc=34,wA=61,q6=35,$6=36,Y6=37,Sc=39,Fc=40,BA=41,X6=95,Er=45,Z6=33,J6=60,e5=62,t5=64,n5=91,r5=93,i5=61,a5=123,Tc=63,s5=125,ME=124,o5=126,A5=128,OE=65533,tg=42,Fs=43,l5=44,c5=58,u5=59,hl=46,h5=0,d5=8,f5=11,g5=14,v5=31,p5=127,Oi=-1,WI=48,qI=97,$I=101,y5=102,m5=117,w5=122,YI=65,XI=69,ZI=70,B5=85,b5=90,Zn=function(r){return r>=WI&&r<=57},E5=function(r){return r>=55296&&r<=57343},ho=function(r){return Zn(r)||r>=YI&&r<=ZI||r>=qI&&r<=y5},x5=function(r){return r>=qI&&r<=w5},C5=function(r){return r>=YI&&r<=b5},S5=function(r){return x5(r)||C5(r)},F5=function(r){return r>=A5},Mc=function(r){return r===ah||r===j6||r===W6},sh=function(r){return S5(r)||F5(r)||r===X6},_E=function(r){return sh(r)||Zn(r)||r===Er},T5=function(r){return r>=h5&&r<=d5||r===f5||r>=g5&&r<=v5||r===p5},Oa=function(r,e){return r!==XA?!1:e!==ah},Oc=function(r,e,t){return r===Er?sh(e)||Oa(e,t):sh(r)?!0:!!(r===XA&&Oa(r,e))},ng=function(r,e,t){return r===Fs||r===Er?Zn(e)?!0:e===hl&&Zn(t):Zn(r===hl?e:r)},M5=function(r){var e=0,t=1;(r[e]===Fs||r[e]===Er)&&(r[e]===Er&&(t=-1),e++);for(var n=[];Zn(r[e]);)n.push(r[e++]);var i=n.length?parseInt(cn.apply(void 0,n),10):0;r[e]===hl&&e++;for(var a=[];Zn(r[e]);)a.push(r[e++]);var s=a.length,o=s?parseInt(cn.apply(void 0,a),10):0;(r[e]===XI||r[e]===$I)&&e++;var A=1;(r[e]===Fs||r[e]===Er)&&(r[e]===Er&&(A=-1),e++);for(var l=[];Zn(r[e]);)l.push(r[e++]);var c=l.length?parseInt(cn.apply(void 0,l),10):0;return t*(i+o*Math.pow(10,-s))*Math.pow(10,A*c)},O5={type:2},_5={type:3},I5={type:4},k5={type:13},L5={type:8},Q5={type:21},N5={type:9},U5={type:10},P5={type:11},R5={type:12},D5={type:14},_c={type:23},H5={type:1},G5={type:25},K5={type:24},z5={type:26},V5={type:27},j5={type:28},W5={type:29},q5={type:31},Jw={type:32},JI=(function(){function r(){this._value=[]}return r.prototype.write=function(e){this._value=this._value.concat(Hh(e))},r.prototype.read=function(){for(var e=[],t=this.consumeToken();t!==Jw;)e.push(t),t=this.consumeToken();return e},r.prototype.consumeToken=function(){var e=this.consumeCodePoint();switch(e){case Cc:return this.consumeStringToken(Cc);case q6:var t=this.peekCodePoint(0),n=this.peekCodePoint(1),i=this.peekCodePoint(2);if(_E(t)||Oa(n,i)){var a=Oc(t,n,i)?V6:z6,s=this.consumeName();return{type:5,value:s,flags:a}}break;case $6:if(this.peekCodePoint(0)===wA)return this.consumeCodePoint(),k5;break;case Sc:return this.consumeStringToken(Sc);case Fc:return O5;case BA:return _5;case tg:if(this.peekCodePoint(0)===wA)return this.consumeCodePoint(),D5;break;case Fs:if(ng(e,this.peekCodePoint(0),this.peekCodePoint(1)))return this.reconsumeCodePoint(e),this.consumeNumericToken();break;case l5:return I5;case Er:var o=e,A=this.peekCodePoint(0),l=this.peekCodePoint(1);if(ng(o,A,l))return this.reconsumeCodePoint(e),this.consumeNumericToken();if(Oc(o,A,l))return this.reconsumeCodePoint(e),this.consumeIdentLikeToken();if(A===Er&&l===e5)return this.consumeCodePoint(),this.consumeCodePoint(),K5;break;case hl:if(ng(e,this.peekCodePoint(0),this.peekCodePoint(1)))return this.reconsumeCodePoint(e),this.consumeNumericToken();break;case TE:if(this.peekCodePoint(0)===tg)for(this.consumeCodePoint();;){var c=this.consumeCodePoint();if(c===tg&&(c=this.consumeCodePoint(),c===TE))return this.consumeToken();if(c===Oi)return this.consumeToken()}break;case c5:return z5;case u5:return V5;case J6:if(this.peekCodePoint(0)===Z6&&this.peekCodePoint(1)===Er&&this.peekCodePoint(2)===Er)return this.consumeCodePoint(),this.consumeCodePoint(),G5;break;case t5:var u=this.peekCodePoint(0),h=this.peekCodePoint(1),d=this.peekCodePoint(2);if(Oc(u,h,d)){var s=this.consumeName();return{type:7,value:s}}break;case n5:return j5;case XA:if(Oa(e,this.peekCodePoint(0)))return this.reconsumeCodePoint(e),this.consumeIdentLikeToken();break;case r5:return W5;case i5:if(this.peekCodePoint(0)===wA)return this.consumeCodePoint(),L5;break;case a5:return P5;case s5:return R5;case m5:case B5:var f=this.peekCodePoint(0),g=this.peekCodePoint(1);return f===Fs&&(ho(g)||g===Tc)&&(this.consumeCodePoint(),this.consumeUnicodeRangeToken()),this.reconsumeCodePoint(e),this.consumeIdentLikeToken();case ME:if(this.peekCodePoint(0)===wA)return this.consumeCodePoint(),N5;if(this.peekCodePoint(0)===ME)return this.consumeCodePoint(),Q5;break;case o5:if(this.peekCodePoint(0)===wA)return this.consumeCodePoint(),U5;break;case Oi:return Jw}return Mc(e)?(this.consumeWhiteSpace(),q5):Zn(e)?(this.reconsumeCodePoint(e),this.consumeNumericToken()):sh(e)?(this.reconsumeCodePoint(e),this.consumeIdentLikeToken()):{type:6,value:cn(e)}},r.prototype.consumeCodePoint=function(){var e=this._value.shift();return typeof e>"u"?-1:e},r.prototype.reconsumeCodePoint=function(e){this._value.unshift(e)},r.prototype.peekCodePoint=function(e){return e>=this._value.length?-1:this._value[e]},r.prototype.consumeUnicodeRangeToken=function(){for(var e=[],t=this.consumeCodePoint();ho(t)&&e.length<6;)e.push(t),t=this.consumeCodePoint();for(var n=!1;t===Tc&&e.length<6;)e.push(t),t=this.consumeCodePoint(),n=!0;if(n){var i=parseInt(cn.apply(void 0,e.map(function(A){return A===Tc?WI:A})),16),a=parseInt(cn.apply(void 0,e.map(function(A){return A===Tc?ZI:A})),16);return{type:30,start:i,end:a}}var s=parseInt(cn.apply(void 0,e),16);if(this.peekCodePoint(0)===Er&&ho(this.peekCodePoint(1))){this.consumeCodePoint(),t=this.consumeCodePoint();for(var o=[];ho(t)&&o.length<6;)o.push(t),t=this.consumeCodePoint();var a=parseInt(cn.apply(void 0,o),16);return{type:30,start:s,end:a}}else return{type:30,start:s,end:s}},r.prototype.consumeIdentLikeToken=function(){var e=this.consumeName();return e.toLowerCase()==="url"&&this.peekCodePoint(0)===Fc?(this.consumeCodePoint(),this.consumeUrlToken()):this.peekCodePoint(0)===Fc?(this.consumeCodePoint(),{type:19,value:e}):{type:20,value:e}},r.prototype.consumeUrlToken=function(){var e=[];if(this.consumeWhiteSpace(),this.peekCodePoint(0)===Oi)return{type:22,value:""};var t=this.peekCodePoint(0);if(t===Sc||t===Cc){var n=this.consumeStringToken(this.consumeCodePoint());return n.type===0&&(this.consumeWhiteSpace(),this.peekCodePoint(0)===Oi||this.peekCodePoint(0)===BA)?(this.consumeCodePoint(),{type:22,value:n.value}):(this.consumeBadUrlRemnants(),_c)}for(;;){var i=this.consumeCodePoint();if(i===Oi||i===BA)return{type:22,value:cn.apply(void 0,e)};if(Mc(i))return this.consumeWhiteSpace(),this.peekCodePoint(0)===Oi||this.peekCodePoint(0)===BA?(this.consumeCodePoint(),{type:22,value:cn.apply(void 0,e)}):(this.consumeBadUrlRemnants(),_c);if(i===Cc||i===Sc||i===Fc||T5(i))return this.consumeBadUrlRemnants(),_c;if(i===XA)if(Oa(i,this.peekCodePoint(0)))e.push(this.consumeEscapedCodePoint());else return this.consumeBadUrlRemnants(),_c;else e.push(i)}},r.prototype.consumeWhiteSpace=function(){for(;Mc(this.peekCodePoint(0));)this.consumeCodePoint()},r.prototype.consumeBadUrlRemnants=function(){for(;;){var e=this.consumeCodePoint();if(e===BA||e===Oi)return;Oa(e,this.peekCodePoint(0))&&this.consumeEscapedCodePoint()}},r.prototype.consumeStringSlice=function(e){for(var t=5e4,n="";e>0;){var i=Math.min(t,e);n+=cn.apply(void 0,this._value.splice(0,i)),e-=i}return this._value.shift(),n},r.prototype.consumeStringToken=function(e){var t="",n=0;do{var i=this._value[n];if(i===Oi||i===void 0||i===e)return t+=this.consumeStringSlice(n),{type:0,value:t};if(i===ah)return this._value.splice(0,n),H5;if(i===XA){var a=this._value[n+1];a!==Oi&&a!==void 0&&(a===ah?(t+=this.consumeStringSlice(n),n=-1,this._value.shift()):Oa(i,a)&&(t+=this.consumeStringSlice(n),t+=cn(this.consumeEscapedCodePoint()),n=-1))}n++}while(!0)},r.prototype.consumeNumber=function(){var e=[],t=kl,n=this.peekCodePoint(0);for((n===Fs||n===Er)&&e.push(this.consumeCodePoint());Zn(this.peekCodePoint(0));)e.push(this.consumeCodePoint());n=this.peekCodePoint(0);var i=this.peekCodePoint(1);if(n===hl&&Zn(i))for(e.push(this.consumeCodePoint(),this.consumeCodePoint()),t=FE;Zn(this.peekCodePoint(0));)e.push(this.consumeCodePoint());n=this.peekCodePoint(0),i=this.peekCodePoint(1);var a=this.peekCodePoint(2);if((n===XI||n===$I)&&((i===Fs||i===Er)&&Zn(a)||Zn(i)))for(e.push(this.consumeCodePoint(),this.consumeCodePoint()),t=FE;Zn(this.peekCodePoint(0));)e.push(this.consumeCodePoint());return[M5(e),t]},r.prototype.consumeNumericToken=function(){var e=this.consumeNumber(),t=e[0],n=e[1],i=this.peekCodePoint(0),a=this.peekCodePoint(1),s=this.peekCodePoint(2);if(Oc(i,a,s)){var o=this.consumeName();return{type:15,number:t,flags:n,unit:o}}return i===Y6?(this.consumeCodePoint(),{type:16,number:t,flags:n}):{type:17,number:t,flags:n}},r.prototype.consumeEscapedCodePoint=function(){var e=this.consumeCodePoint();if(ho(e)){for(var t=cn(e);ho(this.peekCodePoint(0))&&t.length<6;)t+=cn(this.consumeCodePoint());Mc(this.peekCodePoint(0))&&this.consumeCodePoint();var n=parseInt(t,16);return n===0||E5(n)||n>1114111?OE:n}return e===Oi?OE:e},r.prototype.consumeName=function(){for(var e="";;){var t=this.consumeCodePoint();if(_E(t))e+=cn(t);else if(Oa(t,this.peekCodePoint(0)))e+=cn(this.consumeEscapedCodePoint());else return this.reconsumeCodePoint(t),e}},r})(),ek=(function(){function r(e){this._tokens=e}return r.create=function(e){var t=new JI;return t.write(e),new r(t.read())},r.parseValue=function(e){return r.create(e).parseComponentValue()},r.parseValues=function(e){return r.create(e).parseComponentValues()},r.prototype.parseComponentValue=function(){for(var e=this.consumeToken();e.type===31;)e=this.consumeToken();if(e.type===32)throw new SyntaxError("Error parsing CSS component value, unexpected EOF");this.reconsumeToken(e);var t=this.consumeComponentValue();do e=this.consumeToken();while(e.type===31);if(e.type===32)return t;throw new SyntaxError("Error parsing CSS component value, multiple values found when expecting only one")},r.prototype.parseComponentValues=function(){for(var e=[];;){var t=this.consumeComponentValue();if(t.type===32)return e;e.push(t),e.push()}},r.prototype.consumeComponentValue=function(){var e=this.consumeToken();switch(e.type){case 11:case 28:case 2:return this.consumeSimpleBlock(e.type);case 19:return this.consumeFunction(e)}return e},r.prototype.consumeSimpleBlock=function(e){for(var t={type:e,values:[]},n=this.consumeToken();;){if(n.type===32||$5(n,e))return t;this.reconsumeToken(n),t.values.push(this.consumeComponentValue()),n=this.consumeToken()}},r.prototype.consumeFunction=function(e){for(var t={name:e.value,values:[],type:18};;){var n=this.consumeToken();if(n.type===32||n.type===3)return t;this.reconsumeToken(n),t.values.push(this.consumeComponentValue())}},r.prototype.consumeToken=function(){var e=this._tokens.shift();return typeof e>"u"?Jw:e},r.prototype.reconsumeToken=function(e){this._tokens.unshift(e)},r})(),Ll=function(r){return r.type===15},Gh=function(r){return r.type===17},nn=function(r){return r.type===20},e1=function(r,e){return nn(r)&&r.value===e},Kh=function(r){return r.type!==31&&r.type!==4},Wi=function(r){var e=[],t=[];return r.forEach(function(n){if(n.type===4){if(t.length===0)throw new Error("Error parsing function args, zero tokens for arg");e.push(t),t=[];return}n.type!==31&&t.push(n)}),t.length&&e.push(t),e},$5=function(r,e){return e===11&&r.type===12||e===28&&r.type===29?!0:e===2&&r.type===3},es=function(r){return r.type===17||r.type===15},pn=function(r){return r.type===16||es(r)},tk=function(r){return r.length>1?[r[0],r[1]]:[r[0]]},Kn={type:17,number:0,flags:kl},iB={type:16,number:50,flags:kl},Ua={type:16,number:100,flags:kl},LA=function(r,e,t){var n=r[0],i=r[1];return[kt(n,e),kt(typeof i<"u"?i:n,t)]},kt=function(r,e){if(r.type===16)return r.number/100*e;if(Ll(r))switch(r.unit){case"rem":case"em":return 16*r.number;default:return r.number}return r.number},nk="deg",rk="grad",ik="rad",ak="turn",zh={name:"angle",parse:function(r,e){if(e.type===15)switch(e.unit){case nk:return Math.PI*e.number/180;case rk:return Math.PI/200*e.number;case ik:return e.number;case ak:return Math.PI*2*e.number}throw new Error("Unsupported angle type")}},sk=function(r){return r.type===15&&(r.unit===nk||r.unit===rk||r.unit===ik||r.unit===ak)},ok=function(r){var e=r.filter(nn).map(function(t){return t.value}).join(" ");switch(e){case"to bottom right":case"to right bottom":case"left top":case"top left":return[Kn,Kn];case"to top":case"bottom":return ni(0);case"to bottom left":case"to left bottom":case"right top":case"top right":return[Kn,Ua];case"to right":case"left":return ni(90);case"to top left":case"to left top":case"right bottom":case"bottom right":return[Ua,Ua];case"to bottom":case"top":return ni(180);case"to top right":case"to right top":case"left bottom":case"bottom left":return[Ua,Kn];case"to left":case"right":return ni(270)}return 0},ni=function(r){return Math.PI*r/180},Wa={name:"color",parse:function(r,e){if(e.type===18){var t=Y5[e.name];if(typeof t>"u")throw new Error('Attempting to parse an unsupported color function "'+e.name+'"');return t(r,e.values)}if(e.type===5){if(e.value.length===3){var n=e.value.substring(0,1),i=e.value.substring(1,2),a=e.value.substring(2,3);return Pa(parseInt(n+n,16),parseInt(i+i,16),parseInt(a+a,16),1)}if(e.value.length===4){var n=e.value.substring(0,1),i=e.value.substring(1,2),a=e.value.substring(2,3),s=e.value.substring(3,4);return Pa(parseInt(n+n,16),parseInt(i+i,16),parseInt(a+a,16),parseInt(s+s,16)/255)}if(e.value.length===6){var n=e.value.substring(0,2),i=e.value.substring(2,4),a=e.value.substring(4,6);return Pa(parseInt(n,16),parseInt(i,16),parseInt(a,16),1)}if(e.value.length===8){var n=e.value.substring(0,2),i=e.value.substring(2,4),a=e.value.substring(4,6),s=e.value.substring(6,8);return Pa(parseInt(n,16),parseInt(i,16),parseInt(a,16),parseInt(s,16)/255)}}if(e.type===20){var o=dl[e.value.toUpperCase()];if(typeof o<"u")return o}return dl.TRANSPARENT}},Ro=function(r){return(255&r)===0},_n=function(r){var e=255&r,t=255&r>>8,n=255&r>>16,i=255&r>>24;return e<255?"rgba("+i+","+n+","+t+","+e/255+")":"rgb("+i+","+n+","+t+")"},Pa=function(r,e,t,n){return(r<<24|e<<16|t<<8|Math.round(n*255)<<0)>>>0},IE=function(r,e){if(r.type===17)return r.number;if(r.type===16){var t=e===3?1:255;return e===3?r.number/100*t:Math.round(r.number/100*t)}return 0},kE=function(r,e){var t=e.filter(Kh);if(t.length===3){var n=t.map(IE),i=n[0],a=n[1],s=n[2];return Pa(i,a,s,1)}if(t.length===4){var o=t.map(IE),i=o[0],a=o[1],s=o[2],A=o[3];return Pa(i,a,s,A)}return 0};function rg(r,e,t){return t<0&&(t+=1),t>=1&&(t-=1),t<1/6?(e-r)*t*6+r:t<1/2?e:t<2/3?(e-r)*6*(2/3-t)+r:r}var LE=function(r,e){var t=e.filter(Kh),n=t[0],i=t[1],a=t[2],s=t[3],o=(n.type===17?ni(n.number):zh.parse(r,n))/(Math.PI*2),A=pn(i)?i.number/100:0,l=pn(a)?a.number/100:0,c=typeof s<"u"&&pn(s)?kt(s,1):1;if(A===0)return Pa(l*255,l*255,l*255,1);var u=l<=.5?l*(A+1):l+A-l*A,h=l*2-u,d=rg(h,u,o+1/3),f=rg(h,u,o),g=rg(h,u,o-1/3);return Pa(d*255,f*255,g*255,c)},Y5={hsl:LE,hsla:LE,rgb:kE,rgba:kE},QE=function(r,e){return Wa.parse(r,ek.create(e).parseComponentValue())},dl={ALICEBLUE:4042850303,ANTIQUEWHITE:4209760255,AQUA:16777215,AQUAMARINE:2147472639,AZURE:4043309055,BEIGE:4126530815,BISQUE:4293182719,BLACK:255,BLANCHEDALMOND:4293643775,BLUE:65535,BLUEVIOLET:2318131967,BROWN:2771004159,BURLYWOOD:3736635391,CADETBLUE:1604231423,CHARTREUSE:2147418367,CHOCOLATE:3530104575,CORAL:4286533887,CORNFLOWERBLUE:1687547391,CORNSILK:4294499583,CRIMSON:3692313855,CYAN:16777215,DARKBLUE:35839,DARKCYAN:9145343,DARKGOLDENROD:3095837695,DARKGRAY:2846468607,DARKGREEN:6553855,DARKGREY:2846468607,DARKKHAKI:3182914559,DARKMAGENTA:2332068863,DARKOLIVEGREEN:1433087999,DARKORANGE:4287365375,DARKORCHID:2570243327,DARKRED:2332033279,DARKSALMON:3918953215,DARKSEAGREEN:2411499519,DARKSLATEBLUE:1211993087,DARKSLATEGRAY:793726975,DARKSLATEGREY:793726975,DARKTURQUOISE:13554175,DARKVIOLET:2483082239,DEEPPINK:4279538687,DEEPSKYBLUE:12582911,DIMGRAY:1768516095,DIMGREY:1768516095,DODGERBLUE:512819199,FIREBRICK:2988581631,FLORALWHITE:4294635775,FORESTGREEN:579543807,FUCHSIA:4278255615,GAINSBORO:3705462015,GHOSTWHITE:4177068031,GOLD:4292280575,GOLDENROD:3668254975,GRAY:2155905279,GREEN:8388863,GREENYELLOW:2919182335,GREY:2155905279,HONEYDEW:4043305215,HOTPINK:4285117695,INDIANRED:3445382399,INDIGO:1258324735,IVORY:4294963455,KHAKI:4041641215,LAVENDER:3873897215,LAVENDERBLUSH:4293981695,LAWNGREEN:2096890111,LEMONCHIFFON:4294626815,LIGHTBLUE:2916673279,LIGHTCORAL:4034953471,LIGHTCYAN:3774873599,LIGHTGOLDENRODYELLOW:4210742015,LIGHTGRAY:3553874943,LIGHTGREEN:2431553791,LIGHTGREY:3553874943,LIGHTPINK:4290167295,LIGHTSALMON:4288707327,LIGHTSEAGREEN:548580095,LIGHTSKYBLUE:2278488831,LIGHTSLATEGRAY:2005441023,LIGHTSLATEGREY:2005441023,LIGHTSTEELBLUE:2965692159,LIGHTYELLOW:4294959359,LIME:16711935,LIMEGREEN:852308735,LINEN:4210091775,MAGENTA:4278255615,MAROON:2147483903,MEDIUMAQUAMARINE:1724754687,MEDIUMBLUE:52735,MEDIUMORCHID:3126187007,MEDIUMPURPLE:2473647103,MEDIUMSEAGREEN:1018393087,MEDIUMSLATEBLUE:2070474495,MEDIUMSPRINGGREEN:16423679,MEDIUMTURQUOISE:1221709055,MEDIUMVIOLETRED:3340076543,MIDNIGHTBLUE:421097727,MINTCREAM:4127193855,MISTYROSE:4293190143,MOCCASIN:4293178879,NAVAJOWHITE:4292783615,NAVY:33023,OLDLACE:4260751103,OLIVE:2155872511,OLIVEDRAB:1804477439,ORANGE:4289003775,ORANGERED:4282712319,ORCHID:3664828159,PALEGOLDENROD:4008225535,PALEGREEN:2566625535,PALETURQUOISE:2951671551,PALEVIOLETRED:3681588223,PAPAYAWHIP:4293907967,PEACHPUFF:4292524543,PERU:3448061951,PINK:4290825215,PLUM:3718307327,POWDERBLUE:2967529215,PURPLE:2147516671,REBECCAPURPLE:1714657791,RED:4278190335,ROSYBROWN:3163525119,ROYALBLUE:1097458175,SADDLEBROWN:2336560127,SALMON:4202722047,SANDYBROWN:4104413439,SEAGREEN:780883967,SEASHELL:4294307583,SIENNA:2689740287,SILVER:3233857791,SKYBLUE:2278484991,SLATEBLUE:1784335871,SLATEGRAY:1887473919,SLATEGREY:1887473919,SNOW:4294638335,SPRINGGREEN:16744447,STEELBLUE:1182971135,TAN:3535047935,TEAL:8421631,THISTLE:3636451583,TOMATO:4284696575,TRANSPARENT:0,TURQUOISE:1088475391,VIOLET:4001558271,WHEAT:4125012991,WHITE:4294967295,WHITESMOKE:4126537215,YELLOW:4294902015,YELLOWGREEN:2597139199},X5={name:"background-clip",initialValue:"border-box",prefix:!1,type:1,parse:function(r,e){return e.map(function(t){if(nn(t))switch(t.value){case"padding-box":return 1;case"content-box":return 2}return 0})}},Z5={name:"background-color",initialValue:"transparent",prefix:!1,type:3,format:"color"},Vh=function(r,e){var t=Wa.parse(r,e[0]),n=e[1];return n&&pn(n)?{color:t,stop:n}:{color:t,stop:null}},NE=function(r,e){var t=r[0],n=r[r.length-1];t.stop===null&&(t.stop=Kn),n.stop===null&&(n.stop=Ua);for(var i=[],a=0,s=0;s<r.length;s++){var o=r[s].stop;if(o!==null){var A=kt(o,e);A>a?i.push(A):i.push(a),a=A}else i.push(null)}for(var l=null,s=0;s<i.length;s++){var c=i[s];if(c===null)l===null&&(l=s);else if(l!==null){for(var u=s-l,h=i[l-1],d=(c-h)/(u+1),f=1;f<=u;f++)i[l+f-1]=d*f;l=null}}return r.map(function(g,v){var p=g.color;return{color:p,stop:Math.max(Math.min(1,i[v]/e),0)}})},J5=function(r,e,t){var n=e/2,i=t/2,a=kt(r[0],e)-n,s=i-kt(r[1],t);return(Math.atan2(s,a)+Math.PI*2)%(Math.PI*2)},eG=function(r,e,t){var n=typeof r=="number"?r:J5(r,e,t),i=Math.abs(e*Math.sin(n))+Math.abs(t*Math.cos(n)),a=e/2,s=t/2,o=i/2,A=Math.sin(n-Math.PI/2)*o,l=Math.cos(n-Math.PI/2)*o;return[i,a-l,a+l,s-A,s+A]},ui=function(r,e){return Math.sqrt(r*r+e*e)},UE=function(r,e,t,n,i){var a=[[0,0],[0,e],[r,0],[r,e]];return a.reduce(function(s,o){var A=o[0],l=o[1],c=ui(t-A,n-l);return(i?c<s.optimumDistance:c>s.optimumDistance)?{optimumCorner:o,optimumDistance:c}:s},{optimumDistance:i?1/0:-1/0,optimumCorner:null}).optimumCorner},tG=function(r,e,t,n,i){var a=0,s=0;switch(r.size){case 0:r.shape===0?a=s=Math.min(Math.abs(e),Math.abs(e-n),Math.abs(t),Math.abs(t-i)):r.shape===1&&(a=Math.min(Math.abs(e),Math.abs(e-n)),s=Math.min(Math.abs(t),Math.abs(t-i)));break;case 2:if(r.shape===0)a=s=Math.min(ui(e,t),ui(e,t-i),ui(e-n,t),ui(e-n,t-i));else if(r.shape===1){var o=Math.min(Math.abs(t),Math.abs(t-i))/Math.min(Math.abs(e),Math.abs(e-n)),A=UE(n,i,e,t,!0),l=A[0],c=A[1];a=ui(l-e,(c-t)/o),s=o*a}break;case 1:r.shape===0?a=s=Math.max(Math.abs(e),Math.abs(e-n),Math.abs(t),Math.abs(t-i)):r.shape===1&&(a=Math.max(Math.abs(e),Math.abs(e-n)),s=Math.max(Math.abs(t),Math.abs(t-i)));break;case 3:if(r.shape===0)a=s=Math.max(ui(e,t),ui(e,t-i),ui(e-n,t),ui(e-n,t-i));else if(r.shape===1){var o=Math.max(Math.abs(t),Math.abs(t-i))/Math.max(Math.abs(e),Math.abs(e-n)),u=UE(n,i,e,t,!1),l=u[0],c=u[1];a=ui(l-e,(c-t)/o),s=o*a}break}return Array.isArray(r.size)&&(a=kt(r.size[0],n),s=r.size.length===2?kt(r.size[1],i):a),[a,s]},nG=function(r,e){var t=ni(180),n=[];return Wi(e).forEach(function(i,a){if(a===0){var s=i[0];if(s.type===20&&s.value==="to"){t=ok(i);return}else if(sk(s)){t=zh.parse(r,s);return}}var o=Vh(r,i);n.push(o)}),{angle:t,stops:n,type:1}},Ic=function(r,e){var t=ni(180),n=[];return Wi(e).forEach(function(i,a){if(a===0){var s=i[0];if(s.type===20&&["top","left","right","bottom"].indexOf(s.value)!==-1){t=ok(i);return}else if(sk(s)){t=(zh.parse(r,s)+ni(270))%ni(360);return}}var o=Vh(r,i);n.push(o)}),{angle:t,stops:n,type:1}},rG=function(r,e){var t=ni(180),n=[],i=1,a=0,s=3,o=[];return Wi(e).forEach(function(A,l){var c=A[0];if(l===0){if(nn(c)&&c.value==="linear"){i=1;return}else if(nn(c)&&c.value==="radial"){i=2;return}}if(c.type===18){if(c.name==="from"){var u=Wa.parse(r,c.values[0]);n.push({stop:Kn,color:u})}else if(c.name==="to"){var u=Wa.parse(r,c.values[0]);n.push({stop:Ua,color:u})}else if(c.name==="color-stop"){var h=c.values.filter(Kh);if(h.length===2){var u=Wa.parse(r,h[1]),d=h[0];Gh(d)&&n.push({stop:{type:16,number:d.number*100,flags:d.flags},color:u})}}}}),i===1?{angle:(t+ni(180))%ni(360),stops:n,type:i}:{size:s,shape:a,stops:n,position:o,type:i}},Ak="closest-side",lk="farthest-side",ck="closest-corner",uk="farthest-corner",hk="circle",dk="ellipse",fk="cover",gk="contain",iG=function(r,e){var t=0,n=3,i=[],a=[];return Wi(e).forEach(function(s,o){var A=!0;if(o===0){var l=!1;A=s.reduce(function(u,h){if(l)if(nn(h))switch(h.value){case"center":return a.push(iB),u;case"top":case"left":return a.push(Kn),u;case"right":case"bottom":return a.push(Ua),u}else(pn(h)||es(h))&&a.push(h);else if(nn(h))switch(h.value){case hk:return t=0,!1;case dk:return t=1,!1;case"at":return l=!0,!1;case Ak:return n=0,!1;case fk:case lk:return n=1,!1;case gk:case ck:return n=2,!1;case uk:return n=3,!1}else if(es(h)||pn(h))return Array.isArray(n)||(n=[]),n.push(h),!1;return u},A)}if(A){var c=Vh(r,s);i.push(c)}}),{size:n,shape:t,stops:i,position:a,type:2}},kc=function(r,e){var t=0,n=3,i=[],a=[];return Wi(e).forEach(function(s,o){var A=!0;if(o===0?A=s.reduce(function(c,u){if(nn(u))switch(u.value){case"center":return a.push(iB),!1;case"top":case"left":return a.push(Kn),!1;case"right":case"bottom":return a.push(Ua),!1}else if(pn(u)||es(u))return a.push(u),!1;return c},A):o===1&&(A=s.reduce(function(c,u){if(nn(u))switch(u.value){case hk:return t=0,!1;case dk:return t=1,!1;case gk:case Ak:return n=0,!1;case lk:return n=1,!1;case ck:return n=2,!1;case fk:case uk:return n=3,!1}else if(es(u)||pn(u))return Array.isArray(n)||(n=[]),n.push(u),!1;return c},A)),A){var l=Vh(r,s);i.push(l)}}),{size:n,shape:t,stops:i,position:a,type:2}},aG=function(r){return r.type===1},sG=function(r){return r.type===2},aB={name:"image",parse:function(r,e){if(e.type===22){var t={url:e.value,type:0};return r.cache.addImage(e.value),t}if(e.type===18){var n=vk[e.name];if(typeof n>"u")throw new Error('Attempting to parse an unsupported image function "'+e.name+'"');return n(r,e.values)}throw new Error("Unsupported image type "+e.type)}};function oG(r){return!(r.type===20&&r.value==="none")&&(r.type!==18||!!vk[r.name])}var vk={"linear-gradient":nG,"-moz-linear-gradient":Ic,"-ms-linear-gradient":Ic,"-o-linear-gradient":Ic,"-webkit-linear-gradient":Ic,"radial-gradient":iG,"-moz-radial-gradient":kc,"-ms-radial-gradient":kc,"-o-radial-gradient":kc,"-webkit-radial-gradient":kc,"-webkit-gradient":rG},AG={name:"background-image",initialValue:"none",type:1,prefix:!1,parse:function(r,e){if(e.length===0)return[];var t=e[0];return t.type===20&&t.value==="none"?[]:e.filter(function(n){return Kh(n)&&oG(n)}).map(function(n){return aB.parse(r,n)})}},lG={name:"background-origin",initialValue:"border-box",prefix:!1,type:1,parse:function(r,e){return e.map(function(t){if(nn(t))switch(t.value){case"padding-box":return 1;case"content-box":return 2}return 0})}},cG={name:"background-position",initialValue:"0% 0%",type:1,prefix:!1,parse:function(r,e){return Wi(e).map(function(t){return t.filter(pn)}).map(tk)}},uG={name:"background-repeat",initialValue:"repeat",prefix:!1,type:1,parse:function(r,e){return Wi(e).map(function(t){return t.filter(nn).map(function(n){return n.value}).join(" ")}).map(hG)}},hG=function(r){switch(r){case"no-repeat":return 1;case"repeat-x":case"repeat no-repeat":return 2;case"repeat-y":case"no-repeat repeat":return 3;default:return 0}},Do;(function(r){r.AUTO="auto",r.CONTAIN="contain",r.COVER="cover"})(Do||(Do={}));var dG={name:"background-size",initialValue:"0",prefix:!1,type:1,parse:function(r,e){return Wi(e).map(function(t){return t.filter(fG)})}},fG=function(r){return nn(r)||pn(r)},jh=function(r){return{name:"border-"+r+"-color",initialValue:"transparent",prefix:!1,type:3,format:"color"}},gG=jh("top"),vG=jh("right"),pG=jh("bottom"),yG=jh("left"),Wh=function(r){return{name:"border-radius-"+r,initialValue:"0 0",prefix:!1,type:1,parse:function(e,t){return tk(t.filter(pn))}}},mG=Wh("top-left"),wG=Wh("top-right"),BG=Wh("bottom-right"),bG=Wh("bottom-left"),qh=function(r){return{name:"border-"+r+"-style",initialValue:"solid",prefix:!1,type:2,parse:function(e,t){switch(t){case"none":return 0;case"dashed":return 2;case"dotted":return 3;case"double":return 4}return 1}}},EG=qh("top"),xG=qh("right"),CG=qh("bottom"),SG=qh("left"),$h=function(r){return{name:"border-"+r+"-width",initialValue:"0",type:0,prefix:!1,parse:function(e,t){return Ll(t)?t.number:0}}},FG=$h("top"),TG=$h("right"),MG=$h("bottom"),OG=$h("left"),_G={name:"color",initialValue:"transparent",prefix:!1,type:3,format:"color"},IG={name:"direction",initialValue:"ltr",prefix:!1,type:2,parse:function(r,e){return e==="rtl"?1:0}},kG={name:"display",initialValue:"inline-block",prefix:!1,type:1,parse:function(r,e){return e.filter(nn).reduce(function(t,n){return t|LG(n.value)},0)}},LG=function(r){switch(r){case"block":case"-webkit-box":return 2;case"inline":return 4;case"run-in":return 8;case"flow":return 16;case"flow-root":return 32;case"table":return 64;case"flex":case"-webkit-flex":return 128;case"grid":case"-ms-grid":return 256;case"ruby":return 512;case"subgrid":return 1024;case"list-item":return 2048;case"table-row-group":return 4096;case"table-header-group":return 8192;case"table-footer-group":return 16384;case"table-row":return 32768;case"table-cell":return 65536;case"table-column-group":return 131072;case"table-column":return 262144;case"table-caption":return 524288;case"ruby-base":return 1048576;case"ruby-text":return 2097152;case"ruby-base-container":return 4194304;case"ruby-text-container":return 8388608;case"contents":return 16777216;case"inline-block":return 33554432;case"inline-list-item":return 67108864;case"inline-table":return 134217728;case"inline-flex":return 268435456;case"inline-grid":return 536870912}return 0},QG={name:"float",initialValue:"none",prefix:!1,type:2,parse:function(r,e){switch(e){case"left":return 1;case"right":return 2;case"inline-start":return 3;case"inline-end":return 4}return 0}},NG={name:"letter-spacing",initialValue:"0",prefix:!1,type:0,parse:function(r,e){return e.type===20&&e.value==="normal"?0:e.type===17||e.type===15?e.number:0}},oh;(function(r){r.NORMAL="normal",r.STRICT="strict"})(oh||(oh={}));var UG={name:"line-break",initialValue:"normal",prefix:!1,type:2,parse:function(r,e){return e==="strict"?oh.STRICT:oh.NORMAL}},PG={name:"line-height",initialValue:"normal",prefix:!1,type:4},PE=function(r,e){return nn(r)&&r.value==="normal"?1.2*e:r.type===17?e*r.number:pn(r)?kt(r,e):e},RG={name:"list-style-image",initialValue:"none",type:0,prefix:!1,parse:function(r,e){return e.type===20&&e.value==="none"?null:aB.parse(r,e)}},DG={name:"list-style-position",initialValue:"outside",prefix:!1,type:2,parse:function(r,e){return e==="inside"?0:1}},HG={name:"list-style-type",initialValue:"none",prefix:!1,type:2,parse:function(r,e){switch(e){case"disc":return 0;case"circle":return 1;case"square":return 2;case"decimal":return 3;case"cjk-decimal":return 4;case"decimal-leading-zero":return 5;case"lower-roman":return 6;case"upper-roman":return 7;case"lower-greek":return 8;case"lower-alpha":return 9;case"upper-alpha":return 10;case"arabic-indic":return 11;case"armenian":return 12;case"bengali":return 13;case"cambodian":return 14;case"cjk-earthly-branch":return 15;case"cjk-heavenly-stem":return 16;case"cjk-ideographic":return 17;case"devanagari":return 18;case"ethiopic-numeric":return 19;case"georgian":return 20;case"gujarati":return 21;case"gurmukhi":return 22;case"hebrew":return 22;case"hiragana":return 23;case"hiragana-iroha":return 24;case"japanese-formal":return 25;case"japanese-informal":return 26;case"kannada":return 27;case"katakana":return 28;case"katakana-iroha":return 29;case"khmer":return 30;case"korean-hangul-formal":return 31;case"korean-hanja-formal":return 32;case"korean-hanja-informal":return 33;case"lao":return 34;case"lower-armenian":return 35;case"malayalam":return 36;case"mongolian":return 37;case"myanmar":return 38;case"oriya":return 39;case"persian":return 40;case"simp-chinese-formal":return 41;case"simp-chinese-informal":return 42;case"tamil":return 43;case"telugu":return 44;case"thai":return 45;case"tibetan":return 46;case"trad-chinese-formal":return 47;case"trad-chinese-informal":return 48;case"upper-armenian":return 49;case"disclosure-open":return 50;case"disclosure-closed":return 51;default:return-1}}},Yh=function(r){return{name:"margin-"+r,initialValue:"0",prefix:!1,type:4}},GG=Yh("top"),KG=Yh("right"),zG=Yh("bottom"),VG=Yh("left"),jG={name:"overflow",initialValue:"visible",prefix:!1,type:1,parse:function(r,e){return e.filter(nn).map(function(t){switch(t.value){case"hidden":return 1;case"scroll":return 2;case"clip":return 3;case"auto":return 4;default:return 0}})}},WG={name:"overflow-wrap",initialValue:"normal",prefix:!1,type:2,parse:function(r,e){return e==="break-word"?"break-word":"normal"}},Xh=function(r){return{name:"padding-"+r,initialValue:"0",prefix:!1,type:3,format:"length-percentage"}},qG=Xh("top"),$G=Xh("right"),YG=Xh("bottom"),XG=Xh("left"),ZG={name:"text-align",initialValue:"left",prefix:!1,type:2,parse:function(r,e){switch(e){case"right":return 2;case"center":case"justify":return 1;default:return 0}}},JG={name:"position",initialValue:"static",prefix:!1,type:2,parse:function(r,e){switch(e){case"relative":return 1;case"absolute":return 2;case"fixed":return 3;case"sticky":return 4}return 0}},eK={name:"text-shadow",initialValue:"none",type:1,prefix:!1,parse:function(r,e){return e.length===1&&e1(e[0],"none")?[]:Wi(e).map(function(t){for(var n={color:dl.TRANSPARENT,offsetX:Kn,offsetY:Kn,blur:Kn},i=0,a=0;a<t.length;a++){var s=t[a];es(s)?(i===0?n.offsetX=s:i===1?n.offsetY=s:n.blur=s,i++):n.color=Wa.parse(r,s)}return n})}},tK={name:"text-transform",initialValue:"none",prefix:!1,type:2,parse:function(r,e){switch(e){case"uppercase":return 2;case"lowercase":return 1;case"capitalize":return 3}return 0}},nK={name:"transform",initialValue:"none",prefix:!0,type:0,parse:function(r,e){if(e.type===20&&e.value==="none")return null;if(e.type===18){var t=aK[e.name];if(typeof t>"u")throw new Error('Attempting to parse an unsupported transform function "'+e.name+'"');return t(e.values)}return null}},rK=function(r){var e=r.filter(function(t){return t.type===17}).map(function(t){return t.number});return e.length===6?e:null},iK=function(r){var e=r.filter(function(A){return A.type===17}).map(function(A){return A.number}),t=e[0],n=e[1];e[2],e[3];var i=e[4],a=e[5];e[6],e[7],e[8],e[9],e[10],e[11];var s=e[12],o=e[13];return e[14],e[15],e.length===16?[t,n,i,a,s,o]:null},aK={matrix:rK,matrix3d:iK},RE={type:16,number:50,flags:kl},sK=[RE,RE],oK={name:"transform-origin",initialValue:"50% 50%",prefix:!0,type:1,parse:function(r,e){var t=e.filter(pn);return t.length!==2?sK:[t[0],t[1]]}},AK={name:"visible",initialValue:"none",prefix:!1,type:2,parse:function(r,e){switch(e){case"hidden":return 1;case"collapse":return 2;default:return 0}}},ZA;(function(r){r.NORMAL="normal",r.BREAK_ALL="break-all",r.KEEP_ALL="keep-all"})(ZA||(ZA={}));var lK={name:"word-break",initialValue:"normal",prefix:!1,type:2,parse:function(r,e){switch(e){case"break-all":return ZA.BREAK_ALL;case"keep-all":return ZA.KEEP_ALL;default:return ZA.NORMAL}}},cK={name:"z-index",initialValue:"auto",prefix:!1,type:0,parse:function(r,e){if(e.type===20)return{auto:!0,order:0};if(Gh(e))return{auto:!1,order:e.number};throw new Error("Invalid z-index number parsed")}},pk={name:"time",parse:function(r,e){if(e.type===15)switch(e.unit.toLowerCase()){case"s":return 1e3*e.number;case"ms":return e.number}throw new Error("Unsupported time type")}},uK={name:"opacity",initialValue:"1",type:0,prefix:!1,parse:function(r,e){return Gh(e)?e.number:1}},hK={name:"text-decoration-color",initialValue:"transparent",prefix:!1,type:3,format:"color"},dK={name:"text-decoration-line",initialValue:"none",prefix:!1,type:1,parse:function(r,e){return e.filter(nn).map(function(t){switch(t.value){case"underline":return 1;case"overline":return 2;case"line-through":return 3;case"none":return 4}return 0}).filter(function(t){return t!==0})}},fK={name:"font-family",initialValue:"",prefix:!1,type:1,parse:function(r,e){var t=[],n=[];return e.forEach(function(i){switch(i.type){case 20:case 0:t.push(i.value);break;case 17:t.push(i.number.toString());break;case 4:n.push(t.join(" ")),t.length=0;break}}),t.length&&n.push(t.join(" ")),n.map(function(i){return i.indexOf(" ")===-1?i:"'"+i+"'"})}},gK={name:"font-size",initialValue:"0",prefix:!1,type:3,format:"length"},vK={name:"font-weight",initialValue:"normal",type:0,prefix:!1,parse:function(r,e){return Gh(e)?e.number:nn(e)&&e.value==="bold"?700:400}},pK={name:"font-variant",initialValue:"none",type:1,prefix:!1,parse:function(r,e){return e.filter(nn).map(function(t){return t.value})}},yK={name:"font-style",initialValue:"normal",prefix:!1,type:2,parse:function(r,e){switch(e){case"oblique":return"oblique";case"italic":return"italic";default:return"normal"}}},xn=function(r,e){return(r&e)!==0},mK={name:"duration",initialValue:"0s",prefix:!1,type:1,parse:function(r,e){return e.filter(Ll).map(function(t){return pk.parse(r,t)})}},wK={name:"box-shadow",initialValue:"none",type:1,prefix:!1,parse:function(r,e){return e.length===1&&e1(e[0],"none")?[]:Wi(e).map(function(t){for(var n={color:255,offsetX:Kn,offsetY:Kn,blur:Kn,spread:Kn,inset:!1},i=0,a=0;a<t.length;a++){var s=t[a];e1(s,"inset")?n.inset=!0:es(s)?(i===0?n.offsetX=s:i===1?n.offsetY=s:i===2?n.blur=s:n.spread=s,i++):n.color=Wa.parse(r,s)}return n})}},BK={name:"paint-order",initialValue:"normal",prefix:!1,type:1,parse:function(r,e){var t=[0,1,2],n=[];return e.filter(nn).forEach(function(i){switch(i.value){case"stroke":n.push(1);break;case"fill":n.push(0);break;case"markers":n.push(2);break}}),t.forEach(function(i){n.indexOf(i)===-1&&n.push(i)}),n}},bK={name:"-webkit-text-stroke-color",initialValue:"currentcolor",prefix:!1,type:3,format:"color"},EK={name:"-webkit-text-stroke-width",initialValue:"0",type:0,prefix:!1,parse:function(r,e){return Ll(e)?e.number:0}},xK=(function(){function r(e,t){var n,i;this.animationDuration=Ie(e,mK,t.animationDuration),this.backgroundClip=Ie(e,X5,t.backgroundClip),this.backgroundColor=Ie(e,Z5,t.backgroundColor),this.backgroundImage=Ie(e,AG,t.backgroundImage),this.backgroundOrigin=Ie(e,lG,t.backgroundOrigin),this.backgroundPosition=Ie(e,cG,t.backgroundPosition),this.backgroundRepeat=Ie(e,uG,t.backgroundRepeat),this.backgroundSize=Ie(e,dG,t.backgroundSize),this.borderTopColor=Ie(e,gG,t.borderTopColor),this.borderRightColor=Ie(e,vG,t.borderRightColor),this.borderBottomColor=Ie(e,pG,t.borderBottomColor),this.borderLeftColor=Ie(e,yG,t.borderLeftColor),this.borderTopLeftRadius=Ie(e,mG,t.borderTopLeftRadius),this.borderTopRightRadius=Ie(e,wG,t.borderTopRightRadius),this.borderBottomRightRadius=Ie(e,BG,t.borderBottomRightRadius),this.borderBottomLeftRadius=Ie(e,bG,t.borderBottomLeftRadius),this.borderTopStyle=Ie(e,EG,t.borderTopStyle),this.borderRightStyle=Ie(e,xG,t.borderRightStyle),this.borderBottomStyle=Ie(e,CG,t.borderBottomStyle),this.borderLeftStyle=Ie(e,SG,t.borderLeftStyle),this.borderTopWidth=Ie(e,FG,t.borderTopWidth),this.borderRightWidth=Ie(e,TG,t.borderRightWidth),this.borderBottomWidth=Ie(e,MG,t.borderBottomWidth),this.borderLeftWidth=Ie(e,OG,t.borderLeftWidth),this.boxShadow=Ie(e,wK,t.boxShadow),this.color=Ie(e,_G,t.color),this.direction=Ie(e,IG,t.direction),this.display=Ie(e,kG,t.display),this.float=Ie(e,QG,t.cssFloat),this.fontFamily=Ie(e,fK,t.fontFamily),this.fontSize=Ie(e,gK,t.fontSize),this.fontStyle=Ie(e,yK,t.fontStyle),this.fontVariant=Ie(e,pK,t.fontVariant),this.fontWeight=Ie(e,vK,t.fontWeight),this.letterSpacing=Ie(e,NG,t.letterSpacing),this.lineBreak=Ie(e,UG,t.lineBreak),this.lineHeight=Ie(e,PG,t.lineHeight),this.listStyleImage=Ie(e,RG,t.listStyleImage),this.listStylePosition=Ie(e,DG,t.listStylePosition),this.listStyleType=Ie(e,HG,t.listStyleType),this.marginTop=Ie(e,GG,t.marginTop),this.marginRight=Ie(e,KG,t.marginRight),this.marginBottom=Ie(e,zG,t.marginBottom),this.marginLeft=Ie(e,VG,t.marginLeft),this.opacity=Ie(e,uK,t.opacity);var a=Ie(e,jG,t.overflow);this.overflowX=a[0],this.overflowY=a[a.length>1?1:0],this.overflowWrap=Ie(e,WG,t.overflowWrap),this.paddingTop=Ie(e,qG,t.paddingTop),this.paddingRight=Ie(e,$G,t.paddingRight),this.paddingBottom=Ie(e,YG,t.paddingBottom),this.paddingLeft=Ie(e,XG,t.paddingLeft),this.paintOrder=Ie(e,BK,t.paintOrder),this.position=Ie(e,JG,t.position),this.textAlign=Ie(e,ZG,t.textAlign),this.textDecorationColor=Ie(e,hK,(n=t.textDecorationColor)!==null&&n!==void 0?n:t.color),this.textDecorationLine=Ie(e,dK,(i=t.textDecorationLine)!==null&&i!==void 0?i:t.textDecoration),this.textShadow=Ie(e,eK,t.textShadow),this.textTransform=Ie(e,tK,t.textTransform),this.transform=Ie(e,nK,t.transform),this.transformOrigin=Ie(e,oK,t.transformOrigin),this.visibility=Ie(e,AK,t.visibility),this.webkitTextStrokeColor=Ie(e,bK,t.webkitTextStrokeColor),this.webkitTextStrokeWidth=Ie(e,EK,t.webkitTextStrokeWidth),this.wordBreak=Ie(e,lK,t.wordBreak),this.zIndex=Ie(e,cK,t.zIndex)}return r.prototype.isVisible=function(){return this.display>0&&this.opacity>0&&this.visibility===0},r.prototype.isTransparent=function(){return Ro(this.backgroundColor)},r.prototype.isTransformed=function(){return this.transform!==null},r.prototype.isPositioned=function(){return this.position!==0},r.prototype.isPositionedWithZIndex=function(){return this.isPositioned()&&!this.zIndex.auto},r.prototype.isFloating=function(){return this.float!==0},r.prototype.isInlineLevel=function(){return xn(this.display,4)||xn(this.display,33554432)||xn(this.display,268435456)||xn(this.display,536870912)||xn(this.display,67108864)||xn(this.display,134217728)},r})(),Ie=function(r,e,t){var n=new JI,i=t!==null&&typeof t<"u"?t.toString():e.initialValue;n.write(i);var a=new ek(n.read());switch(e.type){case 2:var s=a.parseComponentValue();return e.parse(r,nn(s)?s.value:e.initialValue);case 0:return e.parse(r,a.parseComponentValue());case 1:return e.parse(r,a.parseComponentValues());case 4:return a.parseComponentValue();case 3:switch(e.format){case"angle":return zh.parse(r,a.parseComponentValue());case"color":return Wa.parse(r,a.parseComponentValue());case"image":return aB.parse(r,a.parseComponentValue());case"length":var o=a.parseComponentValue();return es(o)?o:Kn;case"length-percentage":var A=a.parseComponentValue();return pn(A)?A:Kn;case"time":return pk.parse(r,a.parseComponentValue())}break}},CK="data-html2canvas-debug",SK=function(r){var e=r.getAttribute(CK);switch(e){case"all":return 1;case"clone":return 2;case"parse":return 3;case"render":return 4;default:return 0}},DE=function(r,e){var t=SK(r);return t===1||e===t},qi=(function(){function r(e,t){if(this.context=e,this.textNodes=[],this.elements=[],this.flags=0,DE(t,3))debugger;this.styles=new xK(e,window.getComputedStyle(t,null)),S8(t)&&(this.styles.animationDuration.some(function(n){return n>0})&&(t.style.animationDuration="0s"),this.styles.transform!==null&&(t.style.transform="none")),this.bounds=nB(this.context,t),DE(t,4)&&(this.flags|=16)}return r})(),FK="AAAAAAAAAAAAEA4AGBkAAFAaAAACAAAAAAAIABAAGAAwADgACAAQAAgAEAAIABAACAAQAAgAEAAIABAACAAQAAgAEAAIABAAQABIAEQATAAIABAACAAQAAgAEAAIABAAVABcAAgAEAAIABAACAAQAGAAaABwAHgAgACIAI4AlgAIABAAmwCjAKgAsAC2AL4AvQDFAMoA0gBPAVYBWgEIAAgACACMANoAYgFkAWwBdAF8AX0BhQGNAZUBlgGeAaMBlQGWAasBswF8AbsBwwF0AcsBYwHTAQgA2wG/AOMBdAF8AekB8QF0AfkB+wHiAHQBfAEIAAMC5gQIAAsCEgIIAAgAFgIeAggAIgIpAggAMQI5AkACygEIAAgASAJQAlgCYAIIAAgACAAKBQoFCgUTBRMFGQUrBSsFCAAIAAgACAAIAAgACAAIAAgACABdAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACABoAmgCrwGvAQgAbgJ2AggAHgEIAAgACADnAXsCCAAIAAgAgwIIAAgACAAIAAgACACKAggAkQKZAggAPADJAAgAoQKkAqwCsgK6AsICCADJAggA0AIIAAgACAAIANYC3gIIAAgACAAIAAgACABAAOYCCAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAkASoB+QIEAAgACAA8AEMCCABCBQgACABJBVAFCAAIAAgACAAIAAgACAAIAAgACABTBVoFCAAIAFoFCABfBWUFCAAIAAgACAAIAAgAbQUIAAgACAAIAAgACABzBXsFfQWFBYoFigWKBZEFigWKBYoFmAWfBaYFrgWxBbkFCAAIAAgACAAIAAgACAAIAAgACAAIAMEFCAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAMgFCADQBQgACAAIAAgACAAIAAgACAAIAAgACAAIAO4CCAAIAAgAiQAIAAgACABAAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAD0AggACAD8AggACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIANYFCAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAMDvwAIAAgAJAIIAAgACAAIAAgACAAIAAgACwMTAwgACAB9BOsEGwMjAwgAKwMyAwsFYgE3A/MEPwMIAEUDTQNRAwgAWQOsAGEDCAAIAAgACAAIAAgACABpAzQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFOgU0BTUFNgU3BTgFOQU6BTQFNQU2BTcFOAU5BToFNAU1BTYFNwU4BTkFIQUoBSwFCAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACABtAwgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACABMAEwACAAIAAgACAAIABgACAAIAAgACAC/AAgACAAyAQgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACACAAIAAwAAgACAAIAAgACAAIAAgACAAIAAAARABIAAgACAAIABQASAAIAAgAIABwAEAAjgCIABsAqAC2AL0AigDQAtwC+IJIQqVAZUBWQqVAZUBlQGVAZUBlQGrC5UBlQGVAZUBlQGVAZUBlQGVAXsKlQGVAbAK6wsrDGUMpQzlDJUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAZUBlQGVAfAKAAuZA64AtwCJALoC6ADwAAgAuACgA/oEpgO6AqsD+AAIAAgAswMIAAgACAAIAIkAuwP5AfsBwwPLAwgACAAIAAgACADRA9kDCAAIAOED6QMIAAgACAAIAAgACADuA/YDCAAIAP4DyQAIAAgABgQIAAgAXQAOBAgACAAIAAgACAAIABMECAAIAAgACAAIAAgACAD8AAQBCAAIAAgAGgQiBCoECAExBAgAEAEIAAgACAAIAAgACAAIAAgACAAIAAgACAA4BAgACABABEYECAAIAAgATAQYAQgAVAQIAAgACAAIAAgACAAIAAgACAAIAFoECAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAOQEIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAB+BAcACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAEABhgSMBAgACAAIAAgAlAQIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAwAEAAQABAADAAMAAwADAAQABAAEAAQABAAEAAQABHATAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAdQMIAAgACAAIAAgACAAIAMkACAAIAAgAfQMIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACACFA4kDCAAIAAgACAAIAOcBCAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAIcDCAAIAAgACAAIAAgACAAIAAgACAAIAJEDCAAIAAgACADFAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACABgBAgAZgQIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAbAQCBXIECAAIAHkECAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACABAAJwEQACjBKoEsgQIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAC6BMIECAAIAAgACAAIAAgACABmBAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAxwQIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAGYECAAIAAgAzgQIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAigWKBYoFigWKBYoFigWKBd0FXwUIAOIF6gXxBYoF3gT5BQAGCAaKBYoFigWKBYoFigWKBYoFigWKBYoFigXWBIoFigWKBYoFigWKBYoFigWKBYsFEAaKBYoFigWKBYoFigWKBRQGCACKBYoFigWKBQgACAAIANEECAAIABgGigUgBggAJgYIAC4GMwaKBYoF0wQ3Bj4GigWKBYoFigWKBYoFigWKBYoFigWKBYoFigUIAAgACAAIAAgACAAIAAgAigWKBYoFigWKBYoFigWKBYoFigWKBYoFigWKBYoFigWKBYoFigWKBYoFigWKBYoFigWKBYoFigWKBYoFigWLBf///////wQABAAEAAQABAAEAAQABAAEAAQAAwAEAAQAAgAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAAAAAAAAAAAAAAAAAAAAAAAAAOAAAAAAAAAAQADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAAAUAAAAFAAUAAAAFAAUAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAEAAQABAAEAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUABQAFAAUABQAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUAAQAAAAUABQAFAAUABQAFAAAAAAAFAAUAAAAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAUABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAFAAAAAAAFAAUAAQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABwAFAAUABQAFAAAABwAHAAcAAAAHAAcABwAFAAEAAAAAAAAAAAAAAAAAAAAAAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAcABwAFAAUABQAFAAcABwAFAAUAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAAAAQABAAAAAAAAAAAAAAAFAAUABQAFAAAABwAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAHAAcABwAHAAcAAAAHAAcAAAAAAAUABQAHAAUAAQAHAAEABwAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUABwABAAUABQAFAAUAAAAAAAAAAAAAAAEAAQABAAEAAQABAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABwAFAAUAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUAAQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQABQANAAQABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQABAAEAAQABAAEAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAEAAQABAAEAAQABAAEAAQABAAEAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAQABAAEAAQABAAEAAQABAAAAAAAAAAAAAAAAAAAAAAABQAHAAUABQAFAAAAAAAAAAcABQAFAAUABQAFAAQABAAEAAQABAAEAAQABAAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUAAAAFAAUABQAFAAUAAAAFAAUABQAAAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAAAAAAAAAAAAUABQAFAAcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAHAAUAAAAHAAcABwAFAAUABQAFAAUABQAFAAUABwAHAAcABwAFAAcABwAAAAUABQAFAAUABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABwAHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAUABwAHAAUABQAFAAUAAAAAAAcABwAAAAAABwAHAAUAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAABQAFAAcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAAABwAHAAcABQAFAAAAAAAAAAAABQAFAAAAAAAFAAUABQAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAABwAFAAUABQAFAAUAAAAFAAUABwAAAAcABwAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUAAAAFAAUABwAFAAUABQAFAAAAAAAHAAcAAAAAAAcABwAFAAAAAAAAAAAAAAAAAAAABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAcABwAAAAAAAAAHAAcABwAAAAcABwAHAAUAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAABQAHAAcABwAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABwAHAAcABwAAAAUABQAFAAAABQAFAAUABQAAAAAAAAAAAAAAAAAAAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAcABQAHAAcABQAHAAcAAAAFAAcABwAAAAcABwAFAAUAAAAAAAAAAAAAAAAAAAAFAAUAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAcABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAAAAUABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAUAAAAAAAAAAAAFAAcABwAFAAUABQAAAAUAAAAHAAcABwAHAAcABwAHAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUAAAAHAAUABQAFAAUABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAAABwAFAAUABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAUAAAAFAAAAAAAAAAAABwAHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABwAFAAUABQAFAAUAAAAFAAUAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUABQAFAAUABQAAAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABwAFAAUABQAFAAUABQAAAAUABQAHAAcABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAcABQAFAAAAAAAAAAAABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAcABQAFAAAAAAAAAAAAAAAAAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAHAAUABQAFAAUABQAFAAUABwAHAAcABwAHAAcABwAHAAUABwAHAAUABQAFAAUABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABwAHAAcABwAFAAUABwAHAAcAAAAAAAAAAAAHAAcABQAHAAcABwAHAAcABwAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAcABwAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABQAHAAUABQAFAAUABQAFAAUAAAAFAAAABQAAAAAABQAFAAUABQAFAAUABQAFAAcABwAHAAcABwAHAAUABQAFAAUABQAFAAUABQAFAAUAAAAAAAUABQAFAAUABQAHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUABwAFAAcABwAHAAcABwAFAAcABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAUABQAFAAUABwAHAAUABQAHAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAcABQAFAAcABwAHAAUABwAFAAUABQAHAAcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwAHAAcABwAHAAcABwAHAAUABQAFAAUABQAFAAUABQAHAAcABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUAAAAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAcABQAFAAUABQAFAAUABQAAAAAAAAAAAAUAAAAAAAAAAAAAAAAABQAAAAAABwAFAAUAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAAABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUAAAAFAAUABQAFAAUABQAFAAUABQAFAAAAAAAAAAAABQAAAAAAAAAFAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwAHAAUABQAHAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABwAHAAcABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAUABQAFAAUABQAHAAcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAcABwAFAAUABQAFAAcABwAFAAUABwAHAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAFAAcABwAFAAUABwAHAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAFAAcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUAAAAFAAUABQAAAAAABQAFAAAAAAAAAAAAAAAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABQAFAAcABwAAAAAAAAAAAAAABwAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABwAFAAcABwAFAAcABwAAAAcABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAAAAAAAAAAAAAAAAAFAAUABQAAAAUABQAAAAAAAAAAAAAABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAAAAAAAAAAAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABQAHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABwAFAAUABQAFAAUABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwAHAAcABQAFAAUABQAFAAUABQAFAAUABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAcABwAFAAUABQAHAAcABQAHAAUABQAAAAAAAAAAAAAAAAAFAAAABwAHAAcABQAFAAUABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABwAHAAcABwAAAAAABwAHAAAAAAAHAAcABwAAAAAAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAABwAHAAAAAAAFAAUABQAFAAUABQAFAAAAAAAAAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAcABwAFAAUABQAFAAUABQAFAAUABwAHAAUABQAFAAcABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAHAAcABQAFAAUABQAFAAUABwAFAAcABwAFAAcABQAFAAcABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAHAAcABQAFAAUABQAAAAAABwAHAAcABwAFAAUABwAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABwAHAAUABQAFAAUABQAFAAUABQAHAAcABQAHAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABwAFAAcABwAFAAUABQAFAAUABQAHAAUAAAAAAAAAAAAAAAAAAAAAAAcABwAFAAUABQAFAAcABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAcABwAFAAUABQAFAAUABQAFAAUABQAHAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAcABwAFAAUABQAFAAAAAAAFAAUABwAHAAcABwAFAAAAAAAAAAcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUABwAHAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABQAFAAUABQAFAAUABQAAAAUABQAFAAUABQAFAAcABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUAAAAHAAUABQAFAAUABQAFAAUABwAFAAUABwAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUAAAAAAAAABQAAAAUABQAAAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAcABwAHAAcAAAAFAAUAAAAHAAcABQAHAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABwAHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAAAAAAAAAAAAAAAAAAABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAAAAUABQAFAAAAAAAFAAUABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAAAAAAAAAAABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUABQAFAAUABQAAAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUABQAAAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAFAAUABQAAAAAABQAFAAUABQAFAAUABQAAAAUABQAAAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAAUABQAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQAFAAUABQAFAAUABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAFAAUABQAFAAUADgAOAA4ADgAOAA4ADwAPAA8ADwAPAA8ADwAPAA8ADwAPAA8ADwAPAA8ADwAPAA8ADwAPAA8ADwAPAA8ADwAPAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwAHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAcABwAHAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAAAAAAAAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAMAAwADAAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkAAAAAAAAAAAAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAKAAoACgAAAAAAAAAAAAsADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwACwAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAMAAwADAAAAAAADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAA4ADgAOAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4ADgAAAAAAAAAAAAAAAAAAAAAADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAA4ADgAOAA4ADgAOAA4ADgAOAAAAAAAAAAAADgAOAA4AAAAAAAAAAAAAAAAAAAAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAAAAAAAAAAAAAAAAAAAAAAAAAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAA4ADgAAAA4ADgAOAA4ADgAOAAAADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4AAAAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4AAAAAAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAAAA4AAAAOAAAAAAAAAAAAAAAAAA4AAAAAAAAAAAAAAAAADgAAAAAAAAAAAAAAAAAAAAAAAAAAAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAAAAAADgAAAAAAAAAAAA4AAAAOAAAAAAAAAAAADgAOAA4AAAAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAA4ADgAOAA4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAA4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4ADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAAAAAAAAAAAA4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAAAADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4ADgAOAA4ADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAAAAAADgAOAA4ADgAOAA4ADgAOAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAAAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4AAAAAAA4ADgAOAA4ADgAOAA4ADgAOAAAADgAOAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4AAAAAAAAAAAAAAAAADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAA4ADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAA4ADgAOAA4ADgAOAAAAAAAAAAAAAAAAAAAAAAAAAAAADgAOAA4ADgAOAA4AAAAAAAAAAAAAAAAAAAAAAA4ADgAOAA4ADgAOAA4ADgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4AAAAOAA4ADgAOAA4ADgAAAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4ADgAOAA4AAAAAAAAAAAA=",HE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",QA=typeof Uint8Array>"u"?[]:new Uint8Array(256);for(var Lc=0;Lc<HE.length;Lc++)QA[HE.charCodeAt(Lc)]=Lc;var TK=function(r){var e=r.length*.75,t=r.length,n,i=0,a,s,o,A;r[r.length-1]==="="&&(e--,r[r.length-2]==="="&&e--);var l=typeof ArrayBuffer<"u"&&typeof Uint8Array<"u"&&typeof Uint8Array.prototype.slice<"u"?new ArrayBuffer(e):new Array(e),c=Array.isArray(l)?l:new Uint8Array(l);for(n=0;n<t;n+=4)a=QA[r.charCodeAt(n)],s=QA[r.charCodeAt(n+1)],o=QA[r.charCodeAt(n+2)],A=QA[r.charCodeAt(n+3)],c[i++]=a<<2|s>>4,c[i++]=(s&15)<<4|o>>2,c[i++]=(o&3)<<6|A&63;return l},MK=function(r){for(var e=r.length,t=[],n=0;n<e;n+=2)t.push(r[n+1]<<8|r[n]);return t},OK=function(r){for(var e=r.length,t=[],n=0;n<e;n+=4)t.push(r[n+3]<<24|r[n+2]<<16|r[n+1]<<8|r[n]);return t},Ls=5,sB=11,ig=2,_K=sB-Ls,yk=65536>>Ls,IK=1<<Ls,ag=IK-1,kK=1024>>Ls,LK=yk+kK,QK=LK,NK=32,UK=QK+NK,PK=65536>>sB,RK=1<<_K,DK=RK-1,GE=function(r,e,t){return r.slice?r.slice(e,t):new Uint16Array(Array.prototype.slice.call(r,e,t))},HK=function(r,e,t){return r.slice?r.slice(e,t):new Uint32Array(Array.prototype.slice.call(r,e,t))},GK=function(r,e){var t=TK(r),n=Array.isArray(t)?OK(t):new Uint32Array(t),i=Array.isArray(t)?MK(t):new Uint16Array(t),a=24,s=GE(i,a/2,n[4]/2),o=n[5]===2?GE(i,(a+n[4])/2):HK(n,Math.ceil((a+n[4])/4));return new KK(n[0],n[1],n[2],n[3],s,o)},KK=(function(){function r(e,t,n,i,a,s){this.initialValue=e,this.errorValue=t,this.highStart=n,this.highValueIndex=i,this.index=a,this.data=s}return r.prototype.get=function(e){var t;if(e>=0){if(e<55296||e>56319&&e<=65535)return t=this.index[e>>Ls],t=(t<<ig)+(e&ag),this.data[t];if(e<=65535)return t=this.index[yk+(e-55296>>Ls)],t=(t<<ig)+(e&ag),this.data[t];if(e<this.highStart)return t=UK-PK+(e>>sB),t=this.index[t],t+=e>>Ls&DK,t=this.index[t],t=(t<<ig)+(e&ag),this.data[t];if(e<=1114111)return this.data[this.highValueIndex]}return this.errorValue},r})(),KE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",zK=typeof Uint8Array>"u"?[]:new Uint8Array(256);for(var Qc=0;Qc<KE.length;Qc++)zK[KE.charCodeAt(Qc)]=Qc;var VK=1,sg=2,og=3,zE=4,VE=5,jK=7,jE=8,Ag=9,lg=10,WE=11,qE=12,$E=13,YE=14,cg=15,WK=function(r){for(var e=[],t=0,n=r.length;t<n;){var i=r.charCodeAt(t++);if(i>=55296&&i<=56319&&t<n){var a=r.charCodeAt(t++);(a&64512)===56320?e.push(((i&1023)<<10)+(a&1023)+65536):(e.push(i),t--)}else e.push(i)}return e},qK=function(){for(var r=[],e=0;e<arguments.length;e++)r[e]=arguments[e];if(String.fromCodePoint)return String.fromCodePoint.apply(String,r);var t=r.length;if(!t)return"";for(var n=[],i=-1,a="";++i<t;){var s=r[i];s<=65535?n.push(s):(s-=65536,n.push((s>>10)+55296,s%1024+56320)),(i+1===t||n.length>16384)&&(a+=String.fromCharCode.apply(String,n),n.length=0)}return a},$K=GK(FK),Zr="×",ug="÷",YK=function(r){return $K.get(r)},XK=function(r,e,t){var n=t-2,i=e[n],a=e[t-1],s=e[t];if(a===sg&&s===og)return Zr;if(a===sg||a===og||a===zE||s===sg||s===og||s===zE)return ug;if(a===jE&&[jE,Ag,WE,qE].indexOf(s)!==-1||(a===WE||a===Ag)&&(s===Ag||s===lg)||(a===qE||a===lg)&&s===lg||s===$E||s===VE||s===jK||a===VK)return Zr;if(a===$E&&s===YE){for(;i===VE;)i=e[--n];if(i===YE)return Zr}if(a===cg&&s===cg){for(var o=0;i===cg;)o++,i=e[--n];if(o%2===0)return Zr}return ug},ZK=function(r){var e=WK(r),t=e.length,n=0,i=0,a=e.map(YK);return{next:function(){if(n>=t)return{done:!0,value:null};for(var s=Zr;n<t&&(s=XK(e,a,++n))===Zr;);if(s!==Zr||n===t){var o=qK.apply(null,e.slice(i,n));return i=n,{value:o,done:!1}}return{done:!0,value:null}}}},JK=function(r){for(var e=ZK(r),t=[],n;!(n=e.next()).done;)n.value&&t.push(n.value.slice());return t},e8=function(r){var e=123;if(r.createRange){var t=r.createRange();if(t.getBoundingClientRect){var n=r.createElement("boundtest");n.style.height=e+"px",n.style.display="block",r.body.appendChild(n),t.selectNode(n);var i=t.getBoundingClientRect(),a=Math.round(i.height);if(r.body.removeChild(n),a===e)return!0}}return!1},t8=function(r){var e=r.createElement("boundtest");e.style.width="50px",e.style.display="block",e.style.fontSize="12px",e.style.letterSpacing="0px",e.style.wordSpacing="0px",r.body.appendChild(e);var t=r.createRange();e.innerHTML=typeof"".repeat=="function"?"👨".repeat(10):"";var n=e.firstChild,i=Hh(n.data).map(function(A){return cn(A)}),a=0,s={},o=i.every(function(A,l){t.setStart(n,a),t.setEnd(n,a+A.length);var c=t.getBoundingClientRect();a+=A.length;var u=c.x>s.x||c.y>s.y;return s=c,l===0?!0:u});return r.body.removeChild(e),o},n8=function(){return typeof new Image().crossOrigin<"u"},r8=function(){return typeof new XMLHttpRequest().responseType=="string"},i8=function(r){var e=new Image,t=r.createElement("canvas"),n=t.getContext("2d");if(!n)return!1;e.src="data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg'></svg>";try{n.drawImage(e,0,0),t.toDataURL()}catch{return!1}return!0},XE=function(r){return r[0]===0&&r[1]===255&&r[2]===0&&r[3]===255},a8=function(r){var e=r.createElement("canvas"),t=100;e.width=t,e.height=t;var n=e.getContext("2d");if(!n)return Promise.reject(!1);n.fillStyle="rgb(0, 255, 0)",n.fillRect(0,0,t,t);var i=new Image,a=e.toDataURL();i.src=a;var s=t1(t,t,0,0,i);return n.fillStyle="red",n.fillRect(0,0,t,t),ZE(s).then(function(o){n.drawImage(o,0,0);var A=n.getImageData(0,0,t,t).data;n.fillStyle="red",n.fillRect(0,0,t,t);var l=r.createElement("div");return l.style.backgroundImage="url("+a+")",l.style.height=t+"px",XE(A)?ZE(t1(t,t,0,0,l)):Promise.reject(!1)}).then(function(o){return n.drawImage(o,0,0),XE(n.getImageData(0,0,t,t).data)}).catch(function(){return!1})},t1=function(r,e,t,n,i){var a="http://www.w3.org/2000/svg",s=document.createElementNS(a,"svg"),o=document.createElementNS(a,"foreignObject");return s.setAttributeNS(null,"width",r.toString()),s.setAttributeNS(null,"height",e.toString()),o.setAttributeNS(null,"width","100%"),o.setAttributeNS(null,"height","100%"),o.setAttributeNS(null,"x",t.toString()),o.setAttributeNS(null,"y",n.toString()),o.setAttributeNS(null,"externalResourcesRequired","true"),s.appendChild(o),o.appendChild(i),s},ZE=function(r){return new Promise(function(e,t){var n=new Image;n.onload=function(){return e(n)},n.onerror=t,n.src="data:image/svg+xml;charset=utf-8,"+encodeURIComponent(new XMLSerializer().serializeToString(r))})},Ur={get SUPPORT_RANGE_BOUNDS(){var r=e8(document);return Object.defineProperty(Ur,"SUPPORT_RANGE_BOUNDS",{value:r}),r},get SUPPORT_WORD_BREAKING(){var r=Ur.SUPPORT_RANGE_BOUNDS&&t8(document);return Object.defineProperty(Ur,"SUPPORT_WORD_BREAKING",{value:r}),r},get SUPPORT_SVG_DRAWING(){var r=i8(document);return Object.defineProperty(Ur,"SUPPORT_SVG_DRAWING",{value:r}),r},get SUPPORT_FOREIGNOBJECT_DRAWING(){var r=typeof Array.from=="function"&&typeof window.fetch=="function"?a8(document):Promise.resolve(!1);return Object.defineProperty(Ur,"SUPPORT_FOREIGNOBJECT_DRAWING",{value:r}),r},get SUPPORT_CORS_IMAGES(){var r=n8();return Object.defineProperty(Ur,"SUPPORT_CORS_IMAGES",{value:r}),r},get SUPPORT_RESPONSE_TYPE(){var r=r8();return Object.defineProperty(Ur,"SUPPORT_RESPONSE_TYPE",{value:r}),r},get SUPPORT_CORS_XHR(){var r="withCredentials"in new XMLHttpRequest;return Object.defineProperty(Ur,"SUPPORT_CORS_XHR",{value:r}),r},get SUPPORT_NATIVE_TEXT_SEGMENTATION(){var r=!!(typeof Intl<"u"&&Intl.Segmenter);return Object.defineProperty(Ur,"SUPPORT_NATIVE_TEXT_SEGMENTATION",{value:r}),r}},JA=(function(){function r(e,t){this.text=e,this.bounds=t}return r})(),s8=function(r,e,t,n){var i=l8(e,t),a=[],s=0;return i.forEach(function(o){if(t.textDecorationLine.length||o.trim().length>0)if(Ur.SUPPORT_RANGE_BOUNDS){var A=JE(n,s,o.length).getClientRects();if(A.length>1){var l=oB(o),c=0;l.forEach(function(h){a.push(new JA(h,zs.fromDOMRectList(r,JE(n,c+s,h.length).getClientRects()))),c+=h.length})}else a.push(new JA(o,zs.fromDOMRectList(r,A)))}else{var u=n.splitText(o.length);a.push(new JA(o,o8(r,n))),n=u}else Ur.SUPPORT_RANGE_BOUNDS||(n=n.splitText(o.length));s+=o.length}),a},o8=function(r,e){var t=e.ownerDocument;if(t){var n=t.createElement("html2canvaswrapper");n.appendChild(e.cloneNode(!0));var i=e.parentNode;if(i){i.replaceChild(n,e);var a=nB(r,n);return n.firstChild&&i.replaceChild(n.firstChild,n),a}}return zs.EMPTY},JE=function(r,e,t){var n=r.ownerDocument;if(!n)throw new Error("Node has no owner document");var i=n.createRange();return i.setStart(r,e),i.setEnd(r,e+t),i},oB=function(r){if(Ur.SUPPORT_NATIVE_TEXT_SEGMENTATION){var e=new Intl.Segmenter(void 0,{granularity:"grapheme"});return Array.from(e.segment(r)).map(function(t){return t.segment})}return JK(r)},A8=function(r,e){if(Ur.SUPPORT_NATIVE_TEXT_SEGMENTATION){var t=new Intl.Segmenter(void 0,{granularity:"word"});return Array.from(t.segment(r)).map(function(n){return n.segment})}return u8(r,e)},l8=function(r,e){return e.letterSpacing!==0?oB(r):A8(r,e)},c8=[32,160,4961,65792,65793,4153,4241],u8=function(r,e){for(var t=K6(r,{lineBreak:e.lineBreak,wordBreak:e.overflowWrap==="break-word"?"break-word":e.wordBreak}),n=[],i,a=function(){if(i.value){var s=i.value.slice(),o=Hh(s),A="";o.forEach(function(l){c8.indexOf(l)===-1?A+=cn(l):(A.length&&n.push(A),n.push(cn(l)),A="")}),A.length&&n.push(A)}};!(i=t.next()).done;)a();return n},h8=(function(){function r(e,t,n){this.text=d8(t.data,n.textTransform),this.textBounds=s8(e,this.text,n,t)}return r})(),d8=function(r,e){switch(e){case 1:return r.toLowerCase();case 3:return r.replace(f8,g8);case 2:return r.toUpperCase();default:return r}},f8=/(^|\s|:|-|\(|\))([a-z])/g,g8=function(r,e,t){return r.length>0?e+t.toUpperCase():r},mk=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;return i.src=n.currentSrc||n.src,i.intrinsicWidth=n.naturalWidth,i.intrinsicHeight=n.naturalHeight,i.context.cache.addImage(i.src),i}return e})(qi),wk=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;return i.canvas=n,i.intrinsicWidth=n.width,i.intrinsicHeight=n.height,i}return e})(qi),Bk=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this,a=new XMLSerializer,s=nB(t,n);return n.setAttribute("width",s.width+"px"),n.setAttribute("height",s.height+"px"),i.svg="data:image/svg+xml,"+encodeURIComponent(a.serializeToString(n)),i.intrinsicWidth=n.width.baseVal.value,i.intrinsicHeight=n.height.baseVal.value,i.context.cache.addImage(i.svg),i}return e})(qi),bk=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;return i.value=n.value,i}return e})(qi),n1=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;return i.start=n.start,i.reversed=typeof n.reversed=="boolean"&&n.reversed===!0,i}return e})(qi),v8=[{type:15,flags:0,unit:"px",number:3}],p8=[{type:16,flags:0,number:50}],y8=function(r){return r.width>r.height?new zs(r.left+(r.width-r.height)/2,r.top,r.height,r.height):r.width<r.height?new zs(r.left,r.top+(r.height-r.width)/2,r.width,r.width):r},m8=function(r){var e=r.type===w8?new Array(r.value.length+1).join("•"):r.value;return e.length===0?r.placeholder||"":e},Ah="checkbox",lh="radio",w8="password",ex=707406591,AB=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;switch(i.type=n.type.toLowerCase(),i.checked=n.checked,i.value=m8(n),(i.type===Ah||i.type===lh)&&(i.styles.backgroundColor=3739148031,i.styles.borderTopColor=i.styles.borderRightColor=i.styles.borderBottomColor=i.styles.borderLeftColor=2779096575,i.styles.borderTopWidth=i.styles.borderRightWidth=i.styles.borderBottomWidth=i.styles.borderLeftWidth=1,i.styles.borderTopStyle=i.styles.borderRightStyle=i.styles.borderBottomStyle=i.styles.borderLeftStyle=1,i.styles.backgroundClip=[0],i.styles.backgroundOrigin=[0],i.bounds=y8(i.bounds)),i.type){case Ah:i.styles.borderTopRightRadius=i.styles.borderTopLeftRadius=i.styles.borderBottomRightRadius=i.styles.borderBottomLeftRadius=v8;break;case lh:i.styles.borderTopRightRadius=i.styles.borderTopLeftRadius=i.styles.borderBottomRightRadius=i.styles.borderBottomLeftRadius=p8;break}return i}return e})(qi),Ek=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this,a=n.options[n.selectedIndex||0];return i.value=a&&a.text||"",i}return e})(qi),xk=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;return i.value=n.value,i}return e})(qi),Ck=(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;i.src=n.src,i.width=parseInt(n.width,10)||0,i.height=parseInt(n.height,10)||0,i.backgroundColor=i.styles.backgroundColor;try{if(n.contentWindow&&n.contentWindow.document&&n.contentWindow.document.documentElement){i.tree=b8(t,n.contentWindow.document.documentElement);var a=n.contentWindow.document.documentElement?QE(t,getComputedStyle(n.contentWindow.document.documentElement).backgroundColor):dl.TRANSPARENT,s=n.contentWindow.document.body?QE(t,getComputedStyle(n.contentWindow.document.body).backgroundColor):dl.TRANSPARENT;i.backgroundColor=Ro(a)?Ro(s)?i.styles.backgroundColor:s:a}}catch{}return i}return e})(qi),B8=["OL","UL","MENU"],Ou=function(r,e,t,n){for(var i=e.firstChild,a=void 0;i;i=a)if(a=i.nextSibling,C8(i)&&i.data.trim().length>0)t.textNodes.push(new h8(r,i,t.styles));else if(Fk(i))if(Q8(i)&&i.assignedNodes)i.assignedNodes().forEach(function(o){return Ou(r,o,t,n)});else{var s=Sk(r,i);s.styles.isVisible()&&(E8(i,s,n)?s.flags|=4:x8(s.styles)&&(s.flags|=2),B8.indexOf(i.tagName)!==-1&&(s.flags|=8),t.elements.push(s),i.slot,i.shadowRoot?Ou(r,i.shadowRoot,s,n):!Mk(i)&&!Tk(i)&&!Ok(i)&&Ou(r,i,s,n))}},Sk=function(r,e){return k8(e)?new mk(r,e):I8(e)?new wk(r,e):Tk(e)?new Bk(r,e):T8(e)?new bk(r,e):M8(e)?new n1(r,e):O8(e)?new AB(r,e):Ok(e)?new Ek(r,e):Mk(e)?new xk(r,e):L8(e)?new Ck(r,e):new qi(r,e)},b8=function(r,e){var t=Sk(r,e);return t.flags|=4,Ou(r,e,t,t),t},E8=function(r,e,t){return e.styles.isPositionedWithZIndex()||e.styles.opacity<1||e.styles.isTransformed()||_8(r)&&t.styles.isTransparent()},x8=function(r){return r.isPositioned()||r.isFloating()},C8=function(r){return r.nodeType===Node.TEXT_NODE},Fk=function(r){return r.nodeType===Node.ELEMENT_NODE},S8=function(r){return Fk(r)&&typeof r.style<"u"&&!F8(r)},F8=function(r){return typeof r.className=="object"},T8=function(r){return r.tagName==="LI"},M8=function(r){return r.tagName==="OL"},O8=function(r){return r.tagName==="INPUT"},Tk=function(r){return r.tagName==="svg"},_8=function(r){return r.tagName==="BODY"},I8=function(r){return r.tagName==="CANVAS"},k8=function(r){return r.tagName==="IMG"},L8=function(r){return r.tagName==="IFRAME"},Mk=function(r){return r.tagName==="TEXTAREA"},Ok=function(r){return r.tagName==="SELECT"},Q8=function(r){return r.tagName==="SLOT"},tx={integers:[1e3,900,500,400,100,90,50,40,10,9,5,4,1],values:["M","CM","D","CD","C","XC","L","XL","X","IX","V","IV","I"]},nx={integers:[9e3,8e3,7e3,6e3,5e3,4e3,3e3,2e3,1e3,900,800,700,600,500,400,300,200,100,90,80,70,60,50,40,30,20,10,9,8,7,6,5,4,3,2,1],values:["Ք","Փ","Ւ","Ց","Ր","Տ","Վ","Ս","Ռ","Ջ","Պ","Չ","Ո","Շ","Ն","Յ","Մ","Ճ","Ղ","Ձ","Հ","Կ","Ծ","Խ","Լ","Ի","Ժ","Թ","Ը","Է","Զ","Ե","Դ","Գ","Բ","Ա"]},N8={integers:[1e4,9e3,8e3,7e3,6e3,5e3,4e3,3e3,2e3,1e3,400,300,200,100,90,80,70,60,50,40,30,20,19,18,17,16,15,10,9,8,7,6,5,4,3,2,1],values:["י׳","ט׳","ח׳","ז׳","ו׳","ה׳","ד׳","ג׳","ב׳","א׳","ת","ש","ר","ק","צ","פ","ע","ס","נ","מ","ל","כ","יט","יח","יז","טז","טו","י","ט","ח","ז","ו","ה","ד","ג","ב","א"]},U8={integers:[1e4,9e3,8e3,7e3,6e3,5e3,4e3,3e3,2e3,1e3,900,800,700,600,500,400,300,200,100,90,80,70,60,50,40,30,20,10,9,8,7,6,5,4,3,2,1],values:["ჵ","ჰ","ჯ","ჴ","ხ","ჭ","წ","ძ","ც","ჩ","შ","ყ","ღ","ქ","ფ","ჳ","ტ","ს","რ","ჟ","პ","ო","ჲ","ნ","მ","ლ","კ","ი","თ","ჱ","ზ","ვ","ე","დ","გ","ბ","ა"]},fo=function(r,e,t,n,i,a){return r<e||r>t?lB(r,i,a.length>0):n.integers.reduce(function(s,o,A){for(;r>=o;)r-=o,s+=n.values[A];return s},"")+a},_k=function(r,e,t,n){var i="";do t||r--,i=n(r)+i,r/=e;while(r*e>=e);return i},sn=function(r,e,t,n,i){var a=t-e+1;return(r<0?"-":"")+(_k(Math.abs(r),a,n,function(s){return cn(Math.floor(s%a)+e)})+i)},vs=function(r,e,t){t===void 0&&(t=". ");var n=e.length;return _k(Math.abs(r),n,!1,function(i){return e[Math.floor(i%n)]})+t},xo=1,Sa=2,Fa=4,NA=8,ra=function(r,e,t,n,i,a){if(r<-9999||r>9999)return lB(r,4,i.length>0);var s=Math.abs(r),o=i;if(s===0)return e[0]+o;for(var A=0;s>0&&A<=4;A++){var l=s%10;l===0&&xn(a,xo)&&o!==""?o=e[l]+o:l>1||l===1&&A===0||l===1&&A===1&&xn(a,Sa)||l===1&&A===1&&xn(a,Fa)&&r>100||l===1&&A>1&&xn(a,NA)?o=e[l]+(A>0?t[A-1]:"")+o:l===1&&A>0&&(o=t[A-1]+o),s=Math.floor(s/10)}return(r<0?n:"")+o},rx="十百千萬",ix="拾佰仟萬",ax="マイナス",hg="마이너스",lB=function(r,e,t){var n=t?". ":"",i=t?"、":"",a=t?", ":"",s=t?" ":"";switch(e){case 0:return"•"+s;case 1:return"◦"+s;case 2:return"◾"+s;case 5:var o=sn(r,48,57,!0,n);return o.length<4?"0"+o:o;case 4:return vs(r,"〇一二三四五六七八九",i);case 6:return fo(r,1,3999,tx,3,n).toLowerCase();case 7:return fo(r,1,3999,tx,3,n);case 8:return sn(r,945,969,!1,n);case 9:return sn(r,97,122,!1,n);case 10:return sn(r,65,90,!1,n);case 11:return sn(r,1632,1641,!0,n);case 12:case 49:return fo(r,1,9999,nx,3,n);case 35:return fo(r,1,9999,nx,3,n).toLowerCase();case 13:return sn(r,2534,2543,!0,n);case 14:case 30:return sn(r,6112,6121,!0,n);case 15:return vs(r,"子丑寅卯辰巳午未申酉戌亥",i);case 16:return vs(r,"甲乙丙丁戊己庚辛壬癸",i);case 17:case 48:return ra(r,"零一二三四五六七八九",rx,"負",i,Sa|Fa|NA);case 47:return ra(r,"零壹貳參肆伍陸柒捌玖",ix,"負",i,xo|Sa|Fa|NA);case 42:return ra(r,"零一二三四五六七八九",rx,"负",i,Sa|Fa|NA);case 41:return ra(r,"零壹贰叁肆伍陆柒捌玖",ix,"负",i,xo|Sa|Fa|NA);case 26:return ra(r,"〇一二三四五六七八九","十百千万",ax,i,0);case 25:return ra(r,"零壱弐参四伍六七八九","拾百千万",ax,i,xo|Sa|Fa);case 31:return ra(r,"영일이삼사오육칠팔구","십백천만",hg,a,xo|Sa|Fa);case 33:return ra(r,"零一二三四五六七八九","十百千萬",hg,a,0);case 32:return ra(r,"零壹貳參四五六七八九","拾百千",hg,a,xo|Sa|Fa);case 18:return sn(r,2406,2415,!0,n);case 20:return fo(r,1,19999,U8,3,n);case 21:return sn(r,2790,2799,!0,n);case 22:return sn(r,2662,2671,!0,n);case 22:return fo(r,1,10999,N8,3,n);case 23:return vs(r,"あいうえおかきくけこさしすせそたちつてとなにぬねのはひふへほまみむめもやゆよらりるれろわゐゑをん");case 24:return vs(r,"いろはにほへとちりぬるをわかよたれそつねならむうゐのおくやまけふこえてあさきゆめみしゑひもせす");case 27:return sn(r,3302,3311,!0,n);case 28:return vs(r,"アイウエオカキクケコサシスセソタチツテトナニヌネノハヒフヘホマミムメモヤユヨラリルレロワヰヱヲン",i);case 29:return vs(r,"イロハニホヘトチリヌルヲワカヨタレソツネナラムウヰノオクヤマケフコエテアサキユメミシヱヒモセス",i);case 34:return sn(r,3792,3801,!0,n);case 37:return sn(r,6160,6169,!0,n);case 38:return sn(r,4160,4169,!0,n);case 39:return sn(r,2918,2927,!0,n);case 40:return sn(r,1776,1785,!0,n);case 43:return sn(r,3046,3055,!0,n);case 44:return sn(r,3174,3183,!0,n);case 45:return sn(r,3664,3673,!0,n);case 46:return sn(r,3872,3881,!0,n);default:return sn(r,48,57,!0,n)}},sx;(function(r){r[r.BEFORE=0]="BEFORE",r[r.AFTER=1]="AFTER"})(sx||(sx={}));var P8=(function(){function r(){}return r.getOrigin=function(e){var t=r._link;return t?(t.href=e,t.href=t.href,t.protocol+t.hostname+t.port):"about:blank"},r.isSameOrigin=function(e){return r.getOrigin(e)===r._origin},r.setContext=function(e){r._link=e.document.createElement("a"),r._origin=r.getOrigin(e.location.href)},r._origin="about:blank",r})(),Fe=(function(){function r(e,t){this.type=0,this.x=e,this.y=t}return r.prototype.add=function(e,t){return new r(this.x+e,this.y+t)},r})(),go=function(r,e,t){return new Fe(r.x+(e.x-r.x)*t,r.y+(e.y-r.y)*t)},Nc=(function(){function r(e,t,n,i){this.type=1,this.start=e,this.startControl=t,this.endControl=n,this.end=i}return r.prototype.subdivide=function(e,t){var n=go(this.start,this.startControl,e),i=go(this.startControl,this.endControl,e),a=go(this.endControl,this.end,e),s=go(n,i,e),o=go(i,a,e),A=go(s,o,e);return t?new r(this.start,n,s,A):new r(A,o,a,this.end)},r.prototype.add=function(e,t){return new r(this.start.add(e,t),this.startControl.add(e,t),this.endControl.add(e,t),this.end.add(e,t))},r.prototype.reverse=function(){return new r(this.end,this.endControl,this.startControl,this.start)},r})(),ei=function(r){return r.type===1},R8=(function(){function r(e){var t=e.styles,n=e.bounds,i=LA(t.borderTopLeftRadius,n.width,n.height),a=i[0],s=i[1],o=LA(t.borderTopRightRadius,n.width,n.height),A=o[0],l=o[1],c=LA(t.borderBottomRightRadius,n.width,n.height),u=c[0],h=c[1],d=LA(t.borderBottomLeftRadius,n.width,n.height),f=d[0],g=d[1],v=[];v.push((a+A)/n.width),v.push((f+u)/n.width),v.push((s+g)/n.height),v.push((l+h)/n.height);var p=Math.max.apply(Math,v);p>1&&(a/=p,s/=p,A/=p,l/=p,u/=p,h/=p,f/=p,g/=p);var y=n.width-A,m=n.height-h,B=n.width-u,C=n.height-g,S=t.borderTopWidth,F=t.borderRightWidth,T=t.borderBottomWidth,O=t.borderLeftWidth,_=kt(t.paddingTop,e.bounds.width),k=kt(t.paddingRight,e.bounds.width),L=kt(t.paddingBottom,e.bounds.width),U=kt(t.paddingLeft,e.bounds.width);this.topLeftBorderDoubleOuterBox=a>0||s>0?zt(n.left+O/3,n.top+S/3,a-O/3,s-S/3,vt.TOP_LEFT):new Fe(n.left+O/3,n.top+S/3),this.topRightBorderDoubleOuterBox=a>0||s>0?zt(n.left+y,n.top+S/3,A-F/3,l-S/3,vt.TOP_RIGHT):new Fe(n.left+n.width-F/3,n.top+S/3),this.bottomRightBorderDoubleOuterBox=u>0||h>0?zt(n.left+B,n.top+m,u-F/3,h-T/3,vt.BOTTOM_RIGHT):new Fe(n.left+n.width-F/3,n.top+n.height-T/3),this.bottomLeftBorderDoubleOuterBox=f>0||g>0?zt(n.left+O/3,n.top+C,f-O/3,g-T/3,vt.BOTTOM_LEFT):new Fe(n.left+O/3,n.top+n.height-T/3),this.topLeftBorderDoubleInnerBox=a>0||s>0?zt(n.left+O*2/3,n.top+S*2/3,a-O*2/3,s-S*2/3,vt.TOP_LEFT):new Fe(n.left+O*2/3,n.top+S*2/3),this.topRightBorderDoubleInnerBox=a>0||s>0?zt(n.left+y,n.top+S*2/3,A-F*2/3,l-S*2/3,vt.TOP_RIGHT):new Fe(n.left+n.width-F*2/3,n.top+S*2/3),this.bottomRightBorderDoubleInnerBox=u>0||h>0?zt(n.left+B,n.top+m,u-F*2/3,h-T*2/3,vt.BOTTOM_RIGHT):new Fe(n.left+n.width-F*2/3,n.top+n.height-T*2/3),this.bottomLeftBorderDoubleInnerBox=f>0||g>0?zt(n.left+O*2/3,n.top+C,f-O*2/3,g-T*2/3,vt.BOTTOM_LEFT):new Fe(n.left+O*2/3,n.top+n.height-T*2/3),this.topLeftBorderStroke=a>0||s>0?zt(n.left+O/2,n.top+S/2,a-O/2,s-S/2,vt.TOP_LEFT):new Fe(n.left+O/2,n.top+S/2),this.topRightBorderStroke=a>0||s>0?zt(n.left+y,n.top+S/2,A-F/2,l-S/2,vt.TOP_RIGHT):new Fe(n.left+n.width-F/2,n.top+S/2),this.bottomRightBorderStroke=u>0||h>0?zt(n.left+B,n.top+m,u-F/2,h-T/2,vt.BOTTOM_RIGHT):new Fe(n.left+n.width-F/2,n.top+n.height-T/2),this.bottomLeftBorderStroke=f>0||g>0?zt(n.left+O/2,n.top+C,f-O/2,g-T/2,vt.BOTTOM_LEFT):new Fe(n.left+O/2,n.top+n.height-T/2),this.topLeftBorderBox=a>0||s>0?zt(n.left,n.top,a,s,vt.TOP_LEFT):new Fe(n.left,n.top),this.topRightBorderBox=A>0||l>0?zt(n.left+y,n.top,A,l,vt.TOP_RIGHT):new Fe(n.left+n.width,n.top),this.bottomRightBorderBox=u>0||h>0?zt(n.left+B,n.top+m,u,h,vt.BOTTOM_RIGHT):new Fe(n.left+n.width,n.top+n.height),this.bottomLeftBorderBox=f>0||g>0?zt(n.left,n.top+C,f,g,vt.BOTTOM_LEFT):new Fe(n.left,n.top+n.height),this.topLeftPaddingBox=a>0||s>0?zt(n.left+O,n.top+S,Math.max(0,a-O),Math.max(0,s-S),vt.TOP_LEFT):new Fe(n.left+O,n.top+S),this.topRightPaddingBox=A>0||l>0?zt(n.left+Math.min(y,n.width-F),n.top+S,y>n.width+F?0:Math.max(0,A-F),Math.max(0,l-S),vt.TOP_RIGHT):new Fe(n.left+n.width-F,n.top+S),this.bottomRightPaddingBox=u>0||h>0?zt(n.left+Math.min(B,n.width-O),n.top+Math.min(m,n.height-T),Math.max(0,u-F),Math.max(0,h-T),vt.BOTTOM_RIGHT):new Fe(n.left+n.width-F,n.top+n.height-T),this.bottomLeftPaddingBox=f>0||g>0?zt(n.left+O,n.top+Math.min(C,n.height-T),Math.max(0,f-O),Math.max(0,g-T),vt.BOTTOM_LEFT):new Fe(n.left+O,n.top+n.height-T),this.topLeftContentBox=a>0||s>0?zt(n.left+O+U,n.top+S+_,Math.max(0,a-(O+U)),Math.max(0,s-(S+_)),vt.TOP_LEFT):new Fe(n.left+O+U,n.top+S+_),this.topRightContentBox=A>0||l>0?zt(n.left+Math.min(y,n.width+O+U),n.top+S+_,y>n.width+O+U?0:A-O+U,l-(S+_),vt.TOP_RIGHT):new Fe(n.left+n.width-(F+k),n.top+S+_),this.bottomRightContentBox=u>0||h>0?zt(n.left+Math.min(B,n.width-(O+U)),n.top+Math.min(m,n.height+S+_),Math.max(0,u-(F+k)),h-(T+L),vt.BOTTOM_RIGHT):new Fe(n.left+n.width-(F+k),n.top+n.height-(T+L)),this.bottomLeftContentBox=f>0||g>0?zt(n.left+O+U,n.top+C,Math.max(0,f-(O+U)),g-(T+L),vt.BOTTOM_LEFT):new Fe(n.left+O+U,n.top+n.height-(T+L))}return r})(),vt;(function(r){r[r.TOP_LEFT=0]="TOP_LEFT",r[r.TOP_RIGHT=1]="TOP_RIGHT",r[r.BOTTOM_RIGHT=2]="BOTTOM_RIGHT",r[r.BOTTOM_LEFT=3]="BOTTOM_LEFT"})(vt||(vt={}));var zt=function(r,e,t,n,i){var a=4*((Math.sqrt(2)-1)/3),s=t*a,o=n*a,A=r+t,l=e+n;switch(i){case vt.TOP_LEFT:return new Nc(new Fe(r,l),new Fe(r,l-o),new Fe(A-s,e),new Fe(A,e));case vt.TOP_RIGHT:return new Nc(new Fe(r,e),new Fe(r+s,e),new Fe(A,l-o),new Fe(A,l));case vt.BOTTOM_RIGHT:return new Nc(new Fe(A,e),new Fe(A,e+o),new Fe(r+s,l),new Fe(r,l));case vt.BOTTOM_LEFT:default:return new Nc(new Fe(A,l),new Fe(A-s,l),new Fe(r,e+o),new Fe(r,e))}},ch=function(r){return[r.topLeftBorderBox,r.topRightBorderBox,r.bottomRightBorderBox,r.bottomLeftBorderBox]},D8=function(r){return[r.topLeftContentBox,r.topRightContentBox,r.bottomRightContentBox,r.bottomLeftContentBox]},uh=function(r){return[r.topLeftPaddingBox,r.topRightPaddingBox,r.bottomRightPaddingBox,r.bottomLeftPaddingBox]},H8=(function(){function r(e,t,n){this.offsetX=e,this.offsetY=t,this.matrix=n,this.type=0,this.target=6}return r})(),Uc=(function(){function r(e,t){this.path=e,this.target=t,this.type=1}return r})(),G8=(function(){function r(e){this.opacity=e,this.type=2,this.target=6}return r})(),K8=function(r){return r.type===0},Ik=function(r){return r.type===1},z8=function(r){return r.type===2},ox=function(r,e){return r.length===e.length?r.some(function(t,n){return t===e[n]}):!1},V8=function(r,e,t,n,i){return r.map(function(a,s){switch(s){case 0:return a.add(e,t);case 1:return a.add(e+n,t);case 2:return a.add(e+n,t+i);case 3:return a.add(e,t+i)}return a})},kk=(function(){function r(e){this.element=e,this.inlineLevel=[],this.nonInlineLevel=[],this.negativeZIndex=[],this.zeroOrAutoZIndexOrTransformedOrOpacity=[],this.positiveZIndex=[],this.nonPositionedFloats=[],this.nonPositionedInlineLevel=[]}return r})(),Lk=(function(){function r(e,t){if(this.container=e,this.parent=t,this.effects=[],this.curves=new R8(this.container),this.container.styles.opacity<1&&this.effects.push(new G8(this.container.styles.opacity)),this.container.styles.transform!==null){var n=this.container.bounds.left+this.container.styles.transformOrigin[0].number,i=this.container.bounds.top+this.container.styles.transformOrigin[1].number,a=this.container.styles.transform;this.effects.push(new H8(n,i,a))}if(this.container.styles.overflowX!==0){var s=ch(this.curves),o=uh(this.curves);ox(s,o)?this.effects.push(new Uc(s,6)):(this.effects.push(new Uc(s,2)),this.effects.push(new Uc(o,4)))}}return r.prototype.getEffects=function(e){for(var t=[2,3].indexOf(this.container.styles.position)===-1,n=this.parent,i=this.effects.slice(0);n;){var a=n.effects.filter(function(A){return!Ik(A)});if(t||n.container.styles.position!==0||!n.parent){if(i.unshift.apply(i,a),t=[2,3].indexOf(n.container.styles.position)===-1,n.container.styles.overflowX!==0){var s=ch(n.curves),o=uh(n.curves);ox(s,o)||i.unshift(new Uc(o,6))}}else i.unshift.apply(i,a);n=n.parent}return i.filter(function(A){return xn(A.target,e)})},r})(),r1=function(r,e,t,n){r.container.elements.forEach(function(i){var a=xn(i.flags,4),s=xn(i.flags,2),o=new Lk(i,r);xn(i.styles.display,2048)&&n.push(o);var A=xn(i.flags,8)?[]:n;if(a||s){var l=a||i.styles.isPositioned()?t:e,c=new kk(o);if(i.styles.isPositioned()||i.styles.opacity<1||i.styles.isTransformed()){var u=i.styles.zIndex.order;if(u<0){var h=0;l.negativeZIndex.some(function(f,g){return u>f.element.container.styles.zIndex.order?(h=g,!1):h>0}),l.negativeZIndex.splice(h,0,c)}else if(u>0){var d=0;l.positiveZIndex.some(function(f,g){return u>=f.element.container.styles.zIndex.order?(d=g+1,!1):d>0}),l.positiveZIndex.splice(d,0,c)}else l.zeroOrAutoZIndexOrTransformedOrOpacity.push(c)}else i.styles.isFloating()?l.nonPositionedFloats.push(c):l.nonPositionedInlineLevel.push(c);r1(o,c,a?c:t,A)}else i.styles.isInlineLevel()?e.inlineLevel.push(o):e.nonInlineLevel.push(o),r1(o,e,t,A);xn(i.flags,8)&&Qk(i,A)})},Qk=function(r,e){for(var t=r instanceof n1?r.start:1,n=r instanceof n1?r.reversed:!1,i=0;i<e.length;i++){var a=e[i];a.container instanceof bk&&typeof a.container.value=="number"&&a.container.value!==0&&(t=a.container.value),a.listValue=lB(t,a.container.styles.listStyleType,!0),t+=n?-1:1}},j8=function(r){var e=new Lk(r,null),t=new kk(e),n=[];return r1(e,t,t,n),Qk(e.container,n),t},Ax=function(r,e){switch(e){case 0:return ri(r.topLeftBorderBox,r.topLeftPaddingBox,r.topRightBorderBox,r.topRightPaddingBox);case 1:return ri(r.topRightBorderBox,r.topRightPaddingBox,r.bottomRightBorderBox,r.bottomRightPaddingBox);case 2:return ri(r.bottomRightBorderBox,r.bottomRightPaddingBox,r.bottomLeftBorderBox,r.bottomLeftPaddingBox);default:return ri(r.bottomLeftBorderBox,r.bottomLeftPaddingBox,r.topLeftBorderBox,r.topLeftPaddingBox)}},W8=function(r,e){switch(e){case 0:return ri(r.topLeftBorderBox,r.topLeftBorderDoubleOuterBox,r.topRightBorderBox,r.topRightBorderDoubleOuterBox);case 1:return ri(r.topRightBorderBox,r.topRightBorderDoubleOuterBox,r.bottomRightBorderBox,r.bottomRightBorderDoubleOuterBox);case 2:return ri(r.bottomRightBorderBox,r.bottomRightBorderDoubleOuterBox,r.bottomLeftBorderBox,r.bottomLeftBorderDoubleOuterBox);default:return ri(r.bottomLeftBorderBox,r.bottomLeftBorderDoubleOuterBox,r.topLeftBorderBox,r.topLeftBorderDoubleOuterBox)}},q8=function(r,e){switch(e){case 0:return ri(r.topLeftBorderDoubleInnerBox,r.topLeftPaddingBox,r.topRightBorderDoubleInnerBox,r.topRightPaddingBox);case 1:return ri(r.topRightBorderDoubleInnerBox,r.topRightPaddingBox,r.bottomRightBorderDoubleInnerBox,r.bottomRightPaddingBox);case 2:return ri(r.bottomRightBorderDoubleInnerBox,r.bottomRightPaddingBox,r.bottomLeftBorderDoubleInnerBox,r.bottomLeftPaddingBox);default:return ri(r.bottomLeftBorderDoubleInnerBox,r.bottomLeftPaddingBox,r.topLeftBorderDoubleInnerBox,r.topLeftPaddingBox)}},$8=function(r,e){switch(e){case 0:return Pc(r.topLeftBorderStroke,r.topRightBorderStroke);case 1:return Pc(r.topRightBorderStroke,r.bottomRightBorderStroke);case 2:return Pc(r.bottomRightBorderStroke,r.bottomLeftBorderStroke);default:return Pc(r.bottomLeftBorderStroke,r.topLeftBorderStroke)}},Pc=function(r,e){var t=[];return ei(r)?t.push(r.subdivide(.5,!1)):t.push(r),ei(e)?t.push(e.subdivide(.5,!0)):t.push(e),t},ri=function(r,e,t,n){var i=[];return ei(r)?i.push(r.subdivide(.5,!1)):i.push(r),ei(t)?i.push(t.subdivide(.5,!0)):i.push(t),ei(n)?i.push(n.subdivide(.5,!0).reverse()):i.push(n),ei(e)?i.push(e.subdivide(.5,!1).reverse()):i.push(e),i},Nk=function(r){var e=r.bounds,t=r.styles;return e.add(t.borderLeftWidth,t.borderTopWidth,-(t.borderRightWidth+t.borderLeftWidth),-(t.borderTopWidth+t.borderBottomWidth))},hh=function(r){var e=r.styles,t=r.bounds,n=kt(e.paddingLeft,t.width),i=kt(e.paddingRight,t.width),a=kt(e.paddingTop,t.width),s=kt(e.paddingBottom,t.width);return t.add(n+e.borderLeftWidth,a+e.borderTopWidth,-(e.borderRightWidth+e.borderLeftWidth+n+i),-(e.borderTopWidth+e.borderBottomWidth+a+s))},Y8=function(r,e){return r===0?e.bounds:r===2?hh(e):Nk(e)},X8=function(r,e){return r===0?e.bounds:r===2?hh(e):Nk(e)},dg=function(r,e,t){var n=Y8(Co(r.styles.backgroundOrigin,e),r),i=X8(Co(r.styles.backgroundClip,e),r),a=Z8(Co(r.styles.backgroundSize,e),t,n),s=a[0],o=a[1],A=LA(Co(r.styles.backgroundPosition,e),n.width-s,n.height-o),l=J8(Co(r.styles.backgroundRepeat,e),A,a,n,i),c=Math.round(n.left+A[0]),u=Math.round(n.top+A[1]);return[l,c,u,s,o]},vo=function(r){return nn(r)&&r.value===Do.AUTO},Rc=function(r){return typeof r=="number"},Z8=function(r,e,t){var n=e[0],i=e[1],a=e[2],s=r[0],o=r[1];if(!s)return[0,0];if(pn(s)&&o&&pn(o))return[kt(s,t.width),kt(o,t.height)];var A=Rc(a);if(nn(s)&&(s.value===Do.CONTAIN||s.value===Do.COVER)){if(Rc(a)){var l=t.width/t.height;return l<a!=(s.value===Do.COVER)?[t.width,t.width/a]:[t.height*a,t.height]}return[t.width,t.height]}var c=Rc(n),u=Rc(i),h=c||u;if(vo(s)&&(!o||vo(o))){if(c&&u)return[n,i];if(!A&&!h)return[t.width,t.height];if(h&&A){var d=c?n:i*a,f=u?i:n/a;return[d,f]}var g=c?n:t.width,v=u?i:t.height;return[g,v]}if(A){var p=0,y=0;return pn(s)?p=kt(s,t.width):pn(o)&&(y=kt(o,t.height)),vo(s)?p=y*a:(!o||vo(o))&&(y=p/a),[p,y]}var m=null,B=null;if(pn(s)?m=kt(s,t.width):o&&pn(o)&&(B=kt(o,t.height)),m!==null&&(!o||vo(o))&&(B=c&&u?m/n*i:t.height),B!==null&&vo(s)&&(m=c&&u?B/i*n:t.width),m!==null&&B!==null)return[m,B];throw new Error("Unable to calculate background-size for element")},Co=function(r,e){var t=r[e];return typeof t>"u"?r[0]:t},J8=function(r,e,t,n,i){var a=e[0],s=e[1],o=t[0],A=t[1];switch(r){case 2:return[new Fe(Math.round(n.left),Math.round(n.top+s)),new Fe(Math.round(n.left+n.width),Math.round(n.top+s)),new Fe(Math.round(n.left+n.width),Math.round(A+n.top+s)),new Fe(Math.round(n.left),Math.round(A+n.top+s))];case 3:return[new Fe(Math.round(n.left+a),Math.round(n.top)),new Fe(Math.round(n.left+a+o),Math.round(n.top)),new Fe(Math.round(n.left+a+o),Math.round(n.height+n.top)),new Fe(Math.round(n.left+a),Math.round(n.height+n.top))];case 1:return[new Fe(Math.round(n.left+a),Math.round(n.top+s)),new Fe(Math.round(n.left+a+o),Math.round(n.top+s)),new Fe(Math.round(n.left+a+o),Math.round(n.top+s+A)),new Fe(Math.round(n.left+a),Math.round(n.top+s+A))];default:return[new Fe(Math.round(i.left),Math.round(i.top)),new Fe(Math.round(i.left+i.width),Math.round(i.top)),new Fe(Math.round(i.left+i.width),Math.round(i.height+i.top)),new Fe(Math.round(i.left),Math.round(i.height+i.top))]}},ez="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7",lx="Hidden Text",tz=(function(){function r(e){this._data={},this._document=e}return r.prototype.parseMetrics=function(e,t){var n=this._document.createElement("div"),i=this._document.createElement("img"),a=this._document.createElement("span"),s=this._document.body;n.style.visibility="hidden",n.style.fontFamily=e,n.style.fontSize=t,n.style.margin="0",n.style.padding="0",n.style.whiteSpace="nowrap",s.appendChild(n),i.src=ez,i.width=1,i.height=1,i.style.margin="0",i.style.padding="0",i.style.verticalAlign="baseline",a.style.fontFamily=e,a.style.fontSize=t,a.style.margin="0",a.style.padding="0",a.appendChild(this._document.createTextNode(lx)),n.appendChild(a),n.appendChild(i);var o=i.offsetTop-a.offsetTop+2;n.removeChild(a),n.appendChild(this._document.createTextNode(lx)),n.style.lineHeight="normal",i.style.verticalAlign="super";var A=i.offsetTop-n.offsetTop+2;return s.removeChild(n),{baseline:o,middle:A}},r.prototype.getMetrics=function(e,t){var n=e+" "+t;return typeof this._data[n]>"u"&&(this._data[n]=this.parseMetrics(e,t)),this._data[n]},r})(),Uk=(function(){function r(e,t){this.context=e,this.options=t}return r})(),nz=1e4;(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;return i._activeEffects=[],i.canvas=n.canvas?n.canvas:document.createElement("canvas"),i.ctx=i.canvas.getContext("2d"),n.canvas||(i.canvas.width=Math.floor(n.width*n.scale),i.canvas.height=Math.floor(n.height*n.scale),i.canvas.style.width=n.width+"px",i.canvas.style.height=n.height+"px"),i.fontMetrics=new tz(document),i.ctx.scale(i.options.scale,i.options.scale),i.ctx.translate(-n.x,-n.y),i.ctx.textBaseline="bottom",i._activeEffects=[],i.context.logger.debug("Canvas renderer initialized ("+n.width+"x"+n.height+") with scale "+n.scale),i}return e.prototype.applyEffects=function(t){for(var n=this;this._activeEffects.length;)this.popEffect();t.forEach(function(i){return n.applyEffect(i)})},e.prototype.applyEffect=function(t){this.ctx.save(),z8(t)&&(this.ctx.globalAlpha=t.opacity),K8(t)&&(this.ctx.translate(t.offsetX,t.offsetY),this.ctx.transform(t.matrix[0],t.matrix[1],t.matrix[2],t.matrix[3],t.matrix[4],t.matrix[5]),this.ctx.translate(-t.offsetX,-t.offsetY)),Ik(t)&&(this.path(t.path),this.ctx.clip()),this._activeEffects.push(t)},e.prototype.popEffect=function(){this._activeEffects.pop(),this.ctx.restore()},e.prototype.renderStack=function(t){return Yr(this,void 0,void 0,function(){var n;return Lr(this,function(i){switch(i.label){case 0:return n=t.element.container.styles,n.isVisible()?[4,this.renderStackContent(t)]:[3,2];case 1:i.sent(),i.label=2;case 2:return[2]}})})},e.prototype.renderNode=function(t){return Yr(this,void 0,void 0,function(){return Lr(this,function(n){switch(n.label){case 0:if(xn(t.container.flags,16))debugger;return t.container.styles.isVisible()?[4,this.renderNodeBackgroundAndBorders(t)]:[3,3];case 1:return n.sent(),[4,this.renderNodeContent(t)];case 2:n.sent(),n.label=3;case 3:return[2]}})})},e.prototype.renderTextWithLetterSpacing=function(t,n,i){var a=this;if(n===0)this.ctx.fillText(t.text,t.bounds.left,t.bounds.top+i);else{var s=oB(t.text);s.reduce(function(o,A){return a.ctx.fillText(A,o,t.bounds.top+i),o+a.ctx.measureText(A).width},t.bounds.left)}},e.prototype.createFontStyle=function(t){var n=t.fontVariant.filter(function(s){return s==="normal"||s==="small-caps"}).join(""),i=oz(t.fontFamily).join(", "),a=Ll(t.fontSize)?""+t.fontSize.number+t.fontSize.unit:t.fontSize.number+"px";return[[t.fontStyle,n,t.fontWeight,a,i].join(" "),i,a]},e.prototype.renderTextNode=function(t,n){return Yr(this,void 0,void 0,function(){var i,a,s,o,A,l,c,u,h=this;return Lr(this,function(d){return i=this.createFontStyle(n),a=i[0],s=i[1],o=i[2],this.ctx.font=a,this.ctx.direction=n.direction===1?"rtl":"ltr",this.ctx.textAlign="left",this.ctx.textBaseline="alphabetic",A=this.fontMetrics.getMetrics(s,o),l=A.baseline,c=A.middle,u=n.paintOrder,t.textBounds.forEach(function(f){u.forEach(function(g){switch(g){case 0:h.ctx.fillStyle=_n(n.color),h.renderTextWithLetterSpacing(f,n.letterSpacing,l);var v=n.textShadow;v.length&&f.text.trim().length&&(v.slice(0).reverse().forEach(function(p){h.ctx.shadowColor=_n(p.color),h.ctx.shadowOffsetX=p.offsetX.number*h.options.scale,h.ctx.shadowOffsetY=p.offsetY.number*h.options.scale,h.ctx.shadowBlur=p.blur.number,h.renderTextWithLetterSpacing(f,n.letterSpacing,l)}),h.ctx.shadowColor="",h.ctx.shadowOffsetX=0,h.ctx.shadowOffsetY=0,h.ctx.shadowBlur=0),n.textDecorationLine.length&&(h.ctx.fillStyle=_n(n.textDecorationColor||n.color),n.textDecorationLine.forEach(function(p){switch(p){case 1:h.ctx.fillRect(f.bounds.left,Math.round(f.bounds.top+l),f.bounds.width,1);break;case 2:h.ctx.fillRect(f.bounds.left,Math.round(f.bounds.top),f.bounds.width,1);break;case 3:h.ctx.fillRect(f.bounds.left,Math.ceil(f.bounds.top+c),f.bounds.width,1);break}}));break;case 1:n.webkitTextStrokeWidth&&f.text.trim().length&&(h.ctx.strokeStyle=_n(n.webkitTextStrokeColor),h.ctx.lineWidth=n.webkitTextStrokeWidth,h.ctx.lineJoin=window.chrome?"miter":"round",h.ctx.strokeText(f.text,f.bounds.left,f.bounds.top+l)),h.ctx.strokeStyle="",h.ctx.lineWidth=0,h.ctx.lineJoin="miter";break}})}),[2]})})},e.prototype.renderReplacedElement=function(t,n,i){if(i&&t.intrinsicWidth>0&&t.intrinsicHeight>0){var a=hh(t),s=uh(n);this.path(s),this.ctx.save(),this.ctx.clip(),this.ctx.drawImage(i,0,0,t.intrinsicWidth,t.intrinsicHeight,a.left,a.top,a.width,a.height),this.ctx.restore()}},e.prototype.renderNodeContent=function(t){return Yr(this,void 0,void 0,function(){var n,i,a,s,o,A,y,y,l,c,u,h,B,d,f,C,g,v,p,y,m,B,C;return Lr(this,function(S){switch(S.label){case 0:this.applyEffects(t.getEffects(4)),n=t.container,i=t.curves,a=n.styles,s=0,o=n.textNodes,S.label=1;case 1:return s<o.length?(A=o[s],[4,this.renderTextNode(A,a)]):[3,4];case 2:S.sent(),S.label=3;case 3:return s++,[3,1];case 4:if(!(n instanceof mk))return[3,8];S.label=5;case 5:return S.trys.push([5,7,,8]),[4,this.context.cache.match(n.src)];case 6:return y=S.sent(),this.renderReplacedElement(n,i,y),[3,8];case 7:return S.sent(),this.context.logger.error("Error loading image "+n.src),[3,8];case 8:if(n instanceof wk&&this.renderReplacedElement(n,i,n.canvas),!(n instanceof Bk))return[3,12];S.label=9;case 9:return S.trys.push([9,11,,12]),[4,this.context.cache.match(n.svg)];case 10:return y=S.sent(),this.renderReplacedElement(n,i,y),[3,12];case 11:return S.sent(),this.context.logger.error("Error loading svg "+n.svg.substring(0,255)),[3,12];case 12:return n instanceof Ck&&n.tree?(l=new e(this.context,{scale:this.options.scale,backgroundColor:n.backgroundColor,x:0,y:0,width:n.width,height:n.height}),[4,l.render(n.tree)]):[3,14];case 13:c=S.sent(),n.width&&n.height&&this.ctx.drawImage(c,0,0,n.width,n.height,n.bounds.left,n.bounds.top,n.bounds.width,n.bounds.height),S.label=14;case 14:if(n instanceof AB&&(u=Math.min(n.bounds.width,n.bounds.height),n.type===Ah?n.checked&&(this.ctx.save(),this.path([new Fe(n.bounds.left+u*.39363,n.bounds.top+u*.79),new Fe(n.bounds.left+u*.16,n.bounds.top+u*.5549),new Fe(n.bounds.left+u*.27347,n.bounds.top+u*.44071),new Fe(n.bounds.left+u*.39694,n.bounds.top+u*.5649),new Fe(n.bounds.left+u*.72983,n.bounds.top+u*.23),new Fe(n.bounds.left+u*.84,n.bounds.top+u*.34085),new Fe(n.bounds.left+u*.39363,n.bounds.top+u*.79)]),this.ctx.fillStyle=_n(ex),this.ctx.fill(),this.ctx.restore()):n.type===lh&&n.checked&&(this.ctx.save(),this.ctx.beginPath(),this.ctx.arc(n.bounds.left+u/2,n.bounds.top+u/2,u/4,0,Math.PI*2,!0),this.ctx.fillStyle=_n(ex),this.ctx.fill(),this.ctx.restore())),rz(n)&&n.value.length){switch(h=this.createFontStyle(a),B=h[0],d=h[1],f=this.fontMetrics.getMetrics(B,d).baseline,this.ctx.font=B,this.ctx.fillStyle=_n(a.color),this.ctx.textBaseline="alphabetic",this.ctx.textAlign=az(n.styles.textAlign),C=hh(n),g=0,n.styles.textAlign){case 1:g+=C.width/2;break;case 2:g+=C.width;break}v=C.add(g,0,0,-C.height/2+1),this.ctx.save(),this.path([new Fe(C.left,C.top),new Fe(C.left+C.width,C.top),new Fe(C.left+C.width,C.top+C.height),new Fe(C.left,C.top+C.height)]),this.ctx.clip(),this.renderTextWithLetterSpacing(new JA(n.value,v),a.letterSpacing,f),this.ctx.restore(),this.ctx.textBaseline="alphabetic",this.ctx.textAlign="left"}if(!xn(n.styles.display,2048))return[3,20];if(n.styles.listStyleImage===null)return[3,19];if(p=n.styles.listStyleImage,p.type!==0)return[3,18];y=void 0,m=p.url,S.label=15;case 15:return S.trys.push([15,17,,18]),[4,this.context.cache.match(m)];case 16:return y=S.sent(),this.ctx.drawImage(y,n.bounds.left-(y.width+10),n.bounds.top),[3,18];case 17:return S.sent(),this.context.logger.error("Error loading list-style-image "+m),[3,18];case 18:return[3,20];case 19:t.listValue&&n.styles.listStyleType!==-1&&(B=this.createFontStyle(a)[0],this.ctx.font=B,this.ctx.fillStyle=_n(a.color),this.ctx.textBaseline="middle",this.ctx.textAlign="right",C=new zs(n.bounds.left,n.bounds.top+kt(n.styles.paddingTop,n.bounds.width),n.bounds.width,PE(a.lineHeight,a.fontSize.number)/2+1),this.renderTextWithLetterSpacing(new JA(t.listValue,C),a.letterSpacing,PE(a.lineHeight,a.fontSize.number)/2+2),this.ctx.textBaseline="bottom",this.ctx.textAlign="left"),S.label=20;case 20:return[2]}})})},e.prototype.renderStackContent=function(t){return Yr(this,void 0,void 0,function(){var n,i,p,a,s,p,o,A,p,l,c,p,u,h,p,d,f,p,g,v,p;return Lr(this,function(y){switch(y.label){case 0:if(xn(t.element.container.flags,16))debugger;return[4,this.renderNodeBackgroundAndBorders(t.element)];case 1:y.sent(),n=0,i=t.negativeZIndex,y.label=2;case 2:return n<i.length?(p=i[n],[4,this.renderStack(p)]):[3,5];case 3:y.sent(),y.label=4;case 4:return n++,[3,2];case 5:return[4,this.renderNodeContent(t.element)];case 6:y.sent(),a=0,s=t.nonInlineLevel,y.label=7;case 7:return a<s.length?(p=s[a],[4,this.renderNode(p)]):[3,10];case 8:y.sent(),y.label=9;case 9:return a++,[3,7];case 10:o=0,A=t.nonPositionedFloats,y.label=11;case 11:return o<A.length?(p=A[o],[4,this.renderStack(p)]):[3,14];case 12:y.sent(),y.label=13;case 13:return o++,[3,11];case 14:l=0,c=t.nonPositionedInlineLevel,y.label=15;case 15:return l<c.length?(p=c[l],[4,this.renderStack(p)]):[3,18];case 16:y.sent(),y.label=17;case 17:return l++,[3,15];case 18:u=0,h=t.inlineLevel,y.label=19;case 19:return u<h.length?(p=h[u],[4,this.renderNode(p)]):[3,22];case 20:y.sent(),y.label=21;case 21:return u++,[3,19];case 22:d=0,f=t.zeroOrAutoZIndexOrTransformedOrOpacity,y.label=23;case 23:return d<f.length?(p=f[d],[4,this.renderStack(p)]):[3,26];case 24:y.sent(),y.label=25;case 25:return d++,[3,23];case 26:g=0,v=t.positiveZIndex,y.label=27;case 27:return g<v.length?(p=v[g],[4,this.renderStack(p)]):[3,30];case 28:y.sent(),y.label=29;case 29:return g++,[3,27];case 30:return[2]}})})},e.prototype.mask=function(t){this.ctx.beginPath(),this.ctx.moveTo(0,0),this.ctx.lineTo(this.canvas.width,0),this.ctx.lineTo(this.canvas.width,this.canvas.height),this.ctx.lineTo(0,this.canvas.height),this.ctx.lineTo(0,0),this.formatPath(t.slice(0).reverse()),this.ctx.closePath()},e.prototype.path=function(t){this.ctx.beginPath(),this.formatPath(t),this.ctx.closePath()},e.prototype.formatPath=function(t){var n=this;t.forEach(function(i,a){var s=ei(i)?i.start:i;a===0?n.ctx.moveTo(s.x,s.y):n.ctx.lineTo(s.x,s.y),ei(i)&&n.ctx.bezierCurveTo(i.startControl.x,i.startControl.y,i.endControl.x,i.endControl.y,i.end.x,i.end.y)})},e.prototype.renderRepeat=function(t,n,i,a){this.path(t),this.ctx.fillStyle=n,this.ctx.translate(i,a),this.ctx.fill(),this.ctx.translate(-i,-a)},e.prototype.resizeImage=function(t,n,i){var a;if(t.width===n&&t.height===i)return t;var s=(a=this.canvas.ownerDocument)!==null&&a!==void 0?a:document,o=s.createElement("canvas");o.width=Math.max(1,n),o.height=Math.max(1,i);var A=o.getContext("2d");return A.drawImage(t,0,0,t.width,t.height,0,0,n,i),o},e.prototype.renderBackgroundImage=function(t){return Yr(this,void 0,void 0,function(){var n,i,a,s,o,A;return Lr(this,function(l){switch(l.label){case 0:n=t.styles.backgroundImage.length-1,i=function(c){var u,h,d,_,V,K,U,G,T,f,_,V,K,U,G,g,v,p,y,m,B,C,S,F,T,O,_,k,L,U,G,W,V,K,D,X,te,ie,re,xe,$,z;return Lr(this,function(ee){switch(ee.label){case 0:if(c.type!==0)return[3,5];u=void 0,h=c.url,ee.label=1;case 1:return ee.trys.push([1,3,,4]),[4,a.context.cache.match(h)];case 2:return u=ee.sent(),[3,4];case 3:return ee.sent(),a.context.logger.error("Error loading background-image "+h),[3,4];case 4:return u&&(d=dg(t,n,[u.width,u.height,u.width/u.height]),_=d[0],V=d[1],K=d[2],U=d[3],G=d[4],T=a.ctx.createPattern(a.resizeImage(u,U,G),"repeat"),a.renderRepeat(_,T,V,K)),[3,6];case 5:aG(c)?(f=dg(t,n,[null,null,null]),_=f[0],V=f[1],K=f[2],U=f[3],G=f[4],g=eG(c.angle,U,G),v=g[0],p=g[1],y=g[2],m=g[3],B=g[4],C=document.createElement("canvas"),C.width=U,C.height=G,S=C.getContext("2d"),F=S.createLinearGradient(p,m,y,B),NE(c.stops,v).forEach(function(Ae){return F.addColorStop(Ae.stop,_n(Ae.color))}),S.fillStyle=F,S.fillRect(0,0,U,G),U>0&&G>0&&(T=a.ctx.createPattern(C,"repeat"),a.renderRepeat(_,T,V,K))):sG(c)&&(O=dg(t,n,[null,null,null]),_=O[0],k=O[1],L=O[2],U=O[3],G=O[4],W=c.position.length===0?[iB]:c.position,V=kt(W[0],U),K=kt(W[W.length-1],G),D=tG(c,V,K,U,G),X=D[0],te=D[1],X>0&&te>0&&(ie=a.ctx.createRadialGradient(k+V,L+K,0,k+V,L+K,X),NE(c.stops,X*2).forEach(function(Ae){return ie.addColorStop(Ae.stop,_n(Ae.color))}),a.path(_),a.ctx.fillStyle=ie,X!==te?(re=t.bounds.left+.5*t.bounds.width,xe=t.bounds.top+.5*t.bounds.height,$=te/X,z=1/$,a.ctx.save(),a.ctx.translate(re,xe),a.ctx.transform(1,0,0,$,0,0),a.ctx.translate(-re,-xe),a.ctx.fillRect(k,z*(L-xe)+xe,U,G*z),a.ctx.restore()):a.ctx.fill())),ee.label=6;case 6:return n--,[2]}})},a=this,s=0,o=t.styles.backgroundImage.slice(0).reverse(),l.label=1;case 1:return s<o.length?(A=o[s],[5,i(A)]):[3,4];case 2:l.sent(),l.label=3;case 3:return s++,[3,1];case 4:return[2]}})})},e.prototype.renderSolidBorder=function(t,n,i){return Yr(this,void 0,void 0,function(){return Lr(this,function(a){return this.path(Ax(i,n)),this.ctx.fillStyle=_n(t),this.ctx.fill(),[2]})})},e.prototype.renderDoubleBorder=function(t,n,i,a){return Yr(this,void 0,void 0,function(){var s,o;return Lr(this,function(A){switch(A.label){case 0:return n<3?[4,this.renderSolidBorder(t,i,a)]:[3,2];case 1:return A.sent(),[2];case 2:return s=W8(a,i),this.path(s),this.ctx.fillStyle=_n(t),this.ctx.fill(),o=q8(a,i),this.path(o),this.ctx.fill(),[2]}})})},e.prototype.renderNodeBackgroundAndBorders=function(t){return Yr(this,void 0,void 0,function(){var n,i,a,s,o,A,l,c,u=this;return Lr(this,function(h){switch(h.label){case 0:return this.applyEffects(t.getEffects(2)),n=t.container.styles,i=!Ro(n.backgroundColor)||n.backgroundImage.length,a=[{style:n.borderTopStyle,color:n.borderTopColor,width:n.borderTopWidth},{style:n.borderRightStyle,color:n.borderRightColor,width:n.borderRightWidth},{style:n.borderBottomStyle,color:n.borderBottomColor,width:n.borderBottomWidth},{style:n.borderLeftStyle,color:n.borderLeftColor,width:n.borderLeftWidth}],s=iz(Co(n.backgroundClip,0),t.curves),i||n.boxShadow.length?(this.ctx.save(),this.path(s),this.ctx.clip(),Ro(n.backgroundColor)||(this.ctx.fillStyle=_n(n.backgroundColor),this.ctx.fill()),[4,this.renderBackgroundImage(t.container)]):[3,2];case 1:h.sent(),this.ctx.restore(),n.boxShadow.slice(0).reverse().forEach(function(d){u.ctx.save();var f=ch(t.curves),g=d.inset?0:nz,v=V8(f,-g+(d.inset?1:-1)*d.spread.number,(d.inset?1:-1)*d.spread.number,d.spread.number*(d.inset?-2:2),d.spread.number*(d.inset?-2:2));d.inset?(u.path(f),u.ctx.clip(),u.mask(v)):(u.mask(f),u.ctx.clip(),u.path(v)),u.ctx.shadowOffsetX=d.offsetX.number+g,u.ctx.shadowOffsetY=d.offsetY.number,u.ctx.shadowColor=_n(d.color),u.ctx.shadowBlur=d.blur.number,u.ctx.fillStyle=d.inset?_n(d.color):"rgba(0,0,0,1)",u.ctx.fill(),u.ctx.restore()}),h.label=2;case 2:o=0,A=0,l=a,h.label=3;case 3:return A<l.length?(c=l[A],c.style!==0&&!Ro(c.color)&&c.width>0?c.style!==2?[3,5]:[4,this.renderDashedDottedBorder(c.color,c.width,o,t.curves,2)]:[3,11]):[3,13];case 4:return h.sent(),[3,11];case 5:return c.style!==3?[3,7]:[4,this.renderDashedDottedBorder(c.color,c.width,o,t.curves,3)];case 6:return h.sent(),[3,11];case 7:return c.style!==4?[3,9]:[4,this.renderDoubleBorder(c.color,c.width,o,t.curves)];case 8:return h.sent(),[3,11];case 9:return[4,this.renderSolidBorder(c.color,o,t.curves)];case 10:h.sent(),h.label=11;case 11:o++,h.label=12;case 12:return A++,[3,3];case 13:return[2]}})})},e.prototype.renderDashedDottedBorder=function(t,n,i,a,s){return Yr(this,void 0,void 0,function(){var o,A,l,c,u,h,d,f,g,v,p,y,m,B,C,S,C,S;return Lr(this,function(F){return this.ctx.save(),o=$8(a,i),A=Ax(a,i),s===2&&(this.path(A),this.ctx.clip()),ei(A[0])?(l=A[0].start.x,c=A[0].start.y):(l=A[0].x,c=A[0].y),ei(A[1])?(u=A[1].end.x,h=A[1].end.y):(u=A[1].x,h=A[1].y),i===0||i===2?d=Math.abs(l-u):d=Math.abs(c-h),this.ctx.beginPath(),s===3?this.formatPath(o):this.formatPath(A.slice(0,2)),f=n<3?n*3:n*2,g=n<3?n*2:n,s===3&&(f=n,g=n),v=!0,d<=f*2?v=!1:d<=f*2+g?(p=d/(2*f+g),f*=p,g*=p):(y=Math.floor((d+g)/(f+g)),m=(d-y*f)/(y-1),B=(d-(y+1)*f)/y,g=B<=0||Math.abs(g-m)<Math.abs(g-B)?m:B),v&&(s===3?this.ctx.setLineDash([0,f+g]):this.ctx.setLineDash([f,g])),s===3?(this.ctx.lineCap="round",this.ctx.lineWidth=n):this.ctx.lineWidth=n*2+1.1,this.ctx.strokeStyle=_n(t),this.ctx.stroke(),this.ctx.setLineDash([]),s===2&&(ei(A[0])&&(C=A[3],S=A[0],this.ctx.beginPath(),this.formatPath([new Fe(C.end.x,C.end.y),new Fe(S.start.x,S.start.y)]),this.ctx.stroke()),ei(A[1])&&(C=A[1],S=A[2],this.ctx.beginPath(),this.formatPath([new Fe(C.end.x,C.end.y),new Fe(S.start.x,S.start.y)]),this.ctx.stroke())),this.ctx.restore(),[2]})})},e.prototype.render=function(t){return Yr(this,void 0,void 0,function(){var n;return Lr(this,function(i){switch(i.label){case 0:return this.options.backgroundColor&&(this.ctx.fillStyle=_n(this.options.backgroundColor),this.ctx.fillRect(this.options.x,this.options.y,this.options.width,this.options.height)),n=j8(t),[4,this.renderStack(n)];case 1:return i.sent(),this.applyEffects([]),[2,this.canvas]}})})},e})(Uk);var rz=function(r){return r instanceof xk||r instanceof Ek?!0:r instanceof AB&&r.type!==lh&&r.type!==Ah},iz=function(r,e){switch(r){case 0:return ch(e);case 2:return D8(e);default:return uh(e)}},az=function(r){switch(r){case 1:return"center";case 2:return"right";default:return"left"}},sz=["-apple-system","system-ui"],oz=function(r){return/iPhone OS 15_(0|1)/.test(window.navigator.userAgent)?r.filter(function(e){return sz.indexOf(e)===-1}):r};(function(r){Ei(e,r);function e(t,n){var i=r.call(this,t,n)||this;return i.canvas=n.canvas?n.canvas:document.createElement("canvas"),i.ctx=i.canvas.getContext("2d"),i.options=n,i.canvas.width=Math.floor(n.width*n.scale),i.canvas.height=Math.floor(n.height*n.scale),i.canvas.style.width=n.width+"px",i.canvas.style.height=n.height+"px",i.ctx.scale(i.options.scale,i.options.scale),i.ctx.translate(-n.x,-n.y),i.context.logger.debug("EXPERIMENTAL ForeignObject renderer initialized ("+n.width+"x"+n.height+" at "+n.x+","+n.y+") with scale "+n.scale),i}return e.prototype.render=function(t){return Yr(this,void 0,void 0,function(){var n,i;return Lr(this,function(a){switch(a.label){case 0:return n=t1(this.options.width*this.options.scale,this.options.height*this.options.scale,this.options.scale,this.options.scale,t),[4,Az(n)];case 1:return i=a.sent(),this.options.backgroundColor&&(this.ctx.fillStyle=_n(this.options.backgroundColor),this.ctx.fillRect(0,0,this.options.width*this.options.scale,this.options.height*this.options.scale)),this.ctx.drawImage(i,-this.options.x*this.options.scale,-this.options.y*this.options.scale),[2,this.canvas]}})})},e})(Uk);var Az=function(r){return new Promise(function(e,t){var n=new Image;n.onload=function(){e(n)},n.onerror=t,n.src="data:image/svg+xml;charset=utf-8,"+encodeURIComponent(new XMLSerializer().serializeToString(r))})};typeof window<"u"&&P8.setContext(window);var fg=(function(r){function e(t,n,i,a){var s;return ue(this,e),s=qe(this,e,[t]),s.currentTime=i,s.timelineTime=a,s.target=n,s.type="finish",s.bubbles=!1,s.currentTarget=n,s.defaultPrevented=!1,s.eventPhase=s.AT_TARGET,s.timeStamp=Date.now(),s.currentTime=i,s.timelineTime=a,s}return $e(e,r),he(e)})(Rh),lz=0,cz=(function(){function r(e,t){var n;ue(this,r),this.currentTimePending=!1,this._idle=!0,this._paused=!1,this._finishedFlag=!0,this._currentTime=0,this._playbackRate=1,this._inTimeline=!0,this.effect=e,e.animation=this,this.timeline=t,this.id="".concat(lz++),this._inEffect=!!this.effect.update(0),this._totalDuration=Number((n=this.effect)===null||n===void 0?void 0:n.getComputedTiming().endTime),this._holdTime=0,this._paused=!1,this.oldPlayState="idle",this.updatePromises()}return he(r,[{key:"pending",get:function(){return this._startTime===null&&!this._paused&&this.playbackRate!==0||this.currentTimePending}},{key:"playState",get:function(){return this._idle?"idle":this._isFinished?"finished":this._paused?"paused":"running"}},{key:"ready",get:function(){var t=this;return this.readyPromise||(this.timeline.animationsWithPromises.indexOf(this)===-1&&this.timeline.animationsWithPromises.push(this),this.readyPromise=new Promise(function(n,i){t.resolveReadyPromise=function(){n(t)},t.rejectReadyPromise=function(){i(new Error)}}),this.pending||this.resolveReadyPromise()),this.readyPromise}},{key:"finished",get:function(){var t=this;return this.finishedPromise||(this.timeline.animationsWithPromises.indexOf(this)===-1&&this.timeline.animationsWithPromises.push(this),this.finishedPromise=new Promise(function(n,i){t.resolveFinishedPromise=function(){n(t)},t.rejectFinishedPromise=function(){i(new Error)}}),this.playState==="finished"&&this.resolveFinishedPromise()),this.finishedPromise}},{key:"currentTime",get:function(){return this.updatePromises(),this._idle||this.currentTimePending?null:this._currentTime},set:function(t){if(t=Number(t),!isNaN(t)){if(this.timeline.restart(),!this._paused&&this._startTime!==null){var n;this._startTime=Number((n=this.timeline)===null||n===void 0?void 0:n.currentTime)-t/this.playbackRate}this.currentTimePending=!1,this._currentTime!==t&&(this._idle&&(this._idle=!1,this._paused=!0),this.tickCurrentTime(t,!0),this.timeline.applyDirtiedAnimation(this))}}},{key:"startTime",get:function(){return this._startTime},set:function(t){if(t!==null){if(this.updatePromises(),t=Number(t),isNaN(t)||this._paused||this._idle)return;this._startTime=t,this.tickCurrentTime((Number(this.timeline.currentTime)-this._startTime)*this.playbackRate),this.timeline.applyDirtiedAnimation(this),this.updatePromises()}}},{key:"playbackRate",get:function(){return this._playbackRate},set:function(t){if(t!==this._playbackRate){this.updatePromises();var n=this.currentTime;this._playbackRate=t,this.startTime=null,this.playState!=="paused"&&this.playState!=="idle"&&(this._finishedFlag=!1,this._idle=!1,this.ensureAlive(),this.timeline.applyDirtiedAnimation(this)),n!==null&&(this.currentTime=n),this.updatePromises()}}},{key:"_isFinished",get:function(){return!this._idle&&(this._playbackRate>0&&Number(this._currentTime)>=this._totalDuration||this._playbackRate<0&&Number(this._currentTime)<=0)}},{key:"totalDuration",get:function(){return this._totalDuration}},{key:"_needsTick",get:function(){return this.pending||this.playState==="running"||!this._finishedFlag}},{key:"updatePromises",value:function(){var t;if((t=this.effect.target)!==null&&t!==void 0&&t.destroyed)return this.readyPromise=void 0,this.finishedPromise=void 0,!1;var n=this.oldPlayState,i=this.pending?"pending":this.playState;return this.readyPromise&&i!==n&&(i==="idle"?(this.rejectReadyPromise(),this.readyPromise=void 0):n==="pending"?this.resolveReadyPromise():i==="pending"&&(this.readyPromise=void 0)),this.finishedPromise&&i!==n&&(i==="idle"?(this.rejectFinishedPromise(),this.finishedPromise=void 0):i==="finished"?this.resolveFinishedPromise():n==="finished"&&(this.finishedPromise=void 0)),this.oldPlayState=i,this.readyPromise||this.finishedPromise}},{key:"play",value:function(){this.updatePromises(),this._paused=!1,(this._isFinished||this._idle)&&(this.rewind(),this._startTime=null),this._finishedFlag=!1,this._idle=!1,this.ensureAlive(),this.timeline.applyDirtiedAnimation(this),this.timeline.animations.indexOf(this)===-1&&this.timeline.animations.push(this),this.updatePromises()}},{key:"pause",value:function(){this.updatePromises(),this.currentTime&&(this._holdTime=this.currentTime),!this._isFinished&&!this._paused&&!this._idle?this.currentTimePending=!0:this._idle&&(this.rewind(),this._idle=!1),this._startTime=null,this._paused=!0,this.updatePromises()}},{key:"finish",value:function(){this.updatePromises(),!this._idle&&(this.currentTime=this._playbackRate>0?this._totalDuration:0,this._startTime=this._totalDuration-this.currentTime,this.currentTimePending=!1,this.timeline.applyDirtiedAnimation(this),this.updatePromises())}},{key:"cancel",value:function(){var t=this;if(this.updatePromises(),!!this._inEffect&&(this._inEffect=!1,this._idle=!0,this._paused=!1,this._finishedFlag=!0,this._currentTime=null,this._startTime=null,this.effect.update(null),this.timeline.applyDirtiedAnimation(this),this.updatePromises(),this.oncancel)){var n=new fg(null,this,this.currentTime,null);setTimeout(function(){t.oncancel(n)})}}},{key:"reverse",value:function(){this.updatePromises();var t=this.currentTime;this.playbackRate*=-1,this.play(),t!==null&&(this.currentTime=t),this.updatePromises()}},{key:"updatePlaybackRate",value:function(t){this.playbackRate=t}},{key:"targetAnimations",value:function(){var t,n=(t=this.effect)===null||t===void 0?void 0:t.target;return n.getAnimations()}},{key:"markTarget",value:function(){var t=this.targetAnimations();t.indexOf(this)===-1&&t.push(this)}},{key:"unmarkTarget",value:function(){var t=this.targetAnimations(),n=t.indexOf(this);n!==-1&&t.splice(n,1)}},{key:"tick",value:function(t,n){!this._idle&&!this._paused&&(this._startTime===null?n&&(this.startTime=t-this._currentTime/this.playbackRate):this._isFinished||this.tickCurrentTime((t-this._startTime)*this.playbackRate)),n&&(this.currentTimePending=!1,this.fireEvents(t))}},{key:"rewind",value:function(){if(this.playbackRate>=0)this.currentTime=0;else if(this._totalDuration<1/0)this.currentTime=this._totalDuration;else throw new Error("Unable to rewind negative playback rate animation with infinite duration")}},{key:"persist",value:function(){throw new Error(wt)}},{key:"addEventListener",value:function(t,n,i){throw new Error(wt)}},{key:"removeEventListener",value:function(t,n,i){throw new Error(wt)}},{key:"dispatchEvent",value:function(t){throw new Error(wt)}},{key:"commitStyles",value:function(){throw new Error(wt)}},{key:"ensureAlive",value:function(){if(this.playbackRate<0&&this.currentTime===0){var t;this._inEffect=!!((t=this.effect)!==null&&t!==void 0&&t.update(-1))}else{var n;this._inEffect=!!((n=this.effect)!==null&&n!==void 0&&n.update(this.currentTime))}!this._inTimeline&&(this._inEffect||!this._finishedFlag)&&(this._inTimeline=!0,this.timeline.animations.push(this))}},{key:"tickCurrentTime",value:function(t,n){t!==this._currentTime&&(this._currentTime=t,this._isFinished&&!n&&(this._currentTime=this._playbackRate>0?this._totalDuration:0),this.ensureAlive())}},{key:"fireEvents",value:function(t){var n=this;if(this._isFinished){if(!this._finishedFlag){if(this.onfinish){var i=new fg(null,this,this.currentTime,t);setTimeout(function(){n.onfinish&&n.onfinish(i)})}this._finishedFlag=!0}}else{if(this.onframe&&this.playState==="running"){var a=new fg(null,this,this.currentTime,t);this.onframe(a)}this._finishedFlag=!1}}}])})(),uz=4,hz=.001,dz=1e-7,fz=10,UA=11,Dc=1/(UA-1),gz=typeof Float32Array=="function",Pk=function(e,t){return 1-3*t+3*e},Rk=function(e,t){return 3*t-6*e},Dk=function(e){return 3*e},dh=function(e,t,n){return((Pk(t,n)*e+Rk(t,n))*e+Dk(t))*e},Hk=function(e,t,n){return 3*Pk(t,n)*e*e+2*Rk(t,n)*e+Dk(t)},vz=function(e,t,n,i,a){var s,o,A=0;do o=t+(n-t)/2,s=dh(o,i,a)-e,s>0?n=o:t=o;while(Math.abs(s)>dz&&++A<fz);return o},pz=function(e,t,n,i){for(var a=0;a<uz;++a){var s=Hk(t,n,i);if(s===0)return t;var o=dh(t,n,i)-e;t-=o/s}return t},cB=function(e,t,n,i){if(!(e>=0&&e<=1&&n>=0&&n<=1))throw new Error("bezier x values must be in [0, 1] range");if(e===t&&n===i)return function(A){return A};for(var a=gz?new Float32Array(UA):new Array(UA),s=0;s<UA;++s)a[s]=dh(s*Dc,e,n);var o=function(l){for(var c=0,u=1,h=UA-1;u!==h&&a[u]<=l;++u)c+=Dc;--u;var d=(l-a[u])/(a[u+1]-a[u]),f=c+d*Dc,g=Hk(f,e,n);return g>=hz?pz(l,f,e,n):g===0?f:vz(l,c,c+Dc,e,n)};return function(A){return A===0||A===1?A:dh(o(A),t,i)}},yz=function(e){return e=e.replace(/([A-Z])/g,function(t){return"-".concat(t.toLowerCase())}),e.charAt(0)==="-"?e.substring(1):e},Hc=function(e){return Math.pow(e,2)},Gc=function(e){return Math.pow(e,3)},Kc=function(e){return Math.pow(e,4)},zc=function(e){return Math.pow(e,5)},Vc=function(e){return Math.pow(e,6)},jc=function(e){return 1-Math.cos(e*Math.PI/2)},Wc=function(e){return 1-Math.sqrt(1-e*e)},qc=function(e){return e*e*(3*e-2)},$c=function(e){for(var t,n=4;e<((t=Math.pow(2,--n))-1)/11;);return 1/Math.pow(4,3-n)-7.5625*Math.pow((t*3-2)/22-e,2)},Yc=function(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],n=We(t,2),i=n[0],a=i===void 0?1:i,s=n[1],o=s===void 0?.5:s,A=Yt(Number(a),1,10),l=Yt(Number(o),.1,2);return e===0||e===1?e:-A*Math.pow(2,10*(e-1))*Math.sin((e-1-l/(Math.PI*2)*Math.asin(1/A))*(Math.PI*2)/l)},bA=function(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],n=arguments.length>2?arguments[2]:void 0,i=We(t,4),a=i[0],s=a===void 0?1:a,o=i[1],A=o===void 0?100:o,l=i[2],c=l===void 0?10:l,u=i[3],h=u===void 0?0:u;s=Yt(s,.1,1e3),A=Yt(A,.1,1e3),c=Yt(c,.1,1e3),h=Yt(h,.1,1e3);var d=Math.sqrt(A/s),f=c/(2*Math.sqrt(A*s)),g=f<1?d*Math.sqrt(1-f*f):0,v=1,p=f<1?(f*d+-h)/g:-h+d,y=n?n*e/1e3:e;return f<1?y=Math.exp(-y*f*d)*(v*Math.cos(g*y)+p*Math.sin(g*y)):y=(v+p*y)*Math.exp(-y*d),e===0||e===1?e:1-y},gg=function(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],n=t,i=We(n,2),a=i[0],s=a===void 0?10:a,o=i[1],A=o==="start"?Math.ceil:Math.floor;return A(Yt(e,0,1)*s)/s},cx=function(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],n=We(t,4),i=n[0],a=n[1],s=n[2],o=n[3];return cB(i,a,s,o)(e)},Xc=cB(.42,0,1,1),jr=function(e){return function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],i=arguments.length>2?arguments[2]:void 0;return 1-e(1-t,n,i)}},Wr=function(e){return function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],i=arguments.length>2?arguments[2]:void 0;return t<.5?e(t*2,n,i)/2:1-e(t*-2+2,n,i)/2}},qr=function(e){return function(t){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:[],i=arguments.length>2?arguments[2]:void 0;return t<.5?(1-e(1-t*2,n,i))/2:(e(t*2-1,n,i)+1)/2}},ux={steps:gg,"step-start":function(e){return gg(e,[1,"start"])},"step-end":function(e){return gg(e,[1,"end"])},linear:function(e){return e},"cubic-bezier":cx,ease:function(e){return cx(e,[.25,.1,.25,1])},in:Xc,out:jr(Xc),"in-out":Wr(Xc),"out-in":qr(Xc),"in-quad":Hc,"out-quad":jr(Hc),"in-out-quad":Wr(Hc),"out-in-quad":qr(Hc),"in-cubic":Gc,"out-cubic":jr(Gc),"in-out-cubic":Wr(Gc),"out-in-cubic":qr(Gc),"in-quart":Kc,"out-quart":jr(Kc),"in-out-quart":Wr(Kc),"out-in-quart":qr(Kc),"in-quint":zc,"out-quint":jr(zc),"in-out-quint":Wr(zc),"out-in-quint":qr(zc),"in-expo":Vc,"out-expo":jr(Vc),"in-out-expo":Wr(Vc),"out-in-expo":qr(Vc),"in-sine":jc,"out-sine":jr(jc),"in-out-sine":Wr(jc),"out-in-sine":qr(jc),"in-circ":Wc,"out-circ":jr(Wc),"in-out-circ":Wr(Wc),"out-in-circ":qr(Wc),"in-back":qc,"out-back":jr(qc),"in-out-back":Wr(qc),"out-in-back":qr(qc),"in-bounce":$c,"out-bounce":jr($c),"in-out-bounce":Wr($c),"out-in-bounce":qr($c),"in-elastic":Yc,"out-elastic":jr(Yc),"in-out-elastic":Wr(Yc),"out-in-elastic":qr(Yc),spring:bA,"spring-in":bA,"spring-out":jr(bA),"spring-in-out":Wr(bA),"spring-out-in":qr(bA)},mz=function(e){return yz(e).replace(/^ease-/,"").replace(/(\(|\s).+/,"").toLowerCase().trim()},wz=function(e){return ux[mz(e)]||ux.linear},Bz=function(e){return e},bz=1,Ez=.5,hx=0;function dx(r,e){return function(t){if(t>=1)return 1;var n=1/r;return t+=e*n,t-t%n}}var Zc="\\s*(-?\\d+\\.?\\d*|-?\\.\\d+)\\s*",xz=new RegExp("cubic-bezier\\(".concat(Zc,",").concat(Zc,",").concat(Zc,",").concat(Zc,"\\)")),Cz=/steps\(\s*(\d+)\s*\)/,Sz=/steps\(\s*(\d+)\s*,\s*(start|middle|end)\s*\)/;function uB(r){var e=xz.exec(r);if(e)return cB.apply(void 0,tt(e.slice(1).map(Number)));var t=Cz.exec(r);if(t)return dx(Number(t[1]),hx);var n=Sz.exec(r);return n?dx(Number(n[1]),{start:bz,middle:Ez,end:hx}[n[2]]):wz(r)}function Fz(r){return Math.abs(Tz(r)/(r.playbackRate||1))}function Tz(r){var e;return r.duration===0||r.iterations===0?0:(r.duration==="auto"?0:Number(r.duration))*((e=r.iterations)!==null&&e!==void 0?e:1)}var Gk=0,hB=1,Zh=2,Kk=3;function Mz(r,e,t){if(e===null)return Gk;var n=t.endTime;return e<Math.min(t.delay,n)?hB:e>=Math.min(t.delay+r+t.endDelay,n)?Zh:Kk}function Oz(r,e,t,n,i){switch(n){case hB:return e==="backwards"||e==="both"?0:null;case Kk:return t-i;case Zh:return e==="forwards"||e==="both"?r:null;case Gk:return null}}function _z(r,e,t,n,i){var a=i;return r===0?e!==hB&&(a+=t):a+=n/r,a}function Iz(r,e,t,n,i,a){var s=r===1/0?e%1:r%1;return s===0&&t===Zh&&n!==0&&(i!==0||a===0)&&(s=1),s}function kz(r,e,t,n){return r===Zh&&e===1/0?1/0:t===1?Math.floor(n)-1:Math.floor(n)}function Lz(r,e,t){var n=r;if(r!=="normal"&&r!=="reverse"){var i=e;r==="alternate-reverse"&&(i+=1),n="normal",i!==1/0&&i%2!==0&&(n="reverse")}return n==="normal"?t:1-t}function Qz(r,e,t){var n=Mz(r,e,t),i=Oz(r,t.fill,e,n,t.delay);if(i===null)return null;var a=t.duration==="auto"?0:t.duration,s=_z(a,n,t.iterations,i,t.iterationStart),o=Iz(s,t.iterationStart,n,t.iterations,i,a),A=kz(n,t.iterations,o,s),l=Lz(t.direction,A,o);return t.currentIteration=A,t.progress=l,t.easingFunction(l)}function Nz(r,e,t){var n=Uz(r,e),i=Pz(n,t);return function(a,s){if(s!==null)i.filter(function(A){return s>=A.applyFrom&&s<A.applyTo}).forEach(function(A){var l=s-A.startOffset,c=A.endOffset-A.startOffset,u=c===0?0:l/c;a.setAttribute(A.property,A.interpolation(u),!1,!1)});else for(var o in n)zk(o)&&a.setAttribute(o,null)}}function zk(r){return r!=="offset"&&r!=="easing"&&r!=="composite"&&r!=="computedOffset"}function Uz(r,e){for(var t={},n=0;n<r.length;n++)for(var i in r[n])if(zk(i)){var a={offset:r[n].offset,computedOffset:r[n].computedOffset,easing:r[n].easing,easingFunction:uB(r[n].easing)||e.easingFunction,value:r[n][i]};t[i]=t[i]||[],t[i].push(a)}return t}function Pz(r,e){var t=[];for(var n in r)for(var i=r[n],a=0;a<i.length-1;a++){var s=a,o=a+1,A=i[s].computedOffset,l=i[o].computedOffset,c=A,u=l;a===0&&(c=-1/0,l===0&&(o=s)),a===i.length-2&&(u=1/0,A===1&&(s=o)),t.push({applyFrom:c,applyTo:u,startOffset:i[s].computedOffset,endOffset:i[o].computedOffset,easingFunction:i[s].easingFunction,property:n,interpolation:Rz(n,i[s].value,i[o].value,e)})}return t.sort(function(h,d){return h.startOffset-d.startOffset}),t}var fx=function(e,t,n){return function(i){var a=Vk(e,t,i);return Be(a)?a:n(a)}};function Rz(r,e,t,n){var i=BI[r];if(i&&i.syntax&&i.int){var a=de.styleValueRegistry.getPropertySyntax(i.syntax);if(a){var s=a.parser,o=s?s(e,n):e,A=s?s(t,n):t,l=a.mixer(o,A,n);if(l){var c=fx.apply(void 0,tt(l));return function(u){return u===0?e:u===1?t:c(u)}}}}return fx(!1,!0,function(u){return u?t:e})}function Vk(r,e,t){if(typeof r=="number"&&typeof e=="number")return r*(1-t)+e*t;if(typeof r=="boolean"&&typeof e=="boolean"||typeof r=="string"&&typeof e=="string")return t<.5?r:e;if(Array.isArray(r)&&Array.isArray(e)){for(var n=r.length,i=e.length,a=Math.max(n,i),s=[],o=0;o<a;o++)s.push(Vk(r[o<n?o:n-1],e[o<i?o:i-1],t));return s}throw new Error("Mismatched interpolation arguments ".concat(r,":").concat(e))}var Dz=(function(){function r(){ue(this,r),this.delay=0,this.direction="normal",this.duration="auto",this._easing="linear",this.easingFunction=Bz,this.endDelay=0,this.fill="auto",this.iterationStart=0,this.iterations=1,this.currentIteration=null,this.progress=null}return he(r,[{key:"easing",get:function(){return this._easing},set:function(t){this.easingFunction=uB(t),this._easing=t}}])})();function Hz(r){var e=[];for(var t in r)if(!(t in["easing","offset","composite"])){var n=r[t];Array.isArray(n)||(n=[n]);for(var i=n.length,a=0;a<i;a++){if(!e[a]){var s={};"offset"in r&&(s.offset=Number(r.offset)),"easing"in r&&(s.easing=r.easing),"composite"in r&&(s.composite=r.composite),e[a]=s}n[a]!==void 0&&n[a]!==null&&(e[a][t]=n[a])}}return e.sort(function(o,A){return(o.computedOffset||0)-(A.computedOffset||0)}),e}function gx(r,e){if(r===null)return[];Array.isArray(r)||(r=Hz(r));for(var t=r.map(function(A){var l={};e!=null&&e.composite&&(l.composite="auto");for(var c in A){var u=A[c];if(c==="offset"){if(u!==null){if(u=Number(u),!isFinite(u))throw new Error("Keyframe offsets must be numbers.");if(u<0||u>1)throw new Error("Keyframe offsets must be between 0 and 1.");l.computedOffset=u}}else if(c==="composite"&&["replace","add","accumulate","auto"].indexOf(u)===-1)throw new Error("".concat(u," compositing is not supported"));l[c]=u}return l.offset===void 0&&(l.offset=null),l.easing===void 0&&(l.easing=(e==null?void 0:e.easing)||"linear"),l.composite===void 0&&(l.composite="auto"),l}),n=!0,i=-1/0,a=0;a<t.length;a++){var s=t[a].offset;if(ke(s))n=!1;else{if(s<i)throw new TypeError("Keyframes are not loosely sorted by offset. Sort or specify offsets.");i=s}}t=t.filter(function(A){return Number(A.offset)>=0&&Number(A.offset)<=1});function o(){var A,l=t,c=l.length;if(t[c-1].computedOffset=Number((A=t[c-1].offset)!==null&&A!==void 0?A:1),c>1){var u;t[0].computedOffset=Number((u=t[0].offset)!==null&&u!==void 0?u:0)}for(var h=0,d=Number(t[0].computedOffset),f=1;f<c;f++){var g=t[f].computedOffset;if(!ke(g)&&!ke(d)){for(var v=1;v<f-h;v++)t[h+v].computedOffset=d+(Number(g)-d)*v/(f-h);h=f,d=Number(g)}}}return n||o(),t}var Gz="backwards|forwards|both|none".split("|"),Kz="reverse|alternate|alternate-reverse".split("|");function zz(r,e){var t=new Dz;return typeof r=="number"&&!isNaN(r)?t.duration=r:r!==void 0&&Object.keys(r).forEach(function(n){if(r[n]!==void 0&&r[n]!==null&&r[n]!=="auto"){if((typeof t[n]=="number"||n==="duration")&&(typeof r[n]!="number"||isNaN(r[n]))||n==="fill"&&Gz.indexOf(r[n])===-1||n==="direction"&&Kz.indexOf(r[n])===-1)return;t[n]=r[n]}}),t}function Vz(r,e){return r=jz(r??{duration:"auto"}),zz(r)}function jz(r){return typeof r=="number"&&(isNaN(r)?r={duration:"auto"}:r={duration:r}),r}var Wz=(function(){function r(e,t,n){var i=this;ue(this,r),this.composite="replace",this.iterationComposite="replace",this.target=e,this.timing=Vz(n),this.timing.effect=this,this.timing.activeDuration=Fz(this.timing),this.timing.endTime=Math.max(0,this.timing.delay+this.timing.activeDuration+this.timing.endDelay),this.normalizedKeyframes=gx(t,this.timing),this.interpolations=Nz(this.normalizedKeyframes,this.timing,this.target);var a=de.globalThis.Proxy;this.computedTiming=a?new a(this.timing,{get:function(o,A){return A==="duration"?o.duration==="auto"?0:o.duration:A==="fill"?o.fill==="auto"?"none":o.fill:A==="localTime"?i.animation&&i.animation.currentTime||null:A==="currentIteration"?!i.animation||i.animation.playState!=="running"?null:o.currentIteration||0:A==="progress"?!i.animation||i.animation.playState!=="running"?null:o.progress||0:o[A]},set:function(){return!0}}):this.timing}return he(r,[{key:"applyInterpolations",value:function(){this.interpolations(this.target,Number(this.timeFraction))}},{key:"update",value:function(t){return t===null?!1:(this.timeFraction=Qz(this.timing.activeDuration,t,this.timing),this.timeFraction!==null)}},{key:"getKeyframes",value:function(){return this.normalizedKeyframes}},{key:"setKeyframes",value:function(t){this.normalizedKeyframes=gx(t)}},{key:"getComputedTiming",value:function(){return this.computedTiming}},{key:"getTiming",value:function(){return this.timing}},{key:"updateTiming",value:function(t){var n=this;Object.keys(t||{}).forEach(function(i){n.timing[i]=t[i]})}}])})();function vx(r,e){return Number(r.id)-Number(e.id)}var qz=(function(){function r(e){var t=this;ue(this,r),this.animations=[],this.ticking=!1,this.timelineTicking=!1,this.hasRestartedThisFrame=!1,this.animationsWithPromises=[],this.inTick=!1,this.pendingEffects=[],this.currentTime=null,this.rafId=0,this.rafCallbacks=[],this.webAnimationsNextTick=function(n){t.currentTime=n,t.discardAnimations(),t.animations.length===0?t.timelineTicking=!1:t.requestAnimationFrame(t.webAnimationsNextTick)},this.processRafCallbacks=function(n){var i=t.rafCallbacks;t.rafCallbacks=[],n<Number(t.currentTime)&&(n=Number(t.currentTime)),t.animations.sort(vx),t.animations=t.tick(n,!0,t.animations)[0],i.forEach(function(a){a[1](n)}),t.applyPendingEffects()},this.document=e}return he(r,[{key:"getAnimations",value:function(){return this.discardAnimations(),this.animations.slice()}},{key:"isTicking",value:function(){return this.inTick}},{key:"play",value:function(t,n,i){var a=new Wz(t,n,i),s=new cz(a,this);return this.animations.push(s),this.restartWebAnimationsNextTick(),s.updatePromises(),s.play(),s.updatePromises(),s}},{key:"applyDirtiedAnimation",value:function(t){var n=this;if(!this.inTick){t.markTarget();var i=t.targetAnimations();i.sort(vx);var a=this.tick(Number(this.currentTime),!1,i.slice())[1];a.forEach(function(s){var o=n.animations.indexOf(s);o!==-1&&n.animations.splice(o,1)}),this.applyPendingEffects()}}},{key:"restart",value:function(){return this.ticking||(this.ticking=!0,this.requestAnimationFrame(function(){}),this.hasRestartedThisFrame=!0),this.hasRestartedThisFrame}},{key:"destroy",value:function(){this.document.defaultView.cancelAnimationFrame(this.frameId)}},{key:"applyPendingEffects",value:function(){this.pendingEffects.forEach(function(t){t==null||t.applyInterpolations()}),this.pendingEffects=[]}},{key:"updateAnimationsPromises",value:function(){this.animationsWithPromises=this.animationsWithPromises.filter(function(t){return t.updatePromises()})}},{key:"discardAnimations",value:function(){this.updateAnimationsPromises(),this.animations=this.animations.filter(function(t){return t.playState!=="finished"&&t.playState!=="idle"})}},{key:"restartWebAnimationsNextTick",value:function(){this.timelineTicking||(this.timelineTicking=!0,this.requestAnimationFrame(this.webAnimationsNextTick))}},{key:"rAF",value:function(t){var n=this.rafId++;return this.rafCallbacks.length===0&&(this.frameId=this.document.defaultView.requestAnimationFrame(this.processRafCallbacks)),this.rafCallbacks.push([n,t]),n}},{key:"requestAnimationFrame",value:function(t){var n=this;return this.rAF(function(i){n.updateAnimationsPromises(),t(i),n.updateAnimationsPromises()})}},{key:"tick",value:function(t,n,i){var a=this,s,o;this.inTick=!0,this.hasRestartedThisFrame=!1,this.currentTime=t,this.ticking=!1;var A=[],l=[],c=[],u=[];return i.forEach(function(h){h.tick(t,n),h._inEffect?(l.push(h.effect),h.markTarget()):(A.push(h.effect),h.unmarkTarget()),h._needsTick&&(a.ticking=!0);var d=h._inEffect||h._needsTick;h._inTimeline=d,d?c.push(h):u.push(h)}),(s=this.pendingEffects).push.apply(s,A),(o=this.pendingEffects).push.apply(o,l),this.ticking&&this.requestAnimationFrame(function(){}),this.inTick=!1,[c,u]}}])})();de.EasingFunction=uB;de.AnimationTimeline=qz;var $z=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.landmarks=[],t}return $e(e,r),he(e,[{key:"rotate",value:function(n,i,a){if(this.relElevation=Qo(i),this.relAzimuth=Qo(n),this.relRoll=Qo(a),this.elevation+=this.relElevation,this.azimuth+=this.relAzimuth,this.roll+=this.relRoll,this.type===mt.EXPLORING){var s=La(gn(),[1,0,0],ft((this.rotateWorld?1:-1)*this.relElevation)),o=La(gn(),[0,1,0],ft((this.rotateWorld?1:-1)*this.relAzimuth)),A=La(gn(),[0,0,1],ft(this.relRoll)),l=ja(gn(),o,s);l=ja(gn(),l,A);var c=K1(xt(),l);ko(this.matrix,this.matrix,[0,0,-this.distance]),tr(this.matrix,this.matrix,c),ko(this.matrix,this.matrix,[0,0,this.distance])}else{if(Math.abs(this.elevation)>90)return this;this.computeMatrix()}return this._getAxes(),this.type===mt.ORBITING||this.type===mt.EXPLORING?this._getPosition():this.type===mt.TRACKING&&this._getFocalPoint(),this._update(),this}},{key:"pan",value:function(n,i){var a=Ar(n,i,0),s=aa(this.position);return Va(s,s,zu(Ze(),this.right,a[0])),Va(s,s,zu(Ze(),this.up,a[1])),this._setPosition(s),this.triggerUpdate(),this}},{key:"dolly",value:function(n){var i=this.forward,a=aa(this.position),s=n*this.dollyingStep,o=this.distance+n*this.dollyingStep;return s=Math.max(Math.min(o,this.maxDistance),this.minDistance)-this.distance,a[0]+=s*i[0],a[1]+=s*i[1],a[2]+=s*i[2],this._setPosition(a),this.type===mt.ORBITING||this.type===mt.EXPLORING?this._getDistance():this.type===mt.TRACKING&&Va(this.focalPoint,a,this.distanceVector),this.triggerUpdate(),this}},{key:"cancelLandmarkAnimation",value:function(){this.landmarkAnimationID!==void 0&&this.canvas.cancelAnimationFrame(this.landmarkAnimationID)}},{key:"createLandmark",value:function(n){var i,a,s,o,A=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},l=A.position,c=l===void 0?this.position:l,u=A.focalPoint,h=u===void 0?this.focalPoint:u,d=A.roll,f=A.zoom,g=new de.CameraContribution;g.setType(this.type,void 0),g.setPosition(c[0],(i=c[1])!==null&&i!==void 0?i:this.position[1],(a=c[2])!==null&&a!==void 0?a:this.position[2]),g.setFocalPoint(h[0],(s=h[1])!==null&&s!==void 0?s:this.focalPoint[1],(o=h[2])!==null&&o!==void 0?o:this.focalPoint[2]),g.setRoll(d??this.roll),g.setZoom(f??this.zoom);var v={name:n,matrix:m_(g.getWorldTransform()),right:aa(g.right),up:aa(g.up),forward:aa(g.forward),position:aa(g.getPosition()),focalPoint:aa(g.getFocalPoint()),distanceVector:aa(g.getDistanceVector()),distance:g.getDistance(),dollyingStep:g.getDollyingStep(),azimuth:g.getAzimuth(),elevation:g.getElevation(),roll:g.getRoll(),relAzimuth:g.relAzimuth,relElevation:g.relElevation,relRoll:g.relRoll,zoom:g.getZoom()};return this.landmarks.push(v),v}},{key:"gotoLandmark",value:function(n){var i=this,a=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},s=At(n)?this.landmarks.find(function(k){return k.name===n}):n;if(s){var o=Be(a)?{duration:a}:a,A=o.easing,l=A===void 0?"linear":A,c=o.duration,u=c===void 0?100:c,h=o.easingFunction,d=h===void 0?void 0:h,f=o.onfinish,g=f===void 0?void 0:f,v=o.onframe,p=v===void 0?void 0:v,y=.01;this.cancelLandmarkAnimation();var m=s.position,B=s.focalPoint,C=s.zoom,S=s.roll,F=d||de.EasingFunction(l),T,O=function(){i.setFocalPoint(B),i.setPosition(m),i.setRoll(S),i.setZoom(C),i.computeMatrix(),i.triggerUpdate(),g==null||g()};if(u===0)return O();var _=function(L){T===void 0&&(T=L);var U=L-T;if(U>=u){O();return}var G=F(U/u),W=Ze(),V=Ze(),K=1,D=0;pw(W,i.focalPoint,B,G),pw(V,i.position,m,G),D=i.roll*(1-G)+S*G,K=i.zoom*(1-G)+C*G,i.setFocalPoint(W),i.setPosition(V),i.setRoll(D),i.setZoom(K);var X=bb(W,B)+bb(V,m);if(X<=y&&C===void 0&&S===void 0)return O();i.computeMatrix(),i.triggerUpdate(),U<u&&(p==null||p(G),i.landmarkAnimationID=i.canvas.requestAnimationFrame(_))};this.canvas.requestAnimationFrame(_)}}}])})(iI);de.CameraContribution=$z;var Yz=["body","startHead","endHead","startHeadOffset","endHeadOffset"],Xz=["body","startHead","endHead","startHeadOffset","endHeadOffset"],Zz=["body","startHead","endHead","startHeadOffset","endHeadOffset"],jk=(function(r){function e(t){var n;ue(this,e),n=qe(this,e,[De(De({},t),{},{type:e.tag})]);var i=n.attributes,a=i.body,s=i.startHead,o=i.endHead;i.startHeadOffset,i.endHeadOffset;var A=Di(i,Yz);if(!a)throw new Error("Arrow's body is required");return n.body=a,n.appendChild(n.body),n.handleBodyAttributeChanged(n.body),s&&n.appendArrowHead(n.getArrowHeadType(s),!0),o&&n.appendArrowHead(n.getArrowHeadType(o),!1),n.applyArrowStyle(A,[n.body,n.startHead,n.endHead]),n}return $e(e,r),he(e,[{key:"handleBodyAttributeChanged",value:function(n){var i=this;n.addEventListener(it.ATTR_MODIFIED,function(a){var s=a.attrName;s==="x1"||s==="y1"?i.startHead&&i.transformArrowHead(i.startHead,!0):(s==="x2"||s==="y2")&&i.endHead&&i.transformArrowHead(i.endHead,!1)})}},{key:"getBody",value:function(){return this.body}},{key:"getStartHead",value:function(){return this.startHead}},{key:"getEndHead",value:function(){return this.endHead}},{key:"attributeChangedCallback",value:function(n,i,a){if(n==="opacity"||n==="strokeOpacity"||n==="stroke"||n==="lineWidth"||n==="increasedLineWidthForHitTesting")this.applyArrowStyle(Ee({},n,a),[this.body,this.startHead,this.endHead]);else if(n==="startHead"||n==="endHead"){var s=n==="startHead";if(this.destroyArrowHead(s),a){var o=this.attributes;o.body,o.startHead,o.endHead,o.startHeadOffset,o.endHeadOffset;var A=Di(o,Xz);this.appendArrowHead(this.getArrowHeadType(a),s),this.applyArrowStyle(A,[s?this.startHead:this.endHead])}}else if(n==="body"){var l=this.attributes;l.body,l.startHead,l.endHead,l.startHeadOffset,l.endHeadOffset;var c=Di(l,Zz);this.body.destroy(),this.body=a,this.appendChild(this.body),this.applyArrowStyle(c,[this.body])}else n==="startHeadOffset"?this.moveArrowHeadAlongTangent(a,!0):n==="endHeadOffset"&&this.moveArrowHeadAlongTangent(a,!1)}},{key:"getArrowHeadType",value:function(n){return typeof n=="boolean"?"default":"custom"}},{key:"appendArrowHead",value:function(n,i){var a;n==="default"?a=this.createDefaultArrowHead():a=i?this.attributes.startHead:this.attributes.endHead,this.transformArrowHead(a,i),a.setAttribute("zIndex",1),i?this.startHead=a:this.endHead=a,this.appendChild(a);var s=i?this.attributes.startHeadOffset:this.attributes.endHeadOffset;s&&this.moveArrowHeadAlongTangent(s,i)}},{key:"transformArrowHead",value:function(n,i){var a=Ze(),s=0,o=0,A=0,l=0,c=0,u=this.body&&this.body.nodeName;if(u===ae.LINE){var h=this.body.attributes,d=h.x1,f=h.x2,g=h.y1,v=h.y2;o=i?f:d,A=i?d:f,l=i?v:g,c=i?g:v}else if(u===ae.POLYLINE){var p=this.body.attributes.points,y=p.length;o=i?p[1][0]:p[y-2][0],l=i?p[1][1]:p[y-2][1],A=i?p[0][0]:p[y-1][0],c=i?p[0][1]:p[y-1][1]}else if(u===ae.PATH){var m=this.getTangent(this.body,i),B=We(m,2),C=B[0],S=B[1];o=C[0],l=C[1],A=S[0],c=S[1]}var F=o-A,T=l-c;s=Math.atan2(T,F),a=Ct(A,c,0),i?(this.startHeadPosition=a,this.startHeadRad=s):(this.endHeadPosition=a,this.endHeadRad=s),n.setLocalPosition(a),n.setLocalEulerAngles(s*180/Math.PI+n.getLocalEulerAngles())}},{key:"moveArrowHeadAlongTangent",value:function(n,i){var a=i?this.startHead:this.endHead;a&&a.setLocalPosition(U_(Ze(),i?this.startHeadPosition:this.endHeadPosition,Ct(Math.cos(i?this.startHeadRad:this.endHeadRad)*n,Math.sin(i?this.startHeadRad:this.endHeadRad)*n,0))),this.body}},{key:"destroyArrowHead",value:function(n){n&&this.startHead&&(this.startHead.destroy(),this.startHead=void 0),!n&&this.endHead&&(this.endHead.destroy(),this.endHead=void 0)}},{key:"getTangent",value:function(n,i){return i?n.getStartTangent():n.getEndTangent()}},{key:"createDefaultArrowHead",value:function(){var n=this.attributes,i=n.stroke,a=n.lineWidth,s=Math.sin,o=Math.cos,A=Math.PI,l=10*o(A/6);return new rr({style:{d:"M".concat(l/2,",").concat(10*s(A/6)," L-").concat(l/2,",0 L").concat(l/2,",-").concat(10*s(A/6)),stroke:i,lineWidth:a,transformOrigin:"center"}})}},{key:"applyArrowStyle",value:function(n,i){var a=n.opacity,s=n.stroke,o=n.strokeOpacity,A=n.lineWidth,l=n.increasedLineWidthForHitTesting;i.forEach(function(c){c&&(ke(a)||(c.style.opacity=a),ke(s)||(c.style.stroke=s),ke(o)||(c.style.strokeOpacity=o),ke(A)||(c.style.lineWidth=A),ke(l)||(c.style.increasedLineWidthForHitTesting=l))})}}])})(Ol);jk.tag="arrow";jk.PARSED_STYLE_LIST=new Set([].concat(tt(Ol.PARSED_STYLE_LIST),["body","startHead","endHead","startHeadOffset","endHeadOffset","stroke","lineWidth","opacity","strokeOpacity"]));var dB=Math.PI,Jz=dB*2,EA=Math.sin,Jc=Math.cos,eV=Math.acos,Yn=Math.atan2,el=Math.sqrt,i1=Math.max,_i=Math.min,So=1e-4,tV=[{name:"sr",inherits:!1,interpolable:!0,syntax:pe.LENGTH_PERCENTAGE},{name:"sr0",inherits:!1,interpolable:!0,syntax:pe.LENGTH_PERCENTAGE},{name:"startAngle",inherits:!1,interpolable:!0,syntax:pe.ANGLE},{name:"endAngle",inherits:!1,interpolable:!0,syntax:pe.ANGLE}];tV.forEach(function(r){$H.registerProperty(r)});var ci=function(e,t,n,i){return{x:e+n*Math.cos(i),y:t+n*Math.sin(i)}};function nV(r,e,t,n,i,a,s,o){var A=t-r,l=n-e,c=s-i,u=o-a,h=u*A-c*l;if(!(h*h<So))return h=(c*(e-a)-u*(r-i))/h,[r+h*A,e+h*l]}function eu(r,e,t,n,i,a,s){var o=r-t,A=e-n,l=a/el(o*o+A*A),c=l*A,u=-l*o,h=r+c,d=e+u,f=t+c,g=n+u,v=(h+f)/2,p=(d+g)/2,y=f-h,m=g-d,B=y*y+m*m,C=i-a,S=h*g-f*d,F=(m<0?-1:1)*el(i1(0,C*C*B-S*S)),T=(S*m-y*F)/B,O=(-S*y-m*F)/B,_=(S*m+y*F)/B,k=(-S*y+m*F)/B,L=T-v,U=O-p,G=_-v,W=k-p;return L*L+U*U>G*G+W*W&&(T=_,O=k),{cx:T,cy:O,x0:-c,y0:-u,x1:T*(i/C-1),y1:O*(i/C-1)}}function ia(r,e){return e=e<0&&r>=0?e+Jz:e,e-r<=dB?0:1}var rV=(function(r){function e(t){var n;return ue(this,e),n=qe(this,e,[t]),n.updatePath(),n}return $e(e,r),he(e,[{key:"setAttribute",value:function(n,i,a){Yu(e,"setAttribute",this)([n,i,a]),["startAngle","endAngle","sr","sr0","radius"].indexOf(n)>-1&&this.updatePath()}},{key:"updatePath",value:function(){var n=this.parsedStyle,i=n.x,a=n.y,s=n.startAngle,o=n.endAngle,A=n.sr,l=n.sr0,c=n.radius,u=this.createPath(i,a,s?ft(s):0,o?ft(o):Math.PI*2,A||0,l||0,c||[0,0,0,0]);Yu(e,"setAttribute",this)(["d",u])}},{key:"createPath",value:function(n,i,a,s,o,A,l){if(!(o<=0)){var c=ci(n,i,o,a),u=ci(n,i,o,s),h=ci(n,i,A,a),d=ci(n,i,A,s);if(Lo(s-a,Math.PI*2)){var f=ci(n,i,o,a+Math.PI),g=ci(n,i,A,a+Math.PI),v=[["M",c.x,c.y],["A",o,o,0,1,1,f.x,f.y],["A",o,o,0,1,1,u.x,u.y],["M",h.x,h.y]];return A&&(v.push(["A",A,A,0,1,0,g.x,g.y]),v.push(["A",A,A,0,1,0,d.x,d.y])),v.push(["M",c.x,c.y]),v.push(["Z"]),v}var p=s-a,y=o*Jc(a),m=o*EA(a),B=A*Jc(s),C=A*EA(s),S=o*Jc(s),F=o*EA(s),T=A*Jc(a),O=A*EA(a),_=We(l,4),k=_[0],L=_[1],U=_[2],G=_[3],W=(o-A)/2,V=_i(W,k),K=_i(W,L),D=_i(W,U),X=_i(W,G),te=i1(V,K),ie=i1(D,X),re=te,xe=ie;if((te>So||ie>So)&&p<dB){var $=nV(y,m,T,O,S,F,B,C);if($){var z=y-$[0],ee=m-$[1],Ae=S-$[0],be=F-$[1],Le=1/EA(eV((z*Ae+ee*be)/(el(z*z+ee*ee)*el(Ae*Ae+be*be)))/2),Ue=el($[0]*$[0]+$[1]*$[1]);re=_i(te,(o-Ue)/(Le+1)),xe=_i(ie,(A-Ue)/(Le-1))}}var at=ia(a,s),lt=[];if(re>So){var ct=_i(k,re),pt=_i(L,re),Ne=eu(T,O,y,m,o,ct),ht=eu(S,F,B,C,o,pt);if(lt.push(["M",n+Ne.cx+Ne.x0,i+Ne.cy+Ne.y0]),re<te&&ct===pt){var nt=Yn(Ne.y0,Ne.x0),gr=Yn(ht.y0,ht.x0);lt.push(["A",re,re,0,ia(nt,gr),1,n+ht.cx+ht.x0,i+ht.cy+ht.y0])}else{if(ct>0){var St=Yn(Ne.y0,Ne.x0),Ji=Yn(Ne.y1,Ne.x1),ir=ci(n,i,o,Ji);lt.push(["A",ct,ct,0,ia(St,Ji),1,ir.x,ir.y])}var Wt=Yn(Ne.cy+Ne.y1,Ne.cx+Ne.x1),_t=Yn(ht.cy+ht.y1,ht.cx+ht.x1),Qn=ci(n,i,o,_t);if(lt.push(["A",o,o,0,ia(Wt,_t),1,Qn.x,Qn.y]),pt>0){var qn=Yn(ht.y1,ht.x1),vr=Yn(ht.y0,ht.x0);lt.push(["A",pt,pt,0,ia(qn,vr),1,n+ht.cx+ht.x0,i+ht.cy+ht.y0])}}}else lt.push(["M",c.x,c.y]),lt.push(["A",o,o,0,at,1,u.x,u.y]);if(A<So)lt.push(["L",d.x,d.y]);else if(xe>So){var ar=_i(G,xe),$n=_i(U,xe),rn=eu(B,C,0,0,A-o,$n),an=eu(0,0,T,O,A-o,ar);if(lt.push(["L",n+rn.cx+rn.x0,i+rn.cy+rn.y0]),xe<ie&&ar===$n){var cA=Yn(rn.y0,rn.x0),cs=Yn(an.y0,an.x0),Or=ci(n,i,A,cs);lt.push(["A",re,re,0,ia(cA,cs),1,Or.x,Or.y])}else{if($n>0){var Vr=Yn(rn.y0,rn.x0),Xl=Yn(rn.y1,rn.x1),Zl=ci(n,i,A-o,Xl);lt.push(["A",$n,$n,0,ia(Vr,Xl),1,Zl.x,Zl.y])}var Cf=Yn(rn.cy+rn.y1,rn.cx+rn.x1),Jl=Yn(an.cy+an.y1,an.cx+an.x1),ea=ci(n,i,A,Jl);if(lt.push(["A",A,A,0,ia(Jl,Cf),0,ea.x,ea.y]),lt.push(["L",ea.x,ea.y]),ar>0){var ec=Yn(an.y1,an.x1),tc=Yn(an.y0,an.x0);lt.push(["A",ar,ar,0,ia(ec,tc),1,n+an.cx+an.x0,i+an.cy+an.y0])}}}else lt.push(["L",d.x,d.y]),lt.push(["A",A,A,0,at,0,h.x,h.y]);return lt.push(["Z"]),lt}}}])})(rr);rV.PARSED_STYLE_LIST=new Set([].concat(tt(rr.PARSED_STYLE_LIST),["x","y","sr","sr0","radius","startAngle","endAngle"]));const iV={duration:500},aV={duration:1e3,easing:"cubic-bezier(0.250, 0.460, 0.450, 0.940)",iterations:1,fill:"both"};var Ut;(function(r){r.NodeAdded="NodeAdded",r.NodeUpdated="NodeUpdated",r.NodeRemoved="NodeRemoved",r.EdgeAdded="EdgeAdded",r.EdgeUpdated="EdgeUpdated",r.EdgeRemoved="EdgeRemoved",r.ComboAdded="ComboAdded",r.ComboUpdated="ComboUpdated",r.ComboRemoved="ComboRemoved"})(Ut||(Ut={}));var mr;(function(r){r.DRAW="draw",r.COLLAPSE="collapse",r.EXPAND="expand",r.TRANSFORM="transform"})(mr||(mr={}));var ga;(function(r){r.CLICK="canvas:click",r.DBLCLICK="canvas:dblclick",r.POINTER_OVER="canvas:pointerover",r.POINTER_LEAVE="canvas:pointerleave",r.POINTER_ENTER="canvas:pointerenter",r.POINTER_MOVE="canvas:pointermove",r.POINTER_OUT="canvas:pointerout",r.POINTER_DOWN="canvas:pointerdown",r.POINTER_UP="canvas:pointerup",r.CONTEXT_MENU="canvas:contextmenu",r.DRAG_START="canvas:dragstart",r.DRAG="canvas:drag",r.DRAG_END="canvas:dragend",r.DRAG_ENTER="canvas:dragenter",r.DRAG_OVER="canvas:dragover",r.DRAG_LEAVE="canvas:dragleave",r.DROP="canvas:drop",r.WHEEL="canvas:wheel"})(ga||(ga={}));var Ts;(function(r){r.CLICK="combo:click",r.DBLCLICK="combo:dblclick",r.POINTER_OVER="combo:pointerover",r.POINTER_LEAVE="combo:pointerleave",r.POINTER_ENTER="combo:pointerenter",r.POINTER_MOVE="combo:pointermove",r.POINTER_OUT="combo:pointerout",r.POINTER_DOWN="combo:pointerdown",r.POINTER_UP="combo:pointerup",r.CONTEXT_MENU="combo:contextmenu",r.DRAG_START="combo:dragstart",r.DRAG="combo:drag",r.DRAG_END="combo:dragend",r.DRAG_ENTER="combo:dragenter",r.DRAG_OVER="combo:dragover",r.DRAG_LEAVE="combo:dragleave",r.DROP="combo:drop"})(Ts||(Ts={}));var se;(function(r){r.CLICK="click",r.DBLCLICK="dblclick",r.POINTER_OVER="pointerover",r.POINTER_LEAVE="pointerleave",r.POINTER_ENTER="pointerenter",r.POINTER_MOVE="pointermove",r.POINTER_OUT="pointerout",r.POINTER_DOWN="pointerdown",r.POINTER_UP="pointerup",r.CONTEXT_MENU="contextmenu",r.DRAG_START="dragstart",r.DRAG="drag",r.DRAG_END="dragend",r.DRAG_ENTER="dragenter",r.DRAG_OVER="dragover",r.DRAG_LEAVE="dragleave",r.DROP="drop",r.KEY_DOWN="keydown",r.KEY_UP="keyup",r.WHEEL="wheel",r.PINCH="pinch"})(se||(se={}));var Oo;(function(r){r.KEY_DOWN="keydown",r.KEY_UP="keyup"})(Oo||(Oo={}));var fh;(function(r){r.CLICK="edge:click",r.DBLCLICK="edge:dblclick",r.POINTER_OVER="edge:pointerover",r.POINTER_LEAVE="edge:pointerleave",r.POINTER_ENTER="edge:pointerenter",r.POINTER_MOVE="edge:pointermove",r.POINTER_OUT="edge:pointerout",r.POINTER_DOWN="edge:pointerdown",r.POINTER_UP="edge:pointerup",r.CONTEXT_MENU="edge:contextmenu",r.DRAG_ENTER="edge:dragenter",r.DRAG_OVER="edge:dragover",r.DRAG_LEAVE="edge:dragleave",r.DROP="edge:drop"})(fh||(fh={}));var ge;(function(r){r.BEFORE_CANVAS_INIT="beforecanvasinit",r.AFTER_CANVAS_INIT="aftercanvasinit",r.BEFORE_SIZE_CHANGE="beforesizechange",r.AFTER_SIZE_CHANGE="aftersizechange",r.BEFORE_ELEMENT_CREATE="beforeelementcreate",r.AFTER_ELEMENT_CREATE="afterelementcreate",r.BEFORE_ELEMENT_UPDATE="beforeelementupdate",r.AFTER_ELEMENT_UPDATE="afterelementupdate",r.BEFORE_ELEMENT_DESTROY="beforeelementdestroy",r.AFTER_ELEMENT_DESTROY="afterelementdestroy",r.BEFORE_ELEMENT_TRANSLATE="beforeelementtranslate",r.AFTER_ELEMENT_TRANSLATE="afterelementtranslate",r.BEFORE_DRAW="beforedraw",r.AFTER_DRAW="afterdraw",r.BEFORE_RENDER="beforerender",r.AFTER_RENDER="afterrender",r.BEFORE_ANIMATE="beforeanimate",r.AFTER_ANIMATE="afteranimate",r.BEFORE_LAYOUT="beforelayout",r.AFTER_LAYOUT="afterlayout",r.BEFORE_STAGE_LAYOUT="beforestagelayout",r.AFTER_STAGE_LAYOUT="afterstagelayout",r.BEFORE_TRANSFORM="beforetransform",r.AFTER_TRANSFORM="aftertransform",r.BATCH_START="batchstart",r.BATCH_END="batchend",r.BEFORE_DESTROY="beforedestroy",r.AFTER_DESTROY="afterdestroy",r.BEFORE_RENDERER_CHANGE="beforerendererchange",r.AFTER_RENDERER_CHANGE="afterrendererchange"})(ge||(ge={}));var _a;(function(r){r.UNDO="undo",r.REDO="redo",r.CANCEL="cancel",r.ADD="add",r.CLEAR="clear",r.CHANGE="change"})(_a||(_a={}));var ti;(function(r){r.CLICK="node:click",r.DBLCLICK="node:dblclick",r.POINTER_OVER="node:pointerover",r.POINTER_LEAVE="node:pointerleave",r.POINTER_ENTER="node:pointerenter",r.POINTER_MOVE="node:pointermove",r.POINTER_OUT="node:pointerout",r.POINTER_DOWN="node:pointerdown",r.POINTER_UP="node:pointerup",r.CONTEXT_MENU="node:contextmenu",r.DRAG_START="node:dragstart",r.DRAG="node:drag",r.DRAG_END="node:dragend",r.DRAG_ENTER="node:dragenter",r.DRAG_OVER="node:dragover",r.DRAG_LEAVE="node:dragleave",r.DROP="node:drop"})(ti||(ti={}));const Et="combo",Rr="tree";var Wo;(function(r){r.NODE="node",r.EDGE="edge",r.COMBO="combo",r.THEME="theme",r.PALETTE="palette",r.LAYOUT="layout",r.BEHAVIOR="behavior",r.PLUGIN="plugin",r.ANIMATION="animation",r.TRANSFORM="transform",r.SHAPE="shape"})(Wo||(Wo={}));const a1={animation:{},behavior:{},combo:{},edge:{},layout:{},node:{},palette:{},theme:{},plugin:{},transform:{},shape:{}};function va(r,e){var t;const n=(t=a1[r])===null||t===void 0?void 0:t[e];if(n)return n}const sV="5.0.51",oV="G6";function ha(r){return`[${oV} v${sV}] ${r}`}const $i={mute:!1,debug:r=>{console.debug(ha(r))},info:r=>{console.info(ha(r))},warn:r=>{console.warn(ha(r))},error:r=>{console.error(ha(r))}};function Wk(r){const{theme:e}=r;if(!e)return{};const t=va(Wo.THEME,e);return t||($i.warn(`The theme of ${e} is not registered.`),{})}function fB(r,e){if(Array.isArray(r)&&r.length===0)return null;const t=Array.isArray(r)?r[0]:r,n=Array.isArray(r)?r.slice(1):e||[];return new Proxy(t,{get(i,a){return typeof i[a]=="function"&&!["onframe","onfinish"].includes(a)?(...s)=>{i[a](...s),n.forEach(o=>{var A;return(A=o[a])===null||A===void 0?void 0:A.call(o,...s)})}:a==="finished"?Promise.all([t.finished,...n.map(s=>s.finished)]):Reflect.get(i,a)},set(i,a,s){return["onframe","onfinish"].includes(a)||n.forEach(o=>{o[a]=s}),Reflect.set(i,a,s)}})}function s1(r){const e=r.reduce((n,i)=>(Object.entries(i).forEach(([a,s])=>{n[a]===void 0?n[a]=[s]:n[a].push(s)}),n),{});Object.entries(e).forEach(([n,i])=>{(i.length!==r.length||i.some(a=>ke(a))||i.every(a=>!["sourceNode","targetNode","childrenNode"].includes(n)&&Xt(a,i[0])))&&delete e[n]});const t=Object.entries(e).reduce((n,[i,a])=>(a.forEach((s,o)=>{n[o]?n[o][i]=s:n[o]={[i]:s}}),n),[]);return r.length!==0&&t.length===0&&t.push({_:0},{_:0}),t}function fl(r){switch(r){case"opacity":return 1;case"x":case"y":case"z":case"zIndex":return 0;case"visibility":return"visible";case"collapsed":return!1;case"states":return[];default:return}}function qk(r,e){const{animation:t}=r;if(t===!1||e===!1)return!1;const n=Object.assign({},iV);return un(t)&&Object.assign(n,t),un(e)&&Object.assign(n,e),n}function AV(r){if(typeof r=="string"){const e=va(Wo.ANIMATION,r);return e||($i.warn(`The animation of ${r} is not registered.`),[])}return r}function lV(r,e,t,n){var i,a;const{animation:s}=r;if(s===!1||n===!1)return[];const o=(i=r==null?void 0:r[e])===null||i===void 0?void 0:i.animation;if(o===!1)return[];const A=o==null?void 0:o[t];if(A===!1)return[];const l=(a=Wk(r)[e])===null||a===void 0?void 0:a.animation,c=(h=[])=>AV(h).map(d=>Object.assign(Object.assign(Object.assign(Object.assign({},aV),un(s)&&s),d),un(n)&&n));if(A)return c(A);if(!l)return[];const u=l[t];return u===!1?[]:c(u)}function $k(r,e,t,n=[]){if(!n&&r===0&&e===0&&t===0)return null;if(Array.isArray(n)){let a=-1;const s=[];for(let o=0;o<n.length;o++){const A=n[o];if(A[0]==="translate"){if(A[1]===r&&A[2]===e)return null;a=o,s.push(["translate",r,e])}else if(A[0]==="translate3d"){if(A[1]===r&&A[2]===e&&A[3]===t)return null;a=o,s.push(["translate3d",r,e,t??0])}else s.push(A)}return a===-1&&s.splice(0,0,Be(t)?["translate3d",r,e,t??0]:["translate",r,e]),s.length===0?null:s}const i=n?n.replace(/translate(3d)?\([^)]*\)/g,""):"";return t===0?`translate(${r}, ${e})${i}`:`translate3d(${r}, ${e}, ${t})${i}`}var cV=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};const uV=(r,e,t)=>{if(!t.length)return null;const[n,i]=e,a=l=>{var c;if(l){const u=r.getShape(l);if(!u)return null;const h=`get${qu(l)}Style`,d=((c=r==null?void 0:r[h])===null||c===void 0?void 0:c.bind(r))||(v=>v),f=(d==null?void 0:d(n))||{},g=(d==null?void 0:d(i))||{};return{shape:u,fromStyle:f,toStyle:g}}else return{shape:r,fromStyle:n,toStyle:i}};let s;const o=t.map(l=>{var{fields:c,shape:u,states:h}=l,d=cV(l,["fields","shape","states"]);const f=a(u);if(!f)return null;const{shape:g,fromStyle:v,toStyle:p}=f,y=[{},{}];if(c.forEach(B=>{var C,S;Object.assign(y[0],{[B]:(C=v[B])!==null&&C!==void 0?C:fl(B)}),Object.assign(y[1],{[B]:(S=p[B])!==null&&S!==void 0?S:fl(B)})}),y.some(B=>Object.keys(B).some(C=>["x","y","z"].includes(C)))){const{x:B=0,y:C=0,z:S,transform:F=""}=g.attributes||{};y.forEach(T=>{var O,_,k;T.transform=$k((O=T.x)!==null&&O!==void 0?O:B,(_=T.y)!==null&&_!==void 0?_:C,(k=T.z)!==null&&k!==void 0?k:S,F)})}const m=g.animate(s1(y),d);return u===void 0&&(s=m),m}).filter(Boolean),A=s||(o==null?void 0:o[0]);return A?fB(A,o.filter(l=>l!==l)):null},hV=[{fields:["opacity"]}],dV=[{fields:["x","y"]}],Yk=[{fields:["x","y"]}],fV=Yk,Xk=[{fields:["sourceNode","targetNode"]}],gV=Xk,Zk=[{fields:["childrenNode","x","y"]}],vV=Zk;function pV(r){return"source"in r&&"target"in r}function yV(r){return r.length===2}function qo(r){return r instanceof Float32Array?!0:Array.isArray(r)&&(r.length===2||r.length===3)?r.every(e=>typeof e=="number"):!1}function Vi(r,e,t){return r>=e&&r<=t}function ai(r=0){if(Array.isArray(r)){const[e=0,t=e,n=e,i=t]=r;return[e,t,n,i]}return[r,r,r,r]}function mV(r=0){const e=ai(r);return e[0]+e[2]}function Yi(r){return r.max[0]-r.min[0]}function Xi(r){return r.max[1]-r.min[1]}function is(r){return[Yi(r),Xi(r)]}function Ra(r,e){const t=qo(r)?gB(r):r.getShape("key").getBounds();return e?as(t,e):t}function gB(r){const[e,t,n=0]=r,i=new It;return i.setMinMax([e,t,n],[e,t,n]),i}function as(r,e){const[t,n,i,a]=ai(e),[s,o,A]=r.min,[l,c,u]=r.max,h=new It;return h.setMinMax([s-a,o-t,A],[l+n,c+i,u]),h}function Ql(r){if(r.length===0)return new It;if(r.length===1)return r[0];const e=new It;e.setMinMax(r[0].min,r[0].max);for(let t=1;t<r.length;t++){const n=r[t];e.setMinMax([Math.min(e.min[0],n.min[0]),Math.min(e.min[1],n.min[1]),Math.min(e.min[2],n.min[2])],[Math.max(e.max[0],n.max[0]),Math.max(e.max[1],n.max[1]),Math.max(e.max[2],n.max[2])])}return e}function wV(r,e){const[t,n]=r.min,[i,a]=r.max,[s,o]=e.min,[A,l]=e.max;return t>=s&&i<=A&&n>=o&&a<=l}function wi(r,e){return Vi(r[0],e.min[0],e.max[0])&&Vi(r[1],e.min[1],e.max[1])}function Jk(r,e,t=!1){const{min:[n,i],max:[a,s]}=e,o=(r[1]===i||r[1]===s)&&(t||Vi(r[0],n,a)),A=(r[0]===n||r[0]===a)&&(t||Vi(r[1],i,s));return o||A}function BV(r,e){return!wi(r,e)}function gh(r,e){const{center:t}=e;return r[0]===t[0]&&r[1]===t[1]}function tl(r,e){const[t,n]=r,[i,a]=e.min,[s,o]=e.max,A=t-i,l=s-t,c=n-a,u=o-n,h=Math.min(A,l,c,u);return h===A?"left":h===l?"right":h===c?"top":h===u?"bottom":"left"}function Qs(r,e){const t=Za(r);if(wi(r,e))switch(tl(r,e)){case"left":t[0]=e.min[0];break;case"right":t[0]=e.max[0];break;case"top":t[1]=e.min[1];break;case"bottom":t[1]=e.max[1];break}else{const[n,i]=r,[a,s]=e.min,[o,A]=e.max;t[0]=Vi(n,a,o)?n:n<a?a:o,t[1]=Vi(i,s,A)?i:i<s?s:A}return t}function bV(r,e){const{center:t}=r,[n,i]=is(r),a=e==="up"||e==="down"?t[0]:e==="right"?t[0]-n/6:t[0]+n/6,s=e==="left"||e==="right"?t[1]:e==="down"?t[1]-i/6:t[1]+i/6;return[a,s]}function EV(r,e){let[t,n]=is(r);return[t,n]=e==="up"||e==="down"?[t,n]:[n,t],(Math.pow(n,2)-Math.pow(Math.sqrt(Math.pow(t/2,2)+Math.pow(n,2))-t/2,2))/(2*n)}function xV(r){const{min:[e,t],max:[n,i]}=r,a=[e,i],s=[n,i],o=[n,t],A=[e,t];return[[a,s],[s,o],[o,A],[A,a]]}var CV=function(e,t){return e===t},px=(function(){function r(e,t){t===void 0&&(t=null),this.value=e,this.next=t}return r.prototype.toString=function(e){return e?e(this.value):"".concat(this.value)},r})(),SV=(function(){function r(e){e===void 0&&(e=CV),this.head=null,this.tail=null,this.compare=e}return r.prototype.prepend=function(e){var t=new px(e,this.head);return this.head=t,this.tail||(this.tail=t),this},r.prototype.append=function(e){var t=new px(e);return this.head?(this.tail.next=t,this.tail=t,this):(this.head=t,this.tail=t,this)},r.prototype.delete=function(e){if(!this.head)return null;for(var t=null;this.head&&this.compare(this.head.value,e);)t=this.head,this.head=this.head.next;var n=this.head;if(n!==null)for(;n.next;)this.compare(n.next.value,e)?(t=n.next,n.next=n.next.next):n=n.next;return this.compare(this.tail.value,e)&&(this.tail=n),t},r.prototype.find=function(e){var t=e.value,n=t===void 0?void 0:t,i=e.callback,a=i===void 0?void 0:i;if(!this.head)return null;for(var s=this.head;s;){if(a&&a(s.value)||n!==void 0&&this.compare(s.value,n))return s;s=s.next}return null},r.prototype.deleteTail=function(){var e=this.tail;if(this.head===this.tail)return this.head=null,this.tail=null,e;for(var t=this.head;t.next;)t.next.next?t=t.next:t.next=null;return this.tail=t,e},r.prototype.deleteHead=function(){if(!this.head)return null;var e=this.head;return this.head.next?this.head=this.head.next:(this.head=null,this.tail=null),e},r.prototype.fromArray=function(e){var t=this;return e.forEach(function(n){return t.append(n)}),this},r.prototype.toArray=function(){for(var e=[],t=this.head;t;)e.push(t),t=t.next;return e},r.prototype.reverse=function(){for(var e=this.head,t=null,n=null;e;)n=e.next,e.next=t,t=e,e=n;this.tail=this.head,this.head=t},r.prototype.toString=function(e){return e===void 0&&(e=void 0),this.toArray().map(function(t){return t.toString(e)}).toString()},r})(),FV=function(e,t,n){t===void 0&&(t=[]);var i=t.filter(function(A){return A.source===e||A.target===e});if(n==="target"){var a=function(l){return l.source===e};return i.filter(a).map(function(A){return A.target})}if(n==="source"){var s=function(l){return l.target===e};return i.filter(s).map(function(A){return A.source})}var o=function(l){return l.source===e?l.target:l.source};return i.map(o)},TV=function(e,t){return t.filter(function(n){return n.source===e})},MV=function(e,t){return t.filter(function(n){return n.source===e||n.target===e})},OV=function(e){var t={},n=e.nodes,i=n===void 0?[]:n,a=e.edges,s=a===void 0?[]:a;return i.forEach(function(o){t[o.id]={degree:0,inDegree:0,outDegree:0}}),s.forEach(function(o){t[o.source].degree++,t[o.source].outDegree++,t[o.target].degree++,t[o.target].inDegree++}),t},_V={}.toString,vB=function(r,e){return _V.call(r)==="[object "+e+"]"};const eL=(function(r){return vB(r,"Function")}),tL=(function(r){return Array.isArray?Array.isArray(r):vB(r,"Array")}),IV=(function(r){var e=typeof r;return r!==null&&e==="object"||e==="function"});function kV(r,e){if(r){var t;if(tL(r))for(var n=0,i=r.length;n<i&&(t=e(r[n],n),t!==!1);n++);else if(IV(r)){for(var a in r)if(r.hasOwnProperty(a)&&(t=e(r[a],a),t===!1))break}}}const LV=(function(r){return vB(r,"String")});var QV=Object.values?function(r){return Object.values(r)}:function(r){var e=[];return kV(r,function(t,n){eL(r)&&n==="prototype"||e.push(t)}),e};const NV=(function(r,e){if(!eL(r))throw new TypeError("Expected a function");var t=function(){for(var n=[],i=0;i<arguments.length;i++)n[i]=arguments[i];var a=e?e.apply(this,n):n[0],s=t.cache;if(s.has(a))return s.get(a);var o=r.apply(this,n);return s.set(a,o),o};return t.cache=new Map,t});var tu;NV(function(r,e){e===void 0&&(e={});var t=e.fontSize,n=e.fontFamily,i=e.fontWeight,a=e.fontStyle,s=e.fontVariant;return tu||(tu=document.createElement("canvas").getContext("2d")),tu.font=[a,s,i,t+"px",n].join(" "),tu.measureText(LV(r)?r:"").width},function(r,e){return e===void 0&&(e={}),OR([r],QV(e)).join("")});var UV=function(e,t,n){for(var i=1/0,a,s=0;s<t.length;s++){var o=t[s].id;!n[o]&&e[o]<=i&&(i=e[o],a=t[s])}return a},PV=function(e,t,n,i){var a=e.nodes,s=a===void 0?[]:a,o=e.edges,A=o===void 0?[]:o,l={},c={},u={};s.forEach(function(y,m){var B=y.id;c[B]=1/0,B===t&&(c[B]=0)});for(var h=s.length,d=function(m){var B=UV(c,s,l),C=B.id;if(l[C]=!0,c[C]===1/0)return"continue";var S=[];n?S=TV(C,A):S=MV(C,A),S.forEach(function(F){var T=F.target,O=F.source,_=T===C?O:T,k=i&&F[i]?F[i]:1;c[_]>c[B.id]+k?(c[_]=c[B.id]+k,u[_]=[B.id]):c[_]===c[B.id]+k&&u[_].push(B.id)})},f=0;f<h;f++)d();u[t]=[t];var g={};for(var v in c)c[v]!==1/0&&nL(t,v,u,g);var p={};for(var v in g)p[v]=g[v][0];return{length:c,path:p,allPath:g}};function nL(r,e,t,n){if(r===e)return[r];if(n[e])return n[e];for(var i=[],a=0,s=t[e];a<s.length;a++){var o=s[a],A=nL(r,o,t,n);if(!A)return;for(var l=0,c=A;l<c.length;l++){var u=c[l];tL(u)?i.push(_e(_e([],u,!0),[e],!1)):i.push([u,e])}}return n[e]=i,n[e]}var rL=function(e,t,n,i,a){var s=PV(e,t,i,a),o=s.length,A=s.path,l=s.allPath;return{length:o[n],path:A[n],allPath:l[n]}},yx;(function(r){r.EuclideanDistance="euclideanDistance"})(yx||(yx={}));var RV=function(e,t,n){typeof t!="number"&&(t=1e-6),typeof n!="number"&&(n=.85);for(var i=1,a=0,s=1e3,o=e.nodes,A=o===void 0?[]:o,l=e.edges,c=l===void 0?[]:l,u=A.length,h,d={},f={},g=0;g<u;++g){var v=A[g],p=v.id;d[p]=1/u,f[p]=1/u}for(var y=OV(e);s>0&&i>t;){a=0;for(var g=0;g<u;++g){var v=A[g],p=v.id;if(h=0,y[v.id].inDegree===0)d[p]=0;else{for(var m=FV(p,c,"source"),B=0;B<m.length;++B){var C=m[B],S=y[C].outDegree;S>0&&(h+=f[C]/S)}d[p]=n*h,a+=d[p]}}a=(1-a)/u,i=0;for(var g=0;g<u;++g){var v=A[g],p=v.id;h=d[p]+a,i+=Math.abs(h-f[p]),f[p]=h}s-=1}return f};(function(){function r(e){e===void 0&&(e=10),this.linkedList=new SV,this.maxStep=e}return Object.defineProperty(r.prototype,"length",{get:function(){return this.linkedList.toArray().length},enumerable:!1,configurable:!0}),r.prototype.isEmpty=function(){return!this.linkedList.head},r.prototype.isMaxStack=function(){return this.toArray().length>=this.maxStep},r.prototype.peek=function(){return this.isEmpty()?null:this.linkedList.head.value},r.prototype.push=function(e){this.linkedList.prepend(e),this.length>this.maxStep&&this.linkedList.deleteTail()},r.prototype.pop=function(){var e=this.linkedList.deleteHead();return e?e.value:null},r.prototype.toArray=function(){return this.linkedList.toArray().map(function(e){return e.value})},r.prototype.clear=function(){for(;!this.isEmpty();)this.pop()},r})();function Z(r){if(r.id!==void 0)return r.id;if(r.source!==void 0&&r.target!==void 0)return`${r.source}-${r.target}`;throw new Error(ha("The datum does not have available id."))}function nu(r){return r.combo}function iL(r,e){const t={nodes:(r.nodes||[]).map(Z),edges:(r.edges||[]).map(Z),combos:(r.combos||[]).map(Z)};return e?Object.values(t).flat():t}const aL=(r,e,t)=>{var n;switch(t.type){case"degree":{const i=new Map;return(n=r.nodes)===null||n===void 0||n.forEach(a=>{const s=e(Z(a),t.direction).length;i.set(Z(a),s)}),i}case"betweenness":return DV(r,t.directed,t.weightPropertyName);case"closeness":return HV(r,t.directed,t.weightPropertyName);case"eigenvector":return KV(r,t.directed);case"pagerank":return GV(r,t.epsilon,t.linkProb);default:return sL(r)}},sL=r=>{var e;const t=new Map;return(e=r.nodes)===null||e===void 0||e.forEach(n=>{t.set(Z(n),0)}),t},DV=(r,e,t)=>{const n=sL(r),{nodes:i=[]}=r;return i.forEach(a=>{i.forEach(s=>{if(a!==s){const{allPath:o}=rL(r,Z(a),Z(s),e,t),A=o.length;o.flat().forEach(l=>{l!==Z(a)&&l!==Z(s)&&n.set(l,n.get(l)+1/A)})}})}),n},HV=(r,e,t)=>{const n=new Map,{nodes:i=[]}=r;return i.forEach(a=>{const s=i.reduce((o,A)=>{if(a!==A){const{length:l}=rL(r,Z(a),Z(A),e,t);o+=l}return o},0);n.set(Z(a),1/s)}),n},GV=(r,e,t)=>{var n;const i=new Map,a=RV(r,e,t);return(n=r.nodes)===null||n===void 0||n.forEach(s=>{i.set(Z(s),a[Z(s)])}),i},KV=(r,e)=>{const{nodes:t=[]}=r,n=zV(r,e),i=VV(n,t.length),a=new Map;return t.forEach((s,o)=>{a.set(Z(s),i[o])}),a},zV=(r,e)=>{const{nodes:t=[],edges:n=[]}=r,i=Array(t.length).fill(null).map(()=>Array(t.length).fill(0));return n.forEach(({source:a,target:s})=>{const o=t.findIndex(l=>Z(l)===a),A=t.findIndex(l=>Z(l)===s);e?i[o][A]=1:(i[o][A]=1,i[A][o]=1)}),i},VV=(r,e,t=100,n=1e-6)=>{let i=Array(e).fill(1),a=1/0;for(let s=0;s<t&&a>n;s++){const o=Array(e).fill(0);for(let l=0;l<e;l++)for(let c=0;c<e;c++)o[l]+=r[l][c]*i[c];const A=Math.sqrt(o.reduce((l,c)=>l+c*c,0));for(let l=0;l<e;l++)o[l]/=A;a=Math.sqrt(o.reduce((l,c,u)=>l+(c-i[u])*c,0)),i=o}return i};function qa(r,e,t,n=Xt){const i=new Map(r.map(h=>[t(h),h])),a=new Map(e.map(h=>[t(h),h])),s=new Set(i.keys()),o=new Set(a.keys()),A=[],l=[],c=[],u=[];return o.forEach(h=>{s.has(h)?n(i.get(h),a.get(h))?u.push(a.get(h)):l.push(a.get(h)):A.push(a.get(h))}),s.forEach(h=>{o.has(h)||c.push(i.get(h))}),{enter:A,exit:c,keep:u,update:l}}function Vs(r,e,t){const n=i=>{t&&!t(i)||(i.style.visibility=e)};r.forEach(i=>{n(i)})}function jV(r,e,t){const n={},i=a=>(a in n||(n[a]=0),`${e}-${a}-${n[a]++}`);return t.map(a=>typeof a=="string"?{type:a,key:i(a)}:typeof a=="function"?a.call(r):a.key?a:Object.assign(Object.assign({},a),{key:i(a.type)}))}class pB{constructor(e){this.extensions=[],this.extensionMap={},this.context=e}setExtensions(e){const t=jV(this.context.graph,this.category,e),{enter:n,update:i,exit:a,keep:s}=qa(this.extensions,t,o=>o.key);this.createExtensions(n),this.updateExtensions([...i,...s]),this.destroyExtensions(a),this.extensions=t}createExtension(e){const{category:t}=this,{key:n,type:i}=e,a=va(t,i);if(!a)return $i.warn(`The extension ${i} of ${t} is not registered.`);const s=new a(this.context,e);s.initialized=!0,this.extensionMap[n]=s}createExtensions(e){e.forEach(t=>this.createExtension(t))}updateExtension(e){const{key:t}=e,n=this.extensionMap[t];n&&n.update(e)}updateExtensions(e){e.forEach(t=>this.updateExtension(t))}destroyExtension(e){const t=this.extensionMap[e];t&&(t.initialized&&!t.destroyed&&t.destroy(),delete this.extensionMap[e])}destroyExtensions(e){e.forEach(({key:t})=>this.destroyExtension(t))}destroy(){this.destroyExtensions(this.extensions),this.context={},this.extensions=[],this.extensionMap={}}}class yB{constructor(e,t){this.events=[],this.initialized=!1,this.destroyed=!1,this.context=e,this.options=t}update(e){this.options=Object.assign(this.options,e)}destroy(){this.context={},this.options={},this.destroyed=!0}}class zr extends yB{}class Jh extends zr{constructor(e,t){super(e,Object.assign({},Jh.defaultOptions,t)),this.isOverlapping=(n,i)=>i.some(a=>n.intersects(a)),this.occupiedBounds=[],this.detectLabelCollision=n=>{const i=this.context.viewport,a={show:[],hide:[]};return this.occupiedBounds=[],n.forEach(s=>{const o=s.getShape("label").getRenderBounds();i.isInViewport(o,!0)&&!this.isOverlapping(o,this.occupiedBounds)?(a.show.push(s),this.occupiedBounds.push(as(o,this.options.padding))):a.hide.push(s)}),a},this.hideLabelIfExceedViewport=(n,i)=>{const{exit:a}=qa(n,i,s=>s.id);a==null||a.forEach(this.hideLabel)},this.nodeCentralities=new Map,this.sortNodesByCentrality=(n,i)=>{const{model:a}=this.context,s=a.getData(),o=a.getRelatedEdgesData.bind(a);return n.map(l=>(this.nodeCentralities.has(l.id)||(this.nodeCentralities=aL(s,o,i)),{node:l,centrality:this.nodeCentralities.get(l.id)})).sort((l,c)=>c.centrality-l.centrality).map(l=>l.node)},this.sortLabelElementsInView=n=>{const{sort:i,sortNode:a,sortCombo:s,sortEdge:o}=this.options,{model:A}=this.context;if(Te(i))return n.sort((g,v)=>i(A.getElementDataById(g.id),A.getElementDataById(v.id)));const{node:l=[],edge:c=[],combo:u=[]}=Nh(n,g=>g.type),h=Te(s)?u.sort((g,v)=>s(...A.getComboData([g.id,v.id]))):u,d=Te(a)?l.sort((g,v)=>a(...A.getNodeData([g.id,v.id]))):this.sortNodesByCentrality(l,a),f=Te(o)?c.sort((g,v)=>o(...A.getEdgeData([g.id,v.id]))):c;return[...h,...d,...f]},this.labelElementsInView=[],this.isFirstRender=!0,this.onToggleVisibility=n=>{var i;if(((i=n.data)===null||i===void 0?void 0:i.stage)==="zIndex")return;if(!this.validate(n)){this.hiddenElements.size>0&&(this.hiddenElements.forEach(this.showLabel),this.hiddenElements.clear());return}const a=this.isFirstRender?this.getLabelElements():this.getLabelElementsInView();this.hideLabelIfExceedViewport(this.labelElementsInView,a),this.labelElementsInView=a;const s=this.sortLabelElementsInView(this.labelElementsInView),{show:o,hide:A}=this.detectLabelCollision(s);for(let l=o.length-1;l>=0;l--)this.showLabel(o[l]);A.forEach(this.hideLabel)},this.hiddenElements=new Map,this.hideLabel=n=>{const i=n.getShape("label");i&&Vs(i,"hidden"),this.hiddenElements.set(n.id,n)},this.showLabel=n=>{const i=n.getShape("label");i&&Vs(i,"visible"),n.toFront(),this.hiddenElements.delete(n.id)},this.onTransform=V_(this.onToggleVisibility,this.options.throttle,{leading:!0}),this.enableToggle=!0,this.toggle=n=>{this.enableToggle&&this.onToggleVisibility(n)},this.onBeforeRender=()=>{this.enableToggle=!1},this.onAfterRender=n=>{this.onToggleVisibility(n),this.enableToggle=!0},this.bindEvents()}update(e){this.unbindEvents(),super.update(e),this.bindEvents(),this.onToggleVisibility({})}getLabelElements(){const{elementMap:e}=this.context.element,t=[];for(const n in e){const i=e[n];i.isVisible()&&i.getShape("label")&&t.push(i)}return t}getLabelElementsInView(){const e=this.context.viewport;return this.getLabelElements().filter(t=>e.isInViewport(t.getShape("key").getRenderBounds()))}bindEvents(){const{graph:e}=this.context;e.on(ge.BEFORE_RENDER,this.onBeforeRender),e.on(ge.AFTER_RENDER,this.onAfterRender),e.on(ge.AFTER_DRAW,this.toggle),e.on(ge.AFTER_LAYOUT,this.toggle),e.on(ge.AFTER_TRANSFORM,this.onTransform)}unbindEvents(){const{graph:e}=this.context;e.off(ge.BEFORE_RENDER,this.onBeforeRender),e.off(ge.AFTER_RENDER,this.onAfterRender),e.off(ge.AFTER_DRAW,this.toggle),e.off(ge.AFTER_LAYOUT,this.toggle),e.off(ge.AFTER_TRANSFORM,this.onTransform)}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}destroy(){this.unbindEvents(),super.destroy()}}Jh.defaultOptions={enable:!0,throttle:100,padding:0,sortNode:{type:"degree"}};const mx=[0,0,0];function Ve(r,e){return r.map((t,n)=>t+e[n])}function bt(r,e){return r.map((t,n)=>t-e[n])}function vi(r,e){return typeof e=="number"?r.map(t=>t*e):r.map((t,n)=>t*e[n])}function Bi(r,e){return typeof e=="number"?r.map(t=>t/e):r.map((t,n)=>t/e[n])}function WV(r,e){return r.reduce((t,n,i)=>t+n*e[i],0)}function qV(r,e){const t=gl(r),n=gl(e);return[t[1]*n[2]-t[2]*n[1],t[2]*n[0]-t[0]*n[2],t[0]*n[1]-t[1]*n[0]]}function Da(r,e){return r.map(t=>t*e)}function Lt(r,e){return Math.sqrt(r.reduce((t,n,i)=>t+Math.pow(n-e[i]||0,2),0))}function vh(r,e){return r.reduce((t,n,i)=>t+Math.abs(n-e[i]),0)}function fa(r){const e=r.reduce((t,n)=>t+Math.pow(n,2),0);return r.map(t=>t/Math.sqrt(e))}function mB(r,e,t=!1){const n=r[0]*e[1]-r[1]*e[0];let i=Math.acos(vi(r,e).reduce((a,s)=>a+s,0)/(Lt(r,mx)*Lt(e,mx)));return t&&n<0&&(i=2*Math.PI-i),i}function ed(r,e=!0){return e?[-r[1],r[0]]:[r[1],-r[0]]}function vg(r,e){return r.map(t=>t%e)}function js(r){return[r[0],r[1]]}function gl(r){return yV(r)?[r[0],r[1],0]:r}function oL(r){const[e,t]=r;return!e&&!t?0:Math.atan2(t,e)}function AL(r,e){const[t,n]=r;if(e%360===0)return[t,n];const i=e*Math.PI/180,a=Math.cos(i),s=Math.sin(i);return[t*a-n*s,t*s+n*a]}function lL(r,e){const[t,n]=r,[i,a]=e,s=bt(t,n),o=bt(i,a);return qV(s,o).every(A=>A===0)}function wB(r,e,t=!1){if(lL(r,e))return;const[n,i]=r,[a,s]=e,o=((n[0]-a[0])*(a[1]-s[1])-(n[1]-a[1])*(a[0]-s[0]))/((n[0]-i[0])*(a[1]-s[1])-(n[1]-i[1])*(a[0]-s[0])),A=s[0]-a[0]?(n[0]-a[0]+o*(i[0]-n[0]))/(s[0]-a[0]):(n[1]-a[1]+o*(i[1]-n[1]))/(s[1]-a[1]);if(!(!t&&(!Vi(o,0,1)||!Vi(A,0,1))))return[n[0]+o*(i[0]-n[0]),n[1]+o*(i[1]-n[1])]}function cL(r){if(Array.isArray(r))return Vi(r[0],0,1)&&Vi(r[1],0,1)?r:[.5,.5];const e=r.split("-"),t=e.includes("left")?0:e.includes("right")?1:.5,n=e.includes("top")?0:e.includes("bottom")?1:.5;return[t,n]}function Sn(r){const{x:e=0,y:t=0,z:n=0}=r.style||{};return[+e,+t,+n]}function $V(r){const{x:e,y:t,z:n}=r.style||{};return e!==void 0||t!==void 0||n!==void 0}function YV(r,e){const[t,n]=e,{min:i,max:a}=r;return[i[0]+t*(a[0]-i[0]),i[1]+n*(a[1]-i[1])]}function Aa(r,e="center"){const t=cL(e);return YV(r,t)}function Hn(r){var e;return[r.x,r.y,(e=r.z)!==null&&e!==void 0?e:0]}function pi(r){var e;return{x:r[0],y:r[1],z:(e=r[2])!==null&&e!==void 0?e:0}}function xA(r,e=0){return r.map(t=>parseFloat(t.toFixed(e)))}function $a(r,e,t,n=!1){if(Xt(r,e))return r;const i=n?bt(r,e):bt(e,r),a=fa(i),s=[a[0]*t,a[1]*t];return Ve(js(r),s)}function uL(r,e){return r[1]===e[1]}function XV(r,e){return r[0]===e[0]}function ZV(r,e){return uL(r,e)||XV(r,e)}function hL(r,e,t){return lL([r,e],[e,t])}function dL(r,e){return[2*e[0]-r[0],2*e[1]-r[1]]}function fL(r,e,t,n=!0,i=!1){for(let a=0;a<t.length;a++){let s=t[a],o=t[(a+1)%t.length];n&&(s=Ve(e,s),o=Ve(e,o));const A=i?dL(r,e):r,l=wB([e,A],[s,o]);if(l)return{point:l,line:[s,o]}}return{point:e,line:void 0}}function JV(r,e,t,n){const i=r[0],a=r[1];let s=!1;t===void 0&&(t=0),n===void 0&&(n=e.length);const o=n-t;for(let A=0,l=o-1;A<o;l=A++){const c=e[A+t][0],u=e[A+t][1],h=e[l+t][0],d=e[l+t][1];u>a!=d>a&&i<(h-c)*(a-u)/(d-u)+c&&(s=!s)}return s}function ej(r,e,t=!1){const n=Aa(e,"center"),i=[Aa(e,"left-top"),Aa(e,"right-top"),Aa(e,"right-bottom"),Aa(e,"left-bottom")];return fL(r,n,i,!1,t).point}function td(r,e,t=!1){const n=e.center,i=t?dL(r,n):r,a=bt(i,e.center),s=Math.atan2(a[1],a[0]);if(isNaN(s))return n;const o=Yi(e)/2,A=Xi(e)/2,l=n[0]+o*Math.cos(s),c=n[1]+A*Math.sin(s);return[l,c]}function tj(r,e){let t=1/0,n=[r[0],e[0]];return r.forEach(i=>{e.forEach(a=>{const s=Lt(i,a);s<t&&(t=s,n=[i,a])})}),n}function nj(r,e){let t=1/0,n=[[0,0],[0,0]];return e.forEach(i=>{const a=rj(r,i);a<t&&(t=a,n=i)}),n}function rj(r,e){const t=gL(r,e);return Lt(r,t)}function gL(r,e){const[t,n]=e[0],[i,a]=e[1],[s,o]=r,A=i-t,l=a-n;if(A===0&&l===0)return[t,n];let c=((s-t)*A+(o-n)*l)/(A*A+l*l);c>1?c=1:c<0&&(c=0);const u=t+c*A,h=n+c*l;return[u,h]}function ij(r){const e=r.reduce((t,n)=>Ve(t,n),[0,0]);return Bi(e,r.length)}function BB(r,e=!0){const t=ij(r);return r.sort(([n,i],[a,s])=>{const o=Math.atan2(i-t[1],n-t[0]),A=Math.atan2(s-t[1],a-t[0]);return e?A-o:o-A})}function wx(r,e){return[r,[r[0],e[1]],e,[e[0],r[1]]]}class ln{constructor(e,t,n){if(this.phase=t,this.pointerByTouch=[],this.initialDistance=null,this.emitter=e,ln.instance)return ln.callbacks[this.phase].push(n),ln.instance;this.onPointerDown=this.onPointerDown.bind(this),this.onPointerMove=this.onPointerMove.bind(this),this.onPointerUp=this.onPointerUp.bind(this),this.bindEvents(),ln.instance=this,ln.callbacks[this.phase].push(n)}bindEvents(){const{emitter:e}=this;e.on(se.POINTER_DOWN,this.onPointerDown),e.on(se.POINTER_MOVE,this.onPointerMove),e.on(se.POINTER_UP,this.onPointerUp)}updatePointerPosition(e,t,n){const i=this.pointerByTouch.findIndex(a=>a.pointerId===e);i>=0&&(this.pointerByTouch[i]={x:t,y:n,pointerId:e})}onPointerDown(e){const{x:t,y:n}=e.client||{};if(!(t===void 0||n===void 0)&&(this.pointerByTouch.push({x:t,y:n,pointerId:e.pointerId}),e.pointerType==="touch"&&this.pointerByTouch.length===2)){ln.isPinching=!0;const i=this.pointerByTouch[0].x-this.pointerByTouch[1].x,a=this.pointerByTouch[0].y-this.pointerByTouch[1].y;this.initialDistance=Math.sqrt(i*i+a*a),ln.callbacks.pinchstart.forEach(s=>s(e,{scale:0}))}}onPointerMove(e){if(this.pointerByTouch.length!==2||this.initialDistance===null)return;const{x:t,y:n}=e.client||{};if(t===void 0||n===void 0)return;this.updatePointerPosition(e.pointerId,t,n);const i=this.pointerByTouch[0].x-this.pointerByTouch[1].x,a=this.pointerByTouch[0].y-this.pointerByTouch[1].y,o=Math.sqrt(i*i+a*a)/this.initialDistance;ln.callbacks.pinchmove.forEach(A=>A(e,{scale:(o-1)*5}))}onPointerUp(e){var t;ln.callbacks.pinchend.forEach(n=>n(e,{scale:0})),ln.isPinching=!1,this.initialDistance=null,this.pointerByTouch=[],(t=ln.instance)===null||t===void 0||t.tryDestroy()}destroy(){this.emitter.off(se.POINTER_DOWN,this.onPointerDown),this.emitter.off(se.POINTER_MOVE,this.onPointerMove),this.emitter.off(se.POINTER_UP,this.onPointerUp),ln.instance=null}off(e,t){const n=ln.callbacks[e].indexOf(t);n>-1&&ln.callbacks[e].splice(n,1),this.tryDestroy()}tryDestroy(){Object.values(ln.callbacks).every(e=>e.length===0)&&this.destroy()}}ln.isPinching=!1;ln.instance=null;ln.callbacks={pinchstart:[],pinchmove:[],pinchend:[]};const Bx=r=>r.map(e=>At(e)?e.toLocaleLowerCase():e);class ss{constructor(e){this.map=new Map,this.boundHandlePinch=()=>{},this.recordKey=new Set,this.onKeyDown=t=>{t!=null&&t.key&&(this.recordKey.add(t.key),this.trigger(t))},this.onKeyUp=t=>{t!=null&&t.key&&this.recordKey.delete(t.key)},this.onWheel=t=>{this.triggerExtendKey(se.WHEEL,t)},this.onDrag=t=>{this.triggerExtendKey(se.DRAG,t)},this.handlePinch=(t,n)=>{this.triggerExtendKey(se.PINCH,Object.assign(Object.assign({},t),n))},this.onFocus=()=>{this.recordKey.clear()},this.emitter=e,this.bindEvents()}bind(e,t){e.length!==0&&(e.includes(se.PINCH)&&!this.pinchHandler&&(this.boundHandlePinch=this.handlePinch.bind(this),this.pinchHandler=new ln(this.emitter,"pinchmove",this.boundHandlePinch)),this.map.set(e,t))}unbind(e,t){this.map.forEach((n,i)=>{Xt(i,e)&&(!t||t===n)&&this.map.delete(i)})}unbindAll(){this.map.clear()}match(e){const t=Bx(Array.from(this.recordKey)).sort(),n=Bx(e).sort();return Xt(t,n)}bindEvents(){var e;const{emitter:t}=this;t.on(se.KEY_DOWN,this.onKeyDown),t.on(se.KEY_UP,this.onKeyUp),t.on(se.WHEEL,this.onWheel),t.on(se.DRAG,this.onDrag),(e=globalThis.addEventListener)===null||e===void 0||e.call(globalThis,"focus",this.onFocus)}trigger(e){this.map.forEach((t,n)=>{this.match(n)&&t(e)})}triggerExtendKey(e,t){this.map.forEach((n,i)=>{i.includes(e)&&Xt(Array.from(this.recordKey),i.filter(a=>a!==e))&&n(t)})}destroy(){var e,t;this.unbindAll(),this.emitter.off(se.KEY_DOWN,this.onKeyDown),this.emitter.off(se.KEY_UP,this.onKeyUp),this.emitter.off(se.WHEEL,this.onWheel),this.emitter.off(se.DRAG,this.onDrag),(e=this.pinchHandler)===null||e===void 0||e.off("pinchmove",this.boundHandlePinch),(t=globalThis.removeEventListener)===null||t===void 0||t.call(globalThis,"focus",this.onFocus)}}class Nl extends zr{constructor(e,t){super(e,zn({},Nl.defaultOptions,t)),this.shortcut=new ss(e.graph),this.onPointerDown=this.onPointerDown.bind(this),this.onPointerMove=this.onPointerMove.bind(this),this.onPointerUp=this.onPointerUp.bind(this),this.clearStates=this.clearStates.bind(this),this.bindEvents()}onPointerDown(e){if(!this.validate(e)||!this.isKeydown()||this.startPoint)return;const{canvas:t,graph:n}=this.context,i=Object.assign({},this.options.style);this.options.style.lineWidth&&(i.lineWidth=+this.options.style.lineWidth/n.getZoom()),this.rectShape=new Vn({id:"g6-brush-select",style:i}),t.appendChild(this.rectShape),this.startPoint=[e.canvas.x,e.canvas.y]}onPointerMove(e){var t;if(!this.startPoint)return;const{immediately:n,mode:i}=this.options;this.endPoint=ph(e,this.context.graph),(t=this.rectShape)===null||t===void 0||t.attr({x:Math.min(this.endPoint[0],this.startPoint[0]),y:Math.min(this.endPoint[1],this.startPoint[1]),width:Math.abs(this.endPoint[0]-this.startPoint[0]),height:Math.abs(this.endPoint[1]-this.startPoint[1])}),n&&i==="default"&&this.updateElementsStates(wx(this.startPoint,this.endPoint))}onPointerUp(e){if(this.startPoint){if(!this.endPoint){this.clearBrush();return}this.endPoint=ph(e,this.context.graph),this.updateElementsStates(wx(this.startPoint,this.endPoint)),this.clearBrush()}}clearStates(){this.endPoint||this.clearElementsStates()}clearElementsStates(){const{graph:e}=this.context,t=Object.values(e.getData()).reduce((n,i)=>Object.assign({},n,i.reduce((a,s)=>{var o;const A=(o=s.states||[])===null||o===void 0?void 0:o.filter(l=>l!==this.options.state);return a[Z(s)]=A,a},{})),{});e.setElementState(t,this.options.animation)}updateElementsStates(e){const{graph:t}=this.context,{enableElements:n,state:i,mode:a,onSelect:s}=this.options,o=this.selector(t,e,n),A={};switch(a){case"union":o.forEach(l=>{A[l]=[...t.getElementState(l),i]});break;case"diff":o.forEach(l=>{const c=t.getElementState(l);A[l]=c.includes(i)?c.filter(u=>u!==i):[...c,i]});break;case"intersect":o.forEach(l=>{const c=t.getElementState(l);A[l]=c.includes(i)?[i]:[]});break;default:o.forEach(l=>{A[l]=[i]});break}Te(s)&&s(A),t.setElementState(A,this.options.animation)}selector(e,t,n){if(!n||n.length===0)return[];const i=[],a=e.getData();if(n.forEach(s=>{a[`${s}s`].forEach(o=>{const A=Z(o);e.getElementVisibility(A)!=="hidden"&&JV(e.getElementPosition(A),t)&&i.push(A)})}),n.includes("edge")){const s=a.edges;s==null||s.forEach(o=>{const{source:A,target:l}=o;i.includes(A)&&i.includes(l)&&i.push(Z(o))})}return i}clearBrush(){var e;(e=this.rectShape)===null||e===void 0||e.remove(),this.rectShape=void 0,this.startPoint=void 0,this.endPoint=void 0}isKeydown(){const{trigger:e}=this.options,t=Array.isArray(e)?e:[e];return this.shortcut.match(t.filter(n=>n!=="drag"))}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}bindEvents(){const{graph:e}=this.context;e.on(se.POINTER_DOWN,this.onPointerDown),e.on(se.POINTER_MOVE,this.onPointerMove),e.on(se.POINTER_UP,this.onPointerUp),e.on(ga.CLICK,this.clearStates)}unbindEvents(){const{graph:e}=this.context;e.off(se.POINTER_DOWN,this.onPointerDown),e.off(se.POINTER_MOVE,this.onPointerMove),e.off(se.POINTER_UP,this.onPointerUp),e.off(ga.CLICK,this.clearStates)}update(e){this.unbindEvents(),this.options=zn(this.options,e),this.bindEvents()}destroy(){this.unbindEvents(),super.destroy()}}Nl.defaultOptions={animation:!1,enable:!0,enableElements:["node","combo","edge"],immediately:!1,mode:"default",state:"selected",trigger:["shift"],style:{width:0,height:0,lineWidth:1,fill:"#1677FF",stroke:"#1677FF",fillOpacity:.1,zIndex:2,pointerEvents:"none"}};const ph=(r,e)=>{if((r.targetType==="node"||r.targetType==="combo")&&!(r.nativeEvent.target instanceof HTMLCanvasElement)){const[t,n]=e.getCanvasByClient([r.client.x,r.client.y]);return[t,n]}return[r.canvas.x,r.canvas.y]},pa=.8,Ws=["node","edge","combo"];function Ns(r,e,t,n,i=0){n==="TB"&&e(r,i);const a=t(r);if(a)for(const s of a)Ns(s,e,t,n,i+1);n==="BT"&&e(r,i)}function aj(r,e,t){const n=[[r,0]];for(;n.length;){const[i,a]=n.shift();e(i,a);const s=t(i);if(s)for(const o of s)n.push([o,a+1])}}function vL(r,e,t,n,i="both"){if(e==="combo"||e==="node")return pg(r,t,n,i);const a=r.getEdgeData(t);if(!a)return[];const s=pg(r,a.source,n-1,i),o=pg(r,a.target,n-1,i);return Array.from(new Set([...s,...o,t]))}function pg(r,e,t,n="both"){const i=new Set,a=new Set,s=new Set;return aj(e,(o,A)=>{A>t||(s.add(o),r.getRelatedEdgesData(o,n).forEach(l=>{const c=Z(l);!a.has(c)&&A<t&&(s.add(c),a.add(c))}))},o=>r.getRelatedEdgesData(o,n).map(A=>A.source===o?A.target:A.source).filter(A=>i.has(A)?!1:(i.add(A),!0))),Array.from(s)}function yg(r){return r.states||[]}var ru=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class nd extends zr{constructor(e,t){super(e,Object.assign({},nd.defaultOptions,t)),this.onClickSelect=n=>ru(this,void 0,void 0,function*(){var i,a;this.validate(n)&&(yield this.updateState(n),(a=(i=this.options).onClick)===null||a===void 0||a.call(i,n))}),this.onClickCanvas=n=>ru(this,void 0,void 0,function*(){var i,a;this.validate(n)&&(yield this.clearState(),(a=(i=this.options).onClick)===null||a===void 0||a.call(i,n))}),this.shortcut=new ss(e.graph),this.bindEvents()}bindEvents(){const{graph:e}=this.context;this.unbindEvents(),Ws.forEach(t=>{e.on(`${t}:${se.CLICK}`,this.onClickSelect)}),e.on(ga.CLICK,this.onClickCanvas)}get isMultipleSelect(){const{multiple:e,trigger:t}=this.options;return e&&this.shortcut.match(t)}getNeighborIds(e){const{target:t,targetType:n}=e,{graph:i}=this.context,{degree:a}=this.options;return vL(i,n,t.id,typeof a=="function"?a(e):a).filter(s=>s!==t.id)}updateState(e){return ru(this,void 0,void 0,function*(){const{state:t,unselectedState:n,neighborState:i,animation:a}=this.options;if(!t&&!i&&!n)return;const{target:s}=e,{graph:o}=this.context,A=o.getElementData(s.id),l=yg(A).includes(t)?"unselect":"select",c={},u=this.isMultipleSelect,h=[s.id],d=this.getNeighborIds(e);if(u)if(Object.assign(c,this.getDataStates()),l==="select"){const f=(g,v)=>{g.forEach(p=>{const y=new Set(o.getElementState(p));y.add(v),y.delete(n),c[p]=Array.from(y)})};f(h,t),f(d,i),n&&Object.keys(c).forEach(g=>{const v=c[g];!v.includes(t)&&!v.includes(i)&&!v.includes(n)&&c[g].push(n)})}else{const f=c[s.id];c[s.id]=f.filter(g=>g!==t&&g!==i),f.includes(n)||c[s.id].push(n),d.forEach(g=>{c[g]=c[g].filter(v=>v!==i),c[g].includes(t)||c[g].push(n)})}else if(l==="select"){Object.assign(c,this.getClearStates(!!n));const f=(g,v)=>{g.forEach(p=>{c[p]||(c[p]=o.getElementState(p)),c[p].push(v)})};f(h,t),f(d,i),n&&Object.keys(c).forEach(g=>{!h.includes(g)&&!d.includes(g)&&c[g].push(n)})}else Object.assign(c,this.getClearStates());yield o.setElementState(c,a)})}getDataStates(){const{graph:e}=this.context,{nodes:t,edges:n,combos:i}=e.getData(),a={};return[...t,...n,...i].forEach(s=>{a[Z(s)]=yg(s)}),a}getClearStates(e=!1){const{graph:t}=this.context,{state:n,unselectedState:i,neighborState:a}=this.options,s=new Set([n,i,a]),{nodes:o,edges:A,combos:l}=t.getData(),c={};return[...o,...A,...l].forEach(u=>{const h=yg(u),d=h.filter(f=>!s.has(f));(e||d.length!==h.length)&&(c[Z(u)]=d)}),c}clearState(){return ru(this,void 0,void 0,function*(){const{graph:e}=this.context;yield e.setElementState(this.getClearStates(),this.options.animation)})}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}unbindEvents(){const{graph:e}=this.context;Ws.forEach(t=>{e.off(`${t}:${se.CLICK}`,this.onClickSelect)}),e.off(ga.CLICK,this.onClickCanvas)}destroy(){this.unbindEvents(),super.destroy()}}nd.defaultOptions={animation:!0,enable:!0,multiple:!1,trigger:["shift"],state:"selected",neighborState:"selected",unselectedState:void 0,degree:0};function xr(r){var e;return!!(!((e=r.style)===null||e===void 0)&&e.collapsed)}function yh(r,e){if(!r.startsWith(e))return!1;const t=r[e.length];return t>="A"&&t<="Z"}function sj(r,e){return`${e}${qu(r)}`}function oj(r,e,t=!0){if(!e||!yh(r,e))return r;const n=r.slice(e.length);return t?fR(n):n}function tn(r,e){const t=Object.entries(r).reduce((n,[i,a])=>(i==="className"||i==="class"||yh(i,e)&&Object.assign(n,{[oj(i,e)]:a}),n),{});if("opacity"in r){const n=sj("opacity",e),i=r.opacity;if(n in r){const a=r[n];Object.assign(t,{opacity:i*a})}else Object.assign(t,{opacity:i})}return t}function o1(r,e){const t=e.length;return Object.keys(r).reduce((n,i)=>{if(i.startsWith(e)){const a=i.slice(t);n[a]=r[i]}return n},{})}function pL(r,e){const t=typeof e=="string"?[e]:e,n={};return Object.keys(r).forEach(i=>{t.find(a=>i.startsWith(a))||(n[i]=r[i])}),n}function Gr(r=0){if(typeof r=="number")return[r,r,r];const[e,t=e,n=e]=r;return[e,t,n]}var Aj=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};function bx(r,e){const{datum:t,graph:n}=e;return typeof r=="function"?r.call(n,t):Object.fromEntries(Object.entries(r).map(([i,a])=>typeof a=="function"?[i,a.call(n,t)]:[i,a]))}function kn(r,e){const t=(r==null?void 0:r.style)||{},n=(e==null?void 0:e.style)||{};for(const i in t)i in n||(n[i]=t[i]);return Object.assign({},r,e,{style:n})}function lj(r){const{x:e,y:t,z:n,class:i,className:a,transform:s,transformOrigin:o,zIndex:A,visibility:l}=r;return Aj(r,["x","y","z","class","className","transform","transformOrigin","zIndex","visibility"])}function cj(r,e){const t=Gr(r);let n={};return e.text&&!e.fontSize&&(n={fontSize:Math.min(...t)*.5}),e.src&&(!e.width||!e.height)&&(n={width:t[0]*.5,height:t[1]*.5}),n}function Ex(r){if(r)return typeof r=="string"||typeof r=="function"||Array.isArray(r)?{type:"group",field:e=>e.id,color:r,invert:!1}:r}function uj(r,e){if(!e)return{};const{type:t,color:n,field:i,invert:a}=e,s=A=>{const l=typeof n=="string"?va("palette",n):n;if(typeof l=="function"){const c={};return A.forEach(([u,h])=>{c[u]=l(a?1-h:h)}),c}else if(Array.isArray(l)){const c=a?[...l].reverse():l,u={};return A.forEach(([h,d])=>{u[h]=c[d%l.length]}),u}return{}},o=(A,l)=>{var c;return typeof A=="string"?(c=l.data)===null||c===void 0?void 0:c[A]:A==null?void 0:A(l)};if(t==="group"){const A=Nh(r,h=>{if(!i)return"default";const d=o(i,h);return d?String(d):"default"}),l=Object.keys(A),c=s(l.map((h,d)=>[h,d])),u={};return Object.entries(A).forEach(([h,d])=>{d.forEach(f=>{u[Z(f)]=c[h]})}),u}else if(t==="value"){const[A,l]=r.reduce(([u,h],d)=>{const f=o(i,d);if(typeof f!="number")throw new Error(ha(`Palette field ${i} is not a number`));return[Math.min(u,f),Math.max(h,f)]},[1/0,-1/0]),c=l-A;return s(r.map(u=>[u.id,(o(i,u)-A)/c]))}}function yL(r){const e=typeof r=="string"?va("palette",r):r;if(typeof e!="function")return e}function mL(r,e){let t=2*r;return typeof e=="string"?t=r*Number(e.replace("%",""))/100:typeof e=="number"&&(t=e),isNaN(t)&&(t=2*r),t}function wL(r,e,t=1,n=!1){const i=n?t:1,a=(r.max[0]-r.min[0])*i;return mL(a,e)}function hj(r,e,t=1){const n=Lt(r[0],r[1])*t;return mL(n,e)}class Ul extends Ol{constructor(e){xx(e.style),super(e),this.shapeMap={},this.animateMap={},this.render(this.attributes,this),this.setVisibility(),this.bindEvents()}get parsedAttributes(){return this.attributes}upsert(e,t,n,i,a){var s,o,A,l,c,u,h,d;const f=this.shapeMap[e];if(n===!1){f&&((s=a==null?void 0:a.beforeDestroy)===null||s===void 0||s.call(a,f),i.removeChild(f),delete this.shapeMap[e],(o=a==null?void 0:a.afterDestroy)===null||o===void 0||o.call(a,f));return}const g=typeof t=="string"?va(Wo.SHAPE,t):t;if(!g)throw new Error(ha(`Shape ${t} not found`));if(!f||f.destroyed||!(f instanceof g)){f&&((A=a==null?void 0:a.beforeDestroy)===null||A===void 0||A.call(a,f),f==null||f.destroy(),(l=a==null?void 0:a.afterDestroy)===null||l===void 0||l.call(a,f)),(c=a==null?void 0:a.beforeCreate)===null||c===void 0||c.call(a);const v=new g({className:e,style:n});return i.appendChild(v),this.shapeMap[e]=v,(u=a==null?void 0:a.afterCreate)===null||u===void 0||u.call(a,v),v}return(h=a==null?void 0:a.beforeUpdate)===null||h===void 0||h.call(a,f),f1(f,n),(d=a==null?void 0:a.afterUpdate)===null||d===void 0||d.call(a,f),f}update(e={}){const t=Object.assign({},this.attributes,e);xx(t),tW(this,t),this.render(t,this),this.setVisibility()}bindEvents(){}getGraphicStyle(e){return lj(e)}get compositeShapes(){return[["badges","badge-"],["ports","port-"]]}animate(e,t){if(e.length===0)return null;const n=[];if(e[0].x!==void 0||e[0].y!==void 0||e[0].z!==void 0){const{x:a=0,y:s=0,z:o=0}=this.attributes;e.forEach(A=>{const{x:l=a,y:c=s,z:u=o}=A;Object.assign(A,{transform:u?[["translate3d",l,c,u]]:[["translate",l,c]]})})}const i=super.animate(e,t);if(i&&(mg(this,i),n.push(i)),Array.isArray(e)&&e.length>0){const a=["transform","transformOrigin","x","y","z","zIndex"];if(Object.keys(e[0]).some(s=>!a.includes(s))){Object.entries(this.shapeMap).forEach(([o,A])=>{const l=`get${qu(o)}Style`,c=this[l];if(Te(c)){const u=e.map(d=>c.call(this,Object.assign(Object.assign({},this.attributes),d))),h=A.animate(s1(u),t);h&&(mg(A,h),n.push(h))}});const s=(o,A)=>{if(!Qi(o)){const l=`get${qu(A)}Style`,c=this[l];if(Te(c)){const u=e.map(h=>c.call(this,Object.assign(Object.assign({},this.attributes),h)));Object.entries(u[0]).map(([h])=>{const d=u.map(g=>g[h]),f=o[h];if(f){const g=f.animate(s1(d),t);g&&(mg(f,g),n.push(g))}})}}};this.compositeShapes.forEach(([o,A])=>{const l=o1(this.shapeMap,A);s(l,o)})}}return fB(n)}getShape(e){return this.shapeMap[e]}setVisibility(){const{visibility:e}=this.attributes;Vs(this,e)}destroy(){this.shapeMap={},this.animateMap={},super.destroy()}}function mg(r,e){e==null||e.finished.then(()=>{const t=r.activeAnimations.findIndex(n=>n===e);t>-1&&r.activeAnimations.splice(t,1)})}function xx(r){if(!r)return{};if("x"in r||"y"in r||"z"in r){const{x:e=0,y:t=0,z:n,transform:i}=r,a=$k(e,t,n,i);a&&(r.transform=a)}return r}var dj=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class ji extends Ul{constructor(e){super(kn({style:ji.defaultStyleProps},e))}isTextStyle(e){return yh(e,"label")}isBackgroundStyle(e){return yh(e,"background")}getTextStyle(e){const t=this.getGraphicStyle(e),{padding:n}=t,i=dj(t,["padding"]);return pL(i,"background")}getBackgroundStyle(e){if(e.background===!1)return!1;const t=this.getGraphicStyle(e),{wordWrap:n,wordWrapWidth:i,padding:a}=t,s=tn(t,"background"),{min:[o,A],center:[l,c],halfExtents:[u,h]}=this.shapeMap.text.getGeometryBounds(),[d,f,g,v]=ai(a),p=u*2+v+f,{width:y,height:m}=s;y&&m?Object.assign(s,{x:l-Number(y)/2,y:c-Number(m)/2}):Object.assign(s,{x:o-v,y:A-d,width:n?Math.min(p,i+v+f):p,height:h*2+d+g});const{radius:B}=s;if(typeof B=="string"&&B.endsWith("%")){const C=Number(B.replace("%",""))/100;s.radius=Math.min(+s.width,+s.height)*C}return s}render(e=this.parsedAttributes,t=this){this.upsert("text",Zs,this.getTextStyle(e),t),this.upsert("background",Vn,this.getBackgroundStyle(e),t)}getGeometryBounds(){return(this.getShape("background")||this.getShape("text")).getGeometryBounds()}}ji.defaultStyleProps={padding:0,fontSize:12,fontFamily:"system-ui, sans-serif",wordWrap:!0,maxLines:1,wordWrapWidth:128,textOverflow:"...",textBaseline:"middle",backgroundOpacity:.75,backgroundZIndex:-1,backgroundLineWidth:0};class Zo extends Ul{constructor(e){super(kn({style:Zo.defaultStyleProps},e))}getBadgeStyle(e){return this.getGraphicStyle(e)}render(e=this.parsedAttributes,t=this){this.upsert("label",ji,this.getBadgeStyle(e),t)}getGeometryBounds(){const e=this.getShape("label");return(e.getShape("background")||e.getShape("text")).getGeometryBounds()}}Zo.defaultStyleProps={padding:[2,4,2,4],fontSize:10,wordWrap:!1,backgroundRadius:"50%",backgroundOpacity:1};function fj(r,e=!0){const t=[];return r.forEach((n,i)=>{t.push([i===0?"M":"L",...n])}),e&&t.push(["Z"]),t}const Cx={M:["x","y"],m:["dx","dy"],H:["x"],h:["dx"],V:["y"],v:["dy"],L:["x","y"],l:["dx","dy"],Z:[],z:[],C:["x1","y1","x2","y2","x","y"],c:["dx1","dy1","dx2","dy2","dx","dy"],S:["x2","y2","x","y"],s:["dx2","dy2","dx","dy"],Q:["x1","y1","x","y"],q:["dx1","dy1","dx","dy"],T:["x","y"],t:["dx","dy"],A:["rx","ry","rotation","large-arc","sweep","x","y"],a:["rx","ry","rotation","large-arc","sweep","dx","dy"]};function gj(r){const e=r.replace(/[\n\r]/g,"").replace(/-/g," -").replace(/(\d*\.)(\d+)(?=\.)/g,"$1$2 ").trim().split(/\s*,|\s+/),t=[];let n="",i={};for(;e.length>0;){let a=e.shift();a in Cx?n=a:e.unshift(a),i={type:n},Cx[n].forEach(A=>{a=e.shift(),i[A]=a}),n==="M"?n="L":n==="m"&&(n="l");const[s,...o]=Object.values(i);t.push([s,...o.map(Number)])}return t}function vj(r){const e=[];return(typeof r=="string"?gj(r):r).forEach(n=>{const i=n[0];if(i==="Z"){e.push(e[0]);return}if(i!=="A")for(let a=1;a<n.length;a=a+2)e.push([n[a],n[a+1],0]);else{const a=n.length;e.push([n[a-2],n[a-1],0])}}),e}const BL=r=>{if(r.length<2)return[["M",0,0],["L",0,0]];const e=r[0],t=r[1],n=r[r.length-1],i=r[r.length-2];r.unshift(i,n),r.push(e,t);const a=[["M",n[0],n[1]]];for(let s=1;s<r.length-2;s+=1){const[o,A]=r[s-1],[l,c]=r[s],[u,h]=r[s+1],[d,f]=s!==r.length-2?r[s+2]:[u,h],g=l+(u-o)/6,v=c+(h-A)/6,p=u-(d-l)/6,y=h-(f-c)/6;a.push(["C",g,v,p,y,u,h])}return a};function pj(r,e,t,n,i,a,s){const[o,A]=Aa(r,e),l={textAlign:e==="left"?"right":e==="right"?"left":"center",textBaseline:e==="top"?"bottom":e==="bottom"?"top":"middle",transform:[["translate",o+t,A+n]]};if(e==="center"||!i)return l;const c=vj(a);if(!c||c.length<=3)return l;const u=c.map((f,g)=>{const v=f,p=c[(g+1)%c.length];return Xt(v,p)?null:[v,p]}).filter(Boolean),h=nj([o,A],u),d=gL([o,A],h);if(d&&h&&(l.transform=[["translate",d[0]+t,d[1]+n]],s)){const f=Math.atan((h[0][1]-h[1][1])/(h[0][0]-h[1][0]));l.transform.push(["rotate",f/Math.PI*180]),l.textAlign="center",(e==="right"||e==="left")&&(f>0?l.textBaseline=e==="right"?"bottom":"top":l.textBaseline=e==="right"?"top":"bottom")}return l}var yj=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class Pl extends Ul{constructor(e){super(kn({style:Pl.defaultStyleProps},e))}getLabelStyle(e){if(!e.label||!e.d||e.d.length===0)return!1;const t=tn(this.getGraphicStyle(e),"label"),{maxWidth:n,offsetX:i,offsetY:a,autoRotate:s,placement:o,closeToPath:A}=t,l=yj(t,["maxWidth","offsetX","offsetY","autoRotate","placement","closeToPath"]),c=this.shapeMap.key,u=c==null?void 0:c.getRenderBounds();return Object.assign(pj(u,o,i,a,A,e.d,s),{wordWrapWidth:wL(u,n)},l)}getKeyStyle(e){return this.getGraphicStyle(e)}render(e,t){this.upsert("key",rr,this.getKeyStyle(e),t),this.upsert("label",ji,this.getLabelStyle(e),t)}}Pl.defaultStyleProps={label:!0,labelPlacement:"bottom",labelCloseToPath:!0,labelAutoRotate:!0,labelOffsetX:0,labelOffsetY:0};function mj(r){const e=[],t=n=>{n!=null&&n.children.length&&n.children.forEach(i=>{e.push(i),t(i)})};return t(r),e}function wj(r){const e=[];let t=r.parentNode;for(;t;)e.push(t),t=t.parentNode;return e}let bB=class extends Il{constructor(e){super(e),this.onMounted=()=>{this.handleRadius()},this.onAttrModified=()=>{this.handleRadius()},Fo=this,this.isMutationObserved=!0,this.addEventListener(it.MOUNTED,this.onMounted),this.addEventListener(it.ATTR_MODIFIED,this.onAttrModified)}handleRadius(){const{radius:e,clipPath:t,width:n=0,height:i=0}=this.attributes;if(e&&n&&i){const[a,s]=this.getBounds().min,o={x:a,y:s,radius:e,width:n,height:i};if(t)Object.assign(this.parsedStyle.clipPath.style,o);else{const A=new Vn({style:o});this.style.clipPath=A}}else t&&(this.style.clipPath=null)}};const A1=new WeakMap;let Fo=null;const EB=r=>{if(Fo&&wj(Fo).includes(r)){const e=A1.get(r);e?e.includes(Fo)||e.push(Fo):A1.set(r,[Fo])}},xB=r=>{const e=A1.get(r);e&&e.forEach(t=>t.handleRadius())};class bL extends Ul{constructor(e){super(e)}isImage(){const{src:e}=this.attributes;return!!e}getIconStyle(e=this.attributes){const{width:t=0,height:n=0}=e,i=this.getGraphicStyle(e);return this.isImage()?Object.assign({x:-t/2,y:-n/2},i):Object.assign({textBaseline:"middle",textAlign:"center"},i)}render(e=this.attributes,t=this){this.upsert("icon",this.isImage()?bB:Zs,this.getIconStyle(e),t)}}class EL extends Ul{get context(){return this.config.context}get parsedAttributes(){return this.attributes}onframe(){}animate(e,t){const n=super.animate(e,t);return n&&(n.onframe=()=>this.onframe(),n.finished.then(()=>this.onframe())),n}}var iu=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class xi extends EL{constructor(e){super(kn({style:xi.defaultStyleProps},e)),this.type="node"}getSize(e=this.attributes){const{size:t}=e;return Gr(t)}getKeyStyle(e){const t=this.getGraphicStyle(e);return Object.assign(pL(t,["label","halo","icon","badge","port"]))}getLabelStyle(e){if(e.label===!1||!e.labelText)return!1;const t=tn(this.getGraphicStyle(e),"label"),{placement:n,maxWidth:i,offsetX:a,offsetY:s}=t,o=iu(t,["placement","maxWidth","offsetX","offsetY"]),A=this.getShape("key").getLocalBounds();return Object.assign(Hx(A,n,a,s),{wordWrapWidth:wL(A,i)},o)}getHaloStyle(e){if(e.halo===!1)return!1;const t=this.getKeyStyle(e),{fill:n}=t,i=iu(t,["fill"]),a=tn(this.getGraphicStyle(e),"halo");return Object.assign(Object.assign(Object.assign({},i),{stroke:n}),a)}getIconStyle(e){if(e.icon===!1||!e.iconText&&!e.iconSrc)return!1;const t=tn(this.getGraphicStyle(e),"icon");return Object.assign(cj(e.size,t),t)}getBadgesStyle(e){var t;const n=o1(this.shapeMap,"badge-"),i={};if(Object.keys(n).forEach(u=>{i[u]=!1}),e.badge===!1||!(!((t=e.badges)===null||t===void 0)&&t.length))return i;const{badges:a=[],badgePalette:s,opacity:o=1}=e,A=iu(e,["badges","badgePalette","opacity"]),l=yL(s),c=tn(this.getGraphicStyle(A),"badge");return a.forEach((u,h)=>{i[h]=Object.assign(Object.assign({backgroundFill:l?l[h%(l==null?void 0:l.length)]:void 0,opacity:o},c),this.getBadgeStyle(u))}),i}getBadgeStyle(e){const t=this.getShape("key"),{placement:n="top",offsetX:i,offsetY:a}=e,s=iu(e,["placement","offsetX","offsetY"]),o=Hx(t.getLocalBounds(),n,i,a,!0);return Object.assign(Object.assign({},o),s)}getPortsStyle(e){var t;const n=this.getPorts(),i={};if(Object.keys(n).forEach(o=>{i[o]=!1}),e.port===!1||!(!((t=e.ports)===null||t===void 0)&&t.length))return i;const a=tn(this.getGraphicStyle(e),"port"),{ports:s=[]}=e;return s.forEach((o,A)=>{const l=o.key||A,c=Object.assign(Object.assign({},a),o);if(HL(c))i[l]=!1;else{const[u,h]=this.getPortXY(e,o);i[l]=Object.assign({transform:[["translate",u,h]]},c)}}),i}getPortXY(e,t){const{placement:n="left"}=t,i=this.getShape("key");return TB(Bj(this.context,i),n)}getPorts(){return o1(this.shapeMap,"port-")}getCenter(){return this.getShape("key").getBounds().center}getIntersectPoint(e,t=!1){const n=this.getShape("key").getBounds();return ej(e,n,t)}drawHaloShape(e,t){const n=this.getHaloStyle(e),i=this.getShape("key");this.upsert("halo",i.constructor,n,t)}drawIconShape(e,t){const n=this.getIconStyle(e);this.upsert("icon",bL,n,t),EB(this)}drawBadgeShapes(e,t){const n=this.getBadgesStyle(e);Object.keys(n).forEach(i=>{const a=n[i];this.upsert(`badge-${i}`,Zo,a,t)})}drawPortShapes(e,t){const n=this.getPortsStyle(e);Object.keys(n).forEach(i=>{const a=n[i],s=`port-${i}`;this.upsert(s,zi,a,t)})}drawLabelShape(e,t){const n=this.getLabelStyle(e);this.upsert("label",ji,n,t)}_drawKeyShape(e,t){return this.drawKeyShape(e,t)}render(e=this.parsedAttributes,t=this){this._drawKeyShape(e,t),this.getShape("key")&&(this.drawHaloShape(e,t),this.drawIconShape(e,t),this.drawBadgeShapes(e,t),this.drawLabelShape(e,t),this.drawPortShapes(e,t))}update(e){super.update(e),e&&("x"in e||"y"in e||"z"in e)&&xB(this)}onframe(){this.drawBadgeShapes(this.parsedAttributes,this),this.drawLabelShape(this.parsedAttributes,this)}}xi.defaultStyleProps={x:0,y:0,size:32,droppable:!0,draggable:!0,port:!0,ports:[],portZIndex:2,portLinkToCenter:!1,badge:!0,badges:[],badgeZIndex:3,halo:!1,haloDroppable:!1,haloLineDash:0,haloLineWidth:12,haloStrokeOpacity:.25,haloPointerEvents:"none",haloZIndex:-1,icon:!0,iconZIndex:1,label:!0,labelIsBillboard:!0,labelMaxWidth:"200%",labelPlacement:"bottom",labelWordWrap:!1,labelZIndex:0};function Bj(r,e){if(!r)return e.getLocalBounds();const t=r.canvas.getLayer(),n=e.cloneNode();Vs(n,"hidden"),t.appendChild(n);const i=n.getLocalBounds();return n.destroy(),i}let Rl=class xL extends xi{constructor(e){super(kn({style:xL.defaultStyleProps},e))}drawKeyShape(e,t){return this.upsert("key",zi,this.getKeyStyle(e),t)}getKeyStyle(e){const t=super.getKeyStyle(e);return Object.assign(Object.assign({},t),{r:Math.min(...this.getSize(e))/2})}getIconStyle(e){const t=super.getIconStyle(e),{r:n}=this.getShape("key").attributes,i=n*2*pa;return t?Object.assign({width:i,height:i},t):!1}getIntersectPoint(e,t=!1){const n=this.getShape("key").getBounds();return td(e,n,t)}};Rl.defaultStyleProps={size:32};class rd extends xi{constructor(e){super(e)}get parsedAttributes(){return this.attributes}drawKeyShape(e,t){return this.upsert("key",Xs,this.getKeyStyle(e),t)}getKeyStyle(e){const t=super.getKeyStyle(e);return Object.assign(Object.assign({},t),{points:this.getPoints(e)})}getIntersectPoint(e,t=!1){var n,i;const{points:a}=this.getShape("key").attributes,s=[+(((n=this.attributes)===null||n===void 0?void 0:n.x)||0),+(((i=this.attributes)===null||i===void 0?void 0:i.y)||0)];return fL(e,s,a,!0,t).point}}class bj extends rd{constructor(e){super(e)}getPoints(e){const[t,n]=this.getSize(e);return eW(t,n)}}var Ej=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class id extends Rl{constructor(e){super(kn({style:id.defaultStyleProps},e))}parseOuterR(){const{size:e}=this.parsedAttributes;return Math.min(...Gr(e))/2}parseInnerR(){const{innerR:e}=this.parsedAttributes;return At(e)?parseInt(e)/100*this.parseOuterR():e}drawDonutShape(e,t){const{donuts:n}=e;if(!(n!=null&&n.length))return;const i=n.map(u=>Be(u)?{value:u}:u),a=tn(this.getGraphicStyle(e),"donut"),s=yL(e.donutPalette);if(!s)return;const o=i.reduce((u,h)=>{var d;return u+((d=h.value)!==null&&d!==void 0?d:0)},0),A=this.parseOuterR(),l=this.parseInnerR();let c=0;i.forEach((u,h)=>{const{value:d=0,color:f=s[h%s.length]}=u,g=Ej(u,["value","color"]),v=(o===0?1/i.length:d/o)*360;this.upsert(`round${h}`,rr,Object.assign(Object.assign(Object.assign({},a),{d:Sj(A,l,c,c+v),fill:f}),g),t),c+=v})}render(e,t=this){super.render(e,t),this.drawDonutShape(e,t)}}id.defaultStyleProps={innerR:"50%",donuts:[],donutPalette:"tableau"};const au=(r,e,t,n)=>[r+Math.sin(n)*t,e-Math.cos(n)*t],xj=(r,e,t,n)=>n<=0||t<=n?[["M",r-t,e],["A",t,t,0,1,1,r+t,e],["A",t,t,0,1,1,r-t,e],["Z"]]:[["M",r-t,e],["A",t,t,0,1,1,r+t,e],["A",t,t,0,1,1,r-t,e],["Z"],["M",r+n,e],["A",n,n,0,1,0,r-n,e],["A",n,n,0,1,0,r+n,e],["Z"]],Cj=(r,e,t,n,i,a)=>{const[s,o]=[i/360*2*Math.PI,a/360*2*Math.PI],A=[au(r,e,n,s),au(r,e,t,s),au(r,e,t,o),au(r,e,n,o)],l=o-s>Math.PI?1:0;return[["M",A[0][0],A[0][1]],["L",A[1][0],A[1][1]],["A",t,t,0,l,1,A[2][0],A[2][1]],["L",A[3][0],A[3][1]],["A",n,n,0,l,0,A[0][0],A[0][1]],["Z"]]},Sj=(r=0,e=0,t,n)=>{const[i,a]=[0,0];return Math.abs(t-n)%360<1e-6?xj(i,a,r,e):Cj(i,a,r,e,t,n)};class ad extends xi{constructor(e){super(kn({style:ad.defaultStyleProps},e))}drawKeyShape(e,t){return this.upsert("key",_l,this.getKeyStyle(e),t)}getKeyStyle(e){const t=super.getKeyStyle(e),[n,i]=this.getSize(e);return Object.assign(Object.assign({},t),{rx:n/2,ry:i/2})}getIconStyle(e){const t=super.getIconStyle(e),{rx:n,ry:i}=this.getShape("key").attributes,a=Math.min(+n,+i)*2*pa;return t?Object.assign({width:a,height:a},t):!1}getIntersectPoint(e,t=!1){const n=this.getShape("key").getBounds();return td(e,n,t)}}ad.defaultStyleProps={size:[45,35]};class Fj extends rd{constructor(e){super(e)}getOuterR(e){return e.outerR||Math.min(...this.getSize(e))/2}getPoints(e){return nW(this.getOuterR(e))}getIconStyle(e){const t=super.getIconStyle(e),n=this.getOuterR(e)*pa;return t?Object.assign({width:n,height:n},t):!1}}function Ii(r,e){if(!{}.hasOwnProperty.call(r,e))throw new TypeError("attempted to use private field on non-instance");return r}var Tj=0;function Mj(r){return"__private_"+Tj+++"_"+r}var on=Mj("renderState"),CL=(function(){function r(e){ue(this,r),this.renderQueue=[],Object.defineProperty(this,on,{writable:!0,value:{restoreStack:[],prevObject:null,currentContext:new Map}}),this.clearFullScreenLastFrame=!1,this.clearFullScreen=!1,this.vpMatrix=xt(),this.dprMatrix=xt(),this.tmpMat4=xt(),this.vec3a=Ze(),this.vec3b=Ze(),this.vec3c=Ze(),this.vec3d=Ze(),this.canvasRendererPluginOptions=e}return he(r,[{key:"apply",value:function(t,n){var i=this;this.context=t;var a=this.context,s=a.config,o=a.camera,A=a.renderingService,l=a.renderingContext,c=a.pathGeneratorFactory,u=s.renderer.getConfig().enableRenderingOptimization;s.renderer.getConfig().enableDirtyCheck=!1,s.renderer.getConfig().enableDirtyRectangleRendering=!1,this.pathGeneratorFactory=c;var h=t.contextService,d=l.root.ownerDocument.defaultView;A.hooks.init.tap(r.tag,function(){var v=h.getDPR(),p=s.width,y=s.height,m=h.getContext();i.clearRect(m,0,0,p*v,y*v,s.background)}),A.hooks.destroy.tap(r.tag,function(){i.renderQueue=[],Ii(i,on)[on]={restoreStack:[],prevObject:null,currentContext:null}});var f=function(){var p,y=h.getContext(),m=h.getDPR(),B=s.width,C=s.height,S=i.canvasRendererPluginOptions,F=S.dirtyObjectNumThreshold,T=S.dirtyObjectRatioThreshold,O=A.getStats(),_=O.total,k=O.rendered,L=k/_;i.clearFullScreen=i.clearFullScreenLastFrame||!((p=d.context.renderingPlugins[1])!==null&&p!==void 0&&p.isFirstTimeRenderingFinished)||A.disableDirtyRectangleRendering()||k>F&&L>T,y&&(typeof y.resetTransform=="function"?y.resetTransform():y.setTransform(1,0,0,1,0,0),i.clearFullScreen&&i.clearRect(y,0,0,B*m,C*m,s.background))},g=function(p,y){for(var m=[p];m.length>0;){var B,C=m.pop();C.isVisible()&&!C.isCulled()&&(u?i.renderDisplayObjectOptimized(C,y,i.context,Ii(i,on)[on],n):i.renderDisplayObject(C,y,i.context,Ii(i,on)[on],n));for(var S=((B=C.sortable)===null||B===void 0||(B=B.sorted)===null||B===void 0?void 0:B.length)>0?C.sortable.sorted:C.childNodes,F=S.length-1;F>=0;F--)m.push(S[F])}};A.hooks.endFrame.tap(r.tag,function(){if(f(),l.root.childNodes.length===0){i.clearFullScreenLastFrame=!0;return}u=s.renderer.getConfig().enableRenderingOptimization,Ii(i,on)[on]={restoreStack:[],prevObject:null,currentContext:Ii(i,on)[on].currentContext},Ii(i,on)[on].currentContext.clear(),i.clearFullScreenLastFrame=!1;var v=h.getContext(),p=h.getDPR();if(bs(i.dprMatrix,[p,p,1]),tr(i.vpMatrix,i.dprMatrix,o.getOrthoMatrix()),i.clearFullScreen)u?(v.save(),g(l.root,v),v.restore()):g(l.root,v);else{var y=i.safeMergeAABB(i.mergeDirtyAABBs(i.renderQueue));if(It.isEmpty(y)){i.renderQueue=[];return}var m=i.convertAABB2Rect(y),B=m.x,C=m.y,S=m.width,F=m.height,T=nr(i.vec3a,[B,C,0],i.vpMatrix),O=nr(i.vec3b,[B+S,C,0],i.vpMatrix),_=nr(i.vec3c,[B,C+F,0],i.vpMatrix),k=nr(i.vec3d,[B+S,C+F,0],i.vpMatrix),L=Math.min(T[0],O[0],k[0],_[0]),U=Math.min(T[1],O[1],k[1],_[1]),G=Math.max(T[0],O[0],k[0],_[0]),W=Math.max(T[1],O[1],k[1],_[1]),V=Math.floor(L),K=Math.floor(U),D=Math.ceil(G-L),X=Math.ceil(W-U);v.save(),i.clearRect(v,V,K,D,X,s.background),v.beginPath(),v.rect(V,K,D,X),v.clip(),v.setTransform(i.vpMatrix[0],i.vpMatrix[1],i.vpMatrix[4],i.vpMatrix[5],i.vpMatrix[12],i.vpMatrix[13]);var te=s.renderer.getConfig(),ie=te.enableDirtyRectangleRenderingDebug;ie&&d.dispatchEvent(new vn(Pr.DIRTY_RECTANGLE,{dirtyRect:{x:V,y:K,width:D,height:X}}));var re=y.getMin(),xe=We(re,2),$=xe[0],z=xe[1],ee=y.getMax(),Ae=We(ee,2),be=Ae[0],Le=Ae[1],Ue=l.root.ownerDocument.elementsFromBBox($,z,be,Le);Ue.sort(function(at,lt){return at.sortable.renderOrder-lt.sortable.renderOrder}).forEach(function(at){at&&at.isVisible()&&!at.isCulled()&&i.renderDisplayObject(at,v,i.context,Ii(i,on)[on],n)}),v.restore(),i.renderQueue.forEach(function(at){i.saveDirtyAABB(at)}),i.renderQueue=[]}Ii(i,on)[on].restoreStack.forEach(function(){v.restore()}),Ii(i,on)[on].restoreStack=[]}),A.hooks.render.tap(r.tag,function(v){i.clearFullScreen||i.renderQueue.push(v)})}},{key:"clearRect",value:function(t,n,i,a,s,o){t.clearRect(n,i,a,s),o&&(t.fillStyle=o,t.fillRect(n,i,a,s))}},{key:"renderDisplayObjectOptimized",value:function(t,n,i,a,s){var o=t.nodeName,A=!1,l=!1,c=this.context.styleRendererFactory[o],u=this.pathGeneratorFactory[o],h=t.parsedStyle.clipPath;if(h){A=!a.prevObject||!gw(h.getWorldTransform(),a.prevObject.getWorldTransform()),A&&(this.applyWorldTransform(n,h),a.prevObject=null);var d=this.pathGeneratorFactory[h.nodeName];d&&(n.save(),l=!0,n.beginPath(),d(n,h.parsedStyle),n.closePath(),n.clip())}if(c){A=!a.prevObject||!gw(t.getWorldTransform(),a.prevObject.getWorldTransform()),A&&this.applyWorldTransform(n,t);var f=!a.prevObject;if(!f){var g=a.prevObject.nodeName;o===ae.TEXT?f=g!==ae.TEXT:o===ae.IMAGE?f=g!==ae.IMAGE:f=g===ae.TEXT||g===ae.IMAGE}c.applyStyleToContext(n,t,f,a),a.prevObject=t}u&&(n.beginPath(),u(n,t.parsedStyle),o!==ae.LINE&&o!==ae.PATH&&o!==ae.POLYLINE&&n.closePath()),c&&c.drawToContext(n,t,Ii(this,on)[on],this,s),l&&n.restore(),t.dirty(!1)}},{key:"renderDisplayObject",value:function(t,n,i,a,s){var o=t.nodeName,A=a.restoreStack[a.restoreStack.length-1];A&&!(t.compareDocumentPosition(A)&Vt.DOCUMENT_POSITION_CONTAINS)&&(n.restore(),a.restoreStack.pop());var l=this.context.styleRendererFactory[o],c=this.pathGeneratorFactory[o],u=t.parsedStyle.clipPath;if(u){this.applyWorldTransform(n,u);var h=this.pathGeneratorFactory[u.nodeName];h&&(n.save(),a.restoreStack.push(t),n.beginPath(),h(n,u.parsedStyle),n.closePath(),n.clip())}l&&(this.applyWorldTransform(n,t),n.save(),this.applyAttributesToContext(n,t)),c&&(n.beginPath(),c(n,t.parsedStyle),o!==ae.LINE&&o!==ae.PATH&&o!==ae.POLYLINE&&n.closePath()),l&&(l.render(n,t.parsedStyle,t,i,this,s),n.restore()),t.dirty(!1)}},{key:"applyAttributesToContext",value:function(t,n){var i=n.parsedStyle,a=i.stroke,s=i.fill,o=i.opacity,A=i.lineDash,l=i.lineDashOffset;A&&t.setLineDash(A),ke(l)||(t.lineDashOffset=l),ke(o)||(t.globalAlpha*=o),!ke(a)&&!Array.isArray(a)&&!a.isNone&&(t.strokeStyle=n.attributes.stroke),!ke(s)&&!Array.isArray(s)&&!s.isNone&&(t.fillStyle=n.attributes.fill)}},{key:"convertAABB2Rect",value:function(t){var n=t.getMin(),i=t.getMax(),a=Math.floor(n[0]),s=Math.floor(n[1]),o=Math.ceil(i[0]),A=Math.ceil(i[1]),l=o-a,c=A-s;return{x:a,y:s,width:l,height:c}}},{key:"mergeDirtyAABBs",value:function(t){var n=new It;return t.forEach(function(i){var a=i.getRenderBounds();n.add(a);var s=i.renderable.dirtyRenderBounds;s&&n.add(s)}),n}},{key:"saveDirtyAABB",value:function(t){var n=t.renderable;n.dirtyRenderBounds||(n.dirtyRenderBounds=new It);var i=t.getRenderBounds();i&&n.dirtyRenderBounds.update(i.center,i.halfExtents)}},{key:"applyWorldTransform",value:function(t,n,i){i?(Go(this.tmpMat4,n.getLocalTransform()),tr(this.tmpMat4,i,this.tmpMat4),tr(this.tmpMat4,this.vpMatrix,this.tmpMat4)):(Go(this.tmpMat4,n.getWorldTransform()),tr(this.tmpMat4,this.vpMatrix,this.tmpMat4)),t.setTransform(this.tmpMat4[0],this.tmpMat4[1],this.tmpMat4[4],this.tmpMat4[5],this.tmpMat4[12],this.tmpMat4[13])}},{key:"safeMergeAABB",value:function(){for(var t=new It,n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return i.forEach(function(s){t.add(s)}),t}}])})();CL.tag="CanvasRenderer";function mh(r,e,t,n,i,a,s){var o,A;if(r.image.nodeName==="rect"){var l=r.image.parsedStyle,c=l.width,u=l.height;A=n.contextService.getDPR();var h=n.config.offscreenCanvas;o=a.offscreenCanvasCreator.getOrCreateCanvas(h),o.width=c*A,o.height=u*A;var d=a.offscreenCanvasCreator.getOrCreateContext(h),f={restoreStack:[],prevObject:null,currentContext:new Map};r.image.forEach(function(v){i.renderDisplayObject(v,d,n,f,a)}),f.restoreStack.forEach(function(){d.restore()})}var g=s.getOrCreatePatternSync(e,r,t,o,A,e.getGeometryBounds().min,function(){e.dirty(),n.renderingService.dirty()});return g}function wh(r,e,t,n){var i;if(r.type===Qa.LinearGradient||r.type===Qa.RadialGradient){var a=e.getGeometryBounds(),s=a&&a.halfExtents[0]*2||1,o=a&&a.halfExtents[1]*2||1,A=a&&a.min||[0,0];i=n.getOrCreateGradient(De(De({type:r.type},r.value),{},{min:A,width:s,height:o}),t)}return i}var su=["shadowBlur","shadowOffsetX","shadowOffsetY"],Sx=["lineCap","lineJoin","miterLimit"],fn={globalAlpha:1,shadowBlur:0,shadowOffsetX:0,shadowOffsetY:0,shadowColor:"#000",filter:"none",globalCompositeOperation:"source-over",strokeStyle:"#000",strokeOpacity:1,lineWidth:1,lineDash:[],lineDashOffset:0,lineCap:"butt",lineJoin:"miter",miterLimit:10,fillStyle:"#000",fillOpacity:1},Fx={};function qt(r,e,t,n){var i=n.has(e)?n.get(e):fn[e];return i!==t&&(e==="lineDash"?r.setLineDash(t):r[e]=t,n.set(e,t)),i}var Oj=(function(){function r(e){ue(this,r),this.imagePool=e}return he(r,[{key:"applyAttributesToContext",value:function(t,n){}},{key:"render",value:function(t,n,i,a,s,o){}},{key:"applyCommonStyleToContext",value:function(t,n,i,a){var s=i?Fx:a.prevObject.parsedStyle,o=n.parsedStyle;(i||o.opacity!==s.opacity)&&qt(t,"globalAlpha",ke(o.opacity)?fn.globalAlpha:o.opacity,a.currentContext),(i||o.blend!==s.blend)&&qt(t,"globalCompositeOperation",ke(o.blend)?fn.globalCompositeOperation:o.blend,a.currentContext)}},{key:"applyStrokeFillStyleToContext",value:function(t,n,i,a){var s=i?Fx:a.prevObject.parsedStyle,o=n.parsedStyle,A=o.lineWidth,l=A===void 0?fn.lineWidth:A,c=o.fill&&!o.fill.isNone,u=o.stroke&&!o.stroke.isNone&&l>0;if(u){if(i||n.attributes.stroke!==a.prevObject.attributes.stroke){var h=!ke(o.stroke)&&!Array.isArray(o.stroke)&&!o.stroke.isNone?n.attributes.stroke:fn.strokeStyle;qt(t,"strokeStyle",h,a.currentContext)}(i||o.lineWidth!==s.lineWidth)&&qt(t,"lineWidth",ke(o.lineWidth)?fn.lineWidth:o.lineWidth,a.currentContext),(i||o.lineDash!==s.lineDash)&&qt(t,"lineDash",o.lineDash||fn.lineDash,a.currentContext),(i||o.lineDashOffset!==s.lineDashOffset)&&qt(t,"lineDashOffset",ke(o.lineDashOffset)?fn.lineDashOffset:o.lineDashOffset,a.currentContext);for(var d=0;d<Sx.length;d++){var f=Sx[d];(i||o[f]!==s[f])&&qt(t,f,ke(o[f])?fn[f]:o[f],a.currentContext)}}if(c&&(i||n.attributes.fill!==a.prevObject.attributes.fill)){var g=!ke(o.fill)&&!Array.isArray(o.fill)&&!o.fill.isNone?n.attributes.fill:fn.fillStyle;qt(t,"fillStyle",g,a.currentContext)}}},{key:"applyStyleToContext",value:function(t,n,i,a){var s=n.nodeName;this.applyCommonStyleToContext(t,n,i,a),s===ae.IMAGE||this.applyStrokeFillStyleToContext(t,n,i,a)}},{key:"applyShadowAndFilterStyleToContext",value:function(t,n,i,a){var s=n.parsedStyle;if(i){qt(t,"shadowColor",s.shadowColor.toString(),a.currentContext);for(var o=0;o<su.length;o++){var A=su[o];qt(t,A,s[A]||fn[A],a.currentContext)}}s.filter&&s.filter.length&&qt(t,"filter",n.attributes.filter,a.currentContext)}},{key:"clearShadowAndFilterStyleForContext",value:function(t,n,i,a){var s=arguments.length>4&&arguments[4]!==void 0?arguments[4]:!1;if(n){qt(t,"shadowColor",fn.shadowColor,a.currentContext);for(var o=0;o<su.length;o++){var A=su[o];qt(t,A,fn[A],a.currentContext)}}if(i)if(n&&s){var l=t.filter;!ke(l)&&l.indexOf("drop-shadow")>-1&&qt(t,"filter",l.replace(/drop-shadow\([^)]*\)/,"").trim()||fn.filter,a.currentContext)}else qt(t,"filter",fn.filter,a.currentContext)}},{key:"fillToContext",value:function(t,n,i,a,s){var o=this,A=n.parsedStyle,l=A.fill,c=A.fillRule,u=null;if(Array.isArray(l)&&l.length>0)l.forEach(function(d){var f=qt(t,"fillStyle",wh(d,n,t,o.imagePool),i.currentContext);u=u??f,c?t.fill(c):t.fill()});else{if(Gs(l)){var h=mh(l,n,t,n.ownerDocument.defaultView.context,a,s,this.imagePool);h&&(t.fillStyle=h,u=!0)}c?t.fill(c):t.fill()}u!==null&&qt(t,"fillStyle",u,i.currentContext)}},{key:"strokeToContext",value:function(t,n,i,a,s){var o=this,A=n.parsedStyle.stroke,l=null;if(Array.isArray(A)&&A.length>0)A.forEach(function(h){var d=qt(t,"strokeStyle",wh(h,n,t,o.imagePool),i.currentContext);l=l??d,t.stroke()});else{if(Gs(A)){var c=mh(A,n,t,n.ownerDocument.defaultView.context,a,s,this.imagePool);if(c){var u=qt(t,"strokeStyle",c,i.currentContext);l=l??u}}t.stroke()}l!==null&&qt(t,"strokeStyle",l,i.currentContext)}},{key:"drawToContext",value:function(t,n,i,a,s){var o,A=n.nodeName,l=n.parsedStyle,c=l.opacity,u=c===void 0?fn.globalAlpha:c,h=l.fillOpacity,d=h===void 0?fn.fillOpacity:h,f=l.strokeOpacity,g=f===void 0?fn.strokeOpacity:f,v=l.lineWidth,p=v===void 0?fn.lineWidth:v,y=l.fill&&!l.fill.isNone,m=l.stroke&&!l.stroke.isNone&&p>0;if(!(!y&&!m)){var B=!ke(l.shadowColor)&&l.shadowBlur>0,C=l.shadowType==="inner",S=((o=l.fill)===null||o===void 0?void 0:o.alpha)===0,F=!!(l.filter&&l.filter.length),T=B&&m&&(A===ae.PATH||A===ae.LINE||A===ae.POLYLINE||S||C),O=null;if(y){T||this.applyShadowAndFilterStyleToContext(t,n,B,i);var _=u*d;O=qt(t,"globalAlpha",_,i.currentContext),this.fillToContext(t,n,i,a,s),T||this.clearShadowAndFilterStyleForContext(t,B,F,i)}if(m){var k=!1,L=u*g,U=qt(t,"globalAlpha",L,i.currentContext);if(O=y?O:U,T&&(this.applyShadowAndFilterStyleToContext(t,n,B,i),k=!0,C)){var G=t.globalCompositeOperation;t.globalCompositeOperation="source-atop",this.strokeToContext(t,n,i,a,s),t.globalCompositeOperation=G,this.clearShadowAndFilterStyleForContext(t,B,F,i,!0)}this.strokeToContext(t,n,i,a,s),k&&this.clearShadowAndFilterStyleForContext(t,B,F,i)}O!==null&&qt(t,"globalAlpha",O,i.currentContext)}}}])})(),CB=(function(r){function e(){return ue(this,e),qe(this,e,arguments)}return $e(e,r),he(e,[{key:"render",value:function(n,i,a,s,o,A){var l=i.fill,c=i.fillRule,u=i.opacity,h=u===void 0?1:u,d=i.fillOpacity,f=d===void 0?1:d,g=i.stroke,v=i.strokeOpacity,p=v===void 0?1:v,y=i.lineWidth,m=y===void 0?1:y,B=i.lineCap,C=i.lineJoin,S=i.shadowType,F=i.shadowColor,T=i.shadowBlur,O=i.filter,_=i.miterLimit,k=l&&!l.isNone,L=g&&!g.isNone&&m>0,U=(l==null?void 0:l.alpha)===0,G=!!(O&&O.length),W=!ke(F)&&T>0,V=a.nodeName,K=S==="inner",D=L&&W&&(V===ae.PATH||V===ae.LINE||V===ae.POLYLINE||U||K);k&&(n.globalAlpha=h*f,D||Bh(a,n,W),SL(n,a,l,c,s,o,A,this.imagePool),D||this.clearShadowAndFilter(n,G,W)),L&&(n.globalAlpha=h*p,n.lineWidth=m,ke(_)||(n.miterLimit=_),ke(B)||(n.lineCap=B),ke(C)||(n.lineJoin=C),D&&(K&&(n.globalCompositeOperation="source-atop"),Bh(a,n,!0),K&&(l1(n,a,g,s,o,A,this.imagePool),n.globalCompositeOperation=fn.globalCompositeOperation,this.clearShadowAndFilter(n,G,!0))),l1(n,a,g,s,o,A,this.imagePool))}},{key:"clearShadowAndFilter",value:function(n,i,a){if(a&&(n.shadowColor="transparent",n.shadowBlur=0),i){var s=n.filter;!ke(s)&&s.indexOf("drop-shadow")>-1&&(n.filter=s.replace(/drop-shadow\([^)]*\)/,"").trim()||"none")}}}])})(Oj);function Bh(r,e,t){var n=r.parsedStyle,i=n.filter,a=n.shadowColor,s=n.shadowBlur,o=n.shadowOffsetX,A=n.shadowOffsetY;i&&i.length&&(e.filter=r.style.filter),t&&(e.shadowColor=a.toString(),e.shadowBlur=s||0,e.shadowOffsetX=o||0,e.shadowOffsetY=A||0)}function SL(r,e,t,n,i,a,s,o){var A=arguments.length>8&&arguments[8]!==void 0?arguments[8]:!1;Array.isArray(t)?t.forEach(function(l){r.fillStyle=wh(l,e,r,o),A||(n?r.fill(n):r.fill())}):(Gs(t)&&(r.fillStyle=mh(t,e,r,i,a,s,o)),A||(n?r.fill(n):r.fill()))}function l1(r,e,t,n,i,a,s){var o=arguments.length>7&&arguments[7]!==void 0?arguments[7]:!1;Array.isArray(t)?t.forEach(function(A){r.strokeStyle=wh(A,e,r,s),o||r.stroke()}):(Gs(t)&&(r.strokeStyle=mh(t,e,r,n,i,a,s)),o||r.stroke())}function _j(r,e){var t=We(r,4),n=t[0],i=t[1],a=t[2],s=t[3],o=We(e,4),A=o[0],l=o[1],c=o[2],u=o[3],h=Math.max(n,A),d=Math.max(i,l),f=Math.min(n+a,A+c),g=Math.min(i+s,l+u);return f<=h||g<=d?null:[h,d,f-h,g-d]}function Ij(r,e){var t=nr(Ze(),[r[0],r[1],0],e),n=nr(Ze(),[r[0]+r[2],r[1],0],e),i=nr(Ze(),[r[0],r[1]+r[3],0],e),a=nr(Ze(),[r[0]+r[2],r[1]+r[3],0],e);return[Math.min(t[0],n[0],i[0],a[0]),Math.min(t[1],n[1],i[1],a[1]),Math.max(t[0],n[0],i[0],a[0])-Math.min(t[0],n[0],i[0],a[0]),Math.max(t[1],n[1],i[1],a[1])-Math.min(t[1],n[1],i[1],a[1])]}var kj=(function(r){function e(){return ue(this,e),qe(this,e,arguments)}return $e(e,r),he(e,[{key:"renderDownSampled",value:function(n,i,a,s){var o=s.src,A=s.imageCache;if(!A.downSampled){this.imagePool.createDownSampledImage(o,a).then(function(){a.ownerDocument&&(a.dirty(),a.ownerDocument.defaultView.context.renderingService.dirty())}).catch(function(l){console.error(l)});return}n.drawImage(A.downSampled,Math.floor(s.drawRect[0]),Math.floor(s.drawRect[1]),Math.ceil(s.drawRect[2]),Math.ceil(s.drawRect[3]))}},{key:"renderTile",value:function(n,i,a,s){var o=s.src,A=s.imageCache,l=s.imageRect,c=s.drawRect,u=A.size,h=n.getTransform(),d=h.a,f=h.b,g=h.c,v=h.d,p=h.e,y=h.f;if(n.resetTransform(),!(A!=null&&A.gridSize)){this.imagePool.createImageTiles(o,[],function(){a.ownerDocument&&(a.dirty(),a.ownerDocument.defaultView.context.renderingService.dirty())},a).catch(function(W){console.error(W)});return}for(var m=[u[0]/l[2],u[1]/l[3]],B=[A.tileSize[0]/m[0],A.tileSize[1]/m[1]],C=[Math.floor((c[0]-l[0])/B[0]),Math.ceil((c[0]+c[2]-l[0])/B[0])],S=C[0],F=C[1],T=[Math.floor((c[1]-l[1])/B[1]),Math.ceil((c[1]+c[3]-l[1])/B[1])],O=T[0],_=T[1],k=O;k<=_;k++)for(var L=S;L<=F;L++){var U=A.tiles[k][L];if(U){var G=[Math.floor(l[0]+U.tileX*B[0]),Math.floor(l[1]+U.tileY*B[1]),Math.ceil(B[0]),Math.ceil(B[1])];n.drawImage(U.data,G[0],G[1],G[2],G[3])}}n.setTransform(d,f,g,v,p,y)}},{key:"render",value:function(n,i,a){var s=i.x,o=s===void 0?0:s,A=i.y,l=A===void 0?0:A,c=i.width,u=i.height,h=i.src,d=i.shadowColor,f=i.shadowBlur,g=this.imagePool.getImageSync(h,a),v=g==null?void 0:g.img,p=c,y=u;if(v){p||(p=v.width),y||(y=v.height);var m=!ke(d)&&f>0;Bh(a,n,m);try{var B=a.ownerDocument.defaultView.getContextService().getDomElement(),C=B.width,S=B.height,F=n.getTransform(),T=F.a,O=F.b,_=F.c,k=F.d,L=F.e,U=F.f,G=w_(T,_,0,0,O,k,0,0,0,0,1,0,L,U,0,1),W=Ij([o,l,p,y],G),V=_j([0,0,C,S],W);if(!V)return;if(!a.ownerDocument.defaultView.getConfig().enableLargeImageOptimization){e.renderFull(n,i,a,{image:v,drawRect:[o,l,p,y]});return}var K=W[2]/g.size[0];if(K<(g.downSamplingRate||.5)){this.renderDownSampled(n,i,a,{src:h,imageCache:g,drawRect:[o,l,p,y]});return}if(!ImagePool.isSupportTile){e.renderFull(n,i,a,{image:v,drawRect:[o,l,p,y]});return}this.renderTile(n,i,a,{src:h,imageCache:g,imageRect:W,drawRect:V})}catch{}}}},{key:"drawToContext",value:function(n,i,a,s,o){this.render(n,i.parsedStyle,i)}}],[{key:"renderFull",value:function(n,i,a,s){n.drawImage(s.image,Math.floor(s.drawRect[0]),Math.floor(s.drawRect[1]),Math.ceil(s.drawRect[2]),Math.ceil(s.drawRect[3]))}}])})(CB),Lj=(function(r){function e(){return ue(this,e),qe(this,e,arguments)}return $e(e,r),he(e,[{key:"render",value:function(n,i,a,s,o,A){a.getBounds();var l=i.lineWidth,c=l===void 0?1:l,u=i.textAlign,h=u===void 0?"start":u,d=i.textBaseline,f=d===void 0?"alphabetic":d,g=i.lineJoin,v=g===void 0?"miter":g,p=i.miterLimit,y=p===void 0?10:p,m=i.letterSpacing,B=m===void 0?0:m,C=i.stroke,S=i.fill,F=i.fillRule,T=i.fillOpacity,O=T===void 0?1:T,_=i.strokeOpacity,k=_===void 0?1:_,L=i.opacity,U=L===void 0?1:L,G=i.metrics,W=i.x,V=W===void 0?0:W,K=i.y,D=K===void 0?0:K,X=i.dx,te=i.dy,ie=i.shadowColor,re=i.shadowBlur,xe=i.textDecorationLine,$=G.font,z=G.lines,ee=G.height,Ae=G.lineHeight,be=G.lineMetrics;n.font=$,n.lineWidth=c,n.textAlign=h==="middle"?"center":h;var Le=f;Le==="alphabetic"&&(Le="bottom"),n.lineJoin=v,ke(y)||(n.miterLimit=y);var Ue=D;f==="middle"?Ue+=-ee/2-Ae/2:f==="bottom"||f==="alphabetic"||f==="ideographic"?Ue+=-ee:(f==="top"||f==="hanging")&&(Ue+=-Ae);var at=V+(X||0);Ue+=te||0,z.length===1&&(Le==="bottom"?(Le="middle",Ue-=.5*ee):Le==="top"&&(Le="middle",Ue+=.5*ee)),n.textBaseline=Le;var lt=!ke(ie)&&re>0;Bh(a,n,lt);for(var ct=0;ct<z.length;ct++){var pt=c/2+at;Ue+=Ae,!ke(C)&&!C.isNone&&c&&this.drawLetterSpacing(n,a,z[ct],be[ct],h,pt,Ue,B,S,F,O,C,k,U,!0,s,o,A),ke(S)||this.drawLetterSpacing(n,a,z[ct],be[ct],h,pt,Ue,B,S,F,O,C,k,U,!1,s,o,A)}xe&&xe!=="none"&&this.drawTextDecorations(n,i,a,z,Ae,at,D+(te||0),s,o,A)}},{key:"drawLetterSpacing",value:function(n,i,a,s,o,A,l,c,u,h,d,f,g,v,p,y,m,B){if(c===0){p?this.strokeText(n,i,a,A,l,f,g,y,m,B):this.fillText(n,i,a,A,l,u,h,d,v,y,m,B);return}var C=n.textAlign;n.textAlign="left";var S=A;o==="center"||o==="middle"?S=A-s.width/2:(o==="right"||o==="end")&&(S=A-s.width);for(var F=Array.from(a),T=n.measureText(a).width,O=0,_=0;_<F.length;++_){var k=F[_];p?this.strokeText(n,i,k,S,l,f,g,y,m,B):this.fillText(n,i,k,S,l,u,h,d,v,y,m,B),O=n.measureText(a.substring(_+1)).width,S+=T-O+c,T=O}n.textAlign=C}},{key:"fillText",value:function(n,i,a,s,o,A,l,c,u,h,d,f){SL(n,i,A,l,h,d,f,this.imagePool,!0);var g,v=!ke(c)&&c!==1;v&&(g=n.globalAlpha,n.globalAlpha=c*u),n.fillText(a,s,o),v&&(n.globalAlpha=g)}},{key:"strokeText",value:function(n,i,a,s,o,A,l,c,u,h){l1(n,i,A,c,u,h,this.imagePool,!0);var d,f=!ke(l)&&l!==1;f&&(d=n.globalAlpha,n.globalAlpha=l),n.strokeText(a,s,o),f&&(n.globalAlpha=d)}},{key:"drawTextDecorations",value:function(n,i,a,s,o,A,l,c,u,h){var d=i.textDecorationLine,f=i.textDecorationColor,g=i.textDecorationStyle,v=i.textDecorationThickness,p=v===void 0?1:v,y=i.textAlign,m=y===void 0?"start":y,B=i.lineWidth,C=B===void 0?1:B,S=i.metrics;if(!(!d||d==="none")){var F=S.lineMetrics,T=d.split(" ");switch(n.lineWidth=p,f&&(n.strokeStyle="rgba(".concat(f.r,", ").concat(f.g,", ").concat(f.b,", ").concat(f.alpha,")")),g){case"dashed":n.setLineDash([5,5]);break;case"dotted":n.setLineDash([2,2]);break;case"wavy":n.setLineDash([]);break;default:n.setLineDash([]);break}var O=l,_=i.textBaseline,k=_===void 0?"alphabetic":_;k==="middle"?O+=-S.height/2-o/2:k==="bottom"||k==="alphabetic"||k==="ideographic"?O+=-S.height:(k==="top"||k==="hanging")&&(O+=-o);for(var L=0;L<s.length;L++){O+=o;var U=F[L];if(U){var G=C/2,W=A,V=A+U.width;m==="center"||m==="middle"?(W=A-U.width/2,V=A+U.width/2):(m==="right"||m==="end")&&(W=A-U.width,V=A),W+=G,V+=G;var K=ka(T),D;try{for(K.s();!(D=K.n()).done;){var X=D.value,te=O;switch(X){case"underline":te+=2;break;case"overline":te-=o-2;break;case"line-through":te-=o/2;break;default:continue}g==="wavy"?this.drawWavyLine(n,W,V,te):(n.beginPath(),n.moveTo(W,te),n.lineTo(V,te),n.stroke())}}catch(ie){K.e(ie)}finally{K.f()}}}n.setLineDash([])}}},{key:"drawWavyLine",value:function(n,i,a,s){var o=2,A=10,l=Math.floor((a-i)/A);n.beginPath(),n.moveTo(i,s);for(var c=0;c<l;c++){var u=i+c*A+A/4,h=s+o,d=i+c*A+A/2,f=s;n.quadraticCurveTo(u,h,d,f);var g=i+c*A+A*3/4,v=s-o,p=i+(c+1)*A,y=s;n.quadraticCurveTo(g,v,p,y)}n.stroke()}},{key:"drawToContext",value:function(n,i,a,s,o){this.render(n,i.parsedStyle,i,i.ownerDocument.defaultView.context,s,o)}}])})(CB),Qj=(function(r){function e(){var t,n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return ue(this,e),t=qe(this,e),t.name="canvas-renderer",t.options=n,t}return $e(e,r),he(e,[{key:"init",value:function(){var n,i=De({dirtyObjectNumThreshold:500,dirtyObjectRatioThreshold:.8},this.options),a=this.context.imagePool,s=new CB(a),o=(n={},Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(n,ae.CIRCLE,s),ae.ELLIPSE,s),ae.RECT,s),ae.IMAGE,new kj(a)),ae.TEXT,new Lj(a)),ae.LINE,s),ae.POLYLINE,s),ae.POLYGON,s),ae.PATH,s),ae.GROUP,void 0),Ee(Ee(Ee(n,ae.HTML,void 0),ae.MESH,void 0),ae.FRAGMENT,void 0));this.context.defaultStyleRendererFactory=o,this.context.styleRendererFactory=o,this.addRenderingPlugin(new CL(i))}},{key:"destroy",value:function(){this.removeAllRenderingPlugins(),delete this.context.defaultStyleRendererFactory,delete this.context.styleRendererFactory}}])})(rs),Nj=Ze(),Uj=Ze(),Pj=Ze(),Rj=xt(),FL=(function(){function r(){var e=this;ue(this,r),this.isHit=function(t,n,i,a){var s=e.context.pointInPathPickerFactory[t.nodeName];if(s){var o=Ni(Rj,i),A=nr(Uj,er(Pj,n[0],n[1],0),o);if(s(t,new Dn(A[0],A[1]),a,e.isPointInPath,e.context,e.runtime))return!0}return!1},this.isPointInPath=function(t,n){var i=e.runtime.offscreenCanvasCreator.getOrCreateContext(e.context.config.offscreenCanvas),a=e.context.pathGeneratorFactory[t.nodeName];return a&&(i.beginPath(),a(i,t.parsedStyle),i.closePath()),i.isPointInPath(n.x,n.y)}}return he(r,[{key:"apply",value:function(t,n){var i,a=this,s=t.renderingService,o=t.renderingContext;this.context=t,this.runtime=n;var A=(i=o.root)===null||i===void 0?void 0:i.ownerDocument;s.hooks.pick.tapPromise(r.tag,(function(){var l=Ja(Gn().mark(function c(u){return Gn().wrap(function(h){for(;;)switch(h.prev=h.next){case 0:return h.abrupt("return",a.pick(A,u));case 1:case"end":return h.stop()}},c)}));return function(c){return l.apply(this,arguments)}})()),s.hooks.pickSync.tap(r.tag,function(l){return a.pick(A,l)})}},{key:"pick",value:function(t,n){var i=n.topmost,a=n.position,s=a.x,o=a.y,A=er(Nj,s,o,0),l=t.elementsFromBBox(A[0],A[1],A[0],A[1]),c=[],u=ka(l),h;try{for(u.s();!(h=u.n()).done;){var d=h.value,f=d.getWorldTransform(),g=this.isHit(d,A,f,!1);if(g){var v=xI(d);if(v){var p=v.parsedStyle.clipPath,y=this.isHit(p,A,p.getWorldTransform(),!0);if(y){if(i)return n.picked=[d],n;c.push(d)}}else{if(i)return n.picked=[d],n;c.push(d)}}}}catch(m){u.e(m)}finally{u.f()}return n.picked=c,n}}])})();FL.tag="CanvasPicker";function Dj(r,e,t){var n=r.parsedStyle,i=n.cx,a=i===void 0?0:i,s=n.cy,o=s===void 0?0:s,A=n.r,l=n.fill,c=n.stroke,u=n.lineWidth,h=u===void 0?1:u,d=n.increasedLineWidthForHitTesting,f=d===void 0?0:d,g=n.pointerEvents,v=g===void 0?"auto":g,p=(h+f)/2,y=da(a,o,e.x,e.y),m=$s(v,l,c),B=We(m,2),C=B[0],S=B[1];return C&&S||t?y<=A+p:C?y<=A:S?y>=A-p&&y<=A+p:!1}function ou(r,e,t,n){return r/(t*t)+e/(n*n)}function Hj(r,e,t){var n=r.parsedStyle,i=n.cx,a=i===void 0?0:i,s=n.cy,o=s===void 0?0:s,A=n.rx,l=n.ry,c=n.fill,u=n.stroke,h=n.lineWidth,d=h===void 0?1:h,f=n.increasedLineWidthForHitTesting,g=f===void 0?0:f,v=n.pointerEvents,p=v===void 0?"auto":v,y=e.x,m=e.y,B=$s(p,c,u),C=We(B,2),S=C[0],F=C[1],T=(d+g)/2,O=(y-a)*(y-a),_=(m-o)*(m-o);return S&&F||t?ou(O,_,A+T,l+T)<=1:S?ou(O,_,A,l)<=1:F?ou(O,_,A-T,l-T)>=1&&ou(O,_,A+T,l+T)<=1:!1}function Ms(r,e,t,n,i,a){return i>=r&&i<=r+t&&a>=e&&a<=e+n}function Gj(r,e,t,n,i,a,s){var o=i/2;return Ms(r-o,e-o,t,i,a,s)||Ms(r+t-o,e-o,i,n,a,s)||Ms(r+o,e+n-o,t,i,a,s)||Ms(r-o,e+o,i,n,a,s)}function Au(r,e,t,n,i,a,s,o){var A=(Math.atan2(o-e,s-r)+Math.PI*2)%(Math.PI*2),l={x:r+t*Math.cos(A),y:e+t*Math.sin(A)};return da(l.x,l.y,s,o)<=a/2}function Ha(r,e,t,n,i,a,s){var o=Math.min(r,t),A=Math.max(r,t),l=Math.min(e,n),c=Math.max(e,n),u=i/2;return a>=o-u&&a<=A+u&&s>=l-u&&s<=c+u?fD(r,e,t,n,a,s)<=i/2:!1}function TL(r,e,t,n,i){var a=r.length;if(a<2)return!1;for(var s=0;s<a-1;s++){var o=r[s][0],A=r[s][1],l=r[s+1][0],c=r[s+1][1];if(Ha(o,A,l,c,e,t,n))return!0}if(i){var u=r[0],h=r[a-1];if(Ha(u[0],u[1],h[0],h[1],e,t,n))return!0}return!1}var Kj=1e-6;function wg(r){return Math.abs(r)<Kj?0:r<0?-1:1}function zj(r,e,t){return(t[0]-r[0])*(e[1]-r[1])===(e[0]-r[0])*(t[1]-r[1])&&Math.min(r[0],e[0])<=t[0]&&t[0]<=Math.max(r[0],e[0])&&Math.min(r[1],e[1])<=t[1]&&t[1]<=Math.max(r[1],e[1])}function ML(r,e,t){var n=!1,i=r.length;if(i<=2)return!1;for(var a=0;a<i;a++){var s=r[a],o=r[(a+1)%i];if(zj(s,o,[e,t]))return!0;wg(s[1]-t)>0!=wg(o[1]-t)>0&&wg(e-(t-s[1])*(s[0]-o[0])/(s[1]-o[1])-s[0])<0&&(n=!n)}return n}function Tx(r,e,t){for(var n=!1,i=0;i<r.length;i++){var a=r[i];if(n=ML(a,e,t),n)break}return n}function Vj(r,e,t){var n=r.parsedStyle,i=n.x1,a=n.y1,s=n.x2,o=n.y2,A=n.lineWidth,l=A===void 0?1:A,c=n.increasedLineWidthForHitTesting,u=c===void 0?0:c,h=n.pointerEvents,d=h===void 0?"auto":h,f=n.fill,g=n.stroke,v=$s(d,f,g),p=We(v,2),y=p[1];return!y&&!t||!l?!1:Ha(i,a,s,o,l+u,e.x,e.y)}function jj(r,e,t,n,i){for(var a=!1,s=e/2,o=0;o<r.length;o++){var A=r[o],l=A.currentPoint,c=A.params,u=A.prePoint,h=A.box;if(!(h&&!Ms(h.x-s,h.y-s,h.width+e,h.height+e,t,n)))switch(A.command){case"L":case"Z":if(a=Ha(u[0],u[1],l[0],l[1],e,t,n),a)return!0;break;case"Q":var d=BD(u[0],u[1],c[1],c[2],c[3],c[4],t,n);if(a=d<=e/2,a)return!0;break;case"C":var f=_b(u[0],u[1],c[1],c[2],c[3],c[4],c[5],c[6],t,n,i);if(a=f<=e/2,a)return!0;break;case"A":A.cubicParams||(A.cubicParams=j1(u[0],u[1],c[1],c[2],c[3],c[4],c[5],c[6],c[7],void 0));for(var g=A.cubicParams,v=u,p=0;p<g.length;p+=6){var y=_b(v[0],v[1],g[p],g[p+1],g[p+2],g[p+3],g[p+4],g[p+5],t,n,i);if(v=[g[p+4],g[p+5]],a=y<=e/2,a)return!0}break}}return a}function Wj(r,e,t,n,i,a){var s=r.parsedStyle,o=s.lineWidth,A=o===void 0?1:o,l=s.increasedLineWidthForHitTesting,c=l===void 0?0:l,u=s.stroke,h=s.fill,d=s.d,f=s.pointerEvents,g=f===void 0?"auto":f,v=d.segments,p=d.hasArc,y=d.polylines,m=d.polygons,B=$s(g,(m==null?void 0:m.length)&&h,u),C=We(B,2),S=C[0],F=C[1],T=kw(r),O=!1;return S||t?(p?O=n(r,e):O=Tx(m,e.x,e.y)||Tx(y,e.x,e.y),O):((F||t)&&(O=jj(v,A+c,e.x,e.y,T)),O)}function qj(r,e,t){var n=r.parsedStyle,i=n.stroke,a=n.fill,s=n.lineWidth,o=s===void 0?1:s,A=n.increasedLineWidthForHitTesting,l=A===void 0?0:A,c=n.points,u=n.pointerEvents,h=u===void 0?"auto":u,d=$s(h,a,i),f=We(d,2),g=f[0],v=f[1],p=!1;return(v||t)&&(p=TL(c.points,o+l,e.x,e.y,!0)),!p&&(g||t)&&(p=ML(c.points,e.x,e.y)),p}function $j(r,e,t){var n=r.parsedStyle,i=n.lineWidth,a=i===void 0?1:i,s=n.increasedLineWidthForHitTesting,o=s===void 0?0:s,A=n.points,l=n.pointerEvents,c=l===void 0?"auto":l,u=n.fill,h=n.stroke,d=$s(c,u,h),f=We(d,2),g=f[1];return!g&&!t||!a?!1:TL(A.points,a+o,e.x,e.y,!1)}function Yj(r,e,t,n,i){var a=r.parsedStyle,s=a.radius,o=a.fill,A=a.stroke,l=a.lineWidth,c=l===void 0?1:l,u=a.increasedLineWidthForHitTesting,h=u===void 0?0:u,d=a.x,f=d===void 0?0:d,g=a.y,v=g===void 0?0:g,p=a.width,y=a.height,m=a.pointerEvents,B=m===void 0?"auto":m,C=$s(B,o,A),S=We(C,2),F=S[0],T=S[1],O=s&&s.some(function(U){return U!==0}),_=c+h;if(O){var L=!1;return(T||t)&&(L=Xj(f,v,p,y,s.map(function(U){return Yt(U,0,Math.min(Math.abs(p)/2,Math.abs(y)/2))}),_,e.x,e.y)),!L&&(F||t)&&(L=n(r,e)),L}else{var k=_/2;if(F&&T||t)return Ms(f-k,v-k,p+k,y+k,e.x,e.y);if(F)return Ms(f,v,p,y,e.x,e.y);if(T)return Gj(f,v,p,y,_,e.x,e.y)}return!1}function Xj(r,e,t,n,i,a,s,o){var A=We(i,4),l=A[0],c=A[1],u=A[2],h=A[3];return Ha(r+l,e,r+t-c,e,a,s,o)||Ha(r+t,e+c,r+t,e+n-u,a,s,o)||Ha(r+t-u,e+n,r+h,e+n,a,s,o)||Ha(r,e+n-h,r,e+l,a,s,o)||Au(r+t-c,e+c,c,1.5*Math.PI,2*Math.PI,a,s,o)||Au(r+t-u,e+n-u,u,0,.5*Math.PI,a,s,o)||Au(r+h,e+n-h,h,.5*Math.PI,Math.PI,a,s,o)||Au(r+l,e+l,l,Math.PI,1.5*Math.PI,a,s,o)}function Zj(r,e,t,n,i,a){var s=r.parsedStyle,o=s.pointerEvents,A=o===void 0?"auto":o,l=s.x,c=l===void 0?0:l,u=s.y,h=u===void 0?0:u,d=s.width,f=s.height;if(A==="non-transparent-pixel"){var g=i.config.offscreenCanvas,v=a.offscreenCanvasCreator.getOrCreateCanvas(g),p=a.offscreenCanvasCreator.getOrCreateContext(g,{willReadFrequently:!0});v.width=d,v.height=f,i.defaultStyleRendererFactory[ae.IMAGE].render(p,De(De({},r.parsedStyle),{},{x:0,y:0}),r,void 0,void 0,void 0);var y=p.getImageData(e.x-c,e.y-h,1,1).data;return y.every(function(m){return m!==0})}return!0}function Jj(r,e,t,n){var i=r.getGeometryBounds();return e.x>=i.min[0]&&e.y>=i.min[1]&&e.x<=i.max[0]&&e.y<=i.max[1]}var e9=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.name="canvas-picker",t}return $e(e,r),he(e,[{key:"init",value:function(){var n,i=(n={},Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(n,ae.CIRCLE,Dj),ae.ELLIPSE,Hj),ae.RECT,Yj),ae.LINE,Vj),ae.POLYLINE,$j),ae.POLYGON,qj),ae.PATH,Wj),ae.TEXT,Jj),ae.GROUP,null),ae.IMAGE,Zj),Ee(Ee(n,ae.HTML,null),ae.MESH,null));this.context.pointInPathPickerFactory=i,this.addRenderingPlugin(new FL)}},{key:"destroy",value:function(){delete this.context.pointInPathPickerFactory,this.removeAllRenderingPlugins()}}])})(rs);function t9(r,e){var t=e.cx,n=t===void 0?0:t,i=e.cy,a=i===void 0?0:i,s=e.r;r.arc(n,a,s,0,Math.PI*2,!1)}function n9(r,e){var t=e.cx,n=t===void 0?0:t,i=e.cy,a=i===void 0?0:i,s=e.rx,o=e.ry;if(r.ellipse)r.ellipse(n,a,s,o,0,0,Math.PI*2,!1);else{var A=s>o?s:o,l=s>o?1:s/o,c=s>o?o/s:1;r.save(),r.scale(l,c),r.arc(n,a,A,0,Math.PI*2)}}function r9(r,e){var t=e.x1,n=e.y1,i=e.x2,a=e.y2,s=e.markerStart,o=e.markerEnd,A=e.markerStartOffset,l=e.markerEndOffset,c=0,u=0,h=0,d=0,f=0,g,v;s&&ut(s)&&A&&(g=i-t,v=a-n,f=Math.atan2(v,g),c=Math.cos(f)*(A||0),u=Math.sin(f)*(A||0)),o&&ut(o)&&l&&(g=t-i,v=n-a,f=Math.atan2(v,g),h=Math.cos(f)*(l||0),d=Math.sin(f)*(l||0)),r.moveTo(t+c,n+u),r.lineTo(i+h,a+d)}function i9(r,e){var t=e.markerStart,n=e.markerEnd,i=e.markerStartOffset,a=e.markerEndOffset,s=e.d,o=s.absolutePath,A=s.segments,l=0,c=0,u=0,h=0,d=0,f,g;if(t&&ut(t)&&i){var v=t.parentNode.getStartTangent(),p=We(v,2),y=p[0],m=p[1];f=y[0]-m[0],g=y[1]-m[1],d=Math.atan2(g,f),l=Math.cos(d)*(i||0),c=Math.sin(d)*(i||0)}if(n&&ut(n)&&a){var B=n.parentNode.getEndTangent(),C=We(B,2),S=C[0],F=C[1];f=S[0]-F[0],g=S[1]-F[1],d=Math.atan2(g,f),u=Math.cos(d)*(a||0),h=Math.sin(d)*(a||0)}for(var T=0;T<o.length;T++){var O=o[T],_=O[0],k=o[T+1],L=T===0&&(l!==0||c!==0),U=(T===o.length-1||k&&(k[0]==="M"||k[0]==="Z"))&&u!==0&&h!==0,G=L?[l,c]:[0,0],W=We(G,2),V=W[0],K=W[1],D=U?[u,h]:[0,0],X=We(D,2),te=X[0],ie=X[1];switch(_){case"M":r.moveTo(O[1]+V,O[2]+K);break;case"L":r.lineTo(O[1]+te,O[2]+ie);break;case"Q":r.quadraticCurveTo(O[1],O[2],O[3]+te,O[4]+ie);break;case"C":r.bezierCurveTo(O[1],O[2],O[3],O[4],O[5]+te,O[6]+ie);break;case"A":{var re=A[T].arcParams,xe=re.cx,$=re.cy,z=re.rx,ee=re.ry,Ae=re.startAngle,be=re.endAngle,Le=re.xRotation,Ue=re.sweepFlag;if(r.ellipse)r.ellipse(xe,$,z,ee,Le,Ae,be,!!(1-Ue));else{var at=z>ee?z:ee,lt=z>ee?1:z/ee,ct=z>ee?ee/z:1;r.translate(xe,$),r.rotate(Le),r.scale(lt,ct),r.arc(0,0,at,Ae,be,!!(1-Ue)),r.scale(1/lt,1/ct),r.rotate(-Le),r.translate(-xe,-$)}U&&r.lineTo(O[6]+u,O[7]+h);break}case"Z":r.closePath();break}}}function a9(r,e){var t=e.markerStart,n=e.markerEnd,i=e.markerStartOffset,a=e.markerEndOffset,s=e.points.points,o=s.length,A=s[0][0],l=s[0][1],c=s[o-1][0],u=s[o-1][1],h=0,d=0,f=0,g=0,v=0,p,y;t&&ut(t)&&i&&(p=s[1][0]-s[0][0],y=s[1][1]-s[0][1],v=Math.atan2(y,p),h=Math.cos(v)*(i||0),d=Math.sin(v)*(i||0)),n&&ut(n)&&a&&(p=s[o-1][0]-s[0][0],y=s[o-1][1]-s[0][1],v=Math.atan2(y,p),f=Math.cos(v)*(a||0),g=Math.sin(v)*(a||0)),r.moveTo(A+(h||f),l+(d||g));for(var m=1;m<o-1;m++){var B=s[m];r.lineTo(B[0],B[1])}r.lineTo(c,u)}function s9(r,e){var t=e.markerStart,n=e.markerEnd,i=e.markerStartOffset,a=e.markerEndOffset,s=e.points.points,o=s.length,A=s[0][0],l=s[0][1],c=s[o-1][0],u=s[o-1][1],h=0,d=0,f=0,g=0,v=0,p,y;t&&ut(t)&&i&&(p=s[1][0]-s[0][0],y=s[1][1]-s[0][1],v=Math.atan2(y,p),h=Math.cos(v)*(i||0),d=Math.sin(v)*(i||0)),n&&ut(n)&&a&&(p=s[o-2][0]-s[o-1][0],y=s[o-2][1]-s[o-1][1],v=Math.atan2(y,p),f=Math.cos(v)*(a||0),g=Math.sin(v)*(a||0)),r.moveTo(A+h,l+d);for(var m=1;m<o-1;m++){var B=s[m];r.lineTo(B[0],B[1])}r.lineTo(c+f,u+g)}function o9(r,e){var t=e.x,n=t===void 0?0:t,i=e.y,a=i===void 0?0:i,s=e.radius,o=e.width,A=e.height,l=o,c=A,u=s&&s.some(function(C){return C!==0});if(!u)r.rect(n,a,l,c);else{var h=o>0?1:-1,d=A>0?1:-1,f=h+d===0,g=s.map(function(C){return Yt(C,0,Math.min(Math.abs(l)/2,Math.abs(c)/2))}),v=We(g,4),p=v[0],y=v[1],m=v[2],B=v[3];r.moveTo(h*p+n,a),r.lineTo(l-h*y+n,a),y!==0&&r.arc(l-h*y+n,d*y+a,y,-d*Math.PI/2,h>0?0:Math.PI,f),r.lineTo(l+n,c-d*m+a),m!==0&&r.arc(l-h*m+n,c-d*m+a,m,h>0?0:Math.PI,d>0?Math.PI/2:1.5*Math.PI,f),r.lineTo(h*B+n,c+a),B!==0&&r.arc(h*B+n,c-d*B+a,B,d>0?Math.PI/2:-Math.PI/2,h>0?Math.PI:0,f),r.lineTo(n,d*p+a),p!==0&&r.arc(h*p+n,d*p+a,p,h>0?Math.PI:0,d>0?Math.PI*1.5:Math.PI/2,f)}}var A9=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.name="canvas-path-generator",t}return $e(e,r),he(e,[{key:"init",value:function(){var n,i=(n={},Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(Ee(n,ae.CIRCLE,t9),ae.ELLIPSE,n9),ae.RECT,o9),ae.LINE,r9),ae.POLYLINE,s9),ae.POLYGON,a9),ae.PATH,i9),ae.TEXT,void 0),ae.GROUP,void 0),ae.IMAGE,void 0),Ee(Ee(Ee(n,ae.HTML,void 0),ae.MESH,void 0),ae.FRAGMENT,void 0));this.context.pathGeneratorFactory=i}},{key:"destroy",value:function(){delete this.context.pathGeneratorFactory}}])})(rs),l9=(function(){function r(e){ue(this,r),this.renderingContext=e.renderingContext,this.canvasConfig=e.config}return he(r,[{key:"init",value:function(){var t=this.canvasConfig,n=t.container,i=t.canvas;if(i)this.$canvas=i,n&&i.parentElement!==n&&n.appendChild(i),this.$container=i.parentElement,this.canvasConfig.container=this.$container;else if(n&&(this.$container=At(n)?document.getElementById(n):n,this.$container)){var a=document.createElement("canvas");this.$container.appendChild(a),this.$container.style.position||(this.$container.style.position="relative"),this.$canvas=a}this.context=this.$canvas.getContext("2d"),this.resize(this.canvasConfig.width,this.canvasConfig.height)}},{key:"getContext",value:function(){return this.context}},{key:"getDomElement",value:function(){return this.$canvas}},{key:"getDPR",value:function(){return this.dpr}},{key:"getBoundingClientRect",value:function(){if(this.$canvas.getBoundingClientRect)return this.$canvas.getBoundingClientRect()}},{key:"destroy",value:function(){this.$container&&this.$canvas&&this.$canvas.parentNode&&this.$container.removeChild(this.$canvas)}},{key:"resize",value:function(t,n){var i=this.canvasConfig.devicePixelRatio;this.dpr=i,this.$canvas&&(this.$canvas.width=this.dpr*t,this.$canvas.height=this.dpr*n,S4(this.$canvas,t,n)),this.renderingContext.renderReasons.add(Po.CAMERA_CHANGED)}},{key:"applyCursorStyle",value:function(t){this.$container&&this.$container.style&&(this.$container.style.cursor=t)}},{key:"toDataURL",value:(function(){var e=Ja(Gn().mark(function n(){var i,a,s,o=arguments;return Gn().wrap(function(A){for(;;)switch(A.prev=A.next){case 0:return i=o.length>0&&o[0]!==void 0?o[0]:{},a=i.type,s=i.encoderOptions,A.abrupt("return",this.context.canvas.toDataURL(a,s));case 1:case"end":return A.stop()}},n,this)}));function t(){return e.apply(this,arguments)}return t})()}])})(),c9=(function(r){function e(){var t;ue(this,e);for(var n=arguments.length,i=new Array(n),a=0;a<n;a++)i[a]=arguments[a];return t=qe(this,e,[].concat(i)),t.name="canvas-context-register",t}return $e(e,r),he(e,[{key:"init",value:function(){this.context.ContextService=l9}},{key:"destroy",value:function(){delete this.context.ContextService}}])})(rs),vl=(function(r){function e(t){var n;return ue(this,e),n=qe(this,e,[t]),n.registerPlugin(new c9),n.registerPlugin(new n6.Plugin),n.registerPlugin(new A9),n.registerPlugin(new Qj),n.registerPlugin(new o6.Plugin),n.registerPlugin(new e9),n.registerPlugin(new a6.Plugin),n}return $e(e,r),he(e)})(ED),u9=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class sd extends xi{constructor(e){super(Object.assign(Object.assign({},e),{style:Object.assign({},sd.defaultStyleProps,e.style)})),this.rootPointerEvent=new ih(null),this.forwardEvents=t=>{const n=this.context.canvas,i=n.context.renderingContext.root.ownerDocument.defaultView;this.normalizeToPointerEvent(t,i).forEach(s=>{const o=this.bootstrapEvent(this.rootPointerEvent,s,i,t);ol(n.context.eventService,"mappingTable.pointerupoutside",[]),n.context.eventService.mapEvent(o)})}}get eventService(){return this.context.canvas.context.eventService}get events(){return[se.CLICK,se.POINTER_DOWN,se.POINTER_MOVE,se.POINTER_UP,se.POINTER_OVER,se.POINTER_LEAVE]}getDomElement(){return this.getShape("key").getDomElement()}render(e=this.parsedAttributes,t=this){this.drawKeyShape(e,t),this.drawPortShapes(e,t)}getKeyStyle(e){const t=Ds(e,["dx","dy","innerHTML","pointerEvents","cursor"]),{dx:n=0,dy:i=0}=t,a=u9(t,["dx","dy"]),[s,o]=this.getSize(e);return Object.assign(Object.assign({x:n,y:i},a),{width:s,height:o})}drawKeyShape(e,t){const n=this.getKeyStyle(e),{x:i,y:a,width:s=0,height:o=0}=n,A=this.upsert("key-container",Vn,{x:i,y:a,width:s,height:o,opacity:0},t);return this.upsert("key",Ys,n,A)}connectedCallback(){if(!(this.context.canvas.getRenderer("main")instanceof vl))return;const n=this.getDomElement();this.events.forEach(i=>{n.addEventListener(i,this.forwardEvents)})}attributeChangedCallback(e,t,n){e==="zIndex"&&t!==n&&(this.getDomElement().style.zIndex=n)}destroy(){const e=this.getDomElement();this.events.forEach(t=>{e.removeEventListener(t,this.forwardEvents)}),super.destroy()}normalizeToPointerEvent(e,t){const n=[];if(t.isTouchEvent(e))for(let i=0;i<e.changedTouches.length;i++){const a=e.changedTouches[i];He(a.button)&&(a.button=0),He(a.buttons)&&(a.buttons=1),He(a.isPrimary)&&(a.isPrimary=e.touches.length===1&&e.type==="touchstart"),He(a.width)&&(a.width=a.radiusX||1),He(a.height)&&(a.height=a.radiusY||1),He(a.tiltX)&&(a.tiltX=0),He(a.tiltY)&&(a.tiltY=0),He(a.pointerType)&&(a.pointerType="touch"),He(a.pointerId)&&(a.pointerId=a.identifier||0),He(a.pressure)&&(a.pressure=a.force||.5),He(a.twist)&&(a.twist=0),He(a.tangentialPressure)&&(a.tangentialPressure=0),a.isNormalized=!0,a.type=e.type,n.push(a)}else if(t.isMouseEvent(e)){const i=e;He(i.isPrimary)&&(i.isPrimary=!0),He(i.width)&&(i.width=1),He(i.height)&&(i.height=1),He(i.tiltX)&&(i.tiltX=0),He(i.tiltY)&&(i.tiltY=0),He(i.pointerType)&&(i.pointerType="mouse"),He(i.pointerId)&&(i.pointerId=1),He(i.pressure)&&(i.pressure=.5),He(i.twist)&&(i.twist=0),He(i.tangentialPressure)&&(i.tangentialPressure=0),i.isNormalized=!0,n.push(i)}else n.push(e);return n}transferMouseData(e,t){e.isTrusted=t.isTrusted,e.srcElement=t.srcElement,e.timeStamp=performance.now(),e.type=t.type,e.altKey=t.altKey,e.metaKey=t.metaKey,e.shiftKey=t.shiftKey,e.ctrlKey=t.ctrlKey,e.button=t.button,e.buttons=t.buttons,e.client.x=t.clientX,e.client.y=t.clientY,e.movement.x=t.movementX,e.movement.y=t.movementY,e.page.x=t.pageX,e.page.y=t.pageY,e.screen.x=t.screenX,e.screen.y=t.screenY,e.relatedTarget=null}bootstrapEvent(e,t,n,i){e.view=n,e.originalEvent=null,e.nativeEvent=i,e.pointerId=t.pointerId,e.width=t.width,e.height=t.height,e.isPrimary=t.isPrimary,e.pointerType=t.pointerType,e.pressure=t.pressure,e.tangentialPressure=t.tangentialPressure,e.tiltX=t.tiltX,e.tiltY=t.tiltY,e.twist=t.twist,this.transferMouseData(e,t);const{x:a,y:s}=this.getViewportXY(t);e.viewport.x=a,e.viewport.y=s;const[o,A]=this.context.canvas.getCanvasByViewport([a,s]);return e.canvas.x=o,e.canvas.y=A,e.global.copyFrom(e.canvas),e.offset.copyFrom(e.canvas),e.isTrusted=i.isTrusted,e.type==="pointerleave"&&(e.type="pointerout"),e}getViewportXY(e){let t,n;const{offsetX:i,offsetY:a,clientX:s,clientY:o}=e;if(!ke(i)&&!ke(a))t=i,n=a;else{const A=this.eventService.client2Viewport({x:s,y:o});t=A.x,n=A.y}return{x:t,y:n}}onframe(){super.onframe();const{opacity:e}=this.attributes;this.getDomElement().style.opacity=`${e}`}}sd.defaultStyleProps={size:[160,80],halo:!1,icon:!1,label:!1,pointerEvents:"auto"};var Mx=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};let OL=class _L extends xi{constructor(e){super(kn({style:_L.defaultStyleProps},e))}getKeyStyle(e){const[t,n]=this.getSize(e),i=super.getKeyStyle(e),{fillOpacity:a,opacity:s=a}=i,o=Mx(i,["fillOpacity","opacity"]);return Object.assign(Object.assign({opacity:s},o),{width:t,height:n,x:-t/2,y:-n/2})}getBounds(){return this.getShape("key").getBounds()}getHaloStyle(e){if(e.halo===!1)return!1;const t=this.getShape("key").attributes,{fill:n,stroke:i}=t;Mx(t,["fill","stroke"]);const a=tn(this.getGraphicStyle(e),"halo"),s=Number(a.lineWidth),[o,A]=Ve(this.getSize(e),[s,s]),{lineWidth:l}=a,c={fill:"transparent",lineWidth:l/2,width:o-l/2,height:A-l/2,x:-(o-l/2)/2,y:-(A-l/2)/2};return Object.assign(Object.assign({},a),c)}getIconStyle(e){const t=super.getIconStyle(e),[n,i]=this.getSize(e);return t?Object.assign({width:n*pa,height:i*pa},t):!1}drawKeyShape(e,t){const n=this.upsert("key",bB,this.getKeyStyle(e),t);return EB(this),n}drawHaloShape(e,t){this.upsert("halo",Vn,this.getHaloStyle(e),t)}update(e){super.update(e),e&&("x"in e||"y"in e||"z"in e)&&xB(this)}};OL.defaultStyleProps={size:32};class h9 extends xi{constructor(e){super(e)}getKeyStyle(e){const[t,n]=this.getSize(e);return Object.assign(Object.assign({},super.getKeyStyle(e)),{width:t,height:n,x:-t/2,y:-n/2})}getIconStyle(e){const t=super.getIconStyle(e),{width:n,height:i}=this.getShape("key").attributes;return t?Object.assign({width:n*pa,height:i*pa},t):!1}drawKeyShape(e,t){return this.upsert("key",Vn,this.getKeyStyle(e),t)}}class d9 extends rd{constructor(e){super(e)}getInnerR(e){return e.innerR||this.getOuterR(e)*3/8}getOuterR(e){return Math.min(...this.getSize(e))/2}getPoints(e){return Y9(this.getOuterR(e),this.getInnerR(e))}getIconStyle(e){const t=super.getIconStyle(e),n=this.getInnerR(e)*2*pa;return t?Object.assign({width:n,height:n},t):!1}getPortXY(e,t){const{placement:n="top"}=t,i=this.getShape("key").getLocalBounds(),a=X9(this.getOuterR(e),this.getInnerR(e));return TB(i,n,a,!1)}}class od extends rd{constructor(e){super(kn({style:od.defaultStyleProps},e))}getPoints(e){const{direction:t}=e,[n,i]=this.getSize(e);return Z9(n,i,t)}getPortXY(e,t){const{direction:n}=e,{placement:i="top"}=t,a=this.getShape("key").getLocalBounds(),[s,o]=this.getSize(e),A=J9(s,o,n);return TB(a,i,A,!1)}getIconStyle(e){const{icon:t,iconText:n,iconSrc:i,direction:a}=e;if(t===!1||Qi(n||i))return!1;const s=tn(this.getGraphicStyle(e),"icon"),o=this.getShape("key").getLocalBounds(),[A,l]=bV(o,a),c=EV(o,a)*2*pa;return Object.assign({x:A,y:l,width:c,height:c},s)}}od.defaultStyleProps={size:40,direction:"up"};var Ox=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class Jo extends xi{constructor(e){super(kn({style:Jo.defaultStyleProps},e)),this.type="combo",this.updateComboPosition(this.parsedAttributes)}getKeySize(e){const{collapsed:t,childrenNode:n=[]}=e;return n.length===0?this.getEmptyKeySize(e):t?this.getCollapsedKeySize(e):this.getExpandedKeySize(e)}getEmptyKeySize(e){const{padding:t,collapsedSize:n}=e,[i,a,s,o]=ai(t);return Ve(Gr(n),[o+a,i+s,0])}getCollapsedKeySize(e){return Gr(e.collapsedSize)}getExpandedKeySize(e){const t=this.getContentBBox(e);return[Yi(t),Xi(t),0]}getContentBBox(e){const{childrenNode:t=[],padding:n}=e,i=t.map(s=>this.context.element.getElement(s)).filter(Boolean);if(i.length===0){const s=new It,{x:o=0,y:A=0,size:l}=e,[c,u]=Gr(l);return s.setMinMax([o-c/2,A-u/2,0],[o+c/2,A+u/2,0]),s}const a=Ql(i.map(s=>s.getBounds()));return n?as(a,n):a}drawCollapsedMarkerShape(e,t){const n=this.getCollapsedMarkerStyle(e);this.upsert("collapsed-marker",bL,n,t),EB(this)}getCollapsedMarkerStyle(e){if(!e.collapsed||!e.collapsedMarker)return!1;const t=tn(this.getGraphicStyle(e),"collapsedMarker"),{type:n}=t,i=Ox(t,["type"]),a=this.getShape("key"),[s,o]=Aa(a.getLocalBounds(),"center"),A=Object.assign(Object.assign({},i),{x:s,y:o});if(n){const l=this.getCollapsedMarkerText(n,e);Object.assign(A,{text:l})}return A}getCollapsedMarkerText(e,t){const{childrenData:n=[]}=t,{model:i}=this.context;return e==="descendant-count"?i.getDescendantsData(this.id).length.toString():e==="child-count"?n.length.toString():e==="node-count"?i.getDescendantsData(this.id).filter(a=>i.getElementType(Z(a))==="node").length.toString():Te(e)?e(n):""}getComboPosition(e){const{x:t=0,y:n=0,collapsed:i,childrenData:a=[]}=e;if(a.length===0)return[+t,+n,0];if(i){const{model:s}=this.context,o=s.getDescendantsData(this.id).filter(A=>!s.isCombo(Z(A)));if(o.length>0&&o.some($V)){const A=o.reduce((l,c)=>Ve(l,Sn(c)),[0,0,0]);return Bi(A,o.length)}return[+t,+n,0]}return this.getContentBBox(e).center}getComboStyle(e){const[t,n]=this.getComboPosition(e);return{x:t,y:n,transform:[["translate",t,n]]}}updateComboPosition(e){const t=this.getComboStyle(e);Object.assign(this.style,t);const{x:n,y:i}=t;this.context.model.syncNodeLikeDatum({id:this.id,style:{x:n,y:i}}),xB(this)}render(e,t=this){super.render(e,t),this.drawCollapsedMarkerShape(e,t)}update(e={}){super.update(e),this.updateComboPosition(this.parsedAttributes)}onframe(){super.onframe(),this.attributes.collapsed||this.updateComboPosition(this.parsedAttributes),this.drawKeyShape(this.parsedAttributes,this)}animate(e,t){const n=super.animate(this.attributes.collapsed?e:e.map(i=>{var{x:a,y:s,z:o,transform:A}=i,l=Ox(i,["x","y","z","transform"]);return l}),t);return n&&new Proxy(n,{set:(i,a,s)=>(a==="currentTime"&&Promise.resolve().then(()=>this.onframe()),Reflect.set(i,a,s))})}}Jo.defaultStyleProps={childrenNode:[],droppable:!0,draggable:!0,collapsed:!1,collapsedSize:32,collapsedMarker:!0,collapsedMarkerZIndex:1,collapsedMarkerFontSize:12,collapsedMarkerTextAlign:"center",collapsedMarkerTextBaseline:"middle",collapsedMarkerType:"child-count"};class f9 extends Jo{constructor(e){super(e)}drawKeyShape(e,t){return this.upsert("key",zi,this.getKeyStyle(e),t)}getKeyStyle(e){const{collapsed:t}=e,n=super.getKeyStyle(e),[i]=this.getKeySize(e);return Object.assign(Object.assign(Object.assign({},n),t&&tn(n,"collapsed")),{r:i/2})}getCollapsedKeySize(e){const[t,n]=Gr(e.collapsedSize),i=Math.max(t,n)/2;return[i*2,i*2,0]}getExpandedKeySize(e){const t=this.getContentBBox(e),[n,i]=is(t),a=Math.sqrt(Math.pow(n,2)+Math.pow(i,2))/2;return[a*2,a*2,0]}getIntersectPoint(e,t=!1){const n=this.getShape("key").getBounds();return td(e,n,t)}}class g9 extends Jo{constructor(e){super(e)}drawKeyShape(e,t){return this.upsert("key",Vn,this.getKeyStyle(e),t)}getKeyStyle(e){const t=super.getKeyStyle(e),[n,i]=this.getKeySize(e);return Object.assign(Object.assign(Object.assign({},t),e.collapsed&&tn(t,"collapsed")),{width:n,height:i,x:-n/2,y:-i/2})}}const v9={padding:10};function _x(r,e,t,n,i,a){const{padding:s}=Object.assign(v9,a),o=Ra(t,s),A=Ra(n,s),l=[r,...i,e];let c=null;const u=[];for(let h=0,d=l.length;h<d-1;h++){const f=h+1,g=l[h],v=l[f],p=ZV(g,v);let y=null;if(h===0)if(f===d-1)if(o.intersects(A))y=Bg(g,v,o,A);else if(!gh(g,o)&&!gh(v,A)){const m=Qs(g,o),B=Qs(v,A);y=kx(m,B,hr(m,B)),y.points.unshift(m),y.points.push(B)}else p||(y=y9(g,v,o,A));else wi(v,o)?y=Bg(g,v,o,Ra(v,s),c):p||(y=_u(g,v,o));else f===d-1?wi(g,A)?y=Bg(g,v,Ra(g,s),A,c):p||(y=IL(g,v,A,c)):p||(y=kx(g,v,c));y?(u.push(...y.points),c=y.direction):c=hr(g,v),f<d-1&&u.push(v)}return u.map(js)}const p9={N:"S",S:"N",W:"E",E:"W"},Ix={N:-Math.PI/2,S:Math.PI/2,E:0,W:Math.PI};function hr(r,e){const[t,n]=r,[i,a]=e;return t===i?n>a?"N":"S":n===a?t>i?"W":"E":null}function c1(r,e){return e==="N"||e==="S"?Xi(r):Yi(r)}function kx(r,e,t){const n=[r[0],e[1]],i=[e[0],r[1]],a=hr(r,n),s=hr(r,i),o=t?p9[t]:null,A=a===t||a!==o&&s!==t?n:i;return{points:[A],direction:hr(A,e)}}function _u(r,e,t){if(gh(r,t)){const n=pl(r,e,t);return{points:[n],direction:hr(n,e)}}else{const n=Qs(r,t),a=["left","right"].includes(tl(r,t))?[e[0],n[1]]:[n[0],e[1]];return{points:[a],direction:hr(a,e)}}}function IL(r,e,t,n){const i=gh(e,t)?e:Qs(e,t),a=[[i[0],r[1]],[r[0],i[1]]],s=a.filter(A=>BV(A,t)&&!Jk(A,t,!0)),o=s.filter(A=>hr(A,r)!==n);if(o.length>0){const A=o.find(l=>hr(r,l)===n)||o[0];return{points:[A],direction:hr(A,e)}}else{const A=aR(a,s)[0],l=$a(e,A,c1(t,n)/2);return{points:[pl(l,r,t),l],direction:hr(l,e)}}}function y9(r,e,t,n){let i=_u(r,e,t);const a=gl(i.points[0]);if(wi(a,n)){i=_u(e,r,n);const s=gl(i.points[0]);if(wi(s,t)){const o=$a(r,a,c1(t,hr(r,a))/2),A=$a(e,s,c1(n,hr(e,s))/2),l=[(o[0]+A[0])/2,(o[1]+A[1])/2],c=_u(r,l,t),u=IL(l,e,n,c.direction);i.points=[c.points[0],u.points[0]],i.direction=u.direction}}return i}function Bg(r,e,t,n,i){const s=Ql([t,n]),o=Lt(e,s.center)>Lt(r,s.center),[A,l]=o?[e,r]:[r,e],c=Xi(s)+Yi(s);let u;if(i){const f=[A[0]+c*Math.cos(Ix[i]),A[1]+c*Math.sin(Ix[i])];u=$a(Qs(f,s),f,.01)}else u=$a(Qs(A,s),A,-.01);let h=pl(u,l,s),d=[xA(u,2),xA(h,2)];if(Xt(xA(u),xA(h))){const f=mB(bt(u,A),[1,0,0])+Math.PI/2;h=[l[0]+c*Math.cos(f),l[1]+c*Math.sin(f),0],h=xA($a(Qs(h,s),l,-.01),2);const g=pl(u,h,s);d=[u,g,h]}return{points:o?d.reverse():d,direction:hr(o?u:h,e)}}function pl(r,e,t){let n=[r[0],e[1]];return wi(n,t)&&(n=[e[0],r[1]]),n}function kL(r,e,t,n,i){let A=typeof e=="number"?e:.5;e==="start"&&(A=0),e==="end"&&(A=.99);const l=Hn(r.getPoint(A)),c=Hn(r.getPoint(A+.01));let u=e==="start"?"left":e==="end"?"right":"center";if(uL(l,c)||!t){const[p,y]=Lx(r,A,n,i);return{transform:[["translate",p,y]],textAlign:u}}let h=Math.atan2(c[1]-l[1],c[0]-l[0]);c[0]<l[0]&&(u=u==="center"?u:u==="left"?"right":"left",n*=-1,h+=Math.PI);const[f,g]=Lx(r,A,n,i,h),v=[["translate",f,g],["rotate",h/Math.PI*180]];return{textAlign:u,transform:v}}function m9(r,e,t,n,i){var a,s;const o=((a=r.badge)===null||a===void 0?void 0:a.getGeometryBounds().halfExtents[0])*2||0,A=((s=r.label)===null||s===void 0?void 0:s.getGeometryBounds().halfExtents[0])*2||0;return kL(r.key,t,!0,(A?(A/2+o/2)*(e==="suffix"?1:-1):0)+n,i)}function Lx(r,e,t,n,i){const[a,s]=Hn(r.getPoint(e));let o=t,A=n;return i&&(o=t*Math.cos(i)-n*Math.sin(i),A=t*Math.sin(i)+n*Math.cos(i)),[a+o,s+A]}function u1(r,e,t,n){if(Xt(r,e))return r;const i=bt(e,r),a=[r[0]+t*i[0],r[1]+t*i[1]],s=fa(ed(i,!1));return a[0]+=n*s[0],a[1]+=n*s[1],a}function w9(r){return Be(r)?[r,-r]:r}function B9(r){return Be(r)?[r,1-r]:r}function b9(r,e,t){return[["M",r[0],r[1]],["Q",t[0],t[1],e[0],e[1]]]}function LL(r,e,t){return[["M",r[0],r[1]],["C",t[0][0],t[0][1],t[1][0],t[1][1],e[0],e[1]]]}function SB(r,e=0,t=!1){const n=r.length-1,i=r[0],a=r[n],s=r.slice(1,n),o=[["M",i[0],i[1]]];return s.forEach((A,l)=>{const c=s[l-1]||i,u=s[l+1]||a;if(!hL(c,A,u)&&e){const[h,d]=E9(c,A,u,e);o.push(["L",h[0],h[1]],["Q",A[0],A[1],d[0],d[1]],["L",d[0],d[1]])}else o.push(["L",A[0],A[1]])}),o.push(["L",a[0],a[1]]),t&&o.push(["Z"]),o}function E9(r,e,t,n){const i=vh(r,e),a=vh(t,e),s=Math.min(n,Math.min(i,a)/2),o=[e[0]-s/i*(e[0]-r[0]),e[1]-s/i*(e[1]-r[1])],A=[e[0]-s/a*(e[0]-t[0]),e[1]-s/a*(e[1]-t[1])];return[o,A]}const x9=r=>{const e=Math.PI/2,t=Xi(r)/2,n=Yi(r)/2,i=Math.atan2(t,n)/2,a=Math.atan2(n,t)/2;return{top:[-e-a,-e+a],"top-right":[-e+a,-i],"right-top":[-e+a,-i],right:[-i,i],"bottom-right":[i,e-a],"right-bottom":[i,e-a],bottom:[e-a,e+a],"bottom-left":[e+a,Math.PI-i],"left-bottom":[e+a,Math.PI-i],left:[Math.PI-i,Math.PI+i],"top-left":[Math.PI+i,-e-a],"left-top":[Math.PI+i,-e-a]}};function QL(r,e,t,n,i){const a=Ra(r),s=r.getCenter();let o=n&&ts(n),A=i&&ts(i);if(!o||!A){const l=x9(a),c=l[e][0],u=l[e][1],[h,d]=is(a),f=Math.max(h,d),g=Ve(s,[f*Math.cos(c),f*Math.sin(c),0]),v=Ve(s,[f*Math.cos(u),f*Math.sin(u),0]);o=d1(r,g),A=d1(r,v),t||([o,A]=[A,o])}return[o,A]}function C9(r,e,t,n,i,a){const s=r.getPorts()[i||a],o=r.getPorts()[a||i];let[A,l]=QL(r,e,t,s,o);const c=S9(r,A,l,n);return s&&(A=yl(s,c[0])),o&&(l=yl(o,c.at(-1))),LL(A,l,c)}function S9(r,e,t,n){const i=r.getCenter();if(Xt(e,t)){const a=bt(e,i),s=[n*Math.sign(a[0])||n/2,n*Math.sign(a[1])||-n/2,0];return[Ve(e,s),Ve(t,vi(s,[1,-1,1]))]}return[$a(i,e,Lt(i,e)+n),$a(i,t,Lt(i,t)+n)]}function F9(r,e,t,n,i,a,s){const o=MB(r),A=o[a||s],l=o[s||a];let[c,u]=QL(r,t,n,A,l);const h=T9(r,c,u,i);return A&&(c=yl(A,h[0])),l&&(u=yl(l,h.at(-1))),SB([c,...h,u],e)}function T9(r,e,t,n){const i=[],a=Ra(r);if(Xt(e,t))switch(tl(e,a)){case"left":i.push([e[0]-n,e[1]]),i.push([e[0]-n,e[1]+n]),i.push([e[0],e[1]+n]);break;case"right":i.push([e[0]+n,e[1]]),i.push([e[0]+n,e[1]+n]),i.push([e[0],e[1]+n]);break;case"top":i.push([e[0],e[1]-n]),i.push([e[0]+n,e[1]-n]),i.push([e[0]+n,e[1]]);break;case"bottom":i.push([e[0],e[1]+n]),i.push([e[0]+n,e[1]+n]),i.push([e[0]+n,e[1]]);break}else{const s=tl(e,a),o=tl(t,a);if(s===o){const A=s;let l,c;switch(A){case"left":l=Math.min(e[0],t[0])-n,i.push([l,e[1]]),i.push([l,t[1]]);break;case"right":l=Math.max(e[0],t[0])+n,i.push([l,e[1]]),i.push([l,t[1]]);break;case"top":c=Math.min(e[1],t[1])-n,i.push([e[0],c]),i.push([t[0],c]);break;case"bottom":c=Math.max(e[1],t[1])+n,i.push([e[0],c]),i.push([t[0],c]);break}}else{const A=(h,d)=>({left:[d[0]-n,d[1]],right:[d[0]+n,d[1]],top:[d[0],d[1]-n],bottom:[d[0],d[1]+n]})[h],l=A(s,e),c=A(o,t),u=pl(l,c,a);i.push(l,u,c)}}return i}function h1(r,e){const t=new Set,n=new Set,i=new Set;return r.forEach(a=>{e(a).forEach(o=>{t.add(o),r.includes(o.source)&&r.includes(o.target)?n.add(o):i.add(o)})}),{edges:Array.from(t),internal:Array.from(n),external:Array.from(i)}}function Qx(r,e){const t=[];let n=r;for(;n;){t.push(n);const i=e(Z(n));if(i)n=i;else break}if(t.some(i=>{var a;return(a=i.style)===null||a===void 0?void 0:a.collapsed})){const i=t.reverse().findIndex(xr);return t[i]||t.at(-1)}return r}function M9(r,e){return e||(r<4?10:r===4?12:r*2.5)}const O9=(r,e)=>{const t=Math.max(r,e)/2;return[["M",-r/2,0],["A",t,t,0,1,0,2*t-r/2,0],["A",t,t,0,1,0,-r/2,0],["Z"]]},NL=(r,e)=>[["M",-r/2,0],["L",r/2,-e/2],["L",r/2,e/2],["Z"]],_9=(r,e)=>[["M",-r/2,0],["L",0,-e/2],["L",r/2,0],["L",0,e/2],["Z"]],I9=(r,e)=>[["M",-r/2,0],["L",r/2,-e/2],["L",4*r/5-r/2,0],["L",r/2,e/2],["Z"]],k9=(r,e)=>[["M",-r/2,-e/2],["L",r/2,-e/2],["L",r/2,e/2],["L",-r/2,e/2],["Z"]],L9=(r,e)=>{const t=r/2,n=r/7,i=r-n;return[["M",-t,0],["L",0,-e/2],["L",0,e/2],["Z"],["M",i-t,-e/2],["L",i+n-t,-e/2],["L",i+n-t,e/2],["L",i-t,e/2],["Z"]]},Q9=(r,e)=>[["M",r/2,-e/2],["L",-r/2,0],["L",r/2,0],["L",-r/2,0],["L",r/2,e/2]],N9=Object.freeze(Object.defineProperty({__proto__:null,circle:O9,diamond:_9,rect:k9,simple:Q9,triangle:NL,triangleRect:L9,vee:I9},Symbol.toStringTag,{value:"Module"}));var lu=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class os extends EL{constructor(e){super(kn({style:os.defaultStyleProps},e)),this.type="edge"}get sourceNode(){const{sourceNode:e}=this.parsedAttributes;return this.context.element.getElement(e)}get targetNode(){const{targetNode:e}=this.parsedAttributes;return this.context.element.getElement(e)}getKeyStyle(e){const t=this.getGraphicStyle(e),{loop:n}=t,i=lu(t,["loop"]),{sourceNode:a,targetNode:s}=this,A={d:n&&j9(a,s)?this.getLoopPath(e):this.getKeyPath(e)};return rr.PARSED_STYLE_LIST.forEach(l=>{l in i&&(A[l]=i[l])}),A}getLoopPath(e){const{sourcePort:t,targetPort:n}=e,i=this.sourceNode,a=Ra(i),s=Math.max(Yi(a),Xi(a)),{placement:o,clockwise:A,dist:l=s}=tn(this.getGraphicStyle(e),"loop");return C9(i,o,A,l,t,n)}getEndpoints(e,t=!0,n=[]){const{sourcePort:i,targetPort:a}=e,{sourceNode:s,targetNode:o}=this,[A,l]=q9(s,o,i,a);if(!t){const d=A?ts(A):s.getCenter(),f=l?ts(l):o.getCenter();return[d,f]}const c=typeof n=="function"?n():n,u=Dx(A||s,c[0]||l||o),h=Dx(l||o,c[c.length-1]||A||s);return[u,h]}getHaloStyle(e){if(e.halo===!1)return!1;const t=this.getKeyStyle(e),n=tn(this.getGraphicStyle(e),"halo");return Object.assign(Object.assign({},t),n)}getLabelStyle(e){if(e.label===!1||!e.labelText)return!1;const t=tn(this.getGraphicStyle(e),"label"),{placement:n,offsetX:i,offsetY:a,autoRotate:s,maxWidth:o}=t,A=lu(t,["placement","offsetX","offsetY","autoRotate","maxWidth"]),l=kL(this.shapeMap.key,n,s,i,a),c=this.shapeMap.key.getLocalBounds(),u=hj([c.min,c.max],o);return Object.assign({wordWrapWidth:u},l,A)}getBadgeStyle(e){if(e.badge===!1||!e.badgeText)return!1;const t=tn(e,"badge"),{offsetX:n,offsetY:i,placement:a}=t,s=lu(t,["offsetX","offsetY","placement"]);return Object.assign(s,m9(this.shapeMap,a,e.labelPlacement,n,i))}drawArrow(e,t){var n;const i=t==="start",s=e[t==="start"?"startArrow":"endArrow"],o=this.shapeMap.key;if(s){const A=this.getArrowStyle(e,i),[l,c,u]=i?["markerStart","markerStartOffset","startArrowOffset"]:["markerEnd","markerEndOffset","endArrowOffset"],h=o.parsedStyle[l];if(h)h.attr(A);else{const d=A.src?Il:rr,f=new d({style:A});o.style[l]=f}o.style[c]=e[u]||A.width/2+ +A.lineWidth}else{const A=i?"markerStart":"markerEnd";(n=o.style[A])===null||n===void 0||n.destroy(),o.style[A]=null}}getArrowStyle(e,t){const n=this.getShape("key").attributes,i=t?"startArrow":"endArrow",a=tn(this.getGraphicStyle(e),i),{size:s,type:o}=a,A=lu(a,["size","type"]),[l,c]=Gr(M9(n.lineWidth,s)),h=(Te(o)?o:N9[o]||NL)(l,c);return Object.assign(Ds(n,["stroke","strokeOpacity","fillOpacity"]),{width:l,height:c},Object.assign({},h&&{d:h,fill:o==="simple"?"":n.stroke}),A)}drawLabelShape(e,t){const n=this.getLabelStyle(e);this.upsert("label",ji,n,t)}drawHaloShape(e,t){const n=this.getHaloStyle(e);this.upsert("halo",rr,n,t)}drawBadgeShape(e,t){const n=this.getBadgeStyle(e);this.upsert("badge",Zo,n,t)}drawSourceArrow(e){this.drawArrow(e,"start")}drawTargetArrow(e){this.drawArrow(e,"end")}drawKeyShape(e,t){const n=this.getKeyStyle(e);return this.upsert("key",rr,n,t)}render(e=this.parsedAttributes,t=this){this.drawKeyShape(e,t),this.getShape("key")&&(this.drawSourceArrow(e),this.drawTargetArrow(e),this.drawLabelShape(e,t),this.drawHaloShape(e,t),this.drawBadgeShape(e,t))}onframe(){this.drawKeyShape(this.parsedAttributes,this),this.drawSourceArrow(this.parsedAttributes),this.drawTargetArrow(this.parsedAttributes),this.drawHaloShape(this.parsedAttributes,this),this.drawLabelShape(this.parsedAttributes,this),this.drawBadgeShape(this.parsedAttributes,this)}animate(e,t){const n=super.animate(e,t);return n&&new Proxy(n,{set:(i,a,s)=>(a==="currentTime"&&Promise.resolve().then(()=>this.onframe()),Reflect.set(i,a,s))})}}os.defaultStyleProps={badge:!0,badgeOffsetX:0,badgeOffsetY:0,badgePlacement:"suffix",isBillboard:!0,label:!0,labelAutoRotate:!0,labelIsBillboard:!0,labelMaxWidth:"80%",labelOffsetX:4,labelOffsetY:0,labelPlacement:"center",labelTextBaseline:"middle",labelWordWrap:!1,halo:!1,haloDroppable:!1,haloLineDash:0,haloLineWidth:12,haloPointerEvents:"none",haloStrokeOpacity:.25,haloZIndex:-1,loop:!0,startArrow:!1,startArrowLineDash:0,startArrowLineJoin:"round",startArrowLineWidth:1,startArrowTransformOrigin:"center",startArrowType:"vee",endArrow:!1,endArrowLineDash:0,endArrowLineJoin:"round",endArrowLineWidth:1,endArrowTransformOrigin:"center",endArrowType:"vee",loopPlacement:"top",loopClockwise:!0};class Js extends os{constructor(e){super(kn({style:Js.defaultStyleProps},e))}getKeyPath(e){const[t,n]=this.getEndpoints(e),{controlPoints:i,curvePosition:a,curveOffset:s}=e,o=this.getControlPoints(t,n,B9(a),w9(s),i);return LL(t,n,o)}getControlPoints(e,t,n,i,a){return(a==null?void 0:a.length)===2?a:[u1(e,t,n[0],i[0]),u1(e,t,n[1],i[1])]}}Js.defaultStyleProps={curvePosition:.5,curveOffset:20};class Ad extends Js{constructor(e){super(kn({style:Ad.defaultStyleProps},e))}getControlPoints(e,t,n,i){const a=t[0]-e[0];return[[e[0]+a*n[0]+i[0],e[1]],[t[0]-a*n[1]+i[1],t[1]]]}}Ad.defaultStyleProps={curvePosition:[.5,.5],curveOffset:[0,0]};class ld extends Js{constructor(e){super(kn({style:ld.defaultStyleProps},e))}get ref(){return this.context.model.getRootsData()[0]}getEndpoints(e){if(this.sourceNode.id===this.ref.id)return super.getEndpoints(e);const t=Sn(this.ref),n=this.sourceNode.getIntersectPoint(t,!0),i=this.targetNode.getIntersectPoint(t);return[n,i]}toRadialCoordinate(e){const t=Sn(this.ref),n=Lt(e,t),i=oL(bt(e,t));return[n,i]}getControlPoints(e,t,n,i){const[a,s]=this.toRadialCoordinate(e),[o]=this.toRadialCoordinate(t),A=o-a;return[[e[0]+(A*n[0]+i[0])*Math.cos(s),e[1]+(A*n[0]+i[0])*Math.sin(s)],[t[0]-(A*n[1]-i[0])*Math.cos(s),t[1]-(A*n[1]-i[0])*Math.sin(s)]]}}ld.defaultStyleProps={curvePosition:.5,curveOffset:20};class cd extends Js{constructor(e){super(kn({style:cd.defaultStyleProps},e))}getControlPoints(e,t,n,i){const a=t[1]-e[1];return[[e[0],e[1]+a*n[0]+i[0]],[t[0],t[1]-a*n[1]+i[1]]]}}cd.defaultStyleProps={curvePosition:[.5,.5],curveOffset:[0,0]};let UL=class PL extends os{constructor(e){super(kn({style:PL.defaultStyleProps},e))}getKeyPath(e){const[t,n]=this.getEndpoints(e);return[["M",t[0],t[1]],["L",n[0],n[1]]]}};UL.defaultStyleProps={};const U9={enableObstacleAvoidance:!1,offset:10,maxAllowedDirectionChange:Math.PI/2,maximumLoops:3e3,gridSize:5,startDirections:["top","right","bottom","left"],endDirections:["top","right","bottom","left"],directionMap:{right:{stepX:1,stepY:0},left:{stepX:-1,stepY:0},bottom:{stepX:0,stepY:1},top:{stepX:0,stepY:-1}},penalties:{0:0,90:0},distFunc:vh},sa=r=>`${Math.round(r[0])}|||${Math.round(r[1])}`;function Os(r,e){const t=n=>Math.round(n/e);return Be(r)?t(r):r.map(t)}function P9(r,e){const t=Math.abs(r-e);return t>Math.PI?2*Math.PI-t:t}function Nx(r,e){const t=e[0]-r[0],n=e[1]-r[1];return!t&&!n?0:Math.atan2(n,t)}function RL(r,e,t,n){const i=Nx(r,e),a=t[sa(r)],o=Nx(a||n,r);return P9(o,i)}const R9=(r,e)=>{const{offset:t,gridSize:n}=e,i={};return r.forEach(a=>{if(!a||a.destroyed||!a.isVisible())return;const s=as(a.getRenderBounds(),t);for(let o=Os(s.min[0],n);o<=Os(s.max[0],n);o+=1)for(let A=Os(s.min[1],n);A<=Os(s.max[1],n);A+=1)i[`${o}|||${A}`]=!0}),i};function Ux(r,e,t){return Math.min(...e.map(n=>t(r,n)))}function D9(r,e,t){let n=r[0],i=t(r[0],e);for(let a=0;a<r.length;a++){const s=r[a],o=t(s,e);o<i&&(n=s,i=o)}return n}const Px=(r,e,t,n)=>{if(!e)return[r];const{directionMap:i,offset:a}=n,s=as(e.getRenderBounds(),a),o=Object.keys(i).reduce((A,l)=>{if(t.includes(l)){const c=i[l],[u,h]=is(s),d=[r[0]+c.stepX*u,r[1]+c.stepY*h],f=xV(s);for(let g=0;g<f.length;g++){const v=wB([r,d],f[g]);v&&Jk(v,s)&&A.push(v)}}return A},[]);return wi(r,s)||o.push(r),o.map(A=>Os(A,n.gridSize))},H9=(r,e,t,n,i,a,s)=>{const o=[];let A=[a[0]===n[0]?n[0]:r[0]*s,a[1]===n[1]?n[1]:r[1]*s];o.unshift(A);let l=r,c=e[sa(l)];for(;c;){const d=c,f=l;RL(d,f,e,t)&&(A=[d[0]===f[0]?A[0]:d[0]*s,d[1]===f[1]?A[1]:d[1]*s],o.unshift(A)),c=e[sa(d)],l=d}const u=i.map(d=>[d[0]*s,d[1]*s]),h=D9(u,A,vh);return o.unshift(h),o};function G9(r,e,t,n){const i=js(r.getCenter()),a=js(e.getCenter()),s=Object.assign(U9,n),{gridSize:o}=s,A=s.enableObstacleAvoidance?t:[r,e],l=R9(A,s),c=Os(i,o),u=Os(a,o),h=Px(i,r,s.startDirections,s),d=Px(a,e,s.endDirections,s);h.forEach(T=>delete l[sa(T)]),d.forEach(T=>delete l[sa(T)]);const f={},g={},v={},p={},y={},m=new K9;for(let T=0;T<h.length;T++){const O=h[T],_=sa(O);f[_]=O,p[_]=0,y[_]=Ux(O,d,s.distFunc),m.add({id:_,value:y[_]})}const B=d.map(T=>sa(T));let C=s.maximumLoops,S,F=1/0;for(const[T,O]of Object.entries(f))y[T]<=F&&(F=y[T],S=O);for(;Object.keys(f).length>0&&C>0;){const T=m.minId(!1);if(T)S=f[T];else break;const O=sa(S);if(B.includes(O))return H9(S,v,c,a,h,u,o);delete f[O],m.remove(O),g[O]=!0;for(const _ of Object.values(s.directionMap)){const k=Ve(S,[_.stepX,_.stepY]),L=sa(k);if(g[L])continue;const U=RL(S,k,v,c);if(U>s.maxAllowedDirectionChange||l[L])continue;f[L]||(f[L]=k);const G=s.penalties[U],W=s.distFunc(S,k)+(isNaN(G)?o:G),V=p[O]+W,K=p[L];K&&V>=K||(v[L]=S,p[L]=V,y[L]=V+Ux(k,d,s.distFunc),m.add({id:L,value:y[L]}))}C-=1}return[]}class K9{constructor(){this.arr=[],this.map={},this.arr=[],this.map={}}_innerAdd(e,t){let n=0,i=t-1;for(;i-n>1;){const a=Math.floor((n+i)/2);if(this.arr[a].value>e.value)i=a;else if(this.arr[a].value<e.value)n=a;else{this.arr.splice(a,0,e),this.map[e.id]=!0;return}}this.arr.splice(i,0,e),this.map[e.id]=!0}add(e){delete this.map[e.id];const t=this.arr.length;if(!t||this.arr[t-1].value<e.value){this.arr.push(e),this.map[e.id]=!0;return}this._innerAdd(e,t)}remove(e){this.map[e]&&delete this.map[e]}_clearAndGetMinId(){let e;for(let t=this.arr.length-1;t>=0;t--)this.map[this.arr[t].id]?e=this.arr[t].id:this.arr.splice(t,1);return e}_findFirstId(){for(;this.arr.length;){const e=this.arr.shift();if(this.map[e.id])return e.id}}minId(e){return e?this._clearAndGetMinId():this._findFirstId()}}class ud extends os{constructor(e){super(kn({style:ud.defaultStyleProps},e))}getControlPoints(e){const{router:t}=e,{sourceNode:n,targetNode:i}=this,[a,s]=this.getEndpoints(e,!1);let o=[];if(!t)o=e.controlPoints;else if(t.type==="shortest-path"){const A=this.context.element.getNodes();o=G9(n,i,A,t),o.length||(o=_x(a,s,n,i,e.controlPoints,{padding:t.offset}))}else t.type==="orth"&&(o=_x(a,s,n,i,e.controlPoints,t));return o}getPoints(e){const t=this.getControlPoints(e),[n,i]=this.getEndpoints(e,!0,t);return[n,...t,i]}getKeyPath(e){const t=this.getPoints(e);return SB(t,e.radius)}getLoopPath(e){const{sourcePort:t,targetPort:n,radius:i}=e,a=this.sourceNode,s=Ra(a),o=Math.max(Yi(s),Xi(s))/4,{placement:A,clockwise:l,dist:c=o}=tn(this.getGraphicStyle(e),"loop");return F9(a,i,A,l,c,t,n)}}ud.defaultStyleProps={radius:0,controlPoints:[],router:!1};class Dl extends os{constructor(e){super(kn({style:Dl.defaultStyleProps},e))}getKeyPath(e){const{curvePosition:t,curveOffset:n}=e,[i,a]=this.getEndpoints(e),s=e.controlPoint||u1(i,a,t,n);return b9(i,a,s)}}Dl.defaultStyleProps={curvePosition:.5,curveOffset:30};var z9=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};function Hl(r){return r instanceof xi&&r.type==="node"}function DL(r){return r instanceof os}function FB(r){return r instanceof Jo}function V9(r){return Hl(r)||DL(r)||FB(r)}function j9(r,e){return!r||!e?!1:r===e}const W9={top:[.5,0],right:[1,.5],bottom:[.5,1],left:[0,.5],"left-top":[0,0],"top-left":[0,0],"left-bottom":[0,1],"bottom-left":[0,1],"right-top":[1,0],"top-right":[1,0],"right-bottom":[1,1],"bottom-right":[1,1],default:[.5,.5]};function TB(r,e,t=W9,n=!0){const i=[.5,.5],a=At(e)?Rn(t,e.toLocaleLowerCase(),i):e;if(!n&&At(e))return a;const[s,o]=a||i;return[r.min[0]+Yi(r)*s,r.min[1]+Xi(r)*o]}function MB(r){if(!r)return{};const e=r.getPorts();return(r.attributes.ports||[]).forEach((n,i)=>{var a;const{key:s,placement:o}=n;HL(n)&&(e[a=s||i]||(e[a]=Aa(r.getShape("key").getBounds(),o)))}),e}function HL(r){const{r:e}=r;return!e||Number(e)===0}function ts(r){return qo(r)?r:r.getPosition()}function q9(r,e,t,n){const i=Rx(r,e,t,n),a=Rx(e,r,n,t);return[i,a]}function Rx(r,e,t,n){const i=MB(r);if(t)return i[t];const a=Object.values(i);if(a.length===0)return;const s=a.map(l=>ts(l)),o=$9(e,n),[A]=tj(s,o);return a.find(l=>ts(l)===A)}function $9(r,e){const t=MB(r);if(e)return[ts(t[e])];const n=Object.values(t);return n.length>0?n.map(i=>ts(i)):[r.getCenter()]}function Dx(r,e){return FB(r)||Hl(r)?d1(r,e):yl(r,e)}function yl(r,e){if(!r||!e)return[0,0,0];if(qo(r))return r;if(r.attributes.linkToCenter)return r.getPosition();const t=qo(e)?e:Hl(e)?e.getCenter():e.getPosition();return td(t,r.getBounds())}function d1(r,e){if(!r||!e)return[0,0,0];const t=qo(e)?e:Hl(e)?e.getCenter():e.getPosition();return r.getIntersectPoint(t)||r.getCenter()}function Hx(r,e="bottom",t=0,n=0,i=!1){const a=e.split("-"),[s,o]=Aa(r,e),[A,l]=i?["bottom","top"]:["top","bottom"],c=a.includes("top")?l:a.includes("bottom")?A:"middle",u=a.includes("left")?"right":a.includes("right")?"left":"center";return{transform:[["translate",s+t,o+n]],textBaseline:c,textAlign:u}}function Y9(r,e){return[[0,-r],[e*Math.cos(3*Math.PI/10),-e*Math.sin(3*Math.PI/10)],[r*Math.cos(Math.PI/10),-r*Math.sin(Math.PI/10)],[e*Math.cos(Math.PI/10),e*Math.sin(Math.PI/10)],[r*Math.cos(3*Math.PI/10),r*Math.sin(3*Math.PI/10)],[0,e],[-r*Math.cos(3*Math.PI/10),r*Math.sin(3*Math.PI/10)],[-e*Math.cos(Math.PI/10),e*Math.sin(Math.PI/10)],[-r*Math.cos(Math.PI/10),-r*Math.sin(Math.PI/10)],[-e*Math.cos(3*Math.PI/10),-e*Math.sin(3*Math.PI/10)]]}function X9(r,e){const t={};return t.top=[0,-r],t.left=[-r*Math.cos(Math.PI/10),-r*Math.sin(Math.PI/10)],t["left-bottom"]=[-r*Math.cos(3*Math.PI/10),r*Math.sin(3*Math.PI/10)],t.bottom=[0,e],t["right-bottom"]=[r*Math.cos(3*Math.PI/10),r*Math.sin(3*Math.PI/10)],t.right=t.default=[r*Math.cos(Math.PI/10),-r*Math.sin(Math.PI/10)],t}function Z9(r,e,t){const n=e/2,i=r/2,a={up:[[-i,n],[i,n],[0,-n]],left:[[-i,0],[i,n],[i,-n]],right:[[-i,n],[-i,-n],[i,0]],down:[[-i,-n],[i,-n],[0,n]]};return a[t]||a.up}function J9(r,e,t){const n=e/2,i=r/2,a={};return t==="down"?(a.bottom=a.default=[0,n],a.right=[i,-n],a.left=[-i,-n]):t==="left"?(a.top=[i,-n],a.bottom=[i,n],a.left=a.default=[-i,0]):t==="right"?(a.top=[-i,-n],a.bottom=[-i,n],a.right=a.default=[i,0]):(a.left=[-i,n],a.top=a.default=[0,-n],a.right=[i,n]),a}function eW(r,e){return[[0,-e/2],[r/2,0],[0,e/2],[-r/2,0]]}function GL(r){return Rn(r,["style","visibility"])!=="hidden"}function tW(r,e){const{zIndex:t,transform:n,transformOrigin:i,visibility:a,cursor:s,clipPath:o,component:A}=e,l=z9(e,["zIndex","transform","transformOrigin","visibility","cursor","clipPath","component"]);Object.assign(r.attributes,l),n&&r.setAttribute("transform",n),Be(t)&&r.setAttribute("zIndex",t),i&&r.setAttribute("transformOrigin",i),a&&r.setAttribute("visibility",a),s&&r.setAttribute("cursor",s),o&&r.setAttribute("clipPath",o),A&&r.setAttribute("component",A)}function f1(r,e){"update"in r?r.update(e):r.attr(e)}function nW(r){return[[0,r],[r*Math.sqrt(3)/2,r/2],[r*Math.sqrt(3)/2,-r/2],[0,-r],[-r*Math.sqrt(3)/2,-r/2],[-r*Math.sqrt(3)/2,r/2]]}function rW(r){ol(r,"__to_be_destroyed__",!0)}function Gl(r){return Rn(r,"__to_be_destroyed__",!1)}var iW=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class hd extends zr{constructor(e,t){super(e,Object.assign({},hd.defaultOptions,t)),this.onCollapseExpand=n=>iW(this,void 0,void 0,function*(){if(!this.validate(n))return;const{target:i}=n;if(!V9(i))return;const a=i.id,{model:s,graph:o}=this.context,A=s.getElementDataById(a);if(!A)return!1;const{onCollapse:l,onExpand:c,animation:u,align:h}=this.options;xr(A)?(yield o.expandElement(a,{animation:u,align:h}),c==null||c(a)):(yield o.collapseElement(a,{animation:u,align:h}),l==null||l(a))}),this.bindEvents()}update(e){this.unbindEvents(),super.update(e),this.bindEvents()}bindEvents(){const{graph:e}=this.context,{trigger:t}=this.options;e.on(`node:${t}`,this.onCollapseExpand),e.on(`combo:${t}`,this.onCollapseExpand)}unbindEvents(){const{graph:e}=this.context,{trigger:t}=this.options;e.off(`node:${t}`,this.onCollapseExpand),e.off(`combo:${t}`,this.onCollapseExpand)}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}destroy(){this.unbindEvents(),super.destroy()}}hd.defaultOptions={enable:!0,animation:!0,trigger:se.DBLCLICK,align:!0};var ml=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};function ba(r,e){const{data:t,style:n}=r,i=ml(r,["data","style"]),{data:a,style:s}=e,o=ml(e,["data","style"]),A=Object.assign(Object.assign({},i),o);return(t||a)&&Object.assign(A,{data:Object.assign(Object.assign({},t),a)}),(n||s)&&Object.assign(A,{style:Object.assign(Object.assign({},n),s)}),A}function bg(r){const{data:e,style:t}=r,i=ml(r,["data","style"]);return e&&(i.data=Object.assign({},e)),t&&(i.style=Object.assign({},t)),i}function po(r={},e={}){const{states:t=[],data:n={},style:i={},children:a=[]}=r,s=ml(r,["states","data","style","children"]),{states:o=[],data:A={},style:l={},children:c=[]}=e,u=ml(e,["states","data","style","children"]),h=(f,g)=>f.length!==g.length?!1:f.every((v,p)=>v===g[p]),d=(f,g)=>{const v=Object.keys(f),p=Object.keys(g);return v.length!==p.length?!1:v.every(y=>f[y]===g[y])};return!(!d(s,u)||!h(a,c)||!h(t,o)||!d(n,A)||!d(i,l))}const KL="__internal_override__";function Gx(r){return r[KL]!==!1}var cu=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};const aW="g6-create-edge-assist-edge-id",uu="g6-create-edge-assist-node-id";class dd extends zr{constructor(e,t){super(e,Object.assign({},dd.defaultOptions,t)),this.drop=n=>cu(this,void 0,void 0,function*(){const{targetType:i}=n;["combo","node"].includes(i)&&this.source?yield this.handleCreateEdge(n):yield this.cancelEdge()}),this.handleCreateEdge=n=>cu(this,void 0,void 0,function*(){var i,a,s;if(!this.validate(n))return;const{graph:o,canvas:A,batch:l,element:c}=this.context,{style:u}=this.options;if(this.source){this.createEdge(n),yield this.cancelEdge();return}l.startBatch(),A.setCursor("crosshair"),this.source=this.getSelectedNodeIDs([n.target.id])[0];const h=o.getElementData(this.source);o.addNodeData([{id:uu,type:"circle",[KL]:!1,style:{size:1,visibility:"hidden",ports:[{key:"port-1",placement:[.5,.5]}],x:(i=h.style)===null||i===void 0?void 0:i.x,y:(a=h.style)===null||a===void 0?void 0:a.y}}]),o.addEdgeData([{id:aW,source:this.source,target:uu,style:Object.assign({pointerEvents:"none"},u)}]),yield(s=c.draw({animation:!1}))===null||s===void 0?void 0:s.finished}),this.updateAssistEdge=n=>cu(this,void 0,void 0,function*(){var i;if(!this.source)return;const{model:a,element:s}=this.context;a.translateNodeTo(uu,[n.client.x,n.client.y]),yield(i=s.draw({animation:!1,silence:!0}))===null||i===void 0?void 0:i.finished}),this.createEdge=n=>{var i,a;const{graph:s}=this.context,{style:o,onFinish:A,onCreate:l}=this.options;if(((i=n.target)===null||i===void 0?void 0:i.id)===void 0||this.source===void 0)return;const u=(a=this.getSelectedNodeIDs([n.target.id]))===null||a===void 0?void 0:a[0],h=`${this.source}-${u}-${MR()}`,d=l({id:h,source:this.source,target:u,style:o});d&&(s.addEdgeData([d]),A(d))},this.cancelEdge=()=>cu(this,void 0,void 0,function*(){var n;if(!this.source)return;const{graph:i,element:a,batch:s}=this.context;i.removeNodeData([uu]),this.source=void 0,yield(n=a.draw({animation:!1}))===null||n===void 0?void 0:n.finished,s.endBatch()}),this.bindEvents()}update(e){super.update(e),this.bindEvents()}bindEvents(){const{graph:e}=this.context,{trigger:t}=this.options;this.unbindEvents(),t==="click"?(e.on(ti.CLICK,this.handleCreateEdge),e.on(Ts.CLICK,this.handleCreateEdge),e.on(ga.CLICK,this.cancelEdge),e.on(fh.CLICK,this.cancelEdge)):(e.on(ti.DRAG_START,this.handleCreateEdge),e.on(Ts.DRAG_START,this.handleCreateEdge),e.on(se.POINTER_UP,this.drop)),e.on(se.POINTER_MOVE,this.updateAssistEdge)}getSelectedNodeIDs(e){return Array.from(new Set(this.context.graph.getElementDataByState("node",this.options.state).map(t=>t.id).concat(e)))}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}unbindEvents(){const{graph:e}=this.context;e.off(ti.CLICK,this.handleCreateEdge),e.off(Ts.CLICK,this.handleCreateEdge),e.off(ga.CLICK,this.cancelEdge),e.off(fh.CLICK,this.cancelEdge),e.off(ti.DRAG_START,this.handleCreateEdge),e.off(Ts.DRAG_START,this.handleCreateEdge),e.off(se.POINTER_UP,this.drop),e.off(se.POINTER_MOVE,this.updateAssistEdge)}destroy(){this.unbindEvents(),super.destroy()}}dd.defaultOptions={animation:!0,enable:!0,style:{},trigger:"drag",onCreate:r=>r,onFinish:()=>{}};var Kx=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class fd extends zr{constructor(e,t){super(e,Object.assign({},fd.defaultOptions,t)),this.isDragging=!1,this.onDragStart=n=>{this.validate(n)&&(this.isDragging=!0,this.context.canvas.setCursor("grabbing"))},this.onDrag=n=>{var i,a,s,o;if(!this.isDragging||ln.isPinching)return;const A=(a=(i=n.movement)===null||i===void 0?void 0:i.x)!==null&&a!==void 0?a:n.dx,l=(o=(s=n.movement)===null||s===void 0?void 0:s.y)!==null&&o!==void 0?o:n.dy;(A|l)!==0&&this.translate([A,l],!1)},this.onDragEnd=()=>{var n,i;this.isDragging=!1,this.context.canvas.setCursor(this.defaultCursor),(i=(n=this.options).onFinish)===null||i===void 0||i.call(n)},this.invokeOnFinish=Sl(()=>{var n,i;(i=(n=this.options).onFinish)===null||i===void 0||i.call(n)},300),this.shortcut=new ss(e.graph),this.bindEvents(),this.defaultCursor=this.context.canvas.getConfig().cursor||"default"}update(e){this.unbindEvents(),super.update(e),this.bindEvents()}bindEvents(){const{trigger:e}=this.options;if(un(e)){const{up:t=[],down:n=[],left:i=[],right:a=[]}=e;this.shortcut.bind(t,s=>this.onTranslate([0,1],s)),this.shortcut.bind(n,s=>this.onTranslate([0,-1],s)),this.shortcut.bind(i,s=>this.onTranslate([1,0],s)),this.shortcut.bind(a,s=>this.onTranslate([-1,0],s))}else{const{graph:t}=this.context;t.on(se.DRAG_START,this.onDragStart),t.on(se.DRAG,this.onDrag),t.on(se.DRAG_END,this.onDragEnd)}}onTranslate(e,t){return Kx(this,void 0,void 0,function*(){if(!this.validate(t))return;const{sensitivity:n}=this.options,i=n*-1;yield this.translate(vi(e,i),this.options.animation),this.invokeOnFinish()})}translate(e,t){return Kx(this,void 0,void 0,function*(){e=this.clampByDirection(e),e=this.clampByRange(e),e=this.clampByRotation(e),yield this.context.graph.translateBy(e,t)})}clampByRotation([e,t]){const n=this.context.graph.getRotation();return AL([e,t],n)}clampByDirection([e,t]){const{direction:n}=this.options;return n==="x"?t=0:n==="y"&&(e=0),[e,t]}clampByRange([e,t]){const{viewport:n,canvas:i}=this.context,[a,s]=i.getSize(),[o,A,l,c]=ai(this.options.range),u=[s*o,a*A,s*l,a*c],h=as(gB(n.getCanvasCenter()),u),d=bt(n.getViewportCenter(),[e,t,0]);if(!wi(d,h)){const{min:[f,g],max:[v,p]}=h;(d[0]<f&&e>0||d[0]>v&&e<0)&&(e=0),(d[1]<g&&t>0||d[1]>p&&t<0)&&(t=0)}return[e,t]}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return typeof t=="function"?t(e):!!t}unbindEvents(){this.shortcut.unbindAll();const{graph:e}=this.context;e.off(se.DRAG_START,this.onDragStart),e.off(se.DRAG,this.onDrag),e.off(se.DRAG_END,this.onDragEnd)}destroy(){this.shortcut.destroy(),this.unbindEvents(),this.context.canvas.setCursor(this.defaultCursor),super.destroy()}}fd.defaultOptions={enable:r=>"targetType"in r?r.targetType==="canvas":!0,sensitivity:10,direction:"both",range:1/0};var zx=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class Kl extends zr{constructor(e,t){super(e,Object.assign({},Kl.defaultOptions,t)),this.enable=!1,this.enableElements=["node","combo"],this.target=[],this.shadowOrigin=[0,0],this.hiddenEdges=[],this.isDragging=!1,this.onDrop=n=>zx(this,void 0,void 0,function*(){var i;if(this.options.dropEffect!=="link")return;const{model:a,element:s}=this.context,o=n.target.id;this.target.forEach(A=>{const l=a.getParentData(A,Et);l&&Z(l)===o&&a.refreshComboData(o),a.setParent(A,o,Et)}),yield(i=s==null?void 0:s.draw({animation:!0}))===null||i===void 0?void 0:i.finished}),this.setCursor=n=>{if(this.isDragging)return;const{type:i}=n,{canvas:a}=this.context,{cursor:s}=this.options;i===se.POINTER_ENTER?a.setCursor((s==null?void 0:s.grab)||"grab"):a.setCursor((s==null?void 0:s.default)||"default")},this.shortcut=new ss(e.graph),this.onDragStart=this.onDragStart.bind(this),this.onDrag=this.onDrag.bind(this),this.onDragEnd=this.onDragEnd.bind(this),this.onDrop=this.onDrop.bind(this),this.bindEvents()}update(e){this.unbindEvents(),super.update(e),this.bindEvents()}bindEvents(){const{graph:e,canvas:t}=this.context,n=t.getLayer().getContextService().$canvas;n&&(n.addEventListener("blur",this.onDragEnd),n.addEventListener("contextmenu",this.onDragEnd)),this.enableElements.forEach(i=>{e.on(`${i}:${se.DRAG_START}`,this.onDragStart),e.on(`${i}:${se.DRAG}`,this.onDrag),e.on(`${i}:${se.DRAG_END}`,this.onDragEnd),e.on(`${i}:${se.POINTER_ENTER}`,this.setCursor),e.on(`${i}:${se.POINTER_LEAVE}`,this.setCursor)}),["link"].includes(this.options.dropEffect)&&(e.on(Ts.DROP,this.onDrop),e.on(ga.DROP,this.onDrop))}getSelectedNodeIDs(e){return Array.from(new Set(this.context.graph.getElementDataByState("node",this.options.state).map(t=>t.id).concat(e)))}getDelta(e){const t=this.context.graph.getZoom();return Bi([e.dx,e.dy],t)}onDragStart(e){var t;if(this.enable=this.validate(e),!this.enable)return;const{batch:n,canvas:i,graph:a}=this.context;i.setCursor(((t=this.options.cursor)===null||t===void 0?void 0:t.grabbing)||"grabbing"),this.isDragging=!0,n.startBatch();const s=e.target.id;a.getElementState(s).includes(this.options.state)?this.target=this.getSelectedNodeIDs([s]):this.target=[s],this.hideEdge(),this.context.graph.frontElement(this.target),this.options.shadow&&this.createShadow(this.target)}onDrag(e){if(!this.enable)return;const t=this.getDelta(e);this.options.shadow?this.moveShadow(t):this.moveElement(this.target,t)}onDragEnd(){var e,t,n;if(!this.enable)return;if(this.enable=!1,this.options.shadow){if(!this.shadow)return;this.shadow.style.visibility="hidden";const{x:s=0,y:o=0}=this.shadow.attributes,[A,l]=bt([+s,+o],this.shadowOrigin);this.moveElement(this.target,[A,l])}this.showEdges(),(t=(e=this.options).onFinish)===null||t===void 0||t.call(e,this.target);const{batch:i,canvas:a}=this.context;i.endBatch(),a.setCursor(((n=this.options.cursor)===null||n===void 0?void 0:n.grab)||"grab"),this.isDragging=!1,this.target=[]}isKeydown(){const{trigger:e}=this.options;return e!=null&&e.length?this.shortcut.match(e):!0}validate(e){if(this.destroyed||Gl(e.target)||this.context.graph.isCollapsingExpanding||!this.isKeydown())return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}clampByRotation([e,t]){const n=this.context.graph.getRotation();return AL([e,t],n)}moveElement(e,t){return zx(this,void 0,void 0,function*(){const{graph:n,model:i}=this.context,{dropEffect:a}=this.options;a==="move"&&e.forEach(s=>i.refreshComboData(s)),n.translateElementBy(Object.fromEntries(e.map(s=>[s,this.clampByRotation(t)])),!1)})}moveShadow(e){if(!this.shadow)return;const{x:t=0,y:n=0}=this.shadow.attributes,[i,a]=e;this.shadow.attr({x:+t+i,y:+n+a})}createShadow(e){const t=tn(this.options,"shadow"),n=Ql(e.map(l=>this.context.element.getElement(l).getBounds())),[i,a]=n.min;this.shadowOrigin=[i,a];const[s,o]=is(n),A={width:s,height:o,x:i,y:a};this.shadow?this.shadow.attr(Object.assign(Object.assign(Object.assign({},t),A),{visibility:"visible"})):(this.shadow=new Vn({style:Object.assign(Object.assign(Object.assign({$layer:"transient"},t),A),{pointerEvents:"none"})}),this.context.canvas.appendChild(this.shadow))}showEdges(){this.options.shadow||this.hiddenEdges.length===0||(this.context.graph.showElement(this.hiddenEdges),this.hiddenEdges=[])}hideEdge(){const{hideEdge:e,shadow:t}=this.options;if(e==="none"||t)return;const{graph:n}=this.context;e==="all"?this.hiddenEdges=n.getEdgeData().map(Z):this.hiddenEdges=Array.from(new Set(this.target.map(i=>n.getRelatedEdgesData(i,e).map(Z)).flat())),n.hideElement(this.hiddenEdges)}unbindEvents(){const{graph:e,canvas:t}=this.context,n=t.getLayer().getContextService().$canvas;n&&(n.removeEventListener("blur",this.onDragEnd),n.removeEventListener("contextmenu",this.onDragEnd)),this.enableElements.forEach(i=>{e.off(`${i}:${se.DRAG_START}`,this.onDragStart),e.off(`${i}:${se.DRAG}`,this.onDrag),e.off(`${i}:${se.DRAG_END}`,this.onDragEnd),e.off(`${i}:${se.POINTER_ENTER}`,this.setCursor),e.off(`${i}:${se.POINTER_LEAVE}`,this.setCursor)}),e.off(`combo:${se.DROP}`,this.onDrop),e.off(`canvas:${se.DROP}`,this.onDrop)}destroy(){var e;this.unbindEvents(),(e=this.shadow)===null||e===void 0||e.destroy(),super.destroy()}}Kl.defaultOptions={animation:!0,enable:r=>["node","combo"].includes(r.targetType),trigger:[],dropEffect:"move",state:"selected",hideEdge:"none",shadow:!1,shadowZIndex:100,shadowFill:"#F3F9FF",shadowFillOpacity:.5,shadowStroke:"#1890FF",shadowStrokeOpacity:.9,shadowLineDash:[5,5],cursor:{default:"default",grab:"grab",grabbing:"grabbing"}};var sW="*",gd=(function(){function r(){this._events={}}return r.prototype.on=function(e,t,n){return this._events[e]||(this._events[e]=[]),this._events[e].push({callback:t,once:!!n}),this},r.prototype.once=function(e,t){return this.on(e,t,!0)},r.prototype.emit=function(e){for(var t=this,n=[],i=1;i<arguments.length;i++)n[i-1]=arguments[i];var a=this._events[e]||[],s=this._events[sW]||[],o=function(A){for(var l=A.length,c=0;c<l;c++)if(A[c]){var u=A[c],h=u.callback,d=u.once;d&&(A.splice(c,1),A.length===0&&delete t._events[e],l--,c--),h.apply(t,n)}};o(a),o(s)},r.prototype.off=function(e,t){if(!e)this._events={};else if(!t)delete this._events[e];else{for(var n=this._events[e]||[],i=n.length,a=0;a<i;a++)n[a].callback===t&&(n.splice(a,1),i--,a--);n.length===0&&delete this._events[e]}return this},r.prototype.getEvents=function(){return this._events},r})();function g1(r,e,t,n){for(;r.length;){const i=r.shift();if(t(i))return!0;e.add(i.id),n(i.id).forEach(s=>{e.has(s.id)||(e.add(s.id),r.push(s))})}return!1}function bh(r,e,t,n){if(t(r))return!0;e.add(r.id);for(const a of n(r.id))if(!e.has(a.id)&&bh(a,e,t,n))return!0;return!1}const Vx=()=>!0;class oW{graph;nodeFilter;edgeFilter;cacheEnabled;inEdgesMap=new Map;outEdgesMap=new Map;bothEdgesMap=new Map;allNodesMap=new Map;allEdgesMap=new Map;constructor(e){this.graph=e.graph;const t=e.nodeFilter||Vx,n=e.edgeFilter||Vx;this.nodeFilter=t,this.edgeFilter=i=>{const{source:a,target:s}=this.graph.getEdgeDetail(i.id);return!t(a)||!t(s)?!1:n(i,a,s)},e.cache==="auto"?(this.cacheEnabled=!0,this.startAutoCache()):e.cache==="manual"?this.cacheEnabled=!0:this.cacheEnabled=!1}clearCache=()=>{this.inEdgesMap.clear(),this.outEdgesMap.clear(),this.bothEdgesMap.clear(),this.allNodesMap.clear(),this.allEdgesMap.clear()};refreshCache=()=>{this.clearCache(),this.updateCache(this.graph.getAllNodes().map(e=>e.id))};updateCache=e=>{const t=new Set;e.forEach(n=>{const i=this.bothEdgesMap.get(n);if(i&&i.forEach(a=>t.add(a.id)),!this.hasNode(n))this.inEdgesMap.delete(n),this.outEdgesMap.delete(n),this.bothEdgesMap.delete(n),this.allNodesMap.delete(n);else{const a=this.graph.getRelatedEdges(n,"in").filter(this.edgeFilter),s=this.graph.getRelatedEdges(n,"out").filter(this.edgeFilter),o=Array.from(new Set([...a,...s]));o.forEach(A=>t.add(A.id)),this.inEdgesMap.set(n,a),this.outEdgesMap.set(n,s),this.bothEdgesMap.set(n,o),this.allNodesMap.set(n,this.graph.getNode(n))}}),t.forEach(n=>{this.hasEdge(n)?this.allEdgesMap.set(n,this.graph.getEdge(n)):this.allEdgesMap.delete(n)})};startAutoCache(){this.refreshCache(),this.graph.on("changed",this.handleGraphChanged)}stopAutoCache(){this.graph.off("changed",this.handleGraphChanged)}handleGraphChanged=e=>{const t=new Set;e.changes.forEach(n=>{switch(n.type){case"NodeAdded":t.add(n.value.id);break;case"NodeDataUpdated":t.add(n.id);break;case"EdgeAdded":t.add(n.value.source),t.add(n.value.target);break;case"EdgeUpdated":(n.propertyName==="source"||n.propertyName==="target")&&(t.add(n.oldValue),t.add(n.newValue));break;case"EdgeDataUpdated":if(e.graph.hasEdge(n.id)){const i=e.graph.getEdge(n.id);t.add(i.source),t.add(i.target)}break;case"EdgeRemoved":t.add(n.value.source),t.add(n.value.target);break;case"NodeRemoved":t.add(n.value.id);break}}),this.updateCache(t)};checkNodeExistence(e){this.getNode(e)}hasNode(e){if(!this.graph.hasNode(e))return!1;const t=this.graph.getNode(e);return this.nodeFilter(t)}areNeighbors(e,t){return this.checkNodeExistence(e),this.getNeighbors(t).some(n=>n.id===e)}getNode(e){const t=this.graph.getNode(e);if(!this.nodeFilter(t))throw new Error("Node not found for id: "+e);return t}getRelatedEdges(e,t){return this.checkNodeExistence(e),this.cacheEnabled?t==="in"?this.inEdgesMap.get(e):t==="out"?this.outEdgesMap.get(e):this.bothEdgesMap.get(e):this.graph.getRelatedEdges(e,t).filter(this.edgeFilter)}getDegree(e,t){return this.getRelatedEdges(e,t).length}getSuccessors(e){const n=this.getRelatedEdges(e,"out").map(i=>this.getNode(i.target));return Array.from(new Set(n))}getPredecessors(e){const n=this.getRelatedEdges(e,"in").map(i=>this.getNode(i.source));return Array.from(new Set(n))}getNeighbors(e){const t=this.getPredecessors(e),n=this.getSuccessors(e);return Array.from(new Set([...t,...n]))}hasEdge(e){if(!this.graph.hasEdge(e))return!1;const t=this.graph.getEdge(e);return this.edgeFilter(t)}getEdge(e){const t=this.graph.getEdge(e);if(!this.edgeFilter(t))throw new Error("Edge not found for id: "+e);return t}getEdgeDetail(e){const t=this.getEdge(e);return{edge:t,source:this.getNode(t.source),target:this.getNode(t.target)}}hasTreeStructure(e){return this.graph.hasTreeStructure(e)}getRoots(e){return this.graph.getRoots(e).filter(this.nodeFilter)}getChildren(e,t){return this.checkNodeExistence(e),this.graph.getChildren(e,t).filter(this.nodeFilter)}getParent(e,t){this.checkNodeExistence(e);const n=this.graph.getParent(e,t);return!n||!this.nodeFilter(n)?null:n}getAllNodes(){return this.cacheEnabled?Array.from(this.allNodesMap.values()):this.graph.getAllNodes().filter(this.nodeFilter)}getAllEdges(){return this.cacheEnabled?Array.from(this.allEdgesMap.values()):this.graph.getAllEdges().filter(this.edgeFilter)}bfs(e,t,n="out"){const i={in:this.getPredecessors.bind(this),out:this.getSuccessors.bind(this),both:this.getNeighbors.bind(this)}[n];g1([this.getNode(e)],new Set,t,i)}dfs(e,t,n="out"){const i={in:this.getPredecessors.bind(this),out:this.getSuccessors.bind(this),both:this.getNeighbors.bind(this)}[n];bh(this.getNode(e),new Set,t,i)}}let Mn=class zL extends gd{nodeMap=new Map;edgeMap=new Map;inEdgesMap=new Map;outEdgesMap=new Map;bothEdgesMap=new Map;treeIndices=new Map;changes=[];batchCount=0;onChanged=()=>{};constructor(e){super(),e&&(e.nodes&&this.addNodes(e.nodes),e.edges&&this.addEdges(e.edges),e.tree&&this.addTree(e.tree),e.onChanged&&(this.onChanged=e.onChanged))}batch=e=>{this.batchCount+=1,e(),this.batchCount-=1,this.batchCount||this.commit()};commit(){const e=this.changes;this.changes=[];const t={graph:this,changes:e};this.emit("changed",t),this.onChanged(t)}reduceChanges(e){let t=[];return e.forEach(n=>{switch(n.type){case"NodeRemoved":{let i=!1;t=t.filter(a=>{if(a.type==="NodeAdded"){const s=a.value.id===n.value.id;return s&&(i=!0),!s}else{if(a.type==="NodeDataUpdated")return a.id!==n.value.id;if(a.type==="TreeStructureChanged")return a.nodeId!==n.value.id}return!0}),i||t.push(n);break}case"EdgeRemoved":{let i=!1;t=t.filter(a=>{if(a.type==="EdgeAdded"){const s=a.value.id===n.value.id;return s&&(i=!0),!s}else if(a.type==="EdgeDataUpdated"||a.type==="EdgeUpdated")return a.id!==n.value.id;return!0}),i||t.push(n);break}case"NodeDataUpdated":case"EdgeDataUpdated":case"EdgeUpdated":{const i=t.findIndex(s=>s.type===n.type&&s.id===n.id&&(n.propertyName===void 0||s.propertyName===n.propertyName)),a=t[i];a?n.propertyName!==void 0?a.newValue=n.newValue:(t.splice(i,1),t.push(n)):t.push(n);break}case"TreeStructureDetached":{t=t.filter(i=>i.type==="TreeStructureAttached"||i.type==="TreeStructureChanged"?i.treeKey!==n.treeKey:!0),t.push(n);break}case"TreeStructureChanged":{const i=t.find(a=>a.type==="TreeStructureChanged"&&a.treeKey===n.treeKey&&a.nodeId===n.nodeId);i?i.newParentId=n.newParentId:t.push(n);break}default:t.push(n);break}}),t}checkNodeExistence(e){this.getNode(e)}hasNode(e){return this.nodeMap.has(e)}areNeighbors(e,t){return this.getNeighbors(t).some(n=>n.id===e)}getNode(e){const t=this.nodeMap.get(e);if(!t)throw new Error("Node not found for id: "+e);return t}getRelatedEdges(e,t){if(this.checkNodeExistence(e),t==="in"){const n=this.inEdgesMap.get(e);return Array.from(n)}else if(t==="out"){const n=this.outEdgesMap.get(e);return Array.from(n)}else{const n=this.bothEdgesMap.get(e);return Array.from(n)}}getDegree(e,t){return this.getRelatedEdges(e,t).length}getSuccessors(e){const n=this.getRelatedEdges(e,"out").map(i=>this.getNode(i.target));return Array.from(new Set(n))}getPredecessors(e){const n=this.getRelatedEdges(e,"in").map(i=>this.getNode(i.source));return Array.from(new Set(n))}getNeighbors(e){const t=this.getPredecessors(e),n=this.getSuccessors(e);return Array.from(new Set([...t,...n]))}doAddNode(e){if(this.hasNode(e.id))throw new Error("Node already exists: "+e.id);this.nodeMap.set(e.id,e),this.inEdgesMap.set(e.id,new Set),this.outEdgesMap.set(e.id,new Set),this.bothEdgesMap.set(e.id,new Set),this.treeIndices.forEach(t=>{t.childrenMap.set(e.id,new Set)}),this.changes.push({type:"NodeAdded",value:e})}addNodes(e){this.batch(()=>{for(const t of e)this.doAddNode(t)})}addNode(e){this.addNodes([e])}doRemoveNode(e){const t=this.getNode(e),n=this.bothEdgesMap.get(e);n==null||n.forEach(i=>this.doRemoveEdge(i.id)),this.nodeMap.delete(e),this.treeIndices.forEach(i=>{var s,o;(s=i.childrenMap.get(e))==null||s.forEach(A=>{i.parentMap.delete(A.id)});const a=i.parentMap.get(e);a&&((o=i.childrenMap.get(a.id))==null||o.delete(t)),i.parentMap.delete(e),i.childrenMap.delete(e)}),this.bothEdgesMap.delete(e),this.inEdgesMap.delete(e),this.outEdgesMap.delete(e),this.changes.push({type:"NodeRemoved",value:t})}removeNodes(e){this.batch(()=>{e.forEach(t=>this.doRemoveNode(t))})}removeNode(e){this.removeNodes([e])}updateNodeDataProperty(e,t,n){const i=this.getNode(e);this.batch(()=>{const a=i.data[t],s=n;i.data[t]=s,this.changes.push({type:"NodeDataUpdated",id:e,propertyName:t,oldValue:a,newValue:s})})}mergeNodeData(e,t){this.batch(()=>{Object.entries(t).forEach(([n,i])=>{this.updateNodeDataProperty(e,n,i)})})}updateNodeData(...e){const t=e[0],n=this.getNode(t);if(typeof e[1]=="string"){this.updateNodeDataProperty(t,e[1],e[2]);return}let i;if(typeof e[1]=="function"){const a=e[1];i=a(n.data)}else typeof e[1]=="object"&&(i=e[1]);this.batch(()=>{const a=n.data,s=i;n.data=i,this.changes.push({type:"NodeDataUpdated",id:t,oldValue:a,newValue:s})})}checkEdgeExistence(e){if(!this.hasEdge(e))throw new Error("Edge not found for id: "+e)}hasEdge(e){return this.edgeMap.has(e)}getEdge(e){return this.checkEdgeExistence(e),this.edgeMap.get(e)}getEdgeDetail(e){const t=this.getEdge(e);return{edge:t,source:this.getNode(t.source),target:this.getNode(t.target)}}doAddEdge(e){if(this.hasEdge(e.id))throw new Error("Edge already exists: "+e.id);this.checkNodeExistence(e.source),this.checkNodeExistence(e.target),this.edgeMap.set(e.id,e);const t=this.inEdgesMap.get(e.target),n=this.outEdgesMap.get(e.source),i=this.bothEdgesMap.get(e.source),a=this.bothEdgesMap.get(e.target);t.add(e),n.add(e),i.add(e),a.add(e),this.changes.push({type:"EdgeAdded",value:e})}addEdges(e){this.batch(()=>{for(const t of e)this.doAddEdge(t)})}addEdge(e){this.addEdges([e])}doRemoveEdge(e){const t=this.getEdge(e),n=this.outEdgesMap.get(t.source),i=this.inEdgesMap.get(t.target),a=this.bothEdgesMap.get(t.source),s=this.bothEdgesMap.get(t.target);n.delete(t),i.delete(t),a.delete(t),s.delete(t),this.edgeMap.delete(e),this.changes.push({type:"EdgeRemoved",value:t})}removeEdges(e){this.batch(()=>{e.forEach(t=>this.doRemoveEdge(t))})}removeEdge(e){this.removeEdges([e])}updateEdgeSource(e,t){const n=this.getEdge(e);this.checkNodeExistence(t);const i=n.source,a=t;this.outEdgesMap.get(i).delete(n),this.bothEdgesMap.get(i).delete(n),this.outEdgesMap.get(a).add(n),this.bothEdgesMap.get(a).add(n),n.source=t,this.batch(()=>{this.changes.push({type:"EdgeUpdated",id:e,propertyName:"source",oldValue:i,newValue:a})})}updateEdgeTarget(e,t){const n=this.getEdge(e);this.checkNodeExistence(t);const i=n.target,a=t;this.inEdgesMap.get(i).delete(n),this.bothEdgesMap.get(i).delete(n),this.inEdgesMap.get(a).add(n),this.bothEdgesMap.get(a).add(n),n.target=t,this.batch(()=>{this.changes.push({type:"EdgeUpdated",id:e,propertyName:"target",oldValue:i,newValue:a})})}updateEdgeDataProperty(e,t,n){const i=this.getEdge(e);this.batch(()=>{const a=i.data[t],s=n;i.data[t]=s,this.changes.push({type:"EdgeDataUpdated",id:e,propertyName:t,oldValue:a,newValue:s})})}updateEdgeData(...e){const t=e[0],n=this.getEdge(t);if(typeof e[1]=="string"){this.updateEdgeDataProperty(t,e[1],e[2]);return}let i;if(typeof e[1]=="function"){const a=e[1];i=a(n.data)}else typeof e[1]=="object"&&(i=e[1]);this.batch(()=>{const a=n.data,s=i;n.data=i,this.changes.push({type:"EdgeDataUpdated",id:t,oldValue:a,newValue:s})})}mergeEdgeData(e,t){this.batch(()=>{Object.entries(t).forEach(([n,i])=>{this.updateEdgeDataProperty(e,n,i)})})}checkTreeExistence(e){if(!this.hasTreeStructure(e))throw new Error("Tree structure not found for treeKey: "+e)}hasTreeStructure(e){return this.treeIndices.has(e)}attachTreeStructure(e){this.treeIndices.has(e)||(this.treeIndices.set(e,{parentMap:new Map,childrenMap:new Map}),this.batch(()=>{this.changes.push({type:"TreeStructureAttached",treeKey:e})}))}detachTreeStructure(e){this.checkTreeExistence(e),this.treeIndices.delete(e),this.batch(()=>{this.changes.push({type:"TreeStructureDetached",treeKey:e})})}addTree(e,t){this.batch(()=>{this.attachTreeStructure(t);const n=[],i=Array.isArray(e)?e:[e];for(;i.length;){const a=i.shift();n.push(a),a.children&&i.push(...a.children)}this.addNodes(n),n.forEach(a=>{var s;(s=a.children)==null||s.forEach(o=>{this.setParent(o.id,a.id,t)})})})}getRoots(e){return this.checkTreeExistence(e),this.getAllNodes().filter(t=>!this.getParent(t.id,e))}getChildren(e,t){this.checkNodeExistence(e),this.checkTreeExistence(t);const i=this.treeIndices.get(t).childrenMap.get(e);return Array.from(i||[])}getParent(e,t){return this.checkNodeExistence(e),this.checkTreeExistence(t),this.treeIndices.get(t).parentMap.get(e)||null}getAncestors(e,t){const n=[];let i=this.getNode(e),a;for(;a=this.getParent(i.id,t);)n.push(a),i=a;return n}setParent(e,t,n){var l,c;this.checkTreeExistence(n);const i=this.treeIndices.get(n);if(!i)return;const a=this.getNode(e),s=i.parentMap.get(e);if((s==null?void 0:s.id)===t)return;if(t==null){s&&((l=i.childrenMap.get(s.id))==null||l.delete(a)),i.parentMap.delete(e);return}const o=this.getNode(t);i.parentMap.set(e,o),s&&((c=i.childrenMap.get(s.id))==null||c.delete(a));let A=i.childrenMap.get(o.id);A||(A=new Set,i.childrenMap.set(o.id,A)),A.add(a),this.batch(()=>{this.changes.push({type:"TreeStructureChanged",treeKey:n,nodeId:e,oldParentId:s==null?void 0:s.id,newParentId:o.id})})}dfsTree(e,t,n){const i=a=>this.getChildren(a,n);return bh(this.getNode(e),new Set,t,i)}bfsTree(e,t,n){const i=a=>this.getChildren(a,n);return g1([this.getNode(e)],new Set,t,i)}getAllNodes(){return Array.from(this.nodeMap.values())}getAllEdges(){return Array.from(this.edgeMap.values())}bfs(e,t,n="out"){const i={in:this.getPredecessors.bind(this),out:this.getSuccessors.bind(this),both:this.getNeighbors.bind(this)}[n];return g1([this.getNode(e)],new Set,t,i)}dfs(e,t,n="out"){const i={in:this.getPredecessors.bind(this),out:this.getSuccessors.bind(this),both:this.getNeighbors.bind(this)}[n];return bh(this.getNode(e),new Set,t,i)}clone(){const e=this.getAllNodes().map(i=>({...i,data:{...i.data}})),t=this.getAllEdges().map(i=>({...i,data:{...i.data}})),n=new zL({nodes:e,edges:t});return this.treeIndices.forEach(({parentMap:i,childrenMap:a},s)=>{const o=new Map;i.forEach((l,c)=>{o.set(c,n.getNode(l.id))});const A=new Map;a.forEach((l,c)=>{A.set(c,new Set(Array.from(l).map(u=>n.getNode(u.id))))}),n.treeIndices.set(s,{parentMap:o,childrenMap:A})}),n}toJSON(){return JSON.stringify({nodes:this.getAllNodes(),edges:this.getAllEdges()})}createView(e){return new oW({graph:this,...e})}};class vd{constructor(e,t){this.context=e,this.options=t||{}}}var AW=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})},lW=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};function cW(r){const{type:e}=r;return["compact-box","mindmap","dendrogram","indented"].includes(e)}function uW(r){return!Array.isArray(r)&&(r==null?void 0:r.preLayout)}function Iu(r){const{nodes:e,edges:t}=r,n={nodes:[],edges:[],combos:[]};return e.forEach(i=>{const a=i.data._isCombo?n.combos:n.nodes,{x:s,y:o,z:A=0}=i.data;a==null||a.push({id:i.id,style:{x:s,y:o,z:A}})}),t.forEach(i=>{const{id:a,source:s,target:o,data:{points:A=[],controlPoints:l=A.slice(1,A.length-1)}}=i;n.edges.push({id:a,source:s,target:o,style:Object.assign({},l!=null&&l.length?{controlPoints:l.map(Hn)}:{})})}),n}function hW(r,e){class t extends vd{constructor(i,a){if(super(i,a),this.instance=new r({}),this.id=this.instance.id,"stop"in this.instance&&"tick"in this.instance){const s=this.instance;this.stop=s.stop.bind(s),this.tick=o=>{const A=s.tick(o);return Iu(A)}}}execute(i,a){return AW(this,void 0,void 0,function*(){return Iu(yield this.instance.execute(this.graphData2LayoutModel(i),this.transformOptions(zn({},this.options,a))))})}transformOptions(i){if(!("onTick"in i))return i;const a=i.onTick;return i.onTick=s=>a(Iu(s)),i}graphData2LayoutModel(i){const{nodes:a=[],edges:s=[],combos:o=[]}=i,A=a.map(d=>{const f=Z(d),{data:g,style:v,combo:p}=d,y=lW(d,["data","style","combo"]),m={id:f,data:Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},g),{data:g}),p?{parentId:p}:{}),{style:v}),y)};return v!=null&&v.x&&Object.assign(m.data,{x:v.x}),v!=null&&v.y&&Object.assign(m.data,{y:v.y}),v!=null&&v.z&&Object.assign(m.data,{z:v.z}),m}),l=new Map(A.map(d=>[d.id,d])),c=s.filter(d=>{const{source:f,target:g}=d;return l.has(f)&&l.has(g)}).map(d=>{const{source:f,target:g,data:v,style:p}=d;return{id:Z(d),source:f,target:g,data:Object.assign({},v),style:Object.assign({},p)}}),u=o.map(d=>({id:Z(d),data:Object.assign({_isCombo:!0},d.data),style:Object.assign({},d.style)})),h=new Mn({nodes:[...A,...u],edges:c});return e.model.model.hasTreeStructure(Et)&&(h.attachTreeStructure(Et),A.forEach(d=>{const f=e.model.model.getParent(d.id,Et);f&&h.hasNode(f.id)&&h.setParent(d.id,f.id,Et)})),h}}return t}function Eg(r,e,...t){if(e in r)return r[e](...t);if("instance"in r){const n=r.instance;if(e in n)return n[e](...t)}return null}function jx(r,e){if(e in r)return r[e];if("instance"in r){const t=r.instance;if(e in t)return t[e]}return null}var dW=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class fW extends Kl{get forceLayoutInstance(){return this.context.layout.getLayoutInstance().find(e=>["d3-force","d3-force-3d"].includes(e==null?void 0:e.id))}validate(e){return this.context.layout?this.forceLayoutInstance?super.validate(e):($i.warn("DragElementForce only works with d3-force or d3-force-3d layout"),!1):!1}moveElement(e,t){return dW(this,void 0,void 0,function*(){const n=this.forceLayoutInstance;this.context.graph.getNodeData(e).forEach((i,a)=>{const{x:s=0,y:o=0}=i.style||{};n&&Eg(n,"setFixedPosition",e[a],[...Ve([+s,+o],this.clampByRotation(t))])})})}onDragStart(e){if(this.enable=this.validate(e),!this.enable)return;this.target=this.getSelectedNodeIDs([e.target.id]),this.hideEdge(),this.context.graph.frontElement(this.target);const t=this.forceLayoutInstance;t&&jx(t,"simulation").alphaTarget(.3).restart(),this.context.graph.getNodeData(this.target).forEach(n=>{const{x:i=0,y:a=0}=n.style||{};t&&Eg(t,"setFixedPosition",Z(n),[+i,+a])})}onDrag(e){if(!this.enable)return;const t=this.getDelta(e);this.moveElement(this.target,t)}onDragEnd(){const e=this.forceLayoutInstance;e&&jx(e,"simulation").alphaTarget(0),!this.options.fixed&&this.context.graph.getNodeData(this.target).forEach(t=>{e&&Eg(e,"setFixedPosition",Z(t),[null,null,null])})}}var Wx=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class pd extends zr{constructor(e,t){super(e,Object.assign({},pd.defaultOptions,t)),this.isZoomEvent=n=>!!(n.data&&"scale"in n.data),this.relatedEdgeToUpdate=new Set,this.zoom=this.context.graph.getZoom(),this.fixElementSize=n=>Wx(this,void 0,void 0,function*(){if(!this.validate(n))return;const{graph:i}=this.context,{state:a,nodeFilter:s,edgeFilter:o,comboFilter:A}=this.options,l=(a?i.getElementDataByState("node",a):i.getNodeData()).filter(s),c=(a?i.getElementDataByState("edge",a):i.getEdgeData()).filter(o),u=(a?i.getElementDataByState("combo",a):i.getComboData()).filter(A),h=this.isZoomEvent(n)?this.zoom=Math.max(.01,Math.min(n.data.scale,10)):this.zoom,d=[...l,...u];d.length>0&&d.forEach(f=>this.fixNodeLike(f,h)),this.updateRelatedEdges(),c.length>0&&c.forEach(f=>this.fixEdge(f,h))}),this.cachedStyles=new Map,this.getOriginalFieldValue=(n,i,a)=>{var s;const o=this.cachedStyles.get(n)||[],A=((s=o.find(l=>l.shape===i))===null||s===void 0?void 0:s.style)||{};return a in A||(A[a]=i.attributes[a],this.cachedStyles.set(n,[...o.filter(l=>l.shape!==i),{shape:i,style:A}])),A[a]},this.scaleEntireElement=(n,i,a)=>{i.setLocalScale(1/a);const s=this.cachedStyles.get(n)||[];s.push({shape:i}),this.cachedStyles.set(n,s)},this.scaleSpecificShapes=(n,i,a)=>{const s=mj(n);(Array.isArray(a)?a:[a]).forEach(A=>{const{shape:l,fields:c}=A,u=typeof l=="function"?l(s):n.getShape(l);if(u){if(!c){this.scaleEntireElement(n.id,u,i);return}c.forEach(h=>{const d=this.getOriginalFieldValue(n.id,u,h);Be(d)&&(u.style[h]=d/i)})}})},this.skipIfExceedViewport=n=>{const{viewport:i}=this.context;return!(i!=null&&i.isInViewport(n.getRenderBounds(),!1,30))},this.fixNodeLike=(n,i)=>{const a=Z(n),{element:s,model:o}=this.context,A=s.getElement(a);if(!A||this.skipIfExceedViewport(A))return;o.getRelatedEdgesData(a).forEach(u=>this.relatedEdgeToUpdate.add(Z(u)));const c=this.options[A.type];if(!c){this.scaleEntireElement(a,A,i);return}this.scaleSpecificShapes(A,i,c)},this.fixEdge=(n,i)=>{const a=Z(n),s=this.context.element.getElement(a);if(!s||this.skipIfExceedViewport(s))return;const o=this.options.edge;if(!o){s.style.transformOrigin="center",this.scaleEntireElement(a,s,i);return}this.scaleSpecificShapes(s,i,o)},this.updateRelatedEdges=()=>{const{element:n}=this.context;this.relatedEdgeToUpdate.size>0&&this.relatedEdgeToUpdate.forEach(i=>{const a=n.getElement(i);a==null||a.update({})}),this.relatedEdgeToUpdate.clear()},this.resetTransform=n=>Wx(this,void 0,void 0,function*(){var i;!((i=n.data)===null||i===void 0)&&i.firstRender||(this.options.reset?this.restoreCachedStyles():this.fixElementSize({data:{scale:this.zoom}}))}),this.bindEvents()}restoreCachedStyles(){if(this.cachedStyles.size>0){this.cachedStyles.forEach(i=>{i.forEach(({shape:a,style:s})=>{if(Qi(s))a.setLocalScale(1);else{if(this.options.state)return;Object.entries(s).forEach(([o,A])=>a.style[o]=A)}})});const{graph:e,element:t}=this.context,n=Object.keys(Object.fromEntries(this.cachedStyles)).filter(i=>i&&e.getElementType(i)==="node");if(n.length>0){const i=new Set;n.forEach(a=>{e.getRelatedEdgesData(a).forEach(s=>i.add(Z(s)))}),i.forEach(a=>{const s=t==null?void 0:t.getElement(a);s==null||s.update({})})}}}bindEvents(){const{graph:e}=this.context;e.on(ge.AFTER_DRAW,this.resetTransform),e.on(ge.AFTER_TRANSFORM,this.fixElementSize)}unbindEvents(){const{graph:e}=this.context;e.off(ge.AFTER_DRAW,this.resetTransform),e.off(ge.AFTER_TRANSFORM,this.fixElementSize)}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}destroy(){this.unbindEvents(),super.destroy()}}pd.defaultOptions={enable:r=>r.data.scale<1,nodeFilter:()=>!0,edgeFilter:()=>!0,comboFilter:()=>!0,edge:[{shape:"key",fields:["lineWidth"]},{shape:"halo",fields:["lineWidth"]},{shape:"label"}],reset:!1};var gW=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class yd extends zr{constructor(e,t){super(e,Object.assign({},yd.defaultOptions,t)),this.focus=n=>gW(this,void 0,void 0,function*(){if(!this.validate(n))return;const{graph:i}=this.context;yield i.focusElement(n.target.id,this.options.animation)}),this.shortcut=new ss(e.graph),this.bindEvents()}bindEvents(){const{graph:e}=this.context;this.unbindEvents(),Ws.forEach(t=>{e.on(`${t}:${se.CLICK}`,this.focus)})}validate(e){if(this.destroyed||!this.isKeydown())return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}isKeydown(){const{trigger:e}=this.options;return e!=null&&e.length?this.shortcut.match(e):!0}unbindEvents(){const{graph:e}=this.context;Ws.forEach(t=>{e.off(`${t}:${se.CLICK}`,this.focus)})}destroy(){this.unbindEvents(),this.shortcut.destroy(),super.destroy()}}yd.defaultOptions={animation:{easing:"ease-in",duration:500},enable:!0,trigger:[]};class md extends zr{constructor(e,t){super(e,Object.assign({},md.defaultOptions,t)),this.isFrozen=!1,this.toggleFrozen=n=>{this.isFrozen=n.type==="dragstart"},this.hoverElement=n=>{if(!this.validate(n))return;const i=n.type===se.POINTER_ENTER;this.updateElementsState(n,i);const{onHover:a,onHoverEnd:s}=this.options;i?a==null||a(n):s==null||s(n)},this.updateElementsState=(n,i)=>{if(!this.options.state&&!this.options.inactiveState)return;const{graph:a}=this.context,{state:s,animation:o,inactiveState:A}=this.options,l=this.getActiveIds(n),c={};if(s&&Object.assign(c,this.getElementsState(l,s,i)),A){const u=iL(a.getData(),!0).filter(h=>!l.includes(h));Object.assign(c,this.getElementsState(u,A,i))}a.setElementState(c,o)},this.getElementsState=(n,i,a)=>{const{graph:s}=this.context,o={};return n.forEach(A=>{const l=s.getElementState(A);a?o[A]=l.includes(i)?l:[...l,i]:o[A]=l.filter(c=>c!==i)}),o},this.bindEvents()}bindEvents(){const{graph:e}=this.context;this.unbindEvents(),Ws.forEach(n=>{e.on(`${n}:${se.POINTER_ENTER}`,this.hoverElement),e.on(`${n}:${se.POINTER_LEAVE}`,this.hoverElement)});const t=this.context.canvas.document;t.addEventListener(`${se.DRAG_START}`,this.toggleFrozen),t.addEventListener(`${se.DRAG_END}`,this.toggleFrozen)}getActiveIds(e){const{graph:t}=this.context,{degree:n,direction:i}=this.options,a=e.target.id;return n?vL(t,e.targetType,a,typeof n=="function"?n(e):n,i):[a]}validate(e){if(this.destroyed||this.isFrozen||Gl(e.target)||this.context.graph.isCollapsingExpanding)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}unbindEvents(){const{graph:e}=this.context;Ws.forEach(n=>{e.off(`${n}:${se.POINTER_ENTER}`,this.hoverElement),e.off(`${n}:${se.POINTER_LEAVE}`,this.hoverElement)});const t=this.context.canvas.document;t.removeEventListener(`${se.DRAG_START}`,this.toggleFrozen),t.removeEventListener(`${se.DRAG_END}`,this.toggleFrozen)}destroy(){this.unbindEvents(),super.destroy()}}md.defaultOptions={animation:!1,enable:!0,degree:0,direction:"both",state:"active",inactiveState:void 0};class vW extends Nl{onPointerDown(e){if(!super.validate(e)||!super.isKeydown()||this.points)return;const{canvas:t,graph:n}=this.context;this.pathShape=new rr({id:"g6-lasso-select",style:this.options.style}),t.appendChild(this.pathShape),this.points=[ph(e,n)]}onPointerMove(e){var t;if(!this.points)return;const{immediately:n,mode:i}=this.options;this.points.push(ph(e,this.context.graph)),(t=this.pathShape)===null||t===void 0||t.setAttribute("d",fj(this.points)),n&&i==="default"&&this.points.length>2&&super.updateElementsStates(this.points)}onPointerUp(){if(this.points){if(this.points.length<2){this.clearLasso();return}super.updateElementsStates(this.points),this.clearLasso()}}clearLasso(){var e;(e=this.pathShape)===null||e===void 0||e.remove(),this.pathShape=void 0,this.points=void 0}}class wd extends zr{constructor(e,t){super(e,Object.assign({},wd.defaultOptions,t)),this.hiddenShapes=[],this.isVisible=!0,this.setElementsVisibility=(n,i,a)=>{n.filter(Boolean).forEach(s=>{i==="hidden"&&!s.isVisible()?this.hiddenShapes.push(s):i==="visible"&&this.hiddenShapes.includes(s)?this.hiddenShapes.splice(this.hiddenShapes.indexOf(s),1):Vs(s,i,a)})},this.filterShapes=(n,i)=>{if(Te(i))return s=>!i(n,s);const a=i==null?void 0:i[n];return s=>s.className?!(a!=null&&a.includes(s.className)):!0},this.hideShapes=n=>{if(!this.validate(n)||!this.isVisible)return;const{element:i}=this.context,{shapes:a={}}=this.options;this.setElementsVisibility(i.getNodes(),"hidden",this.filterShapes("node",a)),this.setElementsVisibility(i.getEdges(),"hidden",this.filterShapes("edge",a)),this.setElementsVisibility(i.getCombos(),"hidden",this.filterShapes("combo",a)),this.isVisible=!1},this.showShapes=Sl(n=>{if(!this.validate(n)||this.isVisible)return;const{element:i}=this.context;this.setElementsVisibility(i.getNodes(),"visible"),this.setElementsVisibility(i.getEdges(),"visible"),this.setElementsVisibility(i.getCombos(),"visible"),this.isVisible=!0},this.options.debounce),this.bindEvents()}bindEvents(){const{graph:e}=this.context;e.on(ge.BEFORE_TRANSFORM,this.hideShapes),e.on(ge.AFTER_TRANSFORM,this.showShapes)}unbindEvents(){const{graph:e}=this.context;e.off(ge.BEFORE_TRANSFORM,this.hideShapes),e.off(ge.AFTER_TRANSFORM,this.showShapes)}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}update(e){this.unbindEvents(),super.update(e),this.bindEvents()}destroy(){this.unbindEvents(),super.destroy()}}wd.defaultOptions={enable:!0,debounce:200,shapes:r=>r==="node"};var qx=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class Bd extends zr{constructor(e,t){super(e,Object.assign({},Bd.defaultOptions,t)),this.onWheel=n=>qx(this,void 0,void 0,function*(){this.options.preventDefault&&n.preventDefault();const i=n.deltaX,a=n.deltaY;yield this.scroll([-i,-a],n)}),this.shortcut=new ss(e.graph),this.bindEvents()}update(e){super.update(e),this.bindEvents()}bindEvents(){var e,t;const{trigger:n}=this.options;if(this.shortcut.unbindAll(),un(n)){(e=this.graphDom)===null||e===void 0||e.removeEventListener(se.WHEEL,this.onWheel);const{up:i=[],down:a=[],left:s=[],right:o=[]}=n;this.shortcut.bind(i,A=>this.scroll([0,-10],A)),this.shortcut.bind(a,A=>this.scroll([0,10],A)),this.shortcut.bind(s,A=>this.scroll([-10,0],A)),this.shortcut.bind(o,A=>this.scroll([10,0],A))}else(t=this.graphDom)===null||t===void 0||t.addEventListener(se.WHEEL,this.onWheel,{passive:!1})}get graphDom(){return this.context.graph.getCanvas().getContextService().getDomElement()}formatDisplacement(e){const{sensitivity:t}=this.options;return e=vi(e,t),e=this.clampByDirection(e),e=this.clampByRange(e),e}clampByDirection([e,t]){const{direction:n}=this.options;return n==="x"?t=0:n==="y"&&(e=0),[e,t]}clampByRange([e,t]){const{viewport:n,canvas:i}=this.context,[a,s]=i.getSize(),[o,A,l,c]=ai(this.options.range),u=[s*o,a*A,s*l,a*c],h=as(gB(n.getCanvasCenter()),u),d=bt(n.getViewportCenter(),[e,t,0]);if(!wi(d,h)){const{min:[f,g],max:[v,p]}=h;(d[0]<f&&e>0||d[0]>v&&e<0)&&(e=0),(d[1]<g&&t>0||d[1]>p&&t<0)&&(t=0)}return[e,t]}scroll(e,t){return qx(this,void 0,void 0,function*(){if(!this.validate(t))return;const{onFinish:n}=this.options,i=this.context.graph,a=this.formatDisplacement(e);yield i.translateBy(a,!1),n==null||n()})}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}destroy(){var e;this.shortcut.destroy(),(e=this.graphDom)===null||e===void 0||e.removeEventListener(se.WHEEL,this.onWheel),super.destroy()}}Bd.defaultOptions={enable:!0,sensitivity:1,preventDefault:!0,range:1/0};var $x=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class bd extends zr{constructor(e,t){super(e,Object.assign({},bd.defaultOptions,t)),this.zoom=(n,i,a)=>$x(this,void 0,void 0,function*(){if(!this.validate(i))return;const{graph:s}=this.context;let o=this.options.origin;!o&&"viewport"in i&&(o=Hn(i.viewport));const{sensitivity:A,onFinish:l}=this.options,c=1+Yt(n,-50,50)*A/100,u=s.getZoom();yield s.zoomTo(u*c,a,o),l==null||l()}),this.onReset=()=>$x(this,void 0,void 0,function*(){yield this.context.graph.zoomTo(1,this.options.animation)}),this.preventDefault=n=>{this.options.preventDefault&&n.preventDefault()},this.shortcut=new ss(e.graph),this.bindEvents()}update(e){super.update(e),this.bindEvents()}bindEvents(){const{trigger:e}=this.options;if(this.shortcut.unbindAll(),Array.isArray(e))if(e.includes(se.PINCH))this.shortcut.bind([se.PINCH],t=>{this.zoom(t.scale,t,!1)});else{const t=this.context.canvas.getContainer();t==null||t.addEventListener(se.WHEEL,this.preventDefault),this.shortcut.bind([...e,se.WHEEL],n=>{const{deltaX:i,deltaY:a}=n;this.zoom(-(a??i),n,!1)})}if(typeof e=="object"){const{zoomIn:t=[],zoomOut:n=[],reset:i=[]}=e;this.shortcut.bind(t,a=>this.zoom(10,a,this.options.animation)),this.shortcut.bind(n,a=>this.zoom(-10,a,this.options.animation)),this.shortcut.bind(i,this.onReset)}}validate(e){if(this.destroyed)return!1;const{enable:t}=this.options;return Te(t)?t(e):!!t}destroy(){var e;this.shortcut.destroy(),(e=this.context.canvas.getContainer())===null||e===void 0||e.removeEventListener(se.WHEEL,this.preventDefault),super.destroy()}}bd.defaultOptions={animation:{duration:200},enable:!0,sensitivity:1,trigger:[],preventDefault:!0};function Yx(r,e,t,n="height"){const i=r[n],a=e[n];return t==="center"?(i+a)/2:r.height}const eo=Object.assign,pW={getId:r=>r.id||r.name,getPreH:r=>r.preH||0,getPreV:r=>r.preV||0,getHGap:r=>r.hgap||18,getVGap:r=>r.vgap||18,getChildren:r=>r.children,getHeight:r=>r.height||36,getWidth(r){const e=r.label||" ";return r.width||18*e.split("").length}};class Eh{constructor(e,t){if(this.x=0,this.y=0,this.depth=0,this.children=[],this.hgap=0,this.vgap=0,e instanceof Eh||"x"in e&&"y"in e&&"children"in e){const a=e;return this.data=a.data,this.id=a.id,this.x=a.x,this.y=a.y,this.width=a.width,this.height=a.height,this.depth=a.depth,this.children=a.children,this.parent=a.parent,this.hgap=a.hgap,this.vgap=a.vgap,this.preH=a.preH,void(this.preV=a.preV)}this.data=e;const n=t.getHGap(e),i=t.getVGap(e);this.preH=t.getPreH(e),this.preV=t.getPreV(e),this.width=t.getWidth(e),this.height=t.getHeight(e),this.width+=this.preH,this.height+=this.preV,this.id=t.getId(e),this.addGap(n,i)}isRoot(){return this.depth===0}isLeaf(){return this.children.length===0}addGap(e,t){this.hgap+=e,this.vgap+=t,this.width+=2*e,this.height+=2*t}eachNode(e){let t,n=[this];for(;t=n.shift();)e(t),n=t.children.concat(n)}DFTraverse(e){this.eachNode(e)}BFTraverse(e){let t,n=[this];for(;t=n.shift();)e(t),n=n.concat(t.children)}getBoundingBox(){const e={left:Number.MAX_VALUE,top:Number.MAX_VALUE,width:0,height:0};return this.eachNode(t=>{e.left=Math.min(e.left,t.x),e.top=Math.min(e.top,t.y),e.width=Math.max(e.width,t.x+t.width),e.height=Math.max(e.height,t.y+t.height)}),e}translate(e=0,t=0){this.eachNode(n=>{n.x+=e,n.y+=t,n.x+=n.preH,n.y+=n.preV})}right2left(){const e=this.getBoundingBox();this.eachNode(t=>{t.x=t.x-2*(t.x-e.left)-t.width}),this.translate(e.width,0)}bottom2top(){const e=this.getBoundingBox();this.eachNode(t=>{t.y=t.y-2*(t.y-e.top)-t.height}),this.translate(0,e.height)}}function v1(r,e={},t){e=eo({},pW,e);const n=new Eh(r,e),i=[n];let a;if(!t&&!r.collapsed){for(;a=i.shift();)if(!a.data.collapsed){const s=e.getChildren(a.data),o=s?s.length:0;if(a.children=new Array(o),s&&o)for(let A=0;A<o;A++){const l=new Eh(s[A],e);a.children[A]=l,i.push(l),l.parent=a,l.depth=a.depth+1}}}return n}class Ed{constructor(e,t={}){this.options=t,this.rootNode=v1(e,t)}execute(){throw new Error("please override this method")}}let yW=class ku{constructor(e=0,t=0,n=0,i=[]){this.x=0,this.prelim=0,this.mod=0,this.shift=0,this.change=0,this.tl=null,this.tr=null,this.el=null,this.er=null,this.msel=0,this.mser=0,this.w=e||0,this.h=t||0,this.y=n||0,this.c=i||[],this.cs=i.length}static fromNode(e,t){if(!e)return null;const n=[];return e.children.forEach(i=>{const a=ku.fromNode(i,t);a&&n.push(a)}),t?new ku(e.height,e.width,e.x,n):new ku(e.width,e.height,e.y,n)}};function VL(r,e,t){t?r.y+=e:r.x+=e,r.children.forEach(n=>{VL(n,e,t)})}function jL(r,e){let t=e?r.y:r.x;return r.children.forEach(n=>{t=Math.min(jL(n,e),t)}),t}function mW(r,e){VL(r,-jL(r,e),e)}function WL(r,e,t){t?e.y=r.x:e.x=r.x,r.c.forEach((n,i)=>{WL(n,e.children[i],t)})}function qL(r,e,t=0){e?(r.x=t,t+=r.width):(r.y=t,t+=r.height),r.children.forEach(n=>{qL(n,e,t)})}function wW(r,e={}){const t=e.isHorizontal;function n(u){u.cs===0?(u.el=u,u.er=u,u.msel=u.mser=0):(u.el=u.c[0].el,u.msel=u.c[0].msel,u.er=u.c[u.cs-1].er,u.mser=u.c[u.cs-1].mser)}function i(u,h,d){let f=u.c[h-1],g=f.mod,v=u.c[h],p=v.mod;for(;f!==null&&v!==null;){d&&A(f)>d.low&&(d=d.nxt);const y=g+f.prelim+f.w-(p+v.prelim);y>0&&(p+=y,d&&a(u,h,d.index,y));const m=A(f),B=A(v);m<=B&&(f=o(f),f!==null&&(g+=f.mod)),m>=B&&(v=s(v),v!==null&&(p+=v.mod))}!f&&v?(function(y,m,B,C){const S=y.c[0].el;S.tl=B;const F=C-B.mod-y.c[0].msel;S.mod+=F,S.prelim-=F,y.c[0].el=y.c[m].el,y.c[0].msel=y.c[m].msel})(u,h,v,p):f&&!v&&(function(y,m,B,C){const S=y.c[m].er;S.tr=B;const F=C-B.mod-y.c[m].mser;S.mod+=F,S.prelim-=F,y.c[m].er=y.c[m-1].er,y.c[m].mser=y.c[m-1].mser})(u,h,f,g)}function a(u,h,d,f){u.c[h].mod+=f,u.c[h].msel+=f,u.c[h].mser+=f,(function(g,v,p,y){if(p!==v-1){const m=v-p;g.c[p+1].shift+=y/m,g.c[v].shift-=y/m,g.c[v].change-=y-y/m}})(u,h,d,f)}function s(u){return u.cs===0?u.tl:u.c[0]}function o(u){return u.cs===0?u.tr:u.c[u.cs-1]}function A(u){return u.y+u.h}function l(u,h,d){for(;d!==null&&u>=d.low;)d=d.nxt;return{low:u,index:h,nxt:d}}qL(r,t);const c=yW.fromNode(r,t);return c&&((function u(h){if(h.cs===0)return void n(h);u(h.c[0]);let d=l(A(h.c[0].el),0,null);for(let f=1;f<h.cs;++f){u(h.c[f]);const g=A(h.c[f].er);i(h,f,d),d=l(g,f,d)}(function(f){f.prelim=(f.c[0].prelim+f.c[0].mod+f.c[f.cs-1].mod+f.c[f.cs-1].prelim+f.c[f.cs-1].w)/2-f.w/2})(h),n(h)})(c),(function u(h,d){d+=h.mod,h.x=h.prelim+d,(function(f){let g=0,v=0;for(let p=0;p<f.cs;p++)g+=f.c[p].shift,v+=g+f.c[p].change,f.c[p].mod+=v})(h);for(let f=0;f<h.cs;f++)u(h.c[f],d)})(c,0),WL(c,r,t),mW(r,t)),r}function $L(r,e){const t=v1(r.data,e,!0),n=v1(r.data,e,!0),i=r.children.length,a=Math.round(i/2),s=e.getSide||function(o,A){return A<a?"right":"left"};for(let o=0;o<i;o++){const A=r.children[o];s(A,o)==="right"?n.children.push(A):t.children.push(A)}return t.eachNode(o=>{o.isRoot()||(o.side="left")}),n.eachNode(o=>{o.isRoot()||(o.side="right")}),{left:t,right:n}}const Ta=["LR","RL","TB","BT","H","V"],BW=["LR","RL","H"],bW=Ta[0];function OB(r,e,t){const n=e.direction||bW;if(e.isHorizontal=(a=>BW.indexOf(a)>-1)(n),Ta.indexOf(n)===-1)throw new TypeError(`Invalid direction: ${n}`);if(n===Ta[0])t(r,e);else if(n===Ta[1])t(r,e),r.right2left();else if(n===Ta[2])t(r,e);else if(n===Ta[3])t(r,e),r.bottom2top();else if(n===Ta[4]||n===Ta[5]){const{left:a,right:s}=$L(r,e);t(a,e),t(s,e),e.isHorizontal?a.right2left():a.bottom2top(),s.translate(a.x-s.x,a.y-s.y),r.x=a.x,r.y=s.y;const o=r.getBoundingBox();e.isHorizontal?o.top<0&&r.translate(0,-o.top):o.left<0&&r.translate(-o.left,0)}let i=e.fixedRoot;return i===void 0&&(i=!0),i&&r.translate(-(r.x+r.width/2+r.hgap),-(r.y+r.height/2+r.vgap)),(function(a,s){if(s.radial){const[o,A]=s.isHorizontal?["x","y"]:["y","x"],l={x:1/0,y:1/0},c={x:-1/0,y:-1/0};let u=0;a.DFTraverse(f=>{u++;const{x:g,y:v}=f;l.x=Math.min(l.x,g),l.y=Math.min(l.y,v),c.x=Math.max(c.x,g),c.y=Math.max(c.y,v)});const h=c[A]-l[A];if(h===0)return;const d=2*Math.PI/u;a.DFTraverse(f=>{const g=f[A],v=l[A],p=f[o],y=a[o],m=(g-v)/h*(2*Math.PI-d)+d,B=p-y;f.x=Math.cos(m)*B,f.y=Math.sin(m)*B})}})(r,e),r}let EW=class extends Ed{execute(){return OB(this.rootNode,this.options,wW)}};const xW={};function CW(r,e){const t=eo({},xW,e);return new EW(r,t).execute()}let SW=class{constructor(e=0,t=[]){this.x=0,this.y=0,this.leftChild=null,this.rightChild=null,this.isLeaf=!1,this.height=e,this.children=t}};const FW={isHorizontal:!0,nodeSep:20,nodeSize:20,rankSep:200,subTreeSep:10};function YL(r,e,t){t?(e.x=r.x,e.y=r.y):(e.x=r.y,e.y=r.x),r.children.forEach((n,i)=>{YL(n,e.children[i],t)})}function TW(r,e={}){const t=eo({},FW,e);let n=0,i=null;const a=(function s(o){o.width=0,o.depth&&o.depth>n&&(n=o.depth);const A=o.children,l=A.length,c=new SW(0,[]);return A.forEach((u,h)=>{const d=s(u);c.children.push(d),h===0&&(c.leftChild=d),h===l-1&&(c.rightChild=d)}),c.originNode=o,c.isLeaf=o.isLeaf(),c})(r);return(function s(o){if(o.isLeaf||o.children.length===0)o.drawingDepth=n;else{const A=o.children.map(c=>s(c)),l=Math.min(...A);o.drawingDepth=l-1}return o.drawingDepth})(a),(function s(o){o.x=o.drawingDepth*t.rankSep,o.isLeaf?(o.y=0,i&&(o.y=i.y+i.height+t.nodeSep,o.originNode.parent!==i.originNode.parent&&(o.y+=t.subTreeSep)),i=o):(o.children.forEach(A=>{s(A)}),o.y=(o.leftChild.y+o.rightChild.y)/2)})(a),YL(a,r,t.isHorizontal),r}class MW extends Ed{execute(){return this.rootNode.width=0,OB(this.rootNode,this.options,TW)}}const OW={};function _W(r,e){const t=eo({},OW,e);return new MW(r,t).execute()}function hu(r,e,t,n){let i=null;r.eachNode(a=>{(function(s,o,A,l,c){const u=(typeof A=="function"?A(s):A)*s.depth;if(!l)try{if(s.parent&&s.id===s.parent.children[0].id)return s.x+=u,void(s.y=o?o.y:0)}catch{}if(s.x+=u,o){if(s.y=o.y+Yx(o,s,c),o.parent&&s.parent&&s.parent.id!==o.parent.id){const h=o.parent,d=h.y+Yx(h,s,c);s.y=d>s.y?d:s.y}}else s.y=0})(a,i,e,t,n),i=a})}const PA=["LR","RL","H"],IW=PA[0];class kW extends Ed{execute(){const e=this.options,t=this.rootNode;e.isHorizontal=!0;const{indent:n=20,dropCap:i=!0,direction:a=IW,align:s}=e;if(a&&PA.indexOf(a)===-1)throw new TypeError(`Invalid direction: ${a}`);if(a===PA[0])hu(t,n,i,s);else if(a===PA[1])hu(t,n,i,s),t.right2left();else if(a===PA[2]){const{left:o,right:A}=$L(t,e);hu(o,n,i,s),o.right2left(),hu(A,n,i,s);const l=o.getBoundingBox();A.translate(l.width,0),t.x=A.x-t.width/2}return t}}const LW={};function QW(r,e){const t=eo({},LW,e);return new kW(r,t).execute()}function XL(r,e){let t=0;return r.children.length?r.children.forEach(n=>{t+=XL(n,e)}):t=r.height,r._subTreeSep=e.getSubTreeSep(r.data),r.totalHeight=Math.max(r.height,t)+2*r._subTreeSep,r.totalHeight}function ZL(r){const e=r.children,t=e.length;if(t){e.forEach(o=>{ZL(o)});const n=e[0],i=e[t-1],a=i.y-n.y+i.height;let s=0;if(e.forEach(o=>{s+=o.totalHeight}),a>r.height)r.y=n.y+a/2-r.height/2;else if(e.length!==1||r.height>s){const o=r.y+(r.height-a)/2-n.y;e.forEach(A=>{A.translate(0,o)})}else r.y=(n.y+n.height/2+i.y+i.height/2)/2-r.height/2}}const NW={getSubTreeSep:()=>0};function UW(r,e={}){return e=eo({},NW,e),r.parent={x:0,width:0,height:0,y:0},r.BFTraverse(t=>{t.x=t.parent.x+t.parent.width}),r.parent=void 0,XL(r,e),r.startY=0,r.y=r.totalHeight/2-r.height/2,r.eachNode(t=>{const n=t.children,i=n.length;if(i){const a=n[0];if(a.startY=t.startY+t._subTreeSep,i===1)a.y=t.y+t.height/2-a.height/2;else{a.y=a.startY+a.totalHeight/2-a.height/2;for(let s=1;s<i;s++){const o=n[s];o.startY=n[s-1].startY+n[s-1].totalHeight,o.y=o.startY+o.totalHeight/2-o.height/2}}}}),ZL(r),r}class PW extends Ed{execute(){return OB(this.rootNode,this.options,UW)}}const RW={};function DW(r,e){const t=eo({},RW,e);return new PW(r,t).execute()}const HW=(r,e)=>{if(r!=="next"&&r!=="prev")return e},Xx=r=>{r.prev.next=r.next,r.next.prev=r.prev,delete r.next,delete r.prev};let GW=class{constructor(){const e={};e.prev=e,e.next=e.prev,this.shortcut=e}dequeue(){const e=this.shortcut,t=e.prev;if(t&&t!==e)return Xx(t),t}enqueue(e){const t=this.shortcut;e.prev&&e.next&&Xx(e),e.next=t.next,t.next.prev=e,t.next=e,e.prev=t}toString(){const e=[],t=this.shortcut;let n=t.prev;for(;n!==t;)e.push(JSON.stringify(n,HW)),n=n==null?void 0:n.prev;return`[${e.join(", ")}]`}};class KW extends GW{}const zW=()=>1,VW=(r,e)=>{var t;if(r.getAllNodes().length<=1)return[];const n=WW(r,e||zW);return(t=jW(n.graph,n.buckets,n.zeroIdx).map(a=>r.getRelatedEdges(a.v,"out").filter(({target:s})=>s===a.w)))===null||t===void 0?void 0:t.flat()},jW=(r,e,t)=>{let n=[];const i=e[e.length-1],a=e[0];let s;for(;r.getAllNodes().length;){for(;s=a.dequeue();)xg(r,e,t,s);for(;s=i.dequeue();)xg(r,e,t,s);if(r.getAllNodes().length){for(let o=e.length-2;o>0;--o)if(s=e[o].dequeue(),s){n=n.concat(xg(r,e,t,s,!0));break}}}return n},xg=(r,e,t,n,i)=>{var a,s;const o=[];return r.hasNode(n.v)&&((a=r.getRelatedEdges(n.v,"in"))===null||a===void 0||a.forEach(A=>{const l=A.data.weight,c=r.getNode(A.source);i&&o.push({v:A.source,w:A.target,in:0,out:0}),c.data.out===void 0&&(c.data.out=0),c.data.out-=l,p1(e,t,Object.assign({v:c.id},c.data))}),(s=r.getRelatedEdges(n.v,"out"))===null||s===void 0||s.forEach(A=>{const l=A.data.weight,c=A.target,u=r.getNode(c);u.data.in===void 0&&(u.data.in=0),u.data.in-=l,p1(e,t,Object.assign({v:u.id},u.data))}),r.removeNode(n.v)),i?o:void 0},WW=(r,e)=>{const t=new Mn;let n=0,i=0;r.getAllNodes().forEach(A=>{t.addNode({id:A.id,data:{v:A.id,in:0,out:0}})}),r.getAllEdges().forEach(A=>{const l=t.getRelatedEdges(A.source,"out").find(u=>u.target===A.target),c=(e==null?void 0:e(A))||1;l?t.updateEdgeData(l==null?void 0:l.id,Object.assign(Object.assign({},l.data),{weight:l.data.weight+c})):t.addEdge({id:A.id,source:A.source,target:A.target,data:{weight:c}}),i=Math.max(i,t.getNode(A.source).data.out+=c),n=Math.max(n,t.getNode(A.target).data.in+=c)});const a=[],s=i+n+3;for(let A=0;A<s;A++)a.push(new KW);const o=n+1;return t.getAllNodes().forEach(A=>{p1(a,o,Object.assign({v:A.id},t.getNode(A.id).data))}),{buckets:a,zeroIdx:o,graph:t}},p1=(r,e,t)=>{t.out?t.in?r[t.out-t.in+e].enqueue(t):r[r.length-1].enqueue(t):r[0].enqueue(t)},qW=(r,e)=>{const n=VW(r,(i=>a=>a.data.weight||1)());n==null||n.forEach(i=>{const a=i.data;r.removeEdge(i.id),a.forwardName=i.data.name,a.reversed=!0,r.addEdge({id:i.id,source:i.target,target:i.source,data:Object.assign({},a)})})},$W=r=>{r.getAllEdges().forEach(e=>{const t=e.data;if(t.reversed){r.removeEdge(e.id);const n=t.forwardName;delete t.reversed,delete t.forwardName,r.addEdge({id:e.id,source:e.target,target:e.source,data:Object.assign(Object.assign({},t),{forwardName:n})})}})},YW=(r,e)=>Number(r)-Number(e),eA=(r,e,t,n)=>{let i;do i=`${n}${Math.random()}`;while(r.hasNode(i));return t.dummy=e,r.addNode({id:i,data:t}),i},XW=r=>{const e=new Mn;return r.getAllNodes().forEach(t=>{e.addNode(Object.assign({},t))}),r.getAllEdges().forEach(t=>{const n=e.getRelatedEdges(t.source,"out").find(i=>i.target===t.target);n?e.updateEdgeData(n==null?void 0:n.id,Object.assign(Object.assign({},n.data),{weight:n.data.weight+t.data.weight||0,minlen:Math.max(n.data.minlen,t.data.minlen||1)})):e.addEdge({id:t.id,source:t.source,target:t.target,data:{weight:t.data.weight||0,minlen:t.data.minlen||1}})}),e},JL=r=>{const e=new Mn;return r.getAllNodes().forEach(t=>{r.getChildren(t.id).length||e.addNode(Object.assign({},t))}),r.getAllEdges().forEach(t=>{e.addEdge(t)}),e},ZW=(r,e)=>r==null?void 0:r.reduce((t,n,i)=>(t[n]=e[i],t),{}),Zx=(r,e)=>{const t=Number(r.x),n=Number(r.y),i=Number(e.x)-t,a=Number(e.y)-n;let s=Number(r.width)/2,o=Number(r.height)/2;if(!i&&!a)return{x:0,y:0};let A,l;return Math.abs(a)*s>Math.abs(i)*o?(a<0&&(o=-o),A=o*i/a,l=o):(i<0&&(s=-s),A=s,l=s*a/i),{x:t+A,y:n+l}},wl=r=>{const e=[],t=eQ(r)+1;for(let n=0;n<t;n++)e.push([]);r.getAllNodes().forEach(n=>{const i=n.data.rank;i!==void 0&&e[i]&&e[i].push(n.id)});for(let n=0;n<t;n++)e[n]=e[n].sort((i,a)=>YW(r.getNode(i).data.order,r.getNode(a).data.order));return e},JW=r=>{const e=r.getAllNodes().filter(n=>n.data.rank!==void 0).map(n=>n.data.rank),t=Math.min(...e);r.getAllNodes().forEach(n=>{n.data.hasOwnProperty("rank")&&t!==1/0&&(n.data.rank-=t)})},eq=(r,e=0)=>{const t=r.getAllNodes(),n=t.filter(o=>o.data.rank!==void 0).map(o=>o.data.rank),i=Math.min(...n),a=[];t.forEach(o=>{const A=(o.data.rank||0)-i;a[A]||(a[A]=[]),a[A].push(o.id)});let s=0;for(let o=0;o<a.length;o++){const A=a[o];A===void 0?o%e!==0&&(s-=1):s&&(A==null||A.forEach(l=>{const c=r.getNode(l);c&&(c.data.rank=c.data.rank||0,c.data.rank+=s)}))}},Jx=(r,e,t,n)=>{const i={width:0,height:0};return Be(t)&&Be(n)&&(i.rank=t,i.order=n),eA(r,"border",i,e)},eQ=r=>{let e;return r.getAllNodes().forEach(t=>{const n=t.data.rank;n!==void 0&&(e===void 0||n>e)&&(e=n)}),e||(e=0),e},tq=(r,e)=>{const t={lhs:[],rhs:[]};return r==null||r.forEach(n=>{e(n)?t.lhs.push(n):t.rhs.push(n)}),t},_B=(r,e)=>r.reduce((t,n)=>{const i=e(t),a=e(n);return i>a?n:t}),tQ=(r,e,t,n,i,a)=>{n.includes(e.id)||(n.push(e.id),t||a.push(e.id),i(e.id).forEach(s=>tQ(r,s,t,n,i,a)),t&&a.push(e.id))},nQ=(r,e,t,n)=>{const i=Array.isArray(e)?e:[e],a=A=>r.getNeighbors(A),s=[],o=[];return i.forEach(A=>{if(r.hasNode(A.id))tQ(r,A,t==="post",o,a,s);else throw new Error(`Graph does not have node: ${A}`)}),s},nq=r=>{const e=t=>{const n=r.getChildren(t),i=r.getNode(t);if(n!=null&&n.length&&n.forEach(a=>e(a.id)),i.data.hasOwnProperty("minRank")){i.data.borderLeft=[],i.data.borderRight=[];for(let a=i.data.minRank,s=i.data.maxRank+1;a<s;a+=1)eC(r,"borderLeft","_bl",t,i,a),eC(r,"borderRight","_br",t,i,a)}};r.getRoots().forEach(t=>e(t.id))},eC=(r,e,t,n,i,a)=>{const s={rank:a,borderType:e,width:0,height:0},o=i.data[e][a-1],A=eA(r,"border",s,t);i.data[e][a]=A,r.setParent(A,n),o&&r.addEdge({id:`e${Math.random()}`,source:o,target:A,data:{weight:1}})},rq=(r,e)=>{const t=e.toLowerCase();(t==="lr"||t==="rl")&&rQ(r)},iq=(r,e)=>{const t=e.toLowerCase();(t==="bt"||t==="rl")&&aq(r),(t==="lr"||t==="rl")&&(sq(r),rQ(r))},rQ=r=>{r.getAllNodes().forEach(e=>{tC(e)}),r.getAllEdges().forEach(e=>{tC(e)})},tC=r=>{const e=r.data.width;r.data.width=r.data.height,r.data.height=e},aq=r=>{r.getAllNodes().forEach(e=>{Cg(e.data)}),r.getAllEdges().forEach(e=>{var t;(t=e.data.points)===null||t===void 0||t.forEach(n=>Cg(n)),e.data.hasOwnProperty("y")&&Cg(e.data)})},Cg=r=>{r!=null&&r.y&&(r.y=-r.y)},sq=r=>{r.getAllNodes().forEach(e=>{Sg(e.data)}),r.getAllEdges().forEach(e=>{var t;(t=e.data.points)===null||t===void 0||t.forEach(n=>Sg(n)),e.data.hasOwnProperty("x")&&Sg(e.data)})},Sg=r=>{const e=r.x;r.x=r.y,r.y=e},oq=r=>{const e=eA(r,"root",{},"_root"),t=Aq(r);let n=Math.max(...Object.values(t));Math.abs(n)===1/0&&(n=1);const i=n-1,a=2*i+1;r.getAllEdges().forEach(o=>{o.data.minlen*=a});const s=lq(r)+1;return r.getRoots().forEach(o=>{iQ(r,e,a,s,i,t,o.id)}),{nestingRoot:e,nodeRankFactor:a}},iQ=(r,e,t,n,i,a,s)=>{const o=r.getChildren(s);if(!(o!=null&&o.length)){s!==e&&r.addEdge({id:`e${Math.random()}`,source:e,target:s,data:{weight:0,minlen:t}});return}const A=Jx(r,"_bt"),l=Jx(r,"_bb"),c=r.getNode(s);r.setParent(A,s),c.data.borderTop=A,r.setParent(l,s),c.data.borderBottom=l,o==null||o.forEach(u=>{iQ(r,e,t,n,i,a,u.id);const h=u.data.borderTop?u.data.borderTop:u.id,d=u.data.borderBottom?u.data.borderBottom:u.id,f=u.data.borderTop?n:2*n,g=h!==d?1:i-a[s]+1;r.addEdge({id:`e${Math.random()}`,source:A,target:h,data:{minlen:g,weight:f,nestingEdge:!0}}),r.addEdge({id:`e${Math.random()}`,source:d,target:l,data:{minlen:g,weight:f,nestingEdge:!0}})}),r.getParent(s)||r.addEdge({id:`e${Math.random()}`,source:e,target:A,data:{weight:0,minlen:i+a[s]}})},Aq=r=>{const e={},t=(n,i)=>{const a=r.getChildren(n);a==null||a.forEach(s=>t(s.id,i+1)),e[n]=i};return r.getRoots().forEach(n=>t(n.id,1)),e},lq=r=>{let e=0;return r.getAllEdges().forEach(t=>{e+=t.data.weight}),e},cq=(r,e)=>{e&&r.removeNode(e),r.getAllEdges().forEach(t=>{t.data.nestingEdge&&r.removeEdge(t.id)})},uq="edge",aQ="edge-label",hq=(r,e)=>{r.getAllEdges().forEach(t=>dq(r,t,e))},dq=(r,e,t)=>{let n=e.source,i=r.getNode(n).data.rank;const a=e.target,s=r.getNode(a).data.rank,o=e.data.labelRank;if(s===i+1)return;r.removeEdge(e.id);let A,l,c;for(c=0,++i;i<s;++c,++i)e.data.points=[],l={originalEdge:e,width:0,height:0,rank:i},A=eA(r,uq,l,"_d"),i===o&&(l.width=e.data.width,l.height=e.data.height,l.dummy=aQ,l.labelpos=e.data.labelpos),r.addEdge({id:`e${Math.random()}`,source:n,target:A,data:{weight:e.data.weight}}),c===0&&t.push(A),n=A;r.addEdge({id:`e${Math.random()}`,source:n,target:a,data:{weight:e.data.weight}})},fq=(r,e)=>{e.forEach(t=>{let n=r.getNode(t);const{data:i}=n,a=i.originalEdge;let s;a&&r.addEdge(a);let o=t;for(;n.data.dummy;)s=r.getSuccessors(o)[0],r.removeNode(o),a.data.points.push({x:n.data.x,y:n.data.y}),n.data.dummy===aQ&&(a.data.x=n.data.x,a.data.y=n.data.y,a.data.width=n.data.width,a.data.height=n.data.height),o=s.id,n=r.getNode(o)})},gq=(r,e,t)=>{const n={};let i;t==null||t.forEach(a=>{let s=r.getParent(a),o,A;for(;s;){if(o=r.getParent(s.id),o?(A=n[o.id],n[o.id]=s.id):(A=i,i=s.id),A&&A!==s.id){e.hasNode(A)||e.addNode({id:A,data:{}}),e.hasNode(s.id)||e.addNode({id:s.id,data:{}}),e.hasEdge(`e${A}-${s.id}`)||e.addEdge({id:`e${A}-${s.id}`,source:A,target:s.id,data:{}});return}s=o}})},vq=(r,e,t)=>{const n=pq(r),i=new Mn({tree:[{id:n,children:[],data:{}}]});return r.getAllNodes().forEach(a=>{const s=r.getParent(a.id);(a.data.rank===e||a.data.minRank<=e&&e<=a.data.maxRank)&&(i.hasNode(a.id)||i.addNode(Object.assign({},a)),s!=null&&s.id&&!i.hasNode(s==null?void 0:s.id)&&i.addNode(Object.assign({},s)),i.setParent(a.id,(s==null?void 0:s.id)||n),r.getRelatedEdges(a.id,t).forEach(o=>{const A=o.source===a.id?o.target:o.source;i.hasNode(A)||i.addNode(Object.assign({},r.getNode(A)));const l=i.getRelatedEdges(A,"out").find(({target:u})=>u===a.id),c=l!==void 0?l.data.weight:0;l?i.updateEdgeData(l.id,Object.assign(Object.assign({},l.data),{weight:o.data.weight+c})):i.addEdge({id:o.id,source:A,target:a.id,data:{weight:o.data.weight+c}})}),a.data.hasOwnProperty("minRank")&&i.updateNodeData(a.id,Object.assign(Object.assign({},a.data),{borderLeft:a.data.borderLeft[e],borderRight:a.data.borderRight[e]})))}),i},pq=r=>{let e;for(;r.hasNode(e=`_root${Math.random()}`););return e},yq=(r,e,t)=>{const n=ZW(t,t.map((c,u)=>u)),a=e.map(c=>{const u=r.getRelatedEdges(c,"out").map(h=>({pos:n[h.target]||0,weight:h.data.weight}));return u==null?void 0:u.sort((h,d)=>h.pos-d.pos)}).flat().filter(c=>c!==void 0);let s=1;for(;s<t.length;)s<<=1;const o=2*s-1;s-=1;const A=Array(o).fill(0,0,o);let l=0;return a==null||a.forEach(c=>{if(c){let u=c.pos+s;A[u]+=c.weight;let h=0;for(;u>0;)u%2&&(h+=A[u+1]),u=u-1>>1,A[u]+=c.weight;l+=c.weight*h}}),l},nC=(r,e)=>{let t=0;for(let n=1;n<(e==null?void 0:e.length);n+=1)t+=yq(r,e[n-1],e[n]);return t},rC=r=>{const e={},t=r.getAllNodes(),n=t.map(l=>{var c;return(c=l.data.rank)!==null&&c!==void 0?c:-1/0}),i=Math.max(...n),a=[];for(let l=0;l<i+1;l++)a.push([]);const s=t.sort((l,c)=>r.getNode(l.id).data.rank-r.getNode(c.id).data.rank),A=s.filter(l=>r.getNode(l.id).data.fixorder!==void 0).sort((l,c)=>r.getNode(l.id).data.fixorder-r.getNode(c.id).data.fixorder);return A==null||A.forEach(l=>{isNaN(r.getNode(l.id).data.rank)||a[r.getNode(l.id).data.rank].push(l.id),e[l.id]=!0}),s==null||s.forEach(l=>r.dfsTree(l.id,c=>{if(e.hasOwnProperty(c.id))return!0;e[c.id]=!0,isNaN(c.data.rank)||a[c.data.rank].push(c.id)})),a},mq=(r,e)=>e.map(t=>{const n=r.getRelatedEdges(t,"in");if(!(n!=null&&n.length))return{v:t};const i={sum:0,weight:0};return n==null||n.forEach(a=>{const s=r.getNode(a.source);i.sum+=a.data.weight*s.data.order,i.weight+=a.data.weight}),{v:t,barycenter:i.sum/i.weight,weight:i.weight}}),wq=(r,e)=>{var t,n,i;const a={};r==null||r.forEach((o,A)=>{a[o.v]={i:A,indegree:0,in:[],out:[],vs:[o.v]};const l=a[o.v];o.barycenter!==void 0&&(l.barycenter=o.barycenter,l.weight=o.weight)}),(t=e.getAllEdges())===null||t===void 0||t.forEach(o=>{const A=a[o.source],l=a[o.target];A!==void 0&&l!==void 0&&(l.indegree++,A.out.push(a[o.target]))});const s=(i=(n=Object.values(a)).filter)===null||i===void 0?void 0:i.call(n,o=>!o.indegree);return Bq(s)},Bq=r=>{var e,t;const n=[],i=A=>l=>{l.merged||(l.barycenter===void 0||A.barycenter===void 0||l.barycenter>=A.barycenter)&&bq(A,l)},a=A=>l=>{l.in.push(A),--l.indegree===0&&r.push(l)};for(;r!=null&&r.length;){const A=r.pop();n.push(A),(e=A.in.reverse())===null||e===void 0||e.forEach(l=>i(A)(l)),(t=A.out)===null||t===void 0||t.forEach(l=>a(A)(l))}const s=n.filter(A=>!A.merged),o=["vs","i","barycenter","weight"];return s.map(A=>{const l={};return o==null||o.forEach(c=>{A[c]!==void 0&&(l[c]=A[c])}),l})},bq=(r,e)=>{var t;let n=0,i=0;r.weight&&(n+=r.barycenter*r.weight,i+=r.weight),e.weight&&(n+=e.barycenter*e.weight,i+=e.weight),r.vs=(t=e.vs)===null||t===void 0?void 0:t.concat(r.vs),r.barycenter=n/i,r.weight=i,r.i=Math.min(e.i,r.i),e.merged=!0},Eq=(r,e,t,n)=>{const i=tq(r,h=>{const d=h.hasOwnProperty("fixorder")&&!isNaN(h.fixorder);return n?!d&&h.hasOwnProperty("barycenter"):d||h.hasOwnProperty("barycenter")}),a=i.lhs,s=i.rhs.sort((h,d)=>-h.i- -d.i),o=[];let A=0,l=0,c=0;a==null||a.sort(xq(!!e,!!t)),c=iC(o,s,c),a==null||a.forEach(h=>{var d;c+=(d=h.vs)===null||d===void 0?void 0:d.length,o.push(h.vs),A+=h.barycenter*h.weight,l+=h.weight,c=iC(o,s,c)});const u={vs:o.flat()};return l&&(u.barycenter=A/l,u.weight=l),u},iC=(r,e,t)=>{let n=t,i;for(;e.length&&(i=e[e.length-1]).i<=n;)e.pop(),r==null||r.push(i.vs),n++;return n},xq=(r,e)=>(t,n)=>{if(t.fixorder!==void 0&&n.fixorder!==void 0)return t.fixorder-n.fixorder;if(t.barycenter<n.barycenter)return-1;if(t.barycenter>n.barycenter)return 1;if(e&&t.order!==void 0&&n.order!==void 0){if(t.order<n.order)return-1;if(t.order>n.order)return 1}return r?n.i-t.i:t.i-n.i},sQ=(r,e,t,n,i,a)=>{var s,o,A,l;let c=r.getChildren(e).map(y=>y.id);const u=r.getNode(e),h=u?u.data.borderLeft:void 0,d=u?u.data.borderRight:void 0,f={};h&&(c=c==null?void 0:c.filter(y=>y!==h&&y!==d));const g=mq(r,c||[]);g==null||g.forEach(y=>{var m;if(!((m=r.getChildren(y.v))===null||m===void 0)&&m.length){const B=sQ(r,y.v,t,n,a);f[y.v]=B,B.hasOwnProperty("barycenter")&&Sq(y,B)}});const v=wq(g,t);Cq(v,f),(s=v.filter(y=>y.vs.length>0))===null||s===void 0||s.forEach(y=>{const m=r.getNode(y.vs[0]);m&&(y.fixorder=m.data.fixorder,y.order=m.data.order)});const p=Eq(v,n,i,a);if(h&&(p.vs=[h,p.vs,d].flat(),!((o=r.getPredecessors(h))===null||o===void 0)&&o.length)){const y=r.getNode(((A=r.getPredecessors(h))===null||A===void 0?void 0:A[0].id)||""),m=r.getNode(((l=r.getPredecessors(d))===null||l===void 0?void 0:l[0].id)||"");p.hasOwnProperty("barycenter")||(p.barycenter=0,p.weight=0),p.barycenter=(p.barycenter*p.weight+y.data.order+m.data.order)/(p.weight+2),p.weight+=2}return p},Cq=(r,e)=>{r==null||r.forEach(t=>{var n;const i=(n=t.vs)===null||n===void 0?void 0:n.map(a=>e[a]?e[a].vs:a);t.vs=i.flat()})},Sq=(r,e)=>{r.barycenter!==void 0?(r.barycenter=(r.barycenter*r.weight+e.barycenter*e.weight)/(r.weight+e.weight),r.weight+=e.weight):(r.barycenter=e.barycenter,r.weight=e.weight)},Fq=(r,e)=>{const t=eQ(r),n=[],i=[];for(let c=1;c<t+1;c++)n.push(c);for(let c=t-1;c>-1;c--)i.push(c);const a=aC(r,n,"in"),s=aC(r,i,"out");let o=rC(r);Fg(r,o);let A=Number.POSITIVE_INFINITY,l;for(let c=0,u=0;u<4;++c,++u){sC(c%2?a:s,c%4>=2,!1,e),o=wl(r);const h=nC(r,o);h<A&&(u=0,l=Za(o),A=h)}o=rC(r),Fg(r,o);for(let c=0,u=0;u<4;++c,++u){sC(c%2?a:s,c%4>=2,!0,e),o=wl(r);const h=nC(r,o);h<A&&(u=0,l=Za(o),A=h)}Fg(r,l)},aC=(r,e,t)=>e.map(n=>vq(r,n,t)),sC=(r,e,t,n)=>{const i=new Mn;r==null||r.forEach(a=>{var s;const o=a.getRoots()[0].id,A=sQ(a,o,i,e,t,n);for(let l=0;l<((s=A.vs)===null||s===void 0?void 0:s.length);l++){const c=a.getNode(A.vs[l]);c&&(c.data.order=l)}gq(a,i,A.vs)})},Fg=(r,e)=>{e==null||e.forEach(t=>{t==null||t.forEach((n,i)=>{r.getNode(n).data.order=i})})},Tq=(r,e)=>{const n=r.getAllNodes().filter(s=>{var o;return!(!((o=r.getChildren(s.id))===null||o===void 0)&&o.length)}).map(s=>s.data.rank),i=Math.max(...n),a=[];for(let s=0;s<i+1;s++)a[s]=[];e==null||e.forEach(s=>{const o=r.getNode(s);!o||o.data.dummy||isNaN(o.data.rank)||(o.data.fixorder=a[o.data.rank].length,a[o.data.rank].push(s))})},Mq=r=>{const e={};let t=0;const n=i=>{const a=t;r.getChildren(i).forEach(s=>n(s.id)),e[i]={low:a,lim:t++}};return r.getRoots().forEach(i=>n(i.id)),e},Oq=(r,e,t,n)=>{var i,a;const s=[],o=[],A=Math.min(e[t].low,e[n].low),l=Math.max(e[t].lim,e[n].lim);let c,u;c=t;do c=(i=r.getParent(c))===null||i===void 0?void 0:i.id,s.push(c);while(c&&(e[c].low>A||l>e[c].lim));for(u=c,c=n;c&&c!==u;)o.push(c),c=(a=r.getParent(c))===null||a===void 0?void 0:a.id;return{lca:u,path:s.concat(o.reverse())}},_q=(r,e)=>{const t=Mq(r);e.forEach(n=>{var i,a;let s=n,o=r.getNode(s);const A=o.data.originalEdge;if(!A)return;const l=Oq(r,t,A.source,A.target),c=l.path,u=l.lca;let h=0,d=c[h],f=!0;for(;s!==A.target;){if(o=r.getNode(s),f){for(;d!==u&&((i=r.getNode(d))===null||i===void 0?void 0:i.data.maxRank)<o.data.rank;)h++,d=c[h];d===u&&(f=!1)}if(!f){for(;h<c.length-1&&((a=r.getNode(c[h+1]))===null||a===void 0?void 0:a.data.minRank)<=o.data.rank;)h++;d=c[h]}r.hasNode(d)&&r.setParent(s,d),s=r.getSuccessors(s)[0].id}})},Iq=(r,e)=>{const t={},n=(i,a)=>{let s=0,o=0;const A=i.length,l=a==null?void 0:a[(a==null?void 0:a.length)-1];return a==null||a.forEach((c,u)=>{var h;const d=Lq(r,c),f=d?r.getNode(d.id).data.order:A;(d||c===l)&&((h=a.slice(o,u+1))===null||h===void 0||h.forEach(g=>{var v;(v=r.getPredecessors(g))===null||v===void 0||v.forEach(p=>{var y;const m=r.getNode(p.id),B=m.data.order;(B<s||f<B)&&!(m.data.dummy&&(!((y=r.getNode(g))===null||y===void 0)&&y.data.dummy))&&oQ(t,p.id,g)})}),o=u+1,s=f)}),a};return e!=null&&e.length&&e.reduce(n),t},kq=(r,e)=>{const t={};function n(o,A,l,c,u){var h,d;let f;for(let g=A;g<l;g++)f=o[g],!((h=r.getNode(f))===null||h===void 0)&&h.data.dummy&&((d=r.getPredecessors(f))===null||d===void 0||d.forEach(v=>{const p=r.getNode(v.id);p.data.dummy&&(p.data.order<c||p.data.order>u)&&oQ(t,v.id,f)}))}function i(o){return JSON.stringify(o.slice(1))}function a(o,A){const l=i(o);A.get(l)||(n(...o),A.set(l,!0))}const s=(o,A)=>{let l=-1,c,u=0;const h=new Map;return A==null||A.forEach((d,f)=>{var g;if(((g=r.getNode(d))===null||g===void 0?void 0:g.data.dummy)==="border"){const v=r.getPredecessors(d)||[];v.length&&(c=r.getNode(v[0].id).data.order,a([A,u,f,l,c],h),u=f,l=c)}a([A,u,A.length,c,o.length],h)}),A};return e!=null&&e.length&&e.reduce(s),t},Lq=(r,e)=>{var t,n;if(!((t=r.getNode(e))===null||t===void 0)&&t.data.dummy)return(n=r.getPredecessors(e))===null||n===void 0?void 0:n.find(i=>r.getNode(i.id).data.dummy)},oQ=(r,e,t)=>{let n=e,i=t;if(n>i){const s=n;n=i,i=s}let a=r[n];a||(r[n]=a={}),a[i]=!0},Qq=(r,e,t)=>{let n=e,i=t;if(n>i){const a=e;n=i,i=a}return!!r[n]},Nq=(r,e,t,n)=>{const i={},a={},s={};return e==null||e.forEach(o=>{o==null||o.forEach((A,l)=>{i[A]=A,a[A]=A,s[A]=l})}),e==null||e.forEach(o=>{let A=-1;o==null||o.forEach(l=>{let c=n(l).map(u=>u.id);if(c.length){c=c.sort((h,d)=>s[h]-s[d]);const u=(c.length-1)/2;for(let h=Math.floor(u),d=Math.ceil(u);h<=d;++h){const f=c[h];a[l]===l&&A<s[f]&&!Qq(t,l,f)&&(a[f]=l,a[l]=i[l]=i[f],A=s[f])}}})}),{root:i,align:a}},Uq=(r,e,t,n,i,a,s)=>{var o;const A={},l=Pq(r,e,t,i,a,s),c=s?"borderLeft":"borderRight",u=(f,g)=>{let v=l.getAllNodes(),p=v.pop();const y={};for(;p;)y[p.id]?f(p.id):(y[p.id]=!0,v.push(p),v=v.concat(g(p.id))),p=v.pop()},h=f=>{A[f]=(l.getRelatedEdges(f,"in")||[]).reduce((g,v)=>Math.max(g,(A[v.source]||0)+v.data.weight),0)},d=f=>{const g=(l.getRelatedEdges(f,"out")||[]).reduce((p,y)=>Math.min(p,(A[y.target]||0)-y.data.weight),Number.POSITIVE_INFINITY),v=r.getNode(f);g!==Number.POSITIVE_INFINITY&&v.data.borderType!==c&&(A[f]=Math.max(A[f],g))};return u(h,l.getPredecessors.bind(l)),u(d,l.getSuccessors.bind(l)),(o=Object.values(n))===null||o===void 0||o.forEach(f=>{A[f]=A[t[f]]}),A},Pq=(r,e,t,n,i,a)=>{const s=new Mn,o=Gq(n,i,a);return e==null||e.forEach(A=>{let l;A==null||A.forEach(c=>{const u=t[c];if(s.hasNode(u)||s.addNode({id:u,data:{}}),l){const h=t[l],d=s.getRelatedEdges(h,"out").find(f=>f.target===u);d?s.updateEdgeData(d.id,Object.assign(Object.assign({},d.data),{weight:Math.max(o(r,c,l),d.data.weight||0)})):s.addEdge({id:`e${Math.random()}`,source:h,target:u,data:{weight:Math.max(o(r,c,l),0)}})}l=c})}),s},Rq=(r,e)=>_B(Object.values(e),t=>{var n;let i=Number.NEGATIVE_INFINITY,a=Number.POSITIVE_INFINITY;return(n=Object.keys(t))===null||n===void 0||n.forEach(s=>{const o=t[s],A=Kq(r,s)/2;i=Math.max(o+A,i),a=Math.min(o-A,a)}),i-a});function Dq(r,e){const t=Object.values(e),n=Math.min(...t),i=Math.max(...t);["u","d"].forEach(a=>{["l","r"].forEach(s=>{const o=a+s,A=r[o];let l;if(A===e)return;const c=Object.values(A);l=s==="l"?n-Math.min(...c):i-Math.max(...c),l&&(r[o]={},Object.keys(A).forEach(u=>{r[o][u]=A[u]+l}))})})}const Hq=(r,e)=>{const t={};return Object.keys(r.ul).forEach(n=>{if(e)t[n]=r[e.toLowerCase()][n];else{const i=Object.values(r).map(a=>a[n]);t[n]=(i[0]+i[1])/2}}),t},Gq=(r,e,t)=>(n,i,a)=>{const s=n.getNode(i),o=n.getNode(a);let A=0,l=0;if(A+=s.data.width/2,s.data.hasOwnProperty("labelpos"))switch((s.data.labelpos||"").toLowerCase()){case"l":l=-s.data.width/2;break;case"r":l=s.data.width/2;break}if(l&&(A+=t?l:-l),l=0,A+=(s.data.dummy?e:r)/2,A+=(o.data.dummy?e:r)/2,A+=o.data.width/2,o.data.labelpos)switch((o.data.labelpos||"").toLowerCase()){case"l":l=o.data.width/2;break;case"r":l=-o.data.width/2;break}return l&&(A+=t?l:-l),l=0,A},Kq=(r,e)=>r.getNode(e).data.width||0,zq=(r,e)=>{const{ranksep:t=0}=e||{},n=wl(r);let i=0;n==null||n.forEach(a=>{const s=a.map(A=>r.getNode(A).data.height),o=Math.max(...s,0);a==null||a.forEach(A=>{r.getNode(A).data.y=i+o/2}),i+=o+t})},Vq=(r,e)=>{const{align:t,nodesep:n=0,edgesep:i=0}=e||{},a=wl(r),s=Object.assign(Iq(r,a),kq(r,a)),o={};let A=[];["u","d"].forEach(c=>{A=c==="u"?a:Object.values(a).reverse(),["l","r"].forEach(u=>{u==="r"&&(A=A.map(g=>Object.values(g).reverse()));const h=(c==="u"?r.getPredecessors:r.getSuccessors).bind(r),d=Nq(r,A,s,h),f=Uq(r,A,d.root,d.align,n,i,u==="r");u==="r"&&Object.keys(f).forEach(g=>f[g]=-f[g]),o[c+u]=f})});const l=Rq(r,o);return l&&Dq(o,l),Hq(o,t)},jq=(r,e)=>{var t;const n=JL(r);zq(n,e);const i=Vq(n,e);(t=Object.keys(i))===null||t===void 0||t.forEach(a=>{n.getNode(a).data.x=i[a]})},AQ=r=>{const e={},t=n=>{var i;const a=r.getNode(n);if(!a)return 0;if(e[n])return a.data.rank;e[n]=!0;let s;return(i=r.getRelatedEdges(n,"out"))===null||i===void 0||i.forEach(o=>{const A=t(o.target),l=o.data.minlen,c=A-l;c&&(s===void 0||c<s)&&(s=c)}),s||(s=0),a.data.rank=s,s};r.getAllNodes().filter(n=>r.getRelatedEdges(n.id,"in").length===0).forEach(n=>t(n.id))},Wq=r=>{const e={};let t;const n=s=>{var o;const A=r.getNode(s);if(!A)return 0;if(e[s])return A.data.rank;e[s]=!0;let l;return(o=r.getRelatedEdges(s,"out"))===null||o===void 0||o.forEach(c=>{const u=n(c.target),h=c.data.minlen,d=u-h;d&&(l===void 0||d<l)&&(l=d)}),l||(l=0),(t===void 0||l<t)&&(t=l),A.data.rank=l,l};r.getAllNodes().filter(s=>r.getRelatedEdges(s.id,"in").length===0).forEach(s=>{s&&n(s.id)}),t===void 0&&(t=0);const i={},a=(s,o)=>{var A;const l=r.getNode(s),c=isNaN(l.data.layer)?o:l.data.layer;(l.data.rank===void 0||l.data.rank<c)&&(l.data.rank=c),!i[s]&&(i[s]=!0,(A=r.getRelatedEdges(s,"out"))===null||A===void 0||A.forEach(u=>{a(u.target,c+u.data.minlen)}))};r.getAllNodes().forEach(s=>{const o=s.data;o&&(isNaN(o.layer)?o.rank-=t:a(s.id,o.layer))})},ns=(r,e)=>r.getNode(e.target).data.rank-r.getNode(e.source).data.rank-e.data.minlen,qq=r=>{const e=new Mn({tree:[]}),t=r.getAllNodes()[0],n=r.getAllNodes().length;e.addNode(t);let i,a;for(;$q(e,r)<n;)i=lQ(e,r),a=e.hasNode(i.source)?ns(r,i):-ns(r,i),cQ(e,r,a);return e},$q=(r,e)=>{const t=n=>{e.getRelatedEdges(n,"both").forEach(i=>{const a=i.source,s=n===a?i.target:a;!r.hasNode(s)&&!ns(e,i)&&(r.addNode({id:s,data:{}}),r.addEdge({id:i.id,source:n,target:s,data:{}}),t(s))})};return r.getAllNodes().forEach(n=>t(n.id)),r.getAllNodes().length},Yq=r=>{const e=new Mn({tree:[]}),t=r.getAllNodes()[0],n=r.getAllNodes().length;e.addNode(t);let i,a;for(;Xq(e,r)<n;)i=lQ(e,r),a=e.hasNode(i.source)?ns(r,i):-ns(r,i),cQ(e,r,a);return e},Xq=(r,e)=>{const t=n=>{var i;(i=e.getRelatedEdges(n,"both"))===null||i===void 0||i.forEach(a=>{const s=a.source,o=n===s?a.target:s;!r.hasNode(o)&&(e.getNode(o).data.layer!==void 0||!ns(e,a))&&(r.addNode({id:o,data:{}}),r.addEdge({id:a.id,source:n,target:o,data:{}}),t(o))})};return r.getAllNodes().forEach(n=>t(n.id)),r.getAllNodes().length},lQ=(r,e)=>_B(e.getAllEdges(),t=>r.hasNode(t.source)!==r.hasNode(t.target)?ns(e,t):1/0),cQ=(r,e,t)=>{r.getAllNodes().forEach(n=>{const i=e.getNode(n.id);i.data.rank||(i.data.rank=0),i.data.rank+=t})},Zq=r=>{const e=XW(r);AQ(e);const t=qq(e);hQ(t),uQ(t,e);let n,i;for(;n=t$(t);)i=n$(t,e,n),r$(t,e,n,i)},uQ=(r,e)=>{let t=nQ(r,r.getAllNodes(),"post");t=t.slice(0,(t==null?void 0:t.length)-1),t.forEach(n=>{Jq(r,e,n)})},Jq=(r,e,t)=>{const i=r.getNode(t).data.parent,a=r.getRelatedEdges(t,"both").find(s=>s.target===i||s.source===i);a.data.cutvalue=e$(r,e,t)},e$=(r,e,t)=>{const i=r.getNode(t).data.parent;let a=!0,s=e.getRelatedEdges(t,"out").find(A=>A.target===i),o=0;return s||(a=!1,s=e.getRelatedEdges(i,"out").find(A=>A.target===t)),o=s.data.weight,e.getRelatedEdges(t,"both").forEach(A=>{const l=A.source===t,c=l?A.target:A.source;if(c!==i){const u=l===a,h=A.data.weight;if(o+=u?h:-h,a$(r,t,c)){const d=r.getRelatedEdges(t,"both").find(f=>f.source===c||f.target===c).data.cutvalue;o+=u?-d:d}}}),o},hQ=(r,e=r.getAllNodes()[0].id)=>{dQ(r,{},1,e)},dQ=(r,e,t,n,i)=>{var a;const s=t;let o=t;const A=r.getNode(n);return e[n]=!0,(a=r.getNeighbors(n))===null||a===void 0||a.forEach(l=>{e[l.id]||(o=dQ(r,e,o,l.id,n))}),A.data.low=s,A.data.lim=o++,i?A.data.parent=i:delete A.data.parent,o},t$=r=>r.getAllEdges().find(e=>e.data.cutvalue<0),n$=(r,e,t)=>{let n=t.source,i=t.target;e.getRelatedEdges(n,"out").find(c=>c.target===i)||(n=t.target,i=t.source);const a=r.getNode(n),s=r.getNode(i);let o=a,A=!1;a.data.lim>s.data.lim&&(o=s,A=!0);const l=e.getAllEdges().filter(c=>A===oC(r.getNode(c.source),o)&&A!==oC(r.getNode(c.target),o));return _B(l,c=>ns(e,c))},r$=(r,e,t,n)=>{const i=r.getRelatedEdges(t.source,"both").find(a=>a.source===t.target||a.target===t.target);i&&r.removeEdge(i.id),r.addEdge({id:`e${Math.random()}`,source:n.source,target:n.target,data:{}}),hQ(r),uQ(r,e),i$(r,e)},i$=(r,e)=>{const t=r.getAllNodes().find(i=>!i.data.parent);let n=nQ(r,t,"pre");n=n.slice(1),n.forEach(i=>{const a=r.getNode(i).data.parent;let s=e.getRelatedEdges(i,"out").find(A=>A.target===a),o=!1;!s&&e.hasNode(a)&&(s=e.getRelatedEdges(a,"out").find(A=>A.target===i),o=!0),e.getNode(i).data.rank=(e.hasNode(a)&&e.getNode(a).data.rank||0)+(o?s==null?void 0:s.data.minlen:-(s==null?void 0:s.data.minlen))})},a$=(r,e,t)=>r.getRelatedEdges(e,"both").find(n=>n.source===t||n.target===t),oC=(r,e)=>e.data.low<=r.data.lim&&r.data.lim<=e.data.lim,s$=(r,e)=>{switch(e){case"network-simplex":A$(r);break;case"tight-tree":AC(r);break;case"longest-path":o$(r);break;default:AC(r)}},o$=AQ,AC=r=>{Wq(r),Yq(r)},A$=r=>{Zq(r)},l$=(r,e)=>{const{edgeLabelSpace:t,keepNodeOrder:n,prevGraph:i,rankdir:a,ranksep:s}=e;!n&&i&&u$(r,i);const o=p$(r);t&&(e.ranksep=y$(o,{rankdir:a,ranksep:s}));let A;try{A=c$(o,e)}catch(l){if(l.message==="Not possible to find intersection inside of the rectangle"){console.error(`The following error may be caused by improper layer setting, please make sure your manual layer setting does not violate the graph's structure:
|
|
6
|
+
`,l);return}throw l}return h$(r,o),A},c$=(r,e)=>{const{ranker:t,rankdir:n="tb",nodeOrder:i,keepNodeOrder:a,align:s,nodesep:o=50,edgesep:A=20,ranksep:l=50}=e;F$(r),qW(r);const{nestingRoot:c,nodeRankFactor:u}=oq(r);s$(JL(r),t),m$(r),eq(r,u),cq(r,c),JW(r),w$(r),B$(r);const h=[];hq(r,h),_q(r,h),nq(r),a&&Tq(r,i),Fq(r,a),T$(r),rq(r,n),jq(r,{align:s,nodesep:o,edgesep:A,ranksep:l}),M$(r),S$(r),fq(r,h),x$(r),iq(r,n);const{width:d,height:f}=b$(r);return E$(r),C$(r),$W(r),{width:d,height:f}},u$=(r,e)=>{r.getAllNodes().forEach(t=>{const n=r.getNode(t.id);if(e.hasNode(t.id)){const i=e.getNode(t.id);n.data.fixorder=i.data._order,delete i.data._order}else delete n.data.fixorder})},h$=(r,e)=>{r.getAllNodes().forEach(t=>{var n;const i=r.getNode(t.id);if(i){const a=e.getNode(t.id);i.data.x=a.data.x,i.data.y=a.data.y,i.data._order=a.data.order,i.data._rank=a.data.rank,!((n=e.getChildren(t.id))===null||n===void 0)&&n.length&&(i.data.width=a.data.width,i.data.height=a.data.height)}}),r.getAllEdges().forEach(t=>{const n=r.getEdge(t.id),i=e.getEdge(t.id);n.data.points=i?i.data.points:[],i&&i.data.hasOwnProperty("x")&&(n.data.x=i.data.x,n.data.y=i.data.y)})},d$=["width","height","layer","fixorder"],f$={width:0,height:0},g$=["minlen","weight","width","height","labeloffset"],v$={minlen:1,weight:1,width:0,height:0,labeloffset:10,labelpos:"r"},Tg=["labelpos"],p$=r=>{const e=new Mn({tree:[]});return r.getAllNodes().forEach(t=>{const n=cC(r.getNode(t.id).data),i=Object.assign(Object.assign({},f$),n),a=lC(i,d$);e.hasNode(t.id)||e.addNode({id:t.id,data:Object.assign({},a)});const s=r.hasTreeStructure("combo")?r.getParent(t.id,"combo"):r.getParent(t.id);ke(s)||(e.hasNode(s.id)||e.addNode(Object.assign({},s)),e.setParent(t.id,s.id))}),r.getAllEdges().forEach(t=>{const n=cC(r.getEdge(t.id).data),i={};Tg==null||Tg.forEach(a=>{n[a]!==void 0&&(i[a]=n[a])}),e.addEdge({id:t.id,source:t.source,target:t.target,data:Object.assign({},v$,lC(n,g$),i)})}),e},y$=(r,e)=>{const{ranksep:t=0,rankdir:n}=e;return r.getAllNodes().forEach(i=>{isNaN(i.data.layer)||i.data.layer||(i.data.layer=0)}),r.getAllEdges().forEach(i=>{var a;i.data.minlen*=2,((a=i.data.labelpos)===null||a===void 0?void 0:a.toLowerCase())!=="c"&&(n==="TB"||n==="BT"?i.data.width+=i.data.labeloffset:i.data.height+=i.data.labeloffset)}),t/2},m$=r=>{r.getAllEdges().forEach(e=>{if(e.data.width&&e.data.height){const t=r.getNode(e.source),n=r.getNode(e.target),i={e,rank:(n.data.rank-t.data.rank)/2+t.data.rank};eA(r,"edge-proxy",i,"_ep")}})},w$=r=>{let e=0;return r.getAllNodes().forEach(t=>{var n,i;t.data.borderTop&&(t.data.minRank=(n=r.getNode(t.data.borderTop))===null||n===void 0?void 0:n.data.rank,t.data.maxRank=(i=r.getNode(t.data.borderBottom))===null||i===void 0?void 0:i.data.rank,e=Math.max(e,t.data.maxRank||-1/0))}),e},B$=r=>{r.getAllNodes().forEach(e=>{e.data.dummy==="edge-proxy"&&(r.getEdge(e.data.e.id).data.labelRank=e.data.rank,r.removeNode(e.id))})},b$=(r,e)=>{let t,n=0,i,a=0;const{marginx:s=0,marginy:o=0}={},A=l=>{if(!l.data)return;const c=l.data.x,u=l.data.y,h=l.data.width,d=l.data.height;!isNaN(c)&&!isNaN(h)&&(t===void 0&&(t=c-h/2),t=Math.min(t,c-h/2),n=Math.max(n,c+h/2)),!isNaN(u)&&!isNaN(d)&&(i===void 0&&(i=u-d/2),i=Math.min(i,u-d/2),a=Math.max(a,u+d/2))};return r.getAllNodes().forEach(l=>{A(l)}),r.getAllEdges().forEach(l=>{l!=null&&l.data.hasOwnProperty("x")&&A(l)}),t-=s,i-=o,r.getAllNodes().forEach(l=>{l.data.x-=t,l.data.y-=i}),r.getAllEdges().forEach(l=>{var c;(c=l.data.points)===null||c===void 0||c.forEach(u=>{u.x-=t,u.y-=i}),l.data.hasOwnProperty("x")&&(l.data.x-=t),l.data.hasOwnProperty("y")&&(l.data.y-=i)}),{width:n-t+s,height:a-i+o}},E$=r=>{r.getAllEdges().forEach(e=>{const t=r.getNode(e.source),n=r.getNode(e.target);let i,a;e.data.points?(i=e.data.points[0],a=e.data.points[e.data.points.length-1]):(e.data.points=[],i={x:n.data.x,y:n.data.y},a={x:t.data.x,y:t.data.y}),e.data.points.unshift(Zx(t.data,i)),e.data.points.push(Zx(n.data,a))})},x$=r=>{r.getAllEdges().forEach(e=>{if(e.data.hasOwnProperty("x"))switch((e.data.labelpos==="l"||e.data.labelpos==="r")&&(e.data.width-=e.data.labeloffset),e.data.labelpos){case"l":e.data.x-=e.data.width/2+e.data.labeloffset;break;case"r":e.data.x+=e.data.width/2+e.data.labeloffset;break}})},C$=r=>{r.getAllEdges().forEach(e=>{var t;e.data.reversed&&((t=e.data.points)===null||t===void 0||t.reverse())})},S$=r=>{r.getAllNodes().forEach(e=>{var t,n,i;if(!((t=r.getChildren(e.id))===null||t===void 0)&&t.length){const a=r.getNode(e.id),s=r.getNode(a.data.borderTop),o=r.getNode(a.data.borderBottom),A=r.getNode(a.data.borderLeft[((n=a.data.borderLeft)===null||n===void 0?void 0:n.length)-1]),l=r.getNode(a.data.borderRight[((i=a.data.borderRight)===null||i===void 0?void 0:i.length)-1]);a.data.width=Math.abs((l==null?void 0:l.data.x)-(A==null?void 0:A.data.x))||10,a.data.height=Math.abs((o==null?void 0:o.data.y)-(s==null?void 0:s.data.y))||10,a.data.x=((A==null?void 0:A.data.x)||0)+a.data.width/2,a.data.y=((s==null?void 0:s.data.y)||0)+a.data.height/2}}),r.getAllNodes().forEach(e=>{e.data.dummy==="border"&&r.removeNode(e.id)})},F$=r=>{r.getAllEdges().forEach(e=>{if(e.source===e.target){const t=r.getNode(e.source);t.data.selfEdges||(t.data.selfEdges=[]),t.data.selfEdges.push(e),r.removeEdge(e.id)}})},T$=r=>{const e=wl(r);e==null||e.forEach(t=>{let n=0;t==null||t.forEach((i,a)=>{var s;const o=r.getNode(i);o.data.order=a+n,(s=o.data.selfEdges)===null||s===void 0||s.forEach(A=>{eA(r,"selfedge",{width:A.data.width,height:A.data.height,rank:o.data.rank,order:a+ ++n,e:A},"_se")}),delete o.data.selfEdges})})},M$=r=>{r.getAllNodes().forEach(e=>{const t=r.getNode(e.id);if(t.data.dummy==="selfedge"){const n=r.getNode(t.data.e.source),i=n.data.x+n.data.width/2,a=n.data.y,s=t.data.x-i,o=n.data.height/2;r.hasEdge(t.data.e.id)?r.updateEdgeData(t.data.e.id,t.data.e.data):r.addEdge({id:t.data.e.id,source:t.data.e.source,target:t.data.e.target,data:t.data.e.data}),r.removeNode(e.id),t.data.e.data.points=[{x:i+2*s/3,y:a-o},{x:i+5*s/6,y:a-o},{y:a,x:i+s},{x:i+5*s/6,y:a+o},{x:i+2*s/3,y:a+o}],t.data.e.data.x=t.data.x,t.data.e.data.y=t.data.y}})},lC=(r,e)=>{const t={};return e==null||e.forEach(n=>{r[n]!==void 0&&(t[n]=+r[n])}),t},cC=(r={})=>{const e={};return Object.keys(r).forEach(t=>{e[t.toLowerCase()]=r[t]}),e},la=Array.isArray,fQ=r=>{const e=[],t=r.length;for(let n=0;n<t;n+=1){e[n]=[];for(let i=0;i<t;i+=1)n===i?e[n][i]=0:r[n][i]===0||!r[n][i]?e[n][i]=1/0:e[n][i]=r[n][i]}for(let n=0;n<t;n+=1)for(let i=0;i<t;i+=1)for(let a=0;a<t;a+=1)e[i][a]>e[i][n]+e[n][a]&&(e[i][a]=e[i][n]+e[n][a]);return e},gQ=(r,e)=>{const{nodes:t,edges:n}=r,i=[],a={};if(!t)throw new Error("invalid nodes data!");return t&&t.forEach((s,o)=>{a[s.id]=o;const A=[];i.push(A)}),n==null||n.forEach(s=>{const{source:o,target:A}=s,l=a[o],c=a[A];l===void 0||c===void 0||(i[l][c]=1,i[c][l]=1)}),i},O$=(r,e)=>{const t=[];return r.forEach(n=>{const i=[];n.forEach(a=>{i.push(a*e)}),t.push(i)}),t},_$=r=>{let e=1/0,t=1/0,n=-1/0,i=-1/0;return r.forEach(a=>{let s=a.data.size;la(s)?s.length===1&&(s=[s[0],s[0]]):Be(s)?s=[s,s]:(s===void 0||isNaN(s))&&(s=[30,30]);const o=[s[0]/2,s[1]/2],A=a.data.x-o[0],l=a.data.x+o[0],c=a.data.y-o[1],u=a.data.y+o[1];e>A&&(e=A),t>c&&(t=c),n<l&&(n=l),i<u&&(i=u)}),{minX:e,minY:t,maxX:n,maxY:i}},uC=(r,e)=>Math.sqrt((r.x-e.x)*(r.x-e.x)+(r.y-e.y)*(r.y-e.y)),y1=(r,e,t,n="TB",i,a={})=>{if(!(e!=null&&e.length))return;const{stopBranchFn:s,stopAllFn:o}=a;for(let A=0;A<e.length;A++){const l=e[A];if(r.hasNode(l.id)&&!(s!=null&&s(l))){if(o!=null&&o(l))return;n==="TB"&&t(l),y1(r,r.getChildren(l.id,i),t,n,i,a),n!=="TB"&&t(l)}}},m1=r=>{if(r===null)return r;if(r instanceof Date)return new Date(r.getTime());if(r instanceof Array){const e=[];return r.forEach(t=>{e.push(t)}),e.map(t=>m1(t))}if(typeof r=="object"){const e={};return Object.keys(r).forEach(t=>{e[t]=m1(r[t])}),e}return r},Dr=(r,e)=>{const t=m1(r);return t.data=t.data||{},e&&(Be(t.data.x)||(t.data.x=Math.random()*e[0]),Be(t.data.y)||(t.data.y=Math.random()*e[1])),t};function zl(r){if(!r)return[0,0,0];if(Be(r))return[r,r,r];if(r.length===0)return[0,0,0];const[e,t=e,n=e]=r;return[e,t,n]}function Us(r,e){let t;return Te(e)?t=e:Be(e)?t=()=>e:t=()=>r,t}function IB(r,e,t=!0){return!e&&e!==0?n=>{const{size:i}=n.data||{};return i?Array.isArray(i)?t?Math.max(...i)||r:i:un(i)&&i.width&&i.height?t?Math.max(i.width,i.height)||r:[i.width,i.height]:i:r}:Te(e)?e:Be(e)?()=>e:Array.isArray(e)?()=>t?Math.max(...e)||r:e:un(e)&&e.width&&e.height?()=>t?Math.max(e.width,e.height)||r:[e.width,e.height]:()=>r}const kB=(r,e,t=10)=>{let n;const i=typeof e=="function"?e:()=>e||0;return r?Array.isArray(r)?n=s=>r:Te(r)?n=r:n=s=>r:n=s=>{var o,A,l;if(!((o=s.data)===null||o===void 0)&&o.bboxSize)return(A=s.data)===null||A===void 0?void 0:A.bboxSize;if(!((l=s.data)===null||l===void 0)&&l.size){const c=s.data.size;return Array.isArray(c)?c:un(c)?[c.width,c.height]:c}return t},s=>{const o=n(s),A=i(s);return Math.max(...zl(o))+A}},I$={rankdir:"TB",nodesep:50,ranksep:50,edgeLabelSpace:!0,ranker:"tight-tree",controlPoints:!1,radial:!1,focusNode:null};class k${constructor(e={}){this.options=e,this.id="antv-dagre",this.options=Object.assign(Object.assign({},I$),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericDagreLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericDagreLayout(!0,e,t)})}genericDagreLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},this.options),n),{nodeSize:a,align:s,rankdir:o="TB",ranksep:A,nodesep:l,ranksepFunc:c,nodesepFunc:u,edgeLabelSpace:h,ranker:d,nodeOrder:f,begin:g,controlPoints:v,radial:p,sortByCombo:y,preset:m}=i,B=new Mn({tree:[]}),C=Us(A||50,c),S=Us(l||50,u);let F=S,T=C;(o==="LR"||o==="RL")&&(F=C,T=S);const O=IB(10,a,!1),_=t.getAllNodes(),k=t.getAllEdges();_.forEach(D=>{const X=zl(O(D)),te=T(D),ie=F(D),re=X[0]+2*ie,xe=X[1]+2*te,$=D.data.layer;Be($)?B.addNode({id:D.id,data:{width:re,height:xe,layer:$}}):B.addNode({id:D.id,data:{width:re,height:xe}})}),y&&(B.attachTreeStructure("combo"),_.forEach(D=>{const{parentId:X}=D.data;X!==void 0&&B.hasNode(X)&&B.setParent(D.id,X,"combo")})),k.forEach(D=>{B.addEdge({id:D.id,source:D.source,target:D.target,data:{weight:D.data.weight||1}})});let L;m!=null&&m.length&&(L=new Mn({nodes:m})),l$(B,{prevGraph:L,edgeLabelSpace:h,keepNodeOrder:!!f,nodeOrder:f||[],acyclicer:"greedy",ranker:d,rankdir:o,nodesep:l,align:s});const U=[0,0];if(g){let D=1/0,X=1/0;B.getAllNodes().forEach(te=>{D>te.data.x&&(D=te.data.x),X>te.data.y&&(X=te.data.y)}),B.getAllEdges().forEach(te=>{var ie;(ie=te.data.points)===null||ie===void 0||ie.forEach(re=>{D>re.x&&(D=re.x),X>re.y&&(X=re.y)})}),U[0]=g[0]-D,U[1]=g[1]-X}const G=o==="LR"||o==="RL";if(!p){const D=new Set,te=o==="BT"||o==="RL"?($,z)=>z-$:($,z)=>$-z;B.getAllNodes().forEach($=>{$.data.x=$.data.x+U[0],$.data.y=$.data.y+U[1],D.add(G?$.data.x:$.data.y)});const ie=Array.from(D).sort(te),re=G?($,z)=>$.x!==z.x:($,z)=>$.y!==z.y,xe=G?($,z,ee)=>{const Ae=Math.max(z.y,ee.y),be=Math.min(z.y,ee.y);return $.filter(Le=>Le.y<=Ae&&Le.y>=be)}:($,z,ee)=>{const Ae=Math.max(z.x,ee.x),be=Math.min(z.x,ee.x);return $.filter(Le=>Le.x<=Ae&&Le.x>=be)};B.getAllEdges().forEach(($,z)=>{var ee;h&&v&&$.data.type!=="loop"&&($.data.controlPoints=L$((ee=$.data.points)===null||ee===void 0?void 0:ee.map(({x:Ae,y:be})=>({x:Ae+U[0],y:be+U[1]})),B.getNode($.source),B.getNode($.target),ie,G,re,xe))})}let W=[];W=B.getAllNodes().map(D=>Dr(D));const V=B.getAllEdges();return e&&(W.forEach(D=>{t.mergeNodeData(D.id,{x:D.data.x,y:D.data.y})}),V.forEach(D=>{t.mergeEdgeData(D.id,{controlPoints:D.data.controlPoints})})),{nodes:W,edges:V}})}}const L$=(r,e,t,n,i,a,s)=>{let o=(r==null?void 0:r.slice(1,r.length-1))||[];if(e&&t){let{x:A,y:l}=e.data,{x:c,y:u}=t.data;if(i&&(A=e.data.y,l=e.data.x,c=t.data.y,u=t.data.x),u!==l&&A!==c){const h=n.indexOf(l),d=n[h+1];if(d){const v=o[0],p=i?{x:(l+d)/2,y:(v==null?void 0:v.y)||c}:{x:(v==null?void 0:v.x)||c,y:(l+d)/2};(!v||a(v,p))&&o.unshift(p)}const f=n.indexOf(u),g=Math.abs(f-h);if(g===1)o=s(o,e.data,t.data),o.length||o.push(i?{x:(l+u)/2,y:A}:{x:A,y:(l+u)/2});else if(g>1){const v=n[f-1];if(v){const p=o[o.length-1],y=i?{x:(u+v)/2,y:(p==null?void 0:p.y)||c}:{x:(p==null?void 0:p.x)||A,y:(u+v)/2};(!p||a(p,y))&&o.push(y)}}}}return o},to=(r,e,t)=>{const n=r.getAllNodes(),i=r.getAllEdges();if(!(n!=null&&n.length))return{nodes:[],edges:i};if(n.length===1)return e&&r.mergeNodeData(n[0].id,{x:t[0],y:t[1]}),{nodes:[Object.assign(Object.assign({},n[0]),{data:Object.assign(Object.assign({},n[0].data),{x:t[0],y:t[1]})})],edges:i}},Q$={radius:null,startRadius:null,endRadius:null,startAngle:0,endAngle:2*Math.PI,clockwise:!0,divisions:1,ordering:null,angleRatio:1};class N${constructor(e={}){this.options=e,this.id="circular",this.options=Object.assign(Object.assign({},Q$),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericCircularLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericCircularLayout(!0,e,t)})}genericCircularLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},this.options),n),{width:a,height:s,center:o,divisions:A,startAngle:l=0,endAngle:c=2*Math.PI,angleRatio:u,ordering:h,clockwise:d,nodeSpacing:f,nodeSize:g}=i,v=t.getAllNodes(),p=t.getAllEdges(),[y,m,B]=P$(a,s,o),C=v==null?void 0:v.length;if(!C||C===1)return to(t,e,B);const S=(c-l)/C;let{radius:F,startRadius:T,endRadius:O}=i;if(f){const G=Us(10,f),W=IB(10,g);let V=-1/0;v.forEach(D=>{const X=W(D);V<X&&(V=X)});let K=0;v.forEach((D,X)=>{X===0?K+=V||10:K+=(G(D)||0)+(V||10)}),F=K/(2*Math.PI)}else!F&&!T&&!O?F=Math.min(m,y)/2:!T&&O?T=O:T&&!O&&(O=T);const _=S*u;let k=[];h==="topology"?k=hC(t,v):h==="topology-directed"?k=hC(t,v,!0):h==="degree"?k=U$(t,v):k=v.map(G=>Dr(G));const L=Math.ceil(C/A);for(let G=0;G<C;++G){let W=F;!W&&T!==null&&O!==null&&(W=T+G*(O-T)/(C-1)),W||(W=10+G*100/(C-1));let V=l+G%L*_+2*Math.PI/A*Math.floor(G/L);d||(V=c-G%L*_-2*Math.PI/A*Math.floor(G/L)),k[G].data.x=B[0]+Math.cos(V)*W,k[G].data.y=B[1]+Math.sin(V)*W}return e&&k.forEach(G=>{t.mergeNodeData(G.id,{x:G.data.x,y:G.data.y})}),{nodes:k,edges:p}})}}const hC=(r,e,t=!1)=>{const n=[Dr(e[0])],i={},a=e.length;i[e[0].id]=!0;let s=0;return e.forEach((o,A)=>{if(A!==0)if((A===a-1||r.getDegree(o.id,"both")!==r.getDegree(e[A+1].id,"both")||r.areNeighbors(n[s].id,o.id))&&!i[o.id])n.push(Dr(o)),i[o.id]=!0,s++;else{const l=t?r.getSuccessors(n[s].id):r.getNeighbors(n[s].id);let c=!1;for(let h=0;h<l.length;h++){const d=l[h];if(r.getDegree(d.id)===r.getDegree(o.id)&&!i[d.id]){n.push(Dr(d)),i[d.id]=!0,c=!0;break}}let u=0;for(;!c&&(i[e[u].id]||(n.push(Dr(e[u])),i[e[u].id]=!0,c=!0),u++,u!==a););}}),n};function U$(r,e){const t=[];return e.forEach((n,i)=>{t.push(Dr(n))}),t.sort((n,i)=>r.getDegree(n.id,"both")-r.getDegree(i.id,"both")),t}const P$=(r,e,t)=>{let n=r,i=e,a=t;return!n&&typeof window<"u"&&(n=window.innerWidth),!i&&typeof window<"u"&&(i=window.innerHeight),a||(a=[n/2,i/2]),[n,i,a]},R$={nodeSize:30,nodeSpacing:10,preventOverlap:!1,sweep:void 0,equidistant:!1,startAngle:3/2*Math.PI,clockwise:!0,maxLevelDiff:void 0,sortBy:"degree"};class w1{constructor(e={}){this.options=e,this.id="concentric",this.options=Object.assign(Object.assign({},R$),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericConcentricLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericConcentricLayout(!0,e,t)})}genericConcentricLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},this.options),n),{center:a,width:s,height:o,sortBy:A,maxLevelDiff:l,sweep:c,clockwise:u,equidistant:h,preventOverlap:d,startAngle:f=3/2*Math.PI,nodeSize:g,nodeSpacing:v}=i,p=t.getAllNodes(),y=t.getAllEdges(),m=!s&&typeof window<"u"?window.innerWidth:s,B=!o&&typeof window<"u"?window.innerHeight:o,C=a||[m/2,B/2];if(!(p!=null&&p.length)||p.length===1)return to(t,e,C);const S=[];let F,T=0;la(g)?F=Math.max(g[0],g[1]):Te(g)?(F=-1/0,p.forEach(D=>{const X=Math.max(...zl(g(D)));X>F&&(F=X)})):F=g,la(v)?T=Math.max(v[0],v[1]):Be(v)&&(T=v),p.forEach(D=>{const X=Dr(D);S.push(X);let te=F;const{data:ie}=X;la(ie.size)?te=Math.max(ie.size[0],ie.size[1]):Be(ie.size)?te=ie.size:un(ie.size)&&(te=Math.max(ie.size.width,ie.size.height)),F=Math.max(F,te),Te(v)&&(T=Math.max(v(D),T))});const O={};S.forEach((D,X)=>{O[D.id]=X});let _=A;(!At(_)||S[0].data[_]===void 0)&&(_="degree"),_==="degree"?S.sort((D,X)=>t.getDegree(X.id,"both")-t.getDegree(D.id,"both")):S.sort((D,X)=>X.data[_]-D.data[_]);const k=S[0],L=(l||(_==="degree"?t.getDegree(k.id,"both"):k.data[_]))/4,U=[{nodes:[]}];let G=U[0];S.forEach(D=>{if(G.nodes.length>0){const X=Math.abs(_==="degree"?t.getDegree(G.nodes[0].id,"both")-t.getDegree(D.id,"both"):G.nodes[0].data[_]-D.data[_]);L&&X>=L&&(G={nodes:[]},U.push(G))}G.nodes.push(D)});let W=F+T;if(!d){const D=U.length>0&&U[0].nodes.length>1,te=(Math.min(m,B)/2-W)/(U.length+(D?1:0));W=Math.min(W,te)}let V=0;if(U.forEach(D=>{const X=c===void 0?2*Math.PI-2*Math.PI/D.nodes.length:c;if(D.dTheta=X/Math.max(1,D.nodes.length-1),D.nodes.length>1&&d){const te=Math.cos(D.dTheta)-Math.cos(0),ie=Math.sin(D.dTheta)-Math.sin(0),re=Math.sqrt(W*W/(te*te+ie*ie));V=Math.max(re,V)}D.r=V,V+=W}),h){let D=0,X=0;for(let te=0;te<U.length;te++){const re=(U[te].r||0)-X;D=Math.max(D,re)}X=0,U.forEach((te,ie)=>{ie===0&&(X=te.r||0),te.r=X,X+=D})}return U.forEach(D=>{const X=D.dTheta||0,te=D.r||0;D.nodes.forEach((ie,re)=>{const xe=f+(u?1:-1)*X*re;ie.data.x=C[0]+te*Math.cos(xe),ie.data.y=C[1]+te*Math.sin(xe)})}),e&&S.forEach(D=>t.mergeNodeData(D.id,{x:D.data.x,y:D.data.y})),{nodes:S,edges:y}})}}function D$(r){const e=+this._x.call(null,r),t=+this._y.call(null,r);return vQ(this.cover(e,t),e,t,r)}function vQ(r,e,t,n){if(isNaN(e)||isNaN(t))return r;var i,a=r._root,s={data:n},o=r._x0,A=r._y0,l=r._x1,c=r._y1,u,h,d,f,g,v,p,y;if(!a)return r._root=s,r;for(;a.length;)if((g=e>=(u=(o+l)/2))?o=u:l=u,(v=t>=(h=(A+c)/2))?A=h:c=h,i=a,!(a=a[p=v<<1|g]))return i[p]=s,r;if(d=+r._x.call(null,a.data),f=+r._y.call(null,a.data),e===d&&t===f)return s.next=a,i?i[p]=s:r._root=s,r;do i=i?i[p]=new Array(4):r._root=new Array(4),(g=e>=(u=(o+l)/2))?o=u:l=u,(v=t>=(h=(A+c)/2))?A=h:c=h;while((p=v<<1|g)===(y=(f>=h)<<1|d>=u));return i[y]=a,i[p]=s,r}function H$(r){var e,t,n=r.length,i,a,s=new Array(n),o=new Array(n),A=1/0,l=1/0,c=-1/0,u=-1/0;for(t=0;t<n;++t)isNaN(i=+this._x.call(null,e=r[t]))||isNaN(a=+this._y.call(null,e))||(s[t]=i,o[t]=a,i<A&&(A=i),i>c&&(c=i),a<l&&(l=a),a>u&&(u=a));if(A>c||l>u)return this;for(this.cover(A,l).cover(c,u),t=0;t<n;++t)vQ(this,s[t],o[t],r[t]);return this}function G$(r,e){if(isNaN(r=+r)||isNaN(e=+e))return this;var t=this._x0,n=this._y0,i=this._x1,a=this._y1;if(isNaN(t))i=(t=Math.floor(r))+1,a=(n=Math.floor(e))+1;else{for(var s=i-t||1,o=this._root,A,l;t>r||r>=i||n>e||e>=a;)switch(l=(e<n)<<1|r<t,A=new Array(4),A[l]=o,o=A,s*=2,l){case 0:i=t+s,a=n+s;break;case 1:t=i-s,a=n+s;break;case 2:i=t+s,n=a-s;break;case 3:t=i-s,n=a-s;break}this._root&&this._root.length&&(this._root=o)}return this._x0=t,this._y0=n,this._x1=i,this._y1=a,this}function K$(){var r=[];return this.visit(function(e){if(!e.length)do r.push(e.data);while(e=e.next)}),r}function z$(r){return arguments.length?this.cover(+r[0][0],+r[0][1]).cover(+r[1][0],+r[1][1]):isNaN(this._x0)?void 0:[[this._x0,this._y0],[this._x1,this._y1]]}function ur(r,e,t,n,i){this.node=r,this.x0=e,this.y0=t,this.x1=n,this.y1=i}function V$(r,e,t){var n,i=this._x0,a=this._y0,s,o,A,l,c=this._x1,u=this._y1,h=[],d=this._root,f,g;for(d&&h.push(new ur(d,i,a,c,u)),t==null?t=1/0:(i=r-t,a=e-t,c=r+t,u=e+t,t*=t);f=h.pop();)if(!(!(d=f.node)||(s=f.x0)>c||(o=f.y0)>u||(A=f.x1)<i||(l=f.y1)<a))if(d.length){var v=(s+A)/2,p=(o+l)/2;h.push(new ur(d[3],v,p,A,l),new ur(d[2],s,p,v,l),new ur(d[1],v,o,A,p),new ur(d[0],s,o,v,p)),(g=(e>=p)<<1|r>=v)&&(f=h[h.length-1],h[h.length-1]=h[h.length-1-g],h[h.length-1-g]=f)}else{var y=r-+this._x.call(null,d.data),m=e-+this._y.call(null,d.data),B=y*y+m*m;if(B<t){var C=Math.sqrt(t=B);i=r-C,a=e-C,c=r+C,u=e+C,n=d.data}}return n}function j$(r){if(isNaN(c=+this._x.call(null,r))||isNaN(u=+this._y.call(null,r)))return this;var e,t=this._root,n,i,a,s=this._x0,o=this._y0,A=this._x1,l=this._y1,c,u,h,d,f,g,v,p;if(!t)return this;if(t.length)for(;;){if((f=c>=(h=(s+A)/2))?s=h:A=h,(g=u>=(d=(o+l)/2))?o=d:l=d,e=t,!(t=t[v=g<<1|f]))return this;if(!t.length)break;(e[v+1&3]||e[v+2&3]||e[v+3&3])&&(n=e,p=v)}for(;t.data!==r;)if(i=t,!(t=t.next))return this;return(a=t.next)&&delete t.next,i?(a?i.next=a:delete i.next,this):e?(a?e[v]=a:delete e[v],(t=e[0]||e[1]||e[2]||e[3])&&t===(e[3]||e[2]||e[1]||e[0])&&!t.length&&(n?n[p]=t:this._root=t),this):(this._root=a,this)}function W$(r){for(var e=0,t=r.length;e<t;++e)this.remove(r[e]);return this}function q$(){return this._root}function $$(){var r=0;return this.visit(function(e){if(!e.length)do++r;while(e=e.next)}),r}function Y$(r){var e=[],t,n=this._root,i,a,s,o,A;for(n&&e.push(new ur(n,this._x0,this._y0,this._x1,this._y1));t=e.pop();)if(!r(n=t.node,a=t.x0,s=t.y0,o=t.x1,A=t.y1)&&n.length){var l=(a+o)/2,c=(s+A)/2;(i=n[3])&&e.push(new ur(i,l,c,o,A)),(i=n[2])&&e.push(new ur(i,a,c,l,A)),(i=n[1])&&e.push(new ur(i,l,s,o,c)),(i=n[0])&&e.push(new ur(i,a,s,l,c))}return this}function X$(r){var e=[],t=[],n;for(this._root&&e.push(new ur(this._root,this._x0,this._y0,this._x1,this._y1));n=e.pop();){var i=n.node;if(i.length){var a,s=n.x0,o=n.y0,A=n.x1,l=n.y1,c=(s+A)/2,u=(o+l)/2;(a=i[0])&&e.push(new ur(a,s,o,c,u)),(a=i[1])&&e.push(new ur(a,c,o,A,u)),(a=i[2])&&e.push(new ur(a,s,u,c,l)),(a=i[3])&&e.push(new ur(a,c,u,A,l))}t.push(n)}for(;n=t.pop();)r(n.node,n.x0,n.y0,n.x1,n.y1);return this}function Z$(r){return r[0]}function J$(r){return arguments.length?(this._x=r,this):this._x}function e7(r){return r[1]}function t7(r){return arguments.length?(this._y=r,this):this._y}function xd(r,e,t){var n=new LB(e??Z$,t??e7,NaN,NaN,NaN,NaN);return r==null?n:n.addAll(r)}function LB(r,e,t,n,i,a){this._x=r,this._y=e,this._x0=t,this._y0=n,this._x1=i,this._y1=a,this._root=void 0}function dC(r){for(var e={data:r.data},t=e;r=r.next;)t=t.next={data:r.data};return e}var fr=xd.prototype=LB.prototype;fr.copy=function(){var r=new LB(this._x,this._y,this._x0,this._y0,this._x1,this._y1),e=this._root,t,n;if(!e)return r;if(!e.length)return r._root=dC(e),r;for(t=[{source:e,target:r._root=new Array(4)}];e=t.pop();)for(var i=0;i<4;++i)(n=e.source[i])&&(n.length?t.push({source:n,target:e.target[i]=new Array(4)}):e.target[i]=dC(n));return r};fr.add=D$;fr.addAll=H$;fr.cover=G$;fr.data=K$;fr.extent=z$;fr.find=V$;fr.remove=j$;fr.removeAll=W$;fr.root=q$;fr.size=$$;fr.visit=Y$;fr.visitAfter=X$;fr.x=J$;fr.y=t7;function n7(r){const e=+this._x.call(null,r),t=+this._y.call(null,r),n=+this._z.call(null,r);return pQ(this.cover(e,t,n),e,t,n,r)}function pQ(r,e,t,n,i){if(isNaN(e)||isNaN(t)||isNaN(n))return r;var a,s=r._root,o={data:i},A=r._x0,l=r._y0,c=r._z0,u=r._x1,h=r._y1,d=r._z1,f,g,v,p,y,m,B,C,S,F,T;if(!s)return r._root=o,r;for(;s.length;)if((B=e>=(f=(A+u)/2))?A=f:u=f,(C=t>=(g=(l+h)/2))?l=g:h=g,(S=n>=(v=(c+d)/2))?c=v:d=v,a=s,!(s=s[F=S<<2|C<<1|B]))return a[F]=o,r;if(p=+r._x.call(null,s.data),y=+r._y.call(null,s.data),m=+r._z.call(null,s.data),e===p&&t===y&&n===m)return o.next=s,a?a[F]=o:r._root=o,r;do a=a?a[F]=new Array(8):r._root=new Array(8),(B=e>=(f=(A+u)/2))?A=f:u=f,(C=t>=(g=(l+h)/2))?l=g:h=g,(S=n>=(v=(c+d)/2))?c=v:d=v;while((F=S<<2|C<<1|B)===(T=(m>=v)<<2|(y>=g)<<1|p>=f));return a[T]=s,a[F]=o,r}function r7(r){Array.isArray(r)||(r=Array.from(r));const e=r.length,t=new Float64Array(e),n=new Float64Array(e),i=new Float64Array(e);let a=1/0,s=1/0,o=1/0,A=-1/0,l=-1/0,c=-1/0;for(let u=0,h,d,f,g;u<e;++u)isNaN(d=+this._x.call(null,h=r[u]))||isNaN(f=+this._y.call(null,h))||isNaN(g=+this._z.call(null,h))||(t[u]=d,n[u]=f,i[u]=g,d<a&&(a=d),d>A&&(A=d),f<s&&(s=f),f>l&&(l=f),g<o&&(o=g),g>c&&(c=g));if(a>A||s>l||o>c)return this;this.cover(a,s,o).cover(A,l,c);for(let u=0;u<e;++u)pQ(this,t[u],n[u],i[u],r[u]);return this}function i7(r,e,t){if(isNaN(r=+r)||isNaN(e=+e)||isNaN(t=+t))return this;var n=this._x0,i=this._y0,a=this._z0,s=this._x1,o=this._y1,A=this._z1;if(isNaN(n))s=(n=Math.floor(r))+1,o=(i=Math.floor(e))+1,A=(a=Math.floor(t))+1;else{for(var l=s-n||1,c=this._root,u,h;n>r||r>=s||i>e||e>=o||a>t||t>=A;)switch(h=(t<a)<<2|(e<i)<<1|r<n,u=new Array(8),u[h]=c,c=u,l*=2,h){case 0:s=n+l,o=i+l,A=a+l;break;case 1:n=s-l,o=i+l,A=a+l;break;case 2:s=n+l,i=o-l,A=a+l;break;case 3:n=s-l,i=o-l,A=a+l;break;case 4:s=n+l,o=i+l,a=A-l;break;case 5:n=s-l,o=i+l,a=A-l;break;case 6:s=n+l,i=o-l,a=A-l;break;case 7:n=s-l,i=o-l,a=A-l;break}this._root&&this._root.length&&(this._root=c)}return this._x0=n,this._y0=i,this._z0=a,this._x1=s,this._y1=o,this._z1=A,this}function a7(){var r=[];return this.visit(function(e){if(!e.length)do r.push(e.data);while(e=e.next)}),r}function s7(r){return arguments.length?this.cover(+r[0][0],+r[0][1],+r[0][2]).cover(+r[1][0],+r[1][1],+r[1][2]):isNaN(this._x0)?void 0:[[this._x0,this._y0,this._z0],[this._x1,this._y1,this._z1]]}function Mt(r,e,t,n,i,a,s){this.node=r,this.x0=e,this.y0=t,this.z0=n,this.x1=i,this.y1=a,this.z1=s}function o7(r,e,t,n){var i,a=this._x0,s=this._y0,o=this._z0,A,l,c,u,h,d,f=this._x1,g=this._y1,v=this._z1,p=[],y=this._root,m,B;for(y&&p.push(new Mt(y,a,s,o,f,g,v)),n==null?n=1/0:(a=r-n,s=e-n,o=t-n,f=r+n,g=e+n,v=t+n,n*=n);m=p.pop();)if(!(!(y=m.node)||(A=m.x0)>f||(l=m.y0)>g||(c=m.z0)>v||(u=m.x1)<a||(h=m.y1)<s||(d=m.z1)<o))if(y.length){var C=(A+u)/2,S=(l+h)/2,F=(c+d)/2;p.push(new Mt(y[7],C,S,F,u,h,d),new Mt(y[6],A,S,F,C,h,d),new Mt(y[5],C,l,F,u,S,d),new Mt(y[4],A,l,F,C,S,d),new Mt(y[3],C,S,c,u,h,F),new Mt(y[2],A,S,c,C,h,F),new Mt(y[1],C,l,c,u,S,F),new Mt(y[0],A,l,c,C,S,F)),(B=(t>=F)<<2|(e>=S)<<1|r>=C)&&(m=p[p.length-1],p[p.length-1]=p[p.length-1-B],p[p.length-1-B]=m)}else{var T=r-+this._x.call(null,y.data),O=e-+this._y.call(null,y.data),_=t-+this._z.call(null,y.data),k=T*T+O*O+_*_;if(k<n){var L=Math.sqrt(n=k);a=r-L,s=e-L,o=t-L,f=r+L,g=e+L,v=t+L,i=y.data}}return i}const A7=(r,e,t,n,i,a)=>Math.sqrt((r-n)**2+(e-i)**2+(t-a)**2);function l7(r,e,t,n){const i=[],a=r-n,s=e-n,o=t-n,A=r+n,l=e+n,c=t+n;return this.visit((u,h,d,f,g,v,p)=>{if(!u.length)do{const y=u.data;A7(r,e,t,this._x(y),this._y(y),this._z(y))<=n&&i.push(y)}while(u=u.next);return h>A||d>l||f>c||g<a||v<s||p<o}),i}function c7(r){if(isNaN(h=+this._x.call(null,r))||isNaN(d=+this._y.call(null,r))||isNaN(f=+this._z.call(null,r)))return this;var e,t=this._root,n,i,a,s=this._x0,o=this._y0,A=this._z0,l=this._x1,c=this._y1,u=this._z1,h,d,f,g,v,p,y,m,B,C,S;if(!t)return this;if(t.length)for(;;){if((y=h>=(g=(s+l)/2))?s=g:l=g,(m=d>=(v=(o+c)/2))?o=v:c=v,(B=f>=(p=(A+u)/2))?A=p:u=p,e=t,!(t=t[C=B<<2|m<<1|y]))return this;if(!t.length)break;(e[C+1&7]||e[C+2&7]||e[C+3&7]||e[C+4&7]||e[C+5&7]||e[C+6&7]||e[C+7&7])&&(n=e,S=C)}for(;t.data!==r;)if(i=t,!(t=t.next))return this;return(a=t.next)&&delete t.next,i?(a?i.next=a:delete i.next,this):e?(a?e[C]=a:delete e[C],(t=e[0]||e[1]||e[2]||e[3]||e[4]||e[5]||e[6]||e[7])&&t===(e[7]||e[6]||e[5]||e[4]||e[3]||e[2]||e[1]||e[0])&&!t.length&&(n?n[S]=t:this._root=t),this):(this._root=a,this)}function u7(r){for(var e=0,t=r.length;e<t;++e)this.remove(r[e]);return this}function h7(){return this._root}function d7(){var r=0;return this.visit(function(e){if(!e.length)do++r;while(e=e.next)}),r}function f7(r){var e=[],t,n=this._root,i,a,s,o,A,l,c;for(n&&e.push(new Mt(n,this._x0,this._y0,this._z0,this._x1,this._y1,this._z1));t=e.pop();)if(!r(n=t.node,a=t.x0,s=t.y0,o=t.z0,A=t.x1,l=t.y1,c=t.z1)&&n.length){var u=(a+A)/2,h=(s+l)/2,d=(o+c)/2;(i=n[7])&&e.push(new Mt(i,u,h,d,A,l,c)),(i=n[6])&&e.push(new Mt(i,a,h,d,u,l,c)),(i=n[5])&&e.push(new Mt(i,u,s,d,A,h,c)),(i=n[4])&&e.push(new Mt(i,a,s,d,u,h,c)),(i=n[3])&&e.push(new Mt(i,u,h,o,A,l,d)),(i=n[2])&&e.push(new Mt(i,a,h,o,u,l,d)),(i=n[1])&&e.push(new Mt(i,u,s,o,A,h,d)),(i=n[0])&&e.push(new Mt(i,a,s,o,u,h,d))}return this}function g7(r){var e=[],t=[],n;for(this._root&&e.push(new Mt(this._root,this._x0,this._y0,this._z0,this._x1,this._y1,this._z1));n=e.pop();){var i=n.node;if(i.length){var a,s=n.x0,o=n.y0,A=n.z0,l=n.x1,c=n.y1,u=n.z1,h=(s+l)/2,d=(o+c)/2,f=(A+u)/2;(a=i[0])&&e.push(new Mt(a,s,o,A,h,d,f)),(a=i[1])&&e.push(new Mt(a,h,o,A,l,d,f)),(a=i[2])&&e.push(new Mt(a,s,d,A,h,c,f)),(a=i[3])&&e.push(new Mt(a,h,d,A,l,c,f)),(a=i[4])&&e.push(new Mt(a,s,o,f,h,d,u)),(a=i[5])&&e.push(new Mt(a,h,o,f,l,d,u)),(a=i[6])&&e.push(new Mt(a,s,d,f,h,c,u)),(a=i[7])&&e.push(new Mt(a,h,d,f,l,c,u))}t.push(n)}for(;n=t.pop();)r(n.node,n.x0,n.y0,n.z0,n.x1,n.y1,n.z1);return this}function v7(r){return r[0]}function p7(r){return arguments.length?(this._x=r,this):this._x}function y7(r){return r[1]}function m7(r){return arguments.length?(this._y=r,this):this._y}function w7(r){return r[2]}function B7(r){return arguments.length?(this._z=r,this):this._z}function yQ(r,e,t,n){var i=new QB(e??v7,t??y7,n??w7,NaN,NaN,NaN,NaN,NaN,NaN);return r==null?i:i.addAll(r)}function QB(r,e,t,n,i,a,s,o,A){this._x=r,this._y=e,this._z=t,this._x0=n,this._y0=i,this._z0=a,this._x1=s,this._y1=o,this._z1=A,this._root=void 0}function fC(r){for(var e={data:r.data},t=e;r=r.next;)t=t.next={data:r.data};return e}var Wn=yQ.prototype=QB.prototype;Wn.copy=function(){var r=new QB(this._x,this._y,this._z,this._x0,this._y0,this._z0,this._x1,this._y1,this._z1),e=this._root,t,n;if(!e)return r;if(!e.length)return r._root=fC(e),r;for(t=[{source:e,target:r._root=new Array(8)}];e=t.pop();)for(var i=0;i<8;++i)(n=e.source[i])&&(n.length?t.push({source:n,target:e.target[i]=new Array(8)}):e.target[i]=fC(n));return r};Wn.add=n7;Wn.addAll=r7;Wn.cover=i7;Wn.data=a7;Wn.extent=s7;Wn.find=o7;Wn.findAllWithinRadius=l7;Wn.remove=c7;Wn.removeAll=u7;Wn.root=h7;Wn.size=d7;Wn.visit=f7;Wn.visitAfter=g7;Wn.x=p7;Wn.y=m7;Wn.z=B7;const b7=.81,Mg=.1;function E7(r,e,t,n,i=2){const a=e/t,s=r.getAllNodes(),o=s.map((c,u)=>{const{nodeStrength:h,x:d,y:f,z:g,size:v}=c.data;return{x:d,y:f,z:g,size:v,index:u,id:c.id,vx:0,vy:0,vz:0,weight:a*h}}),A=(i===2?xd(o,c=>c.x,c=>c.y):yQ(o,c=>c.x,c=>c.y,c=>c.z)).visitAfter(x7),l=new Map;return o.forEach(c=>{l.set(c.id,c),S7(c,A,i)}),o.map((c,u)=>{const{id:h,data:d}=s[u],{mass:f=1}=d;n[h]={x:c.vx/f,y:c.vy/f,z:c.vz/f}}),n}function x7(r){let e=0,t=0,n=0,i=0,a=0;const s=r.length;if(s){for(let o=0;o<s;o++){const A=r[o];A&&A.weight&&(e+=A.weight,t+=A.x*A.weight,n+=A.y*A.weight,i+=A.z*A.weight,a+=A.size*A.weight)}r.x=t/e,r.y=n/e,r.z=i/e,r.size=a/e,r.weight=e}else{const o=r;r.x=o.data.x,r.y=o.data.y,r.z=o.data.z,r.size=o.data.size,r.weight=o.data.weight}}const C7=(r,e,t,n,i,a,s)=>{var o;if(((o=r.data)===null||o===void 0?void 0:o.id)===a.id)return;const A=[t,n,i][s-1],l=a.x-r.x||Mg,c=a.y-r.y||Mg,u=a.z-r.z||Mg,h=[l,c,u],d=A-e;let f=0;for(let p=0;p<s;p++)f+=h[p]*h[p];const v=Math.sqrt(f)*f;if(d*d*b7<f){const p=r.weight/v;return a.vx+=l*p,a.vy+=c*p,a.vz+=u*p,!0}if(r.length)return!1;if(r.data!==a){const p=r.data.weight/v;a.vx+=l*p,a.vy+=c*p,a.vz+=u*p}};function S7(r,e,t){e.visit((n,i,a,s,o)=>C7(n,i,a,s,o,r,t))}const F7={dimensions:2,maxIteration:500,gravity:10,factor:1,edgeStrength:50,nodeStrength:1e3,coulombDisScale:.005,damping:.9,maxSpeed:200,minMovement:.4,interval:.02,linkDistance:200,clusterNodeStrength:20,preventOverlap:!0,distanceThresholdMode:"mean"};class mQ{constructor(e={}){this.options=e,this.id="force",this.timeInterval=0,this.judgingDistance=0,this.running=!1,this.options=Object.assign(Object.assign({},F7),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericForceLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericForceLayout(!0,e,t)})}stop(){this.timeInterval&&typeof window<"u"&&window.clearInterval(this.timeInterval),this.running=!1}tick(e=this.options.maxIteration||1){if(this.lastResult)return this.lastResult;for(let n=0;(this.judgingDistance>this.lastOptions.minMovement||n<1)&&n<e;n++)this.runOneStep(this.lastCalcGraph,this.lastGraph,n,this.lastVelMap,this.lastOptions),this.updatePosition(this.lastGraph,this.lastCalcGraph,this.lastVelMap,this.lastOptions);const t={nodes:this.lastLayoutNodes,edges:this.lastLayoutEdges};return this.lastAssign&&t.nodes.forEach(n=>this.lastGraph.mergeNodeData(n.id,{x:n.data.x,y:n.data.y,z:this.options.dimensions===3?n.data.z:void 0})),t}genericForceLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},this.options),n),a=t.getAllNodes(),s=t.getAllEdges(),o=this.formatOptions(i,t),{dimensions:A,width:l,height:c,nodeSize:u,getMass:h,nodeStrength:d,edgeStrength:f,linkDistance:g}=o,v=a.map((T,O)=>Object.assign(Object.assign({},T),{data:Object.assign(Object.assign({},T.data),{x:Be(T.data.x)?T.data.x:Math.random()*l,y:Be(T.data.y)?T.data.y:Math.random()*c,z:Be(T.data.z)?T.data.z:Math.random()*Math.sqrt(l*c),size:u(T)||30,mass:h(T),nodeStrength:d(T)})})),p=s.map(T=>Object.assign(Object.assign({},T),{data:Object.assign(Object.assign({},T.data),{edgeStrength:f(T),linkDistance:g(T,t.getNode(T.source),t.getNode(T.target))})}));if(!(a!=null&&a.length))return this.lastResult={nodes:[],edges:s},{nodes:[],edges:s};const y={};a.forEach((T,O)=>{y[T.id]={x:0,y:0,z:0}});const m=new Mn({nodes:v,edges:p});this.formatCentripetal(o,m);const{maxIteration:B,minMovement:C,onTick:S}=o;if(this.lastLayoutNodes=v,this.lastLayoutEdges=p,this.lastAssign=e,this.lastGraph=t,this.lastCalcGraph=m,this.lastOptions=o,this.lastVelMap=y,typeof window>"u")return;let F=0;return new Promise(T=>{this.timeInterval=window.setInterval(()=>{(!a||!this.running)&&T({nodes:Og(t,v),edges:s}),this.runOneStep(m,t,F,y,o),this.updatePosition(t,m,y,o),e&&v.forEach(O=>t.mergeNodeData(O.id,{x:O.data.x,y:O.data.y,z:A===3?O.data.z:void 0})),S==null||S({nodes:Og(t,v),edges:s}),F++,(F>=B||this.judgingDistance<C)&&(window.clearInterval(this.timeInterval),T({nodes:Og(t,v),edges:s}))},0),this.running=!0})})}formatOptions(e,t){const n=Object.assign({},e),{width:i,height:a,getMass:s}=e;n.width=!i&&typeof window<"u"?window.innerWidth:i,n.height=!a&&typeof window<"u"?window.innerHeight:a,e.center||(n.center=[n.width/2,n.height/2]),s||(n.getMass=A=>{let l=1;Be(A==null?void 0:A.data.mass)&&(l=A==null?void 0:A.data.mass);const c=t.getDegree(A.id,"both");return!c||c<5?l:c*5*l}),n.nodeSize=kB(e.nodeSize,e.nodeSpacing);const o=e.linkDistance?Us(1,e.linkDistance):A=>1+n.nodeSize(t.getNode(A.source))+n.nodeSize(t.getNode(A.target));return n.linkDistance=o,n.nodeStrength=Us(1,e.nodeStrength),n.edgeStrength=Us(1,e.edgeStrength),n}formatCentripetal(e,t){const{dimensions:n,centripetalOptions:i,center:a,clusterNodeStrength:s,leafCluster:o,clustering:A,nodeClusterBy:l}=e,c=t.getAllNodes(),u=i||{leaf:2,single:2,others:1,center:p=>({x:a[0],y:a[1],z:n===3?a[2]:void 0})};typeof s!="function"&&(e.clusterNodeStrength=p=>s);let h,d;if(o&&l&&(h=gC(t,l),d=Array.from(new Set(c==null?void 0:c.map(p=>p.data[l])))||[],e.centripetalOptions=Object.assign(u,{single:100,leaf:p=>{const{siblingLeaves:y,sameTypeLeaves:m}=h[p.id]||{};return(m==null?void 0:m.length)===(y==null?void 0:y.length)||(d==null?void 0:d.length)===1?1:e.clusterNodeStrength(p)},others:1,center:p=>{const y=t.getDegree(p.id,"both");if(!y)return{x:100,y:100,z:0};let m;if(y===1){const{sameTypeLeaves:B=[]}=h[p.id]||{};B.length===1?m=void 0:B.length>1&&(m=vC(B))}else m=void 0;return{x:m==null?void 0:m.x,y:m==null?void 0:m.y,z:m==null?void 0:m.z}}})),A&&l){h||(h=gC(t,l)),d||(d=Array.from(new Set(c.map(y=>y.data[l])))),d=d.filter(y=>y!==void 0);const p={};d.forEach(y=>{const m=c.filter(B=>B.data[l]===y).map(B=>t.getNode(B.id));p[y]=vC(m)}),e.centripetalOptions=Object.assign(u,{single:y=>e.clusterNodeStrength(y),leaf:y=>e.clusterNodeStrength(y),others:y=>e.clusterNodeStrength(y),center:y=>{const m=p[y.data[l]];return{x:m==null?void 0:m.x,y:m==null?void 0:m.y,z:m==null?void 0:m.z}}})}const{leaf:f,single:g,others:v}=e.centripetalOptions||{};f&&typeof f!="function"&&(e.centripetalOptions.leaf=()=>f),g&&typeof g!="function"&&(e.centripetalOptions.single=()=>g),v&&typeof v!="function"&&(e.centripetalOptions.others=()=>v)}runOneStep(e,t,n,i,a){const s={},o=e.getAllNodes(),A=e.getAllEdges();if(!(o!=null&&o.length))return;const{monitor:l}=a;if(this.calRepulsive(e,s,a),A&&this.calAttractive(e,s,a),this.calGravity(e,t,s,a),this.updateVelocity(e,s,i,a),l){const c=this.calTotalEnergy(s,o);l({energy:c,nodes:t.getAllNodes(),edges:t.getAllEdges(),iterations:n})}}calTotalEnergy(e,t){if(!(t!=null&&t.length))return 0;let n=0;return t.forEach((i,a)=>{const s=e[i.id].x,o=e[i.id].y,A=this.options.dimensions===3?e[i.id].z:0,l=s*s+o*o+A*A,{mass:c=1}=i.data;n+=c*l*.5}),n}calRepulsive(e,t,n){const{dimensions:i,factor:a,coulombDisScale:s}=n;E7(e,a,s*s,t,i)}calAttractive(e,t,n){const{dimensions:i,nodeSize:a}=n;e.getAllEdges().forEach((s,o)=>{const{source:A,target:l}=s,c=e.getNode(A),u=e.getNode(l);if(!c||!u)return;let h=u.data.x-c.data.x,d=u.data.y-c.data.y,f=i===3?u.data.z-c.data.z:0;!h&&!d&&(h=Math.random()*.01,d=Math.random()*.01,i===3&&!f&&(f=Math.random()*.01));const g=Math.sqrt(h*h+d*d+f*f);if(g<a(c)+a(u))return;const v=h/g,p=d/g,y=f/g,{linkDistance:m=200,edgeStrength:B=200}=s.data||{},S=(m-g)*B,F=c.data.mass||1,T=u.data.mass||1,O=1/F,_=1/T,k=v*S,L=p*S,U=y*S;t[A].x-=k*O,t[A].y-=L*O,t[A].z-=U*O,t[l].x+=k*_,t[l].y+=L*_,t[l].z+=U*_})}calGravity(e,t,n,i){const{getCenter:a}=i,s=e.getAllNodes(),o=t.getAllNodes(),A=t.getAllEdges(),{width:l,height:c,center:u,gravity:h,centripetalOptions:d}=i;s&&s.forEach(f=>{const{id:g,data:v}=f,{mass:p,x:y,y:m,z:B}=v,C=t.getNode(g);let S=0,F=0,T=0,O=h;const _=e.getDegree(g,"in"),k=e.getDegree(g,"out"),L=e.getDegree(g,"both"),U=a==null?void 0:a(C,L);if(U){const[G,W,V]=U;S=y-G,F=m-W,O=V}else S=y-u[0],F=m-u[1],T=B-u[2];if(O&&(n[g].x-=O*S/p,n[g].y-=O*F/p,n[g].z-=O*T/p),d){const{leaf:G,single:W,others:V,center:K}=d,{x:D,y:X,z:te,centerStrength:ie}=(K==null?void 0:K(C,o,A,l,c))||{x:0,y:0,z:0,centerStrength:0};if(!Be(D)||!Be(X))return;const re=(y-D)/p,xe=(m-X)/p,$=(B-te)/p;if(ie&&(n[g].x-=ie*re,n[g].y-=ie*xe,n[g].z-=ie*$),L===0){const ee=W(C);if(!ee)return;n[g].x-=ee*re,n[g].y-=ee*xe,n[g].z-=ee*$;return}if(_===0||k===0){const ee=G(C,o,A);if(!ee)return;n[g].x-=ee*re,n[g].y-=ee*xe,n[g].z-=ee*$;return}const z=V(C);if(!z)return;n[g].x-=z*re,n[g].y-=z*xe,n[g].z-=z*$}})}updateVelocity(e,t,n,i){const{damping:a,maxSpeed:s,interval:o,dimensions:A}=i,l=e.getAllNodes();l!=null&&l.length&&l.forEach(c=>{const{id:u}=c;let h=(n[u].x+t[u].x*o)*a||.01,d=(n[u].y+t[u].y*o)*a||.01,f=A===3?(n[u].z+t[u].z*o)*a||.01:0;const g=Math.sqrt(h*h+d*d+f*f);if(g>s){const v=s/g;h=v*h,d=v*d,f=v*f}n[u]={x:h,y:d,z:f}})}updatePosition(e,t,n,i){const{distanceThresholdMode:a,interval:s,dimensions:o}=i,A=t.getAllNodes();if(!(A!=null&&A.length)){this.judgingDistance=0;return}let l=0;a==="max"?this.judgingDistance=-1/0:a==="min"&&(this.judgingDistance=1/0),A.forEach(c=>{const{id:u}=c,h=e.getNode(u);if(Be(h.data.fx)&&Be(h.data.fy)){t.mergeNodeData(u,{x:h.data.fx,y:h.data.fy,z:o===3?h.data.fz:void 0});return}const d=n[u].x*s,f=n[u].y*s,g=o===3?n[u].z*s:0;t.mergeNodeData(u,{x:c.data.x+d,y:c.data.y+f,z:c.data.z+g});const v=Math.sqrt(d*d+f*f+g*g);switch(a){case"max":this.judgingDistance<v&&(this.judgingDistance=v);break;case"min":this.judgingDistance>v&&(this.judgingDistance=v);break;default:l=l+v;break}}),(!a||a==="mean")&&(this.judgingDistance=l/A.length)}}const gC=(r,e)=>{const t=r.getAllNodes();if(!(t!=null&&t.length))return{};const n={};return t.forEach((i,a)=>{r.getDegree(i.id,"both")===1&&(n[i.id]=T7(r,"leaf",i,e))}),n},T7=(r,e,t,n)=>{const i=r.getDegree(t.id,"in"),a=r.getDegree(t.id,"out");let s=t,o=[];i===0?(s=r.getSuccessors(t.id)[0],o=r.getNeighbors(s.id)):a===0&&(s=r.getPredecessors(t.id)[0],o=r.getNeighbors(s.id)),o=o.filter(l=>r.getDegree(l.id,"in")===0||r.getDegree(l.id,"out")===0);const A=M7(r,e,n,t,o);return{coreNode:s,siblingLeaves:o,sameTypeLeaves:A}},M7=(r,e,t,n,i)=>{const a=n.data[t]||"";let s=(i==null?void 0:i.filter(o=>o.data[t]===a))||[];return s=s.filter(o=>r.getDegree(o.id,"in")===0||r.getDegree(o.id,"out")===0),s},vC=r=>{const e={x:0,y:0};r.forEach(n=>{const{x:i,y:a}=n.data;e.x+=i||0,e.y+=a||0});const t=r.length||1;return{x:e.x/t,y:e.y/t}},Og=(r,e)=>e.map(t=>{const{id:n,data:i}=t,a=r.getNode(n);return Object.assign(Object.assign({},a),{data:Object.assign(Object.assign({},a.data),{x:i.x,y:i.y,z:i.z})})});var rt={};const O7=Object.prototype.toString;function Bl(r){const e=O7.call(r);return e.endsWith("Array]")&&!e.includes("Big")}const _7=Object.freeze(Object.defineProperty({__proto__:null,isAnyArray:Bl},Symbol.toStringTag,{value:"Module"})),I7=f_(_7);function k7(r){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};if(!Bl(r))throw new TypeError("input must be an array");if(r.length===0)throw new TypeError("input must not be empty");var t=e.fromIndex,n=t===void 0?0:t,i=e.toIndex,a=i===void 0?r.length:i;if(n<0||n>=r.length||!Number.isInteger(n))throw new Error("fromIndex must be a positive integer smaller than length");if(a<=n||a>r.length||!Number.isInteger(a))throw new Error("toIndex must be an integer greater than fromIndex and at most equal to length");for(var s=r[n],o=n+1;o<a;o++)r[o]>s&&(s=r[o]);return s}function L7(r){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};if(!Bl(r))throw new TypeError("input must be an array");if(r.length===0)throw new TypeError("input must not be empty");var t=e.fromIndex,n=t===void 0?0:t,i=e.toIndex,a=i===void 0?r.length:i;if(n<0||n>=r.length||!Number.isInteger(n))throw new Error("fromIndex must be a positive integer smaller than length");if(a<=n||a>r.length||!Number.isInteger(a))throw new Error("toIndex must be an integer greater than fromIndex and at most equal to length");for(var s=r[n],o=n+1;o<a;o++)r[o]<s&&(s=r[o]);return s}function Q7(r){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};if(Bl(r)){if(r.length===0)throw new TypeError("input must not be empty")}else throw new TypeError("input must be an array");var t;if(e.output!==void 0){if(!Bl(e.output))throw new TypeError("output option must be an array if specified");t=e.output}else t=new Array(r.length);var n=L7(r),i=k7(r);if(n===i)throw new RangeError("minimum and maximum input values are equal. Cannot rescale a constant array");var a=e.min,s=a===void 0?e.autoMinMax?n:0:a,o=e.max,A=o===void 0?e.autoMinMax?i:1:o;if(s>=A)throw new RangeError("min option must be smaller than max option");for(var l=(A-s)/(i-n),c=0;c<r.length;c++)t[c]=(r[c]-n)*l+s;return t}const N7=Object.freeze(Object.defineProperty({__proto__:null,default:Q7},Symbol.toStringTag,{value:"Module"})),U7=f_(N7);var pC;function P7(){if(pC)return rt;pC=1,Object.defineProperty(rt,"__esModule",{value:!0});var r=I7,e=U7;const t=" ".repeat(2),n=" ".repeat(4);function i(){return a(this)}function a(I,b={}){const{maxRows:E=15,maxColumns:w=10,maxNumSize:x=8,padMinus:M="auto"}=b;return`${I.constructor.name} {
|
|
7
|
+
${t}[
|
|
8
|
+
${n}${s(I,E,w,x,M)}
|
|
9
|
+
${t}]
|
|
10
|
+
${t}rows: ${I.rows}
|
|
11
|
+
${t}columns: ${I.columns}
|
|
12
|
+
}`}function s(I,b,E,w,x){const{rows:M,columns:Q}=I,N=Math.min(M,b),P=Math.min(Q,E),R=[];if(x==="auto"){x=!1;e:for(let J=0;J<N;J++)for(let j=0;j<P;j++)if(I.get(J,j)<0){x=!0;break e}}for(let J=0;J<N;J++){let j=[];for(let oe=0;oe<P;oe++)j.push(o(I.get(J,oe),w,x));R.push(`${j.join(" ")}`)}return P!==Q&&(R[R.length-1]+=` ... ${Q-E} more columns`),N!==M&&R.push(`... ${M-b} more rows`),R.join(`
|
|
13
|
+
${n}`)}function o(I,b,E){return(I>=0&&E?` ${A(I,b-1)}`:A(I,b)).padEnd(b)}function A(I,b){let E=I.toString();if(E.length<=b)return E;let w=I.toFixed(b);if(w.length>b&&(w=I.toFixed(Math.max(0,b-(w.length-b)))),w.length<=b&&!w.startsWith("0.000")&&!w.startsWith("-0.000"))return w;let x=I.toExponential(b);return x.length>b&&(x=I.toExponential(Math.max(0,b-(x.length-b)))),x.slice(0)}function l(I,b){I.prototype.add=function(w){return typeof w=="number"?this.addS(w):this.addM(w)},I.prototype.addS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)+w);return this},I.prototype.addM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)+w.get(x,M));return this},I.add=function(w,x){return new b(w).add(x)},I.prototype.sub=function(w){return typeof w=="number"?this.subS(w):this.subM(w)},I.prototype.subS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)-w);return this},I.prototype.subM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)-w.get(x,M));return this},I.sub=function(w,x){return new b(w).sub(x)},I.prototype.subtract=I.prototype.sub,I.prototype.subtractS=I.prototype.subS,I.prototype.subtractM=I.prototype.subM,I.subtract=I.sub,I.prototype.mul=function(w){return typeof w=="number"?this.mulS(w):this.mulM(w)},I.prototype.mulS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)*w);return this},I.prototype.mulM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)*w.get(x,M));return this},I.mul=function(w,x){return new b(w).mul(x)},I.prototype.multiply=I.prototype.mul,I.prototype.multiplyS=I.prototype.mulS,I.prototype.multiplyM=I.prototype.mulM,I.multiply=I.mul,I.prototype.div=function(w){return typeof w=="number"?this.divS(w):this.divM(w)},I.prototype.divS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)/w);return this},I.prototype.divM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)/w.get(x,M));return this},I.div=function(w,x){return new b(w).div(x)},I.prototype.divide=I.prototype.div,I.prototype.divideS=I.prototype.divS,I.prototype.divideM=I.prototype.divM,I.divide=I.div,I.prototype.mod=function(w){return typeof w=="number"?this.modS(w):this.modM(w)},I.prototype.modS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)%w);return this},I.prototype.modM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)%w.get(x,M));return this},I.mod=function(w,x){return new b(w).mod(x)},I.prototype.modulus=I.prototype.mod,I.prototype.modulusS=I.prototype.modS,I.prototype.modulusM=I.prototype.modM,I.modulus=I.mod,I.prototype.and=function(w){return typeof w=="number"?this.andS(w):this.andM(w)},I.prototype.andS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)&w);return this},I.prototype.andM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)&w.get(x,M));return this},I.and=function(w,x){return new b(w).and(x)},I.prototype.or=function(w){return typeof w=="number"?this.orS(w):this.orM(w)},I.prototype.orS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)|w);return this},I.prototype.orM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)|w.get(x,M));return this},I.or=function(w,x){return new b(w).or(x)},I.prototype.xor=function(w){return typeof w=="number"?this.xorS(w):this.xorM(w)},I.prototype.xorS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)^w);return this},I.prototype.xorM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)^w.get(x,M));return this},I.xor=function(w,x){return new b(w).xor(x)},I.prototype.leftShift=function(w){return typeof w=="number"?this.leftShiftS(w):this.leftShiftM(w)},I.prototype.leftShiftS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)<<w);return this},I.prototype.leftShiftM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)<<w.get(x,M));return this},I.leftShift=function(w,x){return new b(w).leftShift(x)},I.prototype.signPropagatingRightShift=function(w){return typeof w=="number"?this.signPropagatingRightShiftS(w):this.signPropagatingRightShiftM(w)},I.prototype.signPropagatingRightShiftS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)>>w);return this},I.prototype.signPropagatingRightShiftM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)>>w.get(x,M));return this},I.signPropagatingRightShift=function(w,x){return new b(w).signPropagatingRightShift(x)},I.prototype.rightShift=function(w){return typeof w=="number"?this.rightShiftS(w):this.rightShiftM(w)},I.prototype.rightShiftS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)>>>w);return this},I.prototype.rightShiftM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)>>>w.get(x,M));return this},I.rightShift=function(w,x){return new b(w).rightShift(x)},I.prototype.zeroFillRightShift=I.prototype.rightShift,I.prototype.zeroFillRightShiftS=I.prototype.rightShiftS,I.prototype.zeroFillRightShiftM=I.prototype.rightShiftM,I.zeroFillRightShift=I.rightShift,I.prototype.not=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,~this.get(w,x));return this},I.not=function(w){return new b(w).not()},I.prototype.abs=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.abs(this.get(w,x)));return this},I.abs=function(w){return new b(w).abs()},I.prototype.acos=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.acos(this.get(w,x)));return this},I.acos=function(w){return new b(w).acos()},I.prototype.acosh=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.acosh(this.get(w,x)));return this},I.acosh=function(w){return new b(w).acosh()},I.prototype.asin=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.asin(this.get(w,x)));return this},I.asin=function(w){return new b(w).asin()},I.prototype.asinh=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.asinh(this.get(w,x)));return this},I.asinh=function(w){return new b(w).asinh()},I.prototype.atan=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.atan(this.get(w,x)));return this},I.atan=function(w){return new b(w).atan()},I.prototype.atanh=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.atanh(this.get(w,x)));return this},I.atanh=function(w){return new b(w).atanh()},I.prototype.cbrt=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.cbrt(this.get(w,x)));return this},I.cbrt=function(w){return new b(w).cbrt()},I.prototype.ceil=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.ceil(this.get(w,x)));return this},I.ceil=function(w){return new b(w).ceil()},I.prototype.clz32=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.clz32(this.get(w,x)));return this},I.clz32=function(w){return new b(w).clz32()},I.prototype.cos=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.cos(this.get(w,x)));return this},I.cos=function(w){return new b(w).cos()},I.prototype.cosh=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.cosh(this.get(w,x)));return this},I.cosh=function(w){return new b(w).cosh()},I.prototype.exp=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.exp(this.get(w,x)));return this},I.exp=function(w){return new b(w).exp()},I.prototype.expm1=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.expm1(this.get(w,x)));return this},I.expm1=function(w){return new b(w).expm1()},I.prototype.floor=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.floor(this.get(w,x)));return this},I.floor=function(w){return new b(w).floor()},I.prototype.fround=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.fround(this.get(w,x)));return this},I.fround=function(w){return new b(w).fround()},I.prototype.log=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.log(this.get(w,x)));return this},I.log=function(w){return new b(w).log()},I.prototype.log1p=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.log1p(this.get(w,x)));return this},I.log1p=function(w){return new b(w).log1p()},I.prototype.log10=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.log10(this.get(w,x)));return this},I.log10=function(w){return new b(w).log10()},I.prototype.log2=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.log2(this.get(w,x)));return this},I.log2=function(w){return new b(w).log2()},I.prototype.round=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.round(this.get(w,x)));return this},I.round=function(w){return new b(w).round()},I.prototype.sign=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.sign(this.get(w,x)));return this},I.sign=function(w){return new b(w).sign()},I.prototype.sin=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.sin(this.get(w,x)));return this},I.sin=function(w){return new b(w).sin()},I.prototype.sinh=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.sinh(this.get(w,x)));return this},I.sinh=function(w){return new b(w).sinh()},I.prototype.sqrt=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.sqrt(this.get(w,x)));return this},I.sqrt=function(w){return new b(w).sqrt()},I.prototype.tan=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.tan(this.get(w,x)));return this},I.tan=function(w){return new b(w).tan()},I.prototype.tanh=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.tanh(this.get(w,x)));return this},I.tanh=function(w){return new b(w).tanh()},I.prototype.trunc=function(){for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.set(w,x,Math.trunc(this.get(w,x)));return this},I.trunc=function(w){return new b(w).trunc()},I.pow=function(w,x){return new b(w).pow(x)},I.prototype.pow=function(w){return typeof w=="number"?this.powS(w):this.powM(w)},I.prototype.powS=function(w){for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)**w);return this},I.prototype.powM=function(w){if(w=b.checkMatrix(w),this.rows!==w.rows||this.columns!==w.columns)throw new RangeError("Matrices dimensions must be equal");for(let x=0;x<this.rows;x++)for(let M=0;M<this.columns;M++)this.set(x,M,this.get(x,M)**w.get(x,M));return this}}function c(I,b,E){let w=E?I.rows:I.rows-1;if(b<0||b>w)throw new RangeError("Row index out of range")}function u(I,b,E){let w=E?I.columns:I.columns-1;if(b<0||b>w)throw new RangeError("Column index out of range")}function h(I,b){if(b.to1DArray&&(b=b.to1DArray()),b.length!==I.columns)throw new RangeError("vector size must be the same as the number of columns");return b}function d(I,b){if(b.to1DArray&&(b=b.to1DArray()),b.length!==I.rows)throw new RangeError("vector size must be the same as the number of rows");return b}function f(I,b){if(!r.isAnyArray(b))throw new TypeError("row indices must be an array");for(let E=0;E<b.length;E++)if(b[E]<0||b[E]>=I.rows)throw new RangeError("row indices are out of range")}function g(I,b){if(!r.isAnyArray(b))throw new TypeError("column indices must be an array");for(let E=0;E<b.length;E++)if(b[E]<0||b[E]>=I.columns)throw new RangeError("column indices are out of range")}function v(I,b,E,w,x){if(arguments.length!==5)throw new RangeError("expected 4 arguments");if(y("startRow",b),y("endRow",E),y("startColumn",w),y("endColumn",x),b>E||w>x||b<0||b>=I.rows||E<0||E>=I.rows||w<0||w>=I.columns||x<0||x>=I.columns)throw new RangeError("Submatrix indices are out of range")}function p(I,b=0){let E=[];for(let w=0;w<I;w++)E.push(b);return E}function y(I,b){if(typeof b!="number")throw new TypeError(`${I} must be a number`)}function m(I){if(I.isEmpty())throw new Error("Empty matrix has no elements to index")}function B(I){let b=p(I.rows);for(let E=0;E<I.rows;++E)for(let w=0;w<I.columns;++w)b[E]+=I.get(E,w);return b}function C(I){let b=p(I.columns);for(let E=0;E<I.rows;++E)for(let w=0;w<I.columns;++w)b[w]+=I.get(E,w);return b}function S(I){let b=0;for(let E=0;E<I.rows;E++)for(let w=0;w<I.columns;w++)b+=I.get(E,w);return b}function F(I){let b=p(I.rows,1);for(let E=0;E<I.rows;++E)for(let w=0;w<I.columns;++w)b[E]*=I.get(E,w);return b}function T(I){let b=p(I.columns,1);for(let E=0;E<I.rows;++E)for(let w=0;w<I.columns;++w)b[w]*=I.get(E,w);return b}function O(I){let b=1;for(let E=0;E<I.rows;E++)for(let w=0;w<I.columns;w++)b*=I.get(E,w);return b}function _(I,b,E){const w=I.rows,x=I.columns,M=[];for(let Q=0;Q<w;Q++){let N=0,P=0,R=0;for(let J=0;J<x;J++)R=I.get(Q,J)-E[Q],N+=R,P+=R*R;b?M.push((P-N*N/x)/(x-1)):M.push((P-N*N/x)/x)}return M}function k(I,b,E){const w=I.rows,x=I.columns,M=[];for(let Q=0;Q<x;Q++){let N=0,P=0,R=0;for(let J=0;J<w;J++)R=I.get(J,Q)-E[Q],N+=R,P+=R*R;b?M.push((P-N*N/w)/(w-1)):M.push((P-N*N/w)/w)}return M}function L(I,b,E){const w=I.rows,x=I.columns,M=w*x;let Q=0,N=0,P=0;for(let R=0;R<w;R++)for(let J=0;J<x;J++)P=I.get(R,J)-E,Q+=P,N+=P*P;return b?(N-Q*Q/M)/(M-1):(N-Q*Q/M)/M}function U(I,b){for(let E=0;E<I.rows;E++)for(let w=0;w<I.columns;w++)I.set(E,w,I.get(E,w)-b[E])}function G(I,b){for(let E=0;E<I.rows;E++)for(let w=0;w<I.columns;w++)I.set(E,w,I.get(E,w)-b[w])}function W(I,b){for(let E=0;E<I.rows;E++)for(let w=0;w<I.columns;w++)I.set(E,w,I.get(E,w)-b)}function V(I){const b=[];for(let E=0;E<I.rows;E++){let w=0;for(let x=0;x<I.columns;x++)w+=I.get(E,x)**2/(I.columns-1);b.push(Math.sqrt(w))}return b}function K(I,b){for(let E=0;E<I.rows;E++)for(let w=0;w<I.columns;w++)I.set(E,w,I.get(E,w)/b[E])}function D(I){const b=[];for(let E=0;E<I.columns;E++){let w=0;for(let x=0;x<I.rows;x++)w+=I.get(x,E)**2/(I.rows-1);b.push(Math.sqrt(w))}return b}function X(I,b){for(let E=0;E<I.rows;E++)for(let w=0;w<I.columns;w++)I.set(E,w,I.get(E,w)/b[w])}function te(I){const b=I.size-1;let E=0;for(let w=0;w<I.columns;w++)for(let x=0;x<I.rows;x++)E+=I.get(x,w)**2/b;return Math.sqrt(E)}function ie(I,b){for(let E=0;E<I.rows;E++)for(let w=0;w<I.columns;w++)I.set(E,w,I.get(E,w)/b)}class re{static from1DArray(b,E,w){if(b*E!==w.length)throw new RangeError("data length does not match given dimensions");let M=new z(b,E);for(let Q=0;Q<b;Q++)for(let N=0;N<E;N++)M.set(Q,N,w[Q*E+N]);return M}static rowVector(b){let E=new z(1,b.length);for(let w=0;w<b.length;w++)E.set(0,w,b[w]);return E}static columnVector(b){let E=new z(b.length,1);for(let w=0;w<b.length;w++)E.set(w,0,b[w]);return E}static zeros(b,E){return new z(b,E)}static ones(b,E){return new z(b,E).fill(1)}static rand(b,E,w={}){if(typeof w!="object")throw new TypeError("options must be an object");const{random:x=Math.random}=w;let M=new z(b,E);for(let Q=0;Q<b;Q++)for(let N=0;N<E;N++)M.set(Q,N,x());return M}static randInt(b,E,w={}){if(typeof w!="object")throw new TypeError("options must be an object");const{min:x=0,max:M=1e3,random:Q=Math.random}=w;if(!Number.isInteger(x))throw new TypeError("min must be an integer");if(!Number.isInteger(M))throw new TypeError("max must be an integer");if(x>=M)throw new RangeError("min must be smaller than max");let N=M-x,P=new z(b,E);for(let R=0;R<b;R++)for(let J=0;J<E;J++){let j=x+Math.round(Q()*N);P.set(R,J,j)}return P}static eye(b,E,w){E===void 0&&(E=b),w===void 0&&(w=1);let x=Math.min(b,E),M=this.zeros(b,E);for(let Q=0;Q<x;Q++)M.set(Q,Q,w);return M}static diag(b,E,w){let x=b.length;E===void 0&&(E=x),w===void 0&&(w=E);let M=Math.min(x,E,w),Q=this.zeros(E,w);for(let N=0;N<M;N++)Q.set(N,N,b[N]);return Q}static min(b,E){b=this.checkMatrix(b),E=this.checkMatrix(E);let w=b.rows,x=b.columns,M=new z(w,x);for(let Q=0;Q<w;Q++)for(let N=0;N<x;N++)M.set(Q,N,Math.min(b.get(Q,N),E.get(Q,N)));return M}static max(b,E){b=this.checkMatrix(b),E=this.checkMatrix(E);let w=b.rows,x=b.columns,M=new this(w,x);for(let Q=0;Q<w;Q++)for(let N=0;N<x;N++)M.set(Q,N,Math.max(b.get(Q,N),E.get(Q,N)));return M}static checkMatrix(b){return re.isMatrix(b)?b:new z(b)}static isMatrix(b){return b!=null&&b.klass==="Matrix"}get size(){return this.rows*this.columns}apply(b){if(typeof b!="function")throw new TypeError("callback must be a function");for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)b.call(this,E,w);return this}to1DArray(){let b=[];for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)b.push(this.get(E,w));return b}to2DArray(){let b=[];for(let E=0;E<this.rows;E++){b.push([]);for(let w=0;w<this.columns;w++)b[E].push(this.get(E,w))}return b}toJSON(){return this.to2DArray()}isRowVector(){return this.rows===1}isColumnVector(){return this.columns===1}isVector(){return this.rows===1||this.columns===1}isSquare(){return this.rows===this.columns}isEmpty(){return this.rows===0||this.columns===0}isSymmetric(){if(this.isSquare()){for(let b=0;b<this.rows;b++)for(let E=0;E<=b;E++)if(this.get(b,E)!==this.get(E,b))return!1;return!0}return!1}isDistance(){if(!this.isSymmetric())return!1;for(let b=0;b<this.rows;b++)if(this.get(b,b)!==0)return!1;return!0}isEchelonForm(){let b=0,E=0,w=-1,x=!0,M=!1;for(;b<this.rows&&x;){for(E=0,M=!1;E<this.columns&&M===!1;)this.get(b,E)===0?E++:this.get(b,E)===1&&E>w?(M=!0,w=E):(x=!1,M=!0);b++}return x}isReducedEchelonForm(){let b=0,E=0,w=-1,x=!0,M=!1;for(;b<this.rows&&x;){for(E=0,M=!1;E<this.columns&&M===!1;)this.get(b,E)===0?E++:this.get(b,E)===1&&E>w?(M=!0,w=E):(x=!1,M=!0);for(let Q=E+1;Q<this.rows;Q++)this.get(b,Q)!==0&&(x=!1);b++}return x}echelonForm(){let b=this.clone(),E=0,w=0;for(;E<b.rows&&w<b.columns;){let x=E;for(let M=E;M<b.rows;M++)b.get(M,w)>b.get(x,w)&&(x=M);if(b.get(x,w)===0)w++;else{b.swapRows(E,x);let M=b.get(E,w);for(let Q=w;Q<b.columns;Q++)b.set(E,Q,b.get(E,Q)/M);for(let Q=E+1;Q<b.rows;Q++){let N=b.get(Q,w)/b.get(E,w);b.set(Q,w,0);for(let P=w+1;P<b.columns;P++)b.set(Q,P,b.get(Q,P)-b.get(E,P)*N)}E++,w++}}return b}reducedEchelonForm(){let b=this.echelonForm(),E=b.columns,w=b.rows,x=w-1;for(;x>=0;)if(b.maxRow(x)===0)x--;else{let M=0,Q=!1;for(;M<w&&Q===!1;)b.get(x,M)===1?Q=!0:M++;for(let N=0;N<x;N++){let P=b.get(N,M);for(let R=M;R<E;R++){let J=b.get(N,R)-P*b.get(x,R);b.set(N,R,J)}}x--}return b}set(){throw new Error("set method is unimplemented")}get(){throw new Error("get method is unimplemented")}repeat(b={}){if(typeof b!="object")throw new TypeError("options must be an object");const{rows:E=1,columns:w=1}=b;if(!Number.isInteger(E)||E<=0)throw new TypeError("rows must be a positive integer");if(!Number.isInteger(w)||w<=0)throw new TypeError("columns must be a positive integer");let x=new z(this.rows*E,this.columns*w);for(let M=0;M<E;M++)for(let Q=0;Q<w;Q++)x.setSubMatrix(this,this.rows*M,this.columns*Q);return x}fill(b){for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,b);return this}neg(){return this.mulS(-1)}getRow(b){c(this,b);let E=[];for(let w=0;w<this.columns;w++)E.push(this.get(b,w));return E}getRowVector(b){return z.rowVector(this.getRow(b))}setRow(b,E){c(this,b),E=h(this,E);for(let w=0;w<this.columns;w++)this.set(b,w,E[w]);return this}swapRows(b,E){c(this,b),c(this,E);for(let w=0;w<this.columns;w++){let x=this.get(b,w);this.set(b,w,this.get(E,w)),this.set(E,w,x)}return this}getColumn(b){u(this,b);let E=[];for(let w=0;w<this.rows;w++)E.push(this.get(w,b));return E}getColumnVector(b){return z.columnVector(this.getColumn(b))}setColumn(b,E){u(this,b),E=d(this,E);for(let w=0;w<this.rows;w++)this.set(w,b,E[w]);return this}swapColumns(b,E){u(this,b),u(this,E);for(let w=0;w<this.rows;w++){let x=this.get(w,b);this.set(w,b,this.get(w,E)),this.set(w,E,x)}return this}addRowVector(b){b=h(this,b);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,this.get(E,w)+b[w]);return this}subRowVector(b){b=h(this,b);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,this.get(E,w)-b[w]);return this}mulRowVector(b){b=h(this,b);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,this.get(E,w)*b[w]);return this}divRowVector(b){b=h(this,b);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,this.get(E,w)/b[w]);return this}addColumnVector(b){b=d(this,b);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,this.get(E,w)+b[E]);return this}subColumnVector(b){b=d(this,b);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,this.get(E,w)-b[E]);return this}mulColumnVector(b){b=d(this,b);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,this.get(E,w)*b[E]);return this}divColumnVector(b){b=d(this,b);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)this.set(E,w,this.get(E,w)/b[E]);return this}mulRow(b,E){c(this,b);for(let w=0;w<this.columns;w++)this.set(b,w,this.get(b,w)*E);return this}mulColumn(b,E){u(this,b);for(let w=0;w<this.rows;w++)this.set(w,b,this.get(w,b)*E);return this}max(b){if(this.isEmpty())return NaN;switch(b){case"row":{const E=new Array(this.rows).fill(Number.NEGATIVE_INFINITY);for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.get(w,x)>E[w]&&(E[w]=this.get(w,x));return E}case"column":{const E=new Array(this.columns).fill(Number.NEGATIVE_INFINITY);for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.get(w,x)>E[x]&&(E[x]=this.get(w,x));return E}case void 0:{let E=this.get(0,0);for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.get(w,x)>E&&(E=this.get(w,x));return E}default:throw new Error(`invalid option: ${b}`)}}maxIndex(){m(this);let b=this.get(0,0),E=[0,0];for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.get(w,x)>b&&(b=this.get(w,x),E[0]=w,E[1]=x);return E}min(b){if(this.isEmpty())return NaN;switch(b){case"row":{const E=new Array(this.rows).fill(Number.POSITIVE_INFINITY);for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.get(w,x)<E[w]&&(E[w]=this.get(w,x));return E}case"column":{const E=new Array(this.columns).fill(Number.POSITIVE_INFINITY);for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.get(w,x)<E[x]&&(E[x]=this.get(w,x));return E}case void 0:{let E=this.get(0,0);for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.get(w,x)<E&&(E=this.get(w,x));return E}default:throw new Error(`invalid option: ${b}`)}}minIndex(){m(this);let b=this.get(0,0),E=[0,0];for(let w=0;w<this.rows;w++)for(let x=0;x<this.columns;x++)this.get(w,x)<b&&(b=this.get(w,x),E[0]=w,E[1]=x);return E}maxRow(b){if(c(this,b),this.isEmpty())return NaN;let E=this.get(b,0);for(let w=1;w<this.columns;w++)this.get(b,w)>E&&(E=this.get(b,w));return E}maxRowIndex(b){c(this,b),m(this);let E=this.get(b,0),w=[b,0];for(let x=1;x<this.columns;x++)this.get(b,x)>E&&(E=this.get(b,x),w[1]=x);return w}minRow(b){if(c(this,b),this.isEmpty())return NaN;let E=this.get(b,0);for(let w=1;w<this.columns;w++)this.get(b,w)<E&&(E=this.get(b,w));return E}minRowIndex(b){c(this,b),m(this);let E=this.get(b,0),w=[b,0];for(let x=1;x<this.columns;x++)this.get(b,x)<E&&(E=this.get(b,x),w[1]=x);return w}maxColumn(b){if(u(this,b),this.isEmpty())return NaN;let E=this.get(0,b);for(let w=1;w<this.rows;w++)this.get(w,b)>E&&(E=this.get(w,b));return E}maxColumnIndex(b){u(this,b),m(this);let E=this.get(0,b),w=[0,b];for(let x=1;x<this.rows;x++)this.get(x,b)>E&&(E=this.get(x,b),w[0]=x);return w}minColumn(b){if(u(this,b),this.isEmpty())return NaN;let E=this.get(0,b);for(let w=1;w<this.rows;w++)this.get(w,b)<E&&(E=this.get(w,b));return E}minColumnIndex(b){u(this,b),m(this);let E=this.get(0,b),w=[0,b];for(let x=1;x<this.rows;x++)this.get(x,b)<E&&(E=this.get(x,b),w[0]=x);return w}diag(){let b=Math.min(this.rows,this.columns),E=[];for(let w=0;w<b;w++)E.push(this.get(w,w));return E}norm(b="frobenius"){switch(b){case"max":return this.max();case"frobenius":return Math.sqrt(this.dot(this));default:throw new RangeError(`unknown norm type: ${b}`)}}cumulativeSum(){let b=0;for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)b+=this.get(E,w),this.set(E,w,b);return this}dot(b){re.isMatrix(b)&&(b=b.to1DArray());let E=this.to1DArray();if(E.length!==b.length)throw new RangeError("vectors do not have the same size");let w=0;for(let x=0;x<E.length;x++)w+=E[x]*b[x];return w}mmul(b){b=z.checkMatrix(b);let E=this.rows,w=this.columns,x=b.columns,M=new z(E,x),Q=new Float64Array(w);for(let N=0;N<x;N++){for(let P=0;P<w;P++)Q[P]=b.get(P,N);for(let P=0;P<E;P++){let R=0;for(let J=0;J<w;J++)R+=this.get(P,J)*Q[J];M.set(P,N,R)}}return M}strassen2x2(b){b=z.checkMatrix(b);let E=new z(2,2);const w=this.get(0,0),x=b.get(0,0),M=this.get(0,1),Q=b.get(0,1),N=this.get(1,0),P=b.get(1,0),R=this.get(1,1),J=b.get(1,1),j=(w+R)*(x+J),oe=(N+R)*x,me=w*(Q-J),ne=R*(P-x),ce=(w+M)*J,Ce=(N-w)*(x+Q),q=(M-R)*(P+J),ye=j+ne-ce+q,Oe=me+ce,Ke=oe+ne,je=j-oe+me+Ce;return E.set(0,0,ye),E.set(0,1,Oe),E.set(1,0,Ke),E.set(1,1,je),E}strassen3x3(b){b=z.checkMatrix(b);let E=new z(3,3);const w=this.get(0,0),x=this.get(0,1),M=this.get(0,2),Q=this.get(1,0),N=this.get(1,1),P=this.get(1,2),R=this.get(2,0),J=this.get(2,1),j=this.get(2,2),oe=b.get(0,0),me=b.get(0,1),ne=b.get(0,2),ce=b.get(1,0),Ce=b.get(1,1),q=b.get(1,2),ye=b.get(2,0),Oe=b.get(2,1),Ke=b.get(2,2),je=(w+x+M-Q-N-J-j)*Ce,Ht=(w-Q)*(-me+Ce),Qe=N*(-oe+me+ce-Ce-q-ye+Ke),Pe=(-w+Q+N)*(oe-me+Ce),Ft=(Q+N)*(-oe+me),Y=w*oe,fe=(-w+R+J)*(oe-ne+q),Se=(-w+R)*(ne-q),ve=(R+J)*(-oe+ne),Gt=(w+x+M-N-P-R-J)*q,yt=J*(-oe+ne+ce-Ce-q-ye+Oe),Qt=(-M+J+j)*(Ce+ye-Oe),Kt=(M-j)*(Ce-Oe),Nn=M*ye,Ai=(J+j)*(-ye+Oe),bn=(-M+N+P)*(q+ye-Ke),Ti=(M-P)*(q-Ke),ta=(N+P)*(-ye+Ke),st=x*ce,Un=P*Oe,_r=Q*ne,Ir=R*me,En=j*Ke,IU=Y+Nn+st,kU=je+Pe+Ft+Y+Qt+Nn+Ai,LU=Y+fe+ve+Gt+Nn+bn+ta,QU=Ht+Qe+Pe+Y+Nn+bn+Ti,NU=Ht+Pe+Ft+Y+Un,UU=Nn+bn+Ti+ta+_r,PU=Y+fe+Se+yt+Qt+Kt+Nn,RU=Qt+Kt+Nn+Ai+Ir,DU=Y+fe+Se+ve+En;return E.set(0,0,IU),E.set(0,1,kU),E.set(0,2,LU),E.set(1,0,QU),E.set(1,1,NU),E.set(1,2,UU),E.set(2,0,PU),E.set(2,1,RU),E.set(2,2,DU),E}mmulStrassen(b){b=z.checkMatrix(b);let E=this.clone(),w=E.rows,x=E.columns,M=b.rows,Q=b.columns;x!==M&&console.warn(`Multiplying ${w} x ${x} and ${M} x ${Q} matrix: dimensions do not match.`);function N(j,oe,me){let ne=j.rows,ce=j.columns;if(ne===oe&&ce===me)return j;{let Ce=re.zeros(oe,me);return Ce=Ce.setSubMatrix(j,0,0),Ce}}let P=Math.max(w,M),R=Math.max(x,Q);E=N(E,P,R),b=N(b,P,R);function J(j,oe,me,ne){if(me<=512||ne<=512)return j.mmul(oe);me%2===1&&ne%2===1?(j=N(j,me+1,ne+1),oe=N(oe,me+1,ne+1)):me%2===1?(j=N(j,me+1,ne),oe=N(oe,me+1,ne)):ne%2===1&&(j=N(j,me,ne+1),oe=N(oe,me,ne+1));let ce=parseInt(j.rows/2,10),Ce=parseInt(j.columns/2,10),q=j.subMatrix(0,ce-1,0,Ce-1),ye=oe.subMatrix(0,ce-1,0,Ce-1),Oe=j.subMatrix(0,ce-1,Ce,j.columns-1),Ke=oe.subMatrix(0,ce-1,Ce,oe.columns-1),je=j.subMatrix(ce,j.rows-1,0,Ce-1),Ht=oe.subMatrix(ce,oe.rows-1,0,Ce-1),Qe=j.subMatrix(ce,j.rows-1,Ce,j.columns-1),Pe=oe.subMatrix(ce,oe.rows-1,Ce,oe.columns-1),Ft=J(re.add(q,Qe),re.add(ye,Pe),ce,Ce),Y=J(re.add(je,Qe),ye,ce,Ce),fe=J(q,re.sub(Ke,Pe),ce,Ce),Se=J(Qe,re.sub(Ht,ye),ce,Ce),ve=J(re.add(q,Oe),Pe,ce,Ce),Gt=J(re.sub(je,q),re.add(ye,Ke),ce,Ce),yt=J(re.sub(Oe,Qe),re.add(Ht,Pe),ce,Ce),Qt=re.add(Ft,Se);Qt.sub(ve),Qt.add(yt);let Kt=re.add(fe,ve),Nn=re.add(Y,Se),Ai=re.sub(Ft,Y);Ai.add(fe),Ai.add(Gt);let bn=re.zeros(2*Qt.rows,2*Qt.columns);return bn=bn.setSubMatrix(Qt,0,0),bn=bn.setSubMatrix(Kt,Qt.rows,0),bn=bn.setSubMatrix(Nn,0,Qt.columns),bn=bn.setSubMatrix(Ai,Qt.rows,Qt.columns),bn.subMatrix(0,me-1,0,ne-1)}return J(E,b,P,R)}scaleRows(b={}){if(typeof b!="object")throw new TypeError("options must be an object");const{min:E=0,max:w=1}=b;if(!Number.isFinite(E))throw new TypeError("min must be a number");if(!Number.isFinite(w))throw new TypeError("max must be a number");if(E>=w)throw new RangeError("min must be smaller than max");let x=new z(this.rows,this.columns);for(let M=0;M<this.rows;M++){const Q=this.getRow(M);Q.length>0&&e(Q,{min:E,max:w,output:Q}),x.setRow(M,Q)}return x}scaleColumns(b={}){if(typeof b!="object")throw new TypeError("options must be an object");const{min:E=0,max:w=1}=b;if(!Number.isFinite(E))throw new TypeError("min must be a number");if(!Number.isFinite(w))throw new TypeError("max must be a number");if(E>=w)throw new RangeError("min must be smaller than max");let x=new z(this.rows,this.columns);for(let M=0;M<this.columns;M++){const Q=this.getColumn(M);Q.length&&e(Q,{min:E,max:w,output:Q}),x.setColumn(M,Q)}return x}flipRows(){const b=Math.ceil(this.columns/2);for(let E=0;E<this.rows;E++)for(let w=0;w<b;w++){let x=this.get(E,w),M=this.get(E,this.columns-1-w);this.set(E,w,M),this.set(E,this.columns-1-w,x)}return this}flipColumns(){const b=Math.ceil(this.rows/2);for(let E=0;E<this.columns;E++)for(let w=0;w<b;w++){let x=this.get(w,E),M=this.get(this.rows-1-w,E);this.set(w,E,M),this.set(this.rows-1-w,E,x)}return this}kroneckerProduct(b){b=z.checkMatrix(b);let E=this.rows,w=this.columns,x=b.rows,M=b.columns,Q=new z(E*x,w*M);for(let N=0;N<E;N++)for(let P=0;P<w;P++)for(let R=0;R<x;R++)for(let J=0;J<M;J++)Q.set(x*N+R,M*P+J,this.get(N,P)*b.get(R,J));return Q}kroneckerSum(b){if(b=z.checkMatrix(b),!this.isSquare()||!b.isSquare())throw new Error("Kronecker Sum needs two Square Matrices");let E=this.rows,w=b.rows,x=this.kroneckerProduct(z.eye(w,w)),M=z.eye(E,E).kroneckerProduct(b);return x.add(M)}transpose(){let b=new z(this.columns,this.rows);for(let E=0;E<this.rows;E++)for(let w=0;w<this.columns;w++)b.set(w,E,this.get(E,w));return b}sortRows(b=xe){for(let E=0;E<this.rows;E++)this.setRow(E,this.getRow(E).sort(b));return this}sortColumns(b=xe){for(let E=0;E<this.columns;E++)this.setColumn(E,this.getColumn(E).sort(b));return this}subMatrix(b,E,w,x){v(this,b,E,w,x);let M=new z(E-b+1,x-w+1);for(let Q=b;Q<=E;Q++)for(let N=w;N<=x;N++)M.set(Q-b,N-w,this.get(Q,N));return M}subMatrixRow(b,E,w){if(E===void 0&&(E=0),w===void 0&&(w=this.columns-1),E>w||E<0||E>=this.columns||w<0||w>=this.columns)throw new RangeError("Argument out of range");let x=new z(b.length,w-E+1);for(let M=0;M<b.length;M++)for(let Q=E;Q<=w;Q++){if(b[M]<0||b[M]>=this.rows)throw new RangeError(`Row index out of range: ${b[M]}`);x.set(M,Q-E,this.get(b[M],Q))}return x}subMatrixColumn(b,E,w){if(E===void 0&&(E=0),w===void 0&&(w=this.rows-1),E>w||E<0||E>=this.rows||w<0||w>=this.rows)throw new RangeError("Argument out of range");let x=new z(w-E+1,b.length);for(let M=0;M<b.length;M++)for(let Q=E;Q<=w;Q++){if(b[M]<0||b[M]>=this.columns)throw new RangeError(`Column index out of range: ${b[M]}`);x.set(Q-E,M,this.get(Q,b[M]))}return x}setSubMatrix(b,E,w){if(b=z.checkMatrix(b),b.isEmpty())return this;let x=E+b.rows-1,M=w+b.columns-1;v(this,E,x,w,M);for(let Q=0;Q<b.rows;Q++)for(let N=0;N<b.columns;N++)this.set(E+Q,w+N,b.get(Q,N));return this}selection(b,E){f(this,b),g(this,E);let w=new z(b.length,E.length);for(let x=0;x<b.length;x++){let M=b[x];for(let Q=0;Q<E.length;Q++){let N=E[Q];w.set(x,Q,this.get(M,N))}}return w}trace(){let b=Math.min(this.rows,this.columns),E=0;for(let w=0;w<b;w++)E+=this.get(w,w);return E}clone(){return this.constructor.copy(this,new z(this.rows,this.columns))}static copy(b,E){for(const[w,x,M]of b.entries())E.set(w,x,M);return E}sum(b){switch(b){case"row":return B(this);case"column":return C(this);case void 0:return S(this);default:throw new Error(`invalid option: ${b}`)}}product(b){switch(b){case"row":return F(this);case"column":return T(this);case void 0:return O(this);default:throw new Error(`invalid option: ${b}`)}}mean(b){const E=this.sum(b);switch(b){case"row":{for(let w=0;w<this.rows;w++)E[w]/=this.columns;return E}case"column":{for(let w=0;w<this.columns;w++)E[w]/=this.rows;return E}case void 0:return E/this.size;default:throw new Error(`invalid option: ${b}`)}}variance(b,E={}){if(typeof b=="object"&&(E=b,b=void 0),typeof E!="object")throw new TypeError("options must be an object");const{unbiased:w=!0,mean:x=this.mean(b)}=E;if(typeof w!="boolean")throw new TypeError("unbiased must be a boolean");switch(b){case"row":{if(!r.isAnyArray(x))throw new TypeError("mean must be an array");return _(this,w,x)}case"column":{if(!r.isAnyArray(x))throw new TypeError("mean must be an array");return k(this,w,x)}case void 0:{if(typeof x!="number")throw new TypeError("mean must be a number");return L(this,w,x)}default:throw new Error(`invalid option: ${b}`)}}standardDeviation(b,E){typeof b=="object"&&(E=b,b=void 0);const w=this.variance(b,E);if(b===void 0)return Math.sqrt(w);for(let x=0;x<w.length;x++)w[x]=Math.sqrt(w[x]);return w}center(b,E={}){if(typeof b=="object"&&(E=b,b=void 0),typeof E!="object")throw new TypeError("options must be an object");const{center:w=this.mean(b)}=E;switch(b){case"row":{if(!r.isAnyArray(w))throw new TypeError("center must be an array");return U(this,w),this}case"column":{if(!r.isAnyArray(w))throw new TypeError("center must be an array");return G(this,w),this}case void 0:{if(typeof w!="number")throw new TypeError("center must be a number");return W(this,w),this}default:throw new Error(`invalid option: ${b}`)}}scale(b,E={}){if(typeof b=="object"&&(E=b,b=void 0),typeof E!="object")throw new TypeError("options must be an object");let w=E.scale;switch(b){case"row":{if(w===void 0)w=V(this);else if(!r.isAnyArray(w))throw new TypeError("scale must be an array");return K(this,w),this}case"column":{if(w===void 0)w=D(this);else if(!r.isAnyArray(w))throw new TypeError("scale must be an array");return X(this,w),this}case void 0:{if(w===void 0)w=te(this);else if(typeof w!="number")throw new TypeError("scale must be a number");return ie(this,w),this}default:throw new Error(`invalid option: ${b}`)}}toString(b){return a(this,b)}[Symbol.iterator](){return this.entries()}*entries(){for(let b=0;b<this.rows;b++)for(let E=0;E<this.columns;E++)yield[b,E,this.get(b,E)]}*values(){for(let b=0;b<this.rows;b++)for(let E=0;E<this.columns;E++)yield this.get(b,E)}}re.prototype.klass="Matrix",typeof Symbol<"u"&&(re.prototype[Symbol.for("nodejs.util.inspect.custom")]=i);function xe(I,b){return I-b}function $(I){return I.every(b=>typeof b=="number")}re.random=re.rand,re.randomInt=re.randInt,re.diagonal=re.diag,re.prototype.diagonal=re.prototype.diag,re.identity=re.eye,re.prototype.negate=re.prototype.neg,re.prototype.tensorProduct=re.prototype.kroneckerProduct;class z extends re{data;#e(b,E){if(this.data=[],Number.isInteger(E)&&E>=0)for(let w=0;w<b;w++)this.data.push(new Float64Array(E));else throw new TypeError("nColumns must be a positive integer");this.rows=b,this.columns=E}constructor(b,E){if(super(),z.isMatrix(b))this.#e(b.rows,b.columns),z.copy(b,this);else if(Number.isInteger(b)&&b>=0)this.#e(b,E);else if(r.isAnyArray(b)){const w=b;if(b=w.length,E=b?w[0].length:0,typeof E!="number")throw new TypeError("Data must be a 2D array with at least one element");this.data=[];for(let x=0;x<b;x++){if(w[x].length!==E)throw new RangeError("Inconsistent array dimensions");if(!$(w[x]))throw new TypeError("Input data contains non-numeric values");this.data.push(Float64Array.from(w[x]))}this.rows=b,this.columns=E}else throw new TypeError("First argument must be a positive number or an array")}set(b,E,w){return this.data[b][E]=w,this}get(b,E){return this.data[b][E]}removeRow(b){return c(this,b),this.data.splice(b,1),this.rows-=1,this}addRow(b,E){return E===void 0&&(E=b,b=this.rows),c(this,b,!0),E=Float64Array.from(h(this,E)),this.data.splice(b,0,E),this.rows+=1,this}removeColumn(b){u(this,b);for(let E=0;E<this.rows;E++){const w=new Float64Array(this.columns-1);for(let x=0;x<b;x++)w[x]=this.data[E][x];for(let x=b+1;x<this.columns;x++)w[x-1]=this.data[E][x];this.data[E]=w}return this.columns-=1,this}addColumn(b,E){typeof E>"u"&&(E=b,b=this.columns),u(this,b,!0),E=d(this,E);for(let w=0;w<this.rows;w++){const x=new Float64Array(this.columns+1);let M=0;for(;M<b;M++)x[M]=this.data[w][M];for(x[M++]=E[w];M<this.columns+1;M++)x[M]=this.data[w][M-1];this.data[w]=x}return this.columns+=1,this}}l(re,z);class ee extends re{#e;get size(){return this.#e.size}get rows(){return this.#e.rows}get columns(){return this.#e.columns}get diagonalSize(){return this.rows}static isSymmetricMatrix(b){return z.isMatrix(b)&&b.klassType==="SymmetricMatrix"}static zeros(b){return new this(b)}static ones(b){return new this(b).fill(1)}constructor(b){if(super(),z.isMatrix(b)){if(!b.isSymmetric())throw new TypeError("not symmetric data");this.#e=z.copy(b,new z(b.rows,b.rows))}else if(Number.isInteger(b)&&b>=0)this.#e=new z(b,b);else if(this.#e=new z(b),!this.isSymmetric())throw new TypeError("not symmetric data")}clone(){const b=new ee(this.diagonalSize);for(const[E,w,x]of this.upperRightEntries())b.set(E,w,x);return b}toMatrix(){return new z(this)}get(b,E){return this.#e.get(b,E)}set(b,E,w){return this.#e.set(b,E,w),this.#e.set(E,b,w),this}removeCross(b){return this.#e.removeRow(b),this.#e.removeColumn(b),this}addCross(b,E){E===void 0&&(E=b,b=this.diagonalSize);const w=E.slice();return w.splice(b,1),this.#e.addRow(b,w),this.#e.addColumn(b,E),this}applyMask(b){if(b.length!==this.diagonalSize)throw new RangeError("Mask size do not match with matrix size");const E=[];for(const[w,x]of b.entries())x||E.push(w);E.reverse();for(const w of E)this.removeCross(w);return this}toCompact(){const{diagonalSize:b}=this,E=new Array(b*(b+1)/2);for(let w=0,x=0,M=0;M<E.length;M++)E[M]=this.get(x,w),++w>=b&&(w=++x);return E}static fromCompact(b){const E=b.length,w=(Math.sqrt(8*E+1)-1)/2;if(!Number.isInteger(w))throw new TypeError(`This array is not a compact representation of a Symmetric Matrix, ${JSON.stringify(b)}`);const x=new ee(w);for(let M=0,Q=0,N=0;N<E;N++)x.set(M,Q,b[N]),++M>=w&&(M=++Q);return x}*upperRightEntries(){for(let b=0,E=0;b<this.diagonalSize;void 0){const w=this.get(b,E);yield[b,E,w],++E>=this.diagonalSize&&(E=++b)}}*upperRightValues(){for(let b=0,E=0;b<this.diagonalSize;void 0)yield this.get(b,E),++E>=this.diagonalSize&&(E=++b)}}ee.prototype.klassType="SymmetricMatrix";class Ae extends ee{static isDistanceMatrix(b){return ee.isSymmetricMatrix(b)&&b.klassSubType==="DistanceMatrix"}constructor(b){if(super(b),!this.isDistance())throw new TypeError("Provided arguments do no produce a distance matrix")}set(b,E,w){return b===E&&(w=0),super.set(b,E,w)}addCross(b,E){return E===void 0&&(E=b,b=this.diagonalSize),E=E.slice(),E[b]=0,super.addCross(b,E)}toSymmetricMatrix(){return new ee(this)}clone(){const b=new Ae(this.diagonalSize);for(const[E,w,x]of this.upperRightEntries())E!==w&&b.set(E,w,x);return b}toCompact(){const{diagonalSize:b}=this,E=(b-1)*b/2,w=new Array(E);for(let x=1,M=0,Q=0;Q<w.length;Q++)w[Q]=this.get(M,x),++x>=b&&(x=++M+1);return w}static fromCompact(b){const E=b.length;if(E===0)return new this(0);const w=(Math.sqrt(8*E+1)+1)/2;if(!Number.isInteger(w))throw new TypeError(`This array is not a compact representation of a DistanceMatrix, ${JSON.stringify(b)}`);const x=new this(w);for(let M=1,Q=0,N=0;N<E;N++)x.set(M,Q,b[N]),++M>=w&&(M=++Q+1);return x}}Ae.prototype.klassSubType="DistanceMatrix";class be extends re{constructor(b,E,w){super(),this.matrix=b,this.rows=E,this.columns=w}}class Le extends be{constructor(b,E){u(b,E),super(b,b.rows,1),this.column=E}set(b,E,w){return this.matrix.set(b,this.column,w),this}get(b){return this.matrix.get(b,this.column)}}class Ue extends be{constructor(b,E){g(b,E),super(b,b.rows,E.length),this.columnIndices=E}set(b,E,w){return this.matrix.set(b,this.columnIndices[E],w),this}get(b,E){return this.matrix.get(b,this.columnIndices[E])}}class at extends be{constructor(b){super(b,b.rows,b.columns)}set(b,E,w){return this.matrix.set(b,this.columns-E-1,w),this}get(b,E){return this.matrix.get(b,this.columns-E-1)}}class lt extends be{constructor(b){super(b,b.rows,b.columns)}set(b,E,w){return this.matrix.set(this.rows-b-1,E,w),this}get(b,E){return this.matrix.get(this.rows-b-1,E)}}class ct extends be{constructor(b,E){c(b,E),super(b,1,b.columns),this.row=E}set(b,E,w){return this.matrix.set(this.row,E,w),this}get(b,E){return this.matrix.get(this.row,E)}}class pt extends be{constructor(b,E){f(b,E),super(b,E.length,b.columns),this.rowIndices=E}set(b,E,w){return this.matrix.set(this.rowIndices[b],E,w),this}get(b,E){return this.matrix.get(this.rowIndices[b],E)}}class Ne extends be{constructor(b,E,w){f(b,E),g(b,w),super(b,E.length,w.length),this.rowIndices=E,this.columnIndices=w}set(b,E,w){return this.matrix.set(this.rowIndices[b],this.columnIndices[E],w),this}get(b,E){return this.matrix.get(this.rowIndices[b],this.columnIndices[E])}}class ht extends be{constructor(b,E,w,x,M){v(b,E,w,x,M),super(b,w-E+1,M-x+1),this.startRow=E,this.startColumn=x}set(b,E,w){return this.matrix.set(this.startRow+b,this.startColumn+E,w),this}get(b,E){return this.matrix.get(this.startRow+b,this.startColumn+E)}}class nt extends be{constructor(b){super(b,b.columns,b.rows)}set(b,E,w){return this.matrix.set(E,b,w),this}get(b,E){return this.matrix.get(E,b)}}class gr extends re{constructor(b,E={}){const{rows:w=1}=E;if(b.length%w!==0)throw new Error("the data length is not divisible by the number of rows");super(),this.rows=w,this.columns=b.length/w,this.data=b}set(b,E,w){let x=this._calculateIndex(b,E);return this.data[x]=w,this}get(b,E){let w=this._calculateIndex(b,E);return this.data[w]}_calculateIndex(b,E){return b*this.columns+E}}class St extends re{constructor(b){super(),this.data=b,this.rows=b.length,this.columns=b[0].length}set(b,E,w){return this.data[b][E]=w,this}get(b,E){return this.data[b][E]}}function Ji(I,b){if(r.isAnyArray(I))return I[0]&&r.isAnyArray(I[0])?new St(I):new gr(I,b);throw new Error("the argument is not an array")}class ir{constructor(b){b=St.checkMatrix(b);let E=b.clone(),w=E.rows,x=E.columns,M=new Float64Array(w),Q=1,N,P,R,J,j,oe,me,ne,ce;for(N=0;N<w;N++)M[N]=N;for(ne=new Float64Array(w),P=0;P<x;P++){for(N=0;N<w;N++)ne[N]=E.get(N,P);for(N=0;N<w;N++){for(ce=Math.min(N,P),j=0,R=0;R<ce;R++)j+=E.get(N,R)*ne[R];ne[N]-=j,E.set(N,P,ne[N])}for(J=P,N=P+1;N<w;N++)Math.abs(ne[N])>Math.abs(ne[J])&&(J=N);if(J!==P){for(R=0;R<x;R++)oe=E.get(J,R),E.set(J,R,E.get(P,R)),E.set(P,R,oe);me=M[J],M[J]=M[P],M[P]=me,Q=-Q}if(P<w&&E.get(P,P)!==0)for(N=P+1;N<w;N++)E.set(N,P,E.get(N,P)/E.get(P,P))}this.LU=E,this.pivotVector=M,this.pivotSign=Q}isSingular(){let b=this.LU,E=b.columns;for(let w=0;w<E;w++)if(b.get(w,w)===0)return!0;return!1}solve(b){b=z.checkMatrix(b);let E=this.LU;if(E.rows!==b.rows)throw new Error("Invalid matrix dimensions");if(this.isSingular())throw new Error("LU matrix is singular");let x=b.columns,M=b.subMatrixRow(this.pivotVector,0,x-1),Q=E.columns,N,P,R;for(R=0;R<Q;R++)for(N=R+1;N<Q;N++)for(P=0;P<x;P++)M.set(N,P,M.get(N,P)-M.get(R,P)*E.get(N,R));for(R=Q-1;R>=0;R--){for(P=0;P<x;P++)M.set(R,P,M.get(R,P)/E.get(R,R));for(N=0;N<R;N++)for(P=0;P<x;P++)M.set(N,P,M.get(N,P)-M.get(R,P)*E.get(N,R))}return M}get determinant(){let b=this.LU;if(!b.isSquare())throw new Error("Matrix must be square");let E=this.pivotSign,w=b.columns;for(let x=0;x<w;x++)E*=b.get(x,x);return E}get lowerTriangularMatrix(){let b=this.LU,E=b.rows,w=b.columns,x=new z(E,w);for(let M=0;M<E;M++)for(let Q=0;Q<w;Q++)M>Q?x.set(M,Q,b.get(M,Q)):M===Q?x.set(M,Q,1):x.set(M,Q,0);return x}get upperTriangularMatrix(){let b=this.LU,E=b.rows,w=b.columns,x=new z(E,w);for(let M=0;M<E;M++)for(let Q=0;Q<w;Q++)M<=Q?x.set(M,Q,b.get(M,Q)):x.set(M,Q,0);return x}get pivotPermutationVector(){return Array.from(this.pivotVector)}}function Wt(I,b){let E=0;return Math.abs(I)>Math.abs(b)?(E=b/I,Math.abs(I)*Math.sqrt(1+E*E)):b!==0?(E=I/b,Math.abs(b)*Math.sqrt(1+E*E)):0}class _t{constructor(b){b=St.checkMatrix(b);let E=b.clone(),w=b.rows,x=b.columns,M=new Float64Array(x),Q,N,P,R;for(P=0;P<x;P++){let J=0;for(Q=P;Q<w;Q++)J=Wt(J,E.get(Q,P));if(J!==0){for(E.get(P,P)<0&&(J=-J),Q=P;Q<w;Q++)E.set(Q,P,E.get(Q,P)/J);for(E.set(P,P,E.get(P,P)+1),N=P+1;N<x;N++){for(R=0,Q=P;Q<w;Q++)R+=E.get(Q,P)*E.get(Q,N);for(R=-R/E.get(P,P),Q=P;Q<w;Q++)E.set(Q,N,E.get(Q,N)+R*E.get(Q,P))}}M[P]=-J}this.QR=E,this.Rdiag=M}solve(b){b=z.checkMatrix(b);let E=this.QR,w=E.rows;if(b.rows!==w)throw new Error("Matrix row dimensions must agree");if(!this.isFullRank())throw new Error("Matrix is rank deficient");let x=b.columns,M=b.clone(),Q=E.columns,N,P,R,J;for(R=0;R<Q;R++)for(P=0;P<x;P++){for(J=0,N=R;N<w;N++)J+=E.get(N,R)*M.get(N,P);for(J=-J/E.get(R,R),N=R;N<w;N++)M.set(N,P,M.get(N,P)+J*E.get(N,R))}for(R=Q-1;R>=0;R--){for(P=0;P<x;P++)M.set(R,P,M.get(R,P)/this.Rdiag[R]);for(N=0;N<R;N++)for(P=0;P<x;P++)M.set(N,P,M.get(N,P)-M.get(R,P)*E.get(N,R))}return M.subMatrix(0,Q-1,0,x-1)}isFullRank(){let b=this.QR.columns;for(let E=0;E<b;E++)if(this.Rdiag[E]===0)return!1;return!0}get upperTriangularMatrix(){let b=this.QR,E=b.columns,w=new z(E,E),x,M;for(x=0;x<E;x++)for(M=0;M<E;M++)x<M?w.set(x,M,b.get(x,M)):x===M?w.set(x,M,this.Rdiag[x]):w.set(x,M,0);return w}get orthogonalMatrix(){let b=this.QR,E=b.rows,w=b.columns,x=new z(E,w),M,Q,N,P;for(N=w-1;N>=0;N--){for(M=0;M<E;M++)x.set(M,N,0);for(x.set(N,N,1),Q=N;Q<w;Q++)if(b.get(N,N)!==0){for(P=0,M=N;M<E;M++)P+=b.get(M,N)*x.get(M,Q);for(P=-P/b.get(N,N),M=N;M<E;M++)x.set(M,Q,x.get(M,Q)+P*b.get(M,N))}}return x}}class Qn{constructor(b,E={}){if(b=St.checkMatrix(b),b.isEmpty())throw new Error("Matrix must be non-empty");let w=b.rows,x=b.columns;const{computeLeftSingularVectors:M=!0,computeRightSingularVectors:Q=!0,autoTranspose:N=!1}=E;let P=!!M,R=!!Q,J=!1,j;if(w<x)if(!N)j=b.clone(),console.warn("Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose");else{j=b.transpose(),w=j.rows,x=j.columns,J=!0;let Y=P;P=R,R=Y}else j=b.clone();let oe=Math.min(w,x),me=Math.min(w+1,x),ne=new Float64Array(me),ce=new z(w,oe),Ce=new z(x,x),q=new Float64Array(x),ye=new Float64Array(w),Oe=new Float64Array(me);for(let Y=0;Y<me;Y++)Oe[Y]=Y;let Ke=Math.min(w-1,x),je=Math.max(0,Math.min(x-2,w)),Ht=Math.max(Ke,je);for(let Y=0;Y<Ht;Y++){if(Y<Ke){ne[Y]=0;for(let fe=Y;fe<w;fe++)ne[Y]=Wt(ne[Y],j.get(fe,Y));if(ne[Y]!==0){j.get(Y,Y)<0&&(ne[Y]=-ne[Y]);for(let fe=Y;fe<w;fe++)j.set(fe,Y,j.get(fe,Y)/ne[Y]);j.set(Y,Y,j.get(Y,Y)+1)}ne[Y]=-ne[Y]}for(let fe=Y+1;fe<x;fe++){if(Y<Ke&&ne[Y]!==0){let Se=0;for(let ve=Y;ve<w;ve++)Se+=j.get(ve,Y)*j.get(ve,fe);Se=-Se/j.get(Y,Y);for(let ve=Y;ve<w;ve++)j.set(ve,fe,j.get(ve,fe)+Se*j.get(ve,Y))}q[fe]=j.get(Y,fe)}if(P&&Y<Ke)for(let fe=Y;fe<w;fe++)ce.set(fe,Y,j.get(fe,Y));if(Y<je){q[Y]=0;for(let fe=Y+1;fe<x;fe++)q[Y]=Wt(q[Y],q[fe]);if(q[Y]!==0){q[Y+1]<0&&(q[Y]=0-q[Y]);for(let fe=Y+1;fe<x;fe++)q[fe]/=q[Y];q[Y+1]+=1}if(q[Y]=-q[Y],Y+1<w&&q[Y]!==0){for(let fe=Y+1;fe<w;fe++)ye[fe]=0;for(let fe=Y+1;fe<w;fe++)for(let Se=Y+1;Se<x;Se++)ye[fe]+=q[Se]*j.get(fe,Se);for(let fe=Y+1;fe<x;fe++){let Se=-q[fe]/q[Y+1];for(let ve=Y+1;ve<w;ve++)j.set(ve,fe,j.get(ve,fe)+Se*ye[ve])}}if(R)for(let fe=Y+1;fe<x;fe++)Ce.set(fe,Y,q[fe])}}let Qe=Math.min(x,w+1);if(Ke<x&&(ne[Ke]=j.get(Ke,Ke)),w<Qe&&(ne[Qe-1]=0),je+1<Qe&&(q[je]=j.get(je,Qe-1)),q[Qe-1]=0,P){for(let Y=Ke;Y<oe;Y++){for(let fe=0;fe<w;fe++)ce.set(fe,Y,0);ce.set(Y,Y,1)}for(let Y=Ke-1;Y>=0;Y--)if(ne[Y]!==0){for(let fe=Y+1;fe<oe;fe++){let Se=0;for(let ve=Y;ve<w;ve++)Se+=ce.get(ve,Y)*ce.get(ve,fe);Se=-Se/ce.get(Y,Y);for(let ve=Y;ve<w;ve++)ce.set(ve,fe,ce.get(ve,fe)+Se*ce.get(ve,Y))}for(let fe=Y;fe<w;fe++)ce.set(fe,Y,-ce.get(fe,Y));ce.set(Y,Y,1+ce.get(Y,Y));for(let fe=0;fe<Y-1;fe++)ce.set(fe,Y,0)}else{for(let fe=0;fe<w;fe++)ce.set(fe,Y,0);ce.set(Y,Y,1)}}if(R)for(let Y=x-1;Y>=0;Y--){if(Y<je&&q[Y]!==0)for(let fe=Y+1;fe<x;fe++){let Se=0;for(let ve=Y+1;ve<x;ve++)Se+=Ce.get(ve,Y)*Ce.get(ve,fe);Se=-Se/Ce.get(Y+1,Y);for(let ve=Y+1;ve<x;ve++)Ce.set(ve,fe,Ce.get(ve,fe)+Se*Ce.get(ve,Y))}for(let fe=0;fe<x;fe++)Ce.set(fe,Y,0);Ce.set(Y,Y,1)}let Pe=Qe-1,Ft=Number.EPSILON;for(;Qe>0;){let Y,fe;for(Y=Qe-2;Y>=-1&&Y!==-1;Y--){const Se=Number.MIN_VALUE+Ft*Math.abs(ne[Y]+Math.abs(ne[Y+1]));if(Math.abs(q[Y])<=Se||Number.isNaN(q[Y])){q[Y]=0;break}}if(Y===Qe-2)fe=4;else{let Se;for(Se=Qe-1;Se>=Y&&Se!==Y;Se--){let ve=(Se!==Qe?Math.abs(q[Se]):0)+(Se!==Y+1?Math.abs(q[Se-1]):0);if(Math.abs(ne[Se])<=Ft*ve){ne[Se]=0;break}}Se===Y?fe=3:Se===Qe-1?fe=1:(fe=2,Y=Se)}switch(Y++,fe){case 1:{let Se=q[Qe-2];q[Qe-2]=0;for(let ve=Qe-2;ve>=Y;ve--){let Gt=Wt(ne[ve],Se),yt=ne[ve]/Gt,Qt=Se/Gt;if(ne[ve]=Gt,ve!==Y&&(Se=-Qt*q[ve-1],q[ve-1]=yt*q[ve-1]),R)for(let Kt=0;Kt<x;Kt++)Gt=yt*Ce.get(Kt,ve)+Qt*Ce.get(Kt,Qe-1),Ce.set(Kt,Qe-1,-Qt*Ce.get(Kt,ve)+yt*Ce.get(Kt,Qe-1)),Ce.set(Kt,ve,Gt)}break}case 2:{let Se=q[Y-1];q[Y-1]=0;for(let ve=Y;ve<Qe;ve++){let Gt=Wt(ne[ve],Se),yt=ne[ve]/Gt,Qt=Se/Gt;if(ne[ve]=Gt,Se=-Qt*q[ve],q[ve]=yt*q[ve],P)for(let Kt=0;Kt<w;Kt++)Gt=yt*ce.get(Kt,ve)+Qt*ce.get(Kt,Y-1),ce.set(Kt,Y-1,-Qt*ce.get(Kt,ve)+yt*ce.get(Kt,Y-1)),ce.set(Kt,ve,Gt)}break}case 3:{const Se=Math.max(Math.abs(ne[Qe-1]),Math.abs(ne[Qe-2]),Math.abs(q[Qe-2]),Math.abs(ne[Y]),Math.abs(q[Y])),ve=ne[Qe-1]/Se,Gt=ne[Qe-2]/Se,yt=q[Qe-2]/Se,Qt=ne[Y]/Se,Kt=q[Y]/Se,Nn=((Gt+ve)*(Gt-ve)+yt*yt)/2,Ai=ve*yt*(ve*yt);let bn=0;(Nn!==0||Ai!==0)&&(Nn<0?bn=0-Math.sqrt(Nn*Nn+Ai):bn=Math.sqrt(Nn*Nn+Ai),bn=Ai/(Nn+bn));let Ti=(Qt+ve)*(Qt-ve)+bn,ta=Qt*Kt;for(let st=Y;st<Qe-1;st++){let Un=Wt(Ti,ta);Un===0&&(Un=Number.MIN_VALUE);let _r=Ti/Un,Ir=ta/Un;if(st!==Y&&(q[st-1]=Un),Ti=_r*ne[st]+Ir*q[st],q[st]=_r*q[st]-Ir*ne[st],ta=Ir*ne[st+1],ne[st+1]=_r*ne[st+1],R)for(let En=0;En<x;En++)Un=_r*Ce.get(En,st)+Ir*Ce.get(En,st+1),Ce.set(En,st+1,-Ir*Ce.get(En,st)+_r*Ce.get(En,st+1)),Ce.set(En,st,Un);if(Un=Wt(Ti,ta),Un===0&&(Un=Number.MIN_VALUE),_r=Ti/Un,Ir=ta/Un,ne[st]=Un,Ti=_r*q[st]+Ir*ne[st+1],ne[st+1]=-Ir*q[st]+_r*ne[st+1],ta=Ir*q[st+1],q[st+1]=_r*q[st+1],P&&st<w-1)for(let En=0;En<w;En++)Un=_r*ce.get(En,st)+Ir*ce.get(En,st+1),ce.set(En,st+1,-Ir*ce.get(En,st)+_r*ce.get(En,st+1)),ce.set(En,st,Un)}q[Qe-2]=Ti;break}case 4:{if(ne[Y]<=0&&(ne[Y]=ne[Y]<0?-ne[Y]:0,R))for(let Se=0;Se<=Pe;Se++)Ce.set(Se,Y,-Ce.get(Se,Y));for(;Y<Pe&&!(ne[Y]>=ne[Y+1]);){let Se=ne[Y];if(ne[Y]=ne[Y+1],ne[Y+1]=Se,R&&Y<x-1)for(let ve=0;ve<x;ve++)Se=Ce.get(ve,Y+1),Ce.set(ve,Y+1,Ce.get(ve,Y)),Ce.set(ve,Y,Se);if(P&&Y<w-1)for(let ve=0;ve<w;ve++)Se=ce.get(ve,Y+1),ce.set(ve,Y+1,ce.get(ve,Y)),ce.set(ve,Y,Se);Y++}Qe--;break}}}if(J){let Y=Ce;Ce=ce,ce=Y}this.m=w,this.n=x,this.s=ne,this.U=ce,this.V=Ce}solve(b){let E=b,w=this.threshold,x=this.s.length,M=z.zeros(x,x);for(let oe=0;oe<x;oe++)Math.abs(this.s[oe])<=w?M.set(oe,oe,0):M.set(oe,oe,1/this.s[oe]);let Q=this.U,N=this.rightSingularVectors,P=N.mmul(M),R=N.rows,J=Q.rows,j=z.zeros(R,J);for(let oe=0;oe<R;oe++)for(let me=0;me<J;me++){let ne=0;for(let ce=0;ce<x;ce++)ne+=P.get(oe,ce)*Q.get(me,ce);j.set(oe,me,ne)}return j.mmul(E)}solveForDiagonal(b){return this.solve(z.diag(b))}inverse(){let b=this.V,E=this.threshold,w=b.rows,x=b.columns,M=new z(w,this.s.length);for(let J=0;J<w;J++)for(let j=0;j<x;j++)Math.abs(this.s[j])>E&&M.set(J,j,b.get(J,j)/this.s[j]);let Q=this.U,N=Q.rows,P=Q.columns,R=new z(w,N);for(let J=0;J<w;J++)for(let j=0;j<N;j++){let oe=0;for(let me=0;me<P;me++)oe+=M.get(J,me)*Q.get(j,me);R.set(J,j,oe)}return R}get condition(){return this.s[0]/this.s[Math.min(this.m,this.n)-1]}get norm2(){return this.s[0]}get rank(){let b=Math.max(this.m,this.n)*this.s[0]*Number.EPSILON,E=0,w=this.s;for(let x=0,M=w.length;x<M;x++)w[x]>b&&E++;return E}get diagonal(){return Array.from(this.s)}get threshold(){return Number.EPSILON/2*Math.max(this.m,this.n)*this.s[0]}get leftSingularVectors(){return this.U}get rightSingularVectors(){return this.V}get diagonalMatrix(){return z.diag(this.s)}}function qn(I,b=!1){return I=St.checkMatrix(I),b?new Qn(I).inverse():vr(I,z.eye(I.rows))}function vr(I,b,E=!1){return I=St.checkMatrix(I),b=St.checkMatrix(b),E?new Qn(I).solve(b):I.isSquare()?new ir(I).solve(b):new _t(I).solve(b)}function ar(I){if(I=z.checkMatrix(I),I.isSquare()){if(I.columns===0)return 1;let b,E,w,x;if(I.columns===2)return b=I.get(0,0),E=I.get(0,1),w=I.get(1,0),x=I.get(1,1),b*x-E*w;if(I.columns===3){let M,Q,N;return M=new Ne(I,[1,2],[1,2]),Q=new Ne(I,[1,2],[0,2]),N=new Ne(I,[1,2],[0,1]),b=I.get(0,0),E=I.get(0,1),w=I.get(0,2),b*ar(M)-E*ar(Q)+w*ar(N)}else return new ir(I).determinant}else throw Error("determinant can only be calculated for a square matrix")}function $n(I,b){let E=[];for(let w=0;w<I;w++)w!==b&&E.push(w);return E}function rn(I,b,E,w=1e-9,x=1e-9){if(I>x)return new Array(b.rows+1).fill(0);{let M=b.addRow(E,[0]);for(let Q=0;Q<M.rows;Q++)Math.abs(M.get(Q,0))<w&&M.set(Q,0,0);return M.to1DArray()}}function an(I,b={}){const{thresholdValue:E=1e-9,thresholdError:w=1e-9}=b;I=z.checkMatrix(I);let x=I.rows,M=new z(x,x);for(let Q=0;Q<x;Q++){let N=z.columnVector(I.getRow(Q)),P=I.subMatrixRow($n(x,Q)).transpose(),J=new Qn(P).solve(N),j=z.sub(N,P.mmul(J)).abs().max();M.setRow(Q,rn(j,J,Q,E,w))}return M}function cA(I,b=Number.EPSILON){if(I=z.checkMatrix(I),I.isEmpty())return I.transpose();let E=new Qn(I,{autoTranspose:!0}),w=E.leftSingularVectors,x=E.rightSingularVectors,M=E.diagonal;for(let Q=0;Q<M.length;Q++)Math.abs(M[Q])>b?M[Q]=1/M[Q]:M[Q]=0;return x.mmul(z.diag(M).mmul(w.transpose()))}function cs(I,b=I,E={}){I=new z(I);let w=!1;if(typeof b=="object"&&!z.isMatrix(b)&&!r.isAnyArray(b)?(E=b,b=I,w=!0):b=new z(b),I.rows!==b.rows)throw new TypeError("Both matrices must have the same number of rows");const{center:x=!0}=E;x&&(I=I.center("column"),w||(b=b.center("column")));const M=I.transpose().mmul(b);for(let Q=0;Q<M.rows;Q++)for(let N=0;N<M.columns;N++)M.set(Q,N,M.get(Q,N)*(1/(I.rows-1)));return M}function Or(I,b=I,E={}){I=new z(I);let w=!1;if(typeof b=="object"&&!z.isMatrix(b)&&!r.isAnyArray(b)?(E=b,b=I,w=!0):b=new z(b),I.rows!==b.rows)throw new TypeError("Both matrices must have the same number of rows");const{center:x=!0,scale:M=!0}=E;x&&(I.center("column"),w||b.center("column")),M&&(I.scale("column"),w||b.scale("column"));const Q=I.standardDeviation("column",{unbiased:!0}),N=w?Q:b.standardDeviation("column",{unbiased:!0}),P=I.transpose().mmul(b);for(let R=0;R<P.rows;R++)for(let J=0;J<P.columns;J++)P.set(R,J,P.get(R,J)*(1/(Q[R]*N[J]))*(1/(I.rows-1)));return P}class Vr{constructor(b,E={}){const{assumeSymmetric:w=!1}=E;if(b=St.checkMatrix(b),!b.isSquare())throw new Error("Matrix is not a square matrix");if(b.isEmpty())throw new Error("Matrix must be non-empty");let x=b.columns,M=new z(x,x),Q=new Float64Array(x),N=new Float64Array(x),P=b,R,J,j=!1;if(w?j=!0:j=b.isSymmetric(),j){for(R=0;R<x;R++)for(J=0;J<x;J++)M.set(R,J,P.get(R,J));Xl(x,N,Q,M),Zl(x,N,Q,M)}else{let oe=new z(x,x),me=new Float64Array(x);for(J=0;J<x;J++)for(R=0;R<x;R++)oe.set(R,J,P.get(R,J));Cf(x,oe,me,M),Jl(x,N,Q,M,oe)}this.n=x,this.e=N,this.d=Q,this.V=M}get realEigenvalues(){return Array.from(this.d)}get imaginaryEigenvalues(){return Array.from(this.e)}get eigenvectorMatrix(){return this.V}get diagonalMatrix(){let b=this.n,E=this.e,w=this.d,x=new z(b,b),M,Q;for(M=0;M<b;M++){for(Q=0;Q<b;Q++)x.set(M,Q,0);x.set(M,M,w[M]),E[M]>0?x.set(M,M+1,E[M]):E[M]<0&&x.set(M,M-1,E[M])}return x}}function Xl(I,b,E,w){let x,M,Q,N,P,R,J,j;for(P=0;P<I;P++)E[P]=w.get(I-1,P);for(N=I-1;N>0;N--){for(j=0,Q=0,R=0;R<N;R++)j=j+Math.abs(E[R]);if(j===0)for(b[N]=E[N-1],P=0;P<N;P++)E[P]=w.get(N-1,P),w.set(N,P,0),w.set(P,N,0);else{for(R=0;R<N;R++)E[R]/=j,Q+=E[R]*E[R];for(x=E[N-1],M=Math.sqrt(Q),x>0&&(M=-M),b[N]=j*M,Q=Q-x*M,E[N-1]=x-M,P=0;P<N;P++)b[P]=0;for(P=0;P<N;P++){for(x=E[P],w.set(P,N,x),M=b[P]+w.get(P,P)*x,R=P+1;R<=N-1;R++)M+=w.get(R,P)*E[R],b[R]+=w.get(R,P)*x;b[P]=M}for(x=0,P=0;P<N;P++)b[P]/=Q,x+=b[P]*E[P];for(J=x/(Q+Q),P=0;P<N;P++)b[P]-=J*E[P];for(P=0;P<N;P++){for(x=E[P],M=b[P],R=P;R<=N-1;R++)w.set(R,P,w.get(R,P)-(x*b[R]+M*E[R]));E[P]=w.get(N-1,P),w.set(N,P,0)}}E[N]=Q}for(N=0;N<I-1;N++){if(w.set(I-1,N,w.get(N,N)),w.set(N,N,1),Q=E[N+1],Q!==0){for(R=0;R<=N;R++)E[R]=w.get(R,N+1)/Q;for(P=0;P<=N;P++){for(M=0,R=0;R<=N;R++)M+=w.get(R,N+1)*w.get(R,P);for(R=0;R<=N;R++)w.set(R,P,w.get(R,P)-M*E[R])}}for(R=0;R<=N;R++)w.set(R,N+1,0)}for(P=0;P<I;P++)E[P]=w.get(I-1,P),w.set(I-1,P,0);w.set(I-1,I-1,1),b[0]=0}function Zl(I,b,E,w){let x,M,Q,N,P,R,J,j,oe,me,ne,ce,Ce,q,ye,Oe;for(Q=1;Q<I;Q++)b[Q-1]=b[Q];b[I-1]=0;let Ke=0,je=0,Ht=Number.EPSILON;for(R=0;R<I;R++){for(je=Math.max(je,Math.abs(E[R])+Math.abs(b[R])),J=R;J<I&&!(Math.abs(b[J])<=Ht*je);)J++;if(J>R)do{for(x=E[R],j=(E[R+1]-x)/(2*b[R]),oe=Wt(j,1),j<0&&(oe=-oe),E[R]=b[R]/(j+oe),E[R+1]=b[R]*(j+oe),me=E[R+1],M=x-E[R],Q=R+2;Q<I;Q++)E[Q]-=M;for(Ke=Ke+M,j=E[J],ne=1,ce=ne,Ce=ne,q=b[R+1],ye=0,Oe=0,Q=J-1;Q>=R;Q--)for(Ce=ce,ce=ne,Oe=ye,x=ne*b[Q],M=ne*j,oe=Wt(j,b[Q]),b[Q+1]=ye*oe,ye=b[Q]/oe,ne=j/oe,j=ne*E[Q]-ye*x,E[Q+1]=M+ye*(ne*x+ye*E[Q]),P=0;P<I;P++)M=w.get(P,Q+1),w.set(P,Q+1,ye*w.get(P,Q)+ne*M),w.set(P,Q,ne*w.get(P,Q)-ye*M);j=-ye*Oe*Ce*q*b[R]/me,b[R]=ye*j,E[R]=ne*j}while(Math.abs(b[R])>Ht*je);E[R]=E[R]+Ke,b[R]=0}for(Q=0;Q<I-1;Q++){for(P=Q,j=E[Q],N=Q+1;N<I;N++)E[N]<j&&(P=N,j=E[N]);if(P!==Q)for(E[P]=E[Q],E[Q]=j,N=0;N<I;N++)j=w.get(N,Q),w.set(N,Q,w.get(N,P)),w.set(N,P,j)}}function Cf(I,b,E,w){let x=0,M=I-1,Q,N,P,R,J,j,oe;for(j=x+1;j<=M-1;j++){for(oe=0,R=j;R<=M;R++)oe=oe+Math.abs(b.get(R,j-1));if(oe!==0){for(P=0,R=M;R>=j;R--)E[R]=b.get(R,j-1)/oe,P+=E[R]*E[R];for(N=Math.sqrt(P),E[j]>0&&(N=-N),P=P-E[j]*N,E[j]=E[j]-N,J=j;J<I;J++){for(Q=0,R=M;R>=j;R--)Q+=E[R]*b.get(R,J);for(Q=Q/P,R=j;R<=M;R++)b.set(R,J,b.get(R,J)-Q*E[R])}for(R=0;R<=M;R++){for(Q=0,J=M;J>=j;J--)Q+=E[J]*b.get(R,J);for(Q=Q/P,J=j;J<=M;J++)b.set(R,J,b.get(R,J)-Q*E[J])}E[j]=oe*E[j],b.set(j,j-1,oe*N)}}for(R=0;R<I;R++)for(J=0;J<I;J++)w.set(R,J,R===J?1:0);for(j=M-1;j>=x+1;j--)if(b.get(j,j-1)!==0){for(R=j+1;R<=M;R++)E[R]=b.get(R,j-1);for(J=j;J<=M;J++){for(N=0,R=j;R<=M;R++)N+=E[R]*w.get(R,J);for(N=N/E[j]/b.get(j,j-1),R=j;R<=M;R++)w.set(R,J,w.get(R,J)+N*E[R])}}}function Jl(I,b,E,w,x){let M=I-1,Q=0,N=I-1,P=Number.EPSILON,R=0,J=0,j=0,oe=0,me=0,ne=0,ce=0,Ce=0,q,ye,Oe,Ke,je,Ht,Qe,Pe,Ft,Y,fe,Se,ve,Gt,yt;for(q=0;q<I;q++)for((q<Q||q>N)&&(E[q]=x.get(q,q),b[q]=0),ye=Math.max(q-1,0);ye<I;ye++)J=J+Math.abs(x.get(q,ye));for(;M>=Q;){for(Ke=M;Ke>Q&&(ne=Math.abs(x.get(Ke-1,Ke-1))+Math.abs(x.get(Ke,Ke)),ne===0&&(ne=J),!(Math.abs(x.get(Ke,Ke-1))<P*ne));)Ke--;if(Ke===M)x.set(M,M,x.get(M,M)+R),E[M]=x.get(M,M),b[M]=0,M--,Ce=0;else if(Ke===M-1){if(Qe=x.get(M,M-1)*x.get(M-1,M),j=(x.get(M-1,M-1)-x.get(M,M))/2,oe=j*j+Qe,ce=Math.sqrt(Math.abs(oe)),x.set(M,M,x.get(M,M)+R),x.set(M-1,M-1,x.get(M-1,M-1)+R),Pe=x.get(M,M),oe>=0){for(ce=j>=0?j+ce:j-ce,E[M-1]=Pe+ce,E[M]=E[M-1],ce!==0&&(E[M]=Pe-Qe/ce),b[M-1]=0,b[M]=0,Pe=x.get(M,M-1),ne=Math.abs(Pe)+Math.abs(ce),j=Pe/ne,oe=ce/ne,me=Math.sqrt(j*j+oe*oe),j=j/me,oe=oe/me,ye=M-1;ye<I;ye++)ce=x.get(M-1,ye),x.set(M-1,ye,oe*ce+j*x.get(M,ye)),x.set(M,ye,oe*x.get(M,ye)-j*ce);for(q=0;q<=M;q++)ce=x.get(q,M-1),x.set(q,M-1,oe*ce+j*x.get(q,M)),x.set(q,M,oe*x.get(q,M)-j*ce);for(q=Q;q<=N;q++)ce=w.get(q,M-1),w.set(q,M-1,oe*ce+j*w.get(q,M)),w.set(q,M,oe*w.get(q,M)-j*ce)}else E[M-1]=Pe+j,E[M]=Pe+j,b[M-1]=ce,b[M]=-ce;M=M-2,Ce=0}else{if(Pe=x.get(M,M),Ft=0,Qe=0,Ke<M&&(Ft=x.get(M-1,M-1),Qe=x.get(M,M-1)*x.get(M-1,M)),Ce===10){for(R+=Pe,q=Q;q<=M;q++)x.set(q,q,x.get(q,q)-Pe);ne=Math.abs(x.get(M,M-1))+Math.abs(x.get(M-1,M-2)),Pe=Ft=.75*ne,Qe=-.4375*ne*ne}if(Ce===30&&(ne=(Ft-Pe)/2,ne=ne*ne+Qe,ne>0)){for(ne=Math.sqrt(ne),Ft<Pe&&(ne=-ne),ne=Pe-Qe/((Ft-Pe)/2+ne),q=Q;q<=M;q++)x.set(q,q,x.get(q,q)-ne);R+=ne,Pe=Ft=Qe=.964}for(Ce=Ce+1,je=M-2;je>=Ke&&(ce=x.get(je,je),me=Pe-ce,ne=Ft-ce,j=(me*ne-Qe)/x.get(je+1,je)+x.get(je,je+1),oe=x.get(je+1,je+1)-ce-me-ne,me=x.get(je+2,je+1),ne=Math.abs(j)+Math.abs(oe)+Math.abs(me),j=j/ne,oe=oe/ne,me=me/ne,!(je===Ke||Math.abs(x.get(je,je-1))*(Math.abs(oe)+Math.abs(me))<P*(Math.abs(j)*(Math.abs(x.get(je-1,je-1))+Math.abs(ce)+Math.abs(x.get(je+1,je+1))))));)je--;for(q=je+2;q<=M;q++)x.set(q,q-2,0),q>je+2&&x.set(q,q-3,0);for(Oe=je;Oe<=M-1&&(Gt=Oe!==M-1,Oe!==je&&(j=x.get(Oe,Oe-1),oe=x.get(Oe+1,Oe-1),me=Gt?x.get(Oe+2,Oe-1):0,Pe=Math.abs(j)+Math.abs(oe)+Math.abs(me),Pe!==0&&(j=j/Pe,oe=oe/Pe,me=me/Pe)),Pe!==0);Oe++)if(ne=Math.sqrt(j*j+oe*oe+me*me),j<0&&(ne=-ne),ne!==0){for(Oe!==je?x.set(Oe,Oe-1,-ne*Pe):Ke!==je&&x.set(Oe,Oe-1,-x.get(Oe,Oe-1)),j=j+ne,Pe=j/ne,Ft=oe/ne,ce=me/ne,oe=oe/j,me=me/j,ye=Oe;ye<I;ye++)j=x.get(Oe,ye)+oe*x.get(Oe+1,ye),Gt&&(j=j+me*x.get(Oe+2,ye),x.set(Oe+2,ye,x.get(Oe+2,ye)-j*ce)),x.set(Oe,ye,x.get(Oe,ye)-j*Pe),x.set(Oe+1,ye,x.get(Oe+1,ye)-j*Ft);for(q=0;q<=Math.min(M,Oe+3);q++)j=Pe*x.get(q,Oe)+Ft*x.get(q,Oe+1),Gt&&(j=j+ce*x.get(q,Oe+2),x.set(q,Oe+2,x.get(q,Oe+2)-j*me)),x.set(q,Oe,x.get(q,Oe)-j),x.set(q,Oe+1,x.get(q,Oe+1)-j*oe);for(q=Q;q<=N;q++)j=Pe*w.get(q,Oe)+Ft*w.get(q,Oe+1),Gt&&(j=j+ce*w.get(q,Oe+2),w.set(q,Oe+2,w.get(q,Oe+2)-j*me)),w.set(q,Oe,w.get(q,Oe)-j),w.set(q,Oe+1,w.get(q,Oe+1)-j*oe)}}}if(J!==0){for(M=I-1;M>=0;M--)if(j=E[M],oe=b[M],oe===0)for(Ke=M,x.set(M,M,1),q=M-1;q>=0;q--){for(Qe=x.get(q,q)-j,me=0,ye=Ke;ye<=M;ye++)me=me+x.get(q,ye)*x.get(ye,M);if(b[q]<0)ce=Qe,ne=me;else if(Ke=q,b[q]===0?x.set(q,M,Qe!==0?-me/Qe:-me/(P*J)):(Pe=x.get(q,q+1),Ft=x.get(q+1,q),oe=(E[q]-j)*(E[q]-j)+b[q]*b[q],Ht=(Pe*ne-ce*me)/oe,x.set(q,M,Ht),x.set(q+1,M,Math.abs(Pe)>Math.abs(ce)?(-me-Qe*Ht)/Pe:(-ne-Ft*Ht)/ce)),Ht=Math.abs(x.get(q,M)),P*Ht*Ht>1)for(ye=q;ye<=M;ye++)x.set(ye,M,x.get(ye,M)/Ht)}else if(oe<0)for(Ke=M-1,Math.abs(x.get(M,M-1))>Math.abs(x.get(M-1,M))?(x.set(M-1,M-1,oe/x.get(M,M-1)),x.set(M-1,M,-(x.get(M,M)-j)/x.get(M,M-1))):(yt=ea(0,-x.get(M-1,M),x.get(M-1,M-1)-j,oe),x.set(M-1,M-1,yt[0]),x.set(M-1,M,yt[1])),x.set(M,M-1,0),x.set(M,M,1),q=M-2;q>=0;q--){for(Y=0,fe=0,ye=Ke;ye<=M;ye++)Y=Y+x.get(q,ye)*x.get(ye,M-1),fe=fe+x.get(q,ye)*x.get(ye,M);if(Qe=x.get(q,q)-j,b[q]<0)ce=Qe,me=Y,ne=fe;else if(Ke=q,b[q]===0?(yt=ea(-Y,-fe,Qe,oe),x.set(q,M-1,yt[0]),x.set(q,M,yt[1])):(Pe=x.get(q,q+1),Ft=x.get(q+1,q),Se=(E[q]-j)*(E[q]-j)+b[q]*b[q]-oe*oe,ve=(E[q]-j)*2*oe,Se===0&&ve===0&&(Se=P*J*(Math.abs(Qe)+Math.abs(oe)+Math.abs(Pe)+Math.abs(Ft)+Math.abs(ce))),yt=ea(Pe*me-ce*Y+oe*fe,Pe*ne-ce*fe-oe*Y,Se,ve),x.set(q,M-1,yt[0]),x.set(q,M,yt[1]),Math.abs(Pe)>Math.abs(ce)+Math.abs(oe)?(x.set(q+1,M-1,(-Y-Qe*x.get(q,M-1)+oe*x.get(q,M))/Pe),x.set(q+1,M,(-fe-Qe*x.get(q,M)-oe*x.get(q,M-1))/Pe)):(yt=ea(-me-Ft*x.get(q,M-1),-ne-Ft*x.get(q,M),ce,oe),x.set(q+1,M-1,yt[0]),x.set(q+1,M,yt[1]))),Ht=Math.max(Math.abs(x.get(q,M-1)),Math.abs(x.get(q,M))),P*Ht*Ht>1)for(ye=q;ye<=M;ye++)x.set(ye,M-1,x.get(ye,M-1)/Ht),x.set(ye,M,x.get(ye,M)/Ht)}for(q=0;q<I;q++)if(q<Q||q>N)for(ye=q;ye<I;ye++)w.set(q,ye,x.get(q,ye));for(ye=I-1;ye>=Q;ye--)for(q=Q;q<=N;q++){for(ce=0,Oe=Q;Oe<=Math.min(ye,N);Oe++)ce=ce+w.get(q,Oe)*x.get(Oe,ye);w.set(q,ye,ce)}}}function ea(I,b,E,w){let x,M;return Math.abs(E)>Math.abs(w)?(x=w/E,M=E+x*w,[(I+x*b)/M,(b-x*I)/M]):(x=E/w,M=w+x*E,[(x*I+b)/M,(x*b-I)/M])}class ec{constructor(b){if(b=St.checkMatrix(b),!b.isSymmetric())throw new Error("Matrix is not symmetric");let E=b,w=E.rows,x=new z(w,w),M=!0,Q,N,P;for(N=0;N<w;N++){let R=0;for(P=0;P<N;P++){let J=0;for(Q=0;Q<P;Q++)J+=x.get(P,Q)*x.get(N,Q);J=(E.get(N,P)-J)/x.get(P,P),x.set(N,P,J),R=R+J*J}for(R=E.get(N,N)-R,M&=R>0,x.set(N,N,Math.sqrt(Math.max(R,0))),P=N+1;P<w;P++)x.set(N,P,0)}this.L=x,this.positiveDefinite=!!M}isPositiveDefinite(){return this.positiveDefinite}solve(b){b=St.checkMatrix(b);let E=this.L,w=E.rows;if(b.rows!==w)throw new Error("Matrix dimensions do not match");if(this.isPositiveDefinite()===!1)throw new Error("Matrix is not positive definite");let x=b.columns,M=b.clone(),Q,N,P;for(P=0;P<w;P++)for(N=0;N<x;N++){for(Q=0;Q<P;Q++)M.set(P,N,M.get(P,N)-M.get(Q,N)*E.get(P,Q));M.set(P,N,M.get(P,N)/E.get(P,P))}for(P=w-1;P>=0;P--)for(N=0;N<x;N++){for(Q=P+1;Q<w;Q++)M.set(P,N,M.get(P,N)-M.get(Q,N)*E.get(Q,P));M.set(P,N,M.get(P,N)/E.get(P,P))}return M}get lowerTriangularMatrix(){return this.L}}class tc{constructor(b,E={}){b=St.checkMatrix(b);let{Y:w}=E;const{scaleScores:x=!1,maxIterations:M=1e3,terminationCriteria:Q=1e-10}=E;let N;if(w){if(r.isAnyArray(w)&&typeof w[0]=="number"?w=z.columnVector(w):w=St.checkMatrix(w),w.rows!==b.rows)throw new Error("Y should have the same number of rows as X");N=w.getColumnVector(0)}else N=b.getColumnVector(0);let P=1,R,J,j,oe;for(let me=0;me<M&&P>Q;me++)j=b.transpose().mmul(N).div(N.transpose().mmul(N).get(0,0)),j=j.div(j.norm()),R=b.mmul(j).div(j.transpose().mmul(j).get(0,0)),me>0&&(P=R.clone().sub(oe).pow(2).sum()),oe=R.clone(),w?(J=w.transpose().mmul(R).div(R.transpose().mmul(R).get(0,0)),J=J.div(J.norm()),N=w.mmul(J).div(J.transpose().mmul(J).get(0,0))):N=R;if(w){let me=b.transpose().mmul(R).div(R.transpose().mmul(R).get(0,0));me=me.div(me.norm());let ne=b.clone().sub(R.clone().mmul(me.transpose())),ce=N.transpose().mmul(R).div(R.transpose().mmul(R).get(0,0)),Ce=w.clone().sub(R.clone().mulS(ce.get(0,0)).mmul(J.transpose()));this.t=R,this.p=me.transpose(),this.w=j.transpose(),this.q=J,this.u=N,this.s=R.transpose().mmul(R),this.xResidual=ne,this.yResidual=Ce,this.betas=ce}else this.w=j.transpose(),this.s=R.transpose().mmul(R).sqrt(),x?this.t=R.clone().div(this.s.get(0,0)):this.t=R,this.xResidual=b.sub(R.mmul(j.transpose()))}}return rt.AbstractMatrix=re,rt.CHO=ec,rt.CholeskyDecomposition=ec,rt.DistanceMatrix=Ae,rt.EVD=Vr,rt.EigenvalueDecomposition=Vr,rt.LU=ir,rt.LuDecomposition=ir,rt.Matrix=z,rt.MatrixColumnSelectionView=Ue,rt.MatrixColumnView=Le,rt.MatrixFlipColumnView=at,rt.MatrixFlipRowView=lt,rt.MatrixRowSelectionView=pt,rt.MatrixRowView=ct,rt.MatrixSelectionView=Ne,rt.MatrixSubView=ht,rt.MatrixTransposeView=nt,rt.NIPALS=tc,rt.Nipals=tc,rt.QR=_t,rt.QrDecomposition=_t,rt.SVD=Qn,rt.SingularValueDecomposition=Qn,rt.SymmetricMatrix=ee,rt.WrapperMatrix1D=gr,rt.WrapperMatrix2D=St,rt.correlation=Or,rt.covariance=cs,rt.default=z,rt.determinant=ar,rt.inverse=qn,rt.linearDependencies=an,rt.pseudoInverse=cA,rt.solve=vr,rt.wrap=Ji,rt}var Cd=P7();const yC=Qh(Cd),Ga=Cd.Matrix,wQ=Cd.SingularValueDecomposition;yC.Matrix?yC.Matrix:Cd.Matrix;const R7={center:[0,0],linkDistance:50};class BQ{constructor(e={}){this.options=e,this.id="mds",this.options=Object.assign(Object.assign({},R7),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericMDSLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericMDSLayout(!0,e,t)})}genericMDSLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},this.options),n),{center:a=[0,0],linkDistance:s=50}=i,o=t.getAllNodes(),A=t.getAllEdges();if(!(o!=null&&o.length)||o.length===1)return to(t,e,a);const l=gQ({nodes:o,edges:A}),c=fQ(l);D7(c);const u=O$(c,s),h=H7(u),d=[];return h.forEach((g,v)=>{const p=Dr(o[v]);p.data.x=g[0]+a[0],p.data.y=g[1]+a[1],d.push(p)}),e&&d.forEach(g=>t.mergeNodeData(g.id,{x:g.data.x,y:g.data.y})),{nodes:d,edges:A}})}}const D7=r=>{let e=-999999;r.forEach(t=>{t.forEach(n=>{n!==1/0&&e<n&&(e=n)})}),r.forEach((t,n)=>{t.forEach((i,a)=>{i===1/0&&(r[n][a]=e)})})},H7=r=>{const t=Ga.mul(Ga.pow(r,2),-.5),n=t.mean("row"),i=t.mean("column"),a=t.mean();t.add(a).subRowVector(n).subColumnVector(i);const s=new wQ(t),o=Ga.sqrt(s.diagonalMatrix).diagonal();return s.leftSingularVectors.toJSON().map(A=>Ga.mul([A],[o]).toJSON()[0].splice(0,2))};function B1(r){return!!r.tick&&!!r.stop}const G7={gForce:!0,force2:!0,d3force:!0,fruchterman:!0,forceAtlas2:!0,force:!0,"graphin-force":!0},K7={center:[0,0],comboPadding:10,treeKey:"combo"};class z7{constructor(e={}){this.options=e,this.id="comboCombined",this.options=Object.assign(Object.assign({},K7),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericComboCombinedLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericComboCombinedLayout(!0,e,t)})}genericComboCombinedLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=this.initVals(Object.assign(Object.assign({},this.options),n)),{center:a,treeKey:s,outerLayout:o}=i,A=t.getAllNodes().filter(T=>!T.data._isCombo),l=t.getAllNodes().filter(T=>T.data._isCombo),c=t.getAllEdges(),u=A==null?void 0:A.length;if(!u||u===1)return to(t,e,a);const h=[],d=new Map;A.forEach(T=>{d.set(T.id,T)});const f=new Map;l.forEach(T=>{f.set(T.id,T)});const g=new Map,v=this.getInnerGraphs(t,s,d,f,c,i,g);yield Promise.all(v);const p=new Map,y=[],m=new Map;let B=!0;t.getRoots(s).forEach(T=>{const O=g.get(T.id),_=f.get(T.id)||d.get(T.id),k={id:T.id,data:Object.assign(Object.assign({},T.data),{x:O.data.x||_.data.x,y:O.data.y||_.data.y,fx:O.data.fx||_.data.fx,fy:O.data.fy||_.data.fy,mass:O.data.mass||_.data.mass,size:O.data.size})};y.push(k),p.set(T.id,!0),!isNaN(k.data.x)&&k.data.x!==0&&!isNaN(k.data.y)&&k.data.y!==0?B=!1:(k.data.x=Math.random()*100,k.data.y=Math.random()*100),y1(t,[T],L=>{L.id!==T.id&&m.set(L.id,T.id)},"TB",s)});const C=[];c.forEach(T=>{const O=m.get(T.source)||T.source,_=m.get(T.target)||T.target;O!==_&&p.has(O)&&p.has(_)&&C.push({id:T.id,source:O,target:_,data:{}})});let S;if(y!=null&&y.length){if(y.length===1)y[0].data.x=a[0],y[0].data.y=a[1];else{const T=new Mn({nodes:y,edges:C}),O=o||new mQ;B&&G7[O.id]&&(yield(y.length<100?new BQ:new w1).assign(T));const _=Object.assign({center:a,kg:5,preventOverlap:!0,animate:!1},O.id==="force"?{gravity:1,factor:4,linkDistance:(k,L,U)=>{const G=Math.max(...L.data.size)||32,W=Math.max(...U.data.size)||32;return G/2+W/2+200}}:{});S=yield mC(O,T,_)}g.forEach(T=>{var O;const _=S.nodes.find(U=>U.id===T.id);if(_){const{x:U,y:G}=_.data;T.data.visited=!0,T.data.x=U,T.data.y=G,h.push({id:T.id,data:{x:U,y:G}})}const{x:k,y:L}=T.data;(O=T.data.nodes)===null||O===void 0||O.forEach(U=>{h.push({id:U.id,data:{x:U.data.x+k,y:U.data.y+L}})})}),g.forEach(({data:T})=>{const{x:O,y:_,visited:k,nodes:L}=T;L==null||L.forEach(U=>{if(!k){const G=h.find(W=>W.id===U.id);G.data.x+=O||0,G.data.y+=_||0}})})}return e&&h.forEach(T=>{t.mergeNodeData(T.id,{x:T.data.x,y:T.data.y})}),{nodes:h,edges:c}})}initVals(e){const t=Object.assign({},e),{nodeSize:n,spacing:i,comboPadding:a}=e;let s,o;if(Be(i)?o=()=>i:Te(i)?o=i:o=()=>0,t.spacing=o,!n)s=l=>{const c=o(l);return l.size?la(l.size)?((l.size[0]>l.size[1]?l.size[0]:l.size[1])+c)/2:un(l.size)?((l.size.width>l.size.height?l.size.width:l.size.height)+c)/2:(l.size+c)/2:32+c/2};else if(Te(n))s=l=>{const c=n(l),u=o(l);return la(l.size)?((l.size[0]>l.size[1]?l.size[0]:l.size[1])+u)/2:((c||32)+u)/2};else if(la(n)){const c=(n[0]>n[1]?n[0]:n[1])/2;s=u=>c+o(u)/2}else{const l=n/2;s=c=>l+o(c)/2}t.nodeSize=s;let A;return Be(a)?A=()=>a:la(a)?A=()=>Math.max.apply(null,a):Te(a)?A=a:A=()=>0,t.comboPadding=A,t}getInnerGraphs(e,t,n,i,a,s,o){const{nodeSize:A,comboPadding:l,spacing:c,innerLayout:u}=s,h=u||new w1({}),d={center:[0,0],preventOverlap:!0,nodeSpacing:c},f=[],g=v=>{let p=(l==null?void 0:l(v))||10;return la(p)&&(p=Math.max(...p)),{size:p?[p*2,p*2]:[30,30],padding:p}};return e.getRoots(t).forEach(v=>{o.set(v.id,{id:v.id,data:{nodes:[],size:g(v).size}});let p=Promise.resolve();y1(e,[v],y=>{var m;if(!y.data._isCombo)return;const{size:B,padding:C}=g(y);if(!(!((m=e.getChildren(y.id,t))===null||m===void 0)&&m.length))o.set(y.id,{id:y.id,data:Object.assign(Object.assign({},y.data),{size:B})});else{const S=o.get(y.id);o.set(y.id,{id:y.id,data:Object.assign({nodes:[]},S==null?void 0:S.data)});const F=new Map,T=e.getChildren(y.id,t).map(k=>{if(k.data._isCombo)return o.has(k.id)||o.set(k.id,{id:k.id,data:Object.assign({},k.data)}),F.set(k.id,!0),o.get(k.id);const L=n.get(k.id)||i.get(k.id);return F.set(k.id,!0),{id:k.id,data:Object.assign(Object.assign({},L.data),k.data)}}),O={nodes:T,edges:a.filter(k=>F.has(k.source)&&F.has(k.target))};let _=1/0;T.forEach(k=>{var L;let{size:U}=k.data;U||(U=((L=o.get(k.id))===null||L===void 0?void 0:L.data.size)||(A==null?void 0:A(k))||[30,30]),Be(U)&&(U=[U,U]);const[G,W]=U;_>G&&(_=G),_>W&&(_=W),k.data.size=U}),p=p.then(()=>Je(this,void 0,void 0,function*(){const k=new Mn(O);yield mC(h,k,d,!0);const{minX:L,minY:U,maxX:G,maxY:W}=_$(T),V={x:(G+L)/2,y:(W+U)/2};O.nodes.forEach(D=>{D.data.x-=V.x,D.data.y-=V.y});const K=[Math.max(G-L,_)+C*2,Math.max(W-U,_)+C*2];o.get(y.id).data.size=K,o.get(y.id).data.nodes=T}))}return!0},"BT",t),f.push(p)}),f}}function mC(r,e,t,n){var i;return Je(this,void 0,void 0,function*(){return B1(r)?(r.execute(e,t),r.stop(),r.tick((i=t.iterations)!==null&&i!==void 0?i:300)):n?yield r.assign(e,t):yield r.execute(e,t)})}function V7(r,e){var t,n=1;r==null&&(r=0),e==null&&(e=0);function i(){var a,s=t.length,o,A=0,l=0;for(a=0;a<s;++a)o=t[a],A+=o.x,l+=o.y;for(A=(A/s-r)*n,l=(l/s-e)*n,a=0;a<s;++a)o=t[a],o.x-=A,o.y-=l}return i.initialize=function(a){t=a},i.x=function(a){return arguments.length?(r=+a,i):r},i.y=function(a){return arguments.length?(e=+a,i):e},i.strength=function(a){return arguments.length?(n=+a,i):n},i}function Fn(r){return function(){return r}}function Ka(r){return(r()-.5)*1e-6}function j7(r){return r.x+r.vx}function W7(r){return r.y+r.vy}function q7(r){var e,t,n,i=1,a=1;typeof r!="function"&&(r=Fn(r==null?1:+r));function s(){for(var l,c=e.length,u,h,d,f,g,v,p=0;p<a;++p)for(u=xd(e,j7,W7).visitAfter(o),l=0;l<c;++l)h=e[l],g=t[h.index],v=g*g,d=h.x+h.vx,f=h.y+h.vy,u.visit(y);function y(m,B,C,S,F){var T=m.data,O=m.r,_=g+O;if(T){if(T.index>h.index){var k=d-T.x-T.vx,L=f-T.y-T.vy,U=k*k+L*L;U<_*_&&(k===0&&(k=Ka(n),U+=k*k),L===0&&(L=Ka(n),U+=L*L),U=(_-(U=Math.sqrt(U)))/U*i,h.vx+=(k*=U)*(_=(O*=O)/(v+O)),h.vy+=(L*=U)*_,T.vx-=k*(_=1-_),T.vy-=L*_)}return}return B>d+_||S<d-_||C>f+_||F<f-_}}function o(l){if(l.data)return l.r=t[l.data.index];for(var c=l.r=0;c<4;++c)l[c]&&l[c].r>l.r&&(l.r=l[c].r)}function A(){if(e){var l,c=e.length,u;for(t=new Array(c),l=0;l<c;++l)u=e[l],t[u.index]=+r(u,l,e)}}return s.initialize=function(l,c){e=l,n=c,A()},s.iterations=function(l){return arguments.length?(a=+l,s):a},s.strength=function(l){return arguments.length?(i=+l,s):i},s.radius=function(l){return arguments.length?(r=typeof l=="function"?l:Fn(+l),A(),s):r},s}function $7(r){return r.index}function wC(r,e){var t=r.get(e);if(!t)throw new Error("node not found: "+e);return t}function Y7(r){var e=$7,t=u,n,i=Fn(30),a,s,o,A,l,c=1;r==null&&(r=[]);function u(v){return 1/Math.min(o[v.source.index],o[v.target.index])}function h(v){for(var p=0,y=r.length;p<c;++p)for(var m=0,B,C,S,F,T,O,_;m<y;++m)B=r[m],C=B.source,S=B.target,F=S.x+S.vx-C.x-C.vx||Ka(l),T=S.y+S.vy-C.y-C.vy||Ka(l),O=Math.sqrt(F*F+T*T),O=(O-a[m])/O*v*n[m],F*=O,T*=O,S.vx-=F*(_=A[m]),S.vy-=T*_,C.vx+=F*(_=1-_),C.vy+=T*_}function d(){if(s){var v,p=s.length,y=r.length,m=new Map(s.map((C,S)=>[e(C,S,s),C])),B;for(v=0,o=new Array(p);v<y;++v)B=r[v],B.index=v,typeof B.source!="object"&&(B.source=wC(m,B.source)),typeof B.target!="object"&&(B.target=wC(m,B.target)),o[B.source.index]=(o[B.source.index]||0)+1,o[B.target.index]=(o[B.target.index]||0)+1;for(v=0,A=new Array(y);v<y;++v)B=r[v],A[v]=o[B.source.index]/(o[B.source.index]+o[B.target.index]);n=new Array(y),f(),a=new Array(y),g()}}function f(){if(s)for(var v=0,p=r.length;v<p;++v)n[v]=+t(r[v],v,r)}function g(){if(s)for(var v=0,p=r.length;v<p;++v)a[v]=+i(r[v],v,r)}return h.initialize=function(v,p){s=v,l=p,d()},h.links=function(v){return arguments.length?(r=v,d(),h):r},h.id=function(v){return arguments.length?(e=v,h):e},h.iterations=function(v){return arguments.length?(c=+v,h):c},h.strength=function(v){return arguments.length?(t=typeof v=="function"?v:Fn(+v),f(),h):t},h.distance=function(v){return arguments.length?(i=typeof v=="function"?v:Fn(+v),g(),h):i},h}var X7={value:()=>{}};function bQ(){for(var r=0,e=arguments.length,t={},n;r<e;++r){if(!(n=arguments[r]+"")||n in t||/[\s.]/.test(n))throw new Error("illegal type: "+n);t[n]=[]}return new Lu(t)}function Lu(r){this._=r}function Z7(r,e){return r.trim().split(/^|\s+/).map(function(t){var n="",i=t.indexOf(".");if(i>=0&&(n=t.slice(i+1),t=t.slice(0,i)),t&&!e.hasOwnProperty(t))throw new Error("unknown type: "+t);return{type:t,name:n}})}Lu.prototype=bQ.prototype={constructor:Lu,on:function(r,e){var t=this._,n=Z7(r+"",t),i,a=-1,s=n.length;if(arguments.length<2){for(;++a<s;)if((i=(r=n[a]).type)&&(i=J7(t[i],r.name)))return i;return}if(e!=null&&typeof e!="function")throw new Error("invalid callback: "+e);for(;++a<s;)if(i=(r=n[a]).type)t[i]=BC(t[i],r.name,e);else if(e==null)for(i in t)t[i]=BC(t[i],r.name,null);return this},copy:function(){var r={},e=this._;for(var t in e)r[t]=e[t].slice();return new Lu(r)},call:function(r,e){if((i=arguments.length-2)>0)for(var t=new Array(i),n=0,i,a;n<i;++n)t[n]=arguments[n+2];if(!this._.hasOwnProperty(r))throw new Error("unknown type: "+r);for(a=this._[r],n=0,i=a.length;n<i;++n)a[n].value.apply(e,t)},apply:function(r,e,t){if(!this._.hasOwnProperty(r))throw new Error("unknown type: "+r);for(var n=this._[r],i=0,a=n.length;i<a;++i)n[i].value.apply(e,t)}};function J7(r,e){for(var t=0,n=r.length,i;t<n;++t)if((i=r[t]).name===e)return i.value}function BC(r,e,t){for(var n=0,i=r.length;n<i;++n)if(r[n].name===e){r[n]=X7,r=r.slice(0,n).concat(r.slice(n+1));break}return t!=null&&r.push({name:e,value:t}),r}var $o=0,RA=0,CA=0,EQ=1e3,xh,DA,Ch=0,qs=0,Sd=0,bl=typeof performance=="object"&&performance.now?performance:Date,xQ=typeof window=="object"&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(r){setTimeout(r,17)};function CQ(){return qs||(xQ(eY),qs=bl.now()+Sd)}function eY(){qs=0}function b1(){this._call=this._time=this._next=null}b1.prototype=SQ.prototype={constructor:b1,restart:function(r,e,t){if(typeof r!="function")throw new TypeError("callback is not a function");t=(t==null?CQ():+t)+(e==null?0:+e),!this._next&&DA!==this&&(DA?DA._next=this:xh=this,DA=this),this._call=r,this._time=t,E1()},stop:function(){this._call&&(this._call=null,this._time=1/0,E1())}};function SQ(r,e,t){var n=new b1;return n.restart(r,e,t),n}function tY(){CQ(),++$o;for(var r=xh,e;r;)(e=qs-r._time)>=0&&r._call.call(void 0,e),r=r._next;--$o}function bC(){qs=(Ch=bl.now())+Sd,$o=RA=0;try{tY()}finally{$o=0,rY(),qs=0}}function nY(){var r=bl.now(),e=r-Ch;e>EQ&&(Sd-=e,Ch=r)}function rY(){for(var r,e=xh,t,n=1/0;e;)e._call?(n>e._time&&(n=e._time),r=e,e=e._next):(t=e._next,e._next=null,e=r?r._next=t:xh=t);DA=r,E1(n)}function E1(r){if(!$o){RA&&(RA=clearTimeout(RA));var e=r-qs;e>24?(r<1/0&&(RA=setTimeout(bC,r-bl.now()-Sd)),CA&&(CA=clearInterval(CA))):(CA||(Ch=bl.now(),CA=setInterval(nY,EQ)),$o=1,xQ(bC))}}const iY=1664525,aY=1013904223,EC=4294967296;function sY(){let r=1;return()=>(r=(iY*r+aY)%EC)/EC}function oY(r){return r.x}function AY(r){return r.y}var lY=10,cY=Math.PI*(3-Math.sqrt(5));function uY(r){var e,t=1,n=.001,i=1-Math.pow(n,1/300),a=0,s=.6,o=new Map,A=SQ(u),l=bQ("tick","end"),c=sY();r==null&&(r=[]);function u(){h(),l.call("tick",e),t<n&&(A.stop(),l.call("end",e))}function h(g){var v,p=r.length,y;g===void 0&&(g=1);for(var m=0;m<g;++m)for(t+=(a-t)*i,o.forEach(function(B){B(t)}),v=0;v<p;++v)y=r[v],y.fx==null?y.x+=y.vx*=s:(y.x=y.fx,y.vx=0),y.fy==null?y.y+=y.vy*=s:(y.y=y.fy,y.vy=0);return e}function d(){for(var g=0,v=r.length,p;g<v;++g){if(p=r[g],p.index=g,p.fx!=null&&(p.x=p.fx),p.fy!=null&&(p.y=p.fy),isNaN(p.x)||isNaN(p.y)){var y=lY*Math.sqrt(.5+g),m=g*cY;p.x=y*Math.cos(m),p.y=y*Math.sin(m)}(isNaN(p.vx)||isNaN(p.vy))&&(p.vx=p.vy=0)}}function f(g){return g.initialize&&g.initialize(r,c),g}return d(),e={tick:h,restart:function(){return A.restart(u),e},stop:function(){return A.stop(),e},nodes:function(g){return arguments.length?(r=g,d(),o.forEach(f),e):r},alpha:function(g){return arguments.length?(t=+g,e):t},alphaMin:function(g){return arguments.length?(n=+g,e):n},alphaDecay:function(g){return arguments.length?(i=+g,e):+i},alphaTarget:function(g){return arguments.length?(a=+g,e):a},velocityDecay:function(g){return arguments.length?(s=1-g,e):1-s},randomSource:function(g){return arguments.length?(c=g,o.forEach(f),e):c},force:function(g,v){return arguments.length>1?(v==null?o.delete(g):o.set(g,f(v)),e):o.get(g)},find:function(g,v,p){var y=0,m=r.length,B,C,S,F,T;for(p==null?p=1/0:p*=p,y=0;y<m;++y)F=r[y],B=g-F.x,C=v-F.y,S=B*B+C*C,S<p&&(T=F,p=S);return T},on:function(g,v){return arguments.length>1?(l.on(g,v),e):l.on(g)}}}function hY(){var r,e,t,n,i=Fn(-30),a,s=1,o=1/0,A=.81;function l(d){var f,g=r.length,v=xd(r,oY,AY).visitAfter(u);for(n=d,f=0;f<g;++f)e=r[f],v.visit(h)}function c(){if(r){var d,f=r.length,g;for(a=new Array(f),d=0;d<f;++d)g=r[d],a[g.index]=+i(g,d,r)}}function u(d){var f=0,g,v,p=0,y,m,B;if(d.length){for(y=m=B=0;B<4;++B)(g=d[B])&&(v=Math.abs(g.value))&&(f+=g.value,p+=v,y+=v*g.x,m+=v*g.y);d.x=y/p,d.y=m/p}else{g=d,g.x=g.data.x,g.y=g.data.y;do f+=a[g.data.index];while(g=g.next)}d.value=f}function h(d,f,g,v){if(!d.value)return!0;var p=d.x-e.x,y=d.y-e.y,m=v-f,B=p*p+y*y;if(m*m/A<B)return B<o&&(p===0&&(p=Ka(t),B+=p*p),y===0&&(y=Ka(t),B+=y*y),B<s&&(B=Math.sqrt(s*B)),e.vx+=p*d.value*n/B,e.vy+=y*d.value*n/B),!0;if(d.length||B>=o)return;(d.data!==e||d.next)&&(p===0&&(p=Ka(t),B+=p*p),y===0&&(y=Ka(t),B+=y*y),B<s&&(B=Math.sqrt(s*B)));do d.data!==e&&(m=a[d.data.index]*n/B,e.vx+=p*m,e.vy+=y*m);while(d=d.next)}return l.initialize=function(d,f){r=d,t=f,c()},l.strength=function(d){return arguments.length?(i=typeof d=="function"?d:Fn(+d),c(),l):i},l.distanceMin=function(d){return arguments.length?(s=d*d,l):Math.sqrt(s)},l.distanceMax=function(d){return arguments.length?(o=d*d,l):Math.sqrt(o)},l.theta=function(d){return arguments.length?(A=d*d,l):Math.sqrt(A)},l}function dY(r,e,t){var n,i=Fn(.1),a,s;typeof r!="function"&&(r=Fn(+r)),e==null&&(e=0),t==null&&(t=0);function o(l){for(var c=0,u=n.length;c<u;++c){var h=n[c],d=h.x-e||1e-6,f=h.y-t||1e-6,g=Math.sqrt(d*d+f*f),v=(s[c]-g)*a[c]*l/g;h.vx+=d*v,h.vy+=f*v}}function A(){if(n){var l,c=n.length;for(a=new Array(c),s=new Array(c),l=0;l<c;++l)s[l]=+r(n[l],l,n),a[l]=isNaN(s[l])?0:+i(n[l],l,n)}}return o.initialize=function(l){n=l,A()},o.strength=function(l){return arguments.length?(i=typeof l=="function"?l:Fn(+l),A(),o):i},o.radius=function(l){return arguments.length?(r=typeof l=="function"?l:Fn(+l),A(),o):r},o.x=function(l){return arguments.length?(e=+l,o):e},o.y=function(l){return arguments.length?(t=+l,o):t},o}function fY(r){var e=Fn(.1),t,n,i;typeof r!="function"&&(r=Fn(r==null?0:+r));function a(o){for(var A=0,l=t.length,c;A<l;++A)c=t[A],c.vx+=(i[A]-c.x)*n[A]*o}function s(){if(t){var o,A=t.length;for(n=new Array(A),i=new Array(A),o=0;o<A;++o)n[o]=isNaN(i[o]=+r(t[o],o,t))?0:+e(t[o],o,t)}}return a.initialize=function(o){t=o,s()},a.strength=function(o){return arguments.length?(e=typeof o=="function"?o:Fn(+o),s(),a):e},a.x=function(o){return arguments.length?(r=typeof o=="function"?o:Fn(+o),s(),a):r},a}function gY(r){var e=Fn(.1),t,n,i;typeof r!="function"&&(r=Fn(r==null?0:+r));function a(o){for(var A=0,l=t.length,c;A<l;++A)c=t[A],c.vy+=(i[A]-c.y)*n[A]*o}function s(){if(t){var o,A=t.length;for(n=new Array(A),i=new Array(A),o=0;o<A;++o)n[o]=isNaN(i[o]=+r(t[o],o,t))?0:+e(t[o],o,t)}}return a.initialize=function(o){t=o,s()},a.strength=function(o){return arguments.length?(e=typeof o=="function"?o:Fn(+o),s(),a):e},a.y=function(o){return arguments.length?(r=typeof o=="function"?o:Fn(+o),s(),a):r},a}class vY{constructor(e){this.id="d3-force",this.config={inputNodeAttrs:["x","y","vx","vy","fx","fy"],outputNodeAttrs:["x","y","vx","vy"],simulationAttrs:["alpha","alphaMin","alphaDecay","alphaTarget","velocityDecay","randomSource"]},this.forceMap={link:Y7,manyBody:hY,center:V7,collide:q7,radial:dY,x:fY,y:gY},this.options={link:{id:t=>t.id},manyBody:{},center:{x:0,y:0}},this.context={options:{},assign:!1,nodes:[],edges:[]},zn(this.options,e),this.options.forceSimulation&&(this.simulation=this.options.forceSimulation)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericLayout(!0,e,t)})}stop(){this.simulation.stop()}tick(e){return this.simulation.tick(e),this.getResult()}restart(){this.simulation.restart()}setFixedPosition(e,t){const n=this.context.nodes.find(i=>i.id===e);n&&t.forEach((i,a)=>{if(typeof i=="number"||i===null){const s=["fx","fy","fz"][a];n[s]=i}})}getOptions(e){var t,n;const i=zn({},this.options,e);return i.collide&&((t=i.collide)===null||t===void 0?void 0:t.radius)===void 0&&(i.collide=i.collide||{},i.collide.radius=(n=i.nodeSize)!==null&&n!==void 0?n:10),i.iterations===void 0&&(i.link&&i.link.iterations===void 0&&(i.iterations=i.link.iterations),i.collide&&i.collide.iterations===void 0&&(i.iterations=i.collide.iterations)),this.context.options=i,i}genericLayout(e,t,n){var i;return Je(this,void 0,void 0,function*(){const a=this.getOptions(n),s=t.getAllNodes().map(({id:c,data:u})=>Object.assign(Object.assign({id:c},u),Ds(u.data,this.config.inputNodeAttrs))),o=t.getAllEdges().map(c=>Object.assign({},c));Object.assign(this.context,{assign:e,nodes:s,edges:o,graph:t});const A=new Promise(c=>{this.resolver=c}),l=this.setSimulation(a);return l.nodes(s),(i=l.force("link"))===null||i===void 0||i.links(o),A})}getResult(){const{assign:e,nodes:t,edges:n,graph:i}=this.context,a=t.map(o=>({id:o.id,data:Object.assign(Object.assign({},o.data),Ds(o,this.config.outputNodeAttrs))})),s=n.map(({id:o,source:A,target:l,data:c})=>({id:o,source:typeof A=="object"?A.id:A,target:typeof l=="object"?l.id:l,data:c}));return e&&a.forEach(o=>i.mergeNodeData(o.id,o.data)),{nodes:a,edges:s}}initSimulation(){return uY()}setSimulation(e){const t=this.simulation||this.options.forceSimulation||this.initSimulation();return this.simulation||(this.simulation=t.on("tick",()=>{var n;return(n=e.onTick)===null||n===void 0?void 0:n.call(e,this.getResult())}).on("end",()=>{var n;return(n=this.resolver)===null||n===void 0?void 0:n.call(this,this.getResult())})),xC(t,this.config.simulationAttrs.map(n=>[n,e[n]])),Object.entries(this.forceMap).forEach(([n,i])=>{const a=n;if(e[n]){let s=t.force(a);s||(s=i(),t.force(a,s)),xC(s,Object.entries(e[a]))}else t.force(a,null)}),t}}const xC=(r,e)=>e.reduce((t,[n,i])=>!t[n]||i===void 0?t:t[n].call(r,i),r);var _g,CC;function pY(){if(CC)return _g;CC=1;function r(){this.__data__=[],this.size=0}return _g=r,_g}var Ig,SC;function tA(){if(SC)return Ig;SC=1;function r(e,t){return e===t||e!==e&&t!==t}return Ig=r,Ig}var kg,FC;function Fd(){if(FC)return kg;FC=1;var r=tA();function e(t,n){for(var i=t.length;i--;)if(r(t[i][0],n))return i;return-1}return kg=e,kg}var Lg,TC;function yY(){if(TC)return Lg;TC=1;var r=Fd(),e=Array.prototype,t=e.splice;function n(i){var a=this.__data__,s=r(a,i);if(s<0)return!1;var o=a.length-1;return s==o?a.pop():t.call(a,s,1),--this.size,!0}return Lg=n,Lg}var Qg,MC;function mY(){if(MC)return Qg;MC=1;var r=Fd();function e(t){var n=this.__data__,i=r(n,t);return i<0?void 0:n[i][1]}return Qg=e,Qg}var Ng,OC;function wY(){if(OC)return Ng;OC=1;var r=Fd();function e(t){return r(this.__data__,t)>-1}return Ng=e,Ng}var Ug,_C;function BY(){if(_C)return Ug;_C=1;var r=Fd();function e(t,n){var i=this.__data__,a=r(i,t);return a<0?(++this.size,i.push([t,n])):i[a][1]=n,this}return Ug=e,Ug}var Pg,IC;function Td(){if(IC)return Pg;IC=1;var r=pY(),e=yY(),t=mY(),n=wY(),i=BY();function a(s){var o=-1,A=s==null?0:s.length;for(this.clear();++o<A;){var l=s[o];this.set(l[0],l[1])}}return a.prototype.clear=r,a.prototype.delete=e,a.prototype.get=t,a.prototype.has=n,a.prototype.set=i,Pg=a,Pg}var Rg,kC;function bY(){if(kC)return Rg;kC=1;var r=Td();function e(){this.__data__=new r,this.size=0}return Rg=e,Rg}var Dg,LC;function EY(){if(LC)return Dg;LC=1;function r(e){var t=this.__data__,n=t.delete(e);return this.size=t.size,n}return Dg=r,Dg}var Hg,QC;function xY(){if(QC)return Hg;QC=1;function r(e){return this.__data__.get(e)}return Hg=r,Hg}var Gg,NC;function CY(){if(NC)return Gg;NC=1;function r(e){return this.__data__.has(e)}return Gg=r,Gg}var Kg,UC;function FQ(){if(UC)return Kg;UC=1;var r=typeof nc=="object"&&nc&&nc.Object===Object&&nc;return Kg=r,Kg}var zg,PC;function Ci(){if(PC)return zg;PC=1;var r=FQ(),e=typeof self=="object"&&self&&self.Object===Object&&self,t=r||e||Function("return this")();return zg=t,zg}var Vg,RC;function nA(){if(RC)return Vg;RC=1;var r=Ci(),e=r.Symbol;return Vg=e,Vg}var jg,DC;function SY(){if(DC)return jg;DC=1;var r=nA(),e=Object.prototype,t=e.hasOwnProperty,n=e.toString,i=r?r.toStringTag:void 0;function a(s){var o=t.call(s,i),A=s[i];try{s[i]=void 0;var l=!0}catch{}var c=n.call(s);return l&&(o?s[i]=A:delete s[i]),c}return jg=a,jg}var Wg,HC;function FY(){if(HC)return Wg;HC=1;var r=Object.prototype,e=r.toString;function t(n){return e.call(n)}return Wg=t,Wg}var qg,GC;function no(){if(GC)return qg;GC=1;var r=nA(),e=SY(),t=FY(),n="[object Null]",i="[object Undefined]",a=r?r.toStringTag:void 0;function s(o){return o==null?o===void 0?i:n:a&&a in Object(o)?e(o):t(o)}return qg=s,qg}var $g,KC;function si(){if(KC)return $g;KC=1;function r(e){var t=typeof e;return e!=null&&(t=="object"||t=="function")}return $g=r,$g}var Yg,zC;function Vl(){if(zC)return Yg;zC=1;var r=no(),e=si(),t="[object AsyncFunction]",n="[object Function]",i="[object GeneratorFunction]",a="[object Proxy]";function s(o){if(!e(o))return!1;var A=r(o);return A==n||A==i||A==t||A==a}return Yg=s,Yg}var Xg,VC;function TY(){if(VC)return Xg;VC=1;var r=Ci(),e=r["__core-js_shared__"];return Xg=e,Xg}var Zg,jC;function MY(){if(jC)return Zg;jC=1;var r=TY(),e=(function(){var n=/[^.]+$/.exec(r&&r.keys&&r.keys.IE_PROTO||"");return n?"Symbol(src)_1."+n:""})();function t(n){return!!e&&e in n}return Zg=t,Zg}var Jg,WC;function TQ(){if(WC)return Jg;WC=1;var r=Function.prototype,e=r.toString;function t(n){if(n!=null){try{return e.call(n)}catch{}try{return n+""}catch{}}return""}return Jg=t,Jg}var ev,qC;function OY(){if(qC)return ev;qC=1;var r=Vl(),e=MY(),t=si(),n=TQ(),i=/[\\^$.*+?()[\]{}|]/g,a=/^\[object .+?Constructor\]$/,s=Function.prototype,o=Object.prototype,A=s.toString,l=o.hasOwnProperty,c=RegExp("^"+A.call(l).replace(i,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function u(h){if(!t(h)||e(h))return!1;var d=r(h)?c:a;return d.test(n(h))}return ev=u,ev}var tv,$C;function _Y(){if($C)return tv;$C=1;function r(e,t){return e==null?void 0:e[t]}return tv=r,tv}var nv,YC;function ro(){if(YC)return nv;YC=1;var r=OY(),e=_Y();function t(n,i){var a=e(n,i);return r(a)?a:void 0}return nv=t,nv}var rv,XC;function NB(){if(XC)return rv;XC=1;var r=ro(),e=Ci(),t=r(e,"Map");return rv=t,rv}var iv,ZC;function Md(){if(ZC)return iv;ZC=1;var r=ro(),e=r(Object,"create");return iv=e,iv}var av,JC;function IY(){if(JC)return av;JC=1;var r=Md();function e(){this.__data__=r?r(null):{},this.size=0}return av=e,av}var sv,e2;function kY(){if(e2)return sv;e2=1;function r(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t}return sv=r,sv}var ov,t2;function LY(){if(t2)return ov;t2=1;var r=Md(),e="__lodash_hash_undefined__",t=Object.prototype,n=t.hasOwnProperty;function i(a){var s=this.__data__;if(r){var o=s[a];return o===e?void 0:o}return n.call(s,a)?s[a]:void 0}return ov=i,ov}var Av,n2;function QY(){if(n2)return Av;n2=1;var r=Md(),e=Object.prototype,t=e.hasOwnProperty;function n(i){var a=this.__data__;return r?a[i]!==void 0:t.call(a,i)}return Av=n,Av}var lv,r2;function NY(){if(r2)return lv;r2=1;var r=Md(),e="__lodash_hash_undefined__";function t(n,i){var a=this.__data__;return this.size+=this.has(n)?0:1,a[n]=r&&i===void 0?e:i,this}return lv=t,lv}var cv,i2;function UY(){if(i2)return cv;i2=1;var r=IY(),e=kY(),t=LY(),n=QY(),i=NY();function a(s){var o=-1,A=s==null?0:s.length;for(this.clear();++o<A;){var l=s[o];this.set(l[0],l[1])}}return a.prototype.clear=r,a.prototype.delete=e,a.prototype.get=t,a.prototype.has=n,a.prototype.set=i,cv=a,cv}var uv,a2;function PY(){if(a2)return uv;a2=1;var r=UY(),e=Td(),t=NB();function n(){this.size=0,this.__data__={hash:new r,map:new(t||e),string:new r}}return uv=n,uv}var hv,s2;function RY(){if(s2)return hv;s2=1;function r(e){var t=typeof e;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?e!=="__proto__":e===null}return hv=r,hv}var dv,o2;function Od(){if(o2)return dv;o2=1;var r=RY();function e(t,n){var i=t.__data__;return r(n)?i[typeof n=="string"?"string":"hash"]:i.map}return dv=e,dv}var fv,A2;function DY(){if(A2)return fv;A2=1;var r=Od();function e(t){var n=r(this,t).delete(t);return this.size-=n?1:0,n}return fv=e,fv}var gv,l2;function HY(){if(l2)return gv;l2=1;var r=Od();function e(t){return r(this,t).get(t)}return gv=e,gv}var vv,c2;function GY(){if(c2)return vv;c2=1;var r=Od();function e(t){return r(this,t).has(t)}return vv=e,vv}var pv,u2;function KY(){if(u2)return pv;u2=1;var r=Od();function e(t,n){var i=r(this,t),a=i.size;return i.set(t,n),this.size+=i.size==a?0:1,this}return pv=e,pv}var yv,h2;function UB(){if(h2)return yv;h2=1;var r=PY(),e=DY(),t=HY(),n=GY(),i=KY();function a(s){var o=-1,A=s==null?0:s.length;for(this.clear();++o<A;){var l=s[o];this.set(l[0],l[1])}}return a.prototype.clear=r,a.prototype.delete=e,a.prototype.get=t,a.prototype.has=n,a.prototype.set=i,yv=a,yv}var mv,d2;function zY(){if(d2)return mv;d2=1;var r=Td(),e=NB(),t=UB(),n=200;function i(a,s){var o=this.__data__;if(o instanceof r){var A=o.__data__;if(!e||A.length<n-1)return A.push([a,s]),this.size=++o.size,this;o=this.__data__=new t(A)}return o.set(a,s),this.size=o.size,this}return mv=i,mv}var wv,f2;function _d(){if(f2)return wv;f2=1;var r=Td(),e=bY(),t=EY(),n=xY(),i=CY(),a=zY();function s(o){var A=this.__data__=new r(o);this.size=A.size}return s.prototype.clear=e,s.prototype.delete=t,s.prototype.get=n,s.prototype.has=i,s.prototype.set=a,wv=s,wv}var Bv,g2;function PB(){if(g2)return Bv;g2=1;function r(e,t){for(var n=-1,i=e==null?0:e.length;++n<i&&t(e[n],n,e)!==!1;);return e}return Bv=r,Bv}var bv,v2;function MQ(){if(v2)return bv;v2=1;var r=ro(),e=(function(){try{var t=r(Object,"defineProperty");return t({},"",{}),t}catch{}})();return bv=e,bv}var Ev,p2;function Id(){if(p2)return Ev;p2=1;var r=MQ();function e(t,n,i){n=="__proto__"&&r?r(t,n,{configurable:!0,enumerable:!0,value:i,writable:!0}):t[n]=i}return Ev=e,Ev}var xv,y2;function kd(){if(y2)return xv;y2=1;var r=Id(),e=tA(),t=Object.prototype,n=t.hasOwnProperty;function i(a,s,o){var A=a[s];(!(n.call(a,s)&&e(A,o))||o===void 0&&!(s in a))&&r(a,s,o)}return xv=i,xv}var Cv,m2;function jl(){if(m2)return Cv;m2=1;var r=kd(),e=Id();function t(n,i,a,s){var o=!a;a||(a={});for(var A=-1,l=i.length;++A<l;){var c=i[A],u=s?s(a[c],n[c],c,a,n):void 0;u===void 0&&(u=n[c]),o?e(a,c,u):r(a,c,u)}return a}return Cv=t,Cv}var Sv,w2;function VY(){if(w2)return Sv;w2=1;function r(e,t){for(var n=-1,i=Array(e);++n<e;)i[n]=t(n);return i}return Sv=r,Sv}var Fv,B2;function Zi(){if(B2)return Fv;B2=1;function r(e){return e!=null&&typeof e=="object"}return Fv=r,Fv}var Tv,b2;function jY(){if(b2)return Tv;b2=1;var r=no(),e=Zi(),t="[object Arguments]";function n(i){return e(i)&&r(i)==t}return Tv=n,Tv}var Mv,E2;function Wl(){if(E2)return Mv;E2=1;var r=jY(),e=Zi(),t=Object.prototype,n=t.hasOwnProperty,i=t.propertyIsEnumerable,a=r((function(){return arguments})())?r:function(s){return e(s)&&n.call(s,"callee")&&!i.call(s,"callee")};return Mv=a,Mv}var Ov,x2;function Bn(){if(x2)return Ov;x2=1;var r=Array.isArray;return Ov=r,Ov}var HA={exports:{}},_v,C2;function WY(){if(C2)return _v;C2=1;function r(){return!1}return _v=r,_v}HA.exports;var S2;function rA(){return S2||(S2=1,(function(r,e){var t=Ci(),n=WY(),i=e&&!e.nodeType&&e,a=i&&!0&&r&&!r.nodeType&&r,s=a&&a.exports===i,o=s?t.Buffer:void 0,A=o?o.isBuffer:void 0,l=A||n;r.exports=l})(HA,HA.exports)),HA.exports}var Iv,F2;function Ld(){if(F2)return Iv;F2=1;var r=9007199254740991,e=/^(?:0|[1-9]\d*)$/;function t(n,i){var a=typeof n;return i=i??r,!!i&&(a=="number"||a!="symbol"&&e.test(n))&&n>-1&&n%1==0&&n<i}return Iv=t,Iv}var kv,T2;function RB(){if(T2)return kv;T2=1;var r=9007199254740991;function e(t){return typeof t=="number"&&t>-1&&t%1==0&&t<=r}return kv=e,kv}var Lv,M2;function qY(){if(M2)return Lv;M2=1;var r=no(),e=RB(),t=Zi(),n="[object Arguments]",i="[object Array]",a="[object Boolean]",s="[object Date]",o="[object Error]",A="[object Function]",l="[object Map]",c="[object Number]",u="[object Object]",h="[object RegExp]",d="[object Set]",f="[object String]",g="[object WeakMap]",v="[object ArrayBuffer]",p="[object DataView]",y="[object Float32Array]",m="[object Float64Array]",B="[object Int8Array]",C="[object Int16Array]",S="[object Int32Array]",F="[object Uint8Array]",T="[object Uint8ClampedArray]",O="[object Uint16Array]",_="[object Uint32Array]",k={};k[y]=k[m]=k[B]=k[C]=k[S]=k[F]=k[T]=k[O]=k[_]=!0,k[n]=k[i]=k[v]=k[a]=k[p]=k[s]=k[o]=k[A]=k[l]=k[c]=k[u]=k[h]=k[d]=k[f]=k[g]=!1;function L(U){return t(U)&&e(U.length)&&!!k[r(U)]}return Lv=L,Lv}var Qv,O2;function Qd(){if(O2)return Qv;O2=1;function r(e){return function(t){return e(t)}}return Qv=r,Qv}var GA={exports:{}};GA.exports;var _2;function DB(){return _2||(_2=1,(function(r,e){var t=FQ(),n=e&&!e.nodeType&&e,i=n&&!0&&r&&!r.nodeType&&r,a=i&&i.exports===n,s=a&&t.process,o=(function(){try{var A=i&&i.require&&i.require("util").types;return A||s&&s.binding&&s.binding("util")}catch{}})();r.exports=o})(GA,GA.exports)),GA.exports}var Nv,I2;function ql(){if(I2)return Nv;I2=1;var r=qY(),e=Qd(),t=DB(),n=t&&t.isTypedArray,i=n?e(n):r;return Nv=i,Nv}var Uv,k2;function OQ(){if(k2)return Uv;k2=1;var r=VY(),e=Wl(),t=Bn(),n=rA(),i=Ld(),a=ql(),s=Object.prototype,o=s.hasOwnProperty;function A(l,c){var u=t(l),h=!u&&e(l),d=!u&&!h&&n(l),f=!u&&!h&&!d&&a(l),g=u||h||d||f,v=g?r(l.length,String):[],p=v.length;for(var y in l)(c||o.call(l,y))&&!(g&&(y=="length"||d&&(y=="offset"||y=="parent")||f&&(y=="buffer"||y=="byteLength"||y=="byteOffset")||i(y,p)))&&v.push(y);return v}return Uv=A,Uv}var Pv,L2;function Nd(){if(L2)return Pv;L2=1;var r=Object.prototype;function e(t){var n=t&&t.constructor,i=typeof n=="function"&&n.prototype||r;return t===i}return Pv=e,Pv}var Rv,Q2;function _Q(){if(Q2)return Rv;Q2=1;function r(e,t){return function(n){return e(t(n))}}return Rv=r,Rv}var Dv,N2;function $Y(){if(N2)return Dv;N2=1;var r=_Q(),e=r(Object.keys,Object);return Dv=e,Dv}var Hv,U2;function HB(){if(U2)return Hv;U2=1;var r=Nd(),e=$Y(),t=Object.prototype,n=t.hasOwnProperty;function i(a){if(!r(a))return e(a);var s=[];for(var o in Object(a))n.call(a,o)&&o!="constructor"&&s.push(o);return s}return Hv=i,Hv}var Gv,P2;function wa(){if(P2)return Gv;P2=1;var r=Vl(),e=RB();function t(n){return n!=null&&e(n.length)&&!r(n)}return Gv=t,Gv}var Kv,R2;function As(){if(R2)return Kv;R2=1;var r=OQ(),e=HB(),t=wa();function n(i){return t(i)?r(i):e(i)}return Kv=n,Kv}var zv,D2;function YY(){if(D2)return zv;D2=1;var r=jl(),e=As();function t(n,i){return n&&r(i,e(i),n)}return zv=t,zv}var Vv,H2;function XY(){if(H2)return Vv;H2=1;function r(e){var t=[];if(e!=null)for(var n in Object(e))t.push(n);return t}return Vv=r,Vv}var jv,G2;function ZY(){if(G2)return jv;G2=1;var r=si(),e=Nd(),t=XY(),n=Object.prototype,i=n.hasOwnProperty;function a(s){if(!r(s))return t(s);var o=e(s),A=[];for(var l in s)l=="constructor"&&(o||!i.call(s,l))||A.push(l);return A}return jv=a,jv}var Wv,K2;function io(){if(K2)return Wv;K2=1;var r=OQ(),e=ZY(),t=wa();function n(i){return t(i)?r(i,!0):e(i)}return Wv=n,Wv}var qv,z2;function JY(){if(z2)return qv;z2=1;var r=jl(),e=io();function t(n,i){return n&&r(i,e(i),n)}return qv=t,qv}var KA={exports:{}};KA.exports;var V2;function IQ(){return V2||(V2=1,(function(r,e){var t=Ci(),n=e&&!e.nodeType&&e,i=n&&!0&&r&&!r.nodeType&&r,a=i&&i.exports===n,s=a?t.Buffer:void 0,o=s?s.allocUnsafe:void 0;function A(l,c){if(c)return l.slice();var u=l.length,h=o?o(u):new l.constructor(u);return l.copy(h),h}r.exports=A})(KA,KA.exports)),KA.exports}var $v,j2;function kQ(){if(j2)return $v;j2=1;function r(e,t){var n=-1,i=e.length;for(t||(t=Array(i));++n<i;)t[n]=e[n];return t}return $v=r,$v}var Yv,W2;function LQ(){if(W2)return Yv;W2=1;function r(e,t){for(var n=-1,i=e==null?0:e.length,a=0,s=[];++n<i;){var o=e[n];t(o,n,e)&&(s[a++]=o)}return s}return Yv=r,Yv}var Xv,q2;function QQ(){if(q2)return Xv;q2=1;function r(){return[]}return Xv=r,Xv}var Zv,$2;function GB(){if($2)return Zv;$2=1;var r=LQ(),e=QQ(),t=Object.prototype,n=t.propertyIsEnumerable,i=Object.getOwnPropertySymbols,a=i?function(s){return s==null?[]:(s=Object(s),r(i(s),function(o){return n.call(s,o)}))}:e;return Zv=a,Zv}var Jv,Y2;function eX(){if(Y2)return Jv;Y2=1;var r=jl(),e=GB();function t(n,i){return r(n,e(n),i)}return Jv=t,Jv}var ep,X2;function KB(){if(X2)return ep;X2=1;function r(e,t){for(var n=-1,i=t.length,a=e.length;++n<i;)e[a+n]=t[n];return e}return ep=r,ep}var tp,Z2;function Ud(){if(Z2)return tp;Z2=1;var r=_Q(),e=r(Object.getPrototypeOf,Object);return tp=e,tp}var np,J2;function NQ(){if(J2)return np;J2=1;var r=KB(),e=Ud(),t=GB(),n=QQ(),i=Object.getOwnPropertySymbols,a=i?function(s){for(var o=[];s;)r(o,t(s)),s=e(s);return o}:n;return np=a,np}var rp,eS;function tX(){if(eS)return rp;eS=1;var r=jl(),e=NQ();function t(n,i){return r(n,e(n),i)}return rp=t,rp}var ip,tS;function UQ(){if(tS)return ip;tS=1;var r=KB(),e=Bn();function t(n,i,a){var s=i(n);return e(n)?s:r(s,a(n))}return ip=t,ip}var ap,nS;function PQ(){if(nS)return ap;nS=1;var r=UQ(),e=GB(),t=As();function n(i){return r(i,t,e)}return ap=n,ap}var sp,rS;function nX(){if(rS)return sp;rS=1;var r=UQ(),e=NQ(),t=io();function n(i){return r(i,t,e)}return sp=n,sp}var op,iS;function rX(){if(iS)return op;iS=1;var r=ro(),e=Ci(),t=r(e,"DataView");return op=t,op}var Ap,aS;function iX(){if(aS)return Ap;aS=1;var r=ro(),e=Ci(),t=r(e,"Promise");return Ap=t,Ap}var lp,sS;function RQ(){if(sS)return lp;sS=1;var r=ro(),e=Ci(),t=r(e,"Set");return lp=t,lp}var cp,oS;function aX(){if(oS)return cp;oS=1;var r=ro(),e=Ci(),t=r(e,"WeakMap");return cp=t,cp}var up,AS;function iA(){if(AS)return up;AS=1;var r=rX(),e=NB(),t=iX(),n=RQ(),i=aX(),a=no(),s=TQ(),o="[object Map]",A="[object Object]",l="[object Promise]",c="[object Set]",u="[object WeakMap]",h="[object DataView]",d=s(r),f=s(e),g=s(t),v=s(n),p=s(i),y=a;return(r&&y(new r(new ArrayBuffer(1)))!=h||e&&y(new e)!=o||t&&y(t.resolve())!=l||n&&y(new n)!=c||i&&y(new i)!=u)&&(y=function(m){var B=a(m),C=B==A?m.constructor:void 0,S=C?s(C):"";if(S)switch(S){case d:return h;case f:return o;case g:return l;case v:return c;case p:return u}return B}),up=y,up}var hp,lS;function sX(){if(lS)return hp;lS=1;var r=Object.prototype,e=r.hasOwnProperty;function t(n){var i=n.length,a=new n.constructor(i);return i&&typeof n[0]=="string"&&e.call(n,"index")&&(a.index=n.index,a.input=n.input),a}return hp=t,hp}var dp,cS;function DQ(){if(cS)return dp;cS=1;var r=Ci(),e=r.Uint8Array;return dp=e,dp}var fp,uS;function zB(){if(uS)return fp;uS=1;var r=DQ();function e(t){var n=new t.constructor(t.byteLength);return new r(n).set(new r(t)),n}return fp=e,fp}var gp,hS;function oX(){if(hS)return gp;hS=1;var r=zB();function e(t,n){var i=n?r(t.buffer):t.buffer;return new t.constructor(i,t.byteOffset,t.byteLength)}return gp=e,gp}var vp,dS;function AX(){if(dS)return vp;dS=1;var r=/\w*$/;function e(t){var n=new t.constructor(t.source,r.exec(t));return n.lastIndex=t.lastIndex,n}return vp=e,vp}var pp,fS;function lX(){if(fS)return pp;fS=1;var r=nA(),e=r?r.prototype:void 0,t=e?e.valueOf:void 0;function n(i){return t?Object(t.call(i)):{}}return pp=n,pp}var yp,gS;function HQ(){if(gS)return yp;gS=1;var r=zB();function e(t,n){var i=n?r(t.buffer):t.buffer;return new t.constructor(i,t.byteOffset,t.length)}return yp=e,yp}var mp,vS;function cX(){if(vS)return mp;vS=1;var r=zB(),e=oX(),t=AX(),n=lX(),i=HQ(),a="[object Boolean]",s="[object Date]",o="[object Map]",A="[object Number]",l="[object RegExp]",c="[object Set]",u="[object String]",h="[object Symbol]",d="[object ArrayBuffer]",f="[object DataView]",g="[object Float32Array]",v="[object Float64Array]",p="[object Int8Array]",y="[object Int16Array]",m="[object Int32Array]",B="[object Uint8Array]",C="[object Uint8ClampedArray]",S="[object Uint16Array]",F="[object Uint32Array]";function T(O,_,k){var L=O.constructor;switch(_){case d:return r(O);case a:case s:return new L(+O);case f:return e(O,k);case g:case v:case p:case y:case m:case B:case C:case S:case F:return i(O,k);case o:return new L;case A:case u:return new L(O);case l:return t(O);case c:return new L;case h:return n(O)}}return mp=T,mp}var wp,pS;function GQ(){if(pS)return wp;pS=1;var r=si(),e=Object.create,t=(function(){function n(){}return function(i){if(!r(i))return{};if(e)return e(i);n.prototype=i;var a=new n;return n.prototype=void 0,a}})();return wp=t,wp}var Bp,yS;function KQ(){if(yS)return Bp;yS=1;var r=GQ(),e=Ud(),t=Nd();function n(i){return typeof i.constructor=="function"&&!t(i)?r(e(i)):{}}return Bp=n,Bp}var bp,mS;function uX(){if(mS)return bp;mS=1;var r=iA(),e=Zi(),t="[object Map]";function n(i){return e(i)&&r(i)==t}return bp=n,bp}var Ep,wS;function hX(){if(wS)return Ep;wS=1;var r=uX(),e=Qd(),t=DB(),n=t&&t.isMap,i=n?e(n):r;return Ep=i,Ep}var xp,BS;function dX(){if(BS)return xp;BS=1;var r=iA(),e=Zi(),t="[object Set]";function n(i){return e(i)&&r(i)==t}return xp=n,xp}var Cp,bS;function fX(){if(bS)return Cp;bS=1;var r=dX(),e=Qd(),t=DB(),n=t&&t.isSet,i=n?e(n):r;return Cp=i,Cp}var Sp,ES;function zQ(){if(ES)return Sp;ES=1;var r=_d(),e=PB(),t=kd(),n=YY(),i=JY(),a=IQ(),s=kQ(),o=eX(),A=tX(),l=PQ(),c=nX(),u=iA(),h=sX(),d=cX(),f=KQ(),g=Bn(),v=rA(),p=hX(),y=si(),m=fX(),B=As(),C=io(),S=1,F=2,T=4,O="[object Arguments]",_="[object Array]",k="[object Boolean]",L="[object Date]",U="[object Error]",G="[object Function]",W="[object GeneratorFunction]",V="[object Map]",K="[object Number]",D="[object Object]",X="[object RegExp]",te="[object Set]",ie="[object String]",re="[object Symbol]",xe="[object WeakMap]",$="[object ArrayBuffer]",z="[object DataView]",ee="[object Float32Array]",Ae="[object Float64Array]",be="[object Int8Array]",Le="[object Int16Array]",Ue="[object Int32Array]",at="[object Uint8Array]",lt="[object Uint8ClampedArray]",ct="[object Uint16Array]",pt="[object Uint32Array]",Ne={};Ne[O]=Ne[_]=Ne[$]=Ne[z]=Ne[k]=Ne[L]=Ne[ee]=Ne[Ae]=Ne[be]=Ne[Le]=Ne[Ue]=Ne[V]=Ne[K]=Ne[D]=Ne[X]=Ne[te]=Ne[ie]=Ne[re]=Ne[at]=Ne[lt]=Ne[ct]=Ne[pt]=!0,Ne[U]=Ne[G]=Ne[xe]=!1;function ht(nt,gr,St,Ji,ir,Wt){var _t,Qn=gr&S,qn=gr&F,vr=gr&T;if(St&&(_t=ir?St(nt,Ji,ir,Wt):St(nt)),_t!==void 0)return _t;if(!y(nt))return nt;var ar=g(nt);if(ar){if(_t=h(nt),!Qn)return s(nt,_t)}else{var $n=u(nt),rn=$n==G||$n==W;if(v(nt))return a(nt,Qn);if($n==D||$n==O||rn&&!ir){if(_t=qn||rn?{}:f(nt),!Qn)return qn?A(nt,i(_t,nt)):o(nt,n(_t,nt))}else{if(!Ne[$n])return ir?nt:{};_t=d(nt,$n,Qn)}}Wt||(Wt=new r);var an=Wt.get(nt);if(an)return an;Wt.set(nt,_t),m(nt)?nt.forEach(function(Or){_t.add(ht(Or,gr,St,Or,nt,Wt))}):p(nt)&&nt.forEach(function(Or,Vr){_t.set(Vr,ht(Or,gr,St,Vr,nt,Wt))});var cA=vr?qn?c:l:qn?C:B,cs=ar?void 0:cA(nt);return e(cs||nt,function(Or,Vr){cs&&(Vr=Or,Or=nt[Vr]),t(_t,Vr,ht(Or,gr,St,Vr,nt,Wt))}),_t}return Sp=ht,Sp}var Fp,xS;function gX(){if(xS)return Fp;xS=1;var r=zQ(),e=4;function t(n){return r(n,e)}return Fp=t,Fp}var Tp,CS;function VB(){if(CS)return Tp;CS=1;function r(e){return function(){return e}}return Tp=r,Tp}var Mp,SS;function vX(){if(SS)return Mp;SS=1;function r(e){return function(t,n,i){for(var a=-1,s=Object(t),o=i(t),A=o.length;A--;){var l=o[e?A:++a];if(n(s[l],l,s)===!1)break}return t}}return Mp=r,Mp}var Op,FS;function jB(){if(FS)return Op;FS=1;var r=vX(),e=r();return Op=e,Op}var _p,TS;function WB(){if(TS)return _p;TS=1;var r=jB(),e=As();function t(n,i){return n&&r(n,i,e)}return _p=t,_p}var Ip,MS;function pX(){if(MS)return Ip;MS=1;var r=wa();function e(t,n){return function(i,a){if(i==null)return i;if(!r(i))return t(i,a);for(var s=i.length,o=n?s:-1,A=Object(i);(n?o--:++o<s)&&a(A[o],o,A)!==!1;);return i}}return Ip=e,Ip}var kp,OS;function Pd(){if(OS)return kp;OS=1;var r=WB(),e=pX(),t=e(r);return kp=t,kp}var Lp,_S;function ao(){if(_S)return Lp;_S=1;function r(e){return e}return Lp=r,Lp}var Qp,IS;function VQ(){if(IS)return Qp;IS=1;var r=ao();function e(t){return typeof t=="function"?t:r}return Qp=e,Qp}var Np,kS;function jQ(){if(kS)return Np;kS=1;var r=PB(),e=Pd(),t=VQ(),n=Bn();function i(a,s){var o=n(a)?r:e;return o(a,t(s))}return Np=i,Np}var Up,LS;function WQ(){return LS||(LS=1,Up=jQ()),Up}var Pp,QS;function yX(){if(QS)return Pp;QS=1;var r=Pd();function e(t,n){var i=[];return r(t,function(a,s,o){n(a,s,o)&&i.push(a)}),i}return Pp=e,Pp}var Rp,NS;function mX(){if(NS)return Rp;NS=1;var r="__lodash_hash_undefined__";function e(t){return this.__data__.set(t,r),this}return Rp=e,Rp}var Dp,US;function wX(){if(US)return Dp;US=1;function r(e){return this.__data__.has(e)}return Dp=r,Dp}var Hp,PS;function qQ(){if(PS)return Hp;PS=1;var r=UB(),e=mX(),t=wX();function n(i){var a=-1,s=i==null?0:i.length;for(this.__data__=new r;++a<s;)this.add(i[a])}return n.prototype.add=n.prototype.push=e,n.prototype.has=t,Hp=n,Hp}var Gp,RS;function BX(){if(RS)return Gp;RS=1;function r(e,t){for(var n=-1,i=e==null?0:e.length;++n<i;)if(t(e[n],n,e))return!0;return!1}return Gp=r,Gp}var Kp,DS;function $Q(){if(DS)return Kp;DS=1;function r(e,t){return e.has(t)}return Kp=r,Kp}var zp,HS;function YQ(){if(HS)return zp;HS=1;var r=qQ(),e=BX(),t=$Q(),n=1,i=2;function a(s,o,A,l,c,u){var h=A&n,d=s.length,f=o.length;if(d!=f&&!(h&&f>d))return!1;var g=u.get(s),v=u.get(o);if(g&&v)return g==o&&v==s;var p=-1,y=!0,m=A&i?new r:void 0;for(u.set(s,o),u.set(o,s);++p<d;){var B=s[p],C=o[p];if(l)var S=h?l(C,B,p,o,s,u):l(B,C,p,s,o,u);if(S!==void 0){if(S)continue;y=!1;break}if(m){if(!e(o,function(F,T){if(!t(m,T)&&(B===F||c(B,F,A,l,u)))return m.push(T)})){y=!1;break}}else if(!(B===C||c(B,C,A,l,u))){y=!1;break}}return u.delete(s),u.delete(o),y}return zp=a,zp}var Vp,GS;function bX(){if(GS)return Vp;GS=1;function r(e){var t=-1,n=Array(e.size);return e.forEach(function(i,a){n[++t]=[a,i]}),n}return Vp=r,Vp}var jp,KS;function qB(){if(KS)return jp;KS=1;function r(e){var t=-1,n=Array(e.size);return e.forEach(function(i){n[++t]=i}),n}return jp=r,jp}var Wp,zS;function EX(){if(zS)return Wp;zS=1;var r=nA(),e=DQ(),t=tA(),n=YQ(),i=bX(),a=qB(),s=1,o=2,A="[object Boolean]",l="[object Date]",c="[object Error]",u="[object Map]",h="[object Number]",d="[object RegExp]",f="[object Set]",g="[object String]",v="[object Symbol]",p="[object ArrayBuffer]",y="[object DataView]",m=r?r.prototype:void 0,B=m?m.valueOf:void 0;function C(S,F,T,O,_,k,L){switch(T){case y:if(S.byteLength!=F.byteLength||S.byteOffset!=F.byteOffset)return!1;S=S.buffer,F=F.buffer;case p:return!(S.byteLength!=F.byteLength||!k(new e(S),new e(F)));case A:case l:case h:return t(+S,+F);case c:return S.name==F.name&&S.message==F.message;case d:case g:return S==F+"";case u:var U=i;case f:var G=O&s;if(U||(U=a),S.size!=F.size&&!G)return!1;var W=L.get(S);if(W)return W==F;O|=o,L.set(S,F);var V=n(U(S),U(F),O,_,k,L);return L.delete(S),V;case v:if(B)return B.call(S)==B.call(F)}return!1}return Wp=C,Wp}var qp,VS;function xX(){if(VS)return qp;VS=1;var r=PQ(),e=1,t=Object.prototype,n=t.hasOwnProperty;function i(a,s,o,A,l,c){var u=o&e,h=r(a),d=h.length,f=r(s),g=f.length;if(d!=g&&!u)return!1;for(var v=d;v--;){var p=h[v];if(!(u?p in s:n.call(s,p)))return!1}var y=c.get(a),m=c.get(s);if(y&&m)return y==s&&m==a;var B=!0;c.set(a,s),c.set(s,a);for(var C=u;++v<d;){p=h[v];var S=a[p],F=s[p];if(A)var T=u?A(F,S,p,s,a,c):A(S,F,p,a,s,c);if(!(T===void 0?S===F||l(S,F,o,A,c):T)){B=!1;break}C||(C=p=="constructor")}if(B&&!C){var O=a.constructor,_=s.constructor;O!=_&&"constructor"in a&&"constructor"in s&&!(typeof O=="function"&&O instanceof O&&typeof _=="function"&&_ instanceof _)&&(B=!1)}return c.delete(a),c.delete(s),B}return qp=i,qp}var $p,jS;function CX(){if(jS)return $p;jS=1;var r=_d(),e=YQ(),t=EX(),n=xX(),i=iA(),a=Bn(),s=rA(),o=ql(),A=1,l="[object Arguments]",c="[object Array]",u="[object Object]",h=Object.prototype,d=h.hasOwnProperty;function f(g,v,p,y,m,B){var C=a(g),S=a(v),F=C?c:i(g),T=S?c:i(v);F=F==l?u:F,T=T==l?u:T;var O=F==u,_=T==u,k=F==T;if(k&&s(g)){if(!s(v))return!1;C=!0,O=!1}if(k&&!O)return B||(B=new r),C||o(g)?e(g,v,p,y,m,B):t(g,v,F,p,y,m,B);if(!(p&A)){var L=O&&d.call(g,"__wrapped__"),U=_&&d.call(v,"__wrapped__");if(L||U){var G=L?g.value():g,W=U?v.value():v;return B||(B=new r),m(G,W,p,y,B)}}return k?(B||(B=new r),n(g,v,p,y,m,B)):!1}return $p=f,$p}var Yp,WS;function XQ(){if(WS)return Yp;WS=1;var r=CX(),e=Zi();function t(n,i,a,s,o){return n===i?!0:n==null||i==null||!e(n)&&!e(i)?n!==n&&i!==i:r(n,i,a,s,t,o)}return Yp=t,Yp}var Xp,qS;function SX(){if(qS)return Xp;qS=1;var r=_d(),e=XQ(),t=1,n=2;function i(a,s,o,A){var l=o.length,c=l,u=!A;if(a==null)return!c;for(a=Object(a);l--;){var h=o[l];if(u&&h[2]?h[1]!==a[h[0]]:!(h[0]in a))return!1}for(;++l<c;){h=o[l];var d=h[0],f=a[d],g=h[1];if(u&&h[2]){if(f===void 0&&!(d in a))return!1}else{var v=new r;if(A)var p=A(f,g,d,a,s,v);if(!(p===void 0?e(g,f,t|n,A,v):p))return!1}}return!0}return Xp=i,Xp}var Zp,$S;function ZQ(){if($S)return Zp;$S=1;var r=si();function e(t){return t===t&&!r(t)}return Zp=e,Zp}var Jp,YS;function FX(){if(YS)return Jp;YS=1;var r=ZQ(),e=As();function t(n){for(var i=e(n),a=i.length;a--;){var s=i[a],o=n[s];i[a]=[s,o,r(o)]}return i}return Jp=t,Jp}var e0,XS;function JQ(){if(XS)return e0;XS=1;function r(e,t){return function(n){return n==null?!1:n[e]===t&&(t!==void 0||e in Object(n))}}return e0=r,e0}var t0,ZS;function TX(){if(ZS)return t0;ZS=1;var r=SX(),e=FX(),t=JQ();function n(i){var a=e(i);return a.length==1&&a[0][2]?t(a[0][0],a[0][1]):function(s){return s===i||r(s,i,a)}}return t0=n,t0}var n0,JS;function aA(){if(JS)return n0;JS=1;var r=no(),e=Zi(),t="[object Symbol]";function n(i){return typeof i=="symbol"||e(i)&&r(i)==t}return n0=n,n0}var r0,eF;function $B(){if(eF)return r0;eF=1;var r=Bn(),e=aA(),t=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,n=/^\w*$/;function i(a,s){if(r(a))return!1;var o=typeof a;return o=="number"||o=="symbol"||o=="boolean"||a==null||e(a)?!0:n.test(a)||!t.test(a)||s!=null&&a in Object(s)}return r0=i,r0}var i0,tF;function MX(){if(tF)return i0;tF=1;var r=UB(),e="Expected a function";function t(n,i){if(typeof n!="function"||i!=null&&typeof i!="function")throw new TypeError(e);var a=function(){var s=arguments,o=i?i.apply(this,s):s[0],A=a.cache;if(A.has(o))return A.get(o);var l=n.apply(this,s);return a.cache=A.set(o,l)||A,l};return a.cache=new(t.Cache||r),a}return t.Cache=r,i0=t,i0}var a0,nF;function OX(){if(nF)return a0;nF=1;var r=MX(),e=500;function t(n){var i=r(n,function(s){return a.size===e&&a.clear(),s}),a=i.cache;return i}return a0=t,a0}var s0,rF;function _X(){if(rF)return s0;rF=1;var r=OX(),e=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,t=/\\(\\)?/g,n=r(function(i){var a=[];return i.charCodeAt(0)===46&&a.push(""),i.replace(e,function(s,o,A,l){a.push(A?l.replace(t,"$1"):o||s)}),a});return s0=n,s0}var o0,iF;function Rd(){if(iF)return o0;iF=1;function r(e,t){for(var n=-1,i=e==null?0:e.length,a=Array(i);++n<i;)a[n]=t(e[n],n,e);return a}return o0=r,o0}var A0,aF;function IX(){if(aF)return A0;aF=1;var r=nA(),e=Rd(),t=Bn(),n=aA(),i=r?r.prototype:void 0,a=i?i.toString:void 0;function s(o){if(typeof o=="string")return o;if(t(o))return e(o,s)+"";if(n(o))return a?a.call(o):"";var A=o+"";return A=="0"&&1/o==-1/0?"-0":A}return A0=s,A0}var l0,sF;function eN(){if(sF)return l0;sF=1;var r=IX();function e(t){return t==null?"":r(t)}return l0=e,l0}var c0,oF;function Dd(){if(oF)return c0;oF=1;var r=Bn(),e=$B(),t=_X(),n=eN();function i(a,s){return r(a)?a:e(a,s)?[a]:t(n(a))}return c0=i,c0}var u0,AF;function $l(){if(AF)return u0;AF=1;var r=aA();function e(t){if(typeof t=="string"||r(t))return t;var n=t+"";return n=="0"&&1/t==-1/0?"-0":n}return u0=e,u0}var h0,lF;function Hd(){if(lF)return h0;lF=1;var r=Dd(),e=$l();function t(n,i){i=r(i,n);for(var a=0,s=i.length;n!=null&&a<s;)n=n[e(i[a++])];return a&&a==s?n:void 0}return h0=t,h0}var d0,cF;function kX(){if(cF)return d0;cF=1;var r=Hd();function e(t,n,i){var a=t==null?void 0:r(t,n);return a===void 0?i:a}return d0=e,d0}var f0,uF;function LX(){if(uF)return f0;uF=1;function r(e,t){return e!=null&&t in Object(e)}return f0=r,f0}var g0,hF;function tN(){if(hF)return g0;hF=1;var r=Dd(),e=Wl(),t=Bn(),n=Ld(),i=RB(),a=$l();function s(o,A,l){A=r(A,o);for(var c=-1,u=A.length,h=!1;++c<u;){var d=a(A[c]);if(!(h=o!=null&&l(o,d)))break;o=o[d]}return h||++c!=u?h:(u=o==null?0:o.length,!!u&&i(u)&&n(d,u)&&(t(o)||e(o)))}return g0=s,g0}var v0,dF;function nN(){if(dF)return v0;dF=1;var r=LX(),e=tN();function t(n,i){return n!=null&&e(n,i,r)}return v0=t,v0}var p0,fF;function QX(){if(fF)return p0;fF=1;var r=XQ(),e=kX(),t=nN(),n=$B(),i=ZQ(),a=JQ(),s=$l(),o=1,A=2;function l(c,u){return n(c)&&i(u)?a(s(c),u):function(h){var d=e(h,c);return d===void 0&&d===u?t(h,c):r(u,d,o|A)}}return p0=l,p0}var y0,gF;function rN(){if(gF)return y0;gF=1;function r(e){return function(t){return t==null?void 0:t[e]}}return y0=r,y0}var m0,vF;function NX(){if(vF)return m0;vF=1;var r=Hd();function e(t){return function(n){return r(n,t)}}return m0=e,m0}var w0,pF;function UX(){if(pF)return w0;pF=1;var r=rN(),e=NX(),t=$B(),n=$l();function i(a){return t(a)?r(n(a)):e(a)}return w0=i,w0}var B0,yF;function Ba(){if(yF)return B0;yF=1;var r=TX(),e=QX(),t=ao(),n=Bn(),i=UX();function a(s){return typeof s=="function"?s:s==null?t:typeof s=="object"?n(s)?e(s[0],s[1]):r(s):i(s)}return B0=a,B0}var b0,mF;function iN(){if(mF)return b0;mF=1;var r=LQ(),e=yX(),t=Ba(),n=Bn();function i(a,s){var o=n(a)?r:e;return o(a,t(s,3))}return b0=i,b0}var E0,wF;function PX(){if(wF)return E0;wF=1;var r=Object.prototype,e=r.hasOwnProperty;function t(n,i){return n!=null&&e.call(n,i)}return E0=t,E0}var x0,BF;function aN(){if(BF)return x0;BF=1;var r=PX(),e=tN();function t(n,i){return n!=null&&e(n,i,r)}return x0=t,x0}var C0,bF;function RX(){if(bF)return C0;bF=1;var r=HB(),e=iA(),t=Wl(),n=Bn(),i=wa(),a=rA(),s=Nd(),o=ql(),A="[object Map]",l="[object Set]",c=Object.prototype,u=c.hasOwnProperty;function h(d){if(d==null)return!0;if(i(d)&&(n(d)||typeof d=="string"||typeof d.splice=="function"||a(d)||o(d)||t(d)))return!d.length;var f=e(d);if(f==A||f==l)return!d.size;if(s(d))return!r(d).length;for(var g in d)if(u.call(d,g))return!1;return!0}return C0=h,C0}var S0,EF;function sN(){if(EF)return S0;EF=1;function r(e){return e===void 0}return S0=r,S0}var F0,xF;function oN(){if(xF)return F0;xF=1;var r=Pd(),e=wa();function t(n,i){var a=-1,s=e(n)?Array(n.length):[];return r(n,function(o,A,l){s[++a]=i(o,A,l)}),s}return F0=t,F0}var T0,CF;function AN(){if(CF)return T0;CF=1;var r=Rd(),e=Ba(),t=oN(),n=Bn();function i(a,s){var o=n(a)?r:t;return o(a,e(s,3))}return T0=i,T0}var M0,SF;function DX(){if(SF)return M0;SF=1;function r(e,t,n,i){var a=-1,s=e==null?0:e.length;for(i&&s&&(n=e[++a]);++a<s;)n=t(n,e[a],a,e);return n}return M0=r,M0}var O0,FF;function HX(){if(FF)return O0;FF=1;function r(e,t,n,i,a){return a(e,function(s,o,A){n=i?(i=!1,s):t(n,s,o,A)}),n}return O0=r,O0}var _0,TF;function lN(){if(TF)return _0;TF=1;var r=DX(),e=Pd(),t=Ba(),n=HX(),i=Bn();function a(s,o,A){var l=i(s)?r:n,c=arguments.length<3;return l(s,t(o,4),A,c,e)}return _0=a,_0}var I0,MF;function GX(){if(MF)return I0;MF=1;var r=no(),e=Bn(),t=Zi(),n="[object String]";function i(a){return typeof a=="string"||!e(a)&&t(a)&&r(a)==n}return I0=i,I0}var k0,OF;function KX(){if(OF)return k0;OF=1;var r=rN(),e=r("length");return k0=e,k0}var L0,_F;function zX(){if(_F)return L0;_F=1;var r="\\ud800-\\udfff",e="\\u0300-\\u036f",t="\\ufe20-\\ufe2f",n="\\u20d0-\\u20ff",i=e+t+n,a="\\ufe0e\\ufe0f",s="\\u200d",o=RegExp("["+s+r+i+a+"]");function A(l){return o.test(l)}return L0=A,L0}var Q0,IF;function VX(){if(IF)return Q0;IF=1;var r="\\ud800-\\udfff",e="\\u0300-\\u036f",t="\\ufe20-\\ufe2f",n="\\u20d0-\\u20ff",i=e+t+n,a="\\ufe0e\\ufe0f",s="["+r+"]",o="["+i+"]",A="\\ud83c[\\udffb-\\udfff]",l="(?:"+o+"|"+A+")",c="[^"+r+"]",u="(?:\\ud83c[\\udde6-\\uddff]){2}",h="[\\ud800-\\udbff][\\udc00-\\udfff]",d="\\u200d",f=l+"?",g="["+a+"]?",v="(?:"+d+"(?:"+[c,u,h].join("|")+")"+g+f+")*",p=g+f+v,y="(?:"+[c+o+"?",o,u,h,s].join("|")+")",m=RegExp(A+"(?="+A+")|"+y+p,"g");function B(C){for(var S=m.lastIndex=0;m.test(C);)++S;return S}return Q0=B,Q0}var N0,kF;function jX(){if(kF)return N0;kF=1;var r=KX(),e=zX(),t=VX();function n(i){return e(i)?t(i):r(i)}return N0=n,N0}var U0,LF;function WX(){if(LF)return U0;LF=1;var r=HB(),e=iA(),t=wa(),n=GX(),i=jX(),a="[object Map]",s="[object Set]";function o(A){if(A==null)return 0;if(t(A))return n(A)?i(A):A.length;var l=e(A);return l==a||l==s?A.size:r(A).length}return U0=o,U0}var P0,QF;function qX(){if(QF)return P0;QF=1;var r=PB(),e=GQ(),t=WB(),n=Ba(),i=Ud(),a=Bn(),s=rA(),o=Vl(),A=si(),l=ql();function c(u,h,d){var f=a(u),g=f||s(u)||l(u);if(h=n(h,4),d==null){var v=u&&u.constructor;g?d=f?new v:[]:A(u)?d=o(v)?e(i(u)):{}:d={}}return(g?r:t)(u,function(p,y,m){return h(d,p,y,m)}),d}return P0=c,P0}var R0,NF;function $X(){if(NF)return R0;NF=1;var r=nA(),e=Wl(),t=Bn(),n=r?r.isConcatSpreadable:void 0;function i(a){return t(a)||e(a)||!!(n&&a&&a[n])}return R0=i,R0}var D0,UF;function YB(){if(UF)return D0;UF=1;var r=KB(),e=$X();function t(n,i,a,s,o){var A=-1,l=n.length;for(a||(a=e),o||(o=[]);++A<l;){var c=n[A];i>0&&a(c)?i>1?t(c,i-1,a,s,o):r(o,c):s||(o[o.length]=c)}return o}return D0=t,D0}var H0,PF;function YX(){if(PF)return H0;PF=1;function r(e,t,n){switch(n.length){case 0:return e.call(t);case 1:return e.call(t,n[0]);case 2:return e.call(t,n[0],n[1]);case 3:return e.call(t,n[0],n[1],n[2])}return e.apply(t,n)}return H0=r,H0}var G0,RF;function cN(){if(RF)return G0;RF=1;var r=YX(),e=Math.max;function t(n,i,a){return i=e(i===void 0?n.length-1:i,0),function(){for(var s=arguments,o=-1,A=e(s.length-i,0),l=Array(A);++o<A;)l[o]=s[i+o];o=-1;for(var c=Array(i+1);++o<i;)c[o]=s[o];return c[i]=a(l),r(n,this,c)}}return G0=t,G0}var K0,DF;function XX(){if(DF)return K0;DF=1;var r=VB(),e=MQ(),t=ao(),n=e?function(i,a){return e(i,"toString",{configurable:!0,enumerable:!1,value:r(a),writable:!0})}:t;return K0=n,K0}var z0,HF;function ZX(){if(HF)return z0;HF=1;var r=800,e=16,t=Date.now;function n(i){var a=0,s=0;return function(){var o=t(),A=e-(o-s);if(s=o,A>0){if(++a>=r)return arguments[0]}else a=0;return i.apply(void 0,arguments)}}return z0=n,z0}var V0,GF;function uN(){if(GF)return V0;GF=1;var r=XX(),e=ZX(),t=e(r);return V0=t,V0}var j0,KF;function Gd(){if(KF)return j0;KF=1;var r=ao(),e=cN(),t=uN();function n(i,a){return t(e(i,a,r),i+"")}return j0=n,j0}var W0,zF;function hN(){if(zF)return W0;zF=1;function r(e,t,n,i){for(var a=e.length,s=n+(i?1:-1);i?s--:++s<a;)if(t(e[s],s,e))return s;return-1}return W0=r,W0}var q0,VF;function JX(){if(VF)return q0;VF=1;function r(e){return e!==e}return q0=r,q0}var $0,jF;function eZ(){if(jF)return $0;jF=1;function r(e,t,n){for(var i=n-1,a=e.length;++i<a;)if(e[i]===t)return i;return-1}return $0=r,$0}var Y0,WF;function tZ(){if(WF)return Y0;WF=1;var r=hN(),e=JX(),t=eZ();function n(i,a,s){return a===a?t(i,a,s):r(i,e,s)}return Y0=n,Y0}var X0,qF;function nZ(){if(qF)return X0;qF=1;var r=tZ();function e(t,n){var i=t==null?0:t.length;return!!i&&r(t,n,0)>-1}return X0=e,X0}var Z0,$F;function rZ(){if($F)return Z0;$F=1;function r(e,t,n){for(var i=-1,a=e==null?0:e.length;++i<a;)if(n(t,e[i]))return!0;return!1}return Z0=r,Z0}var J0,YF;function iZ(){if(YF)return J0;YF=1;function r(){}return J0=r,J0}var ey,XF;function aZ(){if(XF)return ey;XF=1;var r=RQ(),e=iZ(),t=qB(),n=1/0,i=r&&1/t(new r([,-0]))[1]==n?function(a){return new r(a)}:e;return ey=i,ey}var ty,ZF;function sZ(){if(ZF)return ty;ZF=1;var r=qQ(),e=nZ(),t=rZ(),n=$Q(),i=aZ(),a=qB(),s=200;function o(A,l,c){var u=-1,h=e,d=A.length,f=!0,g=[],v=g;if(c)f=!1,h=t;else if(d>=s){var p=l?null:i(A);if(p)return a(p);f=!1,h=n,v=new r}else v=l?[]:g;e:for(;++u<d;){var y=A[u],m=l?l(y):y;if(y=c||y!==0?y:0,f&&m===m){for(var B=v.length;B--;)if(v[B]===m)continue e;l&&v.push(m),g.push(y)}else h(v,m,c)||(v!==g&&v.push(m),g.push(y))}return g}return ty=o,ty}var ny,JF;function dN(){if(JF)return ny;JF=1;var r=wa(),e=Zi();function t(n){return e(n)&&r(n)}return ny=t,ny}var ry,eT;function oZ(){if(eT)return ry;eT=1;var r=YB(),e=Gd(),t=sZ(),n=dN(),i=e(function(a){return t(r(a,1,n,!0))});return ry=i,ry}var iy,tT;function AZ(){if(tT)return iy;tT=1;var r=Rd();function e(t,n){return r(n,function(i){return t[i]})}return iy=e,iy}var ay,nT;function fN(){if(nT)return ay;nT=1;var r=AZ(),e=As();function t(n){return n==null?[]:r(n,e(n))}return ay=t,ay}var sy,rT;function oi(){if(rT)return sy;rT=1;var r;if(typeof H1=="function")try{r={clone:gX(),constant:VB(),each:WQ(),filter:iN(),has:aN(),isArray:Bn(),isEmpty:RX(),isFunction:Vl(),isUndefined:sN(),keys:As(),map:AN(),reduce:lN(),size:WX(),transform:qX(),union:oZ(),values:fN()}}catch{}return r||(r=window._),sy=r,sy}var oy,iT;function XB(){if(iT)return oy;iT=1;var r=oi();oy=i;var e="\0",t="\0",n="";function i(c){this._isDirected=r.has(c,"directed")?c.directed:!0,this._isMultigraph=r.has(c,"multigraph")?c.multigraph:!1,this._isCompound=r.has(c,"compound")?c.compound:!1,this._label=void 0,this._defaultNodeLabelFn=r.constant(void 0),this._defaultEdgeLabelFn=r.constant(void 0),this._nodes={},this._isCompound&&(this._parent={},this._children={},this._children[t]={}),this._in={},this._preds={},this._out={},this._sucs={},this._edgeObjs={},this._edgeLabels={}}i.prototype._nodeCount=0,i.prototype._edgeCount=0,i.prototype.isDirected=function(){return this._isDirected},i.prototype.isMultigraph=function(){return this._isMultigraph},i.prototype.isCompound=function(){return this._isCompound},i.prototype.setGraph=function(c){return this._label=c,this},i.prototype.graph=function(){return this._label},i.prototype.setDefaultNodeLabel=function(c){return r.isFunction(c)||(c=r.constant(c)),this._defaultNodeLabelFn=c,this},i.prototype.nodeCount=function(){return this._nodeCount},i.prototype.nodes=function(){return r.keys(this._nodes)},i.prototype.sources=function(){var c=this;return r.filter(this.nodes(),function(u){return r.isEmpty(c._in[u])})},i.prototype.sinks=function(){var c=this;return r.filter(this.nodes(),function(u){return r.isEmpty(c._out[u])})},i.prototype.setNodes=function(c,u){var h=arguments,d=this;return r.each(c,function(f){h.length>1?d.setNode(f,u):d.setNode(f)}),this},i.prototype.setNode=function(c,u){return r.has(this._nodes,c)?(arguments.length>1&&(this._nodes[c]=u),this):(this._nodes[c]=arguments.length>1?u:this._defaultNodeLabelFn(c),this._isCompound&&(this._parent[c]=t,this._children[c]={},this._children[t][c]=!0),this._in[c]={},this._preds[c]={},this._out[c]={},this._sucs[c]={},++this._nodeCount,this)},i.prototype.node=function(c){return this._nodes[c]},i.prototype.hasNode=function(c){return r.has(this._nodes,c)},i.prototype.removeNode=function(c){var u=this;if(r.has(this._nodes,c)){var h=function(d){u.removeEdge(u._edgeObjs[d])};delete this._nodes[c],this._isCompound&&(this._removeFromParentsChildList(c),delete this._parent[c],r.each(this.children(c),function(d){u.setParent(d)}),delete this._children[c]),r.each(r.keys(this._in[c]),h),delete this._in[c],delete this._preds[c],r.each(r.keys(this._out[c]),h),delete this._out[c],delete this._sucs[c],--this._nodeCount}return this},i.prototype.setParent=function(c,u){if(!this._isCompound)throw new Error("Cannot set parent in a non-compound graph");if(r.isUndefined(u))u=t;else{u+="";for(var h=u;!r.isUndefined(h);h=this.parent(h))if(h===c)throw new Error("Setting "+u+" as parent of "+c+" would create a cycle");this.setNode(u)}return this.setNode(c),this._removeFromParentsChildList(c),this._parent[c]=u,this._children[u][c]=!0,this},i.prototype._removeFromParentsChildList=function(c){delete this._children[this._parent[c]][c]},i.prototype.parent=function(c){if(this._isCompound){var u=this._parent[c];if(u!==t)return u}},i.prototype.children=function(c){if(r.isUndefined(c)&&(c=t),this._isCompound){var u=this._children[c];if(u)return r.keys(u)}else{if(c===t)return this.nodes();if(this.hasNode(c))return[]}},i.prototype.predecessors=function(c){var u=this._preds[c];if(u)return r.keys(u)},i.prototype.successors=function(c){var u=this._sucs[c];if(u)return r.keys(u)},i.prototype.neighbors=function(c){var u=this.predecessors(c);if(u)return r.union(u,this.successors(c))},i.prototype.isLeaf=function(c){var u;return this.isDirected()?u=this.successors(c):u=this.neighbors(c),u.length===0},i.prototype.filterNodes=function(c){var u=new this.constructor({directed:this._isDirected,multigraph:this._isMultigraph,compound:this._isCompound});u.setGraph(this.graph());var h=this;r.each(this._nodes,function(g,v){c(v)&&u.setNode(v,g)}),r.each(this._edgeObjs,function(g){u.hasNode(g.v)&&u.hasNode(g.w)&&u.setEdge(g,h.edge(g))});var d={};function f(g){var v=h.parent(g);return v===void 0||u.hasNode(v)?(d[g]=v,v):v in d?d[v]:f(v)}return this._isCompound&&r.each(u.nodes(),function(g){u.setParent(g,f(g))}),u},i.prototype.setDefaultEdgeLabel=function(c){return r.isFunction(c)||(c=r.constant(c)),this._defaultEdgeLabelFn=c,this},i.prototype.edgeCount=function(){return this._edgeCount},i.prototype.edges=function(){return r.values(this._edgeObjs)},i.prototype.setPath=function(c,u){var h=this,d=arguments;return r.reduce(c,function(f,g){return d.length>1?h.setEdge(f,g,u):h.setEdge(f,g),g}),this},i.prototype.setEdge=function(){var c,u,h,d,f=!1,g=arguments[0];typeof g=="object"&&g!==null&&"v"in g?(c=g.v,u=g.w,h=g.name,arguments.length===2&&(d=arguments[1],f=!0)):(c=g,u=arguments[1],h=arguments[3],arguments.length>2&&(d=arguments[2],f=!0)),c=""+c,u=""+u,r.isUndefined(h)||(h=""+h);var v=o(this._isDirected,c,u,h);if(r.has(this._edgeLabels,v))return f&&(this._edgeLabels[v]=d),this;if(!r.isUndefined(h)&&!this._isMultigraph)throw new Error("Cannot set a named edge when isMultigraph = false");this.setNode(c),this.setNode(u),this._edgeLabels[v]=f?d:this._defaultEdgeLabelFn(c,u,h);var p=A(this._isDirected,c,u,h);return c=p.v,u=p.w,Object.freeze(p),this._edgeObjs[v]=p,a(this._preds[u],c),a(this._sucs[c],u),this._in[u][v]=p,this._out[c][v]=p,this._edgeCount++,this},i.prototype.edge=function(c,u,h){var d=arguments.length===1?l(this._isDirected,arguments[0]):o(this._isDirected,c,u,h);return this._edgeLabels[d]},i.prototype.hasEdge=function(c,u,h){var d=arguments.length===1?l(this._isDirected,arguments[0]):o(this._isDirected,c,u,h);return r.has(this._edgeLabels,d)},i.prototype.removeEdge=function(c,u,h){var d=arguments.length===1?l(this._isDirected,arguments[0]):o(this._isDirected,c,u,h),f=this._edgeObjs[d];return f&&(c=f.v,u=f.w,delete this._edgeLabels[d],delete this._edgeObjs[d],s(this._preds[u],c),s(this._sucs[c],u),delete this._in[u][d],delete this._out[c][d],this._edgeCount--),this},i.prototype.inEdges=function(c,u){var h=this._in[c];if(h){var d=r.values(h);return u?r.filter(d,function(f){return f.v===u}):d}},i.prototype.outEdges=function(c,u){var h=this._out[c];if(h){var d=r.values(h);return u?r.filter(d,function(f){return f.w===u}):d}},i.prototype.nodeEdges=function(c,u){var h=this.inEdges(c,u);if(h)return h.concat(this.outEdges(c,u))};function a(c,u){c[u]?c[u]++:c[u]=1}function s(c,u){--c[u]||delete c[u]}function o(c,u,h,d){var f=""+u,g=""+h;if(!c&&f>g){var v=f;f=g,g=v}return f+n+g+n+(r.isUndefined(d)?e:d)}function A(c,u,h,d){var f=""+u,g=""+h;if(!c&&f>g){var v=f;f=g,g=v}var p={v:f,w:g};return d&&(p.name=d),p}function l(c,u){return o(c,u.v,u.w,u.name)}return oy}var Ay,aT;function lZ(){return aT||(aT=1,Ay="2.1.8"),Ay}var ly,sT;function cZ(){return sT||(sT=1,ly={Graph:XB(),version:lZ()}),ly}var cy,oT;function uZ(){if(oT)return cy;oT=1;var r=oi(),e=XB();cy={write:t,read:a};function t(s){var o={options:{directed:s.isDirected(),multigraph:s.isMultigraph(),compound:s.isCompound()},nodes:n(s),edges:i(s)};return r.isUndefined(s.graph())||(o.value=r.clone(s.graph())),o}function n(s){return r.map(s.nodes(),function(o){var A=s.node(o),l=s.parent(o),c={v:o};return r.isUndefined(A)||(c.value=A),r.isUndefined(l)||(c.parent=l),c})}function i(s){return r.map(s.edges(),function(o){var A=s.edge(o),l={v:o.v,w:o.w};return r.isUndefined(o.name)||(l.name=o.name),r.isUndefined(A)||(l.value=A),l})}function a(s){var o=new e(s.options).setGraph(s.value);return r.each(s.nodes,function(A){o.setNode(A.v,A.value),A.parent&&o.setParent(A.v,A.parent)}),r.each(s.edges,function(A){o.setEdge({v:A.v,w:A.w,name:A.name},A.value)}),o}return cy}var uy,AT;function hZ(){if(AT)return uy;AT=1;var r=oi();uy=e;function e(t){var n={},i=[],a;function s(o){r.has(n,o)||(n[o]=!0,a.push(o),r.each(t.successors(o),s),r.each(t.predecessors(o),s))}return r.each(t.nodes(),function(o){a=[],s(o),a.length&&i.push(a)}),i}return uy}var hy,lT;function gN(){if(lT)return hy;lT=1;var r=oi();hy=e;function e(){this._arr=[],this._keyIndices={}}return e.prototype.size=function(){return this._arr.length},e.prototype.keys=function(){return this._arr.map(function(t){return t.key})},e.prototype.has=function(t){return r.has(this._keyIndices,t)},e.prototype.priority=function(t){var n=this._keyIndices[t];if(n!==void 0)return this._arr[n].priority},e.prototype.min=function(){if(this.size()===0)throw new Error("Queue underflow");return this._arr[0].key},e.prototype.add=function(t,n){var i=this._keyIndices;if(t=String(t),!r.has(i,t)){var a=this._arr,s=a.length;return i[t]=s,a.push({key:t,priority:n}),this._decrease(s),!0}return!1},e.prototype.removeMin=function(){this._swap(0,this._arr.length-1);var t=this._arr.pop();return delete this._keyIndices[t.key],this._heapify(0),t.key},e.prototype.decrease=function(t,n){var i=this._keyIndices[t];if(n>this._arr[i].priority)throw new Error("New priority is greater than current priority. Key: "+t+" Old: "+this._arr[i].priority+" New: "+n);this._arr[i].priority=n,this._decrease(i)},e.prototype._heapify=function(t){var n=this._arr,i=2*t,a=i+1,s=t;i<n.length&&(s=n[i].priority<n[s].priority?i:s,a<n.length&&(s=n[a].priority<n[s].priority?a:s),s!==t&&(this._swap(t,s),this._heapify(s)))},e.prototype._decrease=function(t){for(var n=this._arr,i=n[t].priority,a;t!==0&&(a=t>>1,!(n[a].priority<i));)this._swap(t,a),t=a},e.prototype._swap=function(t,n){var i=this._arr,a=this._keyIndices,s=i[t],o=i[n];i[t]=o,i[n]=s,a[o.key]=t,a[s.key]=n},hy}var dy,cT;function vN(){if(cT)return dy;cT=1;var r=oi(),e=gN();dy=n;var t=r.constant(1);function n(a,s,o,A){return i(a,String(s),o||t,A||function(l){return a.outEdges(l)})}function i(a,s,o,A){var l={},c=new e,u,h,d=function(f){var g=f.v!==u?f.v:f.w,v=l[g],p=o(f),y=h.distance+p;if(p<0)throw new Error("dijkstra does not allow negative edge weights. Bad edge: "+f+" Weight: "+p);y<v.distance&&(v.distance=y,v.predecessor=u,c.decrease(g,y))};for(a.nodes().forEach(function(f){var g=f===s?0:Number.POSITIVE_INFINITY;l[f]={distance:g},c.add(f,g)});c.size()>0&&(u=c.removeMin(),h=l[u],h.distance!==Number.POSITIVE_INFINITY);)A(u).forEach(d);return l}return dy}var fy,uT;function dZ(){if(uT)return fy;uT=1;var r=vN(),e=oi();fy=t;function t(n,i,a){return e.transform(n.nodes(),function(s,o){s[o]=r(n,o,i,a)},{})}return fy}var gy,hT;function pN(){if(hT)return gy;hT=1;var r=oi();gy=e;function e(t){var n=0,i=[],a={},s=[];function o(A){var l=a[A]={onStack:!0,lowlink:n,index:n++};if(i.push(A),t.successors(A).forEach(function(h){r.has(a,h)?a[h].onStack&&(l.lowlink=Math.min(l.lowlink,a[h].index)):(o(h),l.lowlink=Math.min(l.lowlink,a[h].lowlink))}),l.lowlink===l.index){var c=[],u;do u=i.pop(),a[u].onStack=!1,c.push(u);while(A!==u);s.push(c)}}return t.nodes().forEach(function(A){r.has(a,A)||o(A)}),s}return gy}var vy,dT;function fZ(){if(dT)return vy;dT=1;var r=oi(),e=pN();vy=t;function t(n){return r.filter(e(n),function(i){return i.length>1||i.length===1&&n.hasEdge(i[0],i[0])})}return vy}var py,fT;function gZ(){if(fT)return py;fT=1;var r=oi();py=t;var e=r.constant(1);function t(i,a,s){return n(i,a||e,s||function(o){return i.outEdges(o)})}function n(i,a,s){var o={},A=i.nodes();return A.forEach(function(l){o[l]={},o[l][l]={distance:0},A.forEach(function(c){l!==c&&(o[l][c]={distance:Number.POSITIVE_INFINITY})}),s(l).forEach(function(c){var u=c.v===l?c.w:c.v,h=a(c);o[l][u]={distance:h,predecessor:l}})}),A.forEach(function(l){var c=o[l];A.forEach(function(u){var h=o[u];A.forEach(function(d){var f=h[l],g=c[d],v=h[d],p=f.distance+g.distance;p<v.distance&&(v.distance=p,v.predecessor=g.predecessor)})})}),o}return py}var yy,gT;function yN(){if(gT)return yy;gT=1;var r=oi();yy=e,e.CycleException=t;function e(n){var i={},a={},s=[];function o(A){if(r.has(a,A))throw new t;r.has(i,A)||(a[A]=!0,i[A]=!0,r.each(n.predecessors(A),o),delete a[A],s.push(A))}if(r.each(n.sinks(),o),r.size(i)!==n.nodeCount())throw new t;return s}function t(){}return t.prototype=new Error,yy}var my,vT;function vZ(){if(vT)return my;vT=1;var r=yN();my=e;function e(t){try{r(t)}catch(n){if(n instanceof r.CycleException)return!1;throw n}return!0}return my}var wy,pT;function mN(){if(pT)return wy;pT=1;var r=oi();wy=e;function e(n,i,a){r.isArray(i)||(i=[i]);var s=(n.isDirected()?n.successors:n.neighbors).bind(n),o=[],A={};return r.each(i,function(l){if(!n.hasNode(l))throw new Error("Graph does not have node: "+l);t(n,l,a==="post",A,s,o)}),o}function t(n,i,a,s,o,A){r.has(s,i)||(s[i]=!0,a||A.push(i),r.each(o(i),function(l){t(n,l,a,s,o,A)}),a&&A.push(i))}return wy}var By,yT;function pZ(){if(yT)return By;yT=1;var r=mN();By=e;function e(t,n){return r(t,n,"post")}return By}var by,mT;function yZ(){if(mT)return by;mT=1;var r=mN();by=e;function e(t,n){return r(t,n,"pre")}return by}var Ey,wT;function mZ(){if(wT)return Ey;wT=1;var r=oi(),e=XB(),t=gN();Ey=n;function n(i,a){var s=new e,o={},A=new t,l;function c(h){var d=h.v===l?h.w:h.v,f=A.priority(d);if(f!==void 0){var g=a(h);g<f&&(o[d]=l,A.decrease(d,g))}}if(i.nodeCount()===0)return s;r.each(i.nodes(),function(h){A.add(h,Number.POSITIVE_INFINITY),s.setNode(h)}),A.decrease(i.nodes()[0],0);for(var u=!1;A.size()>0;){if(l=A.removeMin(),r.has(o,l))s.setEdge(l,o[l]);else{if(u)throw new Error("Input graph is not connected: "+i);u=!0}i.nodeEdges(l).forEach(c)}return s}return Ey}var xy,BT;function wZ(){return BT||(BT=1,xy={components:hZ(),dijkstra:vN(),dijkstraAll:dZ(),findCycles:fZ(),floydWarshall:gZ(),isAcyclic:vZ(),postorder:pZ(),preorder:yZ(),prim:mZ(),tarjan:pN(),topsort:yN()}),xy}var Cy,bT;function BZ(){if(bT)return Cy;bT=1;var r=cZ();return Cy={Graph:r.Graph,json:uZ(),alg:wZ(),version:r.version},Cy}var Sy,ET;function bi(){if(ET)return Sy;ET=1;var r;if(typeof H1=="function")try{r=BZ()}catch{}return r||(r=window.graphlib),Sy=r,Sy}var Fy,xT;function bZ(){if(xT)return Fy;xT=1;var r=zQ(),e=1,t=4;function n(i){return r(i,e|t)}return Fy=n,Fy}var Ty,CT;function Kd(){if(CT)return Ty;CT=1;var r=tA(),e=wa(),t=Ld(),n=si();function i(a,s,o){if(!n(o))return!1;var A=typeof s;return(A=="number"?e(o)&&t(s,o.length):A=="string"&&s in o)?r(o[s],a):!1}return Ty=i,Ty}var My,ST;function EZ(){if(ST)return My;ST=1;var r=Gd(),e=tA(),t=Kd(),n=io(),i=Object.prototype,a=i.hasOwnProperty,s=r(function(o,A){o=Object(o);var l=-1,c=A.length,u=c>2?A[2]:void 0;for(u&&t(A[0],A[1],u)&&(c=1);++l<c;)for(var h=A[l],d=n(h),f=-1,g=d.length;++f<g;){var v=d[f],p=o[v];(p===void 0||e(p,i[v])&&!a.call(o,v))&&(o[v]=h[v])}return o});return My=s,My}var Oy,FT;function xZ(){if(FT)return Oy;FT=1;var r=Ba(),e=wa(),t=As();function n(i){return function(a,s,o){var A=Object(a);if(!e(a)){var l=r(s,3);a=t(a),s=function(u){return l(A[u],u,A)}}var c=i(a,s,o);return c>-1?A[l?a[c]:c]:void 0}}return Oy=n,Oy}var _y,TT;function CZ(){if(TT)return _y;TT=1;var r=/\s/;function e(t){for(var n=t.length;n--&&r.test(t.charAt(n)););return n}return _y=e,_y}var Iy,MT;function SZ(){if(MT)return Iy;MT=1;var r=CZ(),e=/^\s+/;function t(n){return n&&n.slice(0,r(n)+1).replace(e,"")}return Iy=t,Iy}var ky,OT;function FZ(){if(OT)return ky;OT=1;var r=SZ(),e=si(),t=aA(),n=NaN,i=/^[-+]0x[0-9a-f]+$/i,a=/^0b[01]+$/i,s=/^0o[0-7]+$/i,o=parseInt;function A(l){if(typeof l=="number")return l;if(t(l))return n;if(e(l)){var c=typeof l.valueOf=="function"?l.valueOf():l;l=e(c)?c+"":c}if(typeof l!="string")return l===0?l:+l;l=r(l);var u=a.test(l);return u||s.test(l)?o(l.slice(2),u?2:8):i.test(l)?n:+l}return ky=A,ky}var Ly,_T;function wN(){if(_T)return Ly;_T=1;var r=FZ(),e=1/0,t=17976931348623157e292;function n(i){if(!i)return i===0?i:0;if(i=r(i),i===e||i===-e){var a=i<0?-1:1;return a*t}return i===i?i:0}return Ly=n,Ly}var Qy,IT;function TZ(){if(IT)return Qy;IT=1;var r=wN();function e(t){var n=r(t),i=n%1;return n===n?i?n-i:n:0}return Qy=e,Qy}var Ny,kT;function MZ(){if(kT)return Ny;kT=1;var r=hN(),e=Ba(),t=TZ(),n=Math.max;function i(a,s,o){var A=a==null?0:a.length;if(!A)return-1;var l=o==null?0:t(o);return l<0&&(l=n(A+l,0)),r(a,e(s,3),l)}return Ny=i,Ny}var Uy,LT;function OZ(){if(LT)return Uy;LT=1;var r=xZ(),e=MZ(),t=r(e);return Uy=t,Uy}var Py,QT;function BN(){if(QT)return Py;QT=1;var r=YB();function e(t){var n=t==null?0:t.length;return n?r(t,1):[]}return Py=e,Py}var Ry,NT;function _Z(){if(NT)return Ry;NT=1;var r=jB(),e=VQ(),t=io();function n(i,a){return i==null?i:r(i,e(a),t)}return Ry=n,Ry}var Dy,UT;function IZ(){if(UT)return Dy;UT=1;function r(e){var t=e==null?0:e.length;return t?e[t-1]:void 0}return Dy=r,Dy}var Hy,PT;function kZ(){if(PT)return Hy;PT=1;var r=Id(),e=WB(),t=Ba();function n(i,a){var s={};return a=t(a,3),e(i,function(o,A,l){r(s,A,a(o,A,l))}),s}return Hy=n,Hy}var Gy,RT;function ZB(){if(RT)return Gy;RT=1;var r=aA();function e(t,n,i){for(var a=-1,s=t.length;++a<s;){var o=t[a],A=n(o);if(A!=null&&(l===void 0?A===A&&!r(A):i(A,l)))var l=A,c=o}return c}return Gy=e,Gy}var Ky,DT;function LZ(){if(DT)return Ky;DT=1;function r(e,t){return e>t}return Ky=r,Ky}var zy,HT;function QZ(){if(HT)return zy;HT=1;var r=ZB(),e=LZ(),t=ao();function n(i){return i&&i.length?r(i,t,e):void 0}return zy=n,zy}var Vy,GT;function bN(){if(GT)return Vy;GT=1;var r=Id(),e=tA();function t(n,i,a){(a!==void 0&&!e(n[i],a)||a===void 0&&!(i in n))&&r(n,i,a)}return Vy=t,Vy}var jy,KT;function NZ(){if(KT)return jy;KT=1;var r=no(),e=Ud(),t=Zi(),n="[object Object]",i=Function.prototype,a=Object.prototype,s=i.toString,o=a.hasOwnProperty,A=s.call(Object);function l(c){if(!t(c)||r(c)!=n)return!1;var u=e(c);if(u===null)return!0;var h=o.call(u,"constructor")&&u.constructor;return typeof h=="function"&&h instanceof h&&s.call(h)==A}return jy=l,jy}var Wy,zT;function EN(){if(zT)return Wy;zT=1;function r(e,t){if(!(t==="constructor"&&typeof e[t]=="function")&&t!="__proto__")return e[t]}return Wy=r,Wy}var qy,VT;function UZ(){if(VT)return qy;VT=1;var r=jl(),e=io();function t(n){return r(n,e(n))}return qy=t,qy}var $y,jT;function PZ(){if(jT)return $y;jT=1;var r=bN(),e=IQ(),t=HQ(),n=kQ(),i=KQ(),a=Wl(),s=Bn(),o=dN(),A=rA(),l=Vl(),c=si(),u=NZ(),h=ql(),d=EN(),f=UZ();function g(v,p,y,m,B,C,S){var F=d(v,y),T=d(p,y),O=S.get(T);if(O){r(v,y,O);return}var _=C?C(F,T,y+"",v,p,S):void 0,k=_===void 0;if(k){var L=s(T),U=!L&&A(T),G=!L&&!U&&h(T);_=T,L||U||G?s(F)?_=F:o(F)?_=n(F):U?(k=!1,_=e(T,!0)):G?(k=!1,_=t(T,!0)):_=[]:u(T)||a(T)?(_=F,a(F)?_=f(F):(!c(F)||l(F))&&(_=i(T))):k=!1}k&&(S.set(T,_),B(_,T,m,C,S),S.delete(T)),r(v,y,_)}return $y=g,$y}var Yy,WT;function RZ(){if(WT)return Yy;WT=1;var r=_d(),e=bN(),t=jB(),n=PZ(),i=si(),a=io(),s=EN();function o(A,l,c,u,h){A!==l&&t(l,function(d,f){if(h||(h=new r),i(d))n(A,l,f,c,o,u,h);else{var g=u?u(s(A,f),d,f+"",A,l,h):void 0;g===void 0&&(g=d),e(A,f,g)}},a)}return Yy=o,Yy}var Xy,qT;function DZ(){if(qT)return Xy;qT=1;var r=Gd(),e=Kd();function t(n){return r(function(i,a){var s=-1,o=a.length,A=o>1?a[o-1]:void 0,l=o>2?a[2]:void 0;for(A=n.length>3&&typeof A=="function"?(o--,A):void 0,l&&e(a[0],a[1],l)&&(A=o<3?void 0:A,o=1),i=Object(i);++s<o;){var c=a[s];c&&n(i,c,s,A)}return i})}return Xy=t,Xy}var Zy,$T;function HZ(){if($T)return Zy;$T=1;var r=RZ(),e=DZ(),t=e(function(n,i,a){r(n,i,a)});return Zy=t,Zy}var Jy,YT;function xN(){if(YT)return Jy;YT=1;function r(e,t){return e<t}return Jy=r,Jy}var em,XT;function GZ(){if(XT)return em;XT=1;var r=ZB(),e=xN(),t=ao();function n(i){return i&&i.length?r(i,t,e):void 0}return em=n,em}var tm,ZT;function KZ(){if(ZT)return tm;ZT=1;var r=ZB(),e=Ba(),t=xN();function n(i,a){return i&&i.length?r(i,e(a,2),t):void 0}return tm=n,tm}var nm,JT;function zZ(){if(JT)return nm;JT=1;var r=Ci(),e=function(){return r.Date.now()};return nm=e,nm}var rm,eM;function VZ(){if(eM)return rm;eM=1;var r=kd(),e=Dd(),t=Ld(),n=si(),i=$l();function a(s,o,A,l){if(!n(s))return s;o=e(o,s);for(var c=-1,u=o.length,h=u-1,d=s;d!=null&&++c<u;){var f=i(o[c]),g=A;if(f==="__proto__"||f==="constructor"||f==="prototype")return s;if(c!=h){var v=d[f];g=l?l(v,f,d):void 0,g===void 0&&(g=n(v)?v:t(o[c+1])?[]:{})}r(d,f,g),d=d[f]}return s}return rm=a,rm}var im,tM;function jZ(){if(tM)return im;tM=1;var r=Hd(),e=VZ(),t=Dd();function n(i,a,s){for(var o=-1,A=a.length,l={};++o<A;){var c=a[o],u=r(i,c);s(u,c)&&e(l,t(c,i),u)}return l}return im=n,im}var am,nM;function WZ(){if(nM)return am;nM=1;var r=jZ(),e=nN();function t(n,i){return r(n,i,function(a,s){return e(n,s)})}return am=t,am}var sm,rM;function qZ(){if(rM)return sm;rM=1;var r=BN(),e=cN(),t=uN();function n(i){return t(e(i,void 0,r),i+"")}return sm=n,sm}var om,iM;function $Z(){if(iM)return om;iM=1;var r=WZ(),e=qZ(),t=e(function(n,i){return n==null?{}:r(n,i)});return om=t,om}var Am,aM;function YZ(){if(aM)return Am;aM=1;var r=Math.ceil,e=Math.max;function t(n,i,a,s){for(var o=-1,A=e(r((i-n)/(a||1)),0),l=Array(A);A--;)l[s?A:++o]=n,n+=a;return l}return Am=t,Am}var lm,sM;function XZ(){if(sM)return lm;sM=1;var r=YZ(),e=Kd(),t=wN();function n(i){return function(a,s,o){return o&&typeof o!="number"&&e(a,s,o)&&(s=o=void 0),a=t(a),s===void 0?(s=a,a=0):s=t(s),o=o===void 0?a<s?1:-1:t(o),r(a,s,o,i)}}return lm=n,lm}var cm,oM;function ZZ(){if(oM)return cm;oM=1;var r=XZ(),e=r();return cm=e,cm}var um,AM;function JZ(){if(AM)return um;AM=1;function r(e,t){var n=e.length;for(e.sort(t);n--;)e[n]=e[n].value;return e}return um=r,um}var hm,lM;function eJ(){if(lM)return hm;lM=1;var r=aA();function e(t,n){if(t!==n){var i=t!==void 0,a=t===null,s=t===t,o=r(t),A=n!==void 0,l=n===null,c=n===n,u=r(n);if(!l&&!u&&!o&&t>n||o&&A&&c&&!l&&!u||a&&A&&c||!i&&c||!s)return 1;if(!a&&!o&&!u&&t<n||u&&i&&s&&!a&&!o||l&&i&&s||!A&&s||!c)return-1}return 0}return hm=e,hm}var dm,cM;function tJ(){if(cM)return dm;cM=1;var r=eJ();function e(t,n,i){for(var a=-1,s=t.criteria,o=n.criteria,A=s.length,l=i.length;++a<A;){var c=r(s[a],o[a]);if(c){if(a>=l)return c;var u=i[a];return c*(u=="desc"?-1:1)}}return t.index-n.index}return dm=e,dm}var fm,uM;function nJ(){if(uM)return fm;uM=1;var r=Rd(),e=Hd(),t=Ba(),n=oN(),i=JZ(),a=Qd(),s=tJ(),o=ao(),A=Bn();function l(c,u,h){u.length?u=r(u,function(g){return A(g)?function(v){return e(v,g.length===1?g[0]:g)}:g}):u=[o];var d=-1;u=r(u,a(t));var f=n(c,function(g,v,p){var y=r(u,function(m){return m(g)});return{criteria:y,index:++d,value:g}});return i(f,function(g,v){return s(g,v,h)})}return fm=l,fm}var gm,hM;function rJ(){if(hM)return gm;hM=1;var r=YB(),e=nJ(),t=Gd(),n=Kd(),i=t(function(a,s){if(a==null)return[];var o=s.length;return o>1&&n(a,s[0],s[1])?s=[]:o>2&&n(s[0],s[1],s[2])&&(s=[s[0]]),e(a,r(s,1),[])});return gm=i,gm}var vm,dM;function iJ(){if(dM)return vm;dM=1;var r=eN(),e=0;function t(n){var i=++e;return r(n)+i}return vm=t,vm}var pm,fM;function aJ(){if(fM)return pm;fM=1;function r(e,t,n){for(var i=-1,a=e.length,s=t.length,o={};++i<a;){var A=i<s?t[i]:void 0;n(o,e[i],A)}return o}return pm=r,pm}var ym,gM;function sJ(){if(gM)return ym;gM=1;var r=kd(),e=aJ();function t(n,i){return e(n||[],i||[],r)}return ym=t,ym}var mm,vM;function jt(){if(vM)return mm;vM=1;var r;if(typeof H1=="function")try{r={cloneDeep:bZ(),constant:VB(),defaults:EZ(),each:WQ(),filter:iN(),find:OZ(),flatten:BN(),forEach:jQ(),forIn:_Z(),has:aN(),isUndefined:sN(),last:IZ(),map:AN(),mapValues:kZ(),max:QZ(),merge:HZ(),min:GZ(),minBy:KZ(),now:zZ(),pick:$Z(),range:ZZ(),reduce:lN(),sortBy:rJ(),uniqueId:iJ(),values:fN(),zipObject:sJ()}}catch{}return r||(r=window._),mm=r,mm}var wm,pM;function oJ(){if(pM)return wm;pM=1,wm=r;function r(){var n={};n._next=n._prev=n,this._sentinel=n}r.prototype.dequeue=function(){var n=this._sentinel,i=n._prev;if(i!==n)return e(i),i},r.prototype.enqueue=function(n){var i=this._sentinel;n._prev&&n._next&&e(n),n._next=i._next,i._next._prev=n,i._next=n,n._prev=i},r.prototype.toString=function(){for(var n=[],i=this._sentinel,a=i._prev;a!==i;)n.push(JSON.stringify(a,t)),a=a._prev;return"["+n.join(", ")+"]"};function e(n){n._prev._next=n._next,n._next._prev=n._prev,delete n._next,delete n._prev}function t(n,i){if(n!=="_next"&&n!=="_prev")return i}return wm}var Bm,yM;function AJ(){if(yM)return Bm;yM=1;var r=jt(),e=bi().Graph,t=oJ();Bm=i;var n=r.constant(1);function i(l,c){if(l.nodeCount()<=1)return[];var u=o(l,c||n),h=a(u.graph,u.buckets,u.zeroIdx);return r.flatten(r.map(h,function(d){return l.outEdges(d.v,d.w)}),!0)}function a(l,c,u){for(var h=[],d=c[c.length-1],f=c[0],g;l.nodeCount();){for(;g=f.dequeue();)s(l,c,u,g);for(;g=d.dequeue();)s(l,c,u,g);if(l.nodeCount()){for(var v=c.length-2;v>0;--v)if(g=c[v].dequeue(),g){h=h.concat(s(l,c,u,g,!0));break}}}return h}function s(l,c,u,h,d){var f=d?[]:void 0;return r.forEach(l.inEdges(h.v),function(g){var v=l.edge(g),p=l.node(g.v);d&&f.push({v:g.v,w:g.w}),p.out-=v,A(c,u,p)}),r.forEach(l.outEdges(h.v),function(g){var v=l.edge(g),p=g.w,y=l.node(p);y.in-=v,A(c,u,y)}),l.removeNode(h.v),f}function o(l,c){var u=new e,h=0,d=0;r.forEach(l.nodes(),function(v){u.setNode(v,{v,in:0,out:0})}),r.forEach(l.edges(),function(v){var p=u.edge(v.v,v.w)||0,y=c(v),m=p+y;u.setEdge(v.v,v.w,m),d=Math.max(d,u.node(v.v).out+=y),h=Math.max(h,u.node(v.w).in+=y)});var f=r.range(d+h+3).map(function(){return new t}),g=h+1;return r.forEach(u.nodes(),function(v){A(f,g,u.node(v))}),{graph:u,buckets:f,zeroIdx:g}}function A(l,c,u){u.out?u.in?l[u.out-u.in+c].enqueue(u):l[l.length-1].enqueue(u):l[0].enqueue(u)}return Bm}var bm,mM;function lJ(){if(mM)return bm;mM=1;var r=jt(),e=AJ();bm={run:t,undo:i};function t(a){var s=a.graph().acyclicer==="greedy"?e(a,o(a)):n(a);r.forEach(s,function(A){var l=a.edge(A);a.removeEdge(A),l.forwardName=A.name,l.reversed=!0,a.setEdge(A.w,A.v,l,r.uniqueId("rev"))});function o(A){return function(l){return A.edge(l).weight}}}function n(a){var s=[],o={},A={};function l(c){r.has(A,c)||(A[c]=!0,o[c]=!0,r.forEach(a.outEdges(c),function(u){r.has(o,u.w)?s.push(u):l(u.w)}),delete o[c])}return r.forEach(a.nodes(),l),s}function i(a){r.forEach(a.edges(),function(s){var o=a.edge(s);if(o.reversed){a.removeEdge(s);var A=o.forwardName;delete o.reversed,delete o.forwardName,a.setEdge(s.w,s.v,o,A)}})}return bm}var Em,wM;function Sr(){if(wM)return Em;wM=1;var r=jt(),e=bi().Graph;Em={addDummyNode:t,simplify:n,asNonCompoundGraph:i,successorWeights:a,predecessorWeights:s,intersectRect:o,buildLayerMatrix:A,normalizeRanks:l,removeEmptyRanks:c,addBorderNode:u,maxRank:h,partition:d,time:f,notime:g};function t(v,p,y,m){var B;do B=r.uniqueId(m);while(v.hasNode(B));return y.dummy=p,v.setNode(B,y),B}function n(v){var p=new e().setGraph(v.graph());return r.forEach(v.nodes(),function(y){p.setNode(y,v.node(y))}),r.forEach(v.edges(),function(y){var m=p.edge(y.v,y.w)||{weight:0,minlen:1},B=v.edge(y);p.setEdge(y.v,y.w,{weight:m.weight+B.weight,minlen:Math.max(m.minlen,B.minlen)})}),p}function i(v){var p=new e({multigraph:v.isMultigraph()}).setGraph(v.graph());return r.forEach(v.nodes(),function(y){v.children(y).length||p.setNode(y,v.node(y))}),r.forEach(v.edges(),function(y){p.setEdge(y,v.edge(y))}),p}function a(v){var p=r.map(v.nodes(),function(y){var m={};return r.forEach(v.outEdges(y),function(B){m[B.w]=(m[B.w]||0)+v.edge(B).weight}),m});return r.zipObject(v.nodes(),p)}function s(v){var p=r.map(v.nodes(),function(y){var m={};return r.forEach(v.inEdges(y),function(B){m[B.v]=(m[B.v]||0)+v.edge(B).weight}),m});return r.zipObject(v.nodes(),p)}function o(v,p){var y=v.x,m=v.y,B=p.x-y,C=p.y-m,S=v.width/2,F=v.height/2;if(!B&&!C)throw new Error("Not possible to find intersection inside of the rectangle");var T,O;return Math.abs(C)*S>Math.abs(B)*F?(C<0&&(F=-F),T=F*B/C,O=F):(B<0&&(S=-S),T=S,O=S*C/B),{x:y+T,y:m+O}}function A(v){var p=r.map(r.range(h(v)+1),function(){return[]});return r.forEach(v.nodes(),function(y){var m=v.node(y),B=m.rank;r.isUndefined(B)||(p[B][m.order]=y)}),p}function l(v){var p=r.min(r.map(v.nodes(),function(y){return v.node(y).rank}));r.forEach(v.nodes(),function(y){var m=v.node(y);r.has(m,"rank")&&(m.rank-=p)})}function c(v){var p=r.min(r.map(v.nodes(),function(C){return v.node(C).rank})),y=[];r.forEach(v.nodes(),function(C){var S=v.node(C).rank-p;y[S]||(y[S]=[]),y[S].push(C)});var m=0,B=v.graph().nodeRankFactor;r.forEach(y,function(C,S){r.isUndefined(C)&&S%B!==0?--m:m&&r.forEach(C,function(F){v.node(F).rank+=m})})}function u(v,p,y,m){var B={width:0,height:0};return arguments.length>=4&&(B.rank=y,B.order=m),t(v,"border",B,p)}function h(v){return r.max(r.map(v.nodes(),function(p){var y=v.node(p).rank;if(!r.isUndefined(y))return y}))}function d(v,p){var y={lhs:[],rhs:[]};return r.forEach(v,function(m){p(m)?y.lhs.push(m):y.rhs.push(m)}),y}function f(v,p){var y=r.now();try{return p()}finally{console.log(v+" time: "+(r.now()-y)+"ms")}}function g(v,p){return p()}return Em}var xm,BM;function cJ(){if(BM)return xm;BM=1;var r=jt(),e=Sr();xm={run:t,undo:i};function t(a){a.graph().dummyChains=[],r.forEach(a.edges(),function(s){n(a,s)})}function n(a,s){var o=s.v,A=a.node(o).rank,l=s.w,c=a.node(l).rank,u=s.name,h=a.edge(s),d=h.labelRank;if(c!==A+1){a.removeEdge(s);var f,g,v;for(v=0,++A;A<c;++v,++A)h.points=[],g={width:0,height:0,edgeLabel:h,edgeObj:s,rank:A},f=e.addDummyNode(a,"edge",g,"_d"),A===d&&(g.width=h.width,g.height=h.height,g.dummy="edge-label",g.labelpos=h.labelpos),a.setEdge(o,f,{weight:h.weight},u),v===0&&a.graph().dummyChains.push(f),o=f;a.setEdge(o,l,{weight:h.weight},u)}}function i(a){r.forEach(a.graph().dummyChains,function(s){var o=a.node(s),A=o.edgeLabel,l;for(a.setEdge(o.edgeObj,A);o.dummy;)l=a.successors(s)[0],a.removeNode(s),A.points.push({x:o.x,y:o.y}),o.dummy==="edge-label"&&(A.x=o.x,A.y=o.y,A.width=o.width,A.height=o.height),s=l,o=a.node(s)})}return xm}var Cm,bM;function Sh(){if(bM)return Cm;bM=1;var r=jt();Cm={longestPath:e,slack:t};function e(n){var i={};function a(s){var o=n.node(s);if(r.has(i,s))return o.rank;i[s]=!0;var A=r.min(r.map(n.outEdges(s),function(l){return a(l.w)-n.edge(l).minlen}));return(A===Number.POSITIVE_INFINITY||A===void 0||A===null)&&(A=0),o.rank=A}r.forEach(n.sources(),a)}function t(n,i){return n.node(i.w).rank-n.node(i.v).rank-n.edge(i).minlen}return Cm}var Sm,EM;function CN(){if(EM)return Sm;EM=1;var r=jt(),e=bi().Graph,t=Sh().slack;Sm=n;function n(o){var A=new e({directed:!1}),l=o.nodes()[0],c=o.nodeCount();A.setNode(l,{});for(var u,h;i(A,o)<c;)u=a(A,o),h=A.hasNode(u.v)?t(o,u):-t(o,u),s(A,o,h);return A}function i(o,A){function l(c){r.forEach(A.nodeEdges(c),function(u){var h=u.v,d=c===h?u.w:h;!o.hasNode(d)&&!t(A,u)&&(o.setNode(d,{}),o.setEdge(c,d,{}),l(d))})}return r.forEach(o.nodes(),l),o.nodeCount()}function a(o,A){return r.minBy(A.edges(),function(l){if(o.hasNode(l.v)!==o.hasNode(l.w))return t(A,l)})}function s(o,A,l){r.forEach(o.nodes(),function(c){A.node(c).rank+=l})}return Sm}var Fm,xM;function uJ(){if(xM)return Fm;xM=1;var r=jt(),e=CN(),t=Sh().slack,n=Sh().longestPath,i=bi().alg.preorder,a=bi().alg.postorder,s=Sr().simplify;Fm=o,o.initLowLimValues=u,o.initCutValues=A,o.calcCutValue=c,o.leaveEdge=d,o.enterEdge=f,o.exchangeEdges=g;function o(m){m=s(m),n(m);var B=e(m);u(B),A(B,m);for(var C,S;C=d(B);)S=f(B,m,C),g(B,m,C,S)}function A(m,B){var C=a(m,m.nodes());C=C.slice(0,C.length-1),r.forEach(C,function(S){l(m,B,S)})}function l(m,B,C){var S=m.node(C),F=S.parent;m.edge(C,F).cutvalue=c(m,B,C)}function c(m,B,C){var S=m.node(C),F=S.parent,T=!0,O=B.edge(C,F),_=0;return O||(T=!1,O=B.edge(F,C)),_=O.weight,r.forEach(B.nodeEdges(C),function(k){var L=k.v===C,U=L?k.w:k.v;if(U!==F){var G=L===T,W=B.edge(k).weight;if(_+=G?W:-W,p(m,C,U)){var V=m.edge(C,U).cutvalue;_+=G?-V:V}}}),_}function u(m,B){arguments.length<2&&(B=m.nodes()[0]),h(m,{},1,B)}function h(m,B,C,S,F){var T=C,O=m.node(S);return B[S]=!0,r.forEach(m.neighbors(S),function(_){r.has(B,_)||(C=h(m,B,C,_,S))}),O.low=T,O.lim=C++,F?O.parent=F:delete O.parent,C}function d(m){return r.find(m.edges(),function(B){return m.edge(B).cutvalue<0})}function f(m,B,C){var S=C.v,F=C.w;B.hasEdge(S,F)||(S=C.w,F=C.v);var T=m.node(S),O=m.node(F),_=T,k=!1;T.lim>O.lim&&(_=O,k=!0);var L=r.filter(B.edges(),function(U){return k===y(m,m.node(U.v),_)&&k!==y(m,m.node(U.w),_)});return r.minBy(L,function(U){return t(B,U)})}function g(m,B,C,S){var F=C.v,T=C.w;m.removeEdge(F,T),m.setEdge(S.v,S.w,{}),u(m),A(m,B),v(m,B)}function v(m,B){var C=r.find(m.nodes(),function(F){return!B.node(F).parent}),S=i(m,C);S=S.slice(1),r.forEach(S,function(F){var T=m.node(F).parent,O=B.edge(F,T),_=!1;O||(O=B.edge(T,F),_=!0),B.node(F).rank=B.node(T).rank+(_?O.minlen:-O.minlen)})}function p(m,B,C){return m.hasEdge(B,C)}function y(m,B,C){return C.low<=B.lim&&B.lim<=C.lim}return Fm}var Tm,CM;function hJ(){if(CM)return Tm;CM=1;var r=Sh(),e=r.longestPath,t=CN(),n=uJ();Tm=i;function i(A){switch(A.graph().ranker){case"network-simplex":o(A);break;case"tight-tree":s(A);break;case"longest-path":a(A);break;default:o(A)}}var a=e;function s(A){e(A),t(A)}function o(A){n(A)}return Tm}var Mm,SM;function dJ(){if(SM)return Mm;SM=1;var r=jt();Mm=e;function e(i){var a=n(i);r.forEach(i.graph().dummyChains,function(s){for(var o=i.node(s),A=o.edgeObj,l=t(i,a,A.v,A.w),c=l.path,u=l.lca,h=0,d=c[h],f=!0;s!==A.w;){if(o=i.node(s),f){for(;(d=c[h])!==u&&i.node(d).maxRank<o.rank;)h++;d===u&&(f=!1)}if(!f){for(;h<c.length-1&&i.node(d=c[h+1]).minRank<=o.rank;)h++;d=c[h]}i.setParent(s,d),s=i.successors(s)[0]}})}function t(i,a,s,o){var A=[],l=[],c=Math.min(a[s].low,a[o].low),u=Math.max(a[s].lim,a[o].lim),h,d;h=s;do h=i.parent(h),A.push(h);while(h&&(a[h].low>c||u>a[h].lim));for(d=h,h=o;(h=i.parent(h))!==d;)l.push(h);return{path:A.concat(l.reverse()),lca:d}}function n(i){var a={},s=0;function o(A){var l=s;r.forEach(i.children(A),o),a[A]={low:l,lim:s++}}return r.forEach(i.children(),o),a}return Mm}var Om,FM;function fJ(){if(FM)return Om;FM=1;var r=jt(),e=Sr();Om={run:t,cleanup:s};function t(o){var A=e.addDummyNode(o,"root",{},"_root"),l=i(o),c=r.max(r.values(l))-1,u=2*c+1;o.graph().nestingRoot=A,r.forEach(o.edges(),function(d){o.edge(d).minlen*=u});var h=a(o)+1;r.forEach(o.children(),function(d){n(o,A,u,h,c,l,d)}),o.graph().nodeRankFactor=u}function n(o,A,l,c,u,h,d){var f=o.children(d);if(!f.length){d!==A&&o.setEdge(A,d,{weight:0,minlen:l});return}var g=e.addBorderNode(o,"_bt"),v=e.addBorderNode(o,"_bb"),p=o.node(d);o.setParent(g,d),p.borderTop=g,o.setParent(v,d),p.borderBottom=v,r.forEach(f,function(y){n(o,A,l,c,u,h,y);var m=o.node(y),B=m.borderTop?m.borderTop:y,C=m.borderBottom?m.borderBottom:y,S=m.borderTop?c:2*c,F=B!==C?1:u-h[d]+1;o.setEdge(g,B,{weight:S,minlen:F,nestingEdge:!0}),o.setEdge(C,v,{weight:S,minlen:F,nestingEdge:!0})}),o.parent(d)||o.setEdge(A,g,{weight:0,minlen:u+h[d]})}function i(o){var A={};function l(c,u){var h=o.children(c);h&&h.length&&r.forEach(h,function(d){l(d,u+1)}),A[c]=u}return r.forEach(o.children(),function(c){l(c,1)}),A}function a(o){return r.reduce(o.edges(),function(A,l){return A+o.edge(l).weight},0)}function s(o){var A=o.graph();o.removeNode(A.nestingRoot),delete A.nestingRoot,r.forEach(o.edges(),function(l){var c=o.edge(l);c.nestingEdge&&o.removeEdge(l)})}return Om}var _m,TM;function gJ(){if(TM)return _m;TM=1;var r=jt(),e=Sr();_m=t;function t(i){function a(s){var o=i.children(s),A=i.node(s);if(o.length&&r.forEach(o,a),r.has(A,"minRank")){A.borderLeft=[],A.borderRight=[];for(var l=A.minRank,c=A.maxRank+1;l<c;++l)n(i,"borderLeft","_bl",s,A,l),n(i,"borderRight","_br",s,A,l)}}r.forEach(i.children(),a)}function n(i,a,s,o,A,l){var c={width:0,height:0,rank:l,borderType:a},u=A[a][l-1],h=e.addDummyNode(i,"border",c,s);A[a][l]=h,i.setParent(h,o),u&&i.setEdge(u,h,{weight:1})}return _m}var Im,MM;function vJ(){if(MM)return Im;MM=1;var r=jt();Im={adjust:e,undo:t};function e(l){var c=l.graph().rankdir.toLowerCase();(c==="lr"||c==="rl")&&n(l)}function t(l){var c=l.graph().rankdir.toLowerCase();(c==="bt"||c==="rl")&&a(l),(c==="lr"||c==="rl")&&(o(l),n(l))}function n(l){r.forEach(l.nodes(),function(c){i(l.node(c))}),r.forEach(l.edges(),function(c){i(l.edge(c))})}function i(l){var c=l.width;l.width=l.height,l.height=c}function a(l){r.forEach(l.nodes(),function(c){s(l.node(c))}),r.forEach(l.edges(),function(c){var u=l.edge(c);r.forEach(u.points,s),r.has(u,"y")&&s(u)})}function s(l){l.y=-l.y}function o(l){r.forEach(l.nodes(),function(c){A(l.node(c))}),r.forEach(l.edges(),function(c){var u=l.edge(c);r.forEach(u.points,A),r.has(u,"x")&&A(u)})}function A(l){var c=l.x;l.x=l.y,l.y=c}return Im}var km,OM;function pJ(){if(OM)return km;OM=1;var r=jt();km=e;function e(t){var n={},i=r.filter(t.nodes(),function(l){return!t.children(l).length}),a=r.max(r.map(i,function(l){return t.node(l).rank})),s=r.map(r.range(a+1),function(){return[]});function o(l){if(!r.has(n,l)){n[l]=!0;var c=t.node(l);s[c.rank].push(l),r.forEach(t.successors(l),o)}}var A=r.sortBy(i,function(l){return t.node(l).rank});return r.forEach(A,o),s}return km}var Lm,_M;function yJ(){if(_M)return Lm;_M=1;var r=jt();Lm=e;function e(n,i){for(var a=0,s=1;s<i.length;++s)a+=t(n,i[s-1],i[s]);return a}function t(n,i,a){for(var s=r.zipObject(a,r.map(a,function(h,d){return d})),o=r.flatten(r.map(i,function(h){return r.sortBy(r.map(n.outEdges(h),function(d){return{pos:s[d.w],weight:n.edge(d).weight}}),"pos")}),!0),A=1;A<a.length;)A<<=1;var l=2*A-1;A-=1;var c=r.map(new Array(l),function(){return 0}),u=0;return r.forEach(o.forEach(function(h){var d=h.pos+A;c[d]+=h.weight;for(var f=0;d>0;)d%2&&(f+=c[d+1]),d=d-1>>1,c[d]+=h.weight;u+=h.weight*f})),u}return Lm}var Qm,IM;function mJ(){if(IM)return Qm;IM=1;var r=jt();Qm=e;function e(t,n){return r.map(n,function(i){var a=t.inEdges(i);if(a.length){var s=r.reduce(a,function(o,A){var l=t.edge(A),c=t.node(A.v);return{sum:o.sum+l.weight*c.order,weight:o.weight+l.weight}},{sum:0,weight:0});return{v:i,barycenter:s.sum/s.weight,weight:s.weight}}else return{v:i}})}return Qm}var Nm,kM;function wJ(){if(kM)return Nm;kM=1;var r=jt();Nm=e;function e(i,a){var s={};r.forEach(i,function(A,l){var c=s[A.v]={indegree:0,in:[],out:[],vs:[A.v],i:l};r.isUndefined(A.barycenter)||(c.barycenter=A.barycenter,c.weight=A.weight)}),r.forEach(a.edges(),function(A){var l=s[A.v],c=s[A.w];!r.isUndefined(l)&&!r.isUndefined(c)&&(c.indegree++,l.out.push(s[A.w]))});var o=r.filter(s,function(A){return!A.indegree});return t(o)}function t(i){var a=[];function s(l){return function(c){c.merged||(r.isUndefined(c.barycenter)||r.isUndefined(l.barycenter)||c.barycenter>=l.barycenter)&&n(l,c)}}function o(l){return function(c){c.in.push(l),--c.indegree===0&&i.push(c)}}for(;i.length;){var A=i.pop();a.push(A),r.forEach(A.in.reverse(),s(A)),r.forEach(A.out,o(A))}return r.map(r.filter(a,function(l){return!l.merged}),function(l){return r.pick(l,["vs","i","barycenter","weight"])})}function n(i,a){var s=0,o=0;i.weight&&(s+=i.barycenter*i.weight,o+=i.weight),a.weight&&(s+=a.barycenter*a.weight,o+=a.weight),i.vs=a.vs.concat(i.vs),i.barycenter=s/o,i.weight=o,i.i=Math.min(a.i,i.i),a.merged=!0}return Nm}var Um,LM;function BJ(){if(LM)return Um;LM=1;var r=jt(),e=Sr();Um=t;function t(a,s){var o=e.partition(a,function(g){return r.has(g,"barycenter")}),A=o.lhs,l=r.sortBy(o.rhs,function(g){return-g.i}),c=[],u=0,h=0,d=0;A.sort(i(!!s)),d=n(c,l,d),r.forEach(A,function(g){d+=g.vs.length,c.push(g.vs),u+=g.barycenter*g.weight,h+=g.weight,d=n(c,l,d)});var f={vs:r.flatten(c,!0)};return h&&(f.barycenter=u/h,f.weight=h),f}function n(a,s,o){for(var A;s.length&&(A=r.last(s)).i<=o;)s.pop(),a.push(A.vs),o++;return o}function i(a){return function(s,o){return s.barycenter<o.barycenter?-1:s.barycenter>o.barycenter?1:a?o.i-s.i:s.i-o.i}}return Um}var Pm,QM;function bJ(){if(QM)return Pm;QM=1;var r=jt(),e=mJ(),t=wJ(),n=BJ();Pm=i;function i(o,A,l,c){var u=o.children(A),h=o.node(A),d=h?h.borderLeft:void 0,f=h?h.borderRight:void 0,g={};d&&(u=r.filter(u,function(C){return C!==d&&C!==f}));var v=e(o,u);r.forEach(v,function(C){if(o.children(C.v).length){var S=i(o,C.v,l,c);g[C.v]=S,r.has(S,"barycenter")&&s(C,S)}});var p=t(v,l);a(p,g);var y=n(p,c);if(d&&(y.vs=r.flatten([d,y.vs,f],!0),o.predecessors(d).length)){var m=o.node(o.predecessors(d)[0]),B=o.node(o.predecessors(f)[0]);r.has(y,"barycenter")||(y.barycenter=0,y.weight=0),y.barycenter=(y.barycenter*y.weight+m.order+B.order)/(y.weight+2),y.weight+=2}return y}function a(o,A){r.forEach(o,function(l){l.vs=r.flatten(l.vs.map(function(c){return A[c]?A[c].vs:c}),!0)})}function s(o,A){r.isUndefined(o.barycenter)?(o.barycenter=A.barycenter,o.weight=A.weight):(o.barycenter=(o.barycenter*o.weight+A.barycenter*A.weight)/(o.weight+A.weight),o.weight+=A.weight)}return Pm}var Rm,NM;function EJ(){if(NM)return Rm;NM=1;var r=jt(),e=bi().Graph;Rm=t;function t(i,a,s){var o=n(i),A=new e({compound:!0}).setGraph({root:o}).setDefaultNodeLabel(function(l){return i.node(l)});return r.forEach(i.nodes(),function(l){var c=i.node(l),u=i.parent(l);(c.rank===a||c.minRank<=a&&a<=c.maxRank)&&(A.setNode(l),A.setParent(l,u||o),r.forEach(i[s](l),function(h){var d=h.v===l?h.w:h.v,f=A.edge(d,l),g=r.isUndefined(f)?0:f.weight;A.setEdge(d,l,{weight:i.edge(h).weight+g})}),r.has(c,"minRank")&&A.setNode(l,{borderLeft:c.borderLeft[a],borderRight:c.borderRight[a]}))}),A}function n(i){for(var a;i.hasNode(a=r.uniqueId("_root")););return a}return Rm}var Dm,UM;function xJ(){if(UM)return Dm;UM=1;var r=jt();Dm=e;function e(t,n,i){var a={},s;r.forEach(i,function(o){for(var A=t.parent(o),l,c;A;){if(l=t.parent(A),l?(c=a[l],a[l]=A):(c=s,s=A),c&&c!==A){n.setEdge(c,A);return}A=l}})}return Dm}var Hm,PM;function CJ(){if(PM)return Hm;PM=1;var r=jt(),e=pJ(),t=yJ(),n=bJ(),i=EJ(),a=xJ(),s=bi().Graph,o=Sr();Hm=A;function A(h){var d=o.maxRank(h),f=l(h,r.range(1,d+1),"inEdges"),g=l(h,r.range(d-1,-1,-1),"outEdges"),v=e(h);u(h,v);for(var p=Number.POSITIVE_INFINITY,y,m=0,B=0;B<4;++m,++B){c(m%2?f:g,m%4>=2),v=o.buildLayerMatrix(h);var C=t(h,v);C<p&&(B=0,y=r.cloneDeep(v),p=C)}u(h,y)}function l(h,d,f){return r.map(d,function(g){return i(h,g,f)})}function c(h,d){var f=new s;r.forEach(h,function(g){var v=g.graph().root,p=n(g,v,f,d);r.forEach(p.vs,function(y,m){g.node(y).order=m}),a(g,f,p.vs)})}function u(h,d){r.forEach(d,function(f){r.forEach(f,function(g,v){h.node(g).order=v})})}return Hm}var Gm,RM;function SJ(){if(RM)return Gm;RM=1;var r=jt(),e=bi().Graph,t=Sr();Gm={positionX:f,findType1Conflicts:n,findType2Conflicts:i,addConflict:s,hasConflict:o,verticalAlignment:A,horizontalCompaction:l,alignCoordinates:h,findSmallestWidthAlignment:u,balance:d};function n(p,y){var m={};function B(C,S){var F=0,T=0,O=C.length,_=r.last(S);return r.forEach(S,function(k,L){var U=a(p,k),G=U?p.node(U).order:O;(U||k===_)&&(r.forEach(S.slice(T,L+1),function(W){r.forEach(p.predecessors(W),function(V){var K=p.node(V),D=K.order;(D<F||G<D)&&!(K.dummy&&p.node(W).dummy)&&s(m,V,W)})}),T=L+1,F=G)}),S}return r.reduce(y,B),m}function i(p,y){var m={};function B(S,F,T,O,_){var k;r.forEach(r.range(F,T),function(L){k=S[L],p.node(k).dummy&&r.forEach(p.predecessors(k),function(U){var G=p.node(U);G.dummy&&(G.order<O||G.order>_)&&s(m,U,k)})})}function C(S,F){var T=-1,O,_=0;return r.forEach(F,function(k,L){if(p.node(k).dummy==="border"){var U=p.predecessors(k);U.length&&(O=p.node(U[0]).order,B(F,_,L,T,O),_=L,T=O)}B(F,_,F.length,O,S.length)}),F}return r.reduce(y,C),m}function a(p,y){if(p.node(y).dummy)return r.find(p.predecessors(y),function(m){return p.node(m).dummy})}function s(p,y,m){if(y>m){var B=y;y=m,m=B}var C=p[y];C||(p[y]=C={}),C[m]=!0}function o(p,y,m){if(y>m){var B=y;y=m,m=B}return r.has(p[y],m)}function A(p,y,m,B){var C={},S={},F={};return r.forEach(y,function(T){r.forEach(T,function(O,_){C[O]=O,S[O]=O,F[O]=_})}),r.forEach(y,function(T){var O=-1;r.forEach(T,function(_){var k=B(_);if(k.length){k=r.sortBy(k,function(V){return F[V]});for(var L=(k.length-1)/2,U=Math.floor(L),G=Math.ceil(L);U<=G;++U){var W=k[U];S[_]===_&&O<F[W]&&!o(m,_,W)&&(S[W]=_,S[_]=C[_]=C[W],O=F[W])}}})}),{root:C,align:S}}function l(p,y,m,B,C){var S={},F=c(p,y,m,C),T=C?"borderLeft":"borderRight";function O(L,U){for(var G=F.nodes(),W=G.pop(),V={};W;)V[W]?L(W):(V[W]=!0,G.push(W),G=G.concat(U(W))),W=G.pop()}function _(L){S[L]=F.inEdges(L).reduce(function(U,G){return Math.max(U,S[G.v]+F.edge(G))},0)}function k(L){var U=F.outEdges(L).reduce(function(W,V){return Math.min(W,S[V.w]-F.edge(V))},Number.POSITIVE_INFINITY),G=p.node(L);U!==Number.POSITIVE_INFINITY&&G.borderType!==T&&(S[L]=Math.max(S[L],U))}return O(_,F.predecessors.bind(F)),O(k,F.successors.bind(F)),r.forEach(B,function(L){S[L]=S[m[L]]}),S}function c(p,y,m,B){var C=new e,S=p.graph(),F=g(S.nodesep,S.edgesep,B);return r.forEach(y,function(T){var O;r.forEach(T,function(_){var k=m[_];if(C.setNode(k),O){var L=m[O],U=C.edge(L,k);C.setEdge(L,k,Math.max(F(p,_,O),U||0))}O=_})}),C}function u(p,y){return r.minBy(r.values(y),function(m){var B=Number.NEGATIVE_INFINITY,C=Number.POSITIVE_INFINITY;return r.forIn(m,function(S,F){var T=v(p,F)/2;B=Math.max(S+T,B),C=Math.min(S-T,C)}),B-C})}function h(p,y){var m=r.values(y),B=r.min(m),C=r.max(m);r.forEach(["u","d"],function(S){r.forEach(["l","r"],function(F){var T=S+F,O=p[T],_;if(O!==y){var k=r.values(O);_=F==="l"?B-r.min(k):C-r.max(k),_&&(p[T]=r.mapValues(O,function(L){return L+_}))}})})}function d(p,y){return r.mapValues(p.ul,function(m,B){if(y)return p[y.toLowerCase()][B];var C=r.sortBy(r.map(p,B));return(C[1]+C[2])/2})}function f(p){var y=t.buildLayerMatrix(p),m=r.merge(n(p,y),i(p,y)),B={},C;r.forEach(["u","d"],function(F){C=F==="u"?y:r.values(y).reverse(),r.forEach(["l","r"],function(T){T==="r"&&(C=r.map(C,function(L){return r.values(L).reverse()}));var O=(F==="u"?p.predecessors:p.successors).bind(p),_=A(p,C,m,O),k=l(p,C,_.root,_.align,T==="r");T==="r"&&(k=r.mapValues(k,function(L){return-L})),B[F+T]=k})});var S=u(p,B);return h(B,S),d(B,p.graph().align)}function g(p,y,m){return function(B,C,S){var F=B.node(C),T=B.node(S),O=0,_;if(O+=F.width/2,r.has(F,"labelpos"))switch(F.labelpos.toLowerCase()){case"l":_=-F.width/2;break;case"r":_=F.width/2;break}if(_&&(O+=m?_:-_),_=0,O+=(F.dummy?y:p)/2,O+=(T.dummy?y:p)/2,O+=T.width/2,r.has(T,"labelpos"))switch(T.labelpos.toLowerCase()){case"l":_=T.width/2;break;case"r":_=-T.width/2;break}return _&&(O+=m?_:-_),_=0,O}}function v(p,y){return p.node(y).width}return Gm}var Km,DM;function FJ(){if(DM)return Km;DM=1;var r=jt(),e=Sr(),t=SJ().positionX;Km=n;function n(a){a=e.asNonCompoundGraph(a),i(a),r.forEach(t(a),function(s,o){a.node(o).x=s})}function i(a){var s=e.buildLayerMatrix(a),o=a.graph().ranksep,A=0;r.forEach(s,function(l){var c=r.max(r.map(l,function(u){return a.node(u).height}));r.forEach(l,function(u){a.node(u).y=A+c/2}),A+=c+o})}return Km}var zm,HM;function TJ(){if(HM)return zm;HM=1;var r=jt(),e=lJ(),t=cJ(),n=hJ(),i=Sr().normalizeRanks,a=dJ(),s=Sr().removeEmptyRanks,o=fJ(),A=gJ(),l=vJ(),c=CJ(),u=FJ(),h=Sr(),d=bi().Graph;zm=f;function f($,z){var ee=z&&z.debugTiming?h.time:h.notime;ee("layout",function(){var Ae=ee(" buildLayoutGraph",function(){return O($)});ee(" runLayout",function(){g(Ae,ee)}),ee(" updateInputGraph",function(){v($,Ae)})})}function g($,z){z(" makeSpaceForEdgeLabels",function(){_($)}),z(" removeSelfEdges",function(){X($)}),z(" acyclic",function(){e.run($)}),z(" nestingGraph.run",function(){o.run($)}),z(" rank",function(){n(h.asNonCompoundGraph($))}),z(" injectEdgeLabelProxies",function(){k($)}),z(" removeEmptyRanks",function(){s($)}),z(" nestingGraph.cleanup",function(){o.cleanup($)}),z(" normalizeRanks",function(){i($)}),z(" assignRankMinMax",function(){L($)}),z(" removeEdgeLabelProxies",function(){U($)}),z(" normalize.run",function(){t.run($)}),z(" parentDummyChains",function(){a($)}),z(" addBorderSegments",function(){A($)}),z(" order",function(){c($)}),z(" insertSelfEdges",function(){te($)}),z(" adjustCoordinateSystem",function(){l.adjust($)}),z(" position",function(){u($)}),z(" positionSelfEdges",function(){ie($)}),z(" removeBorderNodes",function(){D($)}),z(" normalize.undo",function(){t.undo($)}),z(" fixupEdgeLabelCoords",function(){V($)}),z(" undoCoordinateSystem",function(){l.undo($)}),z(" translateGraph",function(){G($)}),z(" assignNodeIntersects",function(){W($)}),z(" reversePoints",function(){K($)}),z(" acyclic.undo",function(){e.undo($)})}function v($,z){r.forEach($.nodes(),function(ee){var Ae=$.node(ee),be=z.node(ee);Ae&&(Ae.x=be.x,Ae.y=be.y,z.children(ee).length&&(Ae.width=be.width,Ae.height=be.height))}),r.forEach($.edges(),function(ee){var Ae=$.edge(ee),be=z.edge(ee);Ae.points=be.points,r.has(be,"x")&&(Ae.x=be.x,Ae.y=be.y)}),$.graph().width=z.graph().width,$.graph().height=z.graph().height}var p=["nodesep","edgesep","ranksep","marginx","marginy"],y={ranksep:50,edgesep:20,nodesep:50,rankdir:"tb"},m=["acyclicer","ranker","rankdir","align"],B=["width","height"],C={width:0,height:0},S=["minlen","weight","width","height","labeloffset"],F={minlen:1,weight:1,width:0,height:0,labeloffset:10,labelpos:"r"},T=["labelpos"];function O($){var z=new d({multigraph:!0,compound:!0}),ee=xe($.graph());return z.setGraph(r.merge({},y,re(ee,p),r.pick(ee,m))),r.forEach($.nodes(),function(Ae){var be=xe($.node(Ae));z.setNode(Ae,r.defaults(re(be,B),C)),z.setParent(Ae,$.parent(Ae))}),r.forEach($.edges(),function(Ae){var be=xe($.edge(Ae));z.setEdge(Ae,r.merge({},F,re(be,S),r.pick(be,T)))}),z}function _($){var z=$.graph();z.ranksep/=2,r.forEach($.edges(),function(ee){var Ae=$.edge(ee);Ae.minlen*=2,Ae.labelpos.toLowerCase()!=="c"&&(z.rankdir==="TB"||z.rankdir==="BT"?Ae.width+=Ae.labeloffset:Ae.height+=Ae.labeloffset)})}function k($){r.forEach($.edges(),function(z){var ee=$.edge(z);if(ee.width&&ee.height){var Ae=$.node(z.v),be=$.node(z.w),Le={rank:(be.rank-Ae.rank)/2+Ae.rank,e:z};h.addDummyNode($,"edge-proxy",Le,"_ep")}})}function L($){var z=0;r.forEach($.nodes(),function(ee){var Ae=$.node(ee);Ae.borderTop&&(Ae.minRank=$.node(Ae.borderTop).rank,Ae.maxRank=$.node(Ae.borderBottom).rank,z=r.max(z,Ae.maxRank))}),$.graph().maxRank=z}function U($){r.forEach($.nodes(),function(z){var ee=$.node(z);ee.dummy==="edge-proxy"&&($.edge(ee.e).labelRank=ee.rank,$.removeNode(z))})}function G($){var z=Number.POSITIVE_INFINITY,ee=0,Ae=Number.POSITIVE_INFINITY,be=0,Le=$.graph(),Ue=Le.marginx||0,at=Le.marginy||0;function lt(ct){var pt=ct.x,Ne=ct.y,ht=ct.width,nt=ct.height;z=Math.min(z,pt-ht/2),ee=Math.max(ee,pt+ht/2),Ae=Math.min(Ae,Ne-nt/2),be=Math.max(be,Ne+nt/2)}r.forEach($.nodes(),function(ct){lt($.node(ct))}),r.forEach($.edges(),function(ct){var pt=$.edge(ct);r.has(pt,"x")&<(pt)}),z-=Ue,Ae-=at,r.forEach($.nodes(),function(ct){var pt=$.node(ct);pt.x-=z,pt.y-=Ae}),r.forEach($.edges(),function(ct){var pt=$.edge(ct);r.forEach(pt.points,function(Ne){Ne.x-=z,Ne.y-=Ae}),r.has(pt,"x")&&(pt.x-=z),r.has(pt,"y")&&(pt.y-=Ae)}),Le.width=ee-z+Ue,Le.height=be-Ae+at}function W($){r.forEach($.edges(),function(z){var ee=$.edge(z),Ae=$.node(z.v),be=$.node(z.w),Le,Ue;ee.points?(Le=ee.points[0],Ue=ee.points[ee.points.length-1]):(ee.points=[],Le=be,Ue=Ae),ee.points.unshift(h.intersectRect(Ae,Le)),ee.points.push(h.intersectRect(be,Ue))})}function V($){r.forEach($.edges(),function(z){var ee=$.edge(z);if(r.has(ee,"x"))switch((ee.labelpos==="l"||ee.labelpos==="r")&&(ee.width-=ee.labeloffset),ee.labelpos){case"l":ee.x-=ee.width/2+ee.labeloffset;break;case"r":ee.x+=ee.width/2+ee.labeloffset;break}})}function K($){r.forEach($.edges(),function(z){var ee=$.edge(z);ee.reversed&&ee.points.reverse()})}function D($){r.forEach($.nodes(),function(z){if($.children(z).length){var ee=$.node(z),Ae=$.node(ee.borderTop),be=$.node(ee.borderBottom),Le=$.node(r.last(ee.borderLeft)),Ue=$.node(r.last(ee.borderRight));ee.width=Math.abs(Ue.x-Le.x),ee.height=Math.abs(be.y-Ae.y),ee.x=Le.x+ee.width/2,ee.y=Ae.y+ee.height/2}}),r.forEach($.nodes(),function(z){$.node(z).dummy==="border"&&$.removeNode(z)})}function X($){r.forEach($.edges(),function(z){if(z.v===z.w){var ee=$.node(z.v);ee.selfEdges||(ee.selfEdges=[]),ee.selfEdges.push({e:z,label:$.edge(z)}),$.removeEdge(z)}})}function te($){var z=h.buildLayerMatrix($);r.forEach(z,function(ee){var Ae=0;r.forEach(ee,function(be,Le){var Ue=$.node(be);Ue.order=Le+Ae,r.forEach(Ue.selfEdges,function(at){h.addDummyNode($,"selfedge",{width:at.label.width,height:at.label.height,rank:Ue.rank,order:Le+ ++Ae,e:at.e,label:at.label},"_se")}),delete Ue.selfEdges})})}function ie($){r.forEach($.nodes(),function(z){var ee=$.node(z);if(ee.dummy==="selfedge"){var Ae=$.node(ee.e.v),be=Ae.x+Ae.width/2,Le=Ae.y,Ue=ee.x-be,at=Ae.height/2;$.setEdge(ee.e,ee.label),$.removeNode(z),ee.label.points=[{x:be+2*Ue/3,y:Le-at},{x:be+5*Ue/6,y:Le-at},{x:be+Ue,y:Le},{x:be+5*Ue/6,y:Le+at},{x:be+2*Ue/3,y:Le+at}],ee.label.x=ee.x,ee.label.y=ee.y}})}function re($,z){return r.mapValues(r.pick($,z),Number)}function xe($){var z={};return r.forEach($,function(ee,Ae){z[Ae.toLowerCase()]=ee}),z}return zm}var Vm,GM;function MJ(){if(GM)return Vm;GM=1;var r=jt(),e=Sr(),t=bi().Graph;Vm={debugOrdering:n};function n(i){var a=e.buildLayerMatrix(i),s=new t({compound:!0,multigraph:!0}).setGraph({});return r.forEach(i.nodes(),function(o){s.setNode(o,{label:o}),s.setParent(o,"layer"+i.node(o).rank)}),r.forEach(i.edges(),function(o){s.setEdge(o.v,o.w,{},o.name)}),r.forEach(a,function(o,A){var l="layer"+A;s.setNode(l,{rank:"same"}),r.reduce(o,function(c,u){return s.setEdge(c,u,{style:"invis"}),u})}),s}return Vm}var jm,KM;function OJ(){return KM||(KM=1,jm="0.8.5"),jm}var Wm,zM;function _J(){return zM||(zM=1,Wm={graphlib:bi(),layout:TJ(),debug:MJ(),util:{time:Sr().time,notime:Sr().notime},version:OJ()}),Wm}var SN=_J();const IJ=Qh(SN);class zd{constructor(e){this.id="dagre",this.options={},Object.assign(this.options,zd.defaultOptions,e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericDagreLayout(!1,e,Object.assign(Object.assign({},this.options),t))})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericDagreLayout(!0,e,Object.assign(Object.assign({},this.options),t))})}genericDagreLayout(e,t,n){return Je(this,void 0,void 0,function*(){const{nodeSize:i}=n,a=new SN.graphlib.Graph;a.setGraph(n),a.setDefaultEdgeLabel(()=>({}));const s=t.getAllNodes(),o=t.getAllEdges();[...s,...o].some(({id:l})=>Be(l))&&console.error("Dagre layout only support string id, it will convert number to string."),t.getAllNodes().forEach(l=>{const{id:c}=l,u=Object.assign({},l.data);if(i!==void 0){const[h,d]=zl(Te(i)?i(l):i);Object.assign(u,{width:h,height:d})}a.setNode(c.toString(),u)}),t.getAllEdges().forEach(({id:l,source:c,target:u})=>{a.setEdge(c.toString(),u.toString(),{id:l})}),IJ.layout(a);const A={nodes:[],edges:[]};return a.nodes().forEach(l=>{const c=a.node(l);A.nodes.push({id:l,data:c}),e&&t.mergeNodeData(l,c)}),a.edges().forEach(l=>{const c=a.edge(l),{id:u}=c,h=Dt(c,["id"]),{v:d,w:f}=l;A.edges.push({id:u,source:d,target:f,data:h}),e&&t.mergeEdgeData(u,h)}),A})}}zd.defaultOptions={};class JB{constructor(e){this.id=e.id||0,this.rx=e.rx,this.ry=e.ry,this.fx=0,this.fy=0,this.mass=e.mass,this.degree=e.degree,this.g=e.g||0}distanceTo(e){const t=this.rx-e.rx,n=this.ry-e.ry;return Math.hypot(t,n)}setPos(e,t){this.rx=e,this.ry=t}resetForce(){this.fx=0,this.fy=0}addForce(e){const t=e.rx-this.rx,n=e.ry-this.ry;let i=Math.hypot(t,n);i=i<1e-4?1e-4:i;const a=this.g*(this.degree+1)*(e.degree+1)/i;this.fx+=a*t/i,this.fy+=a*n/i}in(e){return e.contains(this.rx,this.ry)}add(e){const t=this.mass+e.mass,n=(this.rx*this.mass+e.rx*e.mass)/t,i=(this.ry*this.mass+e.ry*e.mass)/t,a=this.degree+e.degree,s={rx:n,ry:i,mass:t,degree:a};return new JB(s)}}class _o{constructor(e){this.xmid=e.xmid,this.ymid=e.ymid,this.length=e.length,this.massCenter=e.massCenter||[0,0],this.mass=e.mass||1}getLength(){return this.length}contains(e,t){const n=this.length/2;return e<=this.xmid+n&&e>=this.xmid-n&&t<=this.ymid+n&&t>=this.ymid-n}NW(){const e=this.xmid-this.length/4,t=this.ymid+this.length/4,n=this.length/2,i={xmid:e,ymid:t,length:n};return new _o(i)}NE(){const e=this.xmid+this.length/4,t=this.ymid+this.length/4,n=this.length/2,i={xmid:e,ymid:t,length:n};return new _o(i)}SW(){const e=this.xmid-this.length/4,t=this.ymid-this.length/4,n=this.length/2,i={xmid:e,ymid:t,length:n};return new _o(i)}SE(){const e=this.xmid+this.length/4,t=this.ymid-this.length/4,n=this.length/2,i={xmid:e,ymid:t,length:n};return new _o(i)}}class Io{constructor(e){this.body=null,this.quad=null,this.NW=null,this.NE=null,this.SW=null,this.SE=null,this.theta=.5,e!=null&&(this.quad=e)}insert(e){if(this.body==null){this.body=e;return}this._isExternal()?(this.quad&&(this.NW=new Io(this.quad.NW()),this.NE=new Io(this.quad.NE()),this.SW=new Io(this.quad.SW()),this.SE=new Io(this.quad.SE())),this._putBody(this.body),this._putBody(e),this.body=this.body.add(e)):(this.body=this.body.add(e),this._putBody(e))}_putBody(e){this.quad&&(e.in(this.quad.NW())&&this.NW?this.NW.insert(e):e.in(this.quad.NE())&&this.NE?this.NE.insert(e):e.in(this.quad.SW())&&this.SW?this.SW.insert(e):e.in(this.quad.SE())&&this.SE&&this.SE.insert(e))}_isExternal(){return this.NW==null&&this.NE==null&&this.SW==null&&this.SE==null}updateForce(e){if(!(this.body==null||e===this.body))if(this._isExternal())e.addForce(this.body);else{const t=this.quad?this.quad.getLength():0,n=this.body.distanceTo(e);t/n<this.theta?e.addForce(this.body):(this.NW&&this.NW.updateForce(e),this.NE&&this.NE.updateForce(e),this.SW&&this.SW.updateForce(e),this.SE&&this.SE.updateForce(e))}}}const kJ={center:[0,0],width:300,height:300,kr:5,kg:1,mode:"normal",preventOverlap:!1,dissuadeHubs:!1,maxIteration:0,ks:.1,ksmax:10,tao:.1};class LJ{constructor(e={}){this.options=e,this.id="forceAtlas2",this.options=Object.assign(Object.assign({},kJ),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericForceAtlas2Layout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericForceAtlas2Layout(!0,e,t)})}genericForceAtlas2Layout(e,t,n){return Je(this,void 0,void 0,function*(){const i=t.getAllEdges(),a=t.getAllNodes(),s=this.formatOptions(n,a.length),{width:o,height:A,prune:l,maxIteration:c,nodeSize:u,center:h}=s;if(!(a!=null&&a.length)||a.length===1)return to(t,e,h);const d=a.map(p=>Dr(p,[o,A])),f=i.filter(p=>{const{source:y,target:m}=p;return y!==m}),g=new Mn({nodes:d,edges:f}),v=this.getSizes(g,u);if(this.run(g,t,c,v,e,s),l){for(let y=0;y<f.length;y+=1){const{source:m,target:B}=f[y],C=g.getDegree(m),S=g.getDegree(m);if(C<=1){const F=g.getNode(B);g.mergeNodeData(m,{x:F.data.x,y:F.data.y})}else if(S<=1){const F=g.getNode(m);g.mergeNodeData(B,{x:F.data.x,y:F.data.y})}}const p=Object.assign(Object.assign({},s),{prune:!1,barnesHut:!1});this.run(g,t,100,v,e,p)}return{nodes:d,edges:i}})}getSizes(e,t){const n=e.getAllNodes(),i={};for(let a=0;a<n.length;a+=1){const s=n[a];i[s.id]=kB(t,void 0)(s)}return i}formatOptions(e={},t){const n=Object.assign(Object.assign({},this.options),e),{center:i,width:a,height:s,barnesHut:o,prune:A,maxIteration:l,kr:c,kg:u}=n;return n.width=!a&&typeof window<"u"?window.innerWidth:a,n.height=!s&&typeof window<"u"?window.innerHeight:s,n.center=i||[n.width/2,n.height/2],o===void 0&&t>250&&(n.barnesHut=!0),A===void 0&&t>100&&(n.prune=!0),l===0&&!A?(n.maxIteration=250,t<=200&&t>100?n.maxIteration=1e3:t>200&&(n.maxIteration=1200)):l===0&&A&&(n.maxIteration=100,t<=200&&t>100?n.maxIteration=500:t>200&&(n.maxIteration=950)),c||(n.kr=50,t>100&&t<=500?n.kr=20:t>500&&(n.kr=1)),u||(n.kg=20,t>100&&t<=500?n.kg=10:t>500&&(n.kg=1)),n}run(e,t,n,i,a,s){const{kr:o,barnesHut:A,onTick:l}=s,c=e.getAllNodes();let u=0,h=n;const d={},f={},g={};for(let v=0;v<c.length;v+=1){const{data:p,id:y}=c[v];if(d[y]=[0,0],A){const m={id:v,rx:p.x,ry:p.y,mass:1,g:o,degree:e.getDegree(y)};g[y]=new JB(m)}}for(;h>0;)u=this.oneStep(e,{iter:h,preventOverlapIters:50,krPrime:100,sg:u,forces:d,preForces:f,bodies:g,sizes:i},s),h--,l==null||l({nodes:c,edges:t.getAllEdges()});return e}oneStep(e,t,n){const{iter:i,preventOverlapIters:a,krPrime:s,sg:o,preForces:A,bodies:l,sizes:c}=t;let{forces:u}=t;const{preventOverlap:h,barnesHut:d}=n,f=e.getAllNodes();for(let g=0;g<f.length;g+=1){const{id:v}=f[g];A[v]=[...u[v]],u[v]=[0,0]}return u=this.getAttrForces(e,i,a,c,u,n),d&&(h&&i>a||!h)?u=this.getOptRepGraForces(e,u,l,n):u=this.getRepGraForces(e,i,a,u,s,c,n),this.updatePos(e,u,A,o,n)}getAttrForces(e,t,n,i,a,s){const{preventOverlap:o,dissuadeHubs:A,mode:l,prune:c}=s,u=e.getAllEdges();for(let h=0;h<u.length;h+=1){const{source:d,target:f}=u[h],g=e.getNode(d),v=e.getNode(f),p=e.getDegree(d),y=e.getDegree(f);if(c&&(p<=1||y<=1))continue;const m=[v.data.x-g.data.x,v.data.y-g.data.y];let B=Math.hypot(m[0],m[1]);B=B<1e-4?1e-4:B,m[0]=m[0]/B,m[1]=m[1]/B,o&&t<n&&(B=B-i[d]-i[f]);let C=B,S=C;l==="linlog"&&(C=Math.log(1+B),S=C),A&&(C=B/p,S=B/y),o&&t<n&&B<=0?(C=0,S=0):o&&t<n&&B>0&&(C=B,S=B),a[d][0]+=C*m[0],a[f][0]-=S*m[0],a[d][1]+=C*m[1],a[f][1]-=S*m[1]}return a}getOptRepGraForces(e,t,n,i){const{kg:a,center:s,prune:o}=i,A=e.getAllNodes(),l=A.length;let c=9e10,u=-9e10,h=9e10,d=-9e10;for(let y=0;y<l;y+=1){const{id:m,data:B}=A[y];o&&e.getDegree(m)<=1||(n[m].setPos(B.x,B.y),B.x>=u&&(u=B.x),B.x<=c&&(c=B.x),B.y>=d&&(d=B.y),B.y<=h&&(h=B.y))}const f=Math.max(u-c,d-h),g={xmid:(u+c)/2,ymid:(d+h)/2,length:f,massCenter:s,mass:l},v=new _o(g),p=new Io(v);for(let y=0;y<l;y+=1){const{id:m}=A[y];o&&e.getDegree(m)<=1||n[m].in(v)&&p.insert(n[m])}for(let y=0;y<l;y+=1){const{id:m,data:B}=A[y],C=e.getDegree(m);if(o&&C<=1)continue;n[m].resetForce(),p.updateForce(n[m]),t[m][0]-=n[m].fx,t[m][1]-=n[m].fy;const S=[B.x-s[0],B.y-s[1]];let F=Math.hypot(S[0],S[1]);F=F<1e-4?1e-4:F,S[0]=S[0]/F,S[1]=S[1]/F;const T=a*(C+1);t[m][0]-=T*S[0],t[m][1]-=T*S[1]}return t}getRepGraForces(e,t,n,i,a,s,o){const{preventOverlap:A,kr:l,kg:c,center:u,prune:h}=o,d=e.getAllNodes(),f=d.length;for(let g=0;g<f;g+=1){const v=d[g],p=e.getDegree(v.id);for(let C=g+1;C<f;C+=1){const S=d[C],F=e.getDegree(S.id);if(h&&(p<=1||F<=1))continue;const T=[S.data.x-v.data.x,S.data.y-v.data.y];let O=Math.hypot(T[0],T[1]);O=O<1e-4?1e-4:O,T[0]=T[0]/O,T[1]=T[1]/O,A&&t<n&&(O=O-s[v.id]-s[S.id]);let _=l*(p+1)*(F+1)/O;A&&t<n&&O<0?_=a*(p+1)*(F+1):A&&t<n&&O===0?_=0:A&&t<n&&O>0&&(_=l*(p+1)*(F+1)/O),i[v.id][0]-=_*T[0],i[S.id][0]+=_*T[0],i[v.id][1]-=_*T[1],i[S.id][1]+=_*T[1]}const y=[v.data.x-u[0],v.data.y-u[1]],m=Math.hypot(y[0],y[1]);y[0]=y[0]/m,y[1]=y[1]/m;const B=c*(p+1);i[v.id][0]-=B*y[0],i[v.id][1]-=B*y[1]}return i}updatePos(e,t,n,i,a){const{ks:s,tao:o,prune:A,ksmax:l}=a,c=e.getAllNodes(),u=c.length,h=[],d=[];let f=0,g=0,v=i;for(let y=0;y<u;y+=1){const{id:m}=c[y],B=e.getDegree(m);if(A&&B<=1)continue;const C=[t[m][0]-n[m][0],t[m][1]-n[m][1]],S=Math.hypot(C[0],C[1]),F=[t[m][0]+n[m][0],t[m][1]+n[m][1]],T=Math.hypot(F[0],F[1]);h[y]=S,d[y]=T/2,f+=(B+1)*h[y],g+=(B+1)*d[y]}const p=v;v=o*g/f,p!==0&&(v=v>1.5*p?1.5*p:v);for(let y=0;y<u;y+=1){const{id:m,data:B}=c[y],C=e.getDegree(m);if(A&&C<=1||Be(B.fx)&&Be(B.fy))continue;let S=s*v/(1+v*Math.sqrt(h[y])),F=Math.hypot(t[m][0],t[m][1]);F=F<1e-4?1e-4:F;const T=l/F;S=S>T?T:S;const O=S*t[m][0],_=S*t[m][1];e.mergeNodeData(m,{x:B.x+O,y:B.y+_})}return v}}const QJ={maxIteration:1e3,gravity:10,speed:5,clustering:!1,clusterGravity:10,width:300,height:300,nodeClusterBy:"cluster"},NJ=800;class UJ{constructor(e={}){this.options=e,this.id="fruchterman",this.timeInterval=0,this.running=!1,this.options=Object.assign(Object.assign({},QJ),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericFruchtermanLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericFruchtermanLayout(!0,e,t)})}stop(){this.timeInterval&&typeof window<"u"&&window.clearInterval(this.timeInterval),this.running=!1}tick(e=this.options.maxIteration||1){if(this.lastResult)return this.lastResult;for(let n=0;n<e;n++)this.runOneStep(this.lastGraph,this.lastClusterMap,this.lastOptions);const t={nodes:this.lastLayoutNodes,edges:this.lastLayoutEdges};return this.lastAssign&&t.nodes.forEach(n=>this.lastGraph.mergeNodeData(n.id,{x:n.data.x,y:n.data.y,z:this.options.dimensions===3?n.data.z:void 0})),t}genericFruchtermanLayout(e,t,n){return Je(this,void 0,void 0,function*(){if(this.running)return;const i=this.formatOptions(n),{dimensions:a,width:s,height:o,center:A,clustering:l,nodeClusterBy:c,maxIteration:u,onTick:h}=i,d=t.getAllNodes(),f=t.getAllEdges();if(!(d!=null&&d.length)){const m={nodes:[],edges:f};return this.lastResult=m,m}if(d.length===1){e&&t.mergeNodeData(d[0].id,{x:A[0],y:A[1],z:a===3?A[2]:void 0});const m={nodes:[Object.assign(Object.assign({},d[0]),{data:Object.assign(Object.assign({},d[0].data),{x:A[0],y:A[1],z:a===3?A[2]:void 0})})],edges:f};return this.lastResult=m,m}const g=d.map(m=>Dr(m,[s,o])),v=new Mn({nodes:g,edges:f}),p={};if(l&&g.forEach(m=>{const B=m.data[c];p[B]||(p[B]={name:B,cx:0,cy:0,count:0})}),this.lastLayoutNodes=g,this.lastLayoutEdges=f,this.lastAssign=e,this.lastGraph=v,this.lastOptions=i,this.lastClusterMap=p,typeof window>"u")return;let y=0;return new Promise(m=>{this.timeInterval=window.setInterval(()=>{if(!this.running){m({nodes:g,edges:f});return}this.runOneStep(v,p,i),e&&g.forEach(({id:B,data:C})=>t.mergeNodeData(B,{x:C.x,y:C.y,z:a===3?C.z:void 0})),h==null||h({nodes:g,edges:f}),y++,y>=u&&(window.clearInterval(this.timeInterval),m({nodes:g,edges:f}))},0),this.running=!0})})}formatOptions(e={}){const t=Object.assign(Object.assign({},this.options),e),{clustering:n,nodeClusterBy:i}=t,{center:a,width:s,height:o}=t;return t.width=!s&&typeof window<"u"?window.innerWidth:s,t.height=!o&&typeof window<"u"?window.innerHeight:o,t.center=a||[t.width/2,t.height/2],t.clustering=n&&!!i,t}runOneStep(e,t,n){const{dimensions:i,height:a,width:s,gravity:o,center:A,speed:l,clustering:c,nodeClusterBy:u,clusterGravity:h}=n,d=a*s,f=Math.sqrt(d)/10,g=e.getAllNodes(),v=d/(g.length+1),p=Math.sqrt(v),y={};if(this.applyCalculate(e,y,p,v),c){for(const B in t)t[B].cx=0,t[B].cy=0,t[B].count=0;g.forEach(B=>{const{data:C}=B,S=t[C[u]];Be(C.x)&&(S.cx+=C.x),Be(C.y)&&(S.cy+=C.y),S.count++});for(const B in t)t[B].cx/=t[B].count,t[B].cy/=t[B].count;const m=h||o;g.forEach((B,C)=>{const{id:S,data:F}=B;if(!Be(F.x)||!Be(F.y))return;const T=t[F[u]],O=Math.sqrt((F.x-T.cx)*(F.x-T.cx)+(F.y-T.cy)*(F.y-T.cy)),_=p*m;y[S].x-=_*(F.x-T.cx)/O,y[S].y-=_*(F.y-T.cy)/O})}g.forEach((m,B)=>{const{id:C,data:S}=m;if(!Be(S.x)||!Be(S.y))return;const F=.01*p*o;y[C].x-=F*(S.x-A[0]),y[C].y-=F*(S.y-A[1]),i===3&&(y[C].z-=F*(S.z-A[2]))}),g.forEach((m,B)=>{const{id:C,data:S}=m;if(Be(S.fx)&&Be(S.fy)){S.x=S.fx,S.y=S.fy,i===3&&(S.z=S.fz);return}if(!Be(S.x)||!Be(S.y))return;const F=Math.sqrt(y[C].x*y[C].x+y[C].y*y[C].y+(i===3?y[C].z*y[C].z:0));if(F>0){const T=Math.min(f*(l/NJ),F);e.mergeNodeData(C,{x:S.x+y[C].x/F*T,y:S.y+y[C].y/F*T,z:i===3?S.z+y[C].z/F*T:void 0})}})}applyCalculate(e,t,n,i){this.calRepulsive(e,t,i),this.calAttractive(e,t,n)}calRepulsive(e,t,n){const i=e.getAllNodes();i.forEach(({data:a,id:s},o)=>{t[s]={x:0,y:0,z:0},i.forEach(({data:A,id:l},c)=>{if(o<=c||!Be(a.x)||!Be(A.x)||!Be(a.y)||!Be(A.y))return;let u=a.x-A.x,h=a.y-A.y,d=this.options.dimensions===3?a.z-A.z:0,f=u*u+h*h+d*d;f===0&&(f=1,u=.01,h=.01,d=.01);const g=n/f,v=u*g,p=h*g,y=d*g;t[s].x+=v,t[s].y+=p,t[l].x-=v,t[l].y-=p,this.options.dimensions===3&&(t[s].z+=y,t[l].z-=y)})})}calAttractive(e,t,n){e.getAllEdges().forEach(a=>{const{source:s,target:o}=a;if(!s||!o||s===o)return;const{data:A}=e.getNode(s),{data:l}=e.getNode(o);if(!Be(l.x)||!Be(A.x)||!Be(l.y)||!Be(A.y))return;const c=l.x-A.x,u=l.y-A.y,h=this.options.dimensions===3?l.z-A.z:0,d=Math.sqrt(c*c+u*u+h*h)/n,f=c*d,g=u*d,v=h*d;t[s].x+=f,t[s].y+=g,t[o].x-=f,t[o].y-=g,this.options.dimensions===3&&(t[s].z+=v,t[o].z-=v)})}}const PJ={begin:[0,0],preventOverlap:!0,preventOverlapPadding:10,condense:!1,rows:void 0,cols:void 0,position:void 0,sortBy:"degree",nodeSize:30,width:300,height:300};class RJ{constructor(e={}){this.options=e,this.id="grid",this.options=Object.assign(Object.assign({},PJ),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericGridLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericGridLayout(!0,e,t)})}genericGridLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},this.options),n),{begin:a=[0,0],condense:s,preventOverlapPadding:o,preventOverlap:A,rows:l,cols:c,nodeSpacing:u,nodeSize:h,width:d,height:f,position:g}=i;let{sortBy:v}=i;const p=t.getAllNodes(),y=t.getAllEdges(),m=p==null?void 0:p.length;if(!m||m===1)return to(t,e,a);const B=p.map(W=>Dr(W));v!=="id"&&(!At(v)||B[0].data[v]===void 0)&&(v="degree"),v==="degree"?B.sort((W,V)=>t.getDegree(V.id,"both")-t.getDegree(W.id,"both")):v==="id"?B.sort((W,V)=>Be(V.id)&&Be(W.id)?V.id-W.id:`${W.id}`.localeCompare(`${V.id}`)):B.sort((W,V)=>V.data[v]-W.data[v]);const C=!d&&typeof window<"u"?window.innerWidth:d,S=!f&&typeof window<"u"?window.innerHeight:f,F=m,T={rows:l,cols:c};if(l!=null&&c!=null)T.rows=l,T.cols=c;else if(l!=null&&c==null)T.rows=l,T.cols=Math.ceil(F/T.rows);else if(l==null&&c!=null)T.cols=c,T.rows=Math.ceil(F/T.cols);else{const W=Math.sqrt(F*S/C);T.rows=Math.round(W),T.cols=Math.round(C/S*W)}if(T.rows=Math.max(T.rows,1),T.cols=Math.max(T.cols,1),T.cols*T.rows>F){const W=du(T),V=fu(T);(W-1)*V>=F?du(T,W-1):(V-1)*W>=F&&fu(T,V-1)}else for(;T.cols*T.rows<F;){const W=du(T),V=fu(T);(V+1)*W>=F?fu(T,V+1):du(T,W+1)}let O=s?0:C/T.cols,_=s?0:S/T.rows;if(A||u){const W=Us(10,u),V=IB(30,h,!1);B.forEach(K=>{(!K.data.x||!K.data.y)&&(K.data.x=0,K.data.y=0);const D=t.getNode(K.id),[X,te]=zl(V(D)||30),ie=W!==void 0?W(K):o,re=X+ie,xe=te+ie;O=Math.max(O,re),_=Math.max(_,xe)})}const k={},L={row:0,col:0},U={};for(let W=0;W<B.length;W++){const V=B[W];let K;if(g&&(K=g(t.getNode(V.id))),K&&(K.row!==void 0||K.col!==void 0)){const D={row:K.row,col:K.col};if(D.col===void 0)for(D.col=0;x1(k,D);)D.col++;else if(D.row===void 0)for(D.row=0;x1(k,D);)D.row++;U[V.id]=D,FN(k,D)}DJ(V,a,O,_,U,T,L,k)}const G={nodes:B,edges:y};return e&&B.forEach(W=>{t.mergeNodeData(W.id,{x:W.data.x,y:W.data.y})}),G})}}const du=(r,e)=>{let t;const n=r.rows||5,i=r.cols||5;return e==null?t=Math.min(n,i):Math.min(n,i)===r.rows?r.rows=e:r.cols=e,t},fu=(r,e)=>{let t;const n=r.rows||5,i=r.cols||5;return e==null?t=Math.max(n,i):Math.max(n,i)===r.rows?r.rows=e:r.cols=e,t},x1=(r,e)=>r[`c-${e.row}-${e.col}`]||!1,FN=(r,e)=>r[`c-${e.row}-${e.col}`]=!0,VM=(r,e)=>{const t=r.cols||5;e.col++,e.col>=t&&(e.col=0,e.row++)},DJ=(r,e,t,n,i,a,s,o)=>{let A,l;const c=i[r.id];if(c)A=c.col*t+t/2+e[0],l=c.row*n+n/2+e[1];else{for(;x1(o,s);)VM(a,s);A=s.col*t+t/2+e[0],l=s.row*n+n/2+e[1],FN(o,s),VM(a,s)}r.data.x=A,r.data.y=l},HJ=(r,e,t)=>{try{const n=Ga.mul(Ga.pow(e,2),-.5),i=n.mean("row"),a=n.mean("column"),s=n.mean();n.add(s).subRowVector(i).subColumnVector(a);const o=new wQ(n),A=Ga.sqrt(o.diagonalMatrix).diagonal();return o.leftSingularVectors.toJSON().map(l=>Ga.mul([l],[A]).toJSON()[0].splice(0,r))}catch{const i=[];for(let a=0;a<e.length;a++){const s=Math.random()*t,o=Math.random()*t;i.push([s,o])}return i}},GJ=800,KJ={iterations:10,height:10,width:10,speed:100,gravity:10,k:5},zJ=(r,e)=>{const t=Object.assign(Object.assign({},KJ),e),{positions:n,iterations:i,width:a,k:s,speed:o=100,strictRadial:A,focusIdx:l,radii:c=[],nodeSizeFunc:u}=t,h=r.getAllNodes(),d=[],f=a/10;for(let g=0;g<i;g++)n.forEach((v,p)=>{d[p]={x:0,y:0}}),VJ(h,n,d,s,c,u),jJ(n,d,o,A,l,f,a,c);return n},VJ=(r,e,t,n,i,a)=>{e.forEach((s,o)=>{t[o]={x:0,y:0},e.forEach((A,l)=>{if(o===l||i[o]!==i[l])return;let c=s.x-A.x,u=s.y-A.y,h=Math.sqrt(c*c+u*u);if(h===0){h=1;const d=o>l?1:-1;c=.01*d,u=.01*d}if(h<a(r[o])/2+a(r[l])/2){const d=n*n/h;t[o].x+=c/h*d,t[o].y+=u/h*d}})})},jJ=(r,e,t,n,i,a,s,o)=>{const A=a||s/10;return n&&e.forEach((l,c)=>{const u=r[c].x-r[i].x,h=r[c].y-r[i].y,d=Math.sqrt(u*u+h*h);let f=h/d,g=-u/d;const v=Math.sqrt(l.x*l.x+l.y*l.y);let p=Math.acos((f*l.x+g*l.y)/v);p>Math.PI/2&&(p-=Math.PI/2,f*=-1,g*=-1);const y=Math.cos(p)*v;l.x=f*y,l.y=g*y}),r.forEach((l,c)=>{if(c===i)return;const u=Math.sqrt(e[c].x*e[c].x+e[c].y*e[c].y);if(u>0&&c!==i){const h=Math.min(A*(t/GJ),u);if(l.x+=e[c].x/u*h,l.y+=e[c].y/u*h,n){let d=l.x-r[i].x,f=l.y-r[i].y;const g=Math.sqrt(d*d+f*f);d=d/g*o[c],f=f/g*o[c],l.x=r[i].x+d,l.y=r[i].y+f}}}),r},WJ={maxIteration:1e3,focusNode:null,unitRadius:null,linkDistance:50,preventOverlap:!1,strictRadial:!0,maxPreventOverlapIteration:200,sortStrength:10};class qJ{constructor(e={}){this.options=e,this.id="radial",this.options=Object.assign(Object.assign({},WJ),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericRadialLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericRadialLayout(!0,e,t)})}genericRadialLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},this.options),n),{width:a,height:s,center:o,focusNode:A,unitRadius:l,nodeSize:c,nodeSpacing:u,strictRadial:h,preventOverlap:d,maxPreventOverlapIteration:f,sortBy:g,linkDistance:v=50,sortStrength:p=10,maxIteration:y=1e3}=i,m=t.getAllNodes(),B=t.getAllEdges(),C=!a&&typeof window<"u"?window.innerWidth:a,S=!s&&typeof window<"u"?window.innerHeight:s,F=o||[C/2,S/2];if(!(m!=null&&m.length)||m.length===1)return to(t,e,F);let T=m[0];if(At(A)){for(let Ae=0;Ae<m.length;Ae++)if(m[Ae].id===A){T=m[Ae];break}}else T=A||m[0];const O=XJ(m,T.id),_=gQ({nodes:m,edges:B}),k=fQ(_),L=JJ(k,O);ZJ(k,O,L+1);const U=k[O];let G=C-F[0]>F[0]?F[0]:C-F[0],W=S-F[1]>F[1]?F[1]:S-F[1];G===0&&(G=C/2),W===0&&(W=S/2);const V=Math.min(G,W),K=Math.max(...U),D=[],X=l||V/K;U.forEach((Ae,be)=>{D[be]=Ae*X});const te=$J(m,k,v,D,X,g,p),ie=YJ(te),re=HJ(v,te,v);let xe=re.map(([Ae,be])=>({x:(isNaN(Ae)?Math.random()*v:Ae)-re[O][0],y:(isNaN(be)?Math.random()*v:be)-re[O][1]}));this.run(y,xe,ie,te,D,O);let $;if(d){$=kB(c,u);const Ae={nodes:m,nodeSizeFunc:$,positions:xe,radii:D,height:S,width:C,strictRadial:!!h,focusIdx:O,iterations:f||200,k:xe.length/4.5};xe=zJ(t,Ae)}const z=[];return xe.forEach((Ae,be)=>{const Le=Dr(m[be]);Le.data.x=Ae.x+F[0],Le.data.y=Ae.y+F[1],z.push(Le)}),e&&z.forEach(Ae=>t.mergeNodeData(Ae.id,{x:Ae.data.x,y:Ae.data.y})),{nodes:z,edges:B}})}run(e,t,n,i,a,s){for(let o=0;o<=e;o++){const A=o/e;this.oneIteration(A,t,a,i,n,s)}}oneIteration(e,t,n,i,a,s){const o=1-e;t.forEach((A,l)=>{const c=uC(A,{x:0,y:0}),u=c===0?0:1/c;if(l===s)return;let h=0,d=0,f=0;t.forEach((v,p)=>{if(l===p)return;const y=uC(A,v),m=y===0?0:1/y,B=i[p][l];f+=a[l][p],h+=a[l][p]*(v.x+B*(A.x-v.x)*m),d+=a[l][p]*(v.y+B*(A.y-v.y)*m)});const g=n[l]===0?0:1/n[l];f*=o,f+=e*g*g,h*=o,h+=e*g*A.x*u,A.x=h/f,d*=o,d+=e*g*A.y*u,A.y=d/f})}}const $J=(r,e,t,n,i,a,s)=>{if(!r)return[];const o=[];if(e){const A={};e.forEach((l,c)=>{const u=[];l.forEach((h,d)=>{var f,g;if(c===d)u.push(0);else if(n[c]===n[d])if(a==="data")u.push(h*(Math.abs(c-d)*s)/(n[c]/i));else if(a){let v,p;if(A[r[c].id])v=A[r[c].id];else{const y=(a==="id"?r[c].id:(f=r[c].data)===null||f===void 0?void 0:f[a])||0;At(y)?v=y.charCodeAt(0):v=y,A[r[c].id]=v}if(A[r[d].id])p=A[r[d].id];else{const y=(a==="id"?r[d].id:(g=r[d].data)===null||g===void 0?void 0:g[a])||0;At(y)?p=y.charCodeAt(0):p=y,A[r[d].id]=p}u.push(h*(Math.abs(v-p)*s)/(n[c]/i))}else u.push(h*t/(n[c]/i));else{const v=(t+i)/2;u.push(h*v)}}),o.push(u)})}return o},YJ=r=>{const e=r.length,t=r[0].length,n=[];for(let i=0;i<e;i++){const a=[];for(let s=0;s<t;s++)r[i][s]!==0?a.push(1/(r[i][s]*r[i][s])):a.push(0);n.push(a)}return n},XJ=(r,e)=>{let t=-1;return r.forEach((n,i)=>{n.id===e&&(t=i)}),Math.max(t,0)},ZJ=(r,e,t)=>{const n=r.length;for(let i=0;i<n;i++)if(r[e][i]===1/0){r[e][i]=t,r[i][e]=t;for(let a=0;a<n;a++)r[i][a]!==1/0&&r[e][a]===1/0&&(r[e][a]=t+r[i][a],r[a][e]=t+r[i][a])}for(let i=0;i<n;i++)if(i!==e){for(let a=0;a<n;a++)if(r[i][a]===1/0){let s=Math.abs(r[e][i]-r[e][a]);s=s===0?1:s,r[i][a]=s}}},JJ=(r,e)=>{let t=0;for(let n=0;n<r[e].length;n++)r[e][n]!==1/0&&(t=r[e][n]>t?r[e][n]:t);return t},eee={center:[0,0],width:300,height:300};class tee{constructor(e={}){this.options=e,this.id="random",this.options=Object.assign(Object.assign({},eee),e)}execute(e,t){return Je(this,void 0,void 0,function*(){return this.genericRandomLayout(!1,e,t)})}assign(e,t){return Je(this,void 0,void 0,function*(){yield this.genericRandomLayout(!0,e,t)})}genericRandomLayout(e,t,n){return Je(this,void 0,void 0,function*(){const i=Object.assign(Object.assign({},this.options),n),{center:a,width:s,height:o}=i,A=t.getAllNodes(),l=.9,c=!s&&typeof window<"u"?window.innerWidth:s,u=!o&&typeof window<"u"?window.innerHeight:o,h=a||[c/2,u/2],d=[];return A&&A.forEach(g=>{d.push({id:g.id,data:{x:(Math.random()-.5)*l*c+h[0],y:(Math.random()-.5)*l*u+h[1]}})}),e&&d.forEach(g=>t.mergeNodeData(g.id,{x:g.data.x,y:g.data.y})),{nodes:d,edges:t.getAllEdges()}})}}const TN=Symbol("Comlink.proxy"),nee=Symbol("Comlink.endpoint"),MN=Symbol("Comlink.releaseProxy"),qm=Symbol("Comlink.finalizer"),Qu=Symbol("Comlink.thrown"),ON=r=>typeof r=="object"&&r!==null||typeof r=="function",ree={canHandle:r=>ON(r)&&r[TN],serialize(r){const{port1:e,port2:t}=new MessageChannel;return IN(r,e),[t,[t]]},deserialize(r){return r.start(),LN(r)}},iee={canHandle:r=>ON(r)&&Qu in r,serialize({value:r}){let e;return r instanceof Error?e={isError:!0,value:{message:r.message,name:r.name,stack:r.stack}}:e={isError:!1,value:r},[e,[]]},deserialize(r){throw r.isError?Object.assign(new Error(r.value.message),r.value):r.value}},_N=new Map([["proxy",ree],["throw",iee]]);function aee(r,e){for(const t of r)if(e===t||t==="*"||t instanceof RegExp&&t.test(e))return!0;return!1}function IN(r,e=globalThis,t=["*"]){e.addEventListener("message",function n(i){if(!i||!i.data)return;if(!aee(t,i.origin)){console.warn(`Invalid origin '${i.origin}' for comlink proxy`);return}const{id:a,type:s,path:o}=Object.assign({path:[]},i.data),A=(i.data.argumentList||[]).map(xs);let l;try{const c=o.slice(0,-1).reduce((h,d)=>h[d],r),u=o.reduce((h,d)=>h[d],r);switch(s){case"GET":l=u;break;case"SET":c[o.slice(-1)[0]]=xs(i.data.value),l=!0;break;case"APPLY":l=u.apply(c,A);break;case"CONSTRUCT":{const h=new u(...A);l=uee(h)}break;case"ENDPOINT":{const{port1:h,port2:d}=new MessageChannel;IN(r,d),l=cee(h,[h])}break;case"RELEASE":l=void 0;break;default:return}}catch(c){l={value:c,[Qu]:0}}Promise.resolve(l).catch(c=>({value:c,[Qu]:0})).then(c=>{const[u,h]=Mh(c);e.postMessage(Object.assign(Object.assign({},u),{id:a}),h),s==="RELEASE"&&(e.removeEventListener("message",n),kN(e),qm in r&&typeof r[qm]=="function"&&r[qm]())}).catch(c=>{const[u,h]=Mh({value:new TypeError("Unserializable return value"),[Qu]:0});e.postMessage(Object.assign(Object.assign({},u),{id:a}),h)})}),e.start&&e.start()}function see(r){return r.constructor.name==="MessagePort"}function kN(r){see(r)&&r.close()}function LN(r,e){const t=new Map;return r.addEventListener("message",function(i){const{data:a}=i;if(!a||!a.id)return;const s=t.get(a.id);if(s)try{s(a)}finally{t.delete(a.id)}}),C1(r,t,[],e)}function gu(r){if(r)throw new Error("Proxy has been released and is not useable")}function QN(r){return To(r,new Map,{type:"RELEASE"}).then(()=>{kN(r)})}const Fh=new WeakMap,Th="FinalizationRegistry"in globalThis&&new FinalizationRegistry(r=>{const e=(Fh.get(r)||0)-1;Fh.set(r,e),e===0&&QN(r)});function oee(r,e){const t=(Fh.get(e)||0)+1;Fh.set(e,t),Th&&Th.register(r,e,r)}function Aee(r){Th&&Th.unregister(r)}function C1(r,e,t=[],n=function(){}){let i=!1;const a=new Proxy(n,{get(s,o){if(gu(i),o===MN)return()=>{Aee(a),QN(r),e.clear(),i=!0};if(o==="then"){if(t.length===0)return{then:()=>a};const A=To(r,e,{type:"GET",path:t.map(l=>l.toString())}).then(xs);return A.then.bind(A)}return C1(r,e,[...t,o])},set(s,o,A){gu(i);const[l,c]=Mh(A);return To(r,e,{type:"SET",path:[...t,o].map(u=>u.toString()),value:l},c).then(xs)},apply(s,o,A){gu(i);const l=t[t.length-1];if(l===nee)return To(r,e,{type:"ENDPOINT"}).then(xs);if(l==="bind")return C1(r,e,t.slice(0,-1));const[c,u]=jM(A);return To(r,e,{type:"APPLY",path:t.map(h=>h.toString()),argumentList:c},u).then(xs)},construct(s,o){gu(i);const[A,l]=jM(o);return To(r,e,{type:"CONSTRUCT",path:t.map(c=>c.toString()),argumentList:A},l).then(xs)}});return oee(a,r),a}function lee(r){return Array.prototype.concat.apply([],r)}function jM(r){const e=r.map(Mh);return[e.map(t=>t[0]),lee(e.map(t=>t[1]))]}const NN=new WeakMap;function cee(r,e){return NN.set(r,e),r}function uee(r){return Object.assign(r,{[TN]:!0})}function Mh(r){for(const[e,t]of _N)if(t.canHandle(r)){const[n,i]=t.serialize(r);return[{type:"HANDLER",name:e,value:n},i]}return[{type:"RAW",value:r},NN.get(r)||[]]}function xs(r){switch(r.type){case"HANDLER":return _N.get(r.name).deserialize(r.value);case"RAW":return r.value}}function To(r,e,t,n){return new Promise(i=>{const a=hee();e.set(a,i),r.start&&r.start(),r.postMessage(Object.assign({id:a},t),n)})}function hee(){return new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-")}class dee extends gd{constructor(e,t,n){super(),this.graph=e,this.layout=t,this.options=n,this.spawnWorker()}spawnWorker(){this.proxy=LN(new Worker(new URL("https://registry.npmmirror.com/@gkd-kit/inspect/0.0.1768900570874/files/dist/assets/worker-NxeETyFs.js",import.meta.url),{type:"module"})),this.running&&(this.running=!1,this.execute())}execute(){var e;return Je(this,void 0,void 0,function*(){if(this.running)return this;this.running=!0;const t=this.layout.options,{onTick:n}=t,i=Dt(t,["onTick"]),a={};Object.keys(i).forEach(l=>{Te(i[l])||(a[l]=i[l])});const s={layout:{id:this.layout.id,options:a,iterations:(e=this.options)===null||e===void 0?void 0:e.iterations},nodes:this.graph.getAllNodes(),edges:this.graph.getAllEdges()},o=new Float32Array([0]),[A]=yield this.proxy.calculateLayout(s,[o]);return A})}stop(){return this.running=!1,this.proxy.stopLayout(),this}kill(){this.proxy[MN]()}isRunning(){return this.running}}var fee=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class Vd extends vd{constructor(){super(...arguments),this.id="fishbone"}getRoot(){const e=this.context.model.getRootsData();if(!(Qi(e)||e.length>2))return e[0]}formatSize(e){const t=typeof e=="function"?e:()=>e;return n=>Gr(t(n))}doLayout(e,t){const{hGap:n,getRibSep:i,vGap:a,nodeSize:s,height:o}=t,{model:A}=this.context,l=this.formatSize(s);let c=l(e)[0]+i(e);const u=(m,B=0)=>{var C;return B+=n*((m.children||[]).length+1),(C=m.children)===null||C===void 0||C.forEach(S=>{var F;(F=A.getNodeLikeDatum(S).children)===null||F===void 0||F.forEach(O=>{const _=A.getNodeLikeDatum(O);B=u(_,B)})}),B},h=m=>{if(m.depth===1)return c;const B=A.getParentData(m.id,"tree");if(yo(m)){const C=A.getParentData(B.id,"tree"),S=g(m)-g(C);return h(B)+S*n/a}else{const C=(B.children||[]).indexOf(m.id),S=A.getNodeData((B.children||[]).slice(C));return d(B)-S.reduce((F,T)=>F+u(T),0)-l(B)[0]/2}},d=mw(m=>{if($m(m))return l(m)[0]/2;const B=A.getParentData(m.id,"tree");if(yo(m))return h(m)+u(m)+l(m)[0]/2;{const C=g(m)-g(B),S=n/a;return h(m)+C*S}},m=>m.id),f=m=>g(A.getParentData(m,"tree")),g=mw(m=>{if($m(m))return o/2;if(yo(m)){const B=A.getParentData(m.id,"tree"),C=B.children.indexOf(m.id);if(C===0)return f(B.id)+a;const S=A.getNodeLikeDatum(B.children[C-1]);if(Qi(S.children))return g(S)+a;const F=A.getDescendantsData(S.id);return Math.max(...F.map(T=>yo(T)?f(T.id):g(T)))+a}else{if(Qi(m.children))return f(m.id)+a;const B=A.getNodeLikeDatum(m.children.slice(-1)[0]);if(Qi(B.children))return g(B)+a;const C=A.getDescendantsData(m.id).slice(-1)[0];return(yo(C)?f(C.id):g(C))+a}},m=>m.id);let v=0;const p={nodes:[],edges:[]},y=m=>{var B;(B=m.children)===null||B===void 0||B.forEach(O=>y(A.getNodeLikeDatum(O)));const C=g(m),S=d(m);if(p.nodes.push({id:m.id,x:S,y:C}),$m(m))return;const F=A.getRelatedEdgesData(m.id,"in")[0],T=[h(m),yo(m)?C:f(m.id)];p.edges.push({id:Z(F),controlPoints:[T],relatedNodeId:m.id}),v=Math.max(v,S+i(m)),m.depth===1&&(c=v)};return y(e),p}placeAlterative(e,t){const n=(t.children||[]).filter((o,A)=>A%2!==0);if(n.length===0)return e;const{model:i}=this.context,a=e.nodes.find(o=>o.id===t.id).y,s=o=>{const A=i.getAncestorsData(o,"tree");if(Qi(A))return!1;const l=A.length===1?o:A[A.length-2].id;return n.includes(l)};e.nodes.forEach(o=>{s(o.id)&&(o.y=2*a-o.y)}),e.edges.forEach(o=>{s(o.relatedNodeId)&&(o.controlPoints=o.controlPoints.map(A=>[A[0],2*a-A[1]]))})}rightToLeft(e,t){return e.nodes.forEach(n=>n.x=t.width-n.x),e.edges.forEach(n=>{n.controlPoints=n.controlPoints.map(i=>[t.width-i[0],i[1]])}),e}execute(e,t){return fee(this,void 0,void 0,function*(){const n=Object.assign(Object.assign(Object.assign({},Vd.defaultOptions),this.options),t),{direction:i,nodeSize:a}=n,s=this.getRoot();if(!s)return e;const o=this.formatSize(a);n.vGap||(n.vGap=Math.max(...(e.nodes||[]).map(h=>o(h)[1]))),n.hGap||(n.hGap=Math.max(...(e.nodes||[]).map(h=>o(h)[0])));let A=this.doLayout(s,n);this.placeAlterative(A,s),i==="RL"&&(A=this.rightToLeft(A,n));const{model:l}=this.context,c=[],u=[];return A.nodes.forEach(h=>{const{id:d,x:f,y:g}=h,v=l.getNodeLikeDatum(d);c.push(WM(v,{x:f,y:g}))}),A.edges.forEach(h=>{const{id:d,controlPoints:f}=h,g=l.getEdgeDatum(d);u.push(WM(g,{controlPoints:f}))}),{nodes:c,edges:u}})}}Vd.defaultOptions={direction:"RL",getRibSep:()=>60};const WM=(r,e)=>Object.assign(Object.assign({},r),{style:Object.assign(Object.assign({},r.style||{}),e)}),$m=r=>r.depth===0,yo=r=>(r.depth||(r.depth=0))%2===0;var gee=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class jd extends vd{constructor(){super(...arguments),this.id="snake"}formatSize(e,t){const n=typeof t=="function"?t:(()=>t);return e.reduce((i,a)=>{const[s,o]=Gr(n(a))||[0,0];return[Math.max(i[0],s),Math.max(i[1],o)]},[0,0])}validate(e){const{nodes:t=[],edges:n=[]}=e,i={},a={},s={};t.forEach(h=>{i[h.id]=0,a[h.id]=0,s[h.id]=[]}),n.forEach(h=>{i[h.target]++,a[h.source]++,s[h.source].push(h.target)});const o=new Set,A=h=>{o.has(h)||(o.add(h),s[h].forEach(A))};if(A(t[0].id),o.size!==t.length)return!1;const l=t.filter(h=>i[h.id]===0),c=t.filter(h=>a[h.id]===0);return!(l.length!==1||c.length!==1||t.filter(h=>i[h.id]===1&&a[h.id]===1).length!==t.length-2)}execute(e,t){return gee(this,void 0,void 0,function*(){var n;if(!this.validate(e))return e;const{nodeSize:i,padding:a,sortBy:s,cols:o,colGap:A,rowGap:l,clockwise:c,width:u,height:h}=Object.assign({},jd.defaultOptions,this.options,t),[d,f,g,v]=ai(a),p=this.formatSize(e.nodes||[],i),y=Math.ceil((e.nodes||[]).length/o);let m=A||(u-v-f-o*p[0])/(o-1),B=l||(h-d-g-y*p[1])/(y-1);return(B===1/0||B<0)&&(B=0),(m===1/0||m<0)&&(m=0),{nodes:((s?(n=e.nodes)===null||n===void 0?void 0:n.sort(s):vee(e))||[]).map((F,T)=>{const O=Math.floor(T/o),_=T%o,k=c?O%2===0?_:o-1-_:O%2===0?o-1-_:_,L=v+k*(p[0]+m)+p[0]/2,U=d+O*(p[1]+B)+p[1]/2;return{id:F.id,style:{x:L,y:U}}})}})}}jd.defaultOptions={padding:0,cols:5,clockwise:!0};function vee(r){const{nodes:e=[],edges:t=[]}=r,n={},i={};e.forEach(o=>{n[o.id]=0,i[o.id]=[]}),t.forEach(o=>{n[o.target]++,i[o.source].push(o.target)});const a=[],s=[];for(e.forEach(o=>{n[o.id]===0&&a.push(o.id)});a.length>0;){const o=a.shift(),A=e.find(l=>l.id===o);s.push(A),i[o].forEach(l=>{n[l]--,n[l]===0&&a.push(l)})}return s}const pee=["rgb(158, 1, 66)","rgb(213, 62, 79)","rgb(244, 109, 67)","rgb(253, 174, 97)","rgb(254, 224, 139)","rgb(255, 255, 191)","rgb(230, 245, 152)","rgb(171, 221, 164)","rgb(102, 194, 165)","rgb(50, 136, 189)","rgb(94, 79, 162)"],yee=["rgb(78, 121, 167)","rgb(242, 142, 44)","rgb(225, 87, 89)","rgb(118, 183, 178)","rgb(89, 161, 79)","rgb(237, 201, 73)","rgb(175, 122, 161)","rgb(255, 157, 167)","rgb(156, 117, 95)","rgb(186, 176, 171)"],mee=["rgb(255, 245, 235)","rgb(254, 230, 206)","rgb(253, 208, 162)","rgb(253, 174, 107)","rgb(253, 141, 60)","rgb(241, 105, 19)","rgb(217, 72, 1)","rgb(166, 54, 3)","rgb(127, 39, 4)"],wee=["rgb(247, 252, 245)","rgb(229, 245, 224)","rgb(199, 233, 192)","rgb(161, 217, 155)","rgb(116, 196, 118)","rgb(65, 171, 93)","rgb(35, 139, 69)","rgb(0, 109, 44)","rgb(0, 68, 27)"],Bee=["rgb(247, 251, 255)","rgb(222, 235, 247)","rgb(198, 219, 239)","rgb(158, 202, 225)","rgb(107, 174, 214)","rgb(66, 146, 198)","rgb(33, 113, 181)","rgb(8, 81, 156)","rgb(8, 48, 107)"];class Ln extends yB{}function sA(r,e=!0,t){const n=document.createElement("div");return n.setAttribute("class",`g6-${r}`),Object.assign(n.style,{position:"absolute",display:"block"}),e&&Object.assign(n.style,{position:"unset",gridArea:"1 / 1 / 2 / 2",inset:"0px",height:"100%",width:"100%",overflow:"hidden",pointerEvents:"none"}),t&&Object.assign(n.style,t),n}function S1(r,e="div",t={},n="",i=document.body){const a=document.getElementById(r);a&&a.remove();const s=document.createElement(e);return s.innerHTML=n,s.id=r,Object.assign(s.style,t),i.appendChild(s),s}var bee=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class Wd extends Ln{constructor(e,t){super(e,Object.assign({},Wd.defaultOptions,t)),this.$element=sA("background"),this.context.canvas.getContainer().prepend(this.$element),this.update(t)}update(e){const t=Object.create(null,{update:{get:()=>super.update}});return bee(this,void 0,void 0,function*(){t.update.call(this,e),Object.assign(this.$element.style,V1(this.options,["key","type"]))})}destroy(){super.destroy(),this.$element.remove()}}Wd.defaultOptions={transition:"background 0.5s",backgroundSize:"cover",zIndex:"-1"};function eb(r,e,t,n,i,a){const s=r,o=e,A=t-s,l=n-o;let c=i-s,u=a-o,h=c*A+u*l,d=0;h<=0?d=0:(c=A-c,u=l-u,h=c*A+u*l,h<=0?d=0:d=h*h/(A*A+l*l));const f=c*c+u*u-d;return f<0?0:f}function za(r,e,t,n){return(r-t)*(r-t)+(e-n)*(e-n)}function qM(r,e,t,n,i){return za(r,e,t,n)<i*i}function Eee(r){if(!Number.isFinite(r))return t=>t;if(r===0)return Math.round;const e=Math.pow(10,r);return t=>Math.round(t*e)/e}function UN(r){const e=Math.min(r.x1,r.x2),t=Math.max(r.x1,r.x2),n=Math.min(r.y1,r.y2),i=Math.max(r.y1,r.y2);return{x:e,y:n,x2:t,y2:i,width:t-e,height:i-n}}class In{constructor(e,t,n,i){this.x1=e,this.y1=t,this.x2=n,this.y2=i}equals(e){return this.x1===e.x1&&this.y1===e.y1&&this.x2===e.x2&&this.y2===e.y2}draw(e){e.moveTo(this.x1,this.y1),e.lineTo(this.x2,this.y2)}toString(){return`Line(from=(${this.x1},${this.y1}),to=(${this.x2},${this.y2}))`}static from(e){return new In(e.x1,e.y1,e.x2,e.y2)}cuts(e,t){if(this.y1===this.y2||t<this.y1&&t<=this.y2||t>this.y1&&t>=this.y2||e>this.x1&&e>=this.x2)return!1;if(e<this.x1&&e<=this.x2)return!0;const n=this.x1+(t-this.y1)*(this.x2-this.x1)/(this.y2-this.y1);return e<=n}distSquare(e,t){return eb(this.x1,this.y1,this.x2,this.y2,e,t)}ptClose(e,t,n){if(this.x1<this.x2){if(e<this.x1-n||e>this.x2+n)return!1}else if(e<this.x2-n||e>this.x1+n)return!1;if(this.y1<this.y2){if(t<this.y1-n||t>this.y2+n)return!1}else if(t<this.y2-n||t>this.y1+n)return!1;return!0}}var Jt;(function(r){r[r.POINT=1]="POINT",r[r.PARALLEL=2]="PARALLEL",r[r.COINCIDENT=3]="COINCIDENT",r[r.NONE=4]="NONE"})(Jt||(Jt={}));class Ym{constructor(e,t=0,n=0){this.state=e,this.x=t,this.y=n}}function vu(r,e){const t=(e.x2-e.x1)*(r.y1-e.y1)-(e.y2-e.y1)*(r.x1-e.x1),n=(r.x2-r.x1)*(r.y1-e.y1)-(r.y2-r.y1)*(r.x1-e.x1),i=(e.y2-e.y1)*(r.x2-r.x1)-(e.x2-e.x1)*(r.y2-r.y1);if(i){const a=t/i,s=n/i;return 0<=a&&a<=1&&0<=s&&s<=1?new Ym(Jt.POINT,r.x1+a*(r.x2-r.x1),r.y1+a*(r.y2-r.y1)):new Ym(Jt.NONE)}return new Ym(t===0||n===0?Jt.COINCIDENT:Jt.PARALLEL)}function PN(r,e){const t=(e.x2-e.x1)*(r.y1-e.y1)-(e.y2-e.y1)*(r.x1-e.x1),n=(r.x2-r.x1)*(r.y1-e.y1)-(r.y2-r.y1)*(r.x1-e.x1),i=(e.y2-e.y1)*(r.x2-r.x1)-(e.x2-e.x1)*(r.y2-r.y1);if(i){const a=t/i,s=n/i;if(0<=a&&a<=1&&0<=s&&s<=1)return a}return Number.POSITIVE_INFINITY}function xee(r,e){function t(i,a,s,o){let A=PN(e,new In(i,a,s,o));return A=Math.abs(A-.5),A>=0&&A<=1?1:0}let n=t(r.x,r.y,r.x2,r.y);return n+=t(r.x,r.y,r.x,r.y2),n>1||(n+=t(r.x,r.y2,r.x2,r.y2),n>1)?!0:(n+=t(r.x2,r.y,r.x2,r.y2),n>0)}var en;(function(r){r[r.LEFT=0]="LEFT",r[r.TOP=1]="TOP",r[r.RIGHT=2]="RIGHT",r[r.BOTTOM=3]="BOTTOM"})(en||(en={}));function Nu(r,e,t){const n=new Set;return r.width<=0?(n.add(en.LEFT),n.add(en.RIGHT)):e<r.x?n.add(en.LEFT):e>r.x+r.width&&n.add(en.RIGHT),r.height<=0?(n.add(en.TOP),n.add(en.BOTTOM)):t<r.y?n.add(en.TOP):t>r.y+r.height&&n.add(en.BOTTOM),n}function RN(r,e){let t=e.x1,n=e.y1;const i=e.x2,a=e.y2,s=Array.from(Nu(r,i,a));if(s.length===0)return!0;let o=Nu(r,t,n);for(;o.size!==0;){for(const A of s)if(o.has(A))return!1;if(o.has(en.RIGHT)||o.has(en.LEFT)){let A=r.x;o.has(en.RIGHT)&&(A+=r.width),n=n+(A-t)*(a-n)/(i-t),t=A}else{let A=r.y;o.has(en.BOTTOM)&&(A+=r.height),t=t+(A-n)*(i-t)/(a-n),n=A}o=Nu(r,t,n)}return!0}function Cee(r,e){let t=Number.POSITIVE_INFINITY,n=0;function i(a,s,o,A){let l=PN(e,new In(a,s,o,A));l=Math.abs(l-.5),l>=0&&l<=1&&(n++,l<t&&(t=l))}return i(r.x,r.y,r.x2,r.y),i(r.x,r.y,r.x,r.y2),n>1||(i(r.x,r.y2,r.x2,r.y2),n>1)?t:(i(r.x2,r.y,r.x2,r.y2),n===0?-1:t)}function See(r,e){let t=0;const n=vu(r,new In(e.x,e.y,e.x2,e.y));t+=n.state===Jt.POINT?1:0;const i=vu(r,new In(e.x,e.y,e.x,e.y2));t+=i.state===Jt.POINT?1:0;const a=vu(r,new In(e.x,e.y2,e.x2,e.y2));t+=a.state===Jt.POINT?1:0;const s=vu(r,new In(e.x2,e.y,e.x2,e.y2));return t+=s.state===Jt.POINT?1:0,{top:n,left:i,bottom:a,right:s,count:t}}class Jn{constructor(e,t,n,i){this.x=e,this.y=t,this.width=n,this.height=i}get x2(){return this.x+this.width}get y2(){return this.y+this.height}get cx(){return this.x+this.width/2}get cy(){return this.y+this.height/2}get radius(){return Math.max(this.width,this.height)/2}static from(e){return new Jn(e.x,e.y,e.width,e.height)}equals(e){return this.x===e.x&&this.y===e.y&&this.width===e.width&&this.height===e.height}clone(){return new Jn(this.x,this.y,this.width,this.height)}add(e){const t=Math.min(this.x,e.x),n=Math.min(this.y,e.y),i=Math.max(this.x2,e.x+e.width),a=Math.max(this.y2,e.y+e.height);this.x=t,this.y=n,this.width=i-t,this.height=a-n}addPoint(e){const t=Math.min(this.x,e.x),n=Math.min(this.y,e.y),i=Math.max(this.x2,e.x),a=Math.max(this.y2,e.y);this.x=t,this.y=n,this.width=i-t,this.height=a-n}toString(){return`Rectangle[x=${this.x}, y=${this.y}, w=${this.width}, h=${this.height}]`}draw(e){e.rect(this.x,this.y,this.width,this.height)}containsPt(e,t){return e>=this.x&&e<=this.x2&&t>=this.y&&t<=this.y2}get area(){return this.width*this.height}intersects(e){return this.area<=0||e.width<=0||e.height<=0?!1:e.x+e.width>this.x&&e.y+e.height>this.y&&e.x<this.x2&&e.y<this.y2}distSquare(e,t){if(this.containsPt(e,t))return 0;const n=Nu(this,e,t);return n.has(en.TOP)?n.has(en.LEFT)?za(e,t,this.x,this.y):n.has(en.RIGHT)?za(e,t,this.x2,this.y):(this.y-t)*(this.y-t):n.has(en.BOTTOM)?n.has(en.LEFT)?za(e,t,this.x,this.y2):n.has(en.RIGHT)?za(e,t,this.x2,this.y2):(t-this.y2)*(t-this.y2):n.has(en.LEFT)?(this.x-e)*(this.x-e):n.has(en.RIGHT)?(e-this.x2)*(e-this.x2):0}}function Fee(r){if(r.length===0)return null;const e=r[0],t=new Jn(e.x,e.y,0,0);for(const n of r)t.addPoint(n);return t}class Oh{constructor(e,t,n){this.cx=e,this.cy=t,this.radius=n}get x(){return this.cx-this.radius}get x2(){return this.cx+this.radius}get width(){return this.radius*2}get y(){return this.cy-this.radius}get y2(){return this.cy+this.radius}get height(){return this.radius*2}static from(e){return new Oh(e.cx,e.cy,e.radius)}containsPt(e,t){return za(this.cx,this.cy,e,t)<this.radius*this.radius}distSquare(e,t){const n=za(this.cx,this.cy,e,t);if(n<this.radius*this.radius)return 0;const i=Math.sqrt(n)-this.radius;return i*i}draw(e){e.ellipse(this.cx,this.cy,this.radius,this.radius,0,0,Math.PI*2)}}class Ps{constructor(e,t=0,n=0,i=0,a=0,s=10,o=10,A=new Float32Array(Math.max(0,s*o)).fill(0)){this.pixelGroup=e,this.i=t,this.j=n,this.pixelX=i,this.pixelY=a,this.width=s,this.height=o,this.area=A}createSub(e,t){return new Ps(this.pixelGroup,e.x,e.y,t.x,t.y,e.width,e.height)}static fromPixelRegion(e,t){return new Ps(t,0,0,e.x,e.y,Math.ceil(e.width/t),Math.ceil(e.height/t))}copy(e,t){return new Ps(this.pixelGroup,this.scaleX(t.x),this.scaleY(t.y),t.x,t.y,e.width,e.height,e.area)}boundX(e){return e<this.i?this.i:e>=this.width?this.width-1:e}boundY(e){return e<this.j?this.j:e>=this.height?this.height-1:e}scaleX(e){return this.boundX(Math.floor((e-this.pixelX)/this.pixelGroup))}scaleY(e){return this.boundY(Math.floor((e-this.pixelY)/this.pixelGroup))}scale(e){const t=this.scaleX(e.x),n=this.scaleY(e.y),i=this.boundX(Math.ceil((e.x+e.width-this.pixelX)/this.pixelGroup)),a=this.boundY(Math.ceil((e.y+e.height-this.pixelY)/this.pixelGroup)),s=i-t,o=a-n;return new Jn(t,n,s,o)}invertScaleX(e){return Math.round(e*this.pixelGroup+this.pixelX)}invertScaleY(e){return Math.round(e*this.pixelGroup+this.pixelY)}addPadding(e,t){const n=Math.ceil(t/this.pixelGroup),i=this.boundX(e.x-n),a=this.boundY(e.y-n),s=this.boundX(e.x2+n),o=this.boundY(e.y2+n),A=s-i,l=o-a;return new Jn(i,a,A,l)}get(e,t){return e<0||t<0||e>=this.width||t>=this.height?Number.NaN:this.area[e+t*this.width]}inc(e,t,n){e<0||t<0||e>=this.width||t>=this.height||(this.area[e+t*this.width]+=n)}set(e,t,n){e<0||t<0||e>=this.width||t>=this.height||(this.area[e+t*this.width]=n)}incArea(e,t){if(e.width<=0||e.height<=0||t===0)return;const n=this.width,i=e.width,a=Math.max(0,e.i),s=Math.max(0,e.j),o=Math.min(e.i+e.width,n),A=Math.min(e.j+e.height,this.height);if(!(A<=0||o<=0||a>=n||A>=this.height))for(let l=s;l<A;l++){const c=(l-e.j)*i,u=l*n;for(let h=a;h<o;h++){const d=e.area[h-e.i+c];d!==0&&(this.area[h+u]+=t*d)}}}fill(e){this.area.fill(e)}fillArea(e,t){const n=e.x+e.y*this.width;for(let i=0;i<e.height;i++){const a=n+i*this.width;this.area.fill(t,a,a+e.width)}}fillHorizontalLine(e,t,n,i){const a=e+t*this.width;this.area.fill(i,a,a+n)}fillVerticalLine(e,t,n,i){const a=e+t*this.width;for(let s=0;s<n;s++)this.area[a+s*this.width]=i}clear(){this.area.fill(0)}toString(){let e="";for(let t=0;t<this.height;t++){const n=t*this.width;for(let i=0;i<this.width;i++){const a=this.area[n+i];e+=a.toFixed(1).padStart(6),e+=" "}e+=`
|
|
14
|
+
`}return e}draw(e,t=!0){if(this.width<=0||this.height<=0)return;e.save(),t&&e.translate(this.pixelX,this.pixelY);const n=this.area.reduce((s,o)=>Math.min(s,o),Number.POSITIVE_INFINITY),i=this.area.reduce((s,o)=>Math.max(s,o),Number.NEGATIVE_INFINITY),a=s=>(s-n)/(i-n);e.scale(this.pixelGroup,this.pixelGroup);for(let s=0;s<this.width;s++)for(let o=0;o<this.height;o++){const A=this.area[s+o*this.width];e.fillStyle=`rgba(0, 0, 0, ${a(A)})`,e.fillRect(s,o,1,1)}e.restore()}drawThreshold(e,t,n=!0){if(!(this.width<=0||this.height<=0)){e.save(),n&&e.translate(this.pixelX,this.pixelY),e.scale(this.pixelGroup,this.pixelGroup);for(let i=0;i<this.width;i++)for(let a=0;a<this.height;a++){const s=this.area[i+a*this.width];e.fillStyle=s>t?"black":"white",e.fillRect(i,a,1,1)}e.restore()}}}function DN(r,e){const t=n=>({x:n.x-e,y:n.y-e,width:n.width+2*e,height:n.height+2*e});return Array.isArray(r)?r.map(t):t(r)}function $M(r,e,t){return HN(Object.assign(UN(r),{distSquare:(n,i)=>eb(r.x1,r.y1,r.x2,r.y2,n,i)}),e,t)}function HN(r,e,t){const n=DN(r,t),i=e.scale(n),a=e.createSub(i,n);return Tee(a,e,t,(s,o)=>r.distSquare(s,o)),a}function Tee(r,e,t,n){const i=t*t;for(let a=0;a<r.height;a++)for(let s=0;s<r.width;s++){const o=e.invertScaleX(r.i+s),A=e.invertScaleY(r.j+a),l=n(o,A);if(l===0){r.set(s,a,i);continue}if(l<i){const c=t-Math.sqrt(l);r.set(s,a,c*c)}}return r}function Mee(r,e,t){const n=e.scale(r),i=e.addPadding(n,t),a=e.createSub(i,{x:r.x-t,y:r.y-t}),s=n.x-i.x,o=n.y-i.y,A=i.x2-n.x2,l=i.y2-n.y2,c=i.width-s-A,u=i.height-o-l,h=t*t;a.fillArea({x:s,y:o,width:c+1,height:u+1},h);const d=[0],f=Math.max(o,s,A,l);{const y=e.invertScaleX(n.x+n.width/2);for(let m=1;m<f;m++){const B=e.invertScaleY(n.y-m),C=r.distSquare(y,B);if(C<h){const S=t-Math.sqrt(C);d.push(S*S)}else break}}const g=[],v=Math.max(s,A),p=Math.max(o,A);for(let y=1;y<v;y++){const m=e.invertScaleX(n.x-y),B=[];for(let C=1;C<p;C++){const S=e.invertScaleY(n.y-C),F=r.distSquare(m,S);if(F<h){const T=t-Math.sqrt(F);B.push(T*T)}else B.push(0)}g.push(B)}for(let y=1;y<Math.min(o,d.length);y++){const m=d[y];a.fillHorizontalLine(s,o-y,c+1,m)}for(let y=1;y<Math.min(l,d.length);y++){const m=d[y];a.fillHorizontalLine(s,o+u+y,c+1,m)}for(let y=1;y<Math.min(s,d.length);y++){const m=d[y];a.fillVerticalLine(s-y,o,u+1,m)}for(let y=1;y<Math.min(l,d.length);y++){const m=d[y];a.fillVerticalLine(s+c+y,o,u+1,m)}for(let y=1;y<s;y++){const m=g[y-1],B=s-y;for(let C=1;C<o;C++)a.set(B,o-C,m[C-1]);for(let C=1;C<l;C++)a.set(B,o+u+C,m[C-1])}for(let y=1;y<A;y++){const m=g[y-1],B=s+c+y;for(let C=1;C<o;C++)a.set(B,o-C,m[C-1]);for(let C=1;C<l;C++)a.set(B,o+u+C,m[C-1])}return a}function Nt(r,e){return{x:r,y:e}}function Oee(r,e,t,n){if(r.length===0)return[];const i=Qee(r);return i.map((a,s)=>{const o=i.slice(0,s);return _ee(e,a,o,t,n)}).flat()}function _ee(r,e,t,n,i){const a=Nt(e.cx,e.cy),s=Lee(a,t,r);if(s==null)return[];const o=new In(a.x,a.y,s.cx,s.cy),A=Iee(o,r,n,i);return kee(A,r)}function Iee(r,e,t,n){const i=[],a=[];a.push(r);let s=!0;for(let o=0;o<t&&s;o++)for(s=!1;!s&&a.length>0;){const A=a.pop(),l=GN(e,A),c=l?See(A,l):null;if(!l||!c||c.count!==2){s||i.push(A);continue}let u=n,h=yu(l,u,c,!0),d=Ea(h,a)||Ea(h,i),f=pu(h,e);for(;!d&&f&&u>=1;)u/=1.5,h=yu(l,u,c,!0),d=Ea(h,a)||Ea(h,i),f=pu(h,e);if(h&&!d&&!f&&(a.push(new In(A.x1,A.y1,h.x,h.y)),a.push(new In(h.x,h.y,A.x2,A.y2)),s=!0),s)continue;u=n,h=yu(l,u,c,!1);let g=Ea(h,a)||Ea(h,i);for(f=pu(h,e);!g&&f&&u>=1;)u/=1.5,h=yu(l,u,c,!1),g=Ea(h,a)||Ea(h,i),f=pu(h,e);h&&!g&&(a.push(new In(A.x1,A.y1,h.x,h.y)),a.push(new In(h.x,h.y,A.x2,A.y2)),s=!0),s||i.push(A)}for(;a.length>0;)i.push(a.pop());return i}function kee(r,e){const t=[];for(;r.length>0;){const n=r.pop();if(r.length===0){t.push(n);break}const i=r.pop(),a=new In(n.x1,n.y1,i.x2,i.y2);GN(e,a)?(t.push(n),r.push(i)):r.push(a)}return t}function Lee(r,e,t){let n=Number.POSITIVE_INFINITY;return e.reduce((i,a)=>{const s=za(r.x,r.y,a.cx,a.cy);if(s>n)return i;const o=new In(r.x,r.y,a.cx,a.cy),A=Nee(t,o);return s*(A+1)*(A+1)<n&&(i=a,n=s*(A+1)*(A+1)),i},null)}function Qee(r){if(r.length<2)return r;let e=0,t=0;return r.forEach(n=>{e+=n.cx,t+=n.cy}),e/=r.length,t/=r.length,r.map(n=>{const i=e-n.cx,a=t-n.cy,s=i*i+a*a;return[n,s]}).sort((n,i)=>n[1]-i[1]).map(n=>n[0])}function pu(r,e){return e.some(t=>t.containsPt(r.x,r.y))}function Ea(r,e){return e.some(t=>!!(qM(t.x1,t.y1,r.x,r.y,.001)||qM(t.x2,t.y2,r.x,r.y,.001)))}function GN(r,e){let t=Number.POSITIVE_INFINITY,n=null;for(const i of r){if(!RN(i,e))continue;const a=Cee(i,e);a>=0&&a<t&&(n=i,t=a)}return n}function Nee(r,e){return r.reduce((t,n)=>RN(n,e)&&xee(n,e)?t+1:t,0)}function yu(r,e,t,n){const i=t.top,a=t.left,s=t.bottom,o=t.right;if(n){if(a.state===Jt.POINT){if(i.state===Jt.POINT)return Nt(r.x-e,r.y-e);if(s.state===Jt.POINT)return Nt(r.x-e,r.y2+e);const h=r.width*r.height;return r.width*((a.y-r.y+(o.y-r.y))*.5)<h*.5?a.y>o.y?Nt(r.x-e,r.y-e):Nt(r.x2+e,r.y-e):a.y<o.y?Nt(r.x-e,r.y2+e):Nt(r.x2+e,r.y2+e)}if(o.state===Jt.POINT){if(i.state===Jt.POINT)return Nt(r.x2+e,r.y-e);if(s.state===Jt.POINT)return Nt(r.x2+e,r.y2+e)}const c=r.height*r.width;return r.height*((i.x-r.x+(o.x-r.x))*.5)<c*.5?i.x>s.x?Nt(r.x-e,r.y-e):Nt(r.x-e,r.y2+e):i.x<s.x?Nt(r.x2+e,r.y-e):Nt(r.x2+e,r.y2+e)}if(a.state===Jt.POINT){if(i.state===Jt.POINT)return Nt(r.x2+e,r.y2+e);if(s.state===Jt.POINT)return Nt(r.x2+e,r.y-e);const c=r.height*r.width;return r.width*((a.y-r.y+(o.y-r.y))*.5)<c*.5?a.y>o.y?Nt(r.x2+e,r.y2+e):Nt(r.x-e,r.y2+e):a.y<o.y?Nt(r.x2+e,r.y-e):Nt(r.x-e,r.y-e)}if(o.state===Jt.POINT){if(i.state===Jt.POINT)return Nt(r.x-e,r.y2+e);if(s.state===Jt.POINT)return Nt(r.x-e,r.y-e)}const A=r.height*r.width;return r.height*((i.x-r.x+(o.x-r.x))*.5)<A*.5?i.x>s.x?Nt(r.x2+e,r.y2+e):Nt(r.x2+e,r.y-e):i.x<s.x?Nt(r.x-e,r.y2+e):Nt(r.x-e,r.y-e)}function Uee(r,e,t,n){if(!(r.closed?t<r.length:t<r.length-1))return!1;const a=r.get(e),s=r.get(t+1);for(let o=e+1;o<=t;o++){const A=r.get(o);if(eb(a.x,a.y,s.x,s.y,A.x,A.y)>n)return!1}return!0}function Pee(r=0){return e=>{if(r<0||e.length<3)return e;const t=[];let n=0;const i=r*r;for(;n<e.length;){let a=n+1;for(;Uee(e,n,a,i);)a++;t.push(e.get(n)),n=a}return new oA(t)}}function Ree(r,e){switch(r){case-2:return(((-e+3)*e-3)*e+1)/6;case-1:return((3*e-6)*e*e+4)/6;case 0:return(((-3*e+3)*e+3)*e+1)/6;case 1:return e*e*e/6;default:throw new Error("unknown error")}}function Dee(r=6){function a(s,o,A){let l=0,c=0;for(let u=-2;u<=1;u++){const h=s.get(o+u),d=Ree(u,A);l+=d*h.x,c+=d*h.y}return{x:l,y:c}}return s=>{if(s.length<3)return s;const o=[],A=s.closed,l=s.length+3-1+(A?0:2);o.push(a(s,2-(A?0:2),0));for(let c=2-(A?0:2);c<l;c++)for(let u=1;u<=r;u++)o.push(a(s,c,u/r));return new oA(o)}}function Hee(r=8){return e=>{let t=r,n=e.length;if(t>1)for(n=Math.floor(e.length/t);n<3&&t>1;)t-=1,n=Math.floor(e.length/t);const i=[];for(let a=0,s=0;s<n;s++,a+=t)i.push(e.get(a));return new oA(i)}}class oA{constructor(e=[],t=!0){this.points=e,this.closed=t}get(e){const t=e,n=this.points.length;return e<0?this.closed?this.get(e+n):this.points[0]:e>=n?this.closed?this.get(e-n):this.points[n-1]:this.points[t]}get length(){return this.points.length}toString(e=1/0){const t=this.points;if(t.length===0)return"";const n=typeof e=="function"?e:Eee(e);let i="M";for(const a of t)i+=`${n(a.x)},${n(a.y)} L`;return i=i.slice(0,-1),this.closed&&(i+=" Z"),i}draw(e){const t=this.points;if(t.length!==0){e.beginPath(),e.moveTo(t[0].x,t[0].y);for(const n of t)e.lineTo(n.x,n.y);this.closed&&e.closePath()}}sample(e){return Hee(e)(this)}simplify(e){return Pee(e)(this)}bSplines(e){return Dee(e)(this)}apply(e){return e(this)}containsElements(e){const t=Fee(this.points);return t?e.every(n=>t.containsPt(n.cx,n.cy)&&this.withinArea(n.cx,n.cy)):!1}withinArea(e,t){if(this.length===0)return!1;let n=0;const i=this.points[0],a=new In(i.x,i.y,i.x,i.y);for(let s=1;s<this.points.length;s++){const o=this.points[s];a.x1=a.x2,a.y1=a.y2,a.x2=o.x,a.y2=o.y,a.cuts(e,t)&&n++}return a.x1=a.x2,a.y1=a.y2,a.x2=i.x,a.y2=i.y,a.cuts(e,t)&&n++,n%2===1}}class Gee{constructor(e=0){this.count=0,this.arr=[],this.set=new Set,this.arr.length=e}add(e){this.set.add(`${e.x}x${e.y}`),this.arr[this.count++]=e}contains(e){return this.set.has(`${e.x}x${e.y}`)}isFirst(e){if(this.count===0)return!1;const t=this.arr[0];return t!=null&&t.x===e.x&&t.y===e.y}path(){return new oA(this.arr.slice(0,this.count))}clear(){this.set.clear(),this.count=0}get(e){return this.arr[e]}get length(){return this.count}}const SA=0,mu=1,wu=2,Xm=3;function Kee(r,e){const t=(Math.floor(r.width)+Math.floor(r.height))*2,n=new Gee(t);function i(A,l,c,u){const h=r.get(A,l);return Number.isNaN(h)?Number.NaN:h>e?c+u:c}function a(A,l){let c=SA;return c=i(A,l,c,1),c=i(A+1,l,c,2),c=i(A,l+1,c,4),c=i(A+1,l+1,c,8),Number.isNaN(c)?-1:c}let s=mu;function o(A,l){let c=A,u=l,h=r.invertScaleX(c),d=r.invertScaleY(u);for(let f=0;f<r.width*r.height;f++){const g={x:h,y:d};if(n.contains(g)){if(n.isFirst(g))return!0}else n.add(g);const v=a(c,u);switch(v){case-1:return!0;case 0:case 3:case 2:case 7:s=wu;break;case 12:case 14:case 4:s=Xm;break;case 6:s=s===SA?Xm:wu;break;case 1:case 13:case 5:s=SA;break;case 9:s=s===wu?SA:mu;break;case 10:case 8:case 11:s=mu;break;default:return console.warn("Marching squares invalid state: "+v),!0}switch(s){case SA:u--,d-=r.pixelGroup;break;case mu:u++,d+=r.pixelGroup;break;case Xm:c--,h-=r.pixelGroup;break;case wu:c++,h+=r.pixelGroup;break;default:return console.warn("Marching squares invalid state: "+v),!0}}return!0}for(let A=0;A<r.width;A++)for(let l=0;l<r.height;l++){if(r.get(A,l)<=e)continue;const c=a(A,l);if(!(c<0||c===15)&&o(A,l))return n.path()}return null}const qd={maxRoutingIterations:100,maxMarchingIterations:20,pixelGroup:4,edgeR0:10,edgeR1:20,nodeR0:15,nodeR1:50,morphBuffer:10,threshold:1,memberInfluenceFactor:1,edgeInfluenceFactor:1,nonMemberInfluenceFactor:-.8,virtualEdges:!0};function nl(r){return r!=null&&typeof r.radius=="number"}function YM(r,e){if(nl(r)!==nl(e))return!1;if(nl(r)){const n=e;return r.cx===n.cx&&r.cy===n.cy&&r.radius===n.radius}const t=e;return r.x===t.x&&r.y===t.y&&r.width===t.width&&r.height===t.height}var di;(function(r){r[r.MEMBERS=0]="MEMBERS",r[r.NON_MEMBERS=1]="NON_MEMBERS",r[r.EDGES=2]="EDGES"})(di||(di={}));let XM=class{constructor(e={}){this.dirty=new Set,this.members=[],this.nonMembers=[],this.virtualEdges=[],this.edges=[],this.activeRegion=new Jn(0,0,0,0),this.potentialArea=new Ps(1,0,0,0,0,0,0),this.o=Object.assign({},qd,e)}pushMember(...e){if(e.length!==0){this.dirty.add(di.MEMBERS);for(const t of e)this.members.push({raw:t,obj:nl(t)?Oh.from(t):Jn.from(t),area:null})}}removeMember(e){const t=this.members.findIndex(n=>YM(n.raw,e));return t<0?!1:(this.members.splice(t,1),this.dirty.add(di.MEMBERS),!0)}removeNonMember(e){const t=this.nonMembers.findIndex(n=>YM(n.raw,e));return t<0?!1:(this.nonMembers.splice(t,1),this.dirty.add(di.NON_MEMBERS),!0)}removeEdge(e){const t=this.edges.findIndex(n=>n.obj.equals(e));return t<0?!1:(this.edges.splice(t,1),this.dirty.add(di.NON_MEMBERS),!0)}pushNonMember(...e){if(e.length!==0){this.dirty.add(di.NON_MEMBERS);for(const t of e)this.nonMembers.push({raw:t,obj:nl(t)?Oh.from(t):Jn.from(t),area:null})}}pushEdge(...e){if(e.length!==0){this.dirty.add(di.EDGES);for(const t of e)this.edges.push({raw:t,obj:In.from(t),area:null})}}update(){const e=this.dirty.has(di.MEMBERS),t=this.dirty.has(di.NON_MEMBERS);let n=this.dirty.has(di.EDGES);this.dirty.clear();const i=this.members.map(l=>l.obj);if(this.o.virtualEdges&&(e||t)){const l=this.nonMembers.map(h=>h.obj),c=Oee(i,l,this.o.maxRoutingIterations,this.o.morphBuffer),u=new Map(this.virtualEdges.map(h=>[h.obj.toString(),h.area]));this.virtualEdges=c.map(h=>{var d;return{raw:h,obj:h,area:(d=u.get(h.toString()))!==null&&d!==void 0?d:null}}),n=!0}let a=!1;if(e||n){const l=this.virtualEdges.concat(this.edges).map(d=>d.obj),c=Vee(i,l),u=Math.max(this.o.edgeR1,this.o.nodeR1)+this.o.morphBuffer,h=Jn.from(DN(c,u));h.equals(this.activeRegion)||(a=!0,this.activeRegion=h)}if(a){const l=Math.ceil(this.activeRegion.width/this.o.pixelGroup),c=Math.ceil(this.activeRegion.height/this.o.pixelGroup);this.activeRegion.x!==this.potentialArea.pixelX||this.activeRegion.y!==this.potentialArea.pixelY?(this.potentialArea=Ps.fromPixelRegion(this.activeRegion,this.o.pixelGroup),this.members.forEach(u=>u.area=null),this.nonMembers.forEach(u=>u.area=null),this.edges.forEach(u=>u.area=null),this.virtualEdges.forEach(u=>u.area=null)):(l!==this.potentialArea.width||c!==this.potentialArea.height)&&(this.potentialArea=Ps.fromPixelRegion(this.activeRegion,this.o.pixelGroup))}const s=new Map,o=l=>{if(l.area){const c=`${l.obj.width}x${l.obj.height}x${l.obj instanceof Jn?"R":"C"}`;s.set(c,l.area)}},A=l=>{if(l.area)return;const c=`${l.obj.width}x${l.obj.height}x${l.obj instanceof Jn?"R":"C"}`;if(s.has(c)){const h=s.get(c);l.area=this.potentialArea.copy(h,{x:l.obj.x-this.o.nodeR1,y:l.obj.y-this.o.nodeR1});return}const u=l.obj instanceof Jn?Mee(l.obj,this.potentialArea,this.o.nodeR1):HN(l.obj,this.potentialArea,this.o.nodeR1);l.area=u,s.set(c,u)};this.members.forEach(o),this.nonMembers.forEach(o),this.members.forEach(A),this.nonMembers.forEach(l=>{this.activeRegion.intersects(l.obj)?A(l):l.area=null}),this.edges.forEach(l=>{l.area||(l.area=$M(l.obj,this.potentialArea,this.o.edgeR1))}),this.virtualEdges.forEach(l=>{l.area||(l.area=$M(l.obj,this.potentialArea,this.o.edgeR1))})}drawMembers(e){for(const t of this.members)t.obj.draw(e)}drawNonMembers(e){for(const t of this.nonMembers)t.obj.draw(e)}drawEdges(e){for(const t of this.edges)t.obj.draw(e)}drawPotentialArea(e,t=!0){this.potentialArea.draw(e,t)}compute(){if(this.members.length===0)return new oA([]);this.dirty.size>0&&this.update();const{o:e,potentialArea:t}=this,n=this.members.map(o=>o.area),i=this.virtualEdges.concat(this.edges).map(o=>o.area),a=this.nonMembers.filter(o=>o.area!=null).map(o=>o.area),s=this.members.map(o=>o.obj);return zee(t,n,i,a,o=>o.containsElements(s),e)}};function zee(r,e,t,n,i,a={}){const s=Object.assign({},qd,a);let o=s.threshold,A=s.memberInfluenceFactor,l=s.edgeInfluenceFactor,c=s.nonMemberInfluenceFactor;const u=(s.nodeR0-s.nodeR1)*(s.nodeR0-s.nodeR1),h=(s.edgeR0-s.edgeR1)*(s.edgeR0-s.edgeR1);for(let d=0;d<s.maxMarchingIterations;d++){if(r.clear(),A!==0){const g=A/u;for(const v of e)r.incArea(v,g)}if(l!==0){const g=l/h;for(const v of t)r.incArea(v,g)}if(c!==0){const g=c/u;for(const v of n)r.incArea(v,g)}const f=Kee(r,o);if(f&&i(f))return f;if(o*=.95,d<=s.maxMarchingIterations*.5)A*=1.2,l*=1.2;else if(c!==0&&n.length>0)c*=.8;else break}return new oA([])}function Vee(r,e){if(r.length===0)return new Jn(0,0,0,0);const t=Jn.from(r[0]);for(const n of r)t.add(n);for(const n of e)t.add(UN(n));return t}var jee=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class $d extends Ln{constructor(e,t){super(e,zn({},$d.defaultOptions,t)),this.path=null,this.members=new Map,this.avoidMembers=new Map,this.bubbleSetOptions={},this.drawBubbleSets=()=>{const{style:n,bubbleSetOptions:i}=this.parseOptions();Xt(this.bubbleSetOptions,i)||this.init(),this.bubbleSetOptions=Object.assign({},i);const a=Object.assign(Object.assign({},n),{d:this.getPath()});this.shape?this.shape.update(a):(this.shape=new Pl({style:a}),this.context.canvas.appendChild(this.shape))},this.updateBubbleSetsPath=n=>{if(!this.shape)return;const i=Z(n.data);[...this.options.members,...this.options.avoidMembers].includes(i)&&this.shape.update(Object.assign(Object.assign({},this.parseOptions().style),{d:this.getPath(i)}))},this.getPath=n=>{const{graph:i}=this.context,a=this.options.members,s=[...this.members.keys()],o=this.options.avoidMembers,A=[...this.avoidMembers.keys()];if(a.length===0&&o.length===0)return this.members.clear(),this.avoidMembers.clear(),this.path=[],this.path;if(!n&&this.path&&Xt(a,s)&&Xt(o,A))return this.path;const{enter:l=[],exit:c=[]}=qa(s,a,v=>v),{enter:u=[],exit:h=[]}=qa(A,o,v=>v);if(n){const v=a.includes(n),p=o.includes(n);v&&(c.push(n),l.push(n)),p&&(h.push(n),u.push(n))}const d=(v,p,y)=>{v.forEach(m=>{const B=y?this.members:this.avoidMembers,C=y?"pushMember":"pushNonMember",S=y?"removeMember":"removeNonMember";if(p){let F;i.getElementType(m)==="edge"?([F]=qee(i,m),this.bubbleSets.pushEdge(F)):([F]=Wee(i,m),this.bubbleSets[C](F)),B.set(m,F)}else{const F=B.get(m);F&&(i.getElementType(m)==="edge"?this.bubbleSets.removeEdge(F):this.bubbleSets[S](F),B.delete(m))}})};d(c,!1,!0),d(l,!0,!0),d(h,!1,!1),d(u,!0,!1);const g=this.bubbleSets.compute().sample(8).simplify(0).bSplines().simplify(0);return this.path=BL(g.points.map(Hn)),this.path},this.bindEvents(),this.bubbleSets=new XM(this.options)}bindEvents(){this.context.graph.on(ge.AFTER_RENDER,this.drawBubbleSets),this.context.graph.on(ge.AFTER_ELEMENT_UPDATE,this.updateBubbleSetsPath)}init(){this.bubbleSets=new XM(this.options),this.members.clear(),this.avoidMembers.clear(),this.path=null}parseOptions(){const e=this.options,{type:t,key:n,members:i,avoidMembers:a}=e,s=jee(e,["type","key","members","avoidMembers"]),o=Object.keys(s).reduce((A,l)=>(l in qd?A.bubbleSetOptions[l]=s[l]:A.style[l]=s[l],A),{style:{},bubbleSetOptions:{}});return Object.assign({type:t,key:n,members:i,avoidMembers:a},o)}addMember(e){const t=Array.isArray(e)?e:[e];t.some(n=>this.options.avoidMembers.includes(n))&&(this.options.avoidMembers=this.options.avoidMembers.filter(n=>!t.includes(n))),this.options.members=[...new Set([...this.options.members,...t])],this.drawBubbleSets()}removeMember(e){const t=Array.isArray(e)?e:[e];this.options.members=this.options.members.filter(n=>!t.includes(n)),this.drawBubbleSets()}updateMember(e){this.options.members=Te(e)?e(this.options.members):e,this.drawBubbleSets()}getMember(){return this.options.members}addAvoidMember(e){const t=Array.isArray(e)?e:[e];t.some(n=>this.options.members.includes(n))&&(this.options.members=this.options.members.filter(n=>!t.includes(n))),this.options.avoidMembers=[...new Set([...this.options.avoidMembers,...t])],this.drawBubbleSets()}removeAvoidMember(e){const t=Array.isArray(e)?e:[e];this.options.avoidMembers.some(n=>t.includes(n))&&(this.options.avoidMembers=this.options.avoidMembers.filter(n=>!t.includes(n)),this.drawBubbleSets())}updateAvoidMember(e){this.options.avoidMembers=Array.isArray(e)?e:[e],this.drawBubbleSets()}getAvoidMember(){return this.options.avoidMembers}destroy(){this.context.graph.off(ge.AFTER_RENDER,this.drawBubbleSets),this.context.graph.off(ge.AFTER_ELEMENT_UPDATE,this.updateBubbleSetsPath),this.shape&&(this.shape.destroy(),this.shape=void 0),super.destroy()}}$d.defaultOptions=Object.assign({members:[],avoidMembers:[],fill:"lightblue",fillOpacity:.2,stroke:"blue",strokeOpacity:.2},qd);const Wee=(r,e)=>(Array.isArray(e)?e:[e]).map(n=>{const i=r.getElementRenderBounds(n);return new Jn(i.min[0],i.min[1],Yi(i),Xi(i))}),qee=(r,e)=>(Array.isArray(e)?e:[e]).map(n=>{const i=r.getEdgeData(n),a=r.getElementPosition(i.source),s=r.getElementPosition(i.target);return In.from({x1:a[0],y1:a[1],x2:s[0],y2:s[1]})});function $ee(r){return`
|
|
15
|
+
<ul class="g6-contextmenu-ul">
|
|
16
|
+
${r.map(e=>`<li class="g6-contextmenu-li" value="${e.value}">${e.name}</li>`).join("")}
|
|
17
|
+
</ul>
|
|
18
|
+
`}const Yee=`
|
|
19
|
+
.g6-contextmenu {
|
|
20
|
+
font-size: 12px;
|
|
21
|
+
background-color: rgba(255, 255, 255, 0.96);
|
|
22
|
+
border-radius: 4px;
|
|
23
|
+
overflow: hidden;
|
|
24
|
+
box-shadow: rgba(0, 0, 0, 0.12) 0px 6px 12px 0px;
|
|
25
|
+
transition: visibility 0.2s cubic-bezier(0.23, 1, 0.32, 1) 0s, left 0.4s cubic-bezier(0.23, 1, 0.32, 1) 0s, top 0.4s cubic-bezier(0.23, 1, 0.32, 1) 0s;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
.g6-contextmenu-ul {
|
|
29
|
+
max-width: 256px;
|
|
30
|
+
min-width: 96px;
|
|
31
|
+
list-style: none;
|
|
32
|
+
padding: 0;
|
|
33
|
+
margin: 0;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.g6-contextmenu-li {
|
|
37
|
+
padding: 8px 12px;
|
|
38
|
+
cursor: pointer;
|
|
39
|
+
user-select: none;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
.g6-contextmenu-li:hover {
|
|
43
|
+
background-color: #f5f5f5;
|
|
44
|
+
cursor: pointer;
|
|
45
|
+
}
|
|
46
|
+
`;var ZM=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class Yd extends Ln{constructor(e,t){super(e,Object.assign({},Yd.defaultOptions,t)),this.targetElement=null,this.onTriggerEvent=n=>{var i;(i=n.preventDefault)===null||i===void 0||i.call(n),this.show(n)},this.onMenuItemClick=n=>{const{onClick:i,trigger:a}=this.options;if(n.target instanceof HTMLElement&&n.target.className.includes("g6-contextmenu-li")){const s=n.target.getAttribute("value");i==null||i(s,n.target,this.targetElement),this.hide()}a!=="click"&&this.hide()},this.initElement(),this.update(t)}initElement(){this.$element=sA("contextmenu",!1,{zIndex:"99"});const{className:e}=this.options;e&&this.$element.classList.add(e),this.context.canvas.getContainer().appendChild(this.$element),S1("g6-contextmenu-css","style",{},Yee,document.head)}show(e){return ZM(this,void 0,void 0,function*(){const{enable:t,offset:n}=this.options;if(typeof t=="function"&&!t(e)||!t){this.hide();return}const i=yield this.getDOMContent(e);i instanceof HTMLElement?(this.$element.innerHTML="",this.$element.appendChild(i)):this.$element.innerHTML=i;const a=this.context.graph.getCanvas().getContainer().getBoundingClientRect();this.$element.style.left=`${e.client.x-a.left+n[0]}px`,this.$element.style.top=`${e.client.y-a.top+n[1]}px`,this.$element.style.display="block",this.targetElement=e.target})}hide(){this.$element.style.display="none",this.targetElement=null}update(e){this.unbindEvents(),super.update(e),this.bindEvents()}destroy(){this.unbindEvents(),super.destroy(),this.$element.remove()}getDOMContent(e){return ZM(this,void 0,void 0,function*(){const{getContent:t,getItems:n}=this.options;return n?$ee(yield n(e)):yield t(e)})}bindEvents(){const{graph:e}=this.context,{trigger:t}=this.options;e.on(`canvas:${t}`,this.onTriggerEvent),e.on(`node:${t}`,this.onTriggerEvent),e.on(`edge:${t}`,this.onTriggerEvent),e.on(`combo:${t}`,this.onTriggerEvent),document.addEventListener("click",this.onMenuItemClick)}unbindEvents(){const{graph:e}=this.context,{trigger:t}=this.options;e.off(`canvas:${t}`,this.onTriggerEvent),e.off(`node:${t}`,this.onTriggerEvent),e.off(`edge:${t}`,this.onTriggerEvent),e.off(`combo:${t}`,this.onTriggerEvent),document.removeEventListener("click",this.onMenuItemClick)}}Yd.defaultOptions={trigger:"contextmenu",offset:[4,4],loadingContent:'<div class="g6-contextmenu-loading">Loading...</div>',getContent:()=>"It is a empty context menu.",enable:()=>!0};class Xd extends Ln{constructor(e,t){super(e,Object.assign({},Xd.defaultOptions,t)),this.edgeBundles={},this.edgePoints={},this.onBundle=()=>{const{model:n,element:i}=this.context,a=n.getEdgeData();this.divideEdges(this.options.divisions);const{cycles:s,iterRate:o,divRate:A}=this.options;let{lambda:l,divisions:c,iterations:u}=this.options;for(let h=0;h<s;h++){for(let d=0;d<u;d++){const f={};a.forEach(g=>{var v;if(g.source===g.target)return;const p=Z(g);f[p]=this.getEdgeForces(g,c,l);for(let y=0;y<c+1;y++)(v=this.edgePoints)[p]||(v[p]=[]),this.edgePoints[p][y]=Ve(this.edgePoints[p][y],f[p][y])})}l/=2,c*=A,u*=o,this.divideEdges(c)}a.forEach(h=>{const d=Z(h),f=i.getElement(d);f==null||f.update({d:SB(this.edgePoints[d])})})},this.bindEvents()}get nodeMap(){const e=this.context.model.getNodeData();return Object.fromEntries(e.map(t=>[Z(t),js(Sn(t))]))}divideEdges(e){this.context.model.getEdgeData().forEach(n=>{var i;const a=Z(n);(i=this.edgePoints)[a]||(i[a]=[]);const s=this.nodeMap[n.source],o=this.nodeMap[n.target];if(e===1)this.edgePoints[a].push(s),this.edgePoints[a].push(Bi(Ve(s,o),2)),this.edgePoints[a].push(o);else{const l=(this.edgePoints[a].length===0?Lt(s,o):tte(this.edgePoints[a]))/(e+1);let c=l;const u=[s];for(let h=1;h<this.edgePoints[a].length;h++){const d=this.edgePoints[a][h-1],f=this.edgePoints[a][h];let g=Lt(f,d);for(;g>c;){const v=c/g,p=Ve(d,vi(bt(f,d),v));u.push(p),g-=c,c=l}c-=g}u.push(o),this.edgePoints[a]=u}})}getVectorPosition(e){const t=this.nodeMap[e.source],n=this.nodeMap[e.target],[i,a]=bt(n,t),s=Lt(t,n);return{source:t,target:n,vx:i,vy:a,length:s}}measureEdgeCompatibility(e,t){const n=this.getVectorPosition(e),i=this.getVectorPosition(t),a=Xee(n,i),s=Zee(n,i),o=Jee(n,i),A=ete(n,i);return a*s*o*A}getEdgeBundles(){const e={},t=this.options.bundleThreshold,n=this.context.model.getEdgeData();return n.forEach((i,a)=>{n.forEach((s,o)=>{var A,l;if(o<=a)return;this.measureEdgeCompatibility(i,s)>=t&&(e[A=Z(i)]||(e[A]=[]),e[Z(i)].push(s),e[l=Z(s)]||(e[l]=[]),e[Z(s)].push(i))})}),e}getSpringForce(e,t){const{pre:n,cur:i,next:a}=e;return vi(bt(Ve(n,a),vi(i,2)),t)}getElectrostaticForce(e,t){Qi(this.edgeBundles)&&(this.edgeBundles=this.getEdgeBundles());const n=this.edgeBundles[Z(t)];let i=[0,0];return n==null||n.forEach(a=>{const s=this.edgePoints[Z(a)][e],o=this.edgePoints[Z(t)][e],A=bt(s,o),l=Lt(s,o);i=Ve(i,vi(A,1/l))}),i}getEdgeForces(e,t,n){const i=this.nodeMap[e.source],a=this.nodeMap[e.target],s=this.options.K/(Lt(i,a)*(t+1)),o=[[0,0]],A=Z(e);for(let l=1;l<t;l++){const c=this.getSpringForce({pre:this.edgePoints[A][l-1],cur:this.edgePoints[A][l],next:this.edgePoints[A][l+1]||[0,0]},s),u=this.getElectrostaticForce(l,e);o.push(vi(Ve(c,u),n))}return o.push([0,0]),o}bindEvents(){const{graph:e}=this.context;e.on(ge.AFTER_RENDER,this.onBundle)}unbindEvents(){const{graph:e}=this.context;e.off(ge.AFTER_RENDER,this.onBundle)}destroy(){this.unbindEvents(),super.destroy()}}Xd.defaultOptions={K:.1,lambda:.1,divisions:1,divRate:2,cycles:6,iterations:90,iterRate:2/3,bundleThreshold:.6};const Xee=(r,e)=>Math.abs(WV([r.vx,r.vy],[e.vx,e.vy])/(r.length*e.length)),Zee=(r,e)=>{const t=(r.length+e.length)/2;return 2/(t/Math.min(r.length,e.length)+Math.max(r.length,e.length)/t)},Jee=(r,e)=>{const t=(r.length+e.length)/2,n=Bi(Ve(r.source,r.target),2),i=Bi(Ve(e.source,e.target),2);return t/(t+Lt(n,i))},JM=(r,e)=>{if(e.source[0]===e.target[0])return[e.source[0],r[1]];if(e.source[1]===e.target[1])return[r[0],e.source[1]];const t=(e.source[1]-e.target[1])/(e.source[0]-e.target[0]),n=(t*t*e.source[0]+t*(r[1]-e.source[1])+r[0])/(t*t+1),i=t*(n-e.source[0])+e.source[1];return[n,i]},eO=(r,e)=>{const t=JM(e.source,r),n=JM(e.target,r),i=Bi(Ve(t,n),2),a=Bi(Ve(r.source,r.target),2);return Lt(t,n)===0?0:Math.max(0,1-2*Lt(a,i)/Lt(t,n))},ete=(r,e)=>Math.min(eO(r,e),eO(e,r)),tte=r=>{let e=0;for(let t=1;t<r.length;t++)e+=Lt(r[t],r[t-1]);return e},nte={fill:"#fff",fillOpacity:1,lineWidth:1,stroke:"#000",strokeOpacity:.8,zIndex:-1/0},tO=.05;class Zd extends Ln{constructor(e,t){super(e,Object.assign({},Zd.defaultOptions,t)),this.shapes=new Map,this.r=this.options.r,this.onEdgeFilter=n=>{if(this.options.trigger==="drag"&&this.isLensOn)return;const i=Hn(n.canvas);this.renderLens(i),this.renderFocusElements()},this.renderLens=n=>{const i=Object.assign({},nte,this.options.style);this.isLensOn||(this.lens=new Rl({style:i}),this.canvas.appendChild(this.lens)),Object.assign(i,pi(n),{size:this.r*2}),this.lens.update(i)},this.getFilterData=()=>{const{filter:n}=this.options,{model:i}=this.context,a=i.getData();if(!n)return a;const{nodes:s,edges:o,combos:A}=a;return{nodes:s.filter(l=>n(Z(l),"node")),edges:o.filter(l=>n(Z(l),"edge")),combos:A.filter(l=>n(Z(l),"combo"))}},this.getFocusElements=n=>{const{nodes:i,edges:a}=this.getFilterData(),s=i.filter(l=>Lt(Sn(l),n)<this.r),o=s.map(l=>Z(l)),A=a.filter(l=>{const{source:c,target:u}=l,h=o.includes(c),d=o.includes(u);switch(this.options.nodeType){case"both":return h&&d;case"either":return h!==d;case"source":return h&&!d;case"target":return!h&&d;default:return!1}});return{nodes:s,edges:A}},this.renderFocusElements=()=>{const{element:n,graph:i}=this.context;if(!this.isLensOn)return;const a=this.lens.getCenter(),{nodes:s,edges:o}=this.getFocusElements(a),A=new Set,l=c=>{const u=Z(c);A.add(u);const h=n.getElement(u);if(!h)return;const d=this.shapes.get(u)||h.cloneNode();d.setPosition(h.getPosition()),d.id=h.id,this.shapes.has(u)?Object.entries(h.attributes).forEach(([v,p])=>{d.style[v]!==p&&(d.style[v]=p)}):(this.canvas.appendChild(d),this.shapes.set(u,d));const f=i.getElementType(u),g=this.getElementStyle(f,c);d.update(g)};s.forEach(l),o.forEach(l),this.shapes.forEach((c,u)=>{A.has(u)||(c.destroy(),this.shapes.delete(u))})},this.scaleRByWheel=n=>{var i;this.options.preventDefault&&n.preventDefault();const{clientX:a,clientY:s,deltaX:o,deltaY:A}=n,{graph:l,canvas:c}=this.context,u=l.getCanvasByClient([a,s]),h=(i=this.lens)===null||i===void 0?void 0:i.getCenter();if(!this.isLensOn||Lt(u,h)>this.r)return;const{maxR:d,minR:f}=this.options,g=o+A>0?1/(1-tO):1-tO,v=Math.min(...c.getSize())/2;this.r=Math.max(f||0,Math.min(d||v,this.r*g)),this.renderLens(h),this.renderFocusElements()},this.isLensDragging=!1,this.onDragStart=n=>{var i;const a=Hn(n.canvas),s=(i=this.lens)===null||i===void 0?void 0:i.getCenter();!this.isLensOn||Lt(a,s)>this.r||(this.isLensDragging=!0)},this.onDrag=n=>{if(!this.isLensDragging)return;const i=Hn(n.canvas);this.renderLens(i),this.renderFocusElements()},this.onDragEnd=()=>{this.isLensDragging=!1},this.bindEvents()}get canvas(){return this.context.canvas.getLayer("transient")}get isLensOn(){return this.lens&&!this.lens.destroyed}getElementStyle(e,t){const n=e==="node"?this.options.nodeStyle:this.options.edgeStyle;return typeof n=="function"?n(t):n}get graphDom(){return this.context.graph.getCanvas().getContextService().getDomElement()}bindEvents(){var e;const{graph:t}=this.context,{trigger:n,scaleRBy:i}=this.options,a=t.getCanvas().getLayer();["click","drag"].includes(n)&&a.addEventListener(se.CLICK,this.onEdgeFilter),n==="pointermove"?a.addEventListener(se.POINTER_MOVE,this.onEdgeFilter):n==="drag"&&(a.addEventListener(se.DRAG_START,this.onDragStart),a.addEventListener(se.DRAG,this.onDrag),a.addEventListener(se.DRAG_END,this.onDragEnd)),i==="wheel"&&((e=this.graphDom)===null||e===void 0||e.addEventListener(se.WHEEL,this.scaleRByWheel,{passive:!1}))}unbindEvents(){var e;const{graph:t}=this.context,{trigger:n,scaleRBy:i}=this.options,a=t.getCanvas().getLayer();["click","drag"].includes(n)&&a.removeEventListener(se.CLICK,this.onEdgeFilter),n==="pointermove"?a.removeEventListener(se.POINTER_MOVE,this.onEdgeFilter):n==="drag"&&(a.removeEventListener(se.DRAG_START,this.onDragStart),a.removeEventListener(se.DRAG,this.onDrag),a.removeEventListener(se.DRAG_END,this.onDragEnd)),i==="wheel"&&((e=this.graphDom)===null||e===void 0||e.removeEventListener(se.WHEEL,this.scaleRByWheel))}update(e){var t;this.unbindEvents(),super.update(e),this.r=(t=e.r)!==null&&t!==void 0?t:this.r,this.bindEvents()}destroy(){this.unbindEvents(),this.isLensOn&&this.lens.destroy(),this.shapes.forEach((e,t)=>{e.destroy(),this.shapes.delete(t)}),super.destroy()}}Zd.defaultOptions={trigger:"pointermove",r:60,nodeType:"both",filter:()=>!0,style:{lineWidth:2},nodeStyle:{label:!1},edgeStyle:{label:!0},scaleRBy:"wheel",preventDefault:!0};const rte={fill:"#ccc",fillOpacity:.1,lineWidth:2,stroke:"#000",strokeOpacity:.8,labelFontSize:12},nO=.05,rO=.1;class Jd extends Ln{constructor(e,t){super(e,Object.assign({},Jd.defaultOptions,t)),this.r=this.options.r,this.d=this.options.d,this.onCreateFisheye=n=>{if(this.options.trigger==="drag"&&this.isLensOn)return;const i=Hn(n.canvas);this.onMagnify(i)},this.onMagnify=n=>{n.some(isNaN)||(this.renderLens(n),this.renderFocusElements())},this.renderLens=n=>{const i=Object.assign({},rte,this.options.style);this.isLensOn||(this.lens=new Rl({style:i}),this.canvas.appendChild(this.lens)),Object.assign(i,pi(n),{size:this.r*2,label:this.options.showDPercent,labelText:this.getDPercent()}),this.lens.update(i)},this.getDPercent=()=>{const{minD:n,maxD:i}=this.options;return`${Math.round((this.d-n)/(i-n)*100)}%`},this.prevMagnifiedStyleMap=new Map,this.prevOriginStyleMap=new Map,this.renderFocusElements=()=>{if(!this.isLensOn)return;const{graph:n}=this.context,i=this.lens.getCenter(),a=(this.d+1)*this.r,s=new Map,o=new Map;n.getNodeData().forEach(l=>{const c=Sn(l),u=Lt(c,i);if(u>this.r)return;const h=a*u/(this.d*u+this.r),[d,f]=c,[g,v]=i,p=(d-g)/u,y=(f-v)/u,m=[g+h*p,v+h*y],B=Z(l),C=this.getNodeStyle(l),S=Ds(n.getElementRenderStyle(B),Object.keys(C));s.set(B,Object.assign(Object.assign({},pi(m)),C)),o.set(B,Object.assign(Object.assign({},pi(c)),S))}),this.updateStyle(s,o)},this.getNodeStyle=n=>{const{nodeStyle:i}=this.options;return typeof i=="function"?i(n):i},this.updateStyle=(n,i)=>{const{graph:a,element:s}=this.context,{enter:o,exit:A,keep:l}=qa(Array.from(this.prevMagnifiedStyleMap.keys()),Array.from(n.keys()),h=>h),c=new Set,u=(h,d)=>{const f=s.getElement(h);f==null||f.update(d),a.getRelatedEdgesData(h).forEach(g=>{c.add(Z(g))})};[...o,...l].forEach(h=>{u(h,n.get(h))}),A.forEach(h=>{u(h,this.prevOriginStyleMap.get(h)),this.prevOriginStyleMap.delete(h)}),c.forEach(h=>{const d=s.getElement(h);d==null||d.update({})}),this.prevMagnifiedStyleMap=n,i.forEach((h,d)=>{this.prevOriginStyleMap.has(d)||this.prevOriginStyleMap.set(d,h)})},this.isWheelValid=n=>{if(this.options.preventDefault&&n.preventDefault(),!this.isLensOn)return!1;const{clientX:i,clientY:a}=n,s=this.context.graph.getCanvasByClient([i,a]),o=this.lens.getCenter();return!(Lt(s,o)>this.r)},this.scaleR=n=>{const{maxR:i,minR:a}=this.options,s=n?1/(1-nO):1-nO,o=Math.min(...this.context.canvas.getSize())/2;this.r=Math.max(a||0,Math.min(i||o,this.r*s))},this.scaleD=n=>{const{maxD:i,minD:a}=this.options,s=n?this.d+rO:this.d-rO;this.d=Math.max(a,Math.min(i,s))},this.scaleRByWheel=n=>{if(!this.isWheelValid(n))return;const{deltaX:i,deltaY:a}=n;this.scaleR(i+a>0);const s=this.lens.getCenter();this.onMagnify(s)},this.scaleDByWheel=n=>{if(!this.isWheelValid(n))return;const{deltaX:i,deltaY:a}=n;this.scaleD(i+a>0);const s=this.lens.getCenter();this.onMagnify(s)},this.isDragValid=n=>{if(this.options.preventDefault&&n.preventDefault(),!this.isLensOn)return!1;const i=Hn(n.canvas),a=this.lens.getCenter();return!(Lt(i,a)>this.r)},this.isLensDragging=!1,this.onDragStart=n=>{this.isDragValid(n)&&(this.isLensDragging=!0)},this.onDrag=n=>{if(!this.isLensDragging)return;const i=Hn(n.canvas);this.onMagnify(i)},this.onDragEnd=()=>{this.isLensDragging=!1},this.scaleRByDrag=n=>{if(!this.isLensDragging)return;const{dx:i,dy:a}=n;this.scaleR(i-a>0);const s=this.lens.getCenter();this.onMagnify(s)},this.scaleDByDrag=n=>{if(!this.isLensDragging)return;const{dx:i,dy:a}=n;this.scaleD(i-a>0);const s=this.lens.getCenter();this.onMagnify(s)},this.bindEvents()}get canvas(){return this.context.canvas.getLayer("transient")}get isLensOn(){return this.lens&&!this.lens.destroyed}get graphDom(){return this.context.graph.getCanvas().getContextService().getDomElement()}bindEvents(){var e;const{graph:t}=this.context,{trigger:n,scaleRBy:i,scaleDBy:a}=this.options,s=t.getCanvas().getLayer();if(["click","drag"].includes(n)&&s.addEventListener(se.CLICK,this.onCreateFisheye),n==="pointermove"&&s.addEventListener(se.POINTER_MOVE,this.onCreateFisheye),n==="drag"||i==="drag"||a==="drag"){s.addEventListener(se.DRAG_START,this.onDragStart),s.addEventListener(se.DRAG_END,this.onDragEnd);const o=n==="drag"?this.onDrag:i==="drag"?this.scaleRByDrag:this.scaleDByDrag;s.addEventListener(se.DRAG,o)}if(i==="wheel"||a==="wheel"){const o=i==="wheel"?this.scaleRByWheel:this.scaleDByWheel;(e=this.graphDom)===null||e===void 0||e.addEventListener(se.WHEEL,o,{passive:!1})}}unbindEvents(){var e;const{graph:t}=this.context,{trigger:n,scaleRBy:i,scaleDBy:a}=this.options,s=t.getCanvas().getLayer();if(["click","drag"].includes(n)&&s.removeEventListener(se.CLICK,this.onCreateFisheye),n==="pointermove"&&s.removeEventListener(se.POINTER_MOVE,this.onCreateFisheye),n==="drag"||i==="drag"||a==="drag"){s.removeEventListener(se.DRAG_START,this.onDragStart),s.removeEventListener(se.DRAG_END,this.onDragEnd);const o=n==="drag"?this.onDrag:i==="drag"?this.scaleRByDrag:this.scaleDByDrag;s.removeEventListener(se.DRAG,o)}if(i==="wheel"||a==="wheel"){const o=i==="wheel"?this.scaleRByWheel:this.scaleDByWheel;(e=this.graphDom)===null||e===void 0||e.removeEventListener(se.WHEEL,o)}}update(e){var t,n;this.unbindEvents(),super.update(e),this.r=(t=e.r)!==null&&t!==void 0?t:this.r,this.d=(n=e.d)!==null&&n!==void 0?n:this.d,this.bindEvents()}destroy(){var e;this.unbindEvents(),this.isLensOn&&((e=this.lens)===null||e===void 0||e.destroy()),this.prevMagnifiedStyleMap.clear(),this.prevOriginStyleMap.clear(),super.destroy()}}Jd.defaultOptions={trigger:"pointermove",r:120,d:1.5,maxD:5,minD:0,showDPercent:!0,style:{},nodeStyle:{label:!0},preventDefault:!0};class ef extends Ln{constructor(e,t){super(e,Object.assign({},ef.defaultOptions,t)),this.$el=this.context.canvas.getContainer(),this.graphSize=[0,0],this.onFullscreenChange=()=>{var n,i,a,s;const o=!!document.fullscreenElement;this.options.autoFit&&this.setGraphSize(o),o?(i=(n=this.options).onEnter)===null||i===void 0||i.call(n):(s=(a=this.options).onExit)===null||s===void 0||s.call(a)},this.shortcut=new ss(e.graph),this.bindEvents(),this.style=document.createElement("style"),document.head.appendChild(this.style),this.style.innerHTML=`
|
|
47
|
+
:not(:root):fullscreen::backdrop {
|
|
48
|
+
background: transparent;
|
|
49
|
+
}
|
|
50
|
+
`}bindEvents(){this.unbindEvents(),this.shortcut.unbindAll();const{request:e=[],exit:t=[]}=this.options.trigger;this.shortcut.bind(e,this.request),this.shortcut.bind(t,this.exit),["webkitfullscreenchange","mozfullscreenchange","fullscreenchange","MSFullscreenChange"].forEach(i=>{document.addEventListener(i,this.onFullscreenChange,!1)})}unbindEvents(){this.shortcut.unbindAll(),["webkitfullscreenchange","mozfullscreenchange","fullscreenchange","MSFullscreenChange"].forEach(t=>{document.removeEventListener(t,this.onFullscreenChange,!1)})}setGraphSize(e=!0){var t,n;let i,a;e?(i=((t=globalThis.screen)===null||t===void 0?void 0:t.width)||0,a=((n=globalThis.screen)===null||n===void 0?void 0:n.height)||0,this.graphSize=this.context.graph.getSize()):[i,a]=this.graphSize,this.context.graph.setSize(i,a),this.context.graph.render()}request(){document.fullscreenElement||!ite()||this.$el.requestFullscreen().catch(e=>{$i.warn(`Error attempting to enable full-screen: ${e.message} (${e.name})`)})}exit(){document.fullscreenElement&&document.exitFullscreen()}update(e){this.unbindEvents(),super.update(e),this.bindEvents()}destroy(){this.exit(),this.style.remove(),super.destroy()}}ef.defaultOptions={trigger:{},autoFit:!0};function ite(){return document.fullscreenEnabled||Reflect.get(document,"webkitFullscreenEnabled")||Reflect.get(document,"mozFullscreenEnabled")||Reflect.get(document,"msFullscreenEnabled")}class tf extends Ln{constructor(e,t){super(e,Object.assign({},tf.defaultOptions,t)),this.$element=sA("grid-line",!0),this.offset=[0,0],this.currentScale=1,this.followZoom=i=>{const{data:{scale:a,origin:s}}=i;if(!a||s===void 0&&this.context.viewport===void 0)return;const o=this.currentScale;this.currentScale=a;const A=a/o,l=vi(s||this.context.graph.getCanvasCenter(),1-A),c=this.baseSize*a,u=vi(this.offset,A),h=vg(u,c),d=Ve(h,l);this.$element.style.backgroundSize=`${c}px ${c}px`,this.$element.style.backgroundPosition=`${d[0]}px ${d[1]}px`,this.offset=vg(d,c)},this.followTranslate=i=>{if(!this.options.follow)return;const{data:{translate:a}}=i;a&&this.updateOffset(a)},this.onTransform=i=>{const a=this.parseFollow(this.options.follow);a.zoom&&this.followZoom(i),a.translate&&this.followTranslate(i)},this.context.canvas.getContainer().prepend(this.$element),this.baseSize=this.options.size,this.updateStyle(),this.bindEvents()}update(e){super.update(e),e.size!==void 0&&(this.baseSize=e.size),this.updateStyle()}bindEvents(){const{graph:e}=this.context;e.on(ge.AFTER_TRANSFORM,this.onTransform)}updateStyle(){const{stroke:e,lineWidth:t,border:n,borderLineWidth:i,borderStroke:a,borderStyle:s}=this.options,o=this.baseSize*this.currentScale;Object.assign(this.$element.style,{border:n?`${i}px ${s} ${a}`:"none",backgroundImage:`linear-gradient(${e} ${t}px, transparent ${t}px), linear-gradient(90deg, ${e} ${t}px, transparent ${t}px)`,backgroundSize:`${o}px ${o}px`,backgroundRepeat:"repeat"})}updateOffset(e){const t=this.baseSize*this.currentScale;this.offset=vg(Ve(this.offset,e),t),this.$element.style.backgroundPosition=`${this.offset[0]}px ${this.offset[1]}px`}parseFollow(e){var t,n;return sl(e)?{translate:e,zoom:e}:{translate:(t=e==null?void 0:e.translate)!==null&&t!==void 0?t:!1,zoom:(n=e==null?void 0:e.zoom)!==null&&n!==void 0?n:!1}}destroy(){this.context.graph.off(ge.AFTER_TRANSFORM,this.onTransform),this.$element.remove(),super.destroy()}}tf.defaultOptions={border:!0,borderLineWidth:1,borderStroke:"#eee",borderStyle:"solid",lineWidth:1,size:20,stroke:"#eee"};function tb(r){const e={Added:new Map,Updated:new Map,Removed:new Map};return r.forEach(t=>{const{type:n,value:i}=t,a=Z(i);if(n==="NodeAdded"||n==="EdgeAdded"||n==="ComboAdded")e.Added.set(a,t);else if(n==="NodeUpdated"||n==="EdgeUpdated"||n==="ComboUpdated")if(e.Added.has(a))e.Added.set(a,{type:n.replace("Updated","Added"),value:i});else if(e.Updated.has(a)){const{original:s}=e.Updated.get(a);e.Updated.set(a,{type:n,value:i,original:s})}else e.Removed.has(a)||e.Updated.set(a,t);else(n==="NodeRemoved"||n==="EdgeRemoved"||n==="ComboRemoved")&&(e.Added.has(a)?e.Added.delete(a):(e.Updated.has(a)&&e.Updated.delete(a),e.Removed.set(a,t)))}),[...Array.from(e.Added.values()),...Array.from(e.Updated.values()),...Array.from(e.Removed.values())]}function KN(r){const{NodeAdded:e=[],NodeUpdated:t=[],NodeRemoved:n=[],EdgeAdded:i=[],EdgeUpdated:a=[],EdgeRemoved:s=[],ComboAdded:o=[],ComboUpdated:A=[],ComboRemoved:l=[]}=Nh(r,c=>c.type);return{add:{nodes:e,edges:i,combos:o},update:{nodes:t,edges:a,combos:A},remove:{nodes:n,edges:s,combos:l}}}function zN(r,e){for(const t in r)un(r[t])&&!Array.isArray(r[t])&&r[t]!==null?(e[t]||(e[t]={}),zN(r[t],e[t])):e[t]===void 0&&(e[t]=fl(t))}function ate(r,e=!1,t){const n={animation:e,current:{add:{},update:{},remove:{}},original:{add:{},update:{},remove:{}}},{add:i,update:a,remove:s}=KN(tb(r));return["nodes","edges","combos"].forEach(o=>{a[o]&&a[o].forEach(A=>{var l,c;const u=Object.assign({},A.value);let h=Object.assign({},A.original);if(t){const d=t.graph.getElementType(Z(A.original)),f=d==="edge"?"stroke":"fill",g=t.element.getElementComputedStyle(d,A.original);h=Object.assign(Object.assign({},A.original),{style:Object.assign({[f]:g[f]},A.original.style)})}zN(u,h),(l=n.current.update)[o]||(l[o]=[]),n.current.update[o].push(u),(c=n.original.update)[o]||(c[o]=[]),n.original.update[o].push(h)}),i[o]&&i[o].forEach(A=>{var l,c;const u=Object.assign({},A.value);(l=n.current.add)[o]||(l[o]=[]),n.current.add[o].push(u),(c=n.original.remove)[o]||(c[o]=[]),n.original.remove[o].push(u)}),s[o]&&s[o].forEach(A=>{var l,c;const u=Object.assign({},A.value);(l=n.current.remove)[o]||(l[o]=[]),n.current.remove[o].push(u),(c=n.original.add)[o]||(c[o]=[]),n.original.add[o].push(u)})}),n}class nf extends Ln{constructor(e,t){super(e,Object.assign({},nf.defaultOptions,t)),this.batchChanges=null,this.batchAnimation=!1,this.undoStack=[],this.redoStack=[],this.freezed=!1,this.executeCommand=(i,a=!0)=>{var s,o,A;this.freezed=!0,(o=(s=this.options).executeCommand)===null||o===void 0||o.call(s,i);const l=a?i.original:i.current;this.context.graph.addData(l.add),this.context.graph.updateData(l.update),this.context.graph.removeData(iL(l.remove,!1)),(A=this.context.element)===null||A===void 0||A.draw({silence:!0,animation:i.animation}),this.freezed=!1},this.addCommand=i=>{var a;if(!this.freezed){if(i.type===ge.AFTER_DRAW){const{dataChanges:s=[],animation:o=!0}=i.data;if(!((a=this.context.batch)===null||a===void 0)&&a.isBatching){if(!this.batchChanges)return;this.batchChanges.push(s),this.batchAnimation&&(this.batchAnimation=o);return}this.batchChanges=[s],this.batchAnimation=o}this.undoStackPush(ate(this.batchChanges.flat(),this.batchAnimation,this.context)),this.notify(_a.ADD,this.undoStack[this.undoStack.length-1])}},this.initBatchCommand=i=>{const{initiate:a}=i.data;this.batchAnimation=!1,a?this.batchChanges=[]:this.undoStack.pop()||(this.batchChanges=null)},this.emitter=new gd;const{graph:n}=this.context;n.on(ge.AFTER_DRAW,this.addCommand),n.on(ge.BATCH_START,this.initBatchCommand),n.on(ge.BATCH_END,this.addCommand)}canUndo(){return this.undoStack.length>0}canRedo(){return this.redoStack.length>0}undo(){var e,t,n,i;const a=this.undoStack.pop();if(a){if(this.executeCommand(a),((t=(e=this.options).beforeAddCommand)===null||t===void 0?void 0:t.call(e,a,!1))===!1)return;this.redoStack.push(a),(i=(n=this.options).afterAddCommand)===null||i===void 0||i.call(n,a,!1),this.notify(_a.UNDO,a)}return this}redo(){const e=this.redoStack.pop();return e&&(this.executeCommand(e,!1),this.undoStackPush(e),this.notify(_a.REDO,e)),this}undoAndCancel(){const e=this.undoStack.pop();return e&&(this.executeCommand(e,!1),this.redoStack=[],this.notify(_a.CANCEL,e)),this}undoStackPush(e){var t,n,i,a;const{stackSize:s}=this.options;s!==0&&this.undoStack.length>=s&&this.undoStack.shift(),((n=(t=this.options).beforeAddCommand)===null||n===void 0?void 0:n.call(t,e,!0))!==!1&&(this.undoStack.push(e),(a=(i=this.options).afterAddCommand)===null||a===void 0||a.call(i,e,!0))}clear(){this.undoStack=[],this.redoStack=[],this.batchChanges=null,this.batchAnimation=!1,this.notify(_a.CLEAR,null)}notify(e,t){this.emitter.emit(e,{cmd:t}),this.emitter.emit(_a.CHANGE,{cmd:t})}on(e,t){this.emitter.on(e,t)}destroy(){const{graph:e}=this.context;e.off(ge.AFTER_DRAW,this.addCommand),e.off(ge.BATCH_START,this.initBatchCommand),e.off(ge.BATCH_END,this.addCommand),this.emitter.off(),super.destroy(),this.undoStack=[],this.redoStack=[]}}nf.defaultOptions={stackSize:0};const Zm={toXy(r,e){if(!e)return[...r];const t=e[0].slice(1),n=e[1].slice(1);return r.map(i=>[i[t],i[n]])},fromXy(r,e){if(!e)return[...r];const t=e[0].slice(1),n=e[1].slice(1);return r.map(([i,a])=>({[t]:i,[n]:a}))}};let ste=class{constructor(e,t){this._cells=[],this._cellSize=t,this._reverseCellSize=1/t;for(const n of e){const i=this.coordToCellNum(n[0]),a=this.coordToCellNum(n[1]);this._cells[i]||(this._cells[i]=[]),this._cells[i][a]||(this._cells[i][a]=[]),this._cells[i][a].push(n)}}cellPoints(e,t){var n;return((n=this._cells[e])===null||n===void 0?void 0:n[t])||[]}rangePoints(e){const t=this.coordToCellNum(e[0]),n=this.coordToCellNum(e[1]),i=this.coordToCellNum(e[2]),a=this.coordToCellNum(e[3]),s=[];for(let o=t;o<=i;o++)for(let A=n;A<=a;A++){const l=this.cellPoints(o,A);for(const c of l)s.push(c)}return s}removePoint(e){const t=this.coordToCellNum(e[0]),n=this.coordToCellNum(e[1]),i=this._cells[t][n],a=i.findIndex(([s,o])=>s===e[0]&&o===e[1]);return a>-1&&i.splice(a,1),i}trunc(e){return Math.trunc(e)}coordToCellNum(e){return this.trunc(e*this._reverseCellSize)}extendBbox(e,t){return[e[0]-t*this._cellSize,e[1]-t*this._cellSize,e[2]+t*this._cellSize,e[3]+t*this._cellSize]}};function ote(r,e){return new ste(r,e)}const iO=+(Math.pow(2,27)+1);function Uu(r,e,t){const n=r*e,i=iO*r,a=i-r,s=i-a,o=r-s,A=iO*e,l=A-e,c=A-l,u=e-c,f=n-s*c-o*c-s*u,g=o*u-f;return t?(t[0]=g,t[1]=n,t):[g,n]}function Ate(r,e,t){const n=r+e,i=n-r,a=n-i,s=e-i,o=r-a;return t?(t[0]=o+s,t[1]=n,t):[o+s,n]}function lte(r,e){const t=r.length;if(t===1){const o=Uu(r[0],e);return o[0]?o:[o[1]]}const n=new Array(2*t),i=[.1,.1],a=[.1,.1];let s=0;Uu(r[0],e,i),i[0]&&(n[s++]=i[0]);for(let o=1;o<t;++o){Uu(r[o],e,a);const A=i[1];Ate(A,a[0],i),i[0]&&(n[s++]=i[0]);const l=a[1],c=i[1],u=l+c,h=u-l,d=c-h;i[1]=u,d&&(n[s++]=d)}return i[1]&&(n[s++]=i[1]),s===0&&(n[s++]=0),n.length=s,n}function cte(r,e){const t=r+e,n=t-r,i=t-n,a=e-n,o=r-i+a;return o?[o,t]:[t]}function ute(r,e){const t=r.length|0,n=e.length|0;if(t===1&&n===1)return cte(r[0],-e[0]);const i=t+n,a=new Array(i);let s=0,o=0,A=0;const l=Math.abs;let c=r[o],u=l(c),h=-e[A],d=l(h),f,g;u<d?(g=c,o+=1,o<t&&(c=r[o],u=l(c))):(g=h,A+=1,A<n&&(h=-e[A],d=l(h))),o<t&&u<d||A>=n?(f=c,o+=1,o<t&&(c=r[o],u=l(c))):(f=h,A+=1,A<n&&(h=-e[A],d=l(h)));let v=f+g,p=v-f,y=g-p,m=y,B=v,C,S,F,T,O;for(;o<t&&A<n;)u<d?(f=c,o+=1,o<t&&(c=r[o],u=l(c))):(f=h,A+=1,A<n&&(h=-e[A],d=l(h))),g=m,v=f+g,p=v-f,y=g-p,y&&(a[s++]=y),C=B+v,S=C-B,F=C-S,T=v-S,O=B-F,m=O+T,B=C;for(;o<t;)f=c,g=m,v=f+g,p=v-f,y=g-p,y&&(a[s++]=y),C=B+v,S=C-B,F=C-S,T=v-S,O=B-F,m=O+T,B=C,o+=1,o<t&&(c=r[o]);for(;A<n;)f=h,g=m,v=f+g,p=v-f,y=g-p,y&&(a[s++]=y),C=B+v,S=C-B,F=C-S,T=v-S,O=B-F,m=O+T,B=C,A+=1,A<n&&(h=-e[A]);return m&&(a[s++]=m),B&&(a[s++]=B),s||(a[s++]=0),a.length=s,a}function hte(r,e){const t=r+e,n=t-r,i=t-n,a=e-n,o=r-i+a;return o?[o,t]:[t]}function dte(r,e){const t=r.length|0,n=e.length|0;if(t===1&&n===1)return hte(r[0],e[0]);const i=t+n,a=new Array(i);let s=0,o=0,A=0;const l=Math.abs;let c=r[o],u=l(c),h=e[A],d=l(h),f,g;u<d?(g=c,o+=1,o<t&&(c=r[o],u=l(c))):(g=h,A+=1,A<n&&(h=e[A],d=l(h))),o<t&&u<d||A>=n?(f=c,o+=1,o<t&&(c=r[o],u=l(c))):(f=h,A+=1,A<n&&(h=e[A],d=l(h)));let v=f+g,p=v-f,y=g-p,m=y,B=v,C,S,F,T,O;for(;o<t&&A<n;)u<d?(f=c,o+=1,o<t&&(c=r[o],u=l(c))):(f=h,A+=1,A<n&&(h=e[A],d=l(h))),g=m,v=f+g,p=v-f,y=g-p,y&&(a[s++]=y),C=B+v,S=C-B,F=C-S,T=v-S,O=B-F,m=O+T,B=C;for(;o<t;)f=c,g=m,v=f+g,p=v-f,y=g-p,y&&(a[s++]=y),C=B+v,S=C-B,F=C-S,T=v-S,O=B-F,m=O+T,B=C,o+=1,o<t&&(c=r[o]);for(;A<n;)f=h,g=m,v=f+g,p=v-f,y=g-p,y&&(a[s++]=y),C=B+v,S=C-B,F=C-S,T=v-S,O=B-F,m=O+T,B=C,A+=1,A<n&&(h=e[A]);return m&&(a[s++]=m),B&&(a[s++]=B),s||(a[s++]=0),a.length=s,a}const aO=5,_h=11102230246251565e-32,fte=(3+16*_h)*_h,gte=(7+56*_h)*_h;function vte(r,e,t,n){return function(a,s,o){const A=r(r(e(s[1],o[0]),e(-o[1],s[0])),r(e(a[1],s[0]),e(-s[1],a[0]))),l=r(e(a[1],o[0]),e(-o[1],a[0])),c=n(A,l);return c[c.length-1]}}function pte(r,e,t,n){return function(a,s,o,A){const l=r(r(t(r(e(o[1],A[0]),e(-A[1],o[0])),s[2]),r(t(r(e(s[1],A[0]),e(-A[1],s[0])),-o[2]),t(r(e(s[1],o[0]),e(-o[1],s[0])),A[2]))),r(t(r(e(s[1],A[0]),e(-A[1],s[0])),a[2]),r(t(r(e(a[1],A[0]),e(-A[1],a[0])),-s[2]),t(r(e(a[1],s[0]),e(-s[1],a[0])),A[2])))),c=r(r(t(r(e(o[1],A[0]),e(-A[1],o[0])),a[2]),r(t(r(e(a[1],A[0]),e(-A[1],a[0])),-o[2]),t(r(e(a[1],o[0]),e(-o[1],a[0])),A[2]))),r(t(r(e(s[1],o[0]),e(-o[1],s[0])),a[2]),r(t(r(e(a[1],o[0]),e(-o[1],a[0])),-s[2]),t(r(e(a[1],s[0]),e(-s[1],a[0])),o[2])))),u=n(l,c);return u[u.length-1]}}function yte(r,e,t,n){return function(a,s,o,A,l){const c=r(r(r(t(r(t(r(e(A[1],l[0]),e(-l[1],A[0])),o[2]),r(t(r(e(o[1],l[0]),e(-l[1],o[0])),-A[2]),t(r(e(o[1],A[0]),e(-A[1],o[0])),l[2]))),s[3]),r(t(r(t(r(e(A[1],l[0]),e(-l[1],A[0])),s[2]),r(t(r(e(s[1],l[0]),e(-l[1],s[0])),-A[2]),t(r(e(s[1],A[0]),e(-A[1],s[0])),l[2]))),-o[3]),t(r(t(r(e(o[1],l[0]),e(-l[1],o[0])),s[2]),r(t(r(e(s[1],l[0]),e(-l[1],s[0])),-o[2]),t(r(e(s[1],o[0]),e(-o[1],s[0])),l[2]))),A[3]))),r(t(r(t(r(e(o[1],A[0]),e(-A[1],o[0])),s[2]),r(t(r(e(s[1],A[0]),e(-A[1],s[0])),-o[2]),t(r(e(s[1],o[0]),e(-o[1],s[0])),A[2]))),-l[3]),r(t(r(t(r(e(A[1],l[0]),e(-l[1],A[0])),s[2]),r(t(r(e(s[1],l[0]),e(-l[1],s[0])),-A[2]),t(r(e(s[1],A[0]),e(-A[1],s[0])),l[2]))),a[3]),t(r(t(r(e(A[1],l[0]),e(-l[1],A[0])),a[2]),r(t(r(e(a[1],l[0]),e(-l[1],a[0])),-A[2]),t(r(e(a[1],A[0]),e(-A[1],a[0])),l[2]))),-s[3])))),r(r(t(r(t(r(e(s[1],l[0]),e(-l[1],s[0])),a[2]),r(t(r(e(a[1],l[0]),e(-l[1],a[0])),-s[2]),t(r(e(a[1],s[0]),e(-s[1],a[0])),l[2]))),A[3]),r(t(r(t(r(e(s[1],A[0]),e(-A[1],s[0])),a[2]),r(t(r(e(a[1],A[0]),e(-A[1],a[0])),-s[2]),t(r(e(a[1],s[0]),e(-s[1],a[0])),A[2]))),-l[3]),t(r(t(r(e(o[1],A[0]),e(-A[1],o[0])),s[2]),r(t(r(e(s[1],A[0]),e(-A[1],s[0])),-o[2]),t(r(e(s[1],o[0]),e(-o[1],s[0])),A[2]))),a[3]))),r(t(r(t(r(e(o[1],A[0]),e(-A[1],o[0])),a[2]),r(t(r(e(a[1],A[0]),e(-A[1],a[0])),-o[2]),t(r(e(a[1],o[0]),e(-o[1],a[0])),A[2]))),-s[3]),r(t(r(t(r(e(s[1],A[0]),e(-A[1],s[0])),a[2]),r(t(r(e(a[1],A[0]),e(-A[1],a[0])),-s[2]),t(r(e(a[1],s[0]),e(-s[1],a[0])),A[2]))),o[3]),t(r(t(r(e(s[1],o[0]),e(-o[1],s[0])),a[2]),r(t(r(e(a[1],o[0]),e(-o[1],a[0])),-s[2]),t(r(e(a[1],s[0]),e(-s[1],a[0])),o[2]))),-A[3]))))),u=r(r(r(t(r(t(r(e(A[1],l[0]),e(-l[1],A[0])),o[2]),r(t(r(e(o[1],l[0]),e(-l[1],o[0])),-A[2]),t(r(e(o[1],A[0]),e(-A[1],o[0])),l[2]))),a[3]),t(r(t(r(e(A[1],l[0]),e(-l[1],A[0])),a[2]),r(t(r(e(a[1],l[0]),e(-l[1],a[0])),-A[2]),t(r(e(a[1],A[0]),e(-A[1],a[0])),l[2]))),-o[3])),r(t(r(t(r(e(o[1],l[0]),e(-l[1],o[0])),a[2]),r(t(r(e(a[1],l[0]),e(-l[1],a[0])),-o[2]),t(r(e(a[1],o[0]),e(-o[1],a[0])),l[2]))),A[3]),t(r(t(r(e(o[1],A[0]),e(-A[1],o[0])),a[2]),r(t(r(e(a[1],A[0]),e(-A[1],a[0])),-o[2]),t(r(e(a[1],o[0]),e(-o[1],a[0])),A[2]))),-l[3]))),r(r(t(r(t(r(e(o[1],l[0]),e(-l[1],o[0])),s[2]),r(t(r(e(s[1],l[0]),e(-l[1],s[0])),-o[2]),t(r(e(s[1],o[0]),e(-o[1],s[0])),l[2]))),a[3]),t(r(t(r(e(o[1],l[0]),e(-l[1],o[0])),a[2]),r(t(r(e(a[1],l[0]),e(-l[1],a[0])),-o[2]),t(r(e(a[1],o[0]),e(-o[1],a[0])),l[2]))),-s[3])),r(t(r(t(r(e(s[1],l[0]),e(-l[1],s[0])),a[2]),r(t(r(e(a[1],l[0]),e(-l[1],a[0])),-s[2]),t(r(e(a[1],s[0]),e(-s[1],a[0])),l[2]))),o[3]),t(r(t(r(e(s[1],o[0]),e(-o[1],s[0])),a[2]),r(t(r(e(a[1],o[0]),e(-o[1],a[0])),-s[2]),t(r(e(a[1],s[0]),e(-s[1],a[0])),o[2]))),-l[3])))),h=n(c,u);return h[h.length-1]}}function rf(r){return(r===3?vte:r===4?pte:yte)(dte,Uu,lte,ute)}const mte=rf(3),wte=rf(4),Cs=[function(){return 0},function(){return 0},function(e,t){return t[0]-e[0]},function(e,t,n){const i=(e[1]-n[1])*(t[0]-n[0]),a=(e[0]-n[0])*(t[1]-n[1]),s=i-a;let o;if(i>0){if(a<=0)return s;o=i+a}else if(i<0){if(a>=0)return s;o=-(i+a)}else return s;const A=fte*o;return s>=A||s<=-A?s:mte(e,t,n)},function(e,t,n,i){const a=e[0]-i[0],s=t[0]-i[0],o=n[0]-i[0],A=e[1]-i[1],l=t[1]-i[1],c=n[1]-i[1],u=e[2]-i[2],h=t[2]-i[2],d=n[2]-i[2],f=s*c,g=o*l,v=o*A,p=a*c,y=a*l,m=s*A,B=u*(f-g)+h*(v-p)+d*(y-m),C=(Math.abs(f)+Math.abs(g))*Math.abs(u)+(Math.abs(v)+Math.abs(p))*Math.abs(h)+(Math.abs(y)+Math.abs(m))*Math.abs(d),S=gte*C;return B>S||-B>S?B:wte(e,t,n,i)}];function Bte(r){let e=Cs[r.length];return e||(e=Cs[r.length]=rf(r.length)),e.apply(void 0,...r)}function bte(r,e,t,n,i,a,s){return function(...A){switch(A.length){case 0:case 1:return 0;case 2:return n(A[0],A[1]);case 3:return i(A[0],A[1],A[2]);case 4:return a(A[0],A[1],A[2],A[3]);case 5:return s(A[0],A[1],A[2],A[3],A[4])}return r(A)}}function Ete(){for(;Cs.length<=aO;)Cs.push(rf(Cs.length));const r=bte(void 0,Bte,...Cs);for(let e=0;e<=aO;++e)r[e]=Cs[e];return r}const zA=Ete(),sO=zA[3];function xte(r){const e=r.length;if(e<3){const o=new Array(e);for(let A=0;A<e;++A)o[A]=A;return e===2&&r[0][0]===r[1][0]&&r[0][1]===r[1][1]?[0]:o}const t=new Array(e);for(let o=0;o<e;++o)t[o]=o;t.sort((o,A)=>{const l=r[o][0]-r[A][0];return l||r[o][1]-r[A][1]});const n=[t[0],t[1]],i=[t[0],t[1]];for(let o=2;o<e;++o){const A=t[o],l=r[A];let c=n.length;for(;c>1&&sO(r[n[c-2]],r[n[c-1]],l)<=0;)c-=1,n.pop();for(n.push(A),c=i.length;c>1&&sO(r[i[c-2]],r[i[c-1]],l)>=0;)c-=1,i.pop();i.push(A)}const a=new Array(i.length+n.length-2);let s=0;for(let o=0,A=n.length;o<A;++o)a[s++]=n[o];for(let o=i.length-2;o>0;--o)a[s++]=i[o];return a}function Cte(r,e,t,n){for(let i=0;i<2;++i){const a=r[i],s=e[i],[o,A]=[Math.min(a,s),Math.max(a,s)],l=t[i],c=n[i],[u,h]=[Math.min(l,c),Math.max(l,c)];if(h<o||A<u)return!1}return!0}function Ste(r,e,t,n){const i=zA(r,t,n),a=zA(e,t,n);if(i>0&&a>0||i<0&&a<0)return!1;const s=zA(t,r,e),o=zA(n,r,e);return s>0&&o>0||s<0&&o<0?!1:i===0&&a===0&&s===0&&o===0?Cte(r,e,t,n):!0}function Fte(r){const e=[r[0]];let t=r[0];for(let n=1;n<r.length;n++){const i=r[n];(t[0]!==i[0]||t[1]!==i[1])&&e.push(i),t=i}return e}function Tte(r){return r.sort(function(e,t){return e[0]-t[0]||e[1]-t[1]})}function F1(r,e){return Math.pow(e[0]-r[0],2)+Math.pow(e[1]-r[1],2)}function oO(r,e,t){const n=[e[0]-r[0],e[1]-r[1]],i=[t[0]-r[0],t[1]-r[1]],a=F1(r,e),s=F1(r,t);return(n[0]*i[0]+n[1]*i[1])/Math.sqrt(a*s)}function AO(r,e){for(let t=0;t<e.length-1;t++){const n=[e[t],e[t+1]];if(!(r[0][0]===n[0][0]&&r[0][1]===n[0][1]||r[0][0]===n[1][0]&&r[0][1]===n[1][1])&&Ste(r[0],r[1],n[0],n[1]))return!0}return!1}function Mte(r){let e=1/0,t=1/0,n=-1/0,i=-1/0;for(let a=r.length-1;a>=0;a--)r[a][0]<e&&(e=r[a][0]),r[a][1]<t&&(t=r[a][1]),r[a][0]>n&&(n=r[a][0]),r[a][1]>i&&(i=r[a][1]);return[n-e,i-t]}function Ote(r){return[Math.min(r[0][0],r[1][0]),Math.min(r[0][1],r[1][1]),Math.max(r[0][0],r[1][0]),Math.max(r[0][1],r[1][1])]}function _te(r,e,t){let n=null,i=lO,a=lO,s,o;for(let A=0;A<e.length;A++)s=oO(r[0],r[1],e[A]),o=oO(r[1],r[0],e[A]),s>i&&o>a&&!AO([r[0],e[A]],t)&&!AO([r[1],e[A]],t)&&(i=s,a=o,n=e[A]);return n}function VN(r,e,t,n,i){let a=!1;for(let s=0;s<r.length-1;s++){const o=[r[s],r[s+1]],A=o[0][0]+","+o[0][1]+","+o[1][0]+","+o[1][1];if(F1(o[0],o[1])<e||i.has(A))continue;let l=0,c=Ote(o),u,h,d;do c=n.extendBbox(c,l),u=c[2]-c[0],h=c[3]-c[1],d=_te(o,n.rangePoints(c),r),l++;while(d===null&&(t[0]>u||t[1]>h));u>=t[0]&&h>=t[1]&&i.add(A),d!==null&&(r.splice(s+1,0,d),n.removePoint(d),a=!0)}return a?VN(r,e,t,n,i):r}function Ite(r,e,t){const n=e||20,i=Fte(Tte(Zm.toXy(r,t)));if(i.length<4){const u=i.concat([i[0]]);return t?Zm.fromXy(u,t):u}const a=Mte(i),s=[a[0]*cO,a[1]*cO],o=xte(i).reverse().map(u=>i[u]);o.push(o[0]);const A=i.filter(function(u){return o.indexOf(u)<0}),l=Math.ceil(1/(i.length/(a[0]*a[1]))),c=VN(o,Math.pow(n,2),s,ote(A,l),new Set);return t?Zm.fromXy(c,t):c}const lO=Math.cos(90/(180/Math.PI)),cO=.6;function kte(r,e,t){if(r.length===1)return Lte(r[0],e,t);if(r.length===2)return uO(r,e,t);if(r.length===3){const[n,i,a]=BB(r);if(hL(n,i,a))return uO([n,a],e,t)}switch(t){case"smooth":return Nte(r,e);case"sharp":return Ute(r,e);default:return Qte(r,e)}}const Lte=(r,e,t)=>{if(t==="sharp")return[["M",r[0]-e,r[1]-e],["L",r[0]+e,r[1]-e],["L",r[0]+e,r[1]+e],["L",r[0]-e,r[1]+e],["Z"]];const n=[e,e,0,0,0];return[["M",r[0],r[1]-e],["A",...n,r[0],r[1]+e],["A",...n,r[0],r[1]-e]]},uO=(r,e,t)=>{const n=[e,e,0,0,0],i=t==="sharp"?Ve(r[0],Da(fa(bt(r[0],r[1])),e)):r[0],a=t==="sharp"?Ve(r[1],Da(fa(bt(r[1],r[0])),e)):r[1],s=Da(fa(ed(bt(i,a),!1)),e),o=Da(s,-1),A=Ve(i,s),l=Ve(a,s),c=Ve(a,o),u=Ve(i,o);return t==="sharp"?[["M",A[0],A[1]],["L",l[0],l[1]],["L",c[0],c[1]],["L",u[0],u[1]],["Z"]]:[["M",A[0],A[1]],["L",l[0],l[1]],["A",...n,c[0],c[1]],["L",u[0],u[1]],["A",...n,A[0],A[1]]]},Qte=(r,e)=>{const t=BB(r).map((o,A)=>{const l=(A-2+r.length)%r.length,c=(A-1+r.length)%r.length,u=(A+1)%r.length,h=r[l],d=r[c],f=r[u],g=bt(h,d),v=bt(d,o),p=bt(o,f),y=(F,T)=>mB(F,T,!0)<Math.PI,m=y(g,v),B=y(v,p),C=F=>Da(fa(ed(F,!1)),e),S=C(v);return[{p:js(m?Ve(d,C(g)):Ve(d,S)),concave:m&&d},{p:js(B?Ve(o,C(p)):Ve(o,S)),concave:B&&o}]}),n=[e,e,0,0,0],i=t.findIndex((o,A)=>!t[(A-1+t.length)%t.length][0].concave&&!t[(A-1+t.length)%t.length][1].concave&&!o[0].concave&&!o[0].concave&&!o[1].concave),a=t.slice(i).concat(t.slice(0,i));let s=[];return a.flatMap((o,A)=>{const l=[],c=a[t.length-1];return A===0&&l.push(["M",...c[1].p]),o[0].concave?s.push(o[0].p,o[1].p):l.push(["A",...n,...o[0].p]),o[1].concave?s.unshift(o[1].p):l.push(["L",...o[1].p]),s.length===3&&(l.pop(),l.push(["C",...s.flat()]),s=[]),l})},Nte=(r,e)=>{const t=BB(r).map((n,i)=>{const a=r[(i+1)%r.length];return{p:n,v:fa(bt(a,n))}});return t.forEach((n,i)=>{const a=i>0?i-1:r.length-1,s=t[a].v,o=fa(Ve(s,Da(n.v,mB(s,n.v,!0)<Math.PI?1:-1)));n.p=Ve(n.p,Da(o,e))}),BL(t.map(n=>n.p))},Ute=(r,e)=>{const n=r.map((a,s)=>{const o=r[s===0?r.length-1:s-1],A=gl(Da(fa(ed(bt(o,a),!1)),e));return[Ve(o,A),Ve(a,A)]}).flat();return n.map((a,s)=>{if(s%2===0)return null;const o=[n[(s-1)%n.length],n[s%n.length]],A=[n[(s+1)%n.length],n[(s+2)%n.length]];return wB(o,A,!0)}).filter(Boolean).map((a,s)=>[s===0?"M":"L",a[0],a[1]]).concat([["Z"]])};var Pte=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class af extends Ln{constructor(e,t){super(e,Object.assign({},af.defaultOptions,t)),this.hullMemberIds=[],this.drawHull=()=>{if(!this.shape)this.shape=new Pl({style:this.getHullStyle()}),this.context.canvas.appendChild(this.shape);else{const n=!Xt(this.optionsCache,this.options);this.shape.update(this.getHullStyle(n))}this.optionsCache=Object.assign({},this.options)},this.updateHullPath=n=>{this.shape&&this.options.members.includes(Z(n.data))&&this.shape.update({d:this.getHullPath(!0)})},this.getHullPath=(n=!1)=>{const{graph:i}=this.context,a=this.getMember();if(a.length===0)return"";const s=a.map(l=>i.getNodeData(l)),o=Ite(s.map(Sn),this.options.concavity).slice(1).reverse(),A=o.flatMap(l=>s.filter(c=>Xt(Sn(c),l)).map(Z));return Xt(A,this.hullMemberIds)&&!n?this.path:(this.hullMemberIds=A,this.path=kte(o,this.getPadding(),this.options.corner),this.path)},this.bindEvents()}bindEvents(){this.context.graph.on(ge.AFTER_RENDER,this.drawHull),this.context.graph.on(ge.AFTER_ELEMENT_UPDATE,this.updateHullPath)}unbindEvents(){this.context.graph.off(ge.AFTER_RENDER,this.drawHull),this.context.graph.off(ge.AFTER_ELEMENT_UPDATE,this.updateHullPath)}getHullStyle(e){const t=this.options,{members:n,padding:i,corner:a}=t,s=Pte(t,["members","padding","corner"]);return Object.assign(Object.assign({},s),{d:this.getHullPath(e)})}getPadding(){const{graph:e}=this.context;return this.hullMemberIds.reduce((n,i)=>{const{halfExtents:a}=e.getElementRenderBounds(i),s=Math.max(a[0],a[1]);return Math.max(n,s)},0)+this.options.padding}addMember(e){const t=Array.isArray(e)?e:[e];this.options.members=[...new Set([...this.options.members,...t])],this.shape.update({d:this.getHullPath()})}removeMember(e){const t=Array.isArray(e)?e:[e];this.options.members=this.options.members.filter(n=>!t.includes(n)),t.some(n=>this.hullMemberIds.includes(n))&&this.shape.update({d:this.getHullPath()})}updateMember(e){this.options.members=Te(e)?e(this.options.members):e,this.shape.update(this.getHullStyle(!0))}getMember(){return this.options.members}destroy(){this.unbindEvents(),this.shape.destroy(),this.hullMemberIds=[],super.destroy()}}af.defaultOptions={members:[],padding:10,corner:"rounded",concavity:1/0,fill:"lightblue",fillOpacity:.2,labelOpacity:1,stroke:"blue",strokeOpacity:.2};function jN(r,e){e(r),r.children&&r.children.forEach(function(t){t&&jN(t,e)})}function Yl(r){sf(r,!0)}function yi(r){sf(r,!1)}function sf(r,e){var t=e?"visible":"hidden";jN(r,function(n){n.attr("visibility",t)})}var Rte=(function(r){Xe(e,r);function e(){for(var t=[],n=0;n<arguments.length;n++)t[n]=arguments[n];var i=r.apply(this,_e([],H(t),!1))||this;return i.isMutationObserved=!0,i.addEventListener(it.INSERTED,function(){yi(i)}),i}return e})(Tn);function WN(r){var e=r.appendChild(new Rte({class:"offscreen"}));return yi(e),e}function Dte(r){for(var e=r;e;){if(e.className==="offscreen")return!0;e=e.parent}return!1}var nb=(function(r){Xe(e,r);function e(t){t===void 0&&(t={});var n=t.style,i=Dt(t,["style"]);return r.call(this,le({style:le({text:"",fill:"black",fontFamily:"sans-serif",fontSize:16,fontStyle:"normal",fontVariant:"normal",fontWeight:"normal",lineWidth:1,textAlign:"start",textBaseline:"middle"},n)},i))||this}return Object.defineProperty(e.prototype,"offscreenGroup",{get:function(){return this._offscreen||(this._offscreen=WN(this)),this._offscreen},enumerable:!1,configurable:!0}),e.prototype.disconnectedCallback=function(){var t;(t=this._offscreen)===null||t===void 0||t.destroy()},e})(Zs);function Yo(r){return r*Math.PI/180}function qN(r){return Number((r*180/Math.PI).toPrecision(5))}var dr=(function(){function r(e,t,n,i){e===void 0&&(e=0),t===void 0&&(t=0),n===void 0&&(n=0),i===void 0&&(i=0),this.x=0,this.y=0,this.width=0,this.height=0,this.x=e,this.y=t,this.width=n,this.height=i}return Object.defineProperty(r.prototype,"bottom",{get:function(){return this.y+this.height},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"left",{get:function(){return this.x},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"right",{get:function(){return this.x+this.width},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"top",{get:function(){return this.y},enumerable:!1,configurable:!0}),r.fromRect=function(e){return new r(e.x,e.y,e.width,e.height)},r.prototype.toJSON=function(){return{x:this.x,y:this.y,width:this.width,height:this.height,top:this.top,right:this.right,bottom:this.bottom,left:this.left}},r.prototype.isPointIn=function(e,t){return e>=this.left&&e<=this.right&&t>=this.top&&t<=this.bottom},r})();function Tr(r,e){return Te(r)?r.apply(void 0,_e([],H(e),!1)):r}var Si=function(r,e){var t=function(i){return"".concat(e,"-").concat(i)},n=Object.fromEntries(Object.entries(r).map(function(i){var a=H(i,2),s=a[0],o=a[1],A=t(o);return[s,{name:A,class:".".concat(A),id:"#".concat(A),toString:function(){return A}}]}));return Object.assign(n,{prefix:t}),n},Hte=5,$N=function(r,e,t,n){t===void 0&&(t=0),n===void 0&&(n=Hte),Object.entries(e).forEach(function(i){var a=H(i,2),s=a[0],o=a[1],A=r;Object.prototype.hasOwnProperty.call(e,s)&&(o?zo(o)?(zo(r[s])||(A[s]={}),t<n?$N(r[s],o,t+1,n):A[s]=e[s]):Mr(o)?(A[s]=[],A[s]=A[s].concat(o)):A[s]=o:A[s]=o)})},wn=function(r){for(var e=[],t=1;t<arguments.length;t++)e[t-1]=arguments[t];for(var n=0;n<e.length;n+=1)$N(r,e[n]);return r},Gte=function(r){return r!==void 0&&r!=null&&!Number.isNaN(r)},Bu,Kte=mw(function(r,e){var t=e.fontSize,n=e.fontFamily,i=e.fontWeight,a=e.fontStyle,s=e.fontVariant;return Bu||(Bu=de.offscreenCanvasCreator.getOrCreateContext(void 0)),Bu.font=[a,s,i,"".concat(t,"px"),n].join(" "),Bu.measureText(r).width},function(r,e){return[r,Object.values(e||YN(r)).join()].join("")},4096),YN=function(r){var e=r.style.fontFamily||"sans-serif",t=r.style.fontWeight||"normal",n=r.style.fontStyle||"normal",i=r.style.fontVariant,a=r.style.fontSize;return a=typeof a=="object"?a.value:a,{fontSize:a,fontFamily:e,fontWeight:t,fontStyle:n,fontVariant:i}};function XN(r){return r.nodeName==="text"?r:r.nodeName==="g"&&r.children.length===1&&r.children[0].nodeName==="text"?r.children[0]:null}function ZN(r,e){var t=XN(r);t&&t.attr(e)}function T1(r,e,t){t===void 0&&(t="..."),ZN(r,{wordWrap:!0,wordWrapWidth:e,maxLines:1,textOverflow:t})}function zte(r,e,t,n){t===void 0&&(t=2),n===void 0&&(n="top"),ZN(r,{wordWrap:!0,wordWrapWidth:e,maxLines:t,textBaseline:n})}function hO(r){var e=r.nativeEvent,t=r.touches,n=r.clientX,i=r.clientY;if(e)return[e.clientX,e.clientY];if(t){var a=t[0],s=a.clientX,o=a.clientY;return[s,o]}return typeof n=="number"&&typeof i=="number"?[n,i]:[0,0]}function ya(r){return typeof r=="function"?r():At(r)||Be(r)?new nb({style:{text:String(r)}}):r}function Vte(r,e){return typeof r=="function"?r():At(r)||Be(r)?new Ys({style:le(le({pointerEvents:"auto"},e),{innerHTML:r})}):r}function jte(r,e){return r.reduce(function(t,n){return(t[n[e]]=t[n[e]]||[]).push(n),t},{})}function Fr(r,e,t,n,i){return n===void 0&&(n=!0),i===void 0&&(i=function(a){a.node().removeChildren()}),r?t(e):(n&&i(e),null)}function Pn(r,e,t,n,i){return n===void 0&&(n=!0),i===void 0&&(i=!1),n&&r===e||i&&r===t?!0:r>e&&r<t}var Wte=function(r,e){return function(t){return r*(1-t)+e*t}};function qte(r,e){var t=e?e.length:0,n=r?Math.min(t,r.length):0;return function(i){var a=new Array(n),s=new Array(t),o=0;for(o=0;o<n;++o)a[o]=rb(r[o],e[o]);for(;o<t;++o)s[o]=e[o];for(o=0;o<n;++o)s[o]=a[o](i);return s}}function $te(r,e){r===void 0&&(r={}),e===void 0&&(e={});var t={},n={};return Object.entries(e).forEach(function(i){var a=H(i,2),s=a[0],o=a[1];s in r?t[s]=rb(r[s],o):n[s]=o}),function(i){return Object.entries(t).forEach(function(a){var s=H(a,2),o=s[0],A=s[1];return n[o]=A(i)}),n}}function rb(r,e){return typeof r=="number"&&typeof e=="number"?Wte(r,e):Array.isArray(r)&&Array.isArray(e)?qte(r,e):typeof r=="object"&&typeof e=="object"?$te(r,e):(function(t){return r})}function Yte(r,e,t,n){if(!n)return r.attr("__keyframe_data__",t),null;var i=n.duration,a=i===void 0?0:i,s=rb(e,t),o=Math.ceil(+a/16),A=new Array(o).fill(0).map(function(l,c,u){return{__keyframe_data__:s(c/(u.length-1))}});return r.animate(A,le({fill:"both"},n))}function ca(r,e){return[r[0]*e,r[1]*e]}function VA(r,e){return[r[0]+e[0],r[1]+e[1]]}function Jm(r,e){return[r[0]-e[0],r[1]-e[1]]}function ps(r,e){return[Math.min(r[0],e[0]),Math.min(r[1],e[1])]}function ys(r,e){return[Math.max(r[0],e[0]),Math.max(r[1],e[1])]}function El(r,e){return Math.sqrt(Math.pow(r[0]-e[0],2)+Math.pow(r[1]-e[1],2))}function JN(r){if(r[0]===0&&r[1]===0)return[0,0];var e=Math.sqrt(Math.pow(r[0],2)+Math.pow(r[1],2));return[r[0]/e,r[1]/e]}function Xte(r,e){return e?[r[1],-r[0]]:[-r[1],r[0]]}function dO(r,e){return+r.toPrecision(e)}function M1(r,e){var t={},n=Array.isArray(e)?e:[e];for(var i in r)n.includes(i)||(t[i]=r[i]);return t}function Zte(r,e,t,n){var i,a=[],s=!!n,o,A,l=[1/0,1/0],c=[-1/0,-1/0],u,h,d;if(s){i=H(n,2),l=i[0],c=i[1];for(var f=0,g=r.length;f<g;f+=1){var v=r[f];l=ps(l,v),c=ys(c,v)}}for(var f=0,p=r.length;f<p;f+=1){var v=r[f];if(f===0)d=v;else if(f===p-1)h=v,a.push(d),a.push(h);else{var y=[f?f-1:p-1,f-1][1];o=r[y],A=r[f+1];var m=[0,0];m=Jm(A,o),m=ca(m,e);var B=El(v,o),C=El(v,A),S=B+C;S!==0&&(B/=S,C/=S);var F=ca(m,-B),T=ca(m,C);h=VA(v,F),u=VA(v,T),u=ps(u,ys(A,v)),u=ys(u,ps(A,v)),F=Jm(u,v),F=ca(F,-B/C),h=VA(v,F),h=ps(h,ys(o,v)),h=ys(h,ps(o,v)),T=Jm(v,h),T=ca(T,C/B),u=VA(v,T),s&&(h=ys(h,l),h=ps(h,c),u=ys(u,l),u=ps(u,c)),a.push(d),a.push(h),d=u}}return a}function Jte(r,e,t){t===void 0&&(t=[[0,0],[1,1]]);for(var n=!1,i=[],a=0,s=r.length;a<s;a+=2)i.push([r[a],r[a+1]]);for(var o=Zte(i,.4,n,t),A=i.length,l=[],c,u,h,a=0;a<A-1;a+=1)c=o[a*2],u=o[a*2+1],h=i[a+1],l.push(["C",c[0],c[1],u[0],u[1],h[0],h[1]]);return l}var ene=["$el","cx","cy","d","dx","dy","fill","fillOpacity","filter","fontFamily","fontSize","fontStyle","fontVariant","fontWeight","height","img","increasedLineWidthForHitTesting","innerHTML","isBillboard","billboardRotation","isSizeAttenuation","isClosed","isOverflowing","leading","letterSpacing","lineDash","lineHeight","lineWidth","markerEnd","markerEndOffset","markerMid","markerStart","markerStartOffset","maxLines","metrics","miterLimit","offsetX","offsetY","opacity","path","points","r","radius","rx","ry","shadowColor","src","stroke","strokeOpacity","text","textAlign","textBaseline","textDecorationColor","textDecorationLine","textDecorationStyle","textOverflow","textPath","textPathSide","textPathStartOffset","transform","transformOrigin","visibility","width","wordWrap","wordWrapWidth","x","x1","x2","y","y1","y2","z1","z2","zIndex"];function tne(r){return ene.includes(r)}function fO(r){var e={};for(var t in r)tne(t)&&(e[t]=r[t]);return e}function nne(r,e){if(r.length<=e)return r;for(var t=Math.floor(r.length/e),n=[],i=0;i<r.length;i+=t)n.push(r[i]);return n}function ib(r,e,t){var n=r.getBBox(),i=n.width,a=n.height,s=e/Math.max(i,a);return r.style.transform="scale(".concat(s,")"),s}function rne(r,e){var t=new Map;return r.forEach(function(n){var i=e(n);t.has(i)||t.set(i,[]),t.get(i).push(n)}),t}function ine(r){throw new Error(r)}var ane=(function(){function r(i,a,s,o,A,l,c){i===void 0&&(i=null),a===void 0&&(a=null),s===void 0&&(s=null),o===void 0&&(o=null),A===void 0&&(A=[null,null,null,null,null]),l===void 0&&(l=[]),c===void 0&&(c=[]),e.add(this),this._elements=Array.from(i),this._data=a,this._parent=s,this._document=o,this._enter=A[0],this._update=A[1],this._exit=A[2],this._merge=A[3],this._split=A[4],this._transitions=l,this._facetElements=c}r.prototype.selectAll=function(i){var a=typeof i=="string"?this._parent.querySelectorAll(i):i;return new t(a,null,this._elements[0],this._document)},r.prototype.selectFacetAll=function(i){var a=typeof i=="string"?this._parent.querySelectorAll(i):i;return new t(this._elements,null,this._parent,this._document,void 0,void 0,a)},r.prototype.select=function(i){var a=typeof i=="string"?this._parent.querySelectorAll(i)[0]||null:i;return new t([a],null,a,this._document)},r.prototype.append=function(i){var a=this,s=typeof i=="function"?i:function(){return a.createElement(i)},o=[];if(this._data!==null){for(var A=0;A<this._data.length;A++){var l=this._data[A],c=H(Array.isArray(l)?l:[l,null],2),u=c[0],h=c[1],d=s(u,A);d.__data__=u,h!==null&&(d.__fromElements__=h),this._parent.appendChild(d),o.push(d)}return new t(o,null,this._parent,this._document)}for(var A=0;A<this._elements.length;A++){var f=this._elements[A],u=f.__data__,d=s(u,A);f.appendChild(d),o.push(d)}return new t(o,null,o[0],this._document)},r.prototype.maybeAppend=function(i,a){var s=If(this,e,"m",n).call(this,i[0]==="#"?i:"#".concat(i),a);return s.attr("id",i),s},r.prototype.maybeAppendByClassName=function(i,a){var s=i.toString(),o=If(this,e,"m",n).call(this,s[0]==="."?s:".".concat(s),a);return o.attr("className",s),o},r.prototype.maybeAppendByName=function(i,a){var s=If(this,e,"m",n).call(this,'[name="'.concat(i,'"]'),a);return s.attr("name",i),s},r.prototype.data=function(i,a,s){var o,A;a===void 0&&(a=function(_){return _}),s===void 0&&(s=function(){return null});for(var l=[],c=[],u=new Set(this._elements),h=[],d=new Set,f=new Map(this._elements.map(function(_,k){return[a(_.__data__,k),_]})),g=new Map(this._facetElements.map(function(_,k){return[a(_.__data__,k),_]})),v=rne(this._elements,function(_){return s(_.__data__)}),p=0;p<i.length;p++){var y=i[p],m=a(y,p),B=s(y,p);if(f.has(m)){var C=f.get(m);C.__data__=y,C.__facet__=!1,c.push(C),u.delete(C),f.delete(m)}else if(g.has(m)){var C=g.get(m);C.__data__=y,C.__facet__=!0,c.push(C),g.delete(m)}else if(v.has(m)){var S=v.get(m);h.push([y,S]);try{for(var F=(o=void 0,Fl(S)),T=F.next();!T.done;T=F.next()){var C=T.value;u.delete(C)}}catch(_){o={error:_}}finally{try{T&&!T.done&&(A=F.return)&&A.call(F)}finally{if(o)throw o.error}}v.delete(m)}else if(f.has(B)){var C=f.get(B);C.__toData__?C.__toData__.push(y):C.__toData__=[y],d.add(C),u.delete(C)}else l.push(y)}var O=[new t([],l,this._parent,this._document),new t(c,null,this._parent,this._document),new t(u,null,this._parent,this._document),new t([],h,this._parent,this._document),new t(d,null,this._parent,this._document)];return new t(this._elements,null,this._parent,this._document,O)},r.prototype.merge=function(i){var a=_e(_e([],H(this._elements),!1),H(i._elements),!1),s=_e(_e([],H(this._transitions),!1),H(i._transitions),!1);return new t(a,null,this._parent,this._document,void 0,s)},r.prototype.createElement=function(i){if(this._document)return this._document.createElement(i,{});var a=t.registry[i];return a?new a:ine("Unknown node type: ".concat(i))},r.prototype.join=function(i,a,s,o,A){i===void 0&&(i=function(f){return f}),a===void 0&&(a=function(f){return f}),s===void 0&&(s=function(f){return f.remove()}),o===void 0&&(o=function(f){return f}),A===void 0&&(A=function(f){return f.remove()});var l=i(this._enter),c=a(this._update),u=s(this._exit),h=o(this._merge),d=A(this._split);return c.merge(l).merge(u).merge(h).merge(d)},r.prototype.remove=function(){for(var i=function(o){var A=a._elements[o],l=a._transitions[o];l?l.then(function(){return A.remove()}):A.remove()},a=this,s=0;s<this._elements.length;s++)i(s);return new t([],null,this._parent,this._document,void 0,this._transitions)},r.prototype.each=function(i){for(var a=0;a<this._elements.length;a++){var s=this._elements[a],o=s.__data__;i.call(s,o,a)}return this},r.prototype.attr=function(i,a){var s=typeof a!="function"?function(){return a}:a;return this.each(function(o,A){a!==void 0&&(this[i]=s.call(this,o,A))})},r.prototype.style=function(i,a,s){s===void 0&&(s=!0);var o=typeof a!="function"||!s?function(){return a}:a;return this.each(function(A,l){a!==void 0&&(this.style[i]=o.call(this,A,l))})},r.prototype.styles=function(i,a){return i===void 0&&(i={}),a===void 0&&(a=!0),this.each(function(s,o){var A=this;Object.entries(i).forEach(function(l){var c=H(l,2),u=c[0],h=c[1],d=typeof h!="function"||!a?function(){return h}:h;h!==void 0&&A.attr(u,d.call(A,s,o))})})},r.prototype.update=function(i,a){a===void 0&&(a=!0);var s=typeof i!="function"||!a?function(){return i}:i;return this.each(function(o,A){i&&this.update&&this.update(s.call(this,o,A))})},r.prototype.maybeUpdate=function(i,a){a===void 0&&(a=!0);var s=typeof i!="function"||!a?function(){return i}:i;return this.each(function(o,A){i&&this.update&&this.update(s.call(this,o,A))})},r.prototype.transition=function(i){this._transitions;var a=new Array(this._elements.length);return this.each(function(s,o){a[o]=i.call(this,s,o)}),this._transitions=oR(a),this},r.prototype.on=function(i,a){return this.each(function(){this.addEventListener(i,a)}),this},r.prototype.call=function(i){for(var a=[],s=1;s<arguments.length;s++)a[s-1]=arguments[s];return i.call.apply(i,_e([this._parent,this],H(a),!1)),this},r.prototype.node=function(){return this._elements[0]},r.prototype.nodes=function(){return this._elements},r.prototype.transitions=function(){return this._transitions.filter(function(i){return!!i})},r.prototype.parent=function(){return this._parent};var e,t,n;return t=r,e=new WeakSet,n=function(a,s){var o=this._elements[0],A=o.querySelector(a);if(A)return new t([A],null,this._parent,this._document);var l=typeof s=="string"?this.createElement(s):s();return o.appendChild(l),new t([l],null,this._parent,this._document)},r.registry={g:Tn,rect:Vn,circle:zi,path:rr,text:nb,ellipse:_l,image:Il,line:Ks,polygon:Xs,polyline:Dh,html:Ys},r})();function Me(r){return new ane([r],null,r,r.ownerDocument)}function sne(r,e,t){return r.querySelector(e)?Me(r).select(e):Me(r).append(t)}function jn(r){if(Be(r))return[r,r,r,r];if(Mr(r)){var e=r.length;if(e===1)return[r[0],r[0],r[0],r[0]];if(e===2)return[r[0],r[1],r[0],r[1]];if(e===3)return[r[0],r[1],r[2],r[1]];if(e===4)return r}return[0,0,0,0]}function gO(r){var e=r.getLocalBounds(),t=e.min,n=e.max,i=H([t,n],2),a=H(i[0],2),s=a[0],o=a[1],A=H(i[1],2),l=A[0],c=A[1];return{x:s,y:o,width:l-s,height:c-o,left:s,bottom:c,top:o,right:l}}function one(r,e){var t=H(r,2),n=t[0],i=t[1],a=H(e,2),s=a[0],o=a[1];return n!==s&&i===o}function Ane(r,e){var t,n,i=e.attributes;try{for(var a=Fl(Object.entries(i)),s=a.next();!s.done;s=a.next()){var o=H(s.value,2),A=o[0],l=o[1];A!=="id"&&A!=="className"&&r.attr(A,l)}}catch(c){t={error:c}}finally{try{s&&!s.done&&(n=a.return)&&n.call(a)}finally{if(t)throw t.error}}}function ab(r){return r.toString().charAt(0).toUpperCase()+r.toString().slice(1)}function lne(r){return r.toString().charAt(0).toLowerCase()+r.toString().slice(1)}function cne(r,e){return"".concat(e).concat(ab(r))}function vO(r,e,t){var n;t===void 0&&(t=!0);var i=e||((n=r.match(/^([a-z][a-z0-9]+)/))===null||n===void 0?void 0:n[0])||"",a=r.replace(new RegExp("^(".concat(i,")")),"");return t?lne(a):a}function une(r,e){Object.entries(e).forEach(function(t){var n=H(t,2),i=n[0],a=n[1];_e([r],H(r.querySelectorAll(i)),!1).filter(function(s){return s.matches(i)}).forEach(function(s){if(s){var o=s;o.style.cssText+=Object.entries(a).reduce(function(A,l){return"".concat(A).concat(l.join(":"),";")},"")}})})}var bu=function(r,e){if(!(r!=null&&r.startsWith(e)))return!1;var t=r[e.length];return t>="A"&&t<="Z"};function ze(r,e,t){t===void 0&&(t=!1);var n={};return Object.entries(r).forEach(function(i){var a=H(i,2),s=a[0],o=a[1];if(!(s==="className"||s==="class")){if(bu(s,"show")&&bu(vO(s,"show"),e)!==t)s===cne(e,"show")?n[s]=o:n[s.replace(new RegExp(ab(e)),"")]=o;else if(!bu(s,"show")&&bu(s,e)!==t){var A=vO(s,e);A==="filter"&&typeof o=="function"||(n[A]=o)}}}),n}function Mo(r,e){return Object.entries(r).reduce(function(t,n){var i=H(n,2),a=i[0],s=i[1];return a.startsWith("show")?t["show".concat(e).concat(a.slice(4))]=s:t["".concat(e).concat(ab(a))]=s,t},{})}function ma(r,e){e===void 0&&(e=["x","y","class","className"]);var t=["transform","transformOrigin","anchor","visibility","pointerEvents","zIndex","cursor","clipPath","clipPathTargets","offsetPath","offsetPathTargets","offsetDistance","draggable","droppable"],n={},i={};return Object.entries(r).forEach(function(a){var s=H(a,2),o=s[0],A=s[1];e.includes(o)||(t.indexOf(o)!==-1?i[o]=A:n[o]=A)}),[n,i]}function yr(r,e){var t={YYYY:r.getFullYear(),MM:r.getMonth()+1,DD:r.getDate(),HH:r.getHours(),mm:r.getMinutes(),ss:r.getSeconds()},n=e;return Object.keys(t).forEach(function(i){var a=t[i];n=n.replace(i,i==="YYYY"?"".concat(a):"".concat(a).padStart(2,"0"))}),n}function hne(r,e,t){var n=r.getBBox(),i=n.width,a=n.height,s=H([e,t].map(function(l,c){var u;return l.includes("%")?parseFloat(((u=l.match(/[+-]?([0-9]*[.])?[0-9]+/))===null||u===void 0?void 0:u[0])||"0")/100*(c===0?i:a):l}),2),o=s[0],A=s[1];return[o,A]}function eU(r,e){if(e)try{var t=/translate\(([+-]*[\d]+[%]*),[ ]*([+-]*[\d]+[%]*)\)/g,n=e.replace(t,function(i,a,s){return"translate(".concat(hne(r,a,s),")")});r.attr("transform",n)}catch{}}function dne(r){var e;return((e=r[0])===null||e===void 0?void 0:e.map(function(t,n){return r.map(function(i){return i[n]})}))||[]}var pO=function(r,e){if(e==null){r.innerHTML="";return}r.replaceChildren?Array.isArray(e)?r.replaceChildren.apply(r,_e([],H(e),!1)):r.replaceChildren(e):(r.innerHTML="",Array.isArray(e)?e.forEach(function(t){return r.appendChild(t)}):r.appendChild(e))};function of(r){return/\S+-\S+/g.test(r)?r.split("-").map(function(e){return e[0]}):r.length>2?[r[0]]:r.split("")}var fne=function(r){var e=new DOMParser,t=e.parseFromString(r,"text/html"),n=t.body.firstElementChild;if(console.log(n==null?void 0:n.getClientRects(),11),!n)return 0;var i=n.getAttribute("style")||"",a=Object.fromEntries(i.split(";").map(function(v){return v.trim()}).filter(function(v){return v.includes(":")}).map(function(v){var p=H(v.split(":").map(function(B){return B.trim()}),2),y=p[0],m=p[1];return[y.toLowerCase(),m]})),s=function(v){if(!v)return 0;var p=v.match(/([\d.]+)px/);return p?parseFloat(p[1]):0};if(a.height)return s(a.height);var o=s(a["font-size"])||16,A=a["line-height"],l;!A||A==="normal"?l=1.2*o:A.endsWith("px")?l=s(A):/^[\d.]+$/.test(A)?l=parseFloat(A)*o:l=o;var c=s(a["padding-top"]),u=s(a["padding-bottom"]);if(a.padding){var h=a.padding.split(/\s+/).map(s);h.length===1||h.length===2?(c=h[0],u=h[0]):(h.length===3||h.length===4)&&(c=h[0],u=h[2])}var d=s(a["border-top-width"]),f=s(a["border-bottom-width"]);if(a.border){var g=a.border.match(/([\d.]+)px/);g&&(d=parseFloat(g[1]),f=parseFloat(g[1]))}if(a["border-width"]){var h=a["border-width"].split(/\s+/).map(s);h.length===1||h.length===2?(d=h[0],f=h[0]):(h.length===3||h.length===4)&&(d=h[0],f=h[2])}return l+c+u+d+f};function gne(){sf(this,this.attributes.visibility!=="hidden")}var Zt=(function(r){Xe(e,r);function e(t,n){n===void 0&&(n={});var i=r.call(this,wn({},{style:n},t))||this;return i.initialized=!1,i._defaultOptions=n,i}return Object.defineProperty(e.prototype,"offscreenGroup",{get:function(){return this._offscreen||(this._offscreen=WN(this)),this._offscreen},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"defaultOptions",{get:function(){return this._defaultOptions},enumerable:!1,configurable:!0}),e.prototype.connectedCallback=function(){this.render(this.attributes,this),this.bindEvents(this.attributes,this),this.initialized=!0},e.prototype.disconnectedCallback=function(){var t;(t=this._offscreen)===null||t===void 0||t.destroy()},e.prototype.attributeChangedCallback=function(t){t==="visibility"&&gne.call(this)},e.prototype.update=function(t,n){var i;return this.attr(wn({},this.attributes,t||{})),(i=this.render)===null||i===void 0?void 0:i.call(this,this.attributes,this,n)},e.prototype.clear=function(){this.removeChildren()},e.prototype.bindEvents=function(t,n){},e.prototype.getSubShapeStyle=function(t){t.x,t.y,t.transform,t.transformOrigin,t.class,t.className,t.zIndex;var n=Dt(t,["x","y","transform","transformOrigin","class","className","zIndex"]);return n},e})(Ol),tU=function(r,e,t){return[["M",r-t,e],["A",t,t,0,1,0,r+t,e],["A",t,t,0,1,0,r-t,e],["Z"]]},vne=tU,pne=function(r,e,t){return[["M",r-t,e-t],["L",r+t,e-t],["L",r+t,e+t],["L",r-t,e+t],["Z"]]},yne=function(r,e,t){return[["M",r-t,e],["L",r,e-t],["L",r+t,e],["L",r,e+t],["Z"]]},mne=function(r,e,t){var n=t*Math.sin(.3333333333333333*Math.PI);return[["M",r-t,e+n],["L",r,e-n],["L",r+t,e+n],["Z"]]},wne=function(r,e,t){var n=t*Math.sin(.3333333333333333*Math.PI);return[["M",r-t,e-n],["L",r+t,e-n],["L",r,e+n],["Z"]]},Bne=function(r,e,t){var n=t/2*Math.sqrt(3);return[["M",r,e-t],["L",r+n,e-t/2],["L",r+n,e+t/2],["L",r,e+t],["L",r-n,e+t/2],["L",r-n,e-t/2],["Z"]]},bne=function(r,e,t){var n=t-1.5;return[["M",r-t,e-n],["L",r+t,e+n],["L",r+t,e-n],["L",r-t,e+n],["Z"]]},nU=function(r,e,t){return[["M",r,e+t],["L",r,e-t]]},Ene=function(r,e,t){return[["M",r-t,e-t],["L",r+t,e+t],["M",r+t,e-t],["L",r-t,e+t]]},xne=function(r,e,t){return[["M",r-t/2,e-t],["L",r+t/2,e-t],["M",r,e-t],["L",r,e+t],["M",r-t/2,e+t],["L",r+t/2,e+t]]},Cne=function(r,e,t){return[["M",r-t,e],["L",r+t,e],["M",r,e-t],["L",r,e+t]]},Sne=function(r,e,t){return[["M",r-t,e],["L",r+t,e]]},rU=function(r,e,t){return[["M",r-t,e],["L",r+t,e]]},Fne=rU,Tne=function(r,e,t){return[["M",r-t,e],["A",t/2,t/2,0,1,1,r,e],["A",t/2,t/2,0,1,0,r+t,e]]},Mne=function(r,e,t){return[["M",r-t-1,e-2.5],["L",r,e-2.5],["L",r,e+2.5],["L",r+t+1,e+2.5]]},One=function(r,e,t){return[["M",r-t-1,e+2.5],["L",r,e+2.5],["L",r,e-2.5],["L",r+t+1,e-2.5]]},_ne=function(r,e,t){return[["M",r-(t+1),e+2.5],["L",r-t/2,e+2.5],["L",r-t/2,e-2.5],["L",r+t/2,e-2.5],["L",r+t/2,e+2.5],["L",r+t+1,e+2.5]]};function Ine(r,e){return[["M",r-5,e+2.5],["L",r-5,e],["L",r,e],["L",r,e-3],["L",r,e+3],["L",r+6.5,e+3]]}var kne=function(r,e,t){return[["M",r-t,e-t],["L",r+t,e],["L",r-t,e+t],["Z"]]},Lne=function(r,e,t){var n=t,i=t*.2,a=t*.7;return[["M",r-n,e],["A",n,n,0,1,0,r+n,e],["A",n,n,0,1,0,r-n,e],["Z"],["M",r-a,e],["L",r-i,e],["M",r+i,e],["L",r+a,e],["M",r,e-a],["L",r,e-i],["M",r,e+i],["L",r,e+a]]};function Qne(r){var e="default";if(un(r)&&r instanceof Image)e="image";else if(Te(r))e="symbol";else if(At(r)){var t=new RegExp("data:(image|text)");r.match(t)?e="base64":/^(https?:\/\/(([a-zA-Z0-9]+-?)+[a-zA-Z0-9]+\.)+[a-zA-Z]+)(:\d+)?(\/.*)?(\?.*)?(#.*)?$/.test(r)?e="url":e="symbol"}return e}function Nne(r){var e=Qne(r);return["base64","url","image"].includes(e)?"image":r&&e==="symbol"?"path":null}var gt=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return e.prototype.render=function(t,n){var i=t.x,a=i===void 0?0:i,s=t.y,o=s===void 0?0:s,A=this.getSubShapeStyle(t),l=A.symbol,c=A.size,u=c===void 0?16:c,h=Dt(A,["symbol","size"]),d=Nne(l);Fr(!!d,Me(n),function(f){f.maybeAppendByClassName("marker",d).attr("className","marker ".concat(d,"-marker")).call(function(g){if(d==="image"){var v=u*2;g.styles({img:l,width:v,height:v,x:a-u,y:o-u})}else{var v=u/2,p=Te(l)?l:e.getSymbol(l);g.styles(le({d:p==null?void 0:p(a,o,v)},h))}})})},e.MARKER_SYMBOL_MAP=new Map,e.registerSymbol=function(t,n){e.MARKER_SYMBOL_MAP.set(t,n)},e.getSymbol=function(t){return e.MARKER_SYMBOL_MAP.get(t)},e.getSymbols=function(){return Array.from(e.MARKER_SYMBOL_MAP.keys())},e})(Zt);gt.registerSymbol("cross",Ene);gt.registerSymbol("hyphen",Sne);gt.registerSymbol("line",nU);gt.registerSymbol("plus",Cne);gt.registerSymbol("tick",xne);gt.registerSymbol("circle",tU);gt.registerSymbol("point",vne);gt.registerSymbol("bowtie",bne);gt.registerSymbol("hexagon",Bne);gt.registerSymbol("square",pne);gt.registerSymbol("diamond",yne);gt.registerSymbol("triangle",mne);gt.registerSymbol("triangle-down",wne);gt.registerSymbol("line",nU);gt.registerSymbol("dot",rU);gt.registerSymbol("dash",Fne);gt.registerSymbol("smooth",Tne);gt.registerSymbol("hv",Mne);gt.registerSymbol("vh",One);gt.registerSymbol("hvh",_ne);gt.registerSymbol("vhv",Ine);gt.registerSymbol("focus",Lne);function Ih(r,...e){return e.reduce((t,n)=>i=>t(n(i)),r)}function O1(r,e){return e-r?t=>(t-r)/(e-r):t=>.5}function Une(r,e){const t=e<r?e:r,n=r>e?r:e;return i=>Math.min(Math.max(t,i),n)}function Pne(r,e,t,n,i){let a=t,s=n||r.length;const o=(A=>A);for(;a<s;){const A=Math.floor((a+s)/2);o(r[A])>e?s=A:a=A+1}return a}const yO=Math.sqrt(50),mO=Math.sqrt(10),wO=Math.sqrt(2);function Pu(r,e,t){const n=(e-r)/Math.max(0,t),i=Math.floor(Math.log(n)/Math.LN10),a=n/10**i;return i>=0?(a>=yO?10:a>=mO?5:a>=wO?2:1)*10**i:-(10**-i)/(a>=yO?10:a>=mO?5:a>=wO?2:1)}const Rne=(r,e,t=5)=>{const n=[r,e];let i=0,a=n.length-1,s=n[i],o=n[a],A;return o<s&&([s,o]=[o,s],[i,a]=[a,i]),A=Pu(s,o,t),A>0?(s=Math.floor(s/A)*A,o=Math.ceil(o/A)*A,A=Pu(s,o,t)):A<0&&(s=Math.ceil(s*A)/A,o=Math.floor(o*A)/A,A=Pu(s,o,t)),A>0?(n[i]=Math.floor(s/A)*A,n[a]=Math.ceil(o/A)*A):A<0&&(n[i]=Math.ceil(s*A)/A,n[a]=Math.floor(o*A)/A),n};function BO(r){return!He(r)&&!mR(r)&&!Number.isNaN(r)}var ew={exports:{}},tw,bO;function Dne(){return bO||(bO=1,tw={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]}),tw}var nw={exports:{}},rw,EO;function Hne(){return EO||(EO=1,rw=function(e){return!e||typeof e=="string"?!1:e instanceof Array||Array.isArray(e)||e.length>=0&&(e.splice instanceof Function||Object.getOwnPropertyDescriptor(e,e.length-1)&&e.constructor.name!=="String")}),rw}var xO;function Gne(){if(xO)return nw.exports;xO=1;var r=Hne(),e=Array.prototype.concat,t=Array.prototype.slice,n=nw.exports=function(a){for(var s=[],o=0,A=a.length;o<A;o++){var l=a[o];r(l)?s=e.call(s,t.call(l)):s.push(l)}return s};return n.wrap=function(i){return function(){return i(n(arguments))}},nw.exports}var CO;function Kne(){if(CO)return ew.exports;CO=1;var r=Dne(),e=Gne(),t=Object.hasOwnProperty,n=Object.create(null);for(var i in r)t.call(r,i)&&(n[r[i]]=i);var a=ew.exports={to:{},get:{}};a.get=function(A){var l=A.substring(0,3).toLowerCase(),c,u;switch(l){case"hsl":c=a.get.hsl(A),u="hsl";break;case"hwb":c=a.get.hwb(A),u="hwb";break;default:c=a.get.rgb(A),u="rgb";break}return c?{model:u,value:c}:null},a.get.rgb=function(A){if(!A)return null;var l=/^#([a-f0-9]{3,4})$/i,c=/^#([a-f0-9]{6})([a-f0-9]{2})?$/i,u=/^rgba?\(\s*([+-]?\d+)(?=[\s,])\s*(?:,\s*)?([+-]?\d+)(?=[\s,])\s*(?:,\s*)?([+-]?\d+)\s*(?:[,|\/]\s*([+-]?[\d\.]+)(%?)\s*)?\)$/,h=/^rgba?\(\s*([+-]?[\d\.]+)\%\s*,?\s*([+-]?[\d\.]+)\%\s*,?\s*([+-]?[\d\.]+)\%\s*(?:[,|\/]\s*([+-]?[\d\.]+)(%?)\s*)?\)$/,d=/^(\w+)$/,f=[0,0,0,1],g,v,p;if(g=A.match(c)){for(p=g[2],g=g[1],v=0;v<3;v++){var y=v*2;f[v]=parseInt(g.slice(y,y+2),16)}p&&(f[3]=parseInt(p,16)/255)}else if(g=A.match(l)){for(g=g[1],p=g[3],v=0;v<3;v++)f[v]=parseInt(g[v]+g[v],16);p&&(f[3]=parseInt(p+p,16)/255)}else if(g=A.match(u)){for(v=0;v<3;v++)f[v]=parseInt(g[v+1],0);g[4]&&(g[5]?f[3]=parseFloat(g[4])*.01:f[3]=parseFloat(g[4]))}else if(g=A.match(h)){for(v=0;v<3;v++)f[v]=Math.round(parseFloat(g[v+1])*2.55);g[4]&&(g[5]?f[3]=parseFloat(g[4])*.01:f[3]=parseFloat(g[4]))}else return(g=A.match(d))?g[1]==="transparent"?[0,0,0,0]:t.call(r,g[1])?(f=r[g[1]],f[3]=1,f):null:null;for(v=0;v<3;v++)f[v]=s(f[v],0,255);return f[3]=s(f[3],0,1),f},a.get.hsl=function(A){if(!A)return null;var l=/^hsla?\(\s*([+-]?(?:\d{0,3}\.)?\d+)(?:deg)?\s*,?\s*([+-]?[\d\.]+)%\s*,?\s*([+-]?[\d\.]+)%\s*(?:[,|\/]\s*([+-]?(?=\.\d|\d)(?:0|[1-9]\d*)?(?:\.\d*)?(?:[eE][+-]?\d+)?)\s*)?\)$/,c=A.match(l);if(c){var u=parseFloat(c[4]),h=(parseFloat(c[1])%360+360)%360,d=s(parseFloat(c[2]),0,100),f=s(parseFloat(c[3]),0,100),g=s(isNaN(u)?1:u,0,1);return[h,d,f,g]}return null},a.get.hwb=function(A){if(!A)return null;var l=/^hwb\(\s*([+-]?\d{0,3}(?:\.\d+)?)(?:deg)?\s*,\s*([+-]?[\d\.]+)%\s*,\s*([+-]?[\d\.]+)%\s*(?:,\s*([+-]?(?=\.\d|\d)(?:0|[1-9]\d*)?(?:\.\d*)?(?:[eE][+-]?\d+)?)\s*)?\)$/,c=A.match(l);if(c){var u=parseFloat(c[4]),h=(parseFloat(c[1])%360+360)%360,d=s(parseFloat(c[2]),0,100),f=s(parseFloat(c[3]),0,100),g=s(isNaN(u)?1:u,0,1);return[h,d,f,g]}return null},a.to.hex=function(){var A=e(arguments);return"#"+o(A[0])+o(A[1])+o(A[2])+(A[3]<1?o(Math.round(A[3]*255)):"")},a.to.rgb=function(){var A=e(arguments);return A.length<4||A[3]===1?"rgb("+Math.round(A[0])+", "+Math.round(A[1])+", "+Math.round(A[2])+")":"rgba("+Math.round(A[0])+", "+Math.round(A[1])+", "+Math.round(A[2])+", "+A[3]+")"},a.to.rgb.percent=function(){var A=e(arguments),l=Math.round(A[0]/255*100),c=Math.round(A[1]/255*100),u=Math.round(A[2]/255*100);return A.length<4||A[3]===1?"rgb("+l+"%, "+c+"%, "+u+"%)":"rgba("+l+"%, "+c+"%, "+u+"%, "+A[3]+")"},a.to.hsl=function(){var A=e(arguments);return A.length<4||A[3]===1?"hsl("+A[0]+", "+A[1]+"%, "+A[2]+"%)":"hsla("+A[0]+", "+A[1]+"%, "+A[2]+"%, "+A[3]+")"},a.to.hwb=function(){var A=e(arguments),l="";return A.length>=4&&A[3]!==1&&(l=", "+A[3]),"hwb("+A[0]+", "+A[1]+"%, "+A[2]+"%"+l+")"},a.to.keyword=function(A){return n[A.slice(0,3)]};function s(A,l,c){return Math.min(Math.max(l,A),c)}function o(A){var l=Math.round(A).toString(16).toUpperCase();return l.length<2?"0"+l:l}return ew.exports}var zne=Kne();const Vne=Qh(zne);function iw(r,e,t){let n=t;return n<0&&(n+=1),n>1&&(n-=1),n<1/6?r+(e-r)*6*n:n<1/2?e:n<2/3?r+(e-r)*(2/3-n)*6:r}function jne(r){const e=r[0]/360,t=r[1]/100,n=r[2]/100,i=r[3];if(t===0)return[n*255,n*255,n*255,i];const a=n<.5?n*(1+t):n+t-n*t,s=2*n-a,o=iw(s,a,e+1/3),A=iw(s,a,e),l=iw(s,a,e-1/3);return[o*255,A*255,l*255,i]}function SO(r){const e=Vne.get(r);if(!e)return null;const{model:t,value:n}=e;return t==="rgb"?n:t==="hsl"?jne(n):null}const kh=(r,e)=>t=>r*(1-t)+e*t,Wne=(r,e)=>{const t=SO(r),n=SO(e);return t===null||n===null?t?()=>r:()=>e:i=>{const a=new Array(4);for(let c=0;c<4;c+=1){const u=t[c],h=n[c];a[c]=u*(1-i)+h*i}const[s,o,A,l]=a;return`rgba(${Math.round(s)}, ${Math.round(o)}, ${Math.round(A)}, ${l})`}},qne=(r,e)=>typeof r=="number"&&typeof e=="number"?kh(r,e):typeof r=="string"&&typeof e=="string"?Wne(r,e):()=>r,$ne=(r,e)=>{const t=kh(r,e);return n=>Math.round(t(n))};function FO({map:r,initKey:e},t){const n=e(t);return r.has(n)?r.get(n):t}function Yne({map:r,initKey:e},t){const n=e(t);return r.has(n)?r.get(n):(r.set(n,t),t)}function Xne({map:r,initKey:e},t){const n=e(t);return r.has(n)&&(t=r.get(n),r.delete(n)),t}function Zne(r){return typeof r=="object"?r.valueOf():r}class TO extends Map{constructor(e){if(super(),this.map=new Map,this.initKey=Zne,e!==null)for(const[t,n]of e)this.set(t,n)}get(e){return super.get(FO({map:this.map,initKey:this.initKey},e))}has(e){return super.has(FO({map:this.map,initKey:this.initKey},e))}set(e,t){return super.set(Yne({map:this.map,initKey:this.initKey},e),t)}delete(e){return super.delete(Xne({map:this.map,initKey:this.initKey},e))}}class iU{constructor(e){this.options=zn({},this.getDefaultOptions()),this.update(e)}getOptions(){return this.options}update(e={}){this.options=zn({},this.options,e),this.rescale(e)}rescale(e){}}const sb=Symbol("defaultUnknown");function MO(r,e,t){for(let n=0;n<e.length;n+=1)r.has(e[n])||r.set(t(e[n]),n)}function OO(r){const{value:e,from:t,to:n,mapper:i,notFoundReturn:a}=r;let s=i.get(e);if(s===void 0){if(a!==sb)return a;s=t.push(e)-1,i.set(e,s)}return n[s%n.length]}function _O(r){return r instanceof Date?e=>`${e}`:typeof r=="object"?e=>JSON.stringify(e):e=>e}class ob extends iU{getDefaultOptions(){return{domain:[],range:[],unknown:sb}}constructor(e){super(e)}map(e){return this.domainIndexMap.size===0&&MO(this.domainIndexMap,this.getDomain(),this.domainKey),OO({value:this.domainKey(e),mapper:this.domainIndexMap,from:this.getDomain(),to:this.getRange(),notFoundReturn:this.options.unknown})}invert(e){return this.rangeIndexMap.size===0&&MO(this.rangeIndexMap,this.getRange(),this.rangeKey),OO({value:this.rangeKey(e),mapper:this.rangeIndexMap,from:this.getRange(),to:this.getDomain(),notFoundReturn:this.options.unknown})}rescale(e){const[t]=this.options.domain,[n]=this.options.range;if(this.domainKey=_O(t),this.rangeKey=_O(n),!this.rangeIndexMap){this.rangeIndexMap=new Map,this.domainIndexMap=new Map;return}(!e||e.range)&&this.rangeIndexMap.clear(),(!e||e.domain||e.compare)&&(this.domainIndexMap.clear(),this.sortedDomain=void 0)}clone(){return new ob(this.options)}getRange(){return this.options.range}getDomain(){if(this.sortedDomain)return this.sortedDomain;const{domain:e,compare:t}=this.options;return this.sortedDomain=t?[...e].sort(t):e,this.sortedDomain}}function Jne(r){const e=Math.min(...r);return r.map(t=>t/e)}function ere(r,e){const t=r.length,n=e-t;return n>0?[...r,...new Array(n).fill(1)]:n<0?r.slice(0,e):r}function tre(r){return Math.round(r*1e12)/1e12}function nre(r){const{domain:e,range:t,paddingOuter:n,paddingInner:i,flex:a,round:s,align:o}=r,A=e.length,l=ere(a,A),[c,u]=t,h=u-c,d=2/A*n+1-1/A*i,f=h/d,g=f*i/A,v=f-A*g,p=Jne(l),y=p.reduce((L,U)=>L+U),m=v/y,B=new TO(e.map((L,U)=>{const G=p[U]*m;return[L,s?Math.floor(G):G]})),C=new TO(e.map((L,U)=>{const W=p[U]*m+g;return[L,s?Math.floor(W):W]})),S=Array.from(C.values()).reduce((L,U)=>L+U),T=(h-(S-S/A*i))*o,O=c+T;let _=s?Math.round(O):O;const k=new Array(A);for(let L=0;L<A;L+=1){k[L]=tre(_);const U=e[L];_+=C.get(U)}return{valueBandWidth:B,valueStep:C,adjustedRange:k}}function rre(r){var e;const{domain:t}=r,n=t.length;if(n===0)return{valueBandWidth:void 0,valueStep:void 0,adjustedRange:[]};if(!!(!((e=r.flex)===null||e===void 0)&&e.length))return nre(r);const{range:a,paddingOuter:s,paddingInner:o,round:A,align:l}=r;let c,u,h=a[0];const f=a[1]-h,g=s*2,v=n-o;c=f/Math.max(1,g+v),A&&(c=Math.floor(c)),h+=(f-c*(n-o))*l,u=c*(1-o),A&&(h=Math.round(h),u=Math.round(u));const p=new Array(n).fill(0).map((y,m)=>h+m*c);return{valueStep:c,valueBandWidth:u,adjustedRange:p}}class Ab extends ob{getDefaultOptions(){return{domain:[],range:[0,1],align:.5,round:!1,paddingInner:0,paddingOuter:0,padding:0,unknown:sb,flex:[]}}constructor(e){super(e)}clone(){return new Ab(this.options)}getStep(e){return this.valueStep===void 0?1:typeof this.valueStep=="number"?this.valueStep:e===void 0?Array.from(this.valueStep.values())[0]:this.valueStep.get(e)}getBandWidth(e){return this.valueBandWidth===void 0?1:typeof this.valueBandWidth=="number"?this.valueBandWidth:e===void 0?Array.from(this.valueBandWidth.values())[0]:this.valueBandWidth.get(e)}getRange(){return this.adjustedRange}getPaddingInner(){const{padding:e,paddingInner:t}=this.options;return e>0?e:t}getPaddingOuter(){const{padding:e,paddingOuter:t}=this.options;return e>0?e:t}rescale(){super.rescale();const{align:e,domain:t,range:n,round:i,flex:a}=this.options,{adjustedRange:s,valueBandWidth:o,valueStep:A}=rre({align:e,range:n,round:i,flex:a,paddingInner:this.getPaddingInner(),paddingOuter:this.getPaddingOuter(),domain:t});this.valueStep=A,this.valueBandWidth=o,this.adjustedRange=s}}const ire=(r,e,t)=>{let n,i,a=r,s=e;if(a===s&&t>0)return[a];let o=Pu(a,s,t);if(o===0||!Number.isFinite(o))return[];if(o>0){a=Math.ceil(a/o),s=Math.floor(s/o),i=new Array(n=Math.ceil(s-a+1));for(let A=0;A<n;A+=1)i[A]=(a+A)*o}else{o=-o,a=Math.ceil(a*o),s=Math.floor(s*o),i=new Array(n=Math.ceil(s-a+1));for(let A=0;A<n;A+=1)i[A]=(a+A)/o}return i},are=(r,e,t)=>{const[n,i]=r,[a,s]=e;let o,A;return n<i?(o=O1(n,i),A=t(a,s)):(o=O1(i,n),A=t(s,a)),Ih(A,o)},sre=(r,e,t)=>{const n=Math.min(r.length,e.length)-1,i=new Array(n),a=new Array(n),s=r[0]>r[n],o=s?[...r].reverse():r,A=s?[...e].reverse():e;for(let l=0;l<n;l+=1)i[l]=O1(o[l],o[l+1]),a[l]=t(A[l],A[l+1]);return l=>{const c=Pne(r,l,1,n)-1,u=i[c],h=a[c];return Ih(h,u)(l)}},IO=(r,e,t,n)=>(Math.min(r.length,e.length)>2?sre:are)(r,e,n?$ne:t);class ore extends iU{getDefaultOptions(){return{domain:[0,1],range:[0,1],nice:!1,clamp:!1,round:!1,interpolate:kh,tickCount:5}}map(e){return BO(e)?this.output(e):this.options.unknown}invert(e){return BO(e)?this.input(e):this.options.unknown}nice(){if(!this.options.nice)return;const[e,t,n,...i]=this.getTickMethodOptions();this.options.domain=this.chooseNice()(e,t,n,...i)}getTicks(){const{tickMethod:e}=this.options,[t,n,i,...a]=this.getTickMethodOptions();return e(t,n,i,...a)}getTickMethodOptions(){const{domain:e,tickCount:t}=this.options,n=e[0],i=e[e.length-1];return[n,i,t]}chooseNice(){return Rne}rescale(){this.nice();const[e,t]=this.chooseTransforms();this.composeOutput(e,this.chooseClamp(e)),this.composeInput(e,t,this.chooseClamp(t))}chooseClamp(e){const{clamp:t,range:n}=this.options,i=this.options.domain.map(e),a=Math.min(i.length,n.length);return t?Une(i[0],i[a-1]):ww}composeOutput(e,t){const{domain:n,range:i,round:a,interpolate:s}=this.options,o=IO(n.map(e),i,s,a);this.output=Ih(o,t,e)}composeInput(e,t,n){const{domain:i,range:a}=this.options,s=IO(a,i.map(e),kh);this.input=Ih(t,n,s)}}class rl extends ore{getDefaultOptions(){return{domain:[0,1],range:[0,1],unknown:void 0,nice:!1,clamp:!1,round:!1,interpolate:qne,tickMethod:ire,tickCount:5}}chooseTransforms(){return[ww,ww]}clone(){return new rl(this.options)}}var Are=(function(r){Xe(e,r);function e(t){var n=this,i=t.style,a=Dt(t,["style"]);return n=r.call(this,zn({},{type:"column"},le({style:i},a)))||this,n.columnsGroup=new Tn({name:"columns"}),n.appendChild(n.columnsGroup),n.render(),n}return e.prototype.render=function(){var t=this.attributes,n=t.columns,i=t.x,a=t.y;this.columnsGroup.style.transform="translate(".concat(i,", ").concat(a,")"),Me(this.columnsGroup).selectAll(".column").data(n.flat()).join(function(s){return s.append("rect").attr("className","column").each(function(o){this.attr(o)})},function(s){return s.each(function(o){this.attr(o)})},function(s){return s.remove()})},e.prototype.update=function(t){this.attr(wn({},this.attributes,t)),this.render()},e.prototype.clear=function(){this.removeChildren()},e})(Ot),lre=(function(r){Xe(e,r);function e(t){var n=this,i=t.style,a=Dt(t,["style"]);return n=r.call(this,zn({},{type:"lines"},le({style:i},a)))||this,n.linesGroup=n.appendChild(new Tn),n.areasGroup=n.appendChild(new Tn),n.render(),n}return e.prototype.render=function(){var t=this.attributes,n=t.lines,i=t.areas,a=t.x,s=t.y;this.style.transform="translate(".concat(a,", ").concat(s,")"),n&&this.renderLines(n),i&&this.renderAreas(i)},e.prototype.clear=function(){this.linesGroup.removeChildren(),this.areasGroup.removeChildren()},e.prototype.update=function(t){this.attr(wn({},this.attributes,t)),this.render()},e.prototype.renderLines=function(t){Me(this.linesGroup).selectAll(".line").data(t).join(function(n){return n.append("path").attr("className","line").each(function(i){this.attr(i)})},function(n){return n.each(function(i){this.attr(i)})},function(n){return n.remove()})},e.prototype.renderAreas=function(t){Me(this.linesGroup).selectAll(".area").data(t).join(function(n){return n.append("path").attr("className","area").each(function(i){this.attr(i)})},function(n){return n.each(function(i){this.style(i)})},function(n){return n.remove()})},e})(Ot);function cre(r,e){var t,n=e.x,i=e.y,a=H(i.getOptions().range||[0,0],2),s=a[0],o=a[1];return o>s&&(t=H([s,o],2),o=t[0],s=t[1]),r.map(function(A){var l=A.map(function(c,u){return[n.map(u),Yt(i.map(c),o,s)]});return l})}function xl(r,e){e===void 0&&(e=!1);var t=e?r.length-1:0,n=r.map(function(i,a){return _e([a===t?"M":"L"],H(i),!1)});return e?n.reverse():n}function Lh(r,e){if(e===void 0&&(e=!1),r.length<=2)return xl(r);for(var t=[],n=r.length,i=0;i<n;i+=1){var a=e?r[n-i-1]:r[i];Xt(a,t.slice(-2))||t.push.apply(t,_e([],H(a),!1))}var s=Jte(t);return e?s.unshift(_e(["M"],H(r[n-1]),!1)):s.unshift(_e(["M"],H(r[0]),!1)),s}function lb(r,e,t){var n=Za(r);return n.push(["L",e,t],["L",0,t],["Z"]),n}function ure(r,e,t,n){return r.map(function(i){return lb(e?Lh(i):xl(i),t,n)})}function hre(r,e,t){for(var n=[],i=r.length-1;i>=0;i-=1){var a=r[i],s=xl(a),o=void 0;if(i===0)o=lb(s,e,t);else{var A=r[i-1],l=xl(A,!0);l[0][0]="L",o=_e(_e(_e([],H(s),!1),H(l),!1),[["Z"]],!1)}n.push(o)}return n}function dre(r,e,t){for(var n=[],i=r.length-1;i>=0;i-=1){var a=r[i],s=Lh(a),o=void 0;if(i===0)o=lb(s,e,t);else{var A=r[i-1],l=Lh(A,!0),c=a[0];l[0][0]="L",o=_e(_e(_e([],H(s),!1),H(l),!1),[_e(["M"],H(c),!1),["Z"]],!1)}n.push(o)}return n}function kO(r){return r.length===0?[0,0]:[Wu(dR(r,function(e){return Wu(e)||0})),ju(hR(r,function(e){return ju(e)||0}))]}function LO(r){for(var e=Za(r),t=e[0].length,n=H([Array(t).fill(0),Array(t).fill(0)],2),i=n[0],a=n[1],s=0;s<e.length;s+=1)for(var o=e[s],A=0;A<t;A+=1)o[A]>=0?(o[A]+=i[A],i[A]=o[A]):(o[A]+=a[A],a[A]=o[A]);return e}var fre=(function(r){Xe(e,r);function e(t){return r.call(this,t,{type:"line",x:0,y:0,width:200,height:20,isStack:!1,color:["#83daad","#edbf45","#d2cef9","#e290b3","#6f63f4"],smooth:!0,lineLineWidth:1,areaOpacity:0,isGroup:!1,columnLineWidth:1,columnStroke:"#fff",scale:1,spacing:0})||this}return Object.defineProperty(e.prototype,"rawData",{get:function(){var t=this.attributes.data;if(!t||(t==null?void 0:t.length)===0)return[[]];var n=Za(t);return Be(n[0])?[n]:n},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"data",{get:function(){return this.attributes.isStack?LO(this.rawData):this.rawData},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"scales",{get:function(){return this.createScales(this.data)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"baseline",{get:function(){var t=this.scales.y,n=H(t.getOptions().domain||[0,0],2),i=n[0],a=n[1];return a<0?t.map(a):t.map(i<0?0:i)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"containerShape",{get:function(){var t=this.attributes,n=t.width,i=t.height;return{width:n,height:i}},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"linesStyle",{get:function(){var t=this,n=this.attributes,i=n.type,a=n.isStack,s=n.smooth;if(i!=="line")throw new Error("linesStyle can only be used in line type");var o=ze(this.attributes,"area"),A=ze(this.attributes,"line"),l=this.containerShape.width,c=this.data;if(c[0].length===0)return{lines:[],areas:[]};var u=this.scales,h=u.x,d=u.y,f=cre(c,{x:h,y:d}),g=[];if(o){var v=this.baseline;a?g=s?dre(f,l,v):hre(f,l,v):g=ure(f,s,l,v)}return{lines:f.map(function(p,y){return le({stroke:t.getColor(y),d:s?Lh(p):xl(p)},A)}),areas:g.map(function(p,y){return le({d:p,fill:t.getColor(y)},o)})}},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"columnsStyle",{get:function(){var t=this,n=ze(this.attributes,"column"),i=this.attributes,a=i.isStack,s=i.type,o=i.scale;if(s!=="column")throw new Error("columnsStyle can only be used in column type");var A=this.containerShape.height,l=this.rawData;if(!l)return{columns:[]};a&&(l=LO(l));var c=this.createScales(l),u=c.x,h=c.y,d=H(kO(l),2),f=d[0],g=d[1],v=new rl({domain:[0,g-(f>0?0:f)],range:[0,A*o]}),p=u.getBandWidth(),y=this.rawData;return{columns:l.map(function(m,B){return m.map(function(C,S){var F=p/l.length,T=function(){return{x:u.map(S)+F*B,y:C>=0?h.map(C):h.map(0),width:F,height:v.map(Math.abs(C))}},O=function(){return{x:u.map(S),y:h.map(C),width:p,height:v.map(y[B][S])}};return le(le({fill:t.getColor(B)},n),a?O():T())})})}},enumerable:!1,configurable:!0}),e.prototype.render=function(t,n){sne(n,".container","rect").attr("className","container").node();var i=t.type,a=t.x,s=t.y,o="spark".concat(i),A=le({x:a,y:s},i==="line"?this.linesStyle:this.columnsStyle);Me(n).selectAll(".spark").data([i]).join(function(l){return l.append(function(c){return c==="line"?new lre({className:o,style:A}):new Are({className:o,style:A})}).attr("className","spark ".concat(o))},function(l){return l.update(A)},function(l){return l.remove()})},e.prototype.getColor=function(t){var n=this.attributes.color;return Mr(n)?n[t%n.length]:Te(n)?n.call(null,t):n},e.prototype.createScales=function(t){var n,i,a=this.attributes,s=a.type,o=a.scale,A=a.range,l=A===void 0?[]:A,c=a.spacing,u=this.containerShape,h=u.width,d=u.height,f=H(kO(t),2),g=f[0],v=f[1],p=new rl({domain:[(n=l[0])!==null&&n!==void 0?n:g,(i=l[1])!==null&&i!==void 0?i:v],range:[d,d*(1-o)]});return s==="line"?{type:s,x:new rl({domain:[0,t[0].length-1],range:[0,h]}),y:p}:{type:s,x:new Ab({domain:t[0].map(function(y,m){return m}),range:[0,h],paddingInner:c,paddingOuter:c/2,align:.5}),y:p}},e.tag="sparkline",e})(Zt);function gre(r){return typeof r=="boolean"?!1:"enter"in r&&"update"in r&&"exit"in r}function QO(r){if(!r)return{enter:!1,update:!1,exit:!1};var e=["enter","update","exit"],t=Object.fromEntries(Object.entries(r).filter(function(n){var i=H(n,1),a=i[0];return!e.includes(a)}));return Object.fromEntries(e.map(function(n){return gre(r)?r[n]===!1?[n,!1]:[n,le(le({},r[n]),t)]:[n,t]}))}function AA(r,e){r?r.finished.then(e):e()}function vre(r,e){r.length===0?e():Promise.all(r.map(function(t){return t==null?void 0:t.finished})).then(e)}function aU(r,e){"update"in r?r.update(e):r.attr(e)}function sU(r,e,t){if(e.length===0)return null;if(!t){var n=e.slice(-1)[0];return aU(r,{style:n}),null}return r.animate(e,t)}function pre(r,e){return!(r.nodeName!=="text"||e.nodeName!=="text"||r.attributes.text!==e.attributes.text)}function yre(r,e,t,n){if(n===void 0&&(n="destroy"),pre(r,e))return r.remove(),[null];var i=function(){n==="destroy"?r.destroy():n==="hide"&&yi(r),e.isVisible()&&Yl(e)};if(!t)return i(),[null];var a=t.duration,s=a===void 0?0:a,o=t.delay,A=o===void 0?0:o,l=Math.ceil(+s/2),c=+s/4,u=H(r.getGeometryBounds().center,2),h=u[0],d=u[1],f=H(e.getGeometryBounds().center,2),g=f[0],v=f[1],p=H([(h+g)/2-h,(d+v)/2-d],2),y=p[0],m=p[1],B=r.style.opacity,C=B===void 0?1:B,S=e.style.opacity,F=S===void 0?1:S,T=r.style.transform||"",O=e.style.transform||"",_=r.animate([{opacity:C,transform:"translate(0, 0) ".concat(T)},{opacity:0,transform:"translate(".concat(y,", ").concat(m,") ").concat(T)}],le(le({fill:"both"},t),{duration:A+l+c})),k=e.animate([{opacity:0,transform:"translate(".concat(-y,", ").concat(-m,") ").concat(O),offset:.01},{opacity:F,transform:"translate(0, 0) ".concat(O)}],le(le({fill:"both"},t),{duration:l+c,delay:A+l-c}));return AA(k,i),[_,k]}function mi(r,e,t){var n={},i={};return Object.entries(e).forEach(function(a){var s=H(a,2),o=s[0],A=s[1];if(!ke(A)){var l=r.style[o]||r.parsedStyle[o]||0;l!==A&&(n[o]=l,i[o]=A)}}),t?sU(r,[n,i],le({fill:"both"},t)):(aU(r,i),null)}function Af(r,e){return r.style.opacity||(r.style.opacity=1),mi(r,{opacity:0},e)}var oU={fill:"#fff",lineWidth:1,radius:2,size:10,stroke:"#bfbfbf",strokeOpacity:1,zIndex:0},AU={fill:"#000",fillOpacity:.45,fontSize:12,textAlign:"center",textBaseline:"middle",zIndex:1},lU={x:0,y:0,orientation:"horizontal",showLabel:!0,type:"start"},ki=Si({foreground:"foreground",handle:"handle",selection:"selection",sparkline:"sparkline",sparklineGroup:"sparkline-group",track:"track",brushArea:"brush-area"},"slider"),Jr=Si({labelGroup:"label-group",label:"label",iconGroup:"icon-group",icon:"icon",iconRect:"icon-rect",iconLine:"icon-line"},"handle"),mre=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return e.prototype.render=function(t,n){var i=t.x,a=t.y,s=t.size,o=s===void 0?10:s,A=t.radius,l=A===void 0?o/4:A,c=t.orientation,u=t.classNamePrefix,h=Dt(t,["x","y","size","radius","orientation","classNamePrefix"]),d=o,f=d*2.4,g=u?"".concat(Jr.iconRect.name," ").concat(u,"handle-icon-rect"):Jr.iconRect.name,v=function(S){return u?"".concat(Jr.iconLine,"-").concat(S," ").concat(u,"handle-icon-line"):"".concat(Jr.iconLine,"-").concat(S)},p=Me(n).maybeAppendByClassName(Jr.iconRect,"rect").attr("className",g).styles(le(le({},h),{width:d,height:f,radius:l,x:i-d/2,y:a-f/2,transformOrigin:"center"})),y=i+1/3*d-d/2,m=i+2/3*d-d/2,B=a+1/4*f-f/2,C=a+3/4*f-f/2;p.maybeAppendByClassName("".concat(Jr.iconLine,"-1"),"line").attr("className",v(1)).styles(le({x1:y,x2:y,y1:B,y2:C},h)),p.maybeAppendByClassName("".concat(Jr.iconLine,"-2"),"line").attr("className",v(2)).styles(le({x1:m,x2:m,y1:B,y2:C},h)),c==="vertical"&&(p.node().style.transform="rotate(90)")},e})(Zt),wre=(function(r){Xe(e,r);function e(t){return r.call(this,t,lU)||this}return e.prototype.renderLabel=function(t){var n=this,i=this.attributes,a=i.x,s=i.y,o=i.showLabel,A=ze(this.attributes,"label"),l=A.x,c=l===void 0?0:l,u=A.y,h=u===void 0?0:u,d=A.transform,f=A.transformOrigin,g=Dt(A,["x","y","transform","transformOrigin"]),v=H(ma(g,[]),2),p=v[0],y=v[1],m=Me(t).maybeAppendByClassName(Jr.labelGroup,"g").styles(y),B=le(le({},AU),p),C=B.text,S=Dt(B,["text"]);Fr(!!o,m,function(F){n.label=F.maybeAppendByClassName(Jr.label,"text").styles(le(le({},S),{x:a+c,y:s+h,transform:d,transformOrigin:f,text:"".concat(C)})),n.label.on("mousedown",function(T){T.stopPropagation()}),n.label.on("touchstart",function(T){T.stopPropagation()})})},e.prototype.renderIcon=function(t){var n=this.attributes,i=n.x,a=n.y,s=n.orientation,o=n.type,A=n.classNamePrefix,l=le(le({x:i,y:a,orientation:s,classNamePrefix:A},oU),ze(this.attributes,"icon")),c=this.attributes.iconShape,u=c===void 0?function(){return new mre({style:l})}:c,h=Me(t).maybeAppendByClassName(Jr.iconGroup,"g");h.selectAll(Jr.icon.class).data([u]).join(function(d){return d.append(typeof u=="string"?u:function(){return u(o)}).attr("className",Jr.icon.name)},function(d){return d.update(l)},function(d){return d.remove()})},e.prototype.render=function(t,n){this.renderIcon(n),this.renderLabel(n)},e})(Zt),Bre=(function(r){Xe(e,r);function e(t){var n=r.call(this,t,le(le(le({x:0,y:0,animate:{duration:100,fill:"both"},brushable:!0,formatter:function(i){return i.toString()},handleSpacing:2,orientation:"horizontal",padding:0,autoFitLabel:!0,scrollable:!0,selectionFill:"#5B8FF9",selectionFillOpacity:.45,selectionZIndex:2,showHandle:!0,showLabel:!0,slidable:!0,trackFill:"#416180",trackLength:200,trackOpacity:.05,trackSize:20,trackZIndex:-1,values:[0,1],type:"range",selectionType:"select",handleIconOffset:0},Mo(lU,"handle")),Mo(oU,"handleIcon")),Mo(AU,"handleLabel")))||this;return n.range=[0,1],n.onDragStart=function(i){return function(a){a.stopPropagation(),n.target=i,n.prevPos=n.getOrientVal(hO(a));var s=n.availableSpace,o=s.x,A=s.y,l=n.getBBox(),c=l.x,u=l.y;n.selectionStartPos=n.getRatio(n.prevPos-n.getOrientVal([o,A])-n.getOrientVal([+c,+u])),n.selectionWidth=0,document.addEventListener("pointermove",n.onDragging),document.addEventListener("pointerup",n.onDragEnd)}},n.onDragging=function(i){var a=n.attributes,s=a.slidable,o=a.brushable,A=a.type;i.stopPropagation();var l=n.getOrientVal(hO(i)),c=l-n.prevPos;if(c){var u=n.getRatio(c);switch(n.target){case"start":s&&n.setValuesOffset(u);break;case"end":s&&n.setValuesOffset(0,u);break;case"selection":s&&n.setValuesOffset(u,u);break;case"track":if(!o)return;n.selectionWidth+=u,A==="range"?n.innerSetValues([n.selectionStartPos,n.selectionStartPos+n.selectionWidth].sort(),!0):n.innerSetValues([0,n.selectionStartPos+n.selectionWidth],!0);break}n.prevPos=l}},n.onDragEnd=function(){document.removeEventListener("pointermove",n.onDragging),document.removeEventListener("pointermove",n.onDragging),document.removeEventListener("pointerup",n.onDragEnd),n.target="",n.updateHandlesPosition(!1)},n.onValueChange=function(i){var a=n.attributes,s=a.onChange,o=a.type,A=o==="range"?i:i[1],l=o==="range"?n.getValues():n.getValues()[1],c=new vn("valuechange",{detail:{oldValue:A,value:l}});n.dispatchEvent(c),s==null||s(l)},n.selectionStartPos=0,n.selectionWidth=0,n.prevPos=0,n.target="",n}return Object.defineProperty(e.prototype,"values",{get:function(){return this.attributes.values},set:function(t){this.attributes.values=this.clampValues(t)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"sparklineStyle",{get:function(){var t=this.attributes.orientation;if(t!=="horizontal")return null;var n=ze(this.attributes,"sparkline");return le(le({zIndex:0},this.availableSpace),n)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"shape",{get:function(){var t=this.attributes,n=t.trackLength,i=t.trackSize,a=H(this.getOrientVal([[n,i],[i,n]]),2),s=a[0],o=a[1];return{width:s,height:o}},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"availableSpace",{get:function(){var t=this.attributes;t.x,t.y;var n=t.padding,i=H(jn(n),4),a=i[0],s=i[1],o=i[2],A=i[3],l=this.shape,c=l.width,u=l.height;return{x:A,y:a,width:c-(A+s),height:u-(a+o)}},enumerable:!1,configurable:!0}),e.prototype.getValues=function(){return this.values},e.prototype.setValues=function(t,n){t===void 0&&(t=[0,0]),n===void 0&&(n=!1),this.attributes.values=t;var i=n===!1?!1:this.attributes.animate;this.updateSelectionArea(i),this.updateHandlesPosition(i)},e.prototype.updateSelectionArea=function(t){var n=this.calcSelectionArea();this.foregroundGroup.selectAll(ki.selection.class).each(function(i,a){mi(this,n[a],t)})},e.prototype.updateHandlesPosition=function(t){this.attributes.showHandle&&(this.startHandle&&mi(this.startHandle,this.getHandleStyle("start"),t),this.endHandle&&mi(this.endHandle,this.getHandleStyle("end"),t))},e.prototype.innerSetValues=function(t,n){t===void 0&&(t=[0,0]),n===void 0&&(n=!1);var i=this.values,a=this.clampValues(t);this.attributes.values=a,this.setValues(a),n&&this.onValueChange(i)},e.prototype.renderTrack=function(t){var n=this.attributes,i=n.x,a=n.y,s=ze(this.attributes,"track");this.trackShape=Me(t).maybeAppendByClassName(ki.track,"rect").styles(le(le({x:i,y:a},this.shape),s))},e.prototype.renderBrushArea=function(t){var n=this.attributes,i=n.x,a=n.y,s=n.brushable;this.brushArea=Me(t).maybeAppendByClassName(ki.brushArea,"rect").styles(le({x:i,y:a,fill:"transparent",cursor:s?"crosshair":"default"},this.shape))},e.prototype.renderSparkline=function(t){var n=this,i=this.attributes,a=i.x,s=i.y,o=i.orientation,A=Me(t).maybeAppendByClassName(ki.sparklineGroup,"g");Fr(o==="horizontal",A,function(l){var c=le(le({},n.sparklineStyle),{x:a,y:s});l.maybeAppendByClassName(ki.sparkline,function(){return new fre({style:c})}).update(c)})},e.prototype.renderHandles=function(){var t=this,n,i=this.attributes,a=i.showHandle,s=i.type,o=s==="range"?["start","end"]:["end"],A=a?o:[],l=this;(n=this.foregroundGroup)===null||n===void 0||n.selectAll(ki.handle.class).data(A.map(function(c){return{type:c}}),function(c){return c.type}).join(function(c){return c.append(function(u){var h=u.type;return new wre({style:t.getHandleStyle(h)})}).each(function(u){var h=u.type;this.attr("class","".concat(ki.handle.name," ").concat(h,"-handle"));var d="".concat(h,"Handle");l[d]=this,this.addEventListener("pointerdown",l.onDragStart(h))})},function(c){return c.each(function(u){var h=u.type;this.update(l.getHandleStyle(h))})},function(c){return c.each(function(u){var h=u.type,d="".concat(h,"Handle");l[d]=void 0}).remove()})},e.prototype.renderSelection=function(t){var n=this.attributes,i=n.x,a=n.y,s=n.type,o=n.selectionType;this.foregroundGroup=Me(t).maybeAppendByClassName(ki.foreground,"g");var A=ze(this.attributes,"selection"),l=function(u){return u.style("visibility",function(h){return h.show?"visible":"hidden"}).style("cursor",function(h){return o==="select"?"grab":o==="invert"?"crosshair":"default"}).styles(le(le({},A),{transform:"translate(".concat(i,", ").concat(a,")")}))},c=this;this.foregroundGroup.selectAll(ki.selection.class).data(s==="value"?[]:this.calcSelectionArea().map(function(u,h){return{style:le({},u),index:h,show:o==="select"?h===1:h!==1}}),function(u){return u.index}).join(function(u){return u.append("rect").attr("className",ki.selection.name).call(l).each(function(h,d){var f=this;d===1?(c.selectionShape=Me(this),this.on("pointerdown",function(g){f.attr("cursor","grabbing"),c.onDragStart("selection")(g)}),c.dispatchCustomEvent(this,"pointerenter","selectionMouseenter"),c.dispatchCustomEvent(this,"pointerleave","selectionMouseleave"),c.dispatchCustomEvent(this,"click","selectionClick"),this.addEventListener("pointerdown",function(){f.attr("cursor","grabbing")}),this.addEventListener("pointerup",function(){f.attr("cursor","pointer")}),this.addEventListener("pointerover",function(){f.attr("cursor","pointer")})):this.on("pointerdown",c.onDragStart("track"))})},function(u){return u.call(l)},function(u){return u.remove()}),this.updateSelectionArea(!1),this.renderHandles()},e.prototype.render=function(t,n){this.renderTrack(n),this.renderSparkline(n),this.renderBrushArea(n),this.renderSelection(n)},e.prototype.clampValues=function(t,n){var i;n===void 0&&(n=4);var a=H(this.range,2),s=a[0],o=a[1],A=H(this.getValues().map(function(v){return dO(v,n)}),2),l=A[0],c=A[1],u=Array.isArray(t)?t:[l,t??c],h=H((u||[l,c]).map(function(v){return dO(v,n)}),2),d=h[0],f=h[1];if(this.attributes.type==="value")return[0,Yt(f,s,o)];d>f&&(i=H([f,d],2),d=i[0],f=i[1]);var g=f-d;return g>o-s?[s,o]:d<s?l===s&&c===f?[s,f]:[s,g+s]:f>o?c===o&&l===d?[d,o]:[o-g,o]:[d,f]},e.prototype.calcSelectionArea=function(t){var n=H(this.clampValues(t),2),i=n[0],a=n[1],s=this.availableSpace,o=s.x,A=s.y,l=s.width,c=s.height;return this.getOrientVal([[{y:A,height:c,x:o,width:i*l},{y:A,height:c,x:i*l+o,width:(a-i)*l},{y:A,height:c,x:a*l,width:(1-a)*l}],[{x:o,width:l,y:A,height:i*c},{x:o,width:l,y:i*c+A,height:(a-i)*c},{x:o,width:l,y:a*c,height:(1-a)*c}]])},e.prototype.calcHandlePosition=function(t){var n=this.attributes.handleIconOffset,i=this.availableSpace,a=i.x,s=i.y,o=i.width,A=i.height,l=H(this.clampValues(),2),c=l[0],u=l[1],h=t==="start"?-n:n,d=(t==="start"?c:u)*this.getOrientVal([o,A])+h;return{x:a+this.getOrientVal([d,o/2]),y:s+this.getOrientVal([A/2,d])}},e.prototype.inferTextStyle=function(t){var n=this.attributes.orientation;return n==="horizontal"?{}:t==="start"?{transformOrigin:"left center",transform:"rotate(90)",textAlign:"start"}:t==="end"?{transformOrigin:"right center",transform:"rotate(90)",textAlign:"end"}:{}},e.prototype.calcHandleText=function(t){var n,i=this.attributes,a=i.type,s=i.orientation,o=i.formatter,A=i.autoFitLabel,l=ze(this.attributes,"handle"),c=ze(l,"label"),u=l.spacing,h=this.getHandleSize(),d=this.clampValues(),f=t==="start"?d[0]:d[1],g=o(f),v=new nb({style:le(le(le({},c),this.inferTextStyle(t)),{text:g})}),p=v.getBBox(),y=p.width,m=p.height;if(v.destroy(),!A){if(a==="value")return{text:g,x:0,y:-m-u};var B=u+h+(s==="horizontal"?y/2:0);return n={text:g},n[s==="horizontal"?"x":"y"]=t==="start"?-B:B,n}var C=0,S=0,F=this.availableSpace,T=F.width,O=F.height,_=this.calcSelectionArea()[1],k=_.x,L=_.y,U=_.width,G=_.height,W=u+h;if(s==="horizontal"){var V=W+y/2;if(t==="start"){var K=k-W-y;C=K>0?-V:V}else{var D=T-k-U-W>y;C=D?V:-V}}else{var X=W,te=m+W;t==="start"?S=L-h>m?-te:X:S=O-(L+G)-h>m?te:-X}return{x:C,y:S,text:g}},e.prototype.getHandleLabelStyle=function(t){var n=ze(this.attributes,"handleLabel");return le(le(le({},n),this.calcHandleText(t)),this.inferTextStyle(t))},e.prototype.getHandleIconStyle=function(){var t=this.attributes.handleIconShape,n=ze(this.attributes,"handleIcon"),i=this.getOrientVal(["ew-resize","ns-resize"]),a=this.getHandleSize();return le({cursor:i,shape:t,size:a},n)},e.prototype.getHandleStyle=function(t){var n=this.attributes,i=n.x,a=n.y,s=n.showLabel,o=n.showLabelOnInteraction,A=n.orientation,l=this.calcHandlePosition(t),c=l.x,u=l.y,h=this.calcHandleText(t),d=s;return!s&&o&&(this.target?d=!0:d=!1),le(le(le({},Mo(this.getHandleIconStyle(),"icon")),Mo(le(le({},this.getHandleLabelStyle(t)),h),"label")),{transform:"translate(".concat(c+i,", ").concat(u+a,")"),orientation:A,showLabel:d,type:t,zIndex:3})},e.prototype.getHandleSize=function(){var t=this.attributes,n=t.handleIconSize,i=t.width,a=t.height;return n||Math.floor((this.getOrientVal([+a,+i])+4)/2.4)},e.prototype.getOrientVal=function(t){var n=H(t,2),i=n[0],a=n[1],s=this.attributes.orientation;return s==="horizontal"?i:a},e.prototype.setValuesOffset=function(t,n){n===void 0&&(n=0);var i=this.attributes.type,a=H(this.getValues(),2),s=a[0],o=a[1],A=i==="range"?t:0,l=[s+A,o+n].sort();this.innerSetValues(l,!0)},e.prototype.getRatio=function(t){var n=this.availableSpace,i=n.width,a=n.height;return t/this.getOrientVal([i,a])},e.prototype.dispatchCustomEvent=function(t,n,i){var a=this;t.on(n,function(s){s.stopPropagation(),a.dispatchEvent(new vn(i,{detail:s}))})},e.prototype.bindEvents=function(){this.addEventListener("wheel",this.onScroll);var t=this.brushArea;this.dispatchCustomEvent(t,"click","trackClick"),this.dispatchCustomEvent(t,"pointerenter","trackMouseenter"),this.dispatchCustomEvent(t,"pointerleave","trackMouseleave"),t.on("pointerdown",this.onDragStart("track"))},e.prototype.onScroll=function(t){var n=this.attributes.scrollable;if(n){var i=t.deltaX,a=t.deltaY,s=a||i,o=this.getRatio(s);this.setValuesOffset(o,o)}},e.tag="slider",e})(Zt),dt={gridGroup:"grid-group",mainGroup:"main-group",lineGroup:"line-group",tickGroup:"tick-group",labelGroup:"label-group",titleGroup:"title-group",grid:"grid",line:"line",lineFirst:"line-first",lineSecond:"line-second",tick:"tick",tickItem:"tick-item",label:"label",labelItem:"label-item",title:"title"},cb={data:[],animate:{enter:!1,update:{duration:100,easing:"ease-in-out-sine",fill:"both"},exit:{duration:100,fill:"both"}},showArrow:!0,showGrid:!0,showLabel:!0,showLine:!0,showTick:!0,showTitle:!0,showTrunc:!1,dataThreshold:100,lineLineWidth:1,lineStroke:"black",crossPadding:10,titleFill:"black",titleFontSize:12,titlePosition:"lb",titleSpacing:0,titleTextAlign:"center",titleTextBaseline:"middle",lineArrow:function(){return new rr({style:{d:[["M",10,10],["L",-10,0],["L",10,-10],["L",0,0],["L",10,10],["Z"]],fill:"black",transformOrigin:"center"}})},labelAlign:"parallel",labelDirection:"positive",labelFontSize:12,labelSpacing:0,gridConnect:"line",gridControlAngles:[],gridDirection:"positive",gridLength:0,gridType:"segment",lineArrowOffset:15,lineArrowSize:10,tickDirection:"positive",tickLength:5,tickLineWidth:1,tickStroke:"black",labelOverlap:[]};zn({},cb,{style:{type:"arc"}});zn({},cb,{style:{}});var Ge=Si({mainGroup:dt.mainGroup,gridGroup:dt.gridGroup,grid:dt.grid,lineGroup:dt.lineGroup,line:dt.line,tickGroup:dt.tickGroup,tick:dt.tick,tickItem:dt.tickItem,labelGroup:dt.labelGroup,label:dt.label,labelItem:dt.labelItem,titleGroup:dt.titleGroup,title:dt.title,lineFirst:dt.lineFirst,lineSecond:dt.lineSecond},"axis"),Xo=Si({lineGroup:"line-group",line:"line",regionGroup:"region-group",region:"region"},"grid");function cU(r){return r.reduce(function(e,t,n){return e.push(_e([n===0?"M":"L"],H(t),!1)),e},[])}function bre(r,e,t){var n=e.connect,i=n===void 0?"line":n,a=e.center;if(i==="line")return cU(r);if(!a)return[];var s=El(r[0],a),o=t?0:1;return r.reduce(function(A,l,c){return c===0?A.push(_e(["M"],H(l),!1)):A.push(_e(["A",s,s,0,0,o],H(l),!1)),A},[])}function _1(r,e,t){return e.type==="surround"?bre(r,e,t):cU(r)}function Ere(r,e,t){var n=t.type,i=t.connect,a=t.center,s=t.closed,o=s?[["Z"]]:[],A=H([_1(r,t),_1(e.slice().reverse(),t,!0)],2),l=A[0],c=A[1],u=H([r[0],e.slice(-1)[0]],2),h=u[0],d=u[1],f=function(y,m){return[l,y,c,m,o].flat()};if(i==="line"||n==="surround")return f([_e(["L"],H(d),!1)],[_e(["L"],H(h),!1)]);if(!a)throw new Error("Arc grid need to specified center");var g=H([El(d,a),El(h,a)],2),v=g[0],p=g[1];return f([_e(["A",v,v,0,0,1],H(d),!1),_e(["L"],H(d),!1)],[_e(["A",p,p,0,0,0],H(h),!1),_e(["L"],H(h),!1)])}function xre(r,e,t,n){var i=t.animate,a=t.isBillboard,s=e.map(function(o,A){return{id:o.id||"grid-line-".concat(A),d:_1(o.points,t)}});return r.selectAll(Xo.line.class).data(s,function(o){return o.id}).join(function(o){return o.append("path").each(function(A,l){var c=Tr(fO(le({d:A.d},n)),[A,l,s]);this.attr(le({class:Xo.line.name,stroke:"#D9D9D9",lineWidth:1,lineDash:[4,4],isBillboard:a},c))})},function(o){return o.transition(function(A,l){var c=Tr(fO(le({d:A.d},n)),[A,l,s]);return mi(this,c,i.update)})},function(o){return o.transition(function(){var A=this,l=Af(this,i.exit);return AA(l,function(){return A.remove()}),l})}).transitions()}function Cre(r,e,t){var n=t.animate,i=t.connect,a=t.areaFill;if(e.length<2||!a||!i)return[];for(var s=Array.isArray(a)?a:[a,"transparent"],o=function(f){return s[f%s.length]},A=[],l=0;l<e.length-1;l++){var c=H([e[l].points,e[l+1].points],2),u=c[0],h=c[1],d=Ere(u,h,t);A.push({d,fill:o(l)})}return r.selectAll(Xo.region.class).data(A,function(f,g){return g}).join(function(f){return f.append("path").each(function(g,v){var p=Tr(g,[g,v,A]);this.attr(p)}).attr("className",Xo.region.name)},function(f){return f.transition(function(g,v){var p=Tr(g,[g,v,A]);return mi(this,p,n.update)})},function(f){return f.transition(function(){var g=this,v=Af(this,n.exit);return AA(v,function(){return g.remove()}),v})}).transitions()}function Sre(r){var e=r.data,t=e===void 0?[]:e,n=r.closed;return n?t.map(function(i){var a=i.points,s=H(a,1),o=s[0];return le(le({},i),{points:_e(_e([],H(a),!1),[o],!1)})}):t}var Fre=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return e.prototype.render=function(t,n){t.type,t.center,t.areaFill,t.closed;var i=Dt(t,["type","center","areaFill","closed"]),a=Sre(t),s=Me(n).maybeAppendByClassName(Xo.lineGroup,"g"),o=Me(n).maybeAppendByClassName(Xo.regionGroup,"g"),A=xre(s,a,t,i),l=Cre(o,a,t);return _e(_e([],H(A),!1),H(l),!1)},e})(Zt);function uU(r,e){return Object.fromEntries(Object.entries(r).map(function(t){var n=H(t,2),i=n[0],a=n[1];return[i,Tr(a,e)]}))}function ub(r,e){return e&&Te(e)?r.filter(e):r}function hU(r,e){var t=e.startAngle,n=e.endAngle;return(n-t)*r+t}function lf(r,e){if(e.type==="linear"){var t=H(e.startPos,2),n=t[0],i=t[1],a=H(e.endPos,2),s=a[0],o=a[1],A=H([s-n,o-i],2),l=A[0],c=A[1];return JN([l,c])}var u=Yo(hU(r,e));return[-Math.sin(u),Math.cos(u)]}function hb(r,e,t){var n=lf(r,t);return Xte(n,e!=="positive")}function lA(r,e){return hb(r,e.labelDirection,e)}function Ru(r,e,t){return t?"".concat(r," ").concat(t,"axis-").concat(e):r}function Kr(r,e,t,n){return n&&r.attr("className",Ru(e.name,t,n)),r}function Tre(r,e){var t=H(e.startPos,2),n=t[0],i=t[1],a=H(e.endPos,2),s=a[0],o=a[1],A=H([s-n,o-i],2),l=A[0],c=A[1];return[n+l*r,i+c*r]}function Mre(r,e){var t=e.radius,n=H(e.center,2),i=n[0],a=n[1],s=Yo(hU(r,e));return[i+t*Math.cos(s),a+t*Math.sin(s)]}function cf(r,e){return e.type==="linear"?Tre(r,e):Mre(r,e)}function db(r){return lf(0,r)[1]===0}function dU(r){return lf(0,r)[0]===0}function fU(r,e){return e-r===360}function NO(r,e,t,n,i){var a=e-r,s=H([i,i],2),o=s[0],A=s[1],l=H([Yo(r),Yo(e)],2),c=l[0],u=l[1],h=function(O){return[t+i*Math.cos(O),n+i*Math.sin(O)]},d=H(h(c),2),f=d[0],g=d[1],v=H(h(u),2),p=v[0],y=v[1];if(fU(r,e)){var m=(u+c)/2,B=H(h(m),2),C=B[0],S=B[1];return[["M",f,g],["A",o,A,0,1,0,C,S],["A",o,A,0,1,0,p,y]]}var F=a>180?1:0,T=r>e?0:1;return"M".concat(f,",").concat(g,",A").concat(o,",").concat(A,",0,").concat(F,",").concat(T,",").concat(p,",").concat(y)}function Ore(r){var e=r.attributes,t=e.startAngle,n=e.endAngle,i=e.center,a=e.radius;return _e(_e([t,n],H(i),!1),[a],!1)}function _re(r,e,t,n){var i=e.startAngle,a=e.endAngle,s=e.center,o=e.radius,A=e.classNamePrefix;return r.selectAll(Ge.line.class).data([{d:NO.apply(void 0,_e(_e([i,a],H(s),!1),[o],!1))}],function(l,c){return c}).join(function(l){var c=l.append("path").attr("className",Ge.line.name).styles(e).styles({d:function(u){return u.d}});return Kr(c,Ge.line,dt.line,A),c},function(l){return l.transition(function(){var c=this,u=Yte(this,Ore(this),_e(_e([i,a],H(s),!1),[o],!1),n.update);if(u){var h=function(){var d=Rn(c.attributes,"__keyframe_data__");c.style.d=NO.apply(void 0,_e([],H(d),!1))};u.onframe=h,u.onfinish=h}return u}).styles(e)},function(l){return l.remove()}).styles(t).transitions()}function Ire(r,e){e.truncRange,e.truncShape,e.lineExtension}function kre(r,e,t){t===void 0&&(t=[0,0]);var n=H([r,e,t],3),i=H(n[0],2),a=i[0],s=i[1],o=H(n[1],2),A=o[0],l=o[1],c=H(n[2],2),u=c[0],h=c[1],d=H([A-a,l-s],2),f=d[0],g=d[1],v=Math.sqrt(Math.pow(f,2)+Math.pow(g,2)),p=H([-u/v,h/v],2),y=p[0],m=p[1];return[y*f,y*g,m*f,m*g]}function UO(r){var e=H(r,2),t=H(e[0],2),n=t[0],i=t[1],a=H(e[1],2),s=a[0],o=a[1];return{x1:n,y1:i,x2:s,y2:o}}function Lre(r,e,t,n){var i=e.showTrunc,a=e.startPos,s=e.endPos,o=e.truncRange,A=e.lineExtension,l=e.classNamePrefix,c=H([a,s],2),u=H(c[0],2),h=u[0],d=u[1],f=H(c[1],2),g=f[0],v=f[1],p=H(A?kre(a,s,A):new Array(4).fill(0),4),y=p[0],m=p[1],B=p[2],C=p[3],S=function(X){return r.selectAll(Ge.line.class).data(X,function(te,ie){return ie}).join(function(te){var ie=te.append("line").styles(t).transition(function(re){return mi(this,UO(re.line),!1)});return ie.attr("className",function(re){if(!l)return"".concat(Ge.line.name," ").concat(re.className);var xe=Ru(Ge.line.name,dt.line,l);if(re.className===Ge.lineFirst.name){var $=Ru(Ge.lineFirst.name,dt.lineFirst,l);return"".concat(xe," ").concat($)}if(re.className===Ge.lineSecond.name){var $=Ru(Ge.lineSecond.name,dt.lineSecond,l);return"".concat(xe," ").concat($)}return xe}),ie},function(te){return te.styles(t).transition(function(ie){var re=ie.line;return mi(this,UO(re),n.update)})},function(te){return te.remove()}).transitions()};if(!i||!o)return S([{line:[[h+y,d+m],[g+B,v+C]],className:Ge.line.name}]);var F=H(o,2),T=F[0],O=F[1],_=g-h,k=v-d,L=H([h+_*T,d+k*T],2),U=L[0],G=L[1],W=H([h+_*O,d+k*O],2),V=W[0],K=W[1],D=S([{line:[[h+y,d+m],[U,G]],className:Ge.lineFirst.name},{line:[[V,K],[g+B,v+C]],className:Ge.lineSecond.name}]);return Ire(r,e),D}function Qre(r,e,t,n){var i=t.showArrow,a=t.showTrunc,s=t.lineArrow,o=t.lineArrowOffset,A=t.lineArrowSize,l;if(e==="arc"?l=r.select(Ge.line.class):a?l=r.select(Ge.lineSecond.class):l=r.select(Ge.line.class),!i||!s||t.type==="arc"&&fU(t.startAngle,t.endAngle)){var c=l.node();c&&(c.style.markerEnd=void 0);return}var u=ya(s);u.attr(n),ib(u,A),l.style("markerEnd",u).style("markerEndOffset",-o)}function Nre(r,e,t){var n=e.type,i,a=ze(e,"line");return n==="linear"?i=Lre(r,e,M1(a,"arrow"),t):i=_re(r,e,M1(a,"arrow"),t),Qre(r,n,e,a),i}function Ure(r,e){return hb(r,e.gridDirection,e)}function gU(r){var e=r.type,t=r.gridCenter;return e==="linear"?t:t||r.center}function Pre(r,e){var t=e.gridLength;return r.map(function(n,i){var a=n.value,s=H(cf(a,e),2),o=s[0],A=s[1],l=H(ca(Ure(a,e),t),2),c=l[0],u=l[1];return{id:i,points:[[o,A],[o+c,A+u]]}})}function Rre(r,e){var t=e.gridControlAngles,n=gU(e);if(!n)throw new Error("grid center is not provide");if(r.length<2)throw new Error("Invalid grid data");if(!t||t.length===0)throw new Error("Invalid gridControlAngles");var i=H(n,2),a=i[0],s=i[1];return r.map(function(o,A){var l=o.value,c=H(cf(l,e),2),u=c[0],h=c[1],d=H([u-a,h-s],2),f=d[0],g=d[1],v=[];return t.forEach(function(p){var y=Yo(p),m=H([Math.cos(y),Math.sin(y)],2),B=m[0],C=m[1],S=f*B-g*C+a,F=f*C+g*B+s;v.push([S,F])}),{points:v,id:A}})}function Dre(r,e,t,n){var i=t.classNamePrefix,a=ze(t,"grid"),s=a.type,o=a.areaFill,A=gU(t),l=ub(e,t.gridFilter),c=s==="segment"?Pre(l,t):Rre(l,t),u=le(le({},a),{center:A,areaFill:Te(o)?l.map(function(h,d){return Tr(o,[h,d,l])}):o,animate:n,data:c});return r.selectAll(Ge.grid.class).data([1]).join(function(h){var d=h.append(function(){return new Fre({style:u})}).attr("className",Ge.grid.name);return Kr(d,Ge.grid,dt.grid,i),d},function(h){return h.transition(function(){return this.update(u)})},function(h){return h.remove()}).transitions()}var I1=(function(){function r(e,t,n,i){this.set(e,t,n,i)}return Object.defineProperty(r.prototype,"left",{get:function(){return this.x1},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"top",{get:function(){return this.y1},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"right",{get:function(){return this.x2},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"bottom",{get:function(){return this.y2},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"width",{get:function(){return this.defined("x2")&&this.defined("x1")?this.x2-this.x1:void 0},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"height",{get:function(){return this.defined("y2")&&this.defined("y1")?this.y2-this.y1:void 0},enumerable:!1,configurable:!0}),r.prototype.rotatedPoints=function(e,t,n){var i=this,a=i.x1,s=i.y1,o=i.x2,A=i.y2,l=Math.cos(e),c=Math.sin(e),u=t-t*l+n*c,h=n-t*c-n*l,d=[[l*a-c*A+u,c*a+l*A+h],[l*o-c*A+u,c*o+l*A+h],[l*a-c*s+u,c*a+l*s+h],[l*o-c*s+u,c*o+l*s+h]];return d},r.prototype.set=function(e,t,n,i){return n<e?(this.x2=e,this.x1=n):(this.x1=e,this.x2=n),i<t?(this.y2=t,this.y1=i):(this.y1=t,this.y2=i),this},r.prototype.defined=function(e){return this[e]!==Number.MAX_VALUE&&this[e]!==-Number.MAX_VALUE},r})();function k1(r,e){var t=r.getEulerAngles()||0;r.setEulerAngles(0);var n=r.getBounds(),i=H(n.min,2),a=i[0],s=i[1],o=H(n.max,2),A=o[0],l=o[1],c=r.getBBox(),u=c.width,h=c.height,d=h,f=0,g=0,v=a,p=s,y=XN(r);if(y){d-=1.5;var m=y.style.textAlign,B=y.style.textBaseline;m==="center"?v=(a+A)/2:(m==="right"||m==="end")&&(v=A),B==="middle"?p=(s+l)/2:B==="bottom"&&(p=l)}var C=H(jn(e),4),S=C[0],F=S===void 0?0:S,T=C[1],O=T===void 0?0:T,_=C[2],k=_===void 0?F:_,L=C[3],U=L===void 0?O:L,G=new I1((f+=a)-U,(g+=s)-F,f+u+O,g+d+k);return r.setEulerAngles(t),G.rotatedPoints(Yo(t),v,p)}function jA(r,e){return e[0]<=Math.max(r[0][0],r[1][0])&&e[0]<=Math.min(r[0][0],r[1][0])&&e[1]<=Math.max(r[0][1],r[1][1])&&e[1]<=Math.min(r[0][1],r[1][1])}function WA(r,e,t){var n=(e[1]-r[1])*(t[0]-e[0])-(e[0]-r[0])*(t[1]-e[1]);return n===0?0:n<0?2:1}function Hre(r,e){var t=WA(r[0],r[1],e[0]),n=WA(r[0],r[1],e[1]),i=WA(e[0],e[1],r[0]),a=WA(e[0],e[1],r[1]);return!!(t!==n&&i!==a||t===0&&jA(r,e[0])||n===0&&jA(r,e[1])||i===0&&jA(e,r[0])||a===0&&jA(e,r[1]))}function Gre(r,e){var t=r.length;if(t<3)return!1;var n=[e,[9999,e[1]]],i=0,a=0;do{var s=[r[a],r[(a+1)%t]];if(Hre(s,n)){if(WA(s[0],e,s[1])===0)return jA(s,e);i++}a=(a+1)%t}while(a!==0);return!!(i&1)}function Kre(r,e){return e.every(function(t){return Gre(r,t)})}function zre(r,e,t){var n=r.x1,i=r.x2,a=r.y1,s=r.y2,o=[[n,a],[i,a],[i,s],[n,s]],A=k1(e,t);return Kre(o,A)}function Vre(r,e){var t=H(r,4),n=t[0],i=t[1],a=t[2],s=t[3],o=H(e,4),A=o[0],l=o[1],c=o[2],u=o[3],h=a-n,d=s-i,f=c-A,g=u-l,v=h*g-f*d;if(v===0)return!1;var p=v>0,y=n-A,m=i-l,B=h*m-d*y;if(B<0===p)return!1;var C=f*m-g*y;return!(C<0===p||B>v===p||C>v===p)}function jre(r,e){var t=[[r[0],r[1],r[2],r[3]],[r[2],r[3],r[4],r[5]],[r[4],r[5],r[6],r[7]],[r[6],r[7],r[0],r[1]]];return t.some(function(n){return Vre(e,n)})}function Wre(r,e,t){var n,i,a=k1(r,t).flat(1),s=k1(e,t).flat(1),o=[[a[0],a[1],a[2],a[3]],[a[0],a[1],a[4],a[5]],[a[4],a[5],a[6],a[7]],[a[2],a[3],a[6],a[7]]];try{for(var A=Fl(o),l=A.next();!l.done;l=A.next()){var c=l.value;if(jre(s,c))return!0}}catch(u){n={error:u}}finally{try{l&&!l.done&&(i=A.return)&&i.call(A)}finally{if(n)throw n.error}}return!1}function qre(r,e){var t=r.type,n=r.labelDirection,i=r.crossSize;if(!i)return!1;if(t==="arc"){var a=r.center,s=r.radius,o=H(a,2),A=o[0],l=o[1],c=n==="negative"?0:i,u=-s-c,h=s+c,d=H(jn(e),4),f=d[0],g=d[1],v=d[2],p=d[3];return new I1(A+u-p,l+u-f,A+h+g,l+h+v)}var y=H(r.startPos,2),m=y[0],B=y[1],C=H(r.endPos,2),S=C[0],F=C[1],T=H(dU(r)?[-e,0,e,0]:[0,e,0,-e],4),O=T[0],_=T[1],k=T[2],L=T[3],U=lA(0,r),G=ca(U,i),W=new I1(m,B,S,F);return W.x1+=L,W.y1+=O,W.x2+=_+G[0],W.y2+=k+G[1],W}function uf(r,e,t){var n,i,a=e.crossPadding,s=new Set,o=null,A=qre(e,a),l=function(f){return A?zre(A,f):!0},c=function(f,g){return!f||!f.firstChild?!0:!Wre(f.firstChild,g.firstChild,jn(t))};try{for(var u=Fl(r),h=u.next();!h.done;h=u.next()){var d=h.value;l(d)?!o||c(o,d)?o=d:(s.add(o),s.add(d)):s.add(d)}}catch(f){n={error:f}}finally{try{h&&!h.done&&(i=u.return)&&i.call(u)}finally{if(n)throw n.error}}return Array.from(s)}function aw(r,e){return e===void 0&&(e={}),ke(r)?0:typeof r=="number"?r:Math.floor(Kte(r,e))}function $re(r,e,t,n){if(!(r.length<=0)){var i=e.suffix,a=i===void 0?"...":i,s=e.minLength,o=e.maxLength,A=o===void 0?1/0:o,l=e.step,c=l===void 0?" ":l,u=e.margin,h=u===void 0?[0,0,0,0]:u,d=YN(n.getTextShape(r[0])),f=aw(c,d),g=s?aw(s,d):f,v=aw(A,d);(ke(v)||v===1/0)&&(v=Math.max.apply(null,r.map(function(S){return S.getBBox().width})));var p=r.slice(),y=H(h,4);y[0],y[1],y[2],y[3];for(var m=function(S){if(p.forEach(function(F){n.ellipsis(n.getTextShape(F),S,a)}),p=uf(r,t,h),p.length<1)return{value:void 0}},B=v;B>g+f;B-=f){var C=m(B);if(typeof C=="object")return C.value}}}var Yre={parity:function(r,e){var t=e.seq,n=t===void 0?2:t;return r.filter(function(i,a){return a%n?(yi(i),!1):!0})}},Xre=function(r){return r.filter(Gte)};function Zre(r,e,t,n){var i=r.length,a=e.keepHeader,s=e.keepTail;if(!(i<=1||i===2&&a&&s)){var o=Yre.parity,A=function(m){return m.forEach(n.show),m},l=2,c=r.slice(),u=r.slice(),h=Math.min.apply(Math,_e([1],H(r.map(function(m){return m.getBBox().width})),!1));if(t.type==="linear"&&(db(t)||dU(t))){var d=gO(r[0]).left,f=gO(r[i-1]).right,g=Math.abs(f-d)||1;l=Math.max(Math.floor(i*h/g),l)}var v,p;for(a&&(v=c.splice(0,1)[0]),s&&(p=c.splice(-1,1)[0],c.reverse()),A(c);l<r.length&&uf(Xre(p?_e(_e([p],H(u),!1),[v],!1):_e([v],H(u),!1)),t,e==null?void 0:e.margin).length;){if(p&&!v&&l%2===0){var y=c.splice(0,1);y.forEach(n.hide)}else if(p&&v){var y=c.splice(0,1);y.forEach(n.hide)}u=o(A(c),{seq:l}),l++}}}function Jre(r,e,t,n){var i,a,s=e.optionalAngles,o=s===void 0?[0,45,90]:s,A=e.margin,l=e.recoverWhenFailed,c=l===void 0?!0:l,u=r.map(function(p){return p.getLocalEulerAngles()}),h=function(){return uf(r,t,A).length<1},d=function(p){return r.forEach(function(y,m){var B=Array.isArray(p)?p[m]:p;n.rotate(y,+B)})};try{for(var f=Fl(o),g=f.next();!g.done;g=f.next()){var v=g.value;if(d(v),h())return}}catch(p){i={error:p}}finally{try{g&&!g.done&&(a=f.return)&&a.call(f)}finally{if(i)throw i.error}}c&&d(u)}function eie(r){var e=r.type,t=r.labelDirection;return e==="linear"&&db(r)?t==="negative"?"bottom":"top":"middle"}function tie(r,e,t,n,i){var a,s=e.maxLines,o=s===void 0?3:s,A=e.recoverWhenFailed,l=A===void 0?!0:A,c=e.margin,u=c===void 0?[0,0,0,0]:c,h=Tr((a=e.wordWrapWidth)!==null&&a!==void 0?a:50,[i]),d=r.map(function(m){return m.attr("maxLines")||1}),f=Math.min.apply(Math,_e([],H(d),!1)),g=function(){return uf(r,t,u).length<1},v=eie(t),p=function(m){return r.forEach(function(B,C){var S=Array.isArray(m)?m[C]:m;n.wrap(B,h,S,v)})};if(!(f>o)){if(t.type==="linear"&&db(t)){if(p(o),g())return}else for(var y=f;y<=o;y++)if(p(y),g())return;l&&p(d)}}var nie=new Map([["hide",Zre],["rotate",Jre],["ellipsis",$re],["wrap",tie]]);function rie(r,e,t){return e.labelOverlap.length<1?!1:t==="hide"?!Dte(r[0]):t==="rotate"?!r.some(function(n){var i;return!!(!((i=n.attr("transform"))===null||i===void 0)&&i.includes("rotate"))}):t==="ellipsis"||t==="wrap"?r.filter(function(n){return n.querySelector("text")}).length>=1:!0}function iie(r,e,t,n){var i=e.labelOverlap,a=i===void 0?[]:i;a.length&&a.forEach(function(s){var o=s.type,A=nie.get(o);rie(r,e,o)&&(A==null||A(r,s,e,n,t))})}function aie(){for(var r=[],e=0;e<arguments.length;e++)r[e]=arguments[e];var t=function(n){return n==="positive"?-1:1};return r.reduce(function(n,i){return n*t(i)},1)}function PO(r){for(var e=r;e<0;)e+=360;return Math.round(e%360)}function L1(r,e){var t=H(r,2),n=t[0],i=t[1],a=H(e,2),s=a[0],o=a[1],A=H([n*s+i*o,n*o-i*s],2),l=A[0],c=A[1];return Math.atan2(c,l)}function sie(r){var e=(r+360)%180;return Pn(e,-90,90)||(e+=180),e}function oie(r,e,t){var n,i=t.labelAlign,a=(n=e.style.transform)===null||n===void 0?void 0:n.includes("rotate");if(a)return e.getLocalEulerAngles();var s=0,o=lA(r.value,t),A=lf(r.value,t);return i==="horizontal"?0:(i==="perpendicular"?s=L1([1,0],o):s=L1([A[0]<0?-1:1,0],A),sie(qN(s)))}function vU(r,e,t){var n=t.type,i=t.labelAlign,a=lA(r,t),s=PO(e),o=PO(qN(L1([1,0],a))),A="center",l="middle";return n==="linear"?[90,270].includes(o)&&s===0?(A="center",l=a[1]===1?"top":"bottom"):!(o%180)&&[90,270].includes(s)?A="center":o===0?(Pn(s,0,90,!1,!0)||Pn(s,0,90)||Pn(s,270,360))&&(A="start"):o===90?Pn(s,0,90,!1,!0)?A="start":(Pn(s,90,180)||Pn(s,270,360))&&(A="end"):o===270?Pn(s,0,90,!1,!0)?A="end":(Pn(s,90,180)||Pn(s,270,360))&&(A="start"):o===180&&(s===90?A="start":(Pn(s,0,90)||Pn(s,270,360))&&(A="end")):i==="parallel"?Pn(o,0,180,!0)?l="top":l="bottom":i==="horizontal"?Pn(o,90,270,!1)?A="end":(Pn(o,270,360,!1)||Pn(o,0,90))&&(A="start"):i==="perpendicular"&&(Pn(o,90,270)?A="end":A="start"),{textAlign:A,textBaseline:l}}function Aie(r,e,t){e.setLocalEulerAngles(r);var n=e.__data__.value,i=vU(n,r,t),a=e.querySelector(Ge.labelItem.class);a&&pU(a,i)}function RO(r,e,t){var n=t.showTick,i=t.tickLength,a=t.tickDirection,s=t.labelDirection,o=t.labelSpacing,A=e.indexOf(r),l=Tr(o,[r,A,e]),c=H([lA(r.value,t),aie(s,a)],2),u=c[0],h=c[1],d=h===1?Tr(n?i:0,[r,A,e]):0,f=H(VA(ca(u,l+d),cf(r.value,t)),2),g=f[0],v=f[1];return{x:g,y:v}}function lie(r,e,t,n){var i=n.labelFormatter,a=Te(i)?function(){return ya(Tr(i,[r,e,t,lA(r.value,n)]))}:function(){return ya(r.label||"")};return a}function cie(r,e,t,n){var i=n.labelRender,a=(Rn(n,"endPos.0",400)-Rn(n,"startPos.0",0))/t.length,s=Te(i)?Tr(i,[r,e,t,lA(r.value,n)]):r.label||"",o=fne(s)||30;return function(){return Vte(s,{width:a,height:o})}}var uie={html:["fill"],text:[]};function pU(r,e){["text","html"].includes(r.nodeName)&&r.attr(M1(e,uie[r.nodeName]))}function hie(r,e){iie(this.node().childNodes,r,e,{hide:yi,show:Yl,rotate:function(t,n){Aie(+n,t,r)},ellipsis:function(t,n,i){t&&T1(t,n||1/0,i)},wrap:function(t,n,i){t&&zte(t,n,i)},getTextShape:function(t){return t.querySelector(Ge.labelItem.class)}})}function DO(r,e,t,n,i){var a=t.indexOf(e),s=i.labelRender,o=i.classNamePrefix,A=Me(r).append(s?cie(e,a,t,i):lie(e,a,t,i)).attr("className",Ge.labelItem.name).node();Kr(Me(A),Ge.labelItem,dt.labelItem,o);var l=H(ma(uU(n,[e,a,t])),2),c=l[0],u=l[1],h=u.transform,d=Dt(u,["transform"]);eU(A,h);var f=oie(e,A,i);if(A.getLocalEulerAngles()||A.setLocalEulerAngles(f),pU(A,le(le({},vU(e.value,f,i)),c)),A.nodeName==="html"){var g=A.getBBox(),v=A.style.x||0;A.attr("x",v-g.width/2)}return r.attr(d),A}function die(r,e,t,n,i){var a=t.classNamePrefix,s=ub(e,t.labelFilter),o=ze(t,"label"),A,l=r.selectAll(Ge.label.class).data(s,function(c,u){return u}).join(function(c){var u=c.append("g").attr("className",Ge.label.name).transition(function(h){DO(this,h,e,o,t);var d=RO(h,e,t),f=d.x,g=d.y;return this.style.transform="translate(".concat(f,", ").concat(g,")"),null});return Kr(u,Ge.label,dt.label,a),u},function(c){return c.transition(function(u){var h=this.querySelector(Ge.labelItem.class),d=DO(this,u,e,o,t),f=yre(h,d,n.update),g=RO(u,e,t),v=g.x,p=g.y,y=mi(this,{transform:"translate(".concat(v,", ").concat(p,")")},n.update);return _e(_e([],H(f),!1),[y],!1)})},function(c){return A=c,c.transition(function(){var u=this,h=Af(this.childNodes[0],n.exit);return AA(h,function(){return Me(u).remove()}),h}),A}).transitions();return vre(l,function(){hie.call(r,t,i)}),l}function yU(r,e){return hb(r,e.tickDirection,e)}function fie(r,e){var t=H(r,2),n=t[0],i=t[1];return[[0,0],[n*e,i*e]]}function gie(r,e,t,n,i){var a=i.tickLength,s=H(fie(n,Tr(a,[r,e,t])),2),o=H(s[0],2),A=o[0],l=o[1],c=H(s[1],2),u=c[0],h=c[1];return{x1:A,x2:u,y1:l,y2:h}}function vie(r,e,t,n,i){var a=i.tickFormatter,s=i.classNamePrefix,o=yU(e.value,i),A="line";Te(a)&&(A=function(){return Tr(a,[e,t,n,o])});var l=r.append(A).attr("className",Ge.tickItem.name);return Kr(l,Ge.tickItem,dt.tickItem,s),l}function pie(r,e,t,n,i,a,s){var o=yU(r.value,a),A=gie(r,e,t,o,a),l=A.x1,c=A.x2,u=A.y1,h=A.y2,d=H(ma(uU(s,[r,e,t,o])),2),f=d[0],g=d[1];n.node().nodeName==="line"&&n.styles(le({x1:l,x2:c,y1:u,y2:h},f)),i.attr(g),n.styles(f)}function HO(r,e,t,n,i,a){var s=vie(Me(this),r,e,t,n);pie(r,e,t,s,this,n,i);var o=H(cf(r.value,n),2),A=o[0],l=o[1];return mi(this,{transform:"translate(".concat(A,", ").concat(l,")")},a)}function yie(r,e,t,n){var i=t.classNamePrefix,a=ub(e,t.tickFilter),s=ze(t,"tick");return r.selectAll(Ge.tick.class).data(a,function(o){return o.id||o.label}).join(function(o){var A=o.append("g").attr("className",Ge.tick.name).transition(function(l,c){return HO.call(this,l,c,a,t,s,!1)});return Kr(A,Ge.tick,dt.tick,i),A},function(o){return o.transition(function(A,l){return this.removeChildren(),HO.call(this,A,l,a,t,s,n.update)})},function(o){return o.transition(function(){var A=this,l=Af(this.childNodes[0],n.exit);return AA(l,function(){return A.remove()}),l})}).transitions()}function mie(r,e,t){var n=t.titlePosition,i=n===void 0?"lb":n,a=t.titleSpacing,s=of(i),o=r.node().getLocalBounds(),A=H(o.min,2),l=A[0],c=A[1],u=H(o.halfExtents,2),h=u[0],d=u[1],f=H(e.node().getLocalBounds().halfExtents,2),g=f[0],v=f[1],p=H([l+h,c+d],2),y=p[0],m=p[1],B=H(jn(a),4),C=B[0],S=B[1],F=B[2],T=B[3];if(["start","end"].includes(i)&&t.type==="linear"){var O=t.startPos,_=t.endPos,k=H(i==="start"?[O,_]:[_,O],2),L=k[0],U=k[1],G=JN([-U[0]+L[0],-U[1]+L[1]]),W=H(ca(G,C),2),V=W[0],K=W[1];return{x:L[0]+V,y:L[1]+K}}return s.includes("t")&&(m-=d+v+C),s.includes("r")&&(y+=h+g+S),s.includes("l")&&(y-=h+g+T),s.includes("b")&&(m+=d+v+F),{x:y,y:m}}function wie(r,e,t){var n=r.getGeometryBounds().halfExtents,i=n[1]*2;if(e==="vertical"){if(t==="left")return"rotate(-90) translate(0, ".concat(i/2,")");if(t==="right")return"rotate(-90) translate(0, -".concat(i/2,")")}return""}function GO(r,e,t,n,i){var a=ze(n,"title"),s=H(ma(a),2),o=s[0],A=s[1],l=A.transform,c=A.transformOrigin,u=Dt(A,["transform","transformOrigin"]);e.styles(u);var h=l||wie(r.node(),o.direction,o.position);r.styles(le(le({},o),{transformOrigin:c})),eU(r.node(),h);var d=mie(Me(t._offscreen||t.querySelector(Ge.mainGroup.class)),e,n),f=d.x,g=d.y,v=mi(e.node(),{transform:"translate(".concat(f,", ").concat(g,")")},i);return v}function Bie(r,e,t,n){var i=t.titleText,a=t.classNamePrefix;return r.selectAll(Ge.title.class).data([{title:i}].filter(function(s){return!!s.title}),function(s,o){return s.title}).join(function(s){var o=s.append(function(){return ya(i)}).attr("className",Ge.title.name).transition(function(){return GO(Me(this),r,e,t,n.enter)});return Kr(o,Ge.title,dt.title,a),o},function(s){return s.transition(function(){return GO(Me(this),r,e,t,n.update)})},function(s){return s.remove()}).transitions()}function KO(r,e,t,n){var i=r.showLine,a=r.showTick,s=r.showLabel,o=r.classNamePrefix,A=e.maybeAppendByClassName(Ge.lineGroup,"g");Kr(A,Ge.lineGroup,dt.lineGroup,o);var l=Fr(i,A,function(f){return Nre(f,r,n)})||[],c=e.maybeAppendByClassName(Ge.tickGroup,"g");Kr(c,Ge.tickGroup,dt.tickGroup,o);var u=Fr(a,c,function(f){return yie(f,t,r,n)})||[],h=e.maybeAppendByClassName(Ge.labelGroup,"g");Kr(h,Ge.labelGroup,dt.labelGroup,o);var d=Fr(s,h,function(f){return die(f,t,r,n,e.node())})||[];return _e(_e(_e([],H(l),!1),H(u),!1),H(d),!1).filter(function(f){return!!f})}var bie=(function(r){Xe(e,r);function e(t){return r.call(this,t,cb)||this}return e.prototype.render=function(t,n,i){var a=this,s=t.titleText,o=t.data,A=t.animate,l=t.showTitle,c=t.showGrid,u=t.dataThreshold,h=t.truncRange,d=t.classNamePrefix,f=n.className||"axis";d?n.attr("className","".concat(f," ").concat(d,"axis")):n.className||n.attr("className","axis");var g=nne(o,u).filter(function(F){var T=F.value;return!(h&&T>h[0]&&T<h[1])}),v=QO(i===void 0?A:i),p=Me(n).maybeAppendByClassName(Ge.gridGroup,"g");Kr(p,Ge.gridGroup,dt.gridGroup,d);var y=Fr(c,p,function(F){return Dre(F,g,t,v)})||[],m=Me(n).maybeAppendByClassName(Ge.mainGroup,"g");Kr(m,Ge.mainGroup,dt.mainGroup,d),s&&(!this.initialized&&v.enter||this.initialized&&v.update)&&KO(t,Me(this.offscreenGroup),g,QO(!1));var B=KO(t,Me(m.node()),g,v),C=Me(n).maybeAppendByClassName(Ge.titleGroup,"g");Kr(C,Ge.titleGroup,dt.titleGroup,d);var S=Fr(l,C,function(F){return Bie(F,a,t,v)})||[];return _e(_e(_e([],H(y),!1),H(B),!1),H(S),!1).flat().filter(function(F){return!!F})},e})(Zt);function lr(r,e,t){return t?"".concat(r," ").concat(t,"legend-").concat(e):r}function Eie(r,e,t){var n=1.4,i=n*t;return[["M",r-t,e-i],["L",r+t,e-i],["L",r+t,e+i],["L",r-t,e+i],["Z"]]}var mU=1.4,wU=.4;function xie(r,e,t){var n=t,i=n*mU,a=n/2,s=n/6,o=r+i*wU;return[["M",r,e],["L",o,e+a],["L",r+i,e+a],["L",r+i,e-a],["L",o,e-a],["Z"],["M",o,e+s],["L",r+i-2,e+s],["M",o,e-s],["L",r+i-2,e-s]]}function Cie(r,e,t){var n=t,i=n*mU,a=n/2,s=n/6,o=e+i*wU;return[["M",r,e],["L",r-a,o],["L",r-a,e+i],["L",r+a,e+i],["L",r+a,o],["Z"],["M",r-s,o],["L",r-s,e+i-2],["M",r+s,o],["L",r+s,e+i-2]]}gt.registerSymbol("hiddenHandle",Eie);gt.registerSymbol("verticalHandle",xie);gt.registerSymbol("horizontalHandle",Cie);function Q1(r,e,t){return r===void 0&&(r="horizontal"),r==="horizontal"?e:t}var cr={title:"title",item:"item",marker:"marker",label:"label",value:"value",focusIcon:"focus-icon",background:"background",handleMarker:"handle-marker",handleLabel:"handle-label",prevBtn:"prev-btn",nextBtn:"next-btn",pageInfo:"page-info"},ms=Si({markerGroup:"marker-group",marker:"marker",labelGroup:"label-group",label:"label"},"handle"),BU={showLabel:!0,formatter:function(r){return r.toString()},markerSize:25,markerStroke:"#c5c5c5",markerFill:"#fff",markerLineWidth:1,labelFontSize:12,labelFill:"#c5c5c5",labelText:"",orientation:"vertical",spacing:0};(function(r){Xe(e,r);function e(t){return r.call(this,t,BU)||this}return e.prototype.render=function(t,n){var i=Me(n).maybeAppendByClassName(ms.markerGroup,"g");this.renderMarker(i);var a=Me(n).maybeAppendByClassName(ms.labelGroup,"g");this.renderLabel(a)},e.prototype.renderMarker=function(t){var n=this,i=this.attributes,a=i.orientation,s=i.classNamePrefix,o=i.markerSymbol,A=o===void 0?Q1(a,"horizontalHandle","verticalHandle"):o;Fr(!!A,t,function(l){var c=ze(n.attributes,"marker"),u=le({symbol:A},c),h=lr(ms.marker.name,cr.handleMarker,s);if(n.marker=l.maybeAppendByClassName(ms.marker,function(){return new gt({style:u,className:h})}).update(u),s){var d=n.marker.node().querySelector(".marker");if(d){var f=d.getAttribute("class")||"",g=f.split(" ")[0],v=lr(g,cr.handleMarker,s);d.setAttribute("class",v)}}})},e.prototype.renderLabel=function(t){var n=this,i=this.attributes,a=i.showLabel,s=i.orientation,o=i.spacing,A=o===void 0?0:o,l=i.formatter,c=i.classNamePrefix;Fr(a,t,function(u){var h,d=ze(n.attributes,"label"),f=d.text,g=Dt(d,["text"]),v=((h=u.select(ms.marker.class))===null||h===void 0?void 0:h.node().getBBox())||{},p=v.width,y=p===void 0?0:p,m=v.height,B=m===void 0?0:m,C=H(Q1(s,[0,B+A,"center","top"],[y+A,0,"start","middle"]),4),S=C[0],F=C[1],T=C[2],O=C[3],_=lr(ms.label.name,cr.handleLabel,c);u.maybeAppendByClassName(ms.label,"text").attr("className",_).styles(le(le({},g),{x:S,y:F,text:l(f).toString(),textAlign:T,textBaseline:O}))})},e})(Zt);var bU={showTitle:!0,padding:0,orientation:"horizontal",backgroundFill:"transparent",titleText:"",titleSpacing:4,titlePosition:"top-left",titleFill:"#2C3542",titleFontWeight:"bold",titleFontFamily:"sans-serif",titleFontSize:12},Sie=wn({},bU,{});wn({},bU,Mo(BU,"handle"),{color:["#d0e3fa","#acc7f6","#8daaf2","#6d8eea","#4d73cd","#325bb1","#5a3e75","#8c3c79","#e23455","#e7655b"],indicatorBackgroundFill:"#262626",indicatorLabelFill:"white",indicatorLabelFontSize:12,indicatorVisibility:"hidden",labelAlign:"value",labelDirection:"positive",labelSpacing:5,showHandle:!0,showIndicator:!0,showLabel:!0,slidable:!0,titleText:"",type:"continuous"});var ws=Si({title:"title",html:"html",titleGroup:"title-group",items:"items",itemsGroup:"items-group",contentGroup:"content-group",ribbonGroup:"ribbon-group",ribbon:"ribbon",handlesGroup:"handles-group",handle:"handle",startHandle:"start-handle",endHandle:"end-handle",labelGroup:"label-group",label:"label",indicator:"indicator"},"legend"),sw=Si({text:"text"},"title");function Fie(r,e){var t=r.attributes,n=t.position,i=t.spacing,a=t.inset,s=t.text,o=r.getBBox(),A=e.getBBox(),l=of(n),c=H(jn(s?i:0),4),u=c[0],h=c[1],d=c[2],f=c[3],g=H(jn(a),4),v=g[0],p=g[1],y=g[2],m=g[3],B=H([f+h,u+d],2),C=B[0],S=B[1],F=H([m+p,v+y],2),T=F[0],O=F[1];if(l[0]==="l")return new dr(o.x,o.y,A.width+o.width+C+T,Math.max(A.height+O,o.height));if(l[0]==="t")return new dr(o.x,o.y,Math.max(A.width+T,o.width),A.height+o.height+S+O);var _=H([e.attributes.width||A.width,e.attributes.height||A.height],2),k=_[0],L=_[1];return new dr(A.x,A.y,k+o.width+C+T,L+o.height+S+O)}function Tie(r,e){var t=Object.entries(e).reduce(function(n,i){var a=H(i,2),s=a[0],o=a[1],A=r.node().attr(s);return A||(n[s]=o),n},{});r.styles(t)}function Mie(r){var e,t,n,i,a=r,s=a.width,o=a.height,A=a.position,l=H([+s/2,+o/2],2),c=l[0],u=l[1],h=H([+c,+u,"center","middle"],4),d=h[0],f=h[1],g=h[2],v=h[3],p=of(A);return p.includes("l")&&(e=H([0,"start"],2),d=e[0],g=e[1]),p.includes("r")&&(t=H([+s,"end"],2),d=t[0],g=t[1]),p.includes("t")&&(n=H([0,"top"],2),f=n[0],v=n[1]),p.includes("b")&&(i=H([+o,"bottom"],2),f=i[0],v=i[1]),{x:d,y:f,textAlign:g,textBaseline:v}}var Oie=(function(r){Xe(e,r);function e(t){return r.call(this,t,{text:"",width:0,height:0,fill:"#4a505a",fontWeight:"bold",fontSize:12,fontFamily:"sans-serif",inset:0,spacing:0,position:"top-left"})||this}return e.prototype.getAvailableSpace=function(){var t=this,n=this.attributes,i=n.width,a=n.height,s=n.position,o=n.spacing,A=n.inset,l=t.querySelector(sw.text.class);if(!l)return new dr(0,0,+i,+a);var c=l.getBBox(),u=c.width,h=c.height,d=H(jn(o),4),f=d[0],g=d[1],v=d[2],p=d[3],y=H([0,0,+i,+a],4),m=y[0],B=y[1],C=y[2],S=y[3],F=of(s);if(F.includes("i"))return new dr(m,B,C,S);F.forEach(function(V,K){var D,X,te,ie;V==="t"&&(D=H(K===0?[h+v,+a-h-v]:[0,+a],2),B=D[0],S=D[1]),V==="r"&&(X=H([+i-u-p],1),C=X[0]),V==="b"&&(te=H([+a-h-f],1),S=te[0]),V==="l"&&(ie=H(K===0?[u+g,+i-u-g]:[0,+i],2),m=ie[0],C=ie[1])});var T=H(jn(A),4),O=T[0],_=T[1],k=T[2],L=T[3],U=H([L+_,O+k],2),G=U[0],W=U[1];return new dr(m+L,B+O,C-G,S-W)},e.prototype.getBBox=function(){return this.title?this.title.getBBox():new dr(0,0,0,0)},e.prototype.render=function(t,n){var i=this;t.width,t.height,t.position,t.spacing;var a=t.classNamePrefix,s=Dt(t,["width","height","position","spacing","classNamePrefix"]),o=H(ma(s),1),A=o[0],l=Mie(t),c=l.x,u=l.y,h=l.textAlign,d=l.textBaseline;Fr(!!s.text,Me(n),function(f){var g=lr(sw.text.name,cr.title,a);i.title=f.maybeAppendByClassName(sw.text,"text").attr("className",g).styles(A).call(Tie,{x:c,y:u,textAlign:h,textBaseline:d}).node()})},e})(Zt),or=Si({prevBtnGroup:"prev-btn-group",prevBtn:"prev-btn",nextBtnGroup:"next-btn-group",nextBtn:"next-btn",pageInfoGroup:"page-info-group",pageInfo:"page-info",playWindow:"play-window",contentGroup:"content-group",controller:"controller",clipPath:"clip-path"},"navigator"),_ie=(function(r){Xe(e,r);function e(t){var n=r.call(this,t,{x:0,y:0,animate:{easing:"linear",duration:200,fill:"both"},buttonCursor:"pointer",buttonFill:"black",buttonD:kne(0,0,6),buttonSize:12,controllerPadding:5,controllerSpacing:5,formatter:function(i,a){return"".concat(i,"/").concat(a)},defaultPage:0,loop:!1,orientation:"horizontal",pageNumFill:"black",pageNumFontSize:12,pageNumTextAlign:"start",pageNumTextBaseline:"middle"})||this;return n.playState="idle",n.contentGroup=n.appendChild(new Tn({class:or.contentGroup.name})),n.playWindow=n.contentGroup.appendChild(new Tn({class:or.playWindow.name})),n.innerCurrPage=n.defaultPage,n}return Object.defineProperty(e.prototype,"defaultPage",{get:function(){var t=this.attributes.defaultPage;return Yt(t,0,Math.max(this.pageViews.length-1,0))},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"pageViews",{get:function(){return this.playWindow.children},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"controllerShape",{get:function(){return this.totalPages>1?{width:55,height:0}:{width:0,height:0}},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"pageShape",{get:function(){var t=this.pageViews,n=H(dne(t.map(function(u){var h=u.getBBox(),d=h.width,f=h.height;return[d,f]})).map(function(u){return Math.max.apply(Math,_e([],H(u),!1))}),2),i=n[0],a=n[1],s=this.attributes,o=s.pageWidth,A=o===void 0?i:o,l=s.pageHeight,c=l===void 0?a:l;return{pageWidth:A,pageHeight:c}},enumerable:!1,configurable:!0}),e.prototype.getContainer=function(){return this.playWindow},Object.defineProperty(e.prototype,"totalPages",{get:function(){return this.pageViews.length},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"currPage",{get:function(){return this.innerCurrPage},enumerable:!1,configurable:!0}),e.prototype.getBBox=function(){var t=r.prototype.getBBox.call(this),n=t.x,i=t.y,a=this.controllerShape,s=this.pageShape,o=s.pageWidth,A=s.pageHeight;return new dr(n,i,o+a.width,A)},e.prototype.goTo=function(t){var n=this,i=this.attributes.animate,a=this,s=a.currPage,o=a.playState,A=a.playWindow,l=a.pageViews;if(o!=="idle"||t<0||l.length<=0||t>=l.length)return null;l[s].setLocalPosition(0,0),this.prepareFollowingPage(t);var c=H(this.getFollowingPageDiff(t),2),u=c[0],h=c[1];this.playState="running";var d=sU(A,[{transform:"translate(0, 0)"},{transform:"translate(".concat(-u,", ").concat(-h,")")}],i);return AA(d,function(){n.innerCurrPage=t,n.playState="idle",n.setVisiblePages([t]),n.updatePageInfo()}),d},e.prototype.prev=function(){var t=this.attributes.loop,n=this.pageViews.length,i=this.currPage;if(!t&&i<=0)return null;var a=t?(i-1+n)%n:Yt(i-1,0,n);return this.goTo(a)},e.prototype.next=function(){var t=this.attributes.loop,n=this.pageViews.length,i=this.currPage;if(!t&&i>=n-1)return null;var a=t?(i+1)%n:Yt(i+1,0,n);return this.goTo(a)},e.prototype.renderClipPath=function(t){var n=this.pageShape,i=n.pageWidth,a=n.pageHeight;if(!i||!a){this.contentGroup.style.clipPath=void 0;return}this.clipPath=t.maybeAppendByClassName(or.clipPath,"rect").styles({width:i,height:a}),this.contentGroup.attr("clipPath",this.clipPath.node())},e.prototype.setVisiblePages=function(t){this.playWindow.children.forEach(function(n,i){t.includes(i)?Yl(n):yi(n)})},e.prototype.adjustControllerLayout=function(){var t=this,n=t.prevBtnGroup,i=t.nextBtnGroup,a=t.pageInfoGroup,s=this.attributes,o=s.orientation,A=s.controllerPadding,l=a.getBBox(),c=l.width;l.height;var u=H(o==="horizontal"?[-180,0]:[-90,90],2),h=u[0],d=u[1];n.setLocalEulerAngles(h),i.setLocalEulerAngles(d);var f=n.getBBox(),g=f.width,v=f.height,p=i.getBBox(),y=p.width,m=p.height,B=Math.max(g,c,y),C=o==="horizontal"?{offset:[[0,0],[g/2+A,0],[g+c+A*2,0]],textAlign:"start"}:{offset:[[B/2,-v-A],[B/2,0],[B/2,m+A]],textAlign:"center"},S=H(C.offset,3),F=H(S[0],2),T=F[0],O=F[1],_=H(S[1],2),k=_[0],L=_[1],U=H(S[2],2),G=U[0],W=U[1],V=C.textAlign,K=a.querySelector("text");K&&(K.style.textAlign=V),n.setLocalPosition(T,O),a.setLocalPosition(k,L),i.setLocalPosition(G,W)},e.prototype.updatePageInfo=function(){var t,n=this,i=n.currPage,a=n.pageViews,s=n.attributes.formatter;a.length<2||((t=this.pageInfoGroup.querySelector(or.pageInfo.class))===null||t===void 0||t.attr("text",s(i+1,a.length)),this.adjustControllerLayout())},e.prototype.getFollowingPageDiff=function(t){var n=this.currPage;if(n===t)return[0,0];var i=this.attributes.orientation,a=this.pageShape,s=a.pageWidth,o=a.pageHeight,A=t<n?-1:1;return i==="horizontal"?[A*s,0]:[0,A*o]},e.prototype.prepareFollowingPage=function(t){var n=this,i=n.currPage,a=n.pageViews;if(this.setVisiblePages([t,i]),t!==i){var s=H(this.getFollowingPageDiff(t),2),o=s[0],A=s[1];a[t].setLocalPosition(o,A)}},e.prototype.renderController=function(t){var n=this,i=this.attributes,a=i.controllerSpacing,s=i.classNamePrefix,o=s===void 0?"":s,A=this.pageShape,l=A.pageWidth,c=A.pageHeight,u=this.pageViews.length>=2,h=t.maybeAppendByClassName(or.controller,"g");if(sf(h.node(),u),!!u){var d=ze(this.attributes,"button"),f=ze(this.attributes,"pageNum"),g=H(ma(d),2),v=g[0],p=g[1],y=v.size,m=Dt(v,["size"]),B=!h.select(or.prevBtnGroup.class).node(),C=h.maybeAppendByClassName(or.prevBtnGroup,"g").styles(p);this.prevBtnGroup=C.node();var S=C.maybeAppendByClassName(or.prevBtn,"path");if(o){var F=lr(or.prevBtn.name,cr.prevBtn,o);S.node().setAttribute("class",F)}var T=h.maybeAppendByClassName(or.nextBtnGroup,"g").styles(p);this.nextBtnGroup=T.node();var O=T.maybeAppendByClassName(or.nextBtn,"path");if(o){var _=lr(or.nextBtn.name,cr.nextBtn,o);O.node().setAttribute("class",_)}[S,O].forEach(function(G){G.styles(le(le({},m),{transformOrigin:"center"})),ib(G.node(),y)});var k=h.maybeAppendByClassName(or.pageInfoGroup,"g");this.pageInfoGroup=k.node();var L=k.maybeAppendByClassName(or.pageInfo,"text");if(L.styles(f),o){var U=lr(or.pageInfo.name,cr.pageInfo,o);L.node().setAttribute("class",U)}this.updatePageInfo(),h.node().setLocalPosition(l+a,c/2),B&&(this.prevBtnGroup.addEventListener("click",function(){n.prev()}),this.nextBtnGroup.addEventListener("click",function(){n.next()}))}},e.prototype.render=function(t,n){var i=t.x,a=i===void 0?0:i,s=t.y,o=s===void 0?0:s;this.attr("transform","translate(".concat(a,", ").concat(o,")"));var A=Me(n);this.renderClipPath(A),this.renderController(A),this.setVisiblePages([this.defaultPage]),this.goTo(this.defaultPage)},e.prototype.bindEvents=function(){var t=this,n=Sl(function(){return t.render(t.attributes,t)},50);this.playWindow.addEventListener(it.INSERTED,n),this.playWindow.addEventListener(it.REMOVED,n)},e})(Zt),et,Iie="component-poptip",Ye={CONTAINER:"component-poptip",ARROW:"component-poptip-arrow",TEXT:"component-poptip-text"},zO=(et={},et[".".concat(Ye.CONTAINER)]={visibility:"visible",position:"absolute","background-color":"rgba(0, 0, 0)","box-shadow":"0px 0px 10px #aeaeae","border-radius":"3px",color:"#fff",opacity:.8,"font-size":"12px",padding:"4px 6px",display:"flex","justify-content":"center","align-items":"center","z-index":8,transition:"visibility 50ms"},et[".".concat(Ye.TEXT)]={"text-align":"center"},et[".".concat(Ye.CONTAINER,"[data-position='top']")]={transform:"translate(-50%, -100%)"},et[".".concat(Ye.CONTAINER,"[data-position='left']")]={transform:"translate(-100%, -50%)"},et[".".concat(Ye.CONTAINER,"[data-position='right']")]={transform:"translate(0, -50%)"},et[".".concat(Ye.CONTAINER,"[data-position='bottom']")]={transform:"translate(-50%, 0)"},et[".".concat(Ye.CONTAINER,"[data-position='top-left']")]={transform:"translate(0,-100%)"},et[".".concat(Ye.CONTAINER,"[data-position='top-right']")]={transform:"translate(-100%,-100%)"},et[".".concat(Ye.CONTAINER,"[data-position='left-top']")]={transform:"translate(-100%, 0)"},et[".".concat(Ye.CONTAINER,"[data-position='left-bottom']")]={transform:"translate(-100%, -100%)"},et[".".concat(Ye.CONTAINER,"[data-position='right-top']")]={transform:"translate(0, 0)"},et[".".concat(Ye.CONTAINER,"[data-position='right-bottom']")]={transform:"translate(0, -100%)"},et[".".concat(Ye.CONTAINER,"[data-position='bottom-left']")]={transform:"translate(0, 0)"},et[".".concat(Ye.CONTAINER,"[data-position='bottom-right']")]={transform:"translate(-100%, 0)"},et[".".concat(Ye.ARROW)]={width:"4px",height:"4px",transform:"rotate(45deg)","background-color":"rgba(0, 0, 0)",position:"absolute","z-index":-1},et[".".concat(Ye.CONTAINER,"[data-position='top']")]={transform:"translate(-50%, calc(-100% - 5px))"},et["[data-position='top'] .".concat(Ye.ARROW)]={bottom:"-2px"},et[".".concat(Ye.CONTAINER,"[data-position='left']")]={transform:"translate(calc(-100% - 5px), -50%)"},et["[data-position='left'] .".concat(Ye.ARROW)]={right:"-2px"},et[".".concat(Ye.CONTAINER,"[data-position='right']")]={transform:"translate(5px, -50%)"},et["[data-position='right'] .".concat(Ye.ARROW)]={left:"-2px"},et[".".concat(Ye.CONTAINER,"[data-position='bottom']")]={transform:"translate(-50%, 5px)"},et["[data-position='bottom'] .".concat(Ye.ARROW)]={top:"-2px"},et[".".concat(Ye.CONTAINER,"[data-position='top-left']")]={transform:"translate(0, calc(-100% - 5px))"},et["[data-position='top-left'] .".concat(Ye.ARROW)]={left:"10px",bottom:"-2px"},et[".".concat(Ye.CONTAINER,"[data-position='top-right']")]={transform:"translate(-100%, calc(-100% - 5px))"},et["[data-position='top-right'] .".concat(Ye.ARROW)]={right:"10px",bottom:"-2px"},et[".".concat(Ye.CONTAINER,"[data-position='left-top']")]={transform:"translate(calc(-100% - 5px), 0)"},et["[data-position='left-top'] .".concat(Ye.ARROW)]={right:"-2px",top:"8px"},et[".".concat(Ye.CONTAINER,"[data-position='left-bottom']")]={transform:"translate(calc(-100% - 5px), -100%)"},et["[data-position='left-bottom'] .".concat(Ye.ARROW)]={right:"-2px",bottom:"8px"},et[".".concat(Ye.CONTAINER,"[data-position='right-top']")]={transform:"translate(5px, 0)"},et["[data-position='right-top'] .".concat(Ye.ARROW)]={left:"-2px",top:"8px"},et[".".concat(Ye.CONTAINER,"[data-position='right-bottom']")]={transform:"translate(5px, -100%)"},et["[data-position='right-bottom'] .".concat(Ye.ARROW)]={left:"-2px",bottom:"8px"},et[".".concat(Ye.CONTAINER,"[data-position='bottom-left']")]={transform:"translate(0, 5px)"},et["[data-position='bottom-left'] .".concat(Ye.ARROW)]={top:"-2px",left:"8px"},et[".".concat(Ye.CONTAINER,"[data-position='bottom-right']")]={transform:"translate(-100%, 5px)"},et["[data-position='bottom-right'] .".concat(Ye.ARROW)]={top:"-2px",right:"8px"},et),kie=void 0;function Lie(r,e,t,n,i,a){if(i===void 0&&(i=!1),a===void 0&&(a=!1),a)return[r,e];var s=t.getBoundingClientRect(),o=s.x,A=s.y,l=s.width,c=s.height;switch(n){case"top":return i?[o+l/2,A]:[r,A];case"left":return i?[o,A+c/2]:[o,e];case"bottom":return i?[o+l/2,A+c]:[r,A+c];case"right":return i?[o+l,A+c/2]:[o+l,e];case"top-right":case"right-top":return[o+l,A];case"left-bottom":case"bottom-left":return[o,A+c];case"right-bottom":case"bottom-right":return[o+l,A+c];default:return[o,A]}}var Qie=function(r){var e;return function(){for(var t=[],n=0;n<arguments.length;n++)t[n]=arguments[n];return e||(e=r.apply(kie,t)),e}};function Nie(r){var e=r&&document.getElementById(r);return e||(e=document.createElement("div"),e.setAttribute("id",r),document.body.appendChild(e)),e}function Uie(r){var e=Qie(Nie)(r);return e}var Pie=(function(r){Xe(e,r);function e(t){var n=r.call(this,zn({style:{id:Iie}},e.defaultOptions,t))||this;return n.visibility="visible",n.map=new Map,n.domStyles="",n.initShape(),n.render(n.attributes,n),n}return Object.defineProperty(e.prototype,"visible",{get:function(){return this.visibility==="visible"},enumerable:!1,configurable:!0}),e.prototype.render=function(t,n){this.visibility=this.style.visibility,this.updatePoptipElement()},e.prototype.update=function(t){this.attr(zn({},this.style,t)),this.render(this.attributes,this)},e.prototype.bind=function(t,n){var i=this;if(t){var a=this.style.text,s=function(A){var l=t,c=i.style,u=a;if(n){var h=typeof n=="function"?n.call(null,A):n,d=h.html,f=h.target,g=Dt(h,["html","target"]);c=ER({},i.style,g),(f||f===!1)&&(l=f),typeof d=="string"&&(u=d)}var v=c.position,p=c.arrowPointAtCenter,y=c.follow,m=c.offset;if(l){var B=A,C=B.clientX,S=B.clientY,F=H(Lie(C,S,l,v,p,y),2),T=F[0],O=F[1];i.showTip(T,O,{text:u,position:v,offset:m})}else i.hideTip()},o=function(){i.hideTip()};t.addEventListener("mousemove",s),t.addEventListener("mouseleave",o),this.map.set(t,[s,o])}},e.prototype.unbind=function(t){if(this.map.has(t)){var n=H(this.map.get(t)||[],2),i=n[0],a=n[1];i&&t.removeEventListener("mousemove",i),a&&t.removeEventListener("mouseleave",a),this.map.delete(t)}},e.prototype.clear=function(){this.container.innerHTML=""},e.prototype.destroy=function(){var t=this,n;_e([],H(this.map.keys()),!1).forEach(function(i){return t.unbind(i)}),(n=this.container)===null||n===void 0||n.remove(),r.prototype.destroy.call(this)},e.prototype.showTip=function(t,n,i){var a=Rn(i,"text");if(!(a&&typeof a!="string")&&(this.applyStyles(),t&&n&&i)){var s=i.offset,o=i.position;if(o&&this.container.setAttribute("data-position",o),this.setOffsetPosition(t,n,s),typeof a=="string"){var A=this.container.querySelector(".".concat(Ye.TEXT));A&&(A.innerHTML=a)}this.visibility="visible",this.container.style.visibility="visible"}},e.prototype.hideTip=function(){this.visibility="hidden",this.container.style.visibility="hidden"},e.prototype.getContainer=function(){return this.container},e.prototype.getClassName=function(){var t=this.style.containerClassName;return"".concat(Ye.CONTAINER).concat(t?" ".concat(t):"")},e.prototype.initShape=function(){var t=this,n=this.style.id;this.container=Uie(n),this.container.className=this.getClassName(),this.container.addEventListener("mousemove",function(){return t.showTip()}),this.container.addEventListener("mouseleave",function(){return t.hideTip()})},e.prototype.updatePoptipElement=function(){var t=this.container;this.clear();var n=this.style,i=n.id,a=n.template,s=n.text;this.container.setAttribute("id",i),this.container.className=this.getClassName();var o='<span class="'.concat(Ye.ARROW,'"></span>');t.innerHTML=o,At(a)?t.innerHTML+=a:a&&bR(a)&&t.appendChild(a),s&&(t.getElementsByClassName(Ye.TEXT)[0].textContent=s),this.applyStyles(),this.container.style.visibility=this.visibility},e.prototype.applyStyles=function(){var t=wn({},zO,this.style.domStyles),n=Object.entries(t).reduce(function(a,s){var o=H(s,2),A=o[0],l=o[1],c=Object.entries(l).reduce(function(u,h){var d=H(h,2),f=d[0],g=d[1];return"".concat(u).concat(f,": ").concat(g,";")},"");return"".concat(a).concat(A,"{").concat(c,"}")},"");if(this.domStyles!==n){this.domStyles=n;var i=this.container.querySelector("style");i&&this.container.removeChild(i),i=document.createElement("style"),i.innerHTML=n,this.container.appendChild(i)}},e.prototype.setOffsetPosition=function(t,n,i){i===void 0&&(i=this.style.offset);var a=H(i,2),s=a[0],o=s===void 0?0:s,A=a[1],l=A===void 0?0:A;this.container.style.left="".concat(t+o,"px"),this.container.style.top="".concat(n+l,"px")},e.tag="poptip",e.defaultOptions={style:{x:0,y:0,width:0,height:0,target:null,visibility:"hidden",text:"",position:"top",follow:!1,offset:[0,0],domStyles:zO,template:'<div class="'.concat(Ye.TEXT,'"></div>')}},e})(Zt),dn=Si({layout:"flex",markerGroup:"marker-group",marker:"marker",labelGroup:"label-group",label:"label",valueGroup:"value-group",focusGroup:"focus-group",focus:"focus",value:"value",backgroundGroup:"background-group",background:"background"},"legend-category-item"),Rie={offset:[0,20],domStyles:{".component-poptip":{opacity:"1",padding:"8px 12px",background:"#fff",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.15)"},".component-poptip-arrow":{display:"none"},".component-poptip-text":{color:"#000",lineHeight:"20px"}}};function Die(r){var e=r.querySelector(dn.marker.class);return e?e.style:{}}var Hie=(function(r){Xe(e,r);function e(t,n){var i=r.call(this,t,{span:[1,1],marker:function(){return new zi({style:{r:6}})},markerSize:10,labelFill:"#646464",valueFill:"#646464",labelFontSize:12,valueFontSize:12,labelTextBaseline:"middle",valueTextBaseline:"middle"})||this;return i.keyFields={},i.keyFields=n||{},i}return Object.defineProperty(e.prototype,"showValue",{get:function(){var t=this.attributes.valueText;return t?typeof t=="string"||typeof t=="number"?t!=="":typeof t=="function"?!0:t.attr("text")!=="":!1},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"actualSpace",{get:function(){var t=this.labelGroup,n=this.valueGroup,i=this.attributes,a=i.markerSize,s=i.focus,o=i.focusMarkerSize,A=t.node().getBBox(),l=A.width,c=A.height,u=n.node().getBBox(),h=u.width,d=u.height,f=s?o??12:0;return{markerWidth:a,labelWidth:l,valueWidth:h,focusWidth:f,height:Math.max(a,c,d)}},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"span",{get:function(){var t=this.attributes.span;if(!t)return[1,1];var n=H(jn(t),2),i=n[0],a=n[1],s=this.showValue?a:0,o=i+s;return[i/o,s/o]},enumerable:!1,configurable:!0}),e.prototype.setAttribute=function(t,n){r.prototype.setAttribute.call(this,t,n)},Object.defineProperty(e.prototype,"shape",{get:function(){var t,n=this.attributes,i=n.markerSize,a=n.width,s=this.actualSpace,o=s.markerWidth,A=s.focusWidth,l=s.height,c=this.actualSpace,u=c.labelWidth,h=c.valueWidth,d=H(this.spacing,3),f=d[0],g=d[1],v=d[2];if(a){var p=a-i-f-g-A-v,y=H(this.span,2),m=y[0],B=y[1];t=H([m*p,B*p],2),u=t[0],h=t[1]}var C=o+u+h+f+g+A+v;return{width:C,height:l,markerWidth:o,labelWidth:u,valueWidth:h,focusWidth:A}},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"spacing",{get:function(){var t=this.attributes,n=t.spacing,i=t.focus;if(!n)return[0,0,0];var a=H(jn(n),3),s=a[0],o=a[1],A=a[2];return[s,this.showValue?o:0,i?A:0]},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"layout",{get:function(){var t=this.shape,n=t.markerWidth,i=t.labelWidth,a=t.valueWidth,s=t.focusWidth,o=t.width,A=t.height,l=H(this.spacing,3),c=l[0],u=l[1],h=l[2];return{height:A,width:o,markerWidth:n,labelWidth:i,valueWidth:a,focusWidth:s,position:[n/2,n+c,n+i+c+u,n+i+a+c+u+h+s/2]}},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"scaleSize",{get:function(){var t=Die(this.markerGroup.node()),n=this.attributes,i=n.markerSize,a=n.markerStrokeWidth,s=a===void 0?t.strokeWidth:a,o=n.markerLineWidth,A=o===void 0?t.lineWidth:o,l=n.markerStroke,c=l===void 0?t.stroke:l,u=+(s||A||(c?1:0))*Math.sqrt(2),h=this.markerGroup.node().getBBox(),d=h.width,f=h.height;return(1-u/Math.max(d,f))*i},enumerable:!1,configurable:!0}),e.prototype.renderMarker=function(t){var n=this,i=this.attributes,a=i.marker,s=i.classNamePrefix,o=ze(this.attributes,"marker");this.markerGroup=t.maybeAppendByClassName(dn.markerGroup,"g").style("zIndex",0),Fr(!!a,this.markerGroup,function(){var A,l=n.markerGroup.node(),c=(A=l.childNodes)===null||A===void 0?void 0:A[0],u=lr(dn.marker.name,cr.marker,s),h=typeof a=="string"?new gt({style:{symbol:a},className:u}):a();if(c)if(h.nodeName===c.nodeName)c instanceof gt?c.update(le(le({},o),{symbol:a})):(Ane(c,h),Me(c).styles(o));else{if(c.remove(),!(h instanceof gt)){var f=lr(dn.marker.name,cr.marker,s);h.className=f}Me(h).styles(o),l.appendChild(h)}else{if(!(h instanceof gt)){var d=lr(dn.marker.name,cr.marker,s);h.className=d,Me(h).styles(o)}l.appendChild(h)}n.markerGroup.node().scale(1/n.markerGroup.node().getScale()[0]);var g=ib(n.markerGroup.node(),n.scaleSize);n.markerGroup.node().style._transform="scale(".concat(g,")")})},e.prototype.renderLabel=function(t){var n=ze(this.attributes,"label"),i=n.text,a=Dt(n,["text"]),s=this.attributes.classNamePrefix;this.labelGroup=t.maybeAppendByClassName(dn.labelGroup,"g").style("zIndex",0);var o=lr(dn.label.name,cr.label,s),A=this.labelGroup.maybeAppendByClassName(dn.label,function(){return ya(i)});A.node().setAttribute("class",o),A.styles(a)},e.prototype.renderValue=function(t){var n=this,i=ze(this.attributes,"value"),a=i.text,s=Dt(i,["text"]),o=this.attributes.classNamePrefix;this.valueGroup=t.maybeAppendByClassName(dn.valueGroup,"g").style("zIndex",0),Fr(this.showValue,this.valueGroup,function(){var A=lr(dn.value.name,cr.value,o),l=n.valueGroup.maybeAppendByClassName(dn.value,function(){return ya(a)});l.node().setAttribute("class",A),l.styles(s)})},e.prototype.createPoptip=function(){var t=this.attributes.poptip,n=t||{};n.render;var i=Dt(n,["render"]),a=new Pie({style:wn(Rie,i)});return this.poptipGroup=a,a},e.prototype.bindPoptip=function(t){var n=this,i=this.attributes.poptip;if(i){var a=this.poptipGroup||this.createPoptip();a.bind(t,function(){var s=n.attributes,o=s.labelText,A=s.valueText,l=s.markerFill,c=typeof o=="string"?o:o==null?void 0:o.attr("text"),u=typeof A=="string"?A:A==null?void 0:A.attr("text");if(typeof i.render=="function")return{html:i.render(le(le({},n.keyFields),{label:c,value:u,color:l}))};var h="";return(typeof c=="string"||typeof c=="number")&&(h+='<div class="component-poptip-label">'.concat(c,"</div>")),(typeof u=="string"||typeof u=="number")&&(h+='<div class="component-poptip-value">'.concat(u,"</div>")),{html:h}})}},e.prototype.renderFocus=function(t){var n=this,i=this.attributes,a=i.focus,s=i.focusMarkerSize,o=i.classNamePrefix,A={x:0,y:0,size:s,opacity:.6,symbol:"focus",stroke:"#aaaaaa",lineWidth:1};He(a)||(this.focusGroup=t.maybeAppendByClassName(dn.focusGroup,"g").style("zIndex",0),Fr(a,this.focusGroup,function(){var l=lr(dn.focus.name,cr.focusIcon,o),c=new gt({style:le(le({},A),{symbol:"focus"}),className:l}),u=new zi({style:{r:A.size/2,fill:"transparent"}}),h=n.focusGroup.node();h.appendChild(u),h.appendChild(c),c.update({opacity:0}),t.node().addEventListener("pointerenter",function(){c.update({opacity:1})}),t.node().addEventListener("pointerleave",function(){c.update({opacity:0})})}))},e.prototype.renderPoptip=function(t){var n=this,i=this.attributes.poptip;if(i){var a=t.maybeAppendByClassName(dn.value,"g").node(),s=t.maybeAppendByClassName(dn.label,"g").node();[a,s].forEach(function(o){o&&n.bindPoptip(o)})}},e.prototype.renderBackground=function(t){var n=this.shape,i=n.width,a=n.height,s=ze(this.attributes,"background");this.background=t.maybeAppendByClassName(dn.backgroundGroup,"g").style("zIndex",-1);var o=this.background.maybeAppendByClassName(dn.background,"rect");o.styles(le({width:i,height:a},s));var A=this.attributes.classNamePrefix,l=A===void 0?"":A;if(l){var c=lr(dn.background.name,cr.background,l);o.node().setAttribute("class",c)}},e.prototype.adjustLayout=function(){var t=this.layout,n=t.labelWidth,i=t.valueWidth,a=t.height,s=H(t.position,4),o=s[0],A=s[1],l=s[2],c=s[3],u=a/2;this.markerGroup.styles({transform:"translate(".concat(o,", ").concat(u,")").concat(this.markerGroup.node().style._transform)}),this.labelGroup.styles({transform:"translate(".concat(A,", ").concat(u,")")}),this.focusGroup&&this.focusGroup.styles({transform:"translate(".concat(c,", ").concat(u,")")}),T1(this.labelGroup.select(dn.label.class).node(),Math.ceil(n)),this.showValue&&(this.valueGroup.styles({transform:"translate(".concat(l,", ").concat(u,")")}),T1(this.valueGroup.select(dn.value.class).node(),Math.ceil(i)))},e.prototype.render=function(t,n){var i=Me(n),a=t.x,s=a===void 0?0:a,o=t.y,A=o===void 0?0:o;i.styles({transform:"translate(".concat(s,", ").concat(A,")")}),this.renderMarker(i),this.renderLabel(i),this.renderValue(i),this.renderBackground(i),this.renderPoptip(i),this.renderFocus(i),this.adjustLayout()},e})(Zt),Bs=Si({page:"item-page",navigator:"navigator",item:"item"},"items"),VO=function(r,e,t){return t===void 0&&(t=!0),r?e(r):t},Gie=(function(r){Xe(e,r);function e(t){var n=r.call(this,t,{data:[],gridRow:1/0,gridCol:void 0,padding:0,width:1e3,height:100,rowPadding:0,colPadding:0,layout:"flex",orientation:"horizontal",click:_f,mouseenter:_f,mouseleave:_f})||this;return n.navigatorShape=[0,0],n}return Object.defineProperty(e.prototype,"pageViews",{get:function(){return this.navigator.getContainer()},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"grid",{get:function(){var t=this.attributes,n=t.gridRow,i=t.gridCol,a=t.data;if(!n&&!i)throw new Error("gridRow and gridCol can not be set null at the same time");return n&&i?[n,i]:n?[n,a.length]:[a.length,i]},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"renderData",{get:function(){var t=this.attributes,n=t.data,i=t.layout,a=t.poptip,s=t.focus,o=t.focusMarkerSize,A=t.classNamePrefix,l=ze(this.attributes,"item"),c=n.map(function(u,h){var d=u.id,f=d===void 0?h:d,g=u.label,v=u.value;return{id:"".concat(f),index:h,style:le({layout:i,labelText:g,valueText:v,poptip:a,focus:s,focusMarkerSize:o,classNamePrefix:A},Object.fromEntries(Object.entries(l).map(function(p){var y=H(p,2),m=y[0],B=y[1];return[m,Tr(B,[u,h,n])]})))}});return c},enumerable:!1,configurable:!0}),e.prototype.getGridLayout=function(){var t=this,n=this.attributes,i=n.orientation,a=n.width,s=n.rowPadding,o=n.colPadding,A=H(this.navigatorShape,1),l=A[0],c=H(this.grid,2),u=c[0],h=c[1],d=h*u,f=0;return this.pageViews.children.map(function(g,v){var p,y,m=Math.floor(v/d),B=v%d,C=t.ifHorizontal(h,u),S=[Math.floor(B/C),B%C];i==="vertical"&&S.reverse();var F=H(S,2),T=F[0],O=F[1],_=(a-l-(h-1)*o)/h,k=g.getBBox().height,L=H([0,0],2),U=L[0],G=L[1];return i==="horizontal"?(p=H([f,T*(k+s)],2),U=p[0],G=p[1],f=O===h-1?0:f+_+o):(y=H([O*(_+o),f],2),U=y[0],G=y[1],f=T===u-1?0:f+k+s),{page:m,index:v,row:T,col:O,pageIndex:B,width:_,height:k,x:U,y:G}})},e.prototype.getFlexLayout=function(){var t=this.attributes,n=t.width,i=t.height,a=t.rowPadding,s=t.colPadding,o=H(this.navigatorShape,1),A=o[0],l=H(this.grid,2),c=l[0],u=l[1],h=H([n-A,i],2),d=h[0],f=h[1],g=H([0,0,0,0,0,0,0,0],8),v=g[0],p=g[1],y=g[2],m=g[3],B=g[4],C=g[5],S=g[6],F=g[7];return this.pageViews.children.map(function(T,O){var _,k,L,U,G=T.getBBox(),W=G.width,V=G.height,K=S===0?0:s,D=S+K+W;if(D<=d&&VO(B,function(te){return te<u}))return _=H([S+K,F,D],3),v=_[0],p=_[1],S=_[2],{width:W,height:V,x:v,y:p,page:y,index:O,pageIndex:m++,row:C,col:B++};k=H([C+1,0,0,F+V+a],4),C=k[0],B=k[1],S=k[2],F=k[3];var X=F+V;return X<=f&&VO(C,function(te){return te<c})?(L=H([S,F,W],3),v=L[0],p=L[1],S=L[2],{width:W,height:V,x:v,y:p,page:y,index:O,pageIndex:m++,row:C,col:B++}):(U=H([0,0,W,0,y+1,0,0,0],8),v=U[0],p=U[1],S=U[2],F=U[3],y=U[4],m=U[5],C=U[6],B=U[7],{width:W,height:V,x:v,y:p,page:y,index:O,pageIndex:m++,row:C,col:B++})})},Object.defineProperty(e.prototype,"itemsLayout",{get:function(){this.navigatorShape=[0,0];var t=this.attributes.layout==="grid"?this.getGridLayout:this.getFlexLayout,n=t.call(this);return n.slice(-1)[0].page>0?(this.navigatorShape=[55,0],t.call(this)):n},enumerable:!1,configurable:!0}),e.prototype.ifHorizontal=function(t,n){var i=this.attributes.orientation;return Q1(i,t,n)},e.prototype.flattenPage=function(t){t.querySelectorAll(Bs.item.class).forEach(function(n){t.appendChild(n)}),t.querySelectorAll(Bs.page.class).forEach(function(n){var i=t.removeChild(n);i.destroy()})},e.prototype.renderItems=function(t){var n=this.attributes,i=n.click,a=n.mouseenter,s=n.mouseleave,o=n.classNamePrefix;this.flattenPage(t);var A=this.dispatchCustomEvent.bind(this),l=lr(Bs.item.name,cr.item,o);Me(t).selectAll(Bs.item.class).data(this.renderData,function(c){return c.id}).join(function(c){return c.append(function(u){var h=u.style,d=Dt(u,["style"]);return new Hie({style:h},d)}).attr("className",l).on("click",function(){i==null||i(this),A("itemClick",{item:this})}).on("pointerenter",function(){a==null||a(this),A("itemMouseenter",{item:this})}).on("pointerleave",function(){s==null||s(this),A("itemMouseleave",{item:this})})},function(c){return c.each(function(u){var h=u.style;this.update(h)})},function(c){return c.remove()})},e.prototype.relayoutNavigator=function(){var t,n=this.attributes,i=n.layout,a=n.width,s=((t=this.pageViews.children[0])===null||t===void 0?void 0:t.getBBox().height)||0,o=H(this.navigatorShape,2),A=o[0],l=o[1];this.navigator.update(i==="grid"?{pageWidth:a-A,pageHeight:s-l}:{})},e.prototype.adjustLayout=function(){var t=this,n=Object.entries(jte(this.itemsLayout,"page")).map(function(a){var s=H(a,2),o=s[0],A=s[1];return{page:o,layouts:A}}),i=_e([],H(this.navigator.getContainer().children),!1);n.forEach(function(a){var s=a.layouts,o=t.pageViews.appendChild(new Tn({className:Bs.page.name}));s.forEach(function(A){var l=A.x,c=A.y,u=A.index,h=A.width,d=A.height,f=i[u];o.appendChild(f),ol(f,"__layout__",A),f.update({x:l,y:c,width:h,height:d})})}),this.relayoutNavigator()},e.prototype.renderNavigator=function(t){var n=this.attributes,i=n.orientation,a=n.classNamePrefix,s=ze(this.attributes,"nav"),o=wn({orientation:i,classNamePrefix:a},s),A=this;return t.selectAll(Bs.navigator.class).data(["nav"]).join(function(l){return l.append(function(){return new _ie({style:o})}).attr("className",Bs.navigator.name).each(function(){A.navigator=this})},function(l){return l.each(function(){this.update(o)})},function(l){return l.remove()}),this.navigator},e.prototype.getBBox=function(){return this.navigator.getBBox()},e.prototype.render=function(t,n){var i=this.attributes.data;if(!(!i||i.length===0)){var a=this.renderNavigator(Me(n));this.renderItems(a.getContainer()),this.adjustLayout()}},e.prototype.dispatchCustomEvent=function(t,n){var i=new vn(t,{detail:n});this.dispatchEvent(i)},e})(Zt),Kie=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return e.prototype.update=function(t){this.attr(t)},e})(Ys),zie=(function(r){Xe(e,r);function e(t){return r.call(this,t,Sie)||this}return e.prototype.renderTitle=function(t,n,i){var a=this.attributes,s=a.showTitle,o=a.titleText,A=a.classNamePrefix,l=ze(this.attributes,"title"),c=H(ma(l),2),u=c[0],h=c[1];this.titleGroup=t.maybeAppendByClassName(ws.titleGroup,"g").styles(h);var d=le(le({width:n,height:i},u),{text:s?o:"",classNamePrefix:A});this.title=this.titleGroup.maybeAppendByClassName(ws.title,function(){return new Oie({style:d})}).update(d)},e.prototype.renderCustom=function(t){var n=this.attributes.data,i={innerHTML:this.attributes.render(n),pointerEvents:"auto"};t.maybeAppendByClassName(ws.html,function(){return new Kie({className:ws.html.name,style:i})}).update(i)},e.prototype.renderItems=function(t,n){var i=n.x,a=n.y,s=n.width,o=n.height,A=ze(this.attributes,"title",!0),l=H(ma(A),2),c=l[0],u=l[1],h=le(le({},c),{width:s,height:o,x:0,y:0});this.itemsGroup=t.maybeAppendByClassName(ws.itemsGroup,"g").styles(le(le({},u),{transform:"translate(".concat(i,", ").concat(a,")")}));var d=this;this.itemsGroup.selectAll(ws.items.class).data(["items"]).join(function(f){return f.append(function(){return new Gie({style:h})}).attr("className",ws.items.name).each(function(){d.items=Me(this)})},function(f){return f.update(h)},function(f){return f.remove()})},e.prototype.adjustLayout=function(){var t=this.attributes.showTitle;if(t){var n=this.title.node().getAvailableSpace(),i=n.x,a=n.y;this.itemsGroup.node().style.transform="translate(".concat(i,", ").concat(a,")")}},Object.defineProperty(e.prototype,"availableSpace",{get:function(){var t=this.attributes,n=t.showTitle,i=t.width,a=t.height;return n?this.title.node().getAvailableSpace():new dr(0,0,i,a)},enumerable:!1,configurable:!0}),e.prototype.getBBox=function(){var t,n,i=(t=this.title)===null||t===void 0?void 0:t.node(),a=(n=this.items)===null||n===void 0?void 0:n.node();return!i||!a?r.prototype.getBBox.call(this):Fie(i,a)},e.prototype.render=function(t,n){var i=this.attributes,a=i.width,s=i.height,o=i.x,A=o===void 0?0:o,l=i.y,c=l===void 0?0:l,u=i.classNamePrefix,h=i.render,d=Me(n),f=n.className||"legend-category";u?n.attr("className","".concat(f," ").concat(u,"legend")):n.className||n.attr("className","legend-category"),n.style.transform="translate(".concat(A,", ").concat(c,")"),h?this.renderCustom(d):(this.renderTitle(d,a,s),this.renderItems(d,this.availableSpace),this.adjustLayout())},e})(Zt),Vie={backgroundFill:"#262626",backgroundLineCap:"round",backgroundLineWidth:1,backgroundStroke:"#333",backgroundZIndex:-1,formatter:function(r){return r.toString()},labelFill:"#fff",labelFontSize:12,labelTextBaseline:"middle",padding:[2,4],position:"right",radius:0,zIndex:999},ow=Si({background:"background",labelGroup:"label-group",label:"label"},"indicator"),jie=(function(r){Xe(e,r);function e(t){var n=r.call(this,t,Vie)||this;return n.point=[0,0],n.group=n.appendChild(new Tn({})),n.isMutationObserved=!0,n}return e.prototype.renderBackground=function(){if(this.label){var t=this.attributes,n=t.position,i=t.padding,a=H(jn(i),4),s=a[0],o=a[1],A=a[2],l=a[3],c=this.label.node().getLocalBounds(),u=c.min,h=c.max,d=new dr(u[0]-l,u[1]-s,h[0]+o-u[0]+l,h[1]+A-u[1]+s),f=this.getPath(n,d),g=ze(this.attributes,"background");this.background=Me(this.group).maybeAppendByClassName(ow.background,"path").styles(le(le({},g),{d:f})),this.group.appendChild(this.label.node())}},e.prototype.renderLabel=function(){var t=this.attributes,n=t.formatter,i=t.labelText,a=ze(this.attributes,"label"),s=H(ma(a),2),o=s[0],A=s[1];o.text;var l=Dt(o,["text"]);if(this.label=Me(this.group).maybeAppendByClassName(ow.labelGroup,"g").styles(A),!!i){var c=this.label.maybeAppendByClassName(ow.label,function(){return ya(n(i))}).style("text",n(i).toString());c.selectAll("text").styles(l)}},e.prototype.adjustLayout=function(){var t=H(this.point,2),n=t[0],i=t[1],a=this.attributes,s=a.x,o=a.y;this.group.attr("transform","translate(".concat(s-n,", ").concat(o-i,")"))},e.prototype.getPath=function(t,n){var i=this.attributes.radius,a=n.x,s=n.y,o=n.width,A=n.height,l=[["M",a+i,s],["L",a+o-i,s],["A",i,i,0,0,1,a+o,s+i],["L",a+o,s+A-i],["A",i,i,0,0,1,a+o-i,s+A],["L",a+i,s+A],["A",i,i,0,0,1,a,s+A-i],["L",a,s+i],["A",i,i,0,0,1,a+i,s],["Z"]],c={top:4,right:6,bottom:0,left:2},u=c[t],h=this.createCorner([l[u].slice(-2),l[u+1].slice(-2)]);return l.splice.apply(l,_e([u+1,1],H(h),!1)),l[0][0]="M",l},e.prototype.createCorner=function(t,n){n===void 0&&(n=10);var i=.8,a=one.apply(void 0,_e([],H(t),!1)),s=H(t,2),o=H(s[0],2),A=o[0],l=o[1],c=H(s[1],2),u=c[0],h=c[1],d=H(a?[u-A,[A,u]]:[h-l,[l,h]],2),f=d[0],g=H(d[1],2),v=g[0],p=g[1],y=f/2,m=f/Math.abs(f),B=n*m,C=B/2,S=B*Math.sqrt(3)/2*i,F=H([v,v+y-C,v+y,v+y+C,p],5),T=F[0],O=F[1],_=F[2],k=F[3],L=F[4];return a?(this.point=[_,l-S],[["L",T,l],["L",O,l],["L",_,l-S],["L",k,l],["L",L,l]]):(this.point=[A+S,_],[["L",A,T],["L",A,O],["L",A+S,_],["L",A,k],["L",A,L]])},e.prototype.applyVisibility=function(){var t=this.attributes.visibility;t==="hidden"?yi(this):Yl(this)},e.prototype.bindEvents=function(){this.label.on(it.BOUNDS_CHANGED,this.renderBackground)},e.prototype.render=function(){this.renderLabel(),this.renderBackground(),this.adjustLayout(),this.applyVisibility()},e})(Zt);function N1(r){return r===void 0&&(r=""),{CONTAINER:"".concat(r,"tooltip"),TITLE:"".concat(r,"tooltip-title"),LIST:"".concat(r,"tooltip-list"),LIST_ITEM:"".concat(r,"tooltip-list-item"),NAME:"".concat(r,"tooltip-list-item-name"),MARKER:"".concat(r,"tooltip-list-item-marker"),NAME_LABEL:"".concat(r,"tooltip-list-item-name-label"),VALUE:"".concat(r,"tooltip-list-item-value"),CROSSHAIR_X:"".concat(r,"tooltip-crosshair-x"),CROSSHAIR_Y:"".concat(r,"tooltip-crosshair-y")}}var jO={overflow:"hidden","white-space":"nowrap","text-overflow":"ellipsis"};function Wie(r){var e;r===void 0&&(r="");var t=N1(r);return e={},e[".".concat(t.CONTAINER)]={position:"absolute",visibility:"visible","z-index":8,transition:"visibility 0.2s cubic-bezier(0.23, 1, 0.32, 1), left 0.4s cubic-bezier(0.23, 1, 0.32, 1), top 0.4s cubic-bezier(0.23, 1, 0.32, 1)","background-color":"rgba(255, 255, 255, 0.96)","box-shadow":"0 6px 12px 0 rgba(0, 0, 0, 0.12)","border-radius":"4px",color:"rgba(0, 0, 0, 0.65)","font-size":"12px","line-height":"20px",padding:"12px","min-width":"120px","max-width":"360px","font-family":"Roboto-Regular"},e[".".concat(t.TITLE)]={color:"rgba(0, 0, 0, 0.45)"},e[".".concat(t.LIST)]={margin:"0px","list-style-type":"none",padding:"0px"},e[".".concat(t.LIST_ITEM)]={"list-style-type":"none",display:"flex","line-height":"2em","align-items":"center","justify-content":"space-between","white-space":"nowrap"},e[".".concat(t.MARKER)]={width:"8px",height:"8px","border-radius":"50%",display:"inline-block","margin-right":"4px"},e[".".concat(t.NAME)]={display:"flex","align-items":"center","max-width":"216px"},e[".".concat(t.NAME_LABEL)]=le({flex:1},jO),e[".".concat(t.VALUE)]=le({display:"inline-block",float:"right",flex:1,"text-align":"right","min-width":"28px","margin-left":"30px",color:"rgba(0, 0, 0, 0.85)"},jO),e[".".concat(t.CROSSHAIR_X)]={position:"absolute",width:"1px","background-color":"rgba(0, 0, 0, 0.25)"},e[".".concat(t.CROSSHAIR_Y)]={position:"absolute",height:"1px","background-color":"rgba(0, 0, 0, 0.25)"},e}var qie=(function(r){Xe(e,r);function e(t){var n=this,i,a,s=(a=(i=t.style)===null||i===void 0?void 0:i.template)===null||a===void 0?void 0:a.prefixCls,o=N1(s);return n=r.call(this,t,{data:[],x:0,y:0,visibility:"visible",title:"",position:"bottom-right",offset:[5,5],enterable:!1,container:{x:0,y:0},bounding:null,template:{prefixCls:"",container:'<div class="'.concat(o.CONTAINER,'"></div>'),title:'<div class="'.concat(o.TITLE,'"></div>'),item:'<li class="'.concat(o.LIST_ITEM,`" data-index={index}>
|
|
51
|
+
<span class="`).concat(o.NAME,`">
|
|
52
|
+
<span class="`).concat(o.MARKER,`" style="background:{color}"></span>
|
|
53
|
+
<span class="`).concat(o.NAME_LABEL,`" title="{name}">{name}</span>
|
|
54
|
+
</span>
|
|
55
|
+
<span class="`).concat(o.VALUE,`" title="{value}">{value}</span>
|
|
56
|
+
</li>`)},style:Wie(s)})||this,n.timestamp=-1,n.prevCustomContentKey=n.attributes.contentKey,n.initShape(),n.render(n.attributes,n),n}return Object.defineProperty(e.prototype,"HTMLTooltipElement",{get:function(){return this.element},enumerable:!1,configurable:!0}),e.prototype.getContainer=function(){return this.element},Object.defineProperty(e.prototype,"elementSize",{get:function(){var t=this.element.offsetWidth,n=this.element.offsetHeight;return{width:t,height:n}},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"HTMLTooltipItemsElements",{get:function(){var t=this.attributes,n=t.data,i=t.template;return n.map(function(a,s){var o=a.name,A=o===void 0?"":o,l=a.color,c=l===void 0?"black":l,u=a.index,h=Dt(a,["name","color","index"]),d=le({name:A,color:c,index:u??s},h);return xw(gR(i.item,d))})},enumerable:!1,configurable:!0}),e.prototype.render=function(t,n){this.renderHTMLTooltipElement(),this.updatePosition()},e.prototype.destroy=function(){var t;(t=this.element)===null||t===void 0||t.remove(),r.prototype.destroy.call(this)},e.prototype.show=function(t,n){var i=this;if(t!==void 0&&n!==void 0){var a=this.element.style.visibility==="hidden",s=function(){i.attributes.x=t??i.attributes.x,i.attributes.y=n??i.attributes.y,i.updatePosition()};a?this.closeTransition(s):s()}this.element.style.visibility="visible"},e.prototype.hide=function(t,n){t===void 0&&(t=0),n===void 0&&(n=0);var i=this.attributes.enterable;i&&this.isCursorEntered(t,n)||(this.element.style.visibility="hidden")},e.prototype.initShape=function(){var t=this.attributes.template;this.element=xw(t.container),this.id&&this.element.setAttribute("id",this.id)},e.prototype.renderCustomContent=function(){if(!(this.prevCustomContentKey!==void 0&&this.prevCustomContentKey===this.attributes.contentKey)){this.prevCustomContentKey=this.attributes.contentKey;var t=this.attributes.content;t&&(typeof t=="string"?this.element.innerHTML=t:pO(this.element,t))}},e.prototype.renderHTMLTooltipElement=function(){var t,n,i=this.attributes,a=i.template,s=i.title,o=i.enterable,A=i.style,l=i.content,c=N1(a.prefixCls),u=this.element;if(this.element.style.pointerEvents=o?"auto":"none",l)this.renderCustomContent();else{s?(u.innerHTML=a.title,u.getElementsByClassName(c.TITLE)[0].innerHTML=s):(n=(t=u.getElementsByClassName(c.TITLE))===null||t===void 0?void 0:t[0])===null||n===void 0||n.remove();var h=this.HTMLTooltipItemsElements,d=document.createElement("ul");d.className=c.LIST,pO(d,h);var f=this.element.querySelector(".".concat(c.LIST));f?f.replaceWith(d):u.appendChild(d)}une(u,A)},e.prototype.getRelativeOffsetFromCursor=function(t){var n=this.attributes,i=n.position,a=n.offset,s=t||i,o=s.split("-"),A={left:[-1,0],right:[1,0],top:[0,-1],bottom:[0,1]},l=this.elementSize,c=l.width,u=l.height,h=[-c/2,-u/2];return o.forEach(function(d){var f=H(h,2),g=f[0],v=f[1],p=H(A[d],2),y=p[0],m=p[1];h=[g+(c/2+a[0])*y,v+(u/2+a[1])*m]}),h},e.prototype.setOffsetPosition=function(t){var n=H(t,2),i=n[0],a=n[1],s=this.attributes,o=s.x,A=o===void 0?0:o,l=s.y,c=l===void 0?0:l,u=s.container,h=u.x,d=u.y;this.element.style.left="".concat(+A+h+i,"px"),this.element.style.top="".concat(+c+d+a,"px")},e.prototype.updatePosition=function(){var t=this.attributes.showDelay,n=t===void 0?60:t,i=Date.now();this.timestamp>0&&i-this.timestamp<n||(this.timestamp=i,this.setOffsetPosition(this.autoPosition(this.getRelativeOffsetFromCursor())))},e.prototype.autoPosition=function(t){var n=H(t,2),i=n[0],a=n[1],s=this.attributes,o=s.x,A=s.y,l=s.bounding,c=s.position;if(!l)return[i,a];var u=this.element,h=u.offsetWidth,d=u.offsetHeight,f=H([+o+i,+A+a],2),g=f[0],v=f[1],p={left:"right",right:"left",top:"bottom",bottom:"top"},y=l.x,m=l.y,B=l.width,C=l.height,S={left:g<y,right:g+h>y+B,top:v<m,bottom:v+d>m+C},F=[];c.split("-").forEach(function(O){S[O]?F.push(p[O]):F.push(O)});var T=F.join("-");return this.getRelativeOffsetFromCursor(T)},e.prototype.isCursorEntered=function(t,n){if(this.element){var i=this.element.getBoundingClientRect(),a=i.x,s=i.y,o=i.width,A=i.height;return new dr(a,s,o,A).isPointIn(t,n)}return!1},e.prototype.closeTransition=function(t){var n=this,i=this.element.style.transition;this.element.style.transition="none",t(),setTimeout(function(){n.element.style.transition=i},10)},e.tag="tooltip",e})(Zt),$ie=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},e.defaultOptions,t))||this;return n.hoverColor="#f5f5f5",n.selectedColor="#e6f7ff",n.background=n.appendChild(new Vn({})),n.label=n.background.appendChild(new Tn({})),n}return Object.defineProperty(e.prototype,"padding",{get:function(){return jn(this.style.padding)},enumerable:!1,configurable:!0}),e.prototype.renderLabel=function(){var t=this.style,n=t.label,i=t.value,a=ze(this.attributes,"label");Me(this.label).maybeAppend(".label",function(){return ya(n)}).attr("className","label").styles(a),this.label.attr("__data__",i)},e.prototype.renderBackground=function(){var t=this.label.getBBox(),n=H(this.padding,4),i=n[0],a=n[1],s=n[2],o=n[3],A=t.width,l=t.height,c=A+o+a,u=l+i+s,h=ze(this.attributes,"background"),d=this.style,f=d.width,g=f===void 0?0:f,v=d.height,p=v===void 0?0:v,y=d.selected;this.background.attr(le(le({},h),{width:Math.max(c,g),height:Math.max(u,p),fill:y?this.selectedColor:"#fff"})),this.label.attr({transform:"translate(".concat(o,", ").concat((u-l)/2,")")})},e.prototype.render=function(){this.renderLabel(),this.renderBackground()},e.prototype.bindEvents=function(){var t=this;this.addEventListener("pointerenter",function(){t.style.selected||t.background.attr("fill",t.hoverColor)}),this.addEventListener("pointerleave",function(){t.style.selected||t.background.attr("fill",t.style.backgroundFill)});var n=this;this.addEventListener("click",function(){var i=t.style,a=i.label,s=i.value,o=i.onClick;o==null||o(s,{label:a,value:s},n)})},e.defaultOptions={style:{value:"",label:"",cursor:"pointer"}},e})(Zt),Yie=(function(r){Xe(e,r);function e(t){var n,i,a=r.call(this,wn({},e.defaultOptions,t))||this;a.currentValue=(n=e.defaultOptions.style)===null||n===void 0?void 0:n.defaultValue,a.isPointerInSelect=!1,a.select=a.appendChild(new Vn({className:"select",style:{cursor:"pointer",width:0,height:0}})),a.dropdown=a.appendChild(new Vn({className:"dropdown"}));var s=a.style.defaultValue;return s&&(!((i=a.style.options)===null||i===void 0)&&i.some(function(o){return o.value===s}))&&(a.currentValue=s),a}return e.prototype.setValue=function(t){this.currentValue=t,this.render()},e.prototype.getValue=function(){return this.currentValue},Object.defineProperty(e.prototype,"dropdownPadding",{get:function(){return jn(this.style.dropdownPadding)},enumerable:!1,configurable:!0}),e.prototype.renderSelect=function(){var t=this,n,i=this.style,a=i.x,s=i.y,o=i.width,A=i.height,l=i.bordered,c=i.showDropdownIcon,u=ze(this.attributes,"select"),h=ze(this.attributes,"placeholder");this.select.attr(le(le({x:a,y:s,width:o,height:A},u),{fill:"#fff",strokeWidth:l?1:0}));var d=this.dropdownPadding,f=10;c&&Me(this.select).maybeAppend(".dropdown-icon","path").style("d","M-5,-3.5 L0,3.5 L5,-3.5").style("transform","translate(".concat(a+o-f-d[1]-d[3],", ").concat(s+A/2,")")).style("lineWidth",1).style("stroke",this.select.style.stroke);var g=(n=this.style.options)===null||n===void 0?void 0:n.find(function(m){return m.value===t.currentValue}),v=le({x:a+d[3]},h);Me(this.select).selectAll(".placeholder").data(g?[]:[1]).join(function(m){return m.append("text").attr("className","placeholder").styles(v).style("y",function(){var B=this.getBBox();return s+(A-B.height)/2})},function(m){return m.styles(v)},function(m){return m.remove()});var p=ze(this.attributes,"optionLabel"),y=le({x:a+d[3]},p);Me(this.select).selectAll(".value").data(g?[g]:[]).join(function(m){return m.append(function(B){return ya(B.label)}).attr("className","value").styles(y).style("y",function(){var B=this.getBBox();return s+(A-B.height)/2})},function(m){return m.styles(y)},function(m){return m.remove()})},e.prototype.renderDropdown=function(){var t=this,n,i,a=this.style,s=a.x,o=a.y,A=a.width,l=a.height,c=a.options,u=a.onSelect,h=a.open,d=ze(this.attributes,"dropdown"),f=ze(this.attributes,"option"),g=this.dropdownPadding;Me(this.dropdown).maybeAppend(".dropdown-container","g").attr("className","dropdown-container").selectAll(".dropdown-item").data(c,function(y){return y.value}).join(function(y){return y.append(function(m){return new $ie({className:"dropdown-item",style:le(le(le({},m),f),{width:A-g[1]-g[3],selected:m.value===t.currentValue,onClick:function(B,C,S){t.setValue(B),u==null||u(B,C,S),t.dispatchEvent(new vn("change",{detail:{value:B,option:C,item:S}})),yi(t.dropdown)}})})}).each(function(m,B){var C,S=(C=this.parentNode)===null||C===void 0?void 0:C.children,F=S.reduce(function(T,O,_){return _<B&&(T+=O.getBBox().height),T},0);this.attr("transform","translate(".concat(g[3],", ").concat(g[0]+F,")"))})},function(y){return y.update(function(m){return{selected:m.value===t.currentValue}})},function(y){return y.remove()});var v=(i=(n=this.dropdown.getElementsByClassName("dropdown-container"))===null||n===void 0?void 0:n[0])===null||i===void 0?void 0:i.getBBox(),p=d.spacing;this.dropdown.attr(le({transform:"translate(".concat(s,", ").concat(o+l+p,")"),width:v.width+g[1]+g[3],height:v.height+g[0]+g[2]},d)),!h&&yi(this.dropdown)},e.prototype.render=function(){this.renderSelect(),this.renderDropdown()},e.prototype.bindEvents=function(){var t=this;this.addEventListener("click",function(n){n.stopPropagation()}),this.select.addEventListener("click",function(){t.dropdown.style.visibility==="visible"?yi(t.dropdown):Yl(t.dropdown)}),this.addEventListener("pointerenter",function(){t.isPointerInSelect=!0}),this.addEventListener("pointerleave",function(){t.isPointerInSelect=!1}),document==null||document.addEventListener("click",function(){t.isPointerInSelect||yi(t.dropdown)})},e.defaultOptions={style:{x:0,y:0,width:140,height:32,options:[],bordered:!0,defaultValue:"",selectRadius:8,selectStroke:"#d9d9d9",showDropdownIcon:!0,placeholderText:"请选择",placeholderFontSize:12,placeholderTextBaseline:"top",placeholderFill:"#c2c2c2",dropdownFill:"#fff",dropdownStroke:"#d9d9d9",dropdownRadius:8,dropdownShadowBlur:4,dropdownShadowColor:"rgba(0, 0, 0, 0.08)",dropdownPadding:8,dropdownSpacing:10,optionPadding:[8,12],optionFontSize:12,optionTextBaseline:"top",optionBackgroundFill:"#fff",optionBackgroundRadius:4,optionLabelFontSize:12,optionLabelTextBaseline:"top"}},e})(Zt),Fi=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},{style:{backgroundOpacity:e.backgroundOpacities.default}},e.defaultOptions,t))||this;return n.showBackground=!0,n.background=n.appendChild(new Vn({})),n.icon=n.appendChild(new Tn({})),n}return Object.defineProperty(e.prototype,"label",{get:function(){return"BaseIcon"},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"lineWidth",{get:function(){return Math.log10(this.attributes.size)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"padding",{get:function(){return jn(this.attributes.size/5)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"iconSize",{get:function(){var t=this.attributes.size,n=H(this.padding,4),i=n[0],a=n[1],s=n[2],o=n[3];return Math.max(t-Math.max(o+a,i+s),this.lineWidth*2+1)},enumerable:!1,configurable:!0}),e.prototype.renderBackground=function(){var t=this.attributes,n=t.x,i=t.y,a=t.size,s=a/2,o=ze(this.attributes,"background");this.background.attr(le({x:n-s,y:i-s,width:a,height:a},o))},e.prototype.showIndicator=function(){if(this.label){var t=this.attributes.size,n=this.background.getBBox(),i=n.x,a=n.y;this.indicator.update({x:i+t/2,y:a-5,labelText:this.label,visibility:"visible"})}},e.prototype.hideIndicator=function(){this.indicator.update({visibility:"hidden"})},e.prototype.connectedCallback=function(){var t;r.prototype.connectedCallback.call(this);var n=this.attributes.size,i=this.background.getBBox(),a=i.x,s=i.y,o=(t=this.ownerDocument)===null||t===void 0?void 0:t.defaultView;o&&(this.indicator=o.appendChild(new jie({style:{x:a+n/2,y:s-n/2,visibility:"hidden",position:"top",radius:3,zIndex:100}})))},e.prototype.disconnectedCallback=function(){this.indicator.destroy()},e.prototype.render=function(){this.renderIcon(),this.showBackground&&this.renderBackground()},e.prototype.bindEvents=function(){var t=this,n=this.attributes.onClick;if(this.addEventListener("click",function(){n==null||n(t)}),this.showBackground){var i=function(){return t.background.attr({opacity:e.backgroundOpacities.default})},a=function(){return t.background.attr({opacity:e.backgroundOpacities.hover})},s=function(){return t.background.attr({opacity:e.backgroundOpacities.active})};this.addEventListener("pointerenter",function(){a(),t.showIndicator()}),this.addEventListener("pointerleave",function(){i(),t.hideIndicator()}),this.addEventListener("pointerdown",function(){s()}),this.addEventListener("pointerup",function(){i()})}},e.tag="IconBase",e.defaultOptions={style:{x:0,y:0,size:10,color:"#565758",backgroundRadius:4,backgroundFill:"#e2e2e2"}},e.backgroundOpacities={default:0,hover:.8,active:1},e})(Zt),Cl=function(r,e){return e===void 0&&(e="#565758"),new rr({style:{fill:e,d:"M ".concat(r,",").concat(r," L -").concat(r,",0 L ").concat(r,",-").concat(r," Z"),transformOrigin:"center"}})},Xie=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return e.prototype.arcPath=function(t,n,i){var a=H([i,i],2),s=a[0],o=a[1],A=function(g){return[t+i*Math.cos(g),n+i*Math.sin(g)]},l=H(A(-5/4*Math.PI),2),c=l[0],u=l[1],h=H(A(1/4*Math.PI),2),d=h[0],f=h[1];return"M".concat(c,",").concat(u,",A").concat(s,",").concat(o,",0,1,1,").concat(d,",").concat(f)},Object.defineProperty(e.prototype,"label",{get:function(){return"重置"},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this.iconSize,o=this.lineWidth,A=o+.5;Me(this.icon).maybeAppend(".reset","path").styles({stroke:a,lineWidth:o,d:this.arcPath(n,i,s/2-o),markerStart:Cl(A,a)})},e})(Fi),Zie=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return Object.defineProperty(e.prototype,"label",{get:function(){return"快退"},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this.iconSize,o=s/2,A=s/2/Math.pow(3,.5),l=[[n,i],[n,i-A],[n-o,i],[n,i+A],[n,i],[n+o,i-A],[n+o,i+A],[n,i]];Me(this.icon).maybeAppend(".backward","polygon").styles({points:l,fill:a})},e})(Fi),Jie=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return Object.defineProperty(e.prototype,"label",{get:function(){return"快进"},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this.iconSize,o=s/2,A=s/2/Math.pow(3,.5),l=[[n,i],[n,i-A],[n+o,i],[n,i+A],[n,i],[n-o,i-A],[n-o,i+A],[n,i]];Me(this.icon).maybeAppend(".forward","polygon").styles({points:l,fill:a})},e})(Fi),eae=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return Object.defineProperty(e.prototype,"label",{get:function(){return"播放"},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this.iconSize,o=s/3*Math.pow(3,.5)*.8,A=[[n+o,i],[n-o/2,i-s/2*.8],[n-o/2,i+s/2*.8],[n+o,i]];Me(this.icon).maybeAppend(".play","polygon").styles({points:A,fill:a})},e})(Fi),tae=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return Object.defineProperty(e.prototype,"label",{get:function(){return"暂停"},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this.iconSize,o=s/3,A=[[n-o,i-s/2],[n-o,i+s/2],[n-o/2,i+s/2],[n-o/2,i-s/2],[n-o,i-s/2],[n+o/2,i-s/2],[n+o/2,i+s/2],[n+o,i+s/2],[n+o,i-s/2]];Me(this.icon).maybeAppend(".pause","polygon").styles({points:A,fill:a})},e})(Fi),nae=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return Object.defineProperty(e.prototype,"label",{get:function(){return"范围时间"},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this,o=s.iconSize,A=s.lineWidth,l=A;Me(this.icon).maybeAppend(".left-line","line").styles({x1:n-o/2,y1:i-o/2,x2:n-o/2,y2:i+o/2,stroke:a,lineWidth:A}),Me(this.icon).maybeAppend(".right-line","line").styles({x1:n+o/2,y1:i-o/2,x2:n+o/2,y2:i+o/2,stroke:a,lineWidth:A}),Me(this.icon).maybeAppend(".left-arrow","line").styles({x1:n,y1:i,x2:n-o/2+l*2,y2:i,stroke:a,lineWidth:A,markerEnd:Cl(A*2,a)}),Me(this.icon).maybeAppend(".right-arrow","line").styles({x1:n,y1:i,x2:n+o/2-l*2,y2:i,stroke:a,lineWidth:A,markerEnd:Cl(A*2,a)})},e})(Fi),rae=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return Object.defineProperty(e.prototype,"label",{get:function(){return"单一时间"},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this,o=s.iconSize,A=s.lineWidth;Me(this.icon).maybeAppend(".line","line").styles({x1:n,y1:i-o/2,x2:n,y2:i+o/2,stroke:a,lineWidth:A});var l=A;Me(this.icon).maybeAppend(".left-arrow","line").styles({x1:n-o/2-l*2,y1:i,x2:n-l*2,y2:i,stroke:a,lineWidth:A,markerEnd:Cl(A*2,a)}),Me(this.icon).maybeAppend(".right-arrow","line").styles({x1:n+o/2+l*2,y1:i,x2:n+l*2,y2:i,stroke:a,lineWidth:A,markerEnd:Cl(A*2,a)})},e})(Fi),EU=function(r){return[[-r/2,-r/2],[-r/2,r/2],[r/2,r/2]]},iae=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return Object.defineProperty(e.prototype,"label",{get:function(){return"折线图"},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this,o=s.iconSize,A=s.lineWidth,l=A,c=(o-l*2-A)/4,u=(o-l*2-A)/2,h=H([n-o/2+l,i+o/2-l*2],2),d=h[0],f=h[1];Me(this.icon).maybeAppend(".coordinate","polyline").styles({points:EU(o).map(function(g){var v=H(g,2),p=v[0],y=v[1];return[p+n,y+i]}),stroke:a,lineWidth:A}),Me(this.icon).maybeAppend(".line","polyline").styles({points:[[d,f],[d+c,f-u],[d+c*2,f],[d+c*4,f-u*2]],stroke:a,lineWidth:A})},e})(Fi),aae=(function(r){Xe(e,r);function e(){return r!==null&&r.apply(this,arguments)||this}return Object.defineProperty(e.prototype,"label",{get:function(){return"条形图"},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"data",{get:function(){return[1,4,2,4,3]},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.data,n=this.attributes,i=n.x,a=n.y,s=n.color,o=this,A=o.iconSize,l=o.lineWidth,c=l,u=(A-c)/t.length,h=(A-c*2)/4,d=H([i-A/2+c*2,a+A/2-c],2),f=d[0],g=d[1];Me(this.icon).maybeAppend(".coordinate","polyline").styles({points:EU(A).map(function(v){var p=H(v,2),y=p[0],m=p[1];return[y+i,m+a]}),stroke:s,lineWidth:l}),Me(this.icon).maybeAppend(".bars","g").selectAll(".column").data(this.data.map(function(v,p){return{value:v,index:p}})).join(function(v){return v.append("line").attr("className","column").style("x1",function(p){var y=p.index;return f+u*y}).style("y1",g).style("x2",function(p){var y=p.index;return f+u*y}).style("y2",function(p){var y=p.value;return g-h*y}).styles({y1:g,stroke:s,lineWidth:l})})},e})(Fi),sae=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},{style:{color:"#d8d9d9"}},t))||this;return n.showBackground=!1,n}return e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.color,s=this,o=s.iconSize,A=s.lineWidth;Me(this.icon).maybeAppend(".split","line").styles({x1:n,y1:i-o/2,x2:n,y2:i+o/2,stroke:a,lineWidth:A})},e})(Fi),U1=(function(r){Xe(e,r);function e(){var t=r.apply(this,_e([],H(arguments),!1))||this;return t.showBackground=!1,t}return Object.defineProperty(e.prototype,"padding",{get:function(){return jn(0)},enumerable:!1,configurable:!0}),e.prototype.renderIcon=function(){var t=this.iconSize,n=this.attributes,i=n.x,a=n.y,s=n.speed,o=s===void 0?1:s,A=V1(this.attributes,["x","y","transform","transformOrigin","width","height","size","color","speed"]),l=Yt(t,20,1/0),c=20,u=le(le({},A),{x:i-l/2,y:a-c/2,width:l,height:c,defaultValue:o,bordered:!1,showDropdownIcon:!1,selectRadius:2,dropdownPadding:this.padding,dropdownRadius:2,dropdownSpacing:t/5,placeholderFontSize:t/2,optionPadding:0,optionLabelFontSize:t/2,optionBackgroundRadius:1,options:[{label:"1x",value:1},{label:"1.5x",value:1.5},{label:"2x",value:2}]});Me(this.icon).maybeAppend(".speed",function(){return new Yie({style:u})}).attr("className","speed").each(function(){this.update(u)})},e.tag="SpeedSelect",e})(Fi),fb=(function(r){Xe(e,r);function e(t){var n=r.call(this,t)||this;return n.icon=n.appendChild(new Tn({})),n.currentType=n.attributes.type,n}return e.prototype.getType=function(){return this.currentType},e.prototype.render=function(){var t=this,n=this.attributes;n.onChange;var i=Dt(n,["onChange"]);Me(this.icon).selectAll(".icon").data([this.currentType]).join(function(a){return a.append(function(s){var o,A=(o=t.toggles.find(function(l){var c=H(l,1),u=c[0];return u===s}))===null||o===void 0?void 0:o[1];if(!A)throw new Error("Invalid type: ".concat(s));return new A({})}).attr("className","icon").styles(i,!1).update({})},function(a){return a.styles({restStyles:i}).update({})},function(a){return a.remove()})},e.prototype.bindEvents=function(){var t=this,n=this.attributes.onChange;this.addEventListener("click",function(i){i.preventDefault(),i.stopPropagation();var a=(t.toggles.findIndex(function(o){var A=H(o,1),l=A[0];return l===t.currentType})+1)%t.toggles.length,s=t.toggles[a][0];n==null||n(t.currentType),t.currentType=s,t.render()})},e.tag="ToggleIcon",e})(Zt),P1=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},{style:{type:"play"}},t))||this;return n.toggles=[["play",eae],["pause",tae]],n}return e})(fb),R1=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},{style:{type:"range"}},t))||this;return n.toggles=[["range",nae],["value",rae]],n}return e})(fb),D1=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},{style:{type:"column"}},t))||this;return n.toggles=[["line",iae],["column",aae]],n}return e})(fb),oae={reset:Xie,speed:U1,backward:Zie,playPause:P1,forward:Jie,selectionType:R1,chartType:D1,split:sae},Aae=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},e.defaultOptions,t))||this;return n.background=n.appendChild(new Vn({})),n.functions=n.appendChild(new Tn({})),n}return Object.defineProperty(e.prototype,"padding",{get:function(){return jn(this.attributes.padding)},enumerable:!1,configurable:!0}),e.prototype.renderBackground=function(){var t=this.style,n=t.x,i=t.y,a=t.width,s=t.height,o=ze(this.attributes,"background");this.background.attr(le({x:n,y:i,width:a,height:s},o))},e.prototype.renderFunctions=function(){var t=this,n,i=this.attributes,a=i.functions,s=i.iconSize,o=i.iconSpacing,A=i.x,l=i.y,c=i.width,u=i.height,h=i.align,d=H(this.padding,4),f=d[1],g=d[3],v=a.reduce(function(m,B){return m.length&&B.length?m.concat.apply(m,_e(["split"],H(B),!1)):m.concat.apply(m,_e([],H(B),!1))},[]),p=v.length*(s+o)-o,y={left:g+s/2,center:(c-p)/2+s/2,right:c-p-g-f+s/2}[h]||0;(n=this.speedSelect)===null||n===void 0||n.destroy(),this.functions.removeChildren(),v.forEach(function(m,B){var C,S=oae[m],F={x:A+B*(s+o)+y,y:l+u/2,size:s};if(S===U1?(F.speed=t.attributes.speed,F.onSelect=function(O){return t.handleFunctionChange(m,{value:O})}):[P1,R1,D1].includes(S)?(F.onChange=function(O){return t.handleFunctionChange(m,{value:O})},S===P1&&(F.type=t.attributes.state==="play"?"pause":"play"),S===R1&&(F.type=t.attributes.selectionType==="range"?"value":"range"),S===D1&&(F.type=t.attributes.chartType==="line"?"column":"line")):F.onClick=function(){return t.handleFunctionChange(m,{value:m})},S===U1){var T=(C=t.ownerDocument)===null||C===void 0?void 0:C.defaultView;T&&(t.speedSelect=new S({style:le(le({},F),{zIndex:100})}),T.appendChild(t.speedSelect))}else t.functions.appendChild(new S({style:F}))})},e.prototype.disconnectedCallback=function(){var t;r.prototype.disconnectedCallback.call(this),(t=this.speedSelect)===null||t===void 0||t.destroy()},e.prototype.render=function(){this.renderBackground(),this.renderFunctions()},e.prototype.handleFunctionChange=function(t,n){var i=this.attributes.onChange;i==null||i(t,n)},e.defaultOptions={style:{x:0,y:0,width:300,height:40,padding:0,align:"center",iconSize:25,iconSpacing:0,speed:1,state:"pause",chartType:"line",selectionType:"range",backgroundFill:"#fbfdff",backgroundStroke:"#ebedf0",functions:[["reset","speed"],["backward","playPause","forward"],["selectionType","chartType"]]}},e})(Zt),lae=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},e.defaultOptions,t))||this;return n.bindEvents(),n}return e.prototype.bindEvents=function(){var t=this;this.addEventListener("mouseenter",function(){t.attr("lineWidth",Math.ceil(+(t.style.r||0)/2))}),this.addEventListener("mouseleave",function(){t.attr("lineWidth",0)})},e.defaultOptions={style:{r:5,fill:"#3f7cf7",lineWidth:0,stroke:"#3f7cf7",strokeOpacity:.5,cursor:"pointer"}},e})(zi),cae=(function(r){Xe(e,r);function e(t){return r.call(this,wn({},e.defaultOptions,t))||this}return e.prototype.renderBackground=function(){var t=this.attributes,n=t.x,i=t.y,a=t.width,s=t.height,o=ze(this.attributes,"background");Me(this).maybeAppend("background","rect").attr("className","background").styles(le({x:n-a/2,y:i-s/2,width:a,height:s},o))},e.prototype.renderIcon=function(){var t=this.attributes,n=t.x,i=t.y,a=t.iconSize,s=ze(this.attributes,"icon"),o=1,A=a/2;Me(this).maybeAppend("icon-left-line","line").attr("className","icon-left-line").styles(le({x1:n-o,y1:i-A,x2:n-o,y2:i+A},s)),Me(this).maybeAppend("icon-right-line","line").attr("className","icon-right-line").styles(le({x1:n+o,y1:i-A,x2:n+o,y2:i+A},s))},e.prototype.renderBorder=function(){var t=this.attributes,n=t.x,i=t.y,a=t.width,s=t.height,o=t.type,A=ze(this.attributes,"border"),l=o==="start"?+a/2:-a/2;Me(this).maybeAppend("border","line").attr("className","border").styles(le({x1:l+n,y1:i-s/2,x2:l+n,y2:i+s/2},A))},e.prototype.render=function(){this.renderBackground(),this.renderIcon(),this.renderBorder()},e.defaultOptions={style:{x:0,y:0,width:10,height:50,iconSize:10,type:"start",backgroundFill:"#fff",backgroundFillOpacity:.5,iconStroke:"#9a9a9a",iconLineWidth:1,borderStroke:"#e8e8e8",borderLineWidth:1}},e})(Zt);function uae(r,e){return typeof r=="number"?xU(r):hae(r,e)}function hae(r,e){var t=new Date(r);switch(e){case"half-hour":case"hour":case"four-hour":return[0,6,12,18].includes(t.getHours())&&t.getMinutes()===0?yr(t,`HH:mm
|
|
57
|
+
YYYY-MM-DD`):yr(t,"HH:mm");case"half-day":return t.getHours()<12?`AM
|
|
58
|
+
`.concat(yr(t,"YYYY-MM-DD")):"PM";case"day":return[1,10,20].includes(t.getDate())?yr(t,`DD
|
|
59
|
+
YYYY-MM`):yr(t,"DD");case"week":return t.getDate()<=7?yr(t,`DD
|
|
60
|
+
YYYY-MM`):yr(t,"DD");case"month":return[0,6].includes(t.getMonth())?yr(t,`MM月
|
|
61
|
+
YYYY`):yr(t,"MM月");case"season":return[0].includes(t.getMonth())?yr(t,`MM月
|
|
62
|
+
YYYY`):yr(t,"MM月");case"year":return yr(t,"YYYY");default:return yr(t,"YYYY-MM-DD HH:mm")}}function xU(r){var e=String(Math.floor(r/3600)).padStart(2,"0"),t=String(Math.floor(r%3600/60)).padStart(2,"0"),n=String(Math.floor(r%60)).padStart(2,"0");return r<3600?"".concat(t,":").concat(n):"".concat(e,":").concat(t,":").concat(n)}var dae=(function(r){Xe(e,r);function e(t){var n=r.call(this,wn({},e.defaultOptions,t))||this;n.axis=n.appendChild(new bie({style:{type:"linear",startPos:[0,0],endPos:[0,0],data:[],showArrow:!1,animate:!1}})),n.timeline=n.appendChild(new Bre({style:{onChange:function(u){n.handleSliderChange(u)}}})),n.controller=n.appendChild(new Aae({})),n.states={},n.handleSliderChange=function(u){var h=(function(){var d=n.states.values;return Array.isArray(d)?_e([],H(d),!1):d})();n.setBySliderValues(u),n.dispatchOnChange(h)};var i=n.attributes,a=i.selectionType,s=i.chartType,o=i.speed,A=i.state,l=i.playMode,c=i.values;return n.states={chartType:s,playMode:l,selectionType:a,speed:o,state:A},n.setByTimebarValues(c),n}return Object.defineProperty(e.prototype,"data",{get:function(){var t=this.attributes.data,n=function(i,a){return i.time<a.time?-1:i.time>a.time?1:0};return t.sort(n)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"space",{get:function(){var t=this.attributes,n=t.x,i=t.y,a=t.width,s=t.height,o=t.type,A=t.controllerHeight,l=Yt(+s-A,0,+s),c=new dr(n,i+ +s-A,+a,A),u,h=0;o==="chart"?(h=35,u=new dr(n,i+l-h,+a,h)):u=new dr;var d=o==="time"?10:l,f=new dr(n,i+(o==="time"?l:l-d),+a,d-h);return{axisBBox:u,controllerBBox:c,timelineBBox:f}},enumerable:!1,configurable:!0}),e.prototype.setBySliderValues=function(t){var n,i,a=this.data,s=H(Array.isArray(t)?t:[0,t],2),o=s[0],A=s[1],l=a.length,c=a[Math.floor(o*l)],u=a[Math.ceil(A*l)-(Array.isArray(t)?0:1)];this.states.values=[(n=c==null?void 0:c.time)!==null&&n!==void 0?n:a[0].time,(i=u==null?void 0:u.time)!==null&&i!==void 0?i:1/0]},e.prototype.setByTimebarValues=function(t){var n,i,a,s=this.data,o=H(Array.isArray(t)?t:[void 0,t],2),A=o[0],l=o[1],c=s.find(function(h){var d=h.time;return d===A}),u=s.find(function(h){var d=h.time;return d===l});this.states.values=[(n=c==null?void 0:c.time)!==null&&n!==void 0?n:(i=s[0])===null||i===void 0?void 0:i.time,(a=u==null?void 0:u.time)!==null&&a!==void 0?a:1/0]},e.prototype.setByIndex=function(t){var n,i,a,s,o=this.data,A=H(t,2),l=A[0],c=A[1];this.states.values=[(i=(n=o[l])===null||n===void 0?void 0:n.time)!==null&&i!==void 0?i:o[0].time,(s=(a=this.data[c])===null||a===void 0?void 0:a.time)!==null&&s!==void 0?s:1/0]},Object.defineProperty(e.prototype,"sliderValues",{get:function(){var t=this.states,n=t.values,i=t.selectionType,a=H(Array.isArray(n)?n:[void 0,n],2),s=a[0],o=a[1],A=this.data,l=A.length,c=i==="value",u=function(){var d=A.findIndex(function(f){var g=f.time;return g===s});return c?0:d>-1?d/l:0},h=function(){if(o===1/0)return 1;var d=A.findIndex(function(f){var g=f.time;return g===o});return d>-1?d/l:c?.5:1};return[u(),h()]},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"values",{get:function(){var t=this.states,n=t.values,i=t.selectionType,a=H(Array.isArray(n)?n:[this.data[0].time,n],2),s=a[0],o=a[1];return i==="value"?o:[s,o]},enumerable:!1,configurable:!0}),e.prototype.getDatumByRatio=function(t){var n=this.data,i=n.length,a=Math.floor(t*(i-1));return n[a]},Object.defineProperty(e.prototype,"chartHandleIconShape",{get:function(){var t=this.states.selectionType,n=this.space.timelineBBox.height;return t==="range"?function(i){return new cae({style:{type:i,height:n,iconSize:n/6}})}:function(){return new Ks({style:{x1:0,y1:-n/2,x2:0,y2:n/2,lineWidth:2,stroke:"#c8c8c8"}})}},enumerable:!1,configurable:!0}),e.prototype.getChartStyle=function(t){var n=this,i=t.x,a=t.y,s=t.width,o=t.height,A=this.states,l=A.selectionType,c=A.chartType,u=this.data,h=this.attributes,d=h.type,f=h.labelFormatter,g=ze(this.attributes,"chart");g.type;var v=Dt(g,["type"]),p=l==="range";if(d==="time")return le({handleIconShape:function(){return new lae({})},selectionFill:"#2e7ff8",selectionFillOpacity:1,showLabelOnInteraction:!0,handleLabelDy:p?-15:0,autoFitLabel:p,handleSpacing:p?-15:0,trackFill:"#edeeef",trackLength:s,trackOpacity:.5,trackRadius:o/2,trackSize:o/2,type:l,values:this.sliderValues,formatter:function(B){if(f)return f(B);var C=n.getDatumByRatio(B).time;return typeof C=="number"?xU(C):yr(C,"YYYY-MM-DD HH:mm:ss")},transform:"translate(".concat(i,", ").concat(a,")"),zIndex:1},v);var y=l==="range"?5:0,m=u.map(function(B){var C=B.value;return C});return le({handleIconOffset:y,handleIconShape:this.chartHandleIconShape,selectionFill:"#fff",selectionFillOpacity:.5,selectionType:"invert",sparklineSpacing:.1,sparklineColumnLineWidth:0,sparklineColor:"#d4e5fd",sparklineAreaOpacity:1,sparklineAreaLineWidth:0,sparklineData:m,sparklineType:c,sparklineScale:.8,trackLength:s,trackSize:o,type:l,values:this.sliderValues,transform:"translate(".concat(i,", ").concat(a,")"),zIndex:1},v)},e.prototype.renderChart=function(t){t===void 0&&(t=this.space.timelineBBox),this.timeline.update(this.getChartStyle(t))},e.prototype.updateSelection=function(){this.timeline.setValues(this.sliderValues,!0),this.handleSliderChange(this.sliderValues)},e.prototype.getAxisStyle=function(t){var n=this.data,i=this.attributes,a=i.interval,s=i.labelFormatter,o=ze(this.attributes,"axis"),A=t.x,l=t.y,c=t.width,u=_e(_e([],H(n),!1),[{time:0}],!1).map(function(d,f,g){var v=d.time;return{label:"".concat(v),value:f/(g.length-1),time:v}}),h=le({startPos:[A,l],endPos:[A+c,l],data:u,labelFilter:function(d,f){return f<u.length-1},labelFormatter:function(d){var f=d.time;return s?s(f):uae(f,a)}},o);return h},e.prototype.renderAxis=function(t){t===void 0&&(t=this.space.axisBBox);var n=this.attributes.type;n==="chart"&&this.axis.update(this.getAxisStyle(t))},e.prototype.renderController=function(t){t===void 0&&(t=this.space.controllerBBox);var n=this.attributes.type,i=this.states,a=i.state,s=i.speed,o=i.selectionType,A=i.chartType,l=ze(this.attributes,"controller"),c=this,u=le(le(le({},t),{iconSize:20,speed:s,state:a,selectionType:o,chartType:A,onChange:function(h,d){var f=d.value;switch(h){case"reset":c.internalReset();break;case"speed":c.handleSpeedChange(f);break;case"backward":c.internalBackward();break;case"playPause":f==="play"?c.internalPlay():c.internalPause();break;case"forward":c.internalForward();break;case"selectionType":c.handleSelectionTypeChange(f);break;case"chartType":c.handleChartTypeChange(f);break}}}),l);n==="time"&&(u.functions=[["reset","speed"],["backward","playPause","forward"],["selectionType"]]),this.controller.update(u)},e.prototype.dispatchOnChange=function(t){var n=this.data,i=this.attributes.onChange,a=this.states,s=a.values,o=a.selectionType,A=H(s,2),l=A[0],c=A[1],u=c===1/0?n.at(-1).time:c,h=o==="range"?[l,u]:u,d=function(f,g){return Array.isArray(f)?Array.isArray(g)?f[0]===g[0]&&(f[1]===g[1]||f[1]===1/0||g[1]===1/0):!1:Array.isArray(g)?!1:f===g};(!t||!d(t,h))&&(i==null||i(o==="range"?[l,u]:u))},e.prototype.internalReset=function(t){var n,i,a=this.states.selectionType;this.internalPause(),this.setBySliderValues(a==="range"?[0,1]:[0,0]),this.renderController(),this.updateSelection(),t||((i=(n=this.attributes)===null||n===void 0?void 0:n.onReset)===null||i===void 0||i.call(n),this.dispatchOnChange())},e.prototype.reset=function(){this.internalReset()},e.prototype.moveSelection=function(t,n){var i=this.data,a=i.length,s=this.states,o=s.values,A=s.selectionType,l=s.playMode,c=H(o,2),u=c[0],h=c[1],d=i.findIndex(function(m){var B=m.time;return B===u}),f=i.findIndex(function(m){var B=m.time;return B===h});f===-1&&(f=a);var g=t==="backward"?-1:1,v;A==="range"?l==="acc"?(v=[d,f+g],g===-1&&d===f&&(v=[d,a])):v=[d+g,f+g]:v=[d,f+g];var p=function(m){var B=H(m.sort(function(T,O){return T-O}),2),C=B[0],S=B[1],F=function(T){return Yt(T,0,a)};return S>a?A==="value"?[0,0]:l==="acc"?[F(C),F(C)]:[0,F(S-C)]:C<0?l==="acc"?[0,F(S)]:[F(C+a-S),a]:[F(C),F(S)]},y=p(v);return this.setByIndex(y),this.updateSelection(),y},e.prototype.internalBackward=function(t){var n,i,a=this.moveSelection("backward",t);return t||((i=(n=this.attributes)===null||n===void 0?void 0:n.onBackward)===null||i===void 0||i.call(n),this.dispatchOnChange()),a},e.prototype.backward=function(){this.internalBackward()},e.prototype.internalPlay=function(t){var n=this,i,a,s=this.data,o=this.attributes.loop,A=this.states.speed,l=A===void 0?1:A;this.playInterval=window.setInterval(function(){var c=n.internalForward();c[1]===s.length&&!o&&(n.internalPause(),n.renderController())},1e3/l),this.states.state="play",!t&&((a=(i=this.attributes)===null||i===void 0?void 0:i.onPlay)===null||a===void 0||a.call(i))},e.prototype.play=function(){this.internalPlay()},e.prototype.internalPause=function(t){var n,i;clearInterval(this.playInterval),this.states.state="pause",!t&&((i=(n=this.attributes)===null||n===void 0?void 0:n.onPause)===null||i===void 0||i.call(n))},e.prototype.pause=function(){this.internalPause()},e.prototype.internalForward=function(t){var n,i,a=this.moveSelection("forward",t);return t||((i=(n=this.attributes)===null||n===void 0?void 0:n.onForward)===null||i===void 0||i.call(n),this.dispatchOnChange()),a},e.prototype.forward=function(){this.internalForward()},e.prototype.handleSpeedChange=function(t){var n,i;this.states.speed=t;var a=this.states.state;a==="play"&&(this.internalPause(!0),this.internalPlay(!0)),(i=(n=this.attributes)===null||n===void 0?void 0:n.onSpeedChange)===null||i===void 0||i.call(n,t)},e.prototype.handleSelectionTypeChange=function(t){var n,i;this.states.selectionType=t,this.renderChart(),(i=(n=this.attributes)===null||n===void 0?void 0:n.onSelectionTypeChange)===null||i===void 0||i.call(n,t)},e.prototype.handleChartTypeChange=function(t){var n,i;this.states.chartType=t,this.renderChart(),(i=(n=this.attributes)===null||n===void 0?void 0:n.onChartTypeChange)===null||i===void 0||i.call(n,t)},e.prototype.render=function(){var t=this.space,n=t.axisBBox,i=t.controllerBBox,a=t.timelineBBox;this.renderController(i),this.renderAxis(n),this.renderChart(a),this.states.state==="play"&&this.internalPlay()},e.prototype.destroy=function(){r.prototype.destroy.call(this),this.internalPause(!0)},e.defaultOptions={style:{x:0,y:0,axisLabelFill:"#6e6e6e",axisLabelTextAlign:"left",axisLabelTextBaseline:"top",axisLabelTransform:"translate(5, -12)",axisLineLineWidth:1,axisLineStroke:"#cacdd1",axisTickLength:15,axisTickLineWidth:1,axisTickStroke:"#cacdd1",chartShowLabel:!1,chartType:"line",controllerAlign:"center",controllerHeight:40,data:[],interval:"day",loop:!1,playMode:"acc",selectionType:"range",type:"time"}},e})(Zt);function hf(r){const{width:e,height:t,renderer:n}=r,i=fae(r),a=new Dw({width:e,height:t,container:i,renderer:n||new vl});return[i,a]}function fae(r){var e;const{container:t,className:n,graphCanvas:i}=r;if(t)return typeof t=="string"?document.getElementById(t):t;const a=sA(n,!1),{width:s,height:o,containerStyle:A}=r,[l,c]=gae(r);return Object.assign(a.style,Object.assign({position:"absolute",left:l+"px",top:c+"px",width:s+"px",height:o+"px"},A)),(e=i.getContainer())===null||e===void 0||e.appendChild(a),a}function gae(r){const{width:e,height:t,placement:n,graphCanvas:i}=r,[a,s]=i.getSize(),[o,A]=cL(n);return[o*(a-e),A*(s-t)]}var vae=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class df extends Ln{constructor(e,t){super(e,Object.assign({},df.defaultOptions,t)),this.typePrefix="__data__",this.draw=!1,this.fieldMap={node:new Map,edge:new Map,combo:new Map},this.selectedItems=[],this.bindEvents=()=>{const{graph:n}=this.context;n.on(ge.AFTER_DRAW,this.createElement)},this.changeState=(n,i)=>{const{graph:a}=this.context,{typePrefix:s}=this,o=Rn(n,[s,"id"]),A=Rn(n,[s,"style","labelText"]),[l]=o.split("__"),c=this.fieldMap[l].get(A)||[];a.setElementState(Object.fromEntries(c==null?void 0:c.map(u=>[u,i])))},this.click=n=>{if(this.options.trigger==="hover")return;const i=Rn(n,[this.typePrefix,"id"]);this.selectedItems.includes(i)?(this.selectedItems=this.selectedItems.filter(a=>a!==i),this.changeState(n,[])):(this.selectedItems.push(i),this.changeState(n,"selected"))},this.mouseleave=n=>{this.options.trigger!=="click"&&(this.selectedItems=[],this.changeState(n,[]))},this.mouseenter=n=>{if(this.options.trigger==="click")return;const i=Rn(n,[this.typePrefix,"id"]);this.selectedItems.includes(i)?this.selectedItems=this.selectedItems.filter(a=>a!==i):(this.selectedItems.push(i),this.changeState(n,"active"))},this.setFieldMap=(n,i,a)=>{if(!n)return;const s=this.fieldMap[a];if(s)if(!s.has(n))s.set(n,[i]);else{const o=s.get(n);o&&(o.push(i),s.set(n,o))}},this.getEvents=()=>({mouseenter:this.mouseenter,mouseleave:this.mouseleave,click:this.click}),this.getMarkerData=(n,i)=>{if(!n)return[];const{model:a,element:s}=this.context,{nodes:o,edges:A,combos:l}=a.getData(),c={},u=v=>Te(n)?n(v):n,h={node:"circle",edge:"line",combo:"rect"},d={circle:"circle",ellipse:"circle",image:"bowtie",rect:"square",star:"cross",triangle:"triangle",diamond:"diamond",cubic:"dot",line:"hyphen",polyline:"hyphen",quadratic:"hv","cubic-horizontal":"hyphen","cubic-vertical":"line"},f=(v,p)=>s==null?void 0:s.getElementComputedStyle(v,p),g=(v,p)=>{v.forEach(y=>{const{id:m}=y,B=Rn(y,["data",u(y)]),C=(s==null?void 0:s.getElementType(p,y))||"circle",S=f(p,y),F=(p==="edge"?S==null?void 0:S.stroke:S==null?void 0:S.fill)||"#1783ff";m&&B&&B.replace(/\s+/g,"")&&(this.setFieldMap(B,m,p),c[B]||(c[B]={id:`${p}__${m}`,label:B,marker:d[C]||h[p],elementType:p,lineWidth:1,stroke:F,fill:F}))})};switch(i){case"node":g(o,"node");break;case"edge":g(A,"edge");break;case"combo":g(l,"combo");break;default:return[]}return Object.values(c)},this.createElement=()=>{if(this.draw){this.updateElement();return}const n=this.options,{width:i,height:a,nodeField:s,edgeField:o,comboField:A,trigger:l,position:c,container:u,containerStyle:h,className:d}=n,f=vae(n,["width","height","nodeField","edgeField","comboField","trigger","position","container","containerStyle","className"]),g=this.getMarkerData(s,"node"),v=this.getMarkerData(o,"edge"),p=this.getMarkerData(A,"combo"),y=[...g,...p,...v],m=Object.assign({width:i,height:a,data:y,itemMarkerLineWidth:({lineWidth:S})=>S,itemMarker:({marker:S})=>S,itemMarkerStroke:({stroke:S})=>S,itemMarkerFill:({fill:S})=>S,gridCol:g.length},f,this.getEvents()),B=new zie({className:"legend",style:m});this.category=B,this.upsertCanvas().appendChild(B),this.draw=!0},this.bindEvents()}update(e){super.update(e),this.clear(),this.createElement()}clear(){var e,t;(e=this.canvas)===null||e===void 0||e.destroy(),(t=this.container)===null||t===void 0||t.remove(),this.canvas=void 0,this.container=void 0,this.draw=!1}updateElement(){this.category&&this.category.update({itemMarkerOpacity:({id:e})=>!this.selectedItems.length||this.selectedItems.includes(e)?1:.5,itemLabelOpacity:({id:e})=>!this.selectedItems.length||this.selectedItems.includes(e)?1:.5})}upsertCanvas(){if(this.canvas)return this.canvas;const e=this.context.canvas,[t,n]=e.getSize(),{width:i=t,height:a=n,position:s,container:o,containerStyle:A,className:l}=this.options,[c,u]=hf({width:i,height:a,graphCanvas:e,container:o,containerStyle:A,placement:s,className:"legend"});return this.container=c,l&&c.classList.add(l),this.canvas=u,this.canvas}destroy(){this.clear(),this.context.graph.off(ge.AFTER_DRAW,this.createElement),super.destroy()}}df.defaultOptions={position:"bottom",trigger:"hover",orientation:"horizontal",layout:"flex",itemSpacing:4,rowPadding:10,colPadding:10,itemMarkerSize:16,itemLabelFontSize:16,width:240,height:160};class ff extends Ln{constructor(e,t){super(e,Object.assign({},ff.defaultOptions,t)),this.onDraw=n=>{var i;!((i=n==null?void 0:n.data)===null||i===void 0)&&i.render||this.onRender()},this.landmarkMap=new Map,this.mask=null,this.isMaskDragging=!1,this.onMaskDragStart=n=>{this.mask&&(this.isMaskDragging=!0,this.mask.setPointerCapture(n.pointerId),this.mask.addEventListener("pointermove",this.onMaskDrag),this.mask.addEventListener("pointerup",this.onMaskDragEnd),this.mask.addEventListener("pointercancel",this.onMaskDragEnd))},this.onMaskDrag=n=>{if(!this.mask||!this.isMaskDragging)return;const{size:[i,a]}=this.options,{movementX:s,movementY:o}=n,{left:A,top:l,width:c,height:u}=this.mask.style,[,,h,d]=this.maskBBox;let f=parseInt(A)+s,g=parseInt(l)+o,v=parseInt(c),p=parseInt(u);f<0&&(f=0),g<0&&(g=0),f+v>i&&(f=Ca(i-v,0)),g+p>a&&(g=Ca(a-p,0)),v<h&&(s>0?(f=Ca(f-s,0),v=xa(v+s,i)):s<0&&(v=xa(v-s,i))),p<d&&(o>0?(g=Ca(g-o,0),p=xa(p+o,a)):o<0&&(p=xa(p-o,a))),Object.assign(this.mask.style,{left:f+"px",top:g+"px",width:v+"px",height:p+"px"});const y=parseInt(A)-f,m=parseInt(l)-g;if(y===0&&m===0)return;const B=this.context.canvas.getCamera().getZoom(),C=this.canvas.getCamera().getZoom(),S=B/C;this.context.graph.translateBy([y*S,m*S],!1)},this.onMaskDragEnd=n=>{this.mask&&(this.isMaskDragging=!1,this.mask.releasePointerCapture(n.pointerId),this.mask.removeEventListener("pointermove",this.onMaskDrag),this.mask.removeEventListener("pointerup",this.onMaskDragEnd),this.mask.removeEventListener("pointercancel",this.onMaskDragEnd))},this.onTransform=V_(()=>{this.isMaskDragging||(this.updateMask(),this.setCamera())},32,{leading:!0}),this.setOnRender(),this.bindEvents()}update(e){this.unbindEvents(),super.update(e),"delay"in e&&this.setOnRender(),this.bindEvents()}setOnRender(){this.onRender=Sl(()=>{this.renderMinimap(),this.renderMask()},this.options.delay)}bindEvents(){const{graph:e}=this.context;e.on(ge.AFTER_DRAW,this.onDraw),e.on(ge.AFTER_RENDER,this.onRender),e.on(ge.AFTER_ANIMATE,this.onRender),e.on(ge.AFTER_TRANSFORM,this.onTransform)}unbindEvents(){const{graph:e}=this.context;e.off(ge.AFTER_DRAW,this.onDraw),e.off(ge.AFTER_RENDER,this.onRender),e.off(ge.AFTER_ANIMATE,this.onRender),e.off(ge.AFTER_TRANSFORM,this.onTransform)}renderMinimap(){const e=this.getElements(),t=this.initCanvas();this.setShapes(t,e)}getElements(){const{filter:e}=this.options,{model:t,element:n}=this.context,i=t.getData(),a={nodes:i.nodes.filter(l=>n==null?void 0:n.getElement(Z(l))),edges:i.edges.filter(l=>{const c=n==null?void 0:n.getElement(Z(l));return c&&GL(c)}),combos:i.combos.filter(l=>n==null?void 0:n.getElement(Z(l)))};if(!e)return a;const{nodes:s,edges:o,combos:A}=a;return{nodes:s.filter(l=>e(Z(l),"node")),edges:o.filter(l=>e(Z(l),"edge")),combos:A.filter(l=>e(Z(l),"combo"))}}setShapes(e,t){const{nodes:n,edges:i,combos:a}=t,{shape:s}=this.options,{element:o}=this.context,A=(l,c)=>{const u=Z(l),h=o==null?void 0:o.getElement(u);if(!h)return;const d=h.getShape("key");let f;if(typeof s=="string"){const g=s;f=h.getShape(g).cloneNode()}else{const g=s(u,c,h);g===h?f=g.cloneNode(!0):f=g}f.setPosition(d.getPosition()),h.style.zIndex&&(f.style.zIndex=h.style.zIndex),f.id=h.id,e.appendChild(f)};e.removeChildren(),i.forEach(l=>A(l,"edge")),a.forEach(l=>A(l,"combo")),n.forEach(l=>A(l,"node"))}initCanvas(){const{renderer:e,size:[t,n]}=this.options;if(this.canvas){const{width:i,height:a}=this.canvas.getConfig();(t!==i||n!==a)&&this.canvas.resize(t,n),e&&this.canvas.setRenderer(e)}else{const{className:i,position:a,container:s,containerStyle:o}=this.options,[A,l]=hf({renderer:e,width:t,height:n,placement:a,className:"minimap",container:s,containerStyle:o,graphCanvas:this.context.canvas});i&&A.classList.add(i),this.container=A,this.canvas=l}return this.setCamera(),this.canvas}createLandmark(e,t,n){const i=`${e.join(",")}-${t.join(",")}-${n}`;if(this.landmarkMap.has(i))return this.landmarkMap.get(i);const s=this.canvas.getCamera().createLandmark(i,{position:e,focalPoint:t,zoom:n});return this.landmarkMap.set(i,s),s}setCamera(){var e;const{canvas:t}=this.context,n=(e=this.canvas)===null||e===void 0?void 0:e.getCamera();if(!n)return;const{size:[i,a],padding:s}=this.options,[o,A,l,c]=ai(s),{min:u,max:h,center:d}=t.getBounds("elements"),f=h[0]-u[0],g=h[1]-u[1],v=i-c-A,p=a-o-l,y=v/f,m=p/g,B=Math.min(y,m),C=this.createLandmark(d,d,B);n.gotoLandmark(C,0)}get maskBBox(){const{canvas:e}=this.context,t=e.getSize(),n=e.getCanvasByViewport([0,0]),i=e.getCanvasByViewport(t),a=this.canvas.canvas2Viewport(pi(n)),s=this.canvas.canvas2Viewport(pi(i)),o=s.x-a.x,A=s.y-a.y;return[a.x,a.y,o,A]}calculateMaskBBox(){const{size:[e,t]}=this.options;let[n,i,a,s]=this.maskBBox;return n<0&&(a=xa(a+n,e),n=0),i<0&&(s=xa(s+i,t),i=0),n+a>e&&(a=Ca(e-n,0)),i+s>t&&(s=Ca(t-i,0)),[xa(n,e),xa(i,t),Ca(a,0),Ca(s,0)]}renderMask(){const{maskStyle:e}=this.options;this.mask||(this.mask=document.createElement("div"),this.mask.addEventListener("pointerdown",this.onMaskDragStart),this.mask.draggable=!0,this.mask.addEventListener("dragstart",t=>t.preventDefault&&t.preventDefault())),this.container.appendChild(this.mask),Object.assign(this.mask.style,Object.assign(Object.assign({},e),{cursor:"move",position:"absolute",pointerEvents:"auto"})),this.updateMask()}updateMask(){if(!this.mask)return;const[e,t,n,i]=this.calculateMaskBBox();Object.assign(this.mask.style,{top:t+"px",left:e+"px",width:n+"px",height:i+"px"})}destroy(){var e,t,n;this.unbindEvents(),(e=this.canvas)===null||e===void 0||e.destroy(),(t=this.mask)===null||t===void 0||t.remove(),(n=this.container)===null||n===void 0||n.remove(),super.destroy()}}ff.defaultOptions={size:[240,160],shape:"key",padding:10,position:"right-bottom",maskStyle:{border:"1px solid #ddd",background:"rgba(0, 0, 0, 0.1)"},containerStyle:{border:"1px solid #ddd",background:"#fff"},delay:128};const xa=(r,e)=>Math.min(r,e),Ca=(r,e)=>Math.max(r,e);var Aw=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};const lw={x1:0,y1:0,x2:0,y2:0,visibility:"hidden"};class gf extends Ln{constructor(e,t){super(e,Object.assign({},gf.defaultOptions,t)),this.initSnapline=()=>{const n=this.context.canvas.getLayer("transient");this.horizontalLine||(this.horizontalLine=n.appendChild(new Ks({style:Object.assign(Object.assign({},lw),this.options.horizontalLineStyle)}))),this.verticalLine||(this.verticalLine=n.appendChild(new Ks({style:Object.assign(Object.assign({},lw),this.options.verticalLineStyle)})))},this.isHorizontalSticking=!1,this.isVerticalSticking=!1,this.enableStick=!0,this.autoSnapToLine=(n,i,a)=>Aw(this,void 0,void 0,function*(){const{verticalX:s,horizontalY:o}=a,{tolerance:A}=this.options,{min:[l,c],max:[u,h],center:[d,f]}=i;let g=0,v=0;s!==null&&(Xn(u,s)<A&&(g=s-u),Xn(l,s)<A&&(g=s-l),Xn(d,s)<A&&(g=s-d),g!==0&&(this.isVerticalSticking=!0)),o!==null&&(Xn(h,o)<A&&(v=o-h),Xn(c,o)<A&&(v=o-c),Xn(f,o)<A&&(v=o-f),v!==0&&(this.isHorizontalSticking=!0)),(g!==0||v!==0)&&(yield this.context.graph.translateElementBy({[n]:[g,v]},!1))}),this.enableSnap=n=>{const{target:i}=n,a=.5;if(this.isHorizontalSticking||this.isVerticalSticking){const[s,o]=this.getDelta(n);if(this.isHorizontalSticking&&this.isVerticalSticking&&Math.abs(s)<=a&&Math.abs(o)<=a)return this.context.graph.translateElementBy({[i.id]:[-s,-o]},!1),!1;if(this.isHorizontalSticking&&Math.abs(o)<=a)return this.context.graph.translateElementBy({[i.id]:[0,-o]},!1),!1;if(this.isVerticalSticking&&Math.abs(s)<=a)return this.context.graph.translateElementBy({[i.id]:[-s,0]},!1),!1;this.isHorizontalSticking=!1,this.isVerticalSticking=!1,this.enableStick=!1,setTimeout(()=>{this.enableStick=!0},200)}return this.enableStick},this.calcSnaplineMetadata=(n,i)=>{const{tolerance:a,shape:s}=this.options,{min:[o,A],max:[l,c],center:[u,h]}=i;let d=null,f=null,g=null,v=null,p=null,y=null;return this.getNodes().some(m=>{if(Xt(n.id,m.id))return!1;const B=WO(m,s).getRenderBounds(),{min:[C,S],max:[F,T],center:[O,_]}=B;return d===null&&(Xn(O,u)<a?d=O:Xn(C,o)<a||Xn(C,l)<a?d=C:(Xn(F,l)<a||Xn(F,o)<a)&&(d=F),d!==null&&(f=Math.min(S,A),g=Math.max(T,c))),v===null&&(Xn(_,h)<a?v=_:Xn(S,A)<a||Xn(S,c)<a?v=S:(Xn(T,c)<a||Xn(T,A)<a)&&(v=T),v!==null&&(p=Math.min(C,o),y=Math.max(F,l))),d!==null&&v!==null}),{verticalX:d,verticalMinY:f,verticalMaxY:g,horizontalY:v,horizontalMinX:p,horizontalMaxX:y}},this.onDragStart=()=>{this.initSnapline()},this.onDrag=n=>Aw(this,void 0,void 0,function*(){const{target:i}=n;if(this.options.autoSnap&&!this.enableSnap(n))return;const a=WO(i,this.options.shape).getRenderBounds(),s=this.calcSnaplineMetadata(i,a);this.hideSnapline(),(s.verticalX!==null||s.horizontalY!==null)&&this.updateSnapline(s),this.options.autoSnap&&(yield this.autoSnapToLine(i.id,a,s))}),this.onDragEnd=()=>{this.hideSnapline()},this.bindEvents()}getNodes(){var e;const{filter:t}=this.options,i=(((e=this.context.element)===null||e===void 0?void 0:e.getNodes())||[]).filter(a=>{var s;return GL(a)&&((s=this.context.viewport)===null||s===void 0?void 0:s.isInViewport(a.getRenderBounds()))});return t?i.filter(a=>t(a)):i}hideSnapline(){this.horizontalLine.style.visibility="hidden",this.verticalLine.style.visibility="hidden"}getLineWidth(e){const{lineWidth:t}=this.options[`${e}LineStyle`];return+(t||lw.lineWidth||1)/this.context.graph.getZoom()}updateSnapline(e){const{verticalX:t,verticalMinY:n,verticalMaxY:i,horizontalY:a,horizontalMinX:s,horizontalMaxX:o}=e,[A,l]=this.context.canvas.getSize(),{offset:c}=this.options;a!==null?Object.assign(this.horizontalLine.style,{x1:c===1/0?0:s-c,y1:a,x2:c===1/0?A:o+c,y2:a,visibility:"visible",lineWidth:this.getLineWidth("horizontal")}):this.horizontalLine.style.visibility="hidden",t!==null?Object.assign(this.verticalLine.style,{x1:t,y1:c===1/0?0:n-c,x2:t,y2:c===1/0?l:i+c,visibility:"visible",lineWidth:this.getLineWidth("vertical")}):this.verticalLine.style.visibility="hidden"}getDelta(e){const t=this.context.graph.getZoom();return Bi([e.dx,e.dy],t)}bindEvents(){return Aw(this,void 0,void 0,function*(){const{graph:e}=this.context;e.on(ti.DRAG_START,this.onDragStart),e.on(ti.DRAG,this.onDrag),e.on(ti.DRAG_END,this.onDragEnd)})}unbindEvents(){const{graph:e}=this.context;e.off(ti.DRAG_START,this.onDragStart),e.off(ti.DRAG,this.onDrag),e.off(ti.DRAG_END,this.onDragEnd)}destroyElements(){var e,t;(e=this.horizontalLine)===null||e===void 0||e.destroy(),(t=this.verticalLine)===null||t===void 0||t.destroy()}destroy(){this.destroyElements(),this.unbindEvents(),super.destroy()}}gf.defaultOptions={tolerance:5,offset:20,autoSnap:!0,shape:"key",verticalLineStyle:{stroke:"#1783FF"},horizontalLineStyle:{stroke:"#1783FF"},filter:()=>!0};const Xn=(r,e)=>Math.abs(r-e),WO=(r,e)=>typeof e=="function"?e(r):r.getShape(e);var pae=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})},yae=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};const mae=["timestamp","time","date","datetime"];class vf extends Ln{get padding(){return ai(this.options.padding)}constructor(e,t){super(e,Object.assign({},vf.defaultOptions,t)),this.backup(),this.upsertTimebar()}play(){var e;(e=this.timebar)===null||e===void 0||e.play()}pause(){var e;(e=this.timebar)===null||e===void 0||e.pause()}forward(){var e;(e=this.timebar)===null||e===void 0||e.forward()}backward(){var e;(e=this.timebar)===null||e===void 0||e.backward()}reset(){var e;(e=this.timebar)===null||e===void 0||e.reset()}update(e){super.update(e),this.backup(),this.upsertTimebar()}backup(){this.originalData=qO(this.context.graph.getData())}upsertTimebar(){const{canvas:e}=this.context,t=this.options,{onChange:n,timebarType:i,data:a,x:s,y:o,width:A,height:l,mode:c}=t,u=yae(t,["onChange","timebarType","data","x","y","width","height","mode"]),h=e.getSize(),[d]=this.padding;this.upsertCanvas().ready.then(()=>{var f;const g=Object.assign(Object.assign({x:h[0]/2-A/2,y:d,onChange:v=>{const p=(Mr(v)?v:[v,v]).map(y=>yR(y)?y.getTime():y);this.options.mode==="modify"?this.filterElements(p):this.hiddenElements(p),n==null||n(p)}},u),{data:a.map(v=>Be(v)?{time:v,value:0}:v),width:A,height:l,type:i});this.timebar?this.timebar.update(g):(this.timebar=new dae({style:g}),(f=this.canvas)===null||f===void 0||f.appendChild(this.timebar))})}upsertCanvas(){if(this.canvas)return this.canvas;const{className:e,height:t,position:n}=this.options,i=this.context.canvas,[a]=i.getSize(),[s,,o]=this.padding,[A,l]=hf({width:a,height:t+s+o,graphCanvas:i,className:"timebar",placement:n});return this.container=A,e&&A.classList.add(e),this.canvas=l,this.canvas}filterElements(e){return pae(this,void 0,void 0,function*(){var t;if(!this.originalData)return;const{elementTypes:n,getTime:i}=this.options,{graph:a,element:s}=this.context,o=qO(this.originalData);n.forEach(l=>{const c=`${l}s`;o[c]=(this.originalData[c]||[]).filter(u=>{const h=i(u);return!!$O(h,e)})});const A=[...o.nodes,...o.combos].map(l=>Z(l));o.edges=o.edges.filter(l=>{const c=l.source,u=l.target;return A.includes(c)&&A.includes(u)}),a.setData(o),yield(t=s.draw({animation:!1,silence:!0}))===null||t===void 0?void 0:t.finished})}hiddenElements(e){const{graph:t}=this.context,{elementTypes:n,getTime:i}=this.options,a=[],s=[];n.forEach(o=>{var A;const l=`${o}s`;(((A=this.originalData)===null||A===void 0?void 0:A[l])||[]).forEach(u=>{const h=Z(u),d=i(u);$O(d,e)?s.push(h):a.push(h)})}),t.hideElement(a,!1),t.showElement(s,!1)}destroy(){var e,t,n;const{graph:i}=this.context;this.originalData&&i.setData(Object.assign({},this.originalData)),(e=this.timebar)===null||e===void 0||e.destroy(),(t=this.canvas)===null||t===void 0||t.destroy(),(n=this.container)===null||n===void 0||n.remove(),this.originalData=void 0,this.container=void 0,this.timebar=void 0,this.canvas=void 0,super.destroy()}}vf.defaultOptions={position:"bottom",enable:!0,timebarType:"time",className:"g6-timebar",width:450,height:60,zIndex:3,elementTypes:["node"],padding:10,mode:"modify",getTime:r=>wae(r,mae,void 0),loop:!1};const qO=r=>{const{nodes:e=[],edges:t=[],combos:n=[]}=r;return{nodes:[...e],edges:[...t],combos:[...n]}},$O=(r,e)=>{if(Be(e))return r===e;const[t,n]=e;return r>=t&&r<=n},wae=(r,e,t)=>{var n;for(let i=0;i<e.length;i++){const a=e[i],s=(n=r.data)===null||n===void 0?void 0:n[a];if(s)return s}return t};var Bae=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};const CU={fill:"#1D2129",wordWrap:!0,maxLines:1,textOverflow:"ellipsis",textBaseline:"top",textAlign:"start",x:0},bae=Object.assign(Object.assign({},CU),{fillOpacity:.9,fontSize:16,fontWeight:"bold"}),Eae=Object.assign(Object.assign({},CU),{fillOpacity:.65,fontSize:12,fontWeight:"normal"}),xae={align:"left",spacing:8,size:44,padding:[16,24,0,24]},cw="title",YO="subtitle";class Cae extends Ln{get padding(){return ai(this.options.padding)}constructor(e,t){const n=Object.assign({},xae,t);super(e,n),this.onRender=()=>{const i=this.updateCanvas();this.renderTitle(i)},this.bindEvents()}bindEvents(){const{graph:e}=this.context;e.on(ge.AFTER_RENDER,this.onRender),e.on(ge.AFTER_ANIMATE,this.onRender)}unbindEvents(){const{graph:e}=this.context;e.off(ge.AFTER_RENDER,this.onRender),e.off(ge.AFTER_ANIMATE,this.onRender)}destroy(){var e,t;this.unbindEvents(),(e=this.canvas)===null||e===void 0||e.destroy(),(t=this.container)===null||t===void 0||t.remove(),super.destroy()}updateCanvas(){const{size:e,className:t,align:n}=this.options,[i]=this.context.canvas.getSize(),[a=0,,s=0]=this.padding,o=e+a+s;if(this.canvas){const{width:A,height:l}=this.canvas.getConfig();(i!==A||o!==l)&&this.canvas.resize(i,o)}else{const A={left:"left-top",center:"top",right:"right-top"},[l,c]=hf({width:i,height:o,placement:A[n]||A.left,className:"title-canvas",graphCanvas:this.context.canvas});t&&l.classList.add(t),this.container=l,this.canvas=c}return this.canvas}renderTitle(e){const t=new Sae({options:this.options,ctx:this.context});e.removeChildren(),t.getTitle().forEach(n=>{n&&e.appendChild(n)})}}class Sae{get padding(){return ai(this.options.padding)}constructor(e){const{options:t,ctx:n}=e;this.options=t,this.context=n}getTitle(){const e=this.options,t=cw,n=e[t],i=YO,a=e[i],{spacing:s=44,padding:o,align:A}=e,l=Bae(e,[t+"",i+"","spacing","padding","align"]),c=n,u=a,h=tn(l,cw),d=tn(l,YO),[f]=this.context.graph.getSize(),[g=0,v=0,,p=0]=this.padding,y=f,m=y-p-v;let B=null,C=p,S="left";switch(A){case"left":C=p,S="left";break;case"center":C=y/2,S="center";break;case"right":C=y-v,S="right";break;default:C=p,S="left"}const F=new ji({className:cw,style:Object.assign(Object.assign(Object.assign(Object.assign({},bae),{wordWrapWidth:m-5,x:C,y:g,textAlign:S}),h),{text:c})}),T=F.getBBox();return u&&(B=new ji({className:"subTitle",style:Object.assign(Object.assign(Object.assign(Object.assign({},Eae),{wordWrapWidth:m-5,x:C,y:T.height+s+g,textAlign:S}),d),{text:u})})),[F,B]}}function Fae(r){const e={top:"unset",right:"unset",bottom:"unset",left:"unset"};return r.split("-").forEach(n=>{e[n]="8px"}),e.flexDirection=r.startsWith("top")||r.startsWith("bottom")?"row":"column",e}const Tae=`
|
|
63
|
+
.g6-toolbar {
|
|
64
|
+
position: absolute;
|
|
65
|
+
z-index: 100;
|
|
66
|
+
display: flex;
|
|
67
|
+
flex-direction: row;
|
|
68
|
+
align-items: center;
|
|
69
|
+
justify-content: center;
|
|
70
|
+
border-radius: 4px;
|
|
71
|
+
box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.1);
|
|
72
|
+
opacity: 0.65;
|
|
73
|
+
}
|
|
74
|
+
.g6-toolbar .g6-toolbar-item {
|
|
75
|
+
display: inline-block;
|
|
76
|
+
width: 16px;
|
|
77
|
+
height: 16px;
|
|
78
|
+
padding: 4px;
|
|
79
|
+
cursor: pointer;
|
|
80
|
+
box-sizing: content-box;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
.g6-toolbar .g6-toolbar-item:hover {
|
|
84
|
+
background-color: #f0f0f0;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
.g6-toolbar .g6-toolbar-item svg {
|
|
88
|
+
display: inline-block;
|
|
89
|
+
width: 100%;
|
|
90
|
+
height: 100%;
|
|
91
|
+
pointer-events: none;
|
|
92
|
+
}
|
|
93
|
+
`,Mae=`
|
|
94
|
+
<svg>
|
|
95
|
+
<symbol id="zoom-in" viewBox="64 64 896 896">
|
|
96
|
+
<path d="M637 443H519V309c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v134H325c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h118v134c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V519h118c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zm284 424L775 721c122.1-148.9 113.6-369.5-26-509-148-148.1-388.4-148.1-537 0-148.1 148.6-148.1 389 0 537 139.5 139.6 360.1 148.1 509 26l146 146c3.2 2.8 8.3 2.8 11 0l43-43c2.8-2.7 2.8-7.8 0-11zM696 696c-118.8 118.7-311.2 118.7-430 0-118.7-118.8-118.7-311.2 0-430 118.8-118.7 311.2-118.7 430 0 118.7 118.8 118.7 311.2 0 430z"></path>
|
|
97
|
+
</symbol>
|
|
98
|
+
<symbol id="zoom-out" viewBox="64 64 896 896">
|
|
99
|
+
<path d="M637 443H325c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h312c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zm284 424L775 721c122.1-148.9 113.6-369.5-26-509-148-148.1-388.4-148.1-537 0-148.1 148.6-148.1 389 0 537 139.5 139.6 360.1 148.1 509 26l146 146c3.2 2.8 8.3 2.8 11 0l43-43c2.8-2.7 2.8-7.8 0-11zM696 696c-118.8 118.7-311.2 118.7-430 0-118.7-118.8-118.7-311.2 0-430 118.8-118.7 311.2-118.7 430 0 118.7 118.8 118.7 311.2 0 430z"></path>
|
|
100
|
+
</symbol>
|
|
101
|
+
<symbol id="edit" viewBox="64 64 896 896">
|
|
102
|
+
<path d="M257.7 752c2 0 4-.2 6-.5L431.9 722c2-.4 3.9-1.3 5.3-2.8l423.9-423.9a9.96 9.96 0 000-14.1L694.9 114.9c-1.9-1.9-4.4-2.9-7.1-2.9s-5.2 1-7.1 2.9L256.8 538.8c-1.5 1.5-2.4 3.3-2.8 5.3l-29.5 168.2a33.5 33.5 0 009.4 29.8c6.6 6.4 14.9 9.9 23.8 9.9zm67.4-174.4L687.8 215l73.3 73.3-362.7 362.6-88.9 15.7 15.6-89zM880 836H144c-17.7 0-32 14.3-32 32v36c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-36c0-17.7-14.3-32-32-32z"></path>
|
|
103
|
+
</symbol>
|
|
104
|
+
<symbol id="delete" viewBox="64 64 896 896">
|
|
105
|
+
<path d="M360 184h-8c4.4 0 8-3.6 8-8v8h304v-8c0 4.4 3.6 8 8 8h-8v72h72v-80c0-35.3-28.7-64-64-64H352c-35.3 0-64 28.7-64 64v80h72v-72zm504 72H160c-17.7 0-32 14.3-32 32v32c0 4.4 3.6 8 8 8h60.4l24.7 523c1.6 34.1 29.8 61 63.9 61h454c34.2 0 62.3-26.8 63.9-61l24.7-523H888c4.4 0 8-3.6 8-8v-32c0-17.7-14.3-32-32-32zM731.3 840H292.7l-24.2-512h487l-24.2 512z"></path>
|
|
106
|
+
</symbol>
|
|
107
|
+
<symbol id="redo" viewBox="64 64 896 896">
|
|
108
|
+
<path d="M758.2 839.1C851.8 765.9 912 651.9 912 523.9 912 303 733.5 124.3 512.6 124 291.4 123.7 112 302.8 112 523.9c0 125.2 57.5 236.9 147.6 310.2 3.5 2.8 8.6 2.2 11.4-1.3l39.4-50.5c2.7-3.4 2.1-8.3-1.2-11.1-8.1-6.6-15.9-13.7-23.4-21.2a318.64 318.64 0 01-68.6-101.7C200.4 609 192 567.1 192 523.9s8.4-85.1 25.1-124.5c16.1-38.1 39.2-72.3 68.6-101.7 29.4-29.4 63.6-52.5 101.7-68.6C426.9 212.4 468.8 204 512 204s85.1 8.4 124.5 25.1c38.1 16.1 72.3 39.2 101.7 68.6 29.4 29.4 52.5 63.6 68.6 101.7 16.7 39.4 25.1 81.3 25.1 124.5s-8.4 85.1-25.1 124.5a318.64 318.64 0 01-68.6 101.7c-9.3 9.3-19.1 18-29.3 26L668.2 724a8 8 0 00-14.1 3l-39.6 162.2c-1.2 5 2.6 9.9 7.7 9.9l167 .8c6.7 0 10.5-7.7 6.3-12.9l-37.3-47.9z"></path>
|
|
109
|
+
</symbol>
|
|
110
|
+
<symbol id="undo" viewBox="64 64 896 896">
|
|
111
|
+
<path d="M511.4 124C290.5 124.3 112 303 112 523.9c0 128 60.2 242 153.8 315.2l-37.5 48c-4.1 5.3-.3 13 6.3 12.9l167-.8c5.2 0 9-4.9 7.7-9.9L369.8 727a8 8 0 00-14.1-3L315 776.1c-10.2-8-20-16.7-29.3-26a318.64 318.64 0 01-68.6-101.7C200.4 609 192 567.1 192 523.9s8.4-85.1 25.1-124.5c16.1-38.1 39.2-72.3 68.6-101.7 29.4-29.4 63.6-52.5 101.7-68.6C426.9 212.4 468.8 204 512 204s85.1 8.4 124.5 25.1c38.1 16.1 72.3 39.2 101.7 68.6 29.4 29.4 52.5 63.6 68.6 101.7 16.7 39.4 25.1 81.3 25.1 124.5s-8.4 85.1-25.1 124.5a318.64 318.64 0 01-68.6 101.7c-7.5 7.5-15.3 14.5-23.4 21.2a7.93 7.93 0 00-1.2 11.1l39.4 50.5c2.8 3.5 7.9 4.1 11.4 1.3C854.5 760.8 912 649.1 912 523.9c0-221.1-179.4-400.2-400.6-399.9z"></path>
|
|
112
|
+
</symbol>
|
|
113
|
+
<symbol id="export" viewBox="64 64 896 896">
|
|
114
|
+
<path d="M880 912H144c-17.7 0-32-14.3-32-32V144c0-17.7 14.3-32 32-32h360c4.4 0 8 3.6 8 8v56c0 4.4-3.6 8-8 8H184v656h656V520c0-4.4 3.6-8 8-8h56c4.4 0 8 3.6 8 8v360c0 17.7-14.3 32-32 32zM770.87 199.13l-52.2-52.2a8.01 8.01 0 014.7-13.6l179.4-21c5.1-.6 9.5 3.7 8.9 8.9l-21 179.4c-.8 6.6-8.9 9.4-13.6 4.7l-52.4-52.4-256.2 256.2a8.03 8.03 0 01-11.3 0l-42.4-42.4a8.03 8.03 0 010-11.3l256.1-256.3z"></path>
|
|
115
|
+
</symbol>
|
|
116
|
+
<symbol id="auto-fit" viewBox="64 64 896 896">
|
|
117
|
+
<path d="M952 474H829.8C812.5 327.6 696.4 211.5 550 194.2V72c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v122.2C327.6 211.5 211.5 327.6 194.2 474H72c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h122.2C211.5 696.4 327.6 812.5 474 829.8V952c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V829.8C696.4 812.5 812.5 696.4 829.8 550H952c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zM512 756c-134.8 0-244-109.2-244-244s109.2-244 244-244 244 109.2 244 244-109.2 244-244 244z"></path>
|
|
118
|
+
<path d="M512 392c-32.1 0-62.1 12.4-84.8 35.2-22.7 22.7-35.2 52.7-35.2 84.8s12.5 62.1 35.2 84.8C449.9 619.4 480 632 512 632s62.1-12.5 84.8-35.2C619.4 574.1 632 544 632 512s-12.5-62.1-35.2-84.8A118.57 118.57 0 00512 392z"></path>
|
|
119
|
+
</symbol>
|
|
120
|
+
<symbol id="reset" viewBox="64 64 896 896">
|
|
121
|
+
<path d="M909.1 209.3l-56.4 44.1C775.8 155.1 656.2 92 521.9 92 290 92 102.3 279.5 102 511.5 101.7 743.7 289.8 932 521.9 932c181.3 0 335.8-115 394.6-276.1 1.5-4.2-.7-8.9-4.9-10.3l-56.7-19.5a8 8 0 00-10.1 4.8c-1.8 5-3.8 10-5.9 14.9-17.3 41-42.1 77.8-73.7 109.4A344.77 344.77 0 01655.9 829c-42.3 17.9-87.4 27-133.8 27-46.5 0-91.5-9.1-133.8-27A341.5 341.5 0 01279 755.2a342.16 342.16 0 01-73.7-109.4c-17.9-42.4-27-87.4-27-133.9s9.1-91.5 27-133.9c17.3-41 42.1-77.8 73.7-109.4 31.6-31.6 68.4-56.4 109.3-73.8 42.3-17.9 87.4-27 133.8-27 46.5 0 91.5 9.1 133.8 27a341.5 341.5 0 01109.3 73.8c9.9 9.9 19.2 20.4 27.8 31.4l-60.2 47a8 8 0 003 14.1l175.6 43c5 1.2 9.9-2.6 9.9-7.7l.8-180.9c-.1-6.6-7.8-10.3-13-6.2z"></path>
|
|
122
|
+
</symbol>
|
|
123
|
+
<symbol id="exit-fullscreen" viewBox="0 0 1024 1024">
|
|
124
|
+
<path d="M418.13333333 361.43786666c0 0.2048-0.13653333 0.4096-0.13653334 0.68266667C417.99679999 362.32533333 418.13333333 362.53013333 418.13333333 362.73493333 418.13333333 371.54133333 414.44693333 379.392 408.78079999 385.39946666 408.43946666 385.7408 408.30293333 386.21866666 408.02986666 386.49173333c-1.09226667 1.09226667-2.59413333 1.77493333-3.82293333 2.73066667C398.40426666 393.65973333 391.64586666 396.8 383.93173333 396.8 383.72693333 396.8 383.59039999 396.73173333 383.38559999 396.73173333S382.97599999 396.8 382.77119999 396.8L112.29866666 396.8C92.50133333 396.8 76.79999999 381.50826666 76.79999999 362.66666666 76.66346666 343.89333333 92.63786666 328.53333333 112.16213333 328.53333333l189.44 0L87.44959999 114.51733333C73.59146666 100.59093333 73.25013333 78.5408 86.63039999 65.29706666c13.17546667-13.44853333 35.36213333-12.97066667 49.152 0.88746667l214.08426667 214.08426667L349.86666666 90.89706666C349.79839999 71.23626666 365.22666666 55.46666666 383.99999999 55.46666666 402.77333333 55.33013333 418.13333333 71.30453333 418.13333333 90.8288L418.13333333 361.43786666zM928.90453333 328.53333333l-189.44 0 214.15253333-214.08426667c13.85813333-13.9264 14.19946667-35.90826667 0.88746667-49.22026666-13.17546667-13.44853333-35.36213333-12.97066667-49.152 0.88746666l-214.08426667 214.08426667L691.26826666 90.89706666C691.26826666 71.23626666 675.83999999 55.46666666 657.06666666 55.46666666 638.29333333 55.33013333 622.93333333 71.30453333 622.93333333 90.8288l0 270.60906666c0 0.2048 0.13653333 0.4096 0.13653333 0.68266667C623.06986666 362.32533333 622.93333333 362.53013333 622.93333333 362.73493333 622.93333333 371.54133333 626.61973333 379.392 632.28586666 385.39946666c0.34133333 0.34133333 0.47786667 0.8192 0.8192 1.09226667 1.09226667 1.09226667 2.59413333 1.77493333 3.8912 2.73066667C642.66239999 393.65973333 649.42079999 396.8 657.13493333 396.8c0.2048 0 0.34133333-0.06826667 0.54613333-0.06826667S658.09066666 396.8 658.29546666 396.8l270.5408 0C948.56533333 396.8 964.26666666 381.50826666 964.26666666 362.66666666 964.40319999 343.89333333 948.42879999 328.53333333 928.90453333 328.53333333zM418.13333333 635.73333333c0-8.8064-3.6864-16.5888-9.35253334-22.66453333C408.43946666 612.72746666 408.30293333 612.2496 408.02986666 611.90826666 406.86933333 610.88426666 405.43573333 610.2016 404.20693333 609.24586666 398.47253333 604.80853333 391.64586666 601.6 383.93173333 601.6 383.72693333 601.6 383.59039999 601.73653333 383.38559999 601.73653333S382.97599999 601.6 382.77119999 601.6L112.29866666 601.6C92.50133333 601.6 76.79999999 616.96 76.79999999 635.73333333 76.66346666 654.50666666 92.63786666 669.86666666 112.16213333 669.86666666l189.44 0-214.15253334 214.15253334c-13.85813333 13.85813333-14.19946667 35.84-0.88746666 49.22026666 13.17546667 13.44853333 35.36213333 12.9024 49.152-0.95573333l214.08426666-214.08426667 0 189.37173334c0 19.59253333 15.42826667 35.49866667 34.2016 35.36213333C402.77333333 943.2064 418.13333333 927.232 418.13333333 907.5712L418.13333333 637.09866666c0-0.27306667-0.13653333-0.47786667-0.13653334-0.68266666C417.99679999 636.14293333 418.13333333 635.93813333 418.13333333 635.73333333zM739.46453333 669.86666666l189.44 0c19.456 0 35.49866667-15.36 35.36213333-34.13333333C964.26666666 616.96 948.56533333 601.6 928.76799999 601.6L658.29546666 601.6C658.09066666 601.6 657.88586666 601.73653333 657.68106666 601.73653333S657.33973333 601.6 657.13493333 601.6C649.42079999 601.6 642.59413333 604.80853333 636.85973333 609.24586666 635.63093333 610.2016 634.19733333 610.88426666 633.03679999 611.90826666 632.76373333 612.2496 632.62719999 612.72746666 632.28586666 613.0688 626.61973333 619.14453333 622.93333333 626.92693333 622.93333333 635.73333333c0 0.2048 0.13653333 0.4096 0.13653333 0.68266667C623.06986666 636.6208 622.93333333 636.8256 622.93333333 637.09866666l0 270.5408C622.93333333 927.232 638.29333333 943.2064 657.06666666 942.93333333c18.77333333 0.13653333 34.2016-15.70133333 34.2016-35.36213333l0-189.37173334 214.08426667 214.08426667c13.78986667 13.85813333 35.90826667 14.40426667 49.152 0.95573333 13.312-13.312 12.97066667-35.36213333-0.88746667-49.22026666L739.46453333 669.86666666z" ></path></symbol>
|
|
125
|
+
<symbol id="request-fullscreen" viewBox="0 0 1024 1024">
|
|
126
|
+
<path d="M69.818182 87.598545v273.128728a34.909091 34.909091 0 0 0 69.818182 0V163.653818l221.928727 222.021818a33.512727 33.512727 0 0 0 47.383273-47.383272L186.926545 116.363636h197.073455a34.909091 34.909091 0 0 0 0-69.818181H110.871273C85.364364 46.545455 69.818182 59.671273 69.818182 87.598545zM938.542545 46.545455H665.413818a34.909091 34.909091 0 0 0 0 69.818181h197.073455L640.465455 338.292364a33.512727 33.512727 0 0 0 47.383272 47.383272l221.928728-222.021818v197.073455a34.909091 34.909091 0 0 0 69.818181 0V87.598545c0-27.927273-15.453091-41.053091-40.96-41.05309z m-827.671272 907.636363h273.128727a34.909091 34.909091 0 0 0 0-69.818182H186.926545l222.021819-221.928727a33.512727 33.512727 0 0 0-47.383273-47.383273L139.636364 837.073455V640a34.909091 34.909091 0 0 0-69.818182 0v273.128727c0 27.927273 15.546182 41.053091 41.053091 41.053091z m868.724363-41.053091V640a34.909091 34.909091 0 0 0-69.818181 0v197.073455L687.941818 615.051636a33.512727 33.512727 0 0 0-47.383273 47.383273L862.487273 884.363636H665.413818a34.909091 34.909091 0 0 0 0 69.818182h273.128727c25.6 0 41.053091-13.125818 41.053091-41.053091z" ></path></symbol>
|
|
127
|
+
</svg>
|
|
128
|
+
`;var XO=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class pf extends Ln{constructor(e,t){super(e,Object.assign({},pf.defaultOptions,t)),this.$element=sA("toolbar",!1),this.onToolbarItemClick=i=>{const{onClick:a}=this.options;if(i.target instanceof Element&&i.target.className.includes("g6-toolbar-item")){const s=i.target.getAttribute("value");a==null||a(s,i.target)}};const n=this.context.canvas.getContainer();this.$element.style.display="flex",n.appendChild(this.$element),S1("g6-toolbar-css","style",{},Tae,document.head),S1("g6-toolbar-svgicon","div",{display:"none"},Mae),this.$element.addEventListener("click",this.onToolbarItemClick),this.update(t)}update(e){const t=Object.create(null,{update:{get:()=>super.update}});return XO(this,void 0,void 0,function*(){t.update.call(this,e);const{className:n,position:i,style:a}=this.options;this.$element.className=`g6-toolbar ${n||""}`,Object.assign(this.$element.style,a,Fae(i)),this.$element.innerHTML=yield this.getDOMContent()})}destroy(){this.$element.removeEventListener("click",this.onToolbarItemClick),this.$element.remove(),super.destroy()}getDOMContent(){return XO(this,void 0,void 0,function*(){return(yield this.options.getItems()).map(t=>{var n;return`
|
|
129
|
+
<div class="g6-toolbar-item" value="${t.value}" title="${(n=t.title)!==null&&n!==void 0?n:""}">
|
|
130
|
+
<svg aria-hidden="true" focusable="false">
|
|
131
|
+
<use xlink:href="#${t.id}"></use>
|
|
132
|
+
</svg>
|
|
133
|
+
</div>`}).join("")})}}pf.defaultOptions={position:"top-left"};var ZO=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class yf extends Ln{constructor(e,t){super(e,Object.assign({},yf.defaultOptions,t)),this.currentTarget=null,this.tooltipElement=null,this.container=null,this.isEnable=(n,i)=>{const{enable:a}=this.options;return typeof a=="function"?a(n,i):a},this.onClick=n=>{const{target:{id:i}}=n;this.currentTarget===i?this.hide(n):this.show(n)},this.onPointerMove=n=>{const{target:i}=n;!this.currentTarget||i.id===this.currentTarget||this.show(n)},this.onPointerLeave=n=>{this.hide(n)},this.onCanvasMove=n=>{this.hide(n)},this.onPointerOver=n=>{this.show(n)},this.showById=n=>ZO(this,void 0,void 0,function*(){const i={target:{id:n}};yield this.show(i)}),this.getElementData=(n,i)=>{const{model:a}=this.context;switch(i){case"node":return a.getNodeData([n]);case"edge":return a.getEdgeData([n]);case"combo":return a.getComboData([n]);default:return[]}},this.show=n=>ZO(this,void 0,void 0,function*(){var i,a;const{client:s,target:{id:o}}=n;if(Gl(n.target))return;const A=this.context.graph.getElementType(o),{getContent:l,title:c}=this.options,u=this.getElementData(o,A);if(!this.tooltipElement)return;if(!this.isEnable(n,u)){this.hide(n);return}let h={};if(l){if(h.content=yield l(n,u),!h.content)return}else{const g=this.context.graph.getElementRenderStyle(o),v=A==="node"?g.fill:g.stroke;h={title:c||A,data:u.map(p=>({name:"ID",value:p.id||`${p.source} -> ${p.target}`,color:v}))}}this.currentTarget=o;let d,f;if(s)d=s.x,f=s.y;else{const g=Rn(u,"0.style",{x:0,y:0});d=g.x,f=g.y}(a=(i=this.options).onOpenChange)===null||a===void 0||a.call(i,!0),this.tooltipElement.update(Object.assign(Object.assign(Object.assign({},this.tooltipStyleProps),{x:d,y:f,style:{".tooltip":{visibility:"visible"}}}),h))}),this.hide=n=>{var i,a,s,o,A;if(!n){(a=(i=this.options).onOpenChange)===null||a===void 0||a.call(i,!1),(s=this.tooltipElement)===null||s===void 0||s.hide(),this.currentTarget=null;return}if(!this.tooltipElement||!this.currentTarget)return;const{client:{x:l,y:c}}=n;(A=(o=this.options).onOpenChange)===null||A===void 0||A.call(o,!1),this.tooltipElement.hide(l,c),this.currentTarget=null},this.initTooltip=()=>{var n;const i=new qie({className:"tooltip",style:this.tooltipStyleProps});return(n=this.container)===null||n===void 0||n.appendChild(i.HTMLTooltipElement),i},this.render(),this.bindEvents()}getEvents(){return this.options.trigger==="click"?{"node:click":this.onClick,"edge:click":this.onClick,"combo:click":this.onClick,"canvas:click":this.onPointerLeave,contextmenu:this.onPointerLeave,drag:this.onPointerLeave}:{"node:pointerover":this.onPointerOver,"node:pointermove":this.onPointerMove,"canvas:pointermove":this.onCanvasMove,"edge:pointerover":this.onPointerOver,"edge:pointermove":this.onPointerMove,"combo:pointerover":this.onPointerOver,"combo:pointermove":this.onPointerMove,contextmenu:this.onPointerLeave,"node:drag":this.onPointerLeave}}update(e){var t;this.unbindEvents(),super.update(e),this.tooltipElement&&((t=this.container)===null||t===void 0||t.removeChild(this.tooltipElement.HTMLTooltipElement)),this.tooltipElement=this.initTooltip(),this.bindEvents()}render(){const{canvas:e}=this.context,t=e.getContainer();t&&(this.container=t,this.tooltipElement=this.initTooltip())}unbindEvents(){const{graph:e}=this.context,t=this.getEvents();Object.keys(t).forEach(n=>{e.off(n,t[n])})}bindEvents(){const{graph:e}=this.context,t=this.getEvents();Object.keys(t).forEach(n=>{e.on(n,t[n])})}get tooltipStyleProps(){const{canvas:e}=this.context,{center:t}=e.getBounds(),n=e.getContainer(),{top:i,left:a}=n.getBoundingClientRect(),{style:s,position:o,enterable:A,container:l={x:-a,y:-i},title:c,offset:u}=this.options,[h,d]=t,[f,g]=e.getSize();return{x:h,y:d,container:l,title:c,bounding:{x:0,y:0,width:f,height:g},position:o,enterable:A,offset:u,style:s}}destroy(){var e;this.unbindEvents(),this.tooltipElement&&((e=this.container)===null||e===void 0||e.removeChild(this.tooltipElement.HTMLTooltipElement)),super.destroy()}}yf.defaultOptions={trigger:"hover",position:"top-right",enterable:!1,enable:!0,offset:[10,10],style:{".tooltip":{visibility:"hidden"}}};var SU=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};let mo;function FU(r,e){return mo||(mo=document.createElement("canvas")),mo.width=r,mo.height=e,mo.getContext("2d").clearRect(0,0,r,e),mo}function Oae(r,e,t,n){return SU(this,void 0,void 0,function*(){const i=FU(r,e),a=i.getContext("2d"),{rotate:s,opacity:o,textFill:A,textFontSize:l,textFontFamily:c,textFontVariant:u,textFontWeight:h,textAlign:d,textBaseline:f}=n;return a.textAlign=d,a.textBaseline=f,a.translate(r/2,e/2),a.font=`${l}px ${c} ${u} ${h}`,s&&a.rotate(s),o&&(a.globalAlpha=o),A&&(a.fillStyle=A,a.fillText(`${t}`,0,0)),i.toDataURL()})}function _ae(r,e,t,n){return SU(this,void 0,void 0,function*(){const i=FU(r,e),a=i.getContext("2d"),{rotate:s,opacity:o}=n;s&&a.rotate(s),o&&(a.globalAlpha=o);const A=new Image;return A.crossOrigin="anonymous",A.src=t,new Promise(l=>{A.onload=function(){const c=r>A.width?(r-A.width)/2:0,u=e>A.height?(e-A.height)/2:0;a.drawImage(A,0,0,A.width,A.height,c,u,r-c*2,e-u*2),l(i.toDataURL())}})})}var Iae=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})},kae=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class mf extends Ln{constructor(e,t){super(e,Object.assign({},mf.defaultOptions,t)),this.$element=sA("watermark"),this.context.canvas.getContainer().appendChild(this.$element),this.update(t)}update(e){const t=Object.create(null,{update:{get:()=>super.update}});return Iae(this,void 0,void 0,function*(){t.update.call(this,e);const n=this.options,{width:i,height:a,text:s,imageURL:o}=n,A=kae(n,["width","height","text","imageURL"]);Object.keys(A).forEach(c=>{c.startsWith("background")&&(this.$element.style[c]=e[c])});const l=o?yield _ae(i,a,o,A):yield Oae(i,a,s,A);this.$element.style.backgroundImage=`url(${l})`})}destroy(){super.destroy(),this.$element.remove()}}mf.defaultOptions={width:200,height:100,opacity:.2,rotate:Math.PI/12,text:"",textFill:"#000",textFontSize:16,textAlign:"center",textBaseline:"middle",backgroundRepeat:"repeat"};const Lae=["#7E92B5","#F4664A","#FFBE3A"],Qae={type:"group",color:["#1783FF","#00C9C9","#F08F56","#D580FF","#7863FF","#DB9D0D","#60C42D","#FF80CA","#2491B3","#17C76F"]},Nae={type:"group",color:["#99ADD1","#1783FF","#00C9C9","#F08F56","#D580FF","#7863FF","#DB9D0D","#60C42D","#FF80CA","#2491B3","#17C76F"]};function TU(r){const{bgColor:e,textColor:t,nodeColor:n,nodeColorDisabled:i,nodeStroke:a,nodeHaloStrokeOpacityActive:s=.15,nodeHaloStrokeOpacitySelected:o=.25,nodeOpacityDisabled:A=.06,nodeIconOpacityInactive:l=.85,nodeOpacityInactive:c=.25,nodeBadgePalette:u=Lae,nodePaletteOptions:h=Qae,edgeColor:d,edgeColorDisabled:f,edgePaletteOptions:g=Nae,comboColor:v,comboColorDisabled:p,comboStroke:y,comboStrokeDisabled:m,edgeColorInactive:B}=r;return{background:e,node:{palette:h,style:{donutOpacity:1,badgeBackgroundOpacity:1,badgeFill:"#fff",badgeFontSize:8,badgePadding:[0,4],badgePalette:u,fill:n,fillOpacity:1,halo:!1,iconFill:"#fff",iconOpacity:1,labelBackground:!1,labelBackgroundFill:e,labelBackgroundLineWidth:0,labelBackgroundOpacity:.75,labelFill:t,labelFillOpacity:.85,labelLineHeight:16,labelPadding:[0,2],labelFontSize:12,labelFontWeight:400,labelOpacity:1,labelOffsetY:2,lineWidth:0,portFill:n,portLineWidth:1,portStroke:a,portStrokeOpacity:.65,size:32,stroke:a,strokeOpacity:1,zIndex:2},state:{selected:{halo:!0,haloLineWidth:24,haloStrokeOpacity:o,labelFontSize:12,labelFontWeight:"bold",lineWidth:4,stroke:a},active:{halo:!0,haloLineWidth:12,haloStrokeOpacity:s},highlight:{labelFontWeight:"bold",lineWidth:4,stroke:a,strokeOpacity:.85},inactive:{badgeBackgroundOpacity:c,donutOpacity:c,fillOpacity:c,iconOpacity:l,labelFill:t,labelFillOpacity:c,strokeOpacity:c},disabled:{badgeBackgroundOpacity:.25,donutOpacity:A,fill:i,fillOpacity:A,iconFill:i,iconOpacity:.25,labelFill:t,labelFillOpacity:.25,strokeOpacity:A}},animation:{enter:"fade",exit:"fade",show:"fade",hide:"fade",expand:"node-expand",collapse:"node-collapse",update:[{fields:["x","y","fill","stroke"]}],translate:[{fields:["x","y"]}]}},edge:{palette:g,style:{badgeBackgroundFill:d,badgeFill:"#fff",badgeFontSize:8,badgeOffsetX:10,badgeBackgroundOpacity:1,fillOpacity:1,halo:!1,haloLineWidth:12,haloStrokeOpacity:1,increasedLineWidthForHitTesting:2,labelBackground:!1,labelBackgroundFill:e,labelBackgroundLineWidth:0,labelBackgroundOpacity:.75,labelBackgroundPadding:[4,4,4,4],labelFill:t,labelFontSize:12,labelFontWeight:400,labelOpacity:1,labelPlacement:"center",labelTextBaseline:"middle",lineWidth:1,stroke:d,strokeOpacity:1,zIndex:1},state:{selected:{halo:!0,haloStrokeOpacity:.25,labelFontSize:14,labelFontWeight:"bold",lineWidth:3},active:{halo:!0,haloStrokeOpacity:.15},highlight:{labelFontWeight:"bold",lineWidth:3},inactive:{stroke:B,fillOpacity:.08,labelOpacity:.25,strokeOpacity:.08,badgeBackgroundOpacity:.25},disabled:{stroke:f,fillOpacity:.45,strokeOpacity:.45,labelOpacity:.25,badgeBackgroundOpacity:.45}},animation:{enter:"fade",exit:"fade",expand:"path-in",collapse:"path-out",show:"fade",hide:"fade",update:[{fields:["sourceNode","targetNode"]},{fields:["stroke"],shape:"key"}],translate:[{fields:["sourceNode","targetNode"]}]}},combo:{style:{collapsedMarkerFill:e,collapsedMarkerFontSize:12,collapsedMarkerFillOpacity:1,collapsedSize:32,collapsedFillOpacity:1,fill:v,halo:!1,haloLineWidth:12,haloStroke:y,haloStrokeOpacity:.25,labelBackground:!1,labelBackgroundFill:e,labelBackgroundLineWidth:0,labelBackgroundOpacity:.75,labelBackgroundPadding:[2,4,2,4],labelFill:t,labelFontSize:12,labelFontWeight:400,labelOpacity:1,lineDash:0,lineWidth:1,fillOpacity:.04,strokeOpacity:1,padding:10,stroke:y},state:{selected:{halo:!0,labelFontSize:14,labelFontWeight:700,lineWidth:4},active:{halo:!0},highlight:{labelFontWeight:700,lineWidth:4},inactive:{fillOpacity:.65,labelOpacity:.25,strokeOpacity:.65},disabled:{fill:p,fillOpacity:.25,labelOpacity:.25,stroke:m,strokeOpacity:.25}},animation:{enter:"fade",exit:"fade",show:"fade",hide:"fade",expand:"combo-expand",collapse:"combo-collapse",update:[{fields:["x","y"]},{fields:["fill","stroke","lineWidth"],shape:"key"}],translate:[{fields:["x","y"]}]}}}}const Uae={type:"group",color:["#637088","#0F55A6","#008383","#9C5D38","#8B53A6","#4E40A6","#8F6608","#3E801D","#A65383","#175E75","#0F8248"]},Pae={bgColor:"#000000",comboColor:"#fdfdfd",comboColorDisabled:"#d0e4ff",comboStroke:"#99add1",comboStrokeDisabled:"#969696",edgeColor:"#637088",edgeColorDisabled:"#637088",edgeColorInactive:"#D0E4FF",edgePaletteOptions:Uae,nodeColor:"#1783ff",nodeColorDisabled:"#D0E4FF",nodeHaloStrokeOpacityActive:.25,nodeHaloStrokeOpacitySelected:.45,nodeIconOpacityInactive:.45,nodeOpacityDisabled:.25,nodeOpacityInactive:.45,nodeStroke:"#d0e4ff",textColor:"#ffffff"},Rae=TU(Pae),Dae={bgColor:"#ffffff",comboColor:"#99ADD1",comboColorDisabled:"#f0f0f0",comboStroke:"#99add1",comboStrokeDisabled:"#d9d9d9",edgeColor:"#99add1",edgeColorDisabled:"#d9d9d9",edgeColorInactive:"#1B324F",nodeColor:"#1783ff",nodeColorDisabled:"#1B324F",nodeHaloStrokeOpacityActive:.15,nodeHaloStrokeOpacitySelected:.25,nodeIconOpacityInactive:.85,nodeOpacityDisabled:.06,nodeOpacityInactive:.25,nodeStroke:"#000000",textColor:"#000000"},Hae=TU(Dae);class ls extends yB{beforeDraw(e,t){return e}afterLayout(e,t){}}class Gae extends ls{beforeDraw(e){const{model:t}=this.context,n=e.add.combos,i=a=>{const s=[];return a.forEach((o,A)=>{const c=t.getAncestorsData(A,"combo").map(u=>Z(u)).reverse();s.push([A,o,c.length])}),new Map(s.sort(([,,o],[,,A])=>A-o).map(([o,A])=>[o,A]))};return e.add.combos=i(n),e.update.combos=i(e.update.combos),e}}function Hr(r,e,t,n,i){const a=Z(n),s=`${t}s`,o=i?n:r.add[s].get(a)||r.update[s].get(a)||r.remove[s].get(a)||n;Object.entries(r).forEach(([A,l])=>{e===A?l[s].set(a,o):l[s].delete(a)})}function Du(r,e){return Object.keys(r).every(t=>r[t]===e[t])}class Kae extends ls{beforeDraw(e,t){if(t.stage==="visibility"||!this.context.model.model.hasTreeStructure(Et))return e;const{model:n}=this.context,{add:i,update:a}=e,s=[...e.update.combos.entries(),...e.add.combos.entries()];for(;s.length;){const[o,A]=s.pop();if(xr(A)){const l=n.getDescendantsData(o),c=l.map(Z),{internal:u,external:h}=h1(c,d=>n.getRelatedEdgesData(d));l.forEach(d=>{const f=Z(d),g=s.findIndex(([p])=>p===f);g!==-1&&s.splice(g,1);const v=n.getElementType(f);Hr(e,"remove",v,d)}),u.forEach(d=>Hr(e,"remove","edge",d)),h.forEach(d=>{var f;const g=Z(d);((f=this.context.element)===null||f===void 0?void 0:f.getElement(g))?a.edges.set(g,d):i.edges.set(g,d)})}else{const l=n.getChildrenData(o),c=l.map(Z),{edges:u}=h1(c,h=>n.getRelatedEdgesData(h));[...l,...u].forEach(h=>{var d;const f=Z(h),g=n.getElementType(f);((d=this.context.element)===null||d===void 0?void 0:d.getElement(f))?Hr(e,"update",g,h):Hr(e,"add",g,h),g==="combo"&&s.push([f,h])})}}return e}}const JO=(r,e,t,n)=>{const i=`${t}s`,a=Z(n);!r.add[i].has(a)&&!r.update[i].has(a)&&r[e][i].set(Z(n),n)};class zae extends ls{getElement(e){return this.context.element.getElement(e)}handleExpand(e,t){if(JO(t,"add","node",e),xr(e))return;const n=Z(e);JO(t,"add","node",e),this.context.model.getRelatedEdgesData(n).forEach(s=>{Hr(t,"add","edge",s)}),this.context.model.getChildrenData(n).forEach(s=>{this.handleExpand(s,t)})}beforeDraw(e){const{graph:t,model:n}=this.context;if(!n.model.hasTreeStructure(Rr))return e;const{add:{nodes:i,edges:a},update:{nodes:s}}=e,o=new Map,A=new Map;i.forEach((c,u)=>{xr(c)&&o.set(u,c)}),a.forEach(c=>{if(t.getElementType(c.source)!=="node")return;const u=t.getNodeData(c.source);xr(u)&&o.set(c.source,u)}),s.forEach((c,u)=>{const h=this.getElement(u);if(!h)return;const d=h.attributes.collapsed;xr(c)?d||o.set(u,c):d&&A.set(u,c)});const l=new Set;return o.forEach((c,u)=>{n.getDescendantsData(u).forEach(d=>{const f=Z(d);if(l.has(f))return;Hr(e,"remove","node",d),n.getRelatedEdgesData(f).forEach(v=>{Hr(e,"remove","edge",v)}),l.add(f)})}),A.forEach((c,u)=>{if(n.getAncestorsData(u,Rr).some(xr)){Hr(e,"remove","node",c);return}this.handleExpand(c,e)}),e}}function MU(r,e,t){a1[r][e]&&$i.warn(`The extension ${e} of ${r} has been registered before, and will be overridden.`),Object.assign(a1[r],{[e]:t})}var OU=(function(){function r(e){ue(this,r),this.dragndropPluginOptions=e}return he(r,[{key:"apply",value:function(t){var n=this,i=t.renderingService,a=t.renderingContext,s=a.root.ownerDocument,o=s.defaultView,A=function(c){var u=c.target,h=u===s,d=h&&n.dragndropPluginOptions.isDocumentDraggable?s:u.closest&&u.closest("[draggable=true]");if(d){var f=!1,g=c.timeStamp,v=[c.clientX,c.clientY],p=null,y=[c.clientX,c.clientY],m=(function(){var C=Ja(Gn().mark(function S(F){var T,O,_,k,L,U;return Gn().wrap(function(G){for(;;)switch(G.prev=G.next){case 0:if(f){G.next=2;break}if(T=F.timeStamp-g,O=wr([F.clientX,F.clientY],v),!(T<=n.dragndropPluginOptions.dragstartTimeThreshold||O<=n.dragndropPluginOptions.dragstartDistanceThreshold)){G.next=1;break}return G.abrupt("return");case 1:F.type="dragstart",d.dispatchEvent(F),f=!0;case 2:if(F.type="drag",F.dx=F.clientX-y[0],F.dy=F.clientY-y[1],d.dispatchEvent(F),y=[F.clientX,F.clientY],h){G.next=4;break}return _=n.dragndropPluginOptions.overlap==="pointer"?[F.canvasX,F.canvasY]:u.getBounds().center,G.next=3,s.elementsFromPoint(_[0],_[1]);case 3:k=G.sent,L=k[k.indexOf(u)+1],U=(L==null?void 0:L.closest("[droppable=true]"))||(n.dragndropPluginOptions.isDocumentDroppable?s:null),p!==U&&(p&&(F.type="dragleave",F.target=p,p.dispatchEvent(F)),U&&(F.type="dragenter",F.target=U,U.dispatchEvent(F)),p=U,p&&(F.type="dragover",F.target=p,p.dispatchEvent(F)));case 4:case"end":return G.stop()}},S)}));return function(F){return C.apply(this,arguments)}})();o.addEventListener("pointermove",m);var B=function(S){if(f){S.detail={preventClick:!0};var F=S.clone();p&&(F.type="drop",F.target=p,p.dispatchEvent(F)),F.type="dragend",d.dispatchEvent(F),f=!1}o.removeEventListener("pointermove",m)};u.addEventListener("pointerup",B,{once:!0}),u.addEventListener("pointerupoutside",B,{once:!0})}};i.hooks.init.tap(r.tag,function(){o.addEventListener("pointerdown",A)}),i.hooks.destroy.tap(r.tag,function(){o.removeEventListener("pointerdown",A)})}}])})();OU.tag="Dragndrop";var Vae=(function(r){function e(){var t,n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};return ue(this,e),t=qe(this,e),t.name="dragndrop",t.options=n,t}return $e(e,r),he(e,[{key:"init",value:function(){this.addRenderingPlugin(new OU(De({overlap:"pointer",isDocumentDraggable:!1,isDocumentDroppable:!1,dragstartDistanceThreshold:0,dragstartTimeThreshold:0},this.options)))}},{key:"destroy",value:function(){this.removeAllRenderingPlugins()}},{key:"setOptions",value:function(n){Object.assign(this.plugins[0].dragndropPluginOptions,n)}}])})(rs),e_=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})},t_=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};const n_=["main"],r_=["background","main","label","transient"];function jae(r){return r.main}class i_{getConfig(){return this.config}getLayer(e="main"){return this.extends.layers[e]||jae(this.getLayers())}getLayers(){return this.extends.layers}getRenderer(e){return this.extends.renderers[e]}getCamera(e="main"){return this.getLayer(e).getCamera()}getRoot(e="main"){return this.getLayer(e).getRoot()}getContextService(e="main"){return this.getLayer(e).getContextService()}setCursor(e){this.config.cursor=e,this.getLayer().setCursor(e)}get document(){return this.getLayer().document}get context(){return this.getLayer().context}constructor(e){this.config={enableMultiLayer:!0},Object.assign(this.config,e);const t=this.config,{renderer:n,background:i,cursor:a,enableMultiLayer:s}=t,o=t_(t,["renderer","background","cursor","enableMultiLayer"]),A=s?r_:n_,l=a_(n,A),c=Object.fromEntries(A.map(u=>{const h=new Dw(Object.assign(Object.assign({},o),{supportsMutipleCanvasesInOneContainer:s,renderer:l[u],background:s?u==="background"?i:void 0:i}));return[u,h]}));s_(c),this.extends={config:this.config,renderer:n,renderers:l,layers:c}}get ready(){return Promise.all(Object.entries(this.getLayers()).map(([,e])=>e.ready))}resize(e,t){Object.assign(this.extends.config,{width:e,height:t}),Object.values(this.getLayers()).forEach(n=>{const i=n.getCamera(),a=i.getPosition(),s=i.getFocalPoint();n.resize(e,t),i.setPosition(a),i.setFocalPoint(s)})}getBounds(e){return Ql(Object.values(this.getLayers()).map(t=>e?t.getRoot().childNodes.find(i=>i.classList.includes(e)):t.getRoot()).filter(t=>(t==null?void 0:t.childNodes.length)>0).map(t=>t.getBounds()))}getContainer(){const e=this.extends.config.container;return typeof e=="string"?document.getElementById(e):e}getSize(){return[this.extends.config.width||0,this.extends.config.height||0]}appendChild(e,t){var n;const i=((n=e.style)===null||n===void 0?void 0:n.$layer)||"main";return this.getLayer(i).appendChild(e,t)}setRenderer(e){if(e===this.extends.renderer)return;const t=a_(e,this.config.enableMultiLayer?r_:n_);this.extends.renderers=t,Object.entries(t).forEach(([n,i])=>this.getLayer(n).setRenderer(i)),s_(this.getLayers())}getCanvasByViewport(e){return Hn(this.getLayer().viewport2Canvas(pi(e)))}getViewportByCanvas(e){return Hn(this.getLayer().canvas2Viewport(pi(e)))}getViewportByClient(e){return Hn(this.getLayer().client2Viewport(pi(e)))}getClientByViewport(e){return Hn(this.getLayer().viewport2Client(pi(e)))}getClientByCanvas(e){return this.getClientByViewport(this.getViewportByCanvas(e))}getCanvasByClient(e){const t=this.getLayer(),n=t.client2Viewport(pi(e));return Hn(t.viewport2Canvas(n))}toDataURL(){return e_(this,arguments,void 0,function*(e={}){const t=globalThis.devicePixelRatio||1,{mode:n="viewport"}=e,i=t_(e,["mode"]);let[a,s,o,A]=[0,0,0,0];if(n==="viewport")[o,A]=this.getSize();else if(n==="overall"){const p=this.getBounds(),y=is(p);[a,s]=p.min,[o,A]=y}const l=xw('<div id="virtual-image"></div>'),c=new Dw({width:o,height:A,renderer:new vl,devicePixelRatio:t,container:l,background:this.extends.config.background});yield c.ready,c.appendChild(this.getLayer("background").getRoot().cloneNode(!0)),c.appendChild(this.getRoot().cloneNode(!0));const u=this.getLayer("label").getRoot().cloneNode(!0),h=c.viewport2Canvas({x:0,y:0}),d=this.getCanvasByViewport([0,0]);u.translate([d[0]-h.x,d[1]-h.y]),u.scale(1/this.getCamera().getZoom()),c.appendChild(u),c.appendChild(this.getLayer("transient").getRoot().cloneNode(!0));const f=this.getCamera(),g=c.getCamera();if(n==="viewport")g.setZoom(f.getZoom()),g.setPosition(f.getPosition()),g.setFocalPoint(f.getFocalPoint());else if(n==="overall"){const[p,y,m]=g.getPosition(),[B,C,S]=g.getFocalPoint();g.setPosition([p+a,y+s,m]),g.setFocalPoint([B+a,C+s,S])}const v=c.getContextService();return new Promise(p=>{c.addEventListener(Pr.RERENDER,()=>e_(this,void 0,void 0,function*(){yield new Promise(m=>setTimeout(m,300));const y=yield v.toDataURL(i);p(y)}))})})}destroy(){Object.values(this.getLayers()).forEach(e=>{e.getCamera().cancelLandmarkAnimation(),e.destroy()})}}function a_(r,e){return Object.fromEntries(e.map(t=>{const n=(r==null?void 0:r(t))||new vl;return n instanceof vl&&n.setConfig({enableDirtyRectangleRendering:!1}),t==="main"?n.registerPlugin(new Vae({isDocumentDraggable:!0,isDocumentDroppable:!0,dragstartDistanceThreshold:10,dragstartTimeThreshold:100})):n.unregisterPlugin(n.getPlugin("dom-interaction")),[t,n]}))}function s_(r){Object.entries(r).forEach(([e,t])=>{const n=t.getContextService().getDomElement();n!=null&&n.style&&(n.style.gridArea="1 / 1 / 2 / 2",n.style.outline="none",n.tabIndex=1,e!=="main"&&(n.style.pointerEvents="none")),n!=null&&n.parentElement&&(n.parentElement.style.display="grid",n.parentElement.style.isolation="isolate")})}const wo=r=>r?parseInt(r):0;function Wae(r){const e=getComputedStyle(r),t=r.clientWidth||wo(e.width),n=r.clientHeight||wo(e.height),i=wo(e.paddingLeft)+wo(e.paddingRight),a=wo(e.paddingTop)+wo(e.paddingBottom);return[t-i,n-a]}function o_(r){if(!r)return[0,0];let e=640,t=480;const[n,i]=Wae(r);e=n||e,t=i||t;const a=1,s=1;return[Math.max(Be(e)?e:a,a),Math.max(Be(t)?t:s,s)]}class wf{constructor(e){this.type=e}}class yn extends wf{constructor(e,t){super(e),this.data=t}}class Xr extends wf{constructor(e,t,n,i){super(e),this.animationType=t,this.animation=n,this.data=i}}class Bo extends wf{constructor(e,t,n){super(e),this.elementType=t,this.data=n}}class Eu extends wf{constructor(e,t){super(e),this.data=t}}function Cn(r,e){r.emit(e.type,e)}function qae(r){if(!r)return null;if(r instanceof kI)return{type:"canvas",element:r};let e=r;for(;e;){if(Hl(e))return{type:"node",element:e};if(DL(e))return{type:"edge",element:e};if(FB(e))return{type:"combo",element:e};e=e.parentElement}return null}function A_(r){var e;return((e=r==null?void 0:r.style)===null||e===void 0?void 0:e.zIndex)||0}const il="cachedStyle",gb=r=>`__${r}__`;function $ae(r,e){const t=Array.isArray(e)?e:[e];Rn(r,il)||ol(r,il,{}),t.forEach(n=>{ol(Rn(r,il),gb(n),r.attributes[n])})}function l_(r,e){return Rn(r,[il,gb(e)])}function Yae(r,e){return gb(e)in(Rn(r,il)||{})}class Xae{constructor(e){this.tasks=[],this.animations=new Set,this.context=e}getTasks(){const e=[...this.tasks];return this.tasks=[],e}add(e,t){this.tasks.push([e,t])}animate(e,t,n){var i,a,s;(i=t==null?void 0:t.before)===null||i===void 0||i.call(t);const o=this.getTasks().map(([l,c])=>{var u,h,d;const{element:f,elementType:g,stage:v}=l,p=lV(this.context.options,g,v,e);(u=c==null?void 0:c.before)===null||u===void 0||u.call(c);const y=p.length?uV(f,this.inferStyle(l,n),p):null;return y?((h=c==null?void 0:c.beforeAnimate)===null||h===void 0||h.call(c,y),y.finished.then(()=>{var m,B;(m=c==null?void 0:c.afterAnimate)===null||m===void 0||m.call(c,y),(B=c==null?void 0:c.after)===null||B===void 0||B.call(c),this.animations.delete(y)})):(d=c==null?void 0:c.after)===null||d===void 0||d.call(c),y}).filter(Boolean);o.forEach(l=>this.animations.add(l));const A=fB(o);return A?((a=t==null?void 0:t.beforeAnimate)===null||a===void 0||a.call(t,A),A.finished.then(()=>{var l,c;(l=t==null?void 0:t.afterAnimate)===null||l===void 0||l.call(t,A),(c=t==null?void 0:t.after)===null||c===void 0||c.call(t),this.release()})):(s=t==null?void 0:t.after)===null||s===void 0||s.call(t),A}inferStyle(e,t){var n,i;const{element:a,elementType:s,stage:o,originalStyle:A,updatedStyle:l={}}=e;e.modifiedStyle||(e.modifiedStyle=Object.assign(Object.assign({},A),l));const{modifiedStyle:c}=e,u={},h={};if(o==="enter")Object.assign(u,{opacity:0});else if(o==="exit")Object.assign(h,{opacity:0});else if(o==="show")Object.assign(u,{opacity:0}),Object.assign(h,{opacity:(n=l_(a,"opacity"))!==null&&n!==void 0?n:fl("opacity")});else if(o==="hide")Object.assign(u,{opacity:(i=l_(a,"opacity"))!==null&&i!==void 0?i:fl("opacity")}),Object.assign(h,{opacity:0});else if(o==="collapse"){const{collapse:d}=t||{},{target:f,descendants:g,position:v}=d;if(s==="node"){if(g.includes(a.id)){const[p,y,m]=v;Object.assign(h,{x:p,y,z:m})}}else if(s==="combo"){if(a.id===f||g.includes(a.id)){const[p,y]=v;Object.assign(h,{x:p,y,childrenNode:A.childrenNode})}}else s==="edge"&&Object.assign(h,{sourceNode:c.sourceNode,targetNode:c.targetNode})}else if(o==="expand"){const{expand:d}=t||{},{target:f,descendants:g,position:v}=d;if(s==="node"){if(a.id===f||g.includes(a.id)){const[p,y,m]=v;Object.assign(u,{x:p,y,z:m})}}else if(s==="combo"){if(a.id===f||g.includes(a.id)){const[p,y,m]=v;Object.assign(u,{x:p,y,z:m,childrenNode:c.childrenNode})}}else s==="edge"&&Object.assign(u,{sourceNode:c.sourceNode,targetNode:c.targetNode})}return[Object.keys(u).length>0?Object.assign({},A,u):A,Object.keys(h).length>0?Object.assign({},c,h):c]}stop(){this.animations.forEach(e=>e.cancel())}clear(){this.tasks=[]}release(){var e,t;const{canvas:n}=this.context,i=(t=(e=n.document)===null||e===void 0?void 0:e.timeline)===null||t===void 0?void 0:t.animationsWithPromises;i&&(n.document.timeline.animationsWithPromises=i.filter(a=>a.playState!=="finished"))}destroy(){this.stop(),this.animations.clear(),this.tasks=[]}}class Zae{constructor(e){this.batchCount=0,this.context=e}emit(e){const{graph:t}=this.context;t.emit(e.type,e)}startBatch(e=!0){this.batchCount++,this.batchCount===1&&this.emit(new yn(ge.BATCH_START,{initiate:e}))}endBatch(){this.batchCount--,this.batchCount===0&&this.emit(new yn(ge.BATCH_END))}get isBatching(){return this.batchCount>0}destroy(){this.context=null}}class Jae extends pB{constructor(e){super(e),this.currentTarget=null,this.currentTargetType=null,this.category="behavior",this.forwardCanvasEvents=t=>{const{target:n}=t,i=qae(n);if(!i)return;const{graph:a,canvas:s}=this.context,{type:o,element:A}=i;if("destroyed"in A&&(Gl(A)||A.destroyed))return;const{type:l,detail:c,button:u}=t,h=Object.assign(Object.assign({},t),{target:A,targetType:o,originalTarget:n});l===se.POINTER_MOVE&&(this.currentTarget!==A&&(this.currentTarget&&a.emit(`${this.currentTargetType}:${se.POINTER_LEAVE}`,Object.assign(Object.assign({},h),{type:se.POINTER_LEAVE,target:this.currentTarget,targetType:this.currentTargetType})),A&&(Object.assign(h,{type:se.POINTER_ENTER}),a.emit(`${o}:${se.POINTER_ENTER}`,h))),this.currentTarget=A,this.currentTargetType=o),l===se.CLICK&&u===2||(a.emit(`${o}:${l}`,h),a.emit(l,h)),l===se.CLICK&&c===2&&(Object.assign(h,{type:se.DBLCLICK}),a.emit(`${o}:${se.DBLCLICK}`,h),a.emit(se.DBLCLICK,h)),l===se.POINTER_DOWN&&u===2&&(Object.assign(h,{type:se.CONTEXT_MENU,preventDefault:()=>{var d;(d=s.getContainer())===null||d===void 0||d.addEventListener(se.CONTEXT_MENU,f=>f.preventDefault(),{once:!0})}}),a.emit(`${o}:${se.CONTEXT_MENU}`,h),a.emit(se.CONTEXT_MENU,h))},this.forwardContainerEvents=t=>{this.context.graph.emit(t.type,t)},this.forwardEvents(),this.setBehaviors(this.context.options.behaviors||[])}setBehaviors(e){this.setExtensions(e)}forwardEvents(){const e=this.context.canvas.getContainer();e&&[Oo.KEY_DOWN,Oo.KEY_UP].forEach(n=>{e.addEventListener(n,this.forwardContainerEvents)});const t=this.context.canvas.document;t&&[se.CLICK,se.DBLCLICK,se.POINTER_OVER,se.POINTER_LEAVE,se.POINTER_ENTER,se.POINTER_MOVE,se.POINTER_OUT,se.POINTER_DOWN,se.POINTER_UP,se.CONTEXT_MENU,se.DRAG_START,se.DRAG,se.DRAG_END,se.DRAG_ENTER,se.DRAG_OVER,se.DRAG_LEAVE,se.DROP,se.WHEEL].forEach(n=>{t.addEventListener(n,this.forwardCanvasEvents)})}destroy(){const e=this.context.canvas.getContainer();e&&[Oo.KEY_DOWN,Oo.KEY_UP].forEach(t=>{e.removeEventListener(t,this.forwardContainerEvents)}),this.context.canvas.document.removeAllEventListeners(),super.destroy()}}var ese=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};function uw(r){const{id:e=Z(r),style:t,data:n}=r,i=ese(r,["id","style","data"]),a=Object.assign(Object.assign({},r),{style:Object.assign({},t),data:Object.assign({},n)});return pV(r)?Object.assign({id:e,data:a},i):{id:e,data:a}}function On(r){return r.data}function tse(r){if(r.hasTreeStructure(Rr))return;r.attachTreeStructure(Rr);const e=r.getAllEdges();for(const t of e){const{source:n,target:i}=t;r.setParent(i,n,Rr)}}class nse{constructor(){this.latestRemovedComboIds=new Set,this.comboIds=new Set,this.changes=[],this.batchCount=0,this.isTraceless=!1,this.enableUpdateNodeLikeHierarchy=!0,this.model=new Mn}pushChange(e){if(this.isTraceless)return;const{type:t}=e;if(t===Ut.NodeUpdated||t===Ut.EdgeUpdated||t===Ut.ComboUpdated){const{value:n,original:i}=e;this.changes.push({value:bg(n),original:bg(i),type:t})}else this.changes.push({value:bg(e.value),type:t})}getChanges(){return this.changes}clearChanges(){this.changes=[]}batch(e){this.batchCount++,this.model.batch(e),this.batchCount--}isBatching(){return this.batchCount>0}silence(e){this.isTraceless=!0,e(),this.isTraceless=!1}isCombo(e){return this.comboIds.has(e)||this.latestRemovedComboIds.has(e)}getData(){return{nodes:this.getNodeData(),edges:this.getEdgeData(),combos:this.getComboData()}}getNodeData(e){return this.model.getAllNodes().reduce((t,n)=>{const i=On(n);return this.isCombo(Z(i))||(e===void 0||e.includes(Z(i)))&&t.push(i),t},[])}getEdgeDatum(e){return On(this.model.getEdge(e))}getEdgeData(e){return this.model.getAllEdges().reduce((t,n)=>{const i=On(n);return(e===void 0||e.includes(Z(i)))&&t.push(i),t},[])}getComboData(e){return this.model.getAllNodes().reduce((t,n)=>{const i=On(n);return this.isCombo(Z(i))&&(e===void 0||e.includes(Z(i)))&&t.push(i),t},[])}getRootsData(e=Rr){return this.model.getRoots(e).map(On)}getAncestorsData(e,t){const{model:n}=this;return!n.hasNode(e)||!n.hasTreeStructure(t)?[]:n.getAncestors(e,t).map(On)}getDescendantsData(e){const t=this.getElementDataById(e),n=[];return Ns(t,i=>{i!==t&&n.push(i)},i=>this.getChildrenData(Z(i)),"TB"),n}getParentData(e,t){const{model:n}=this;if(!t){$i.warn("The hierarchy structure key is not specified");return}if(!n.hasNode(e)||!n.hasTreeStructure(t))return;const i=n.getParent(e,t);return i?On(i):void 0}getChildrenData(e){const t=this.getElementType(e)==="node"?Rr:Et,{model:n}=this;return!n.hasNode(e)||!n.hasTreeStructure(t)?[]:n.getChildren(e,t).map(On)}getElementsDataByType(e){return e==="node"?this.getNodeData():e==="edge"?this.getEdgeData():e==="combo"?this.getComboData():[]}getElementDataById(e){return this.getElementType(e)==="edge"?this.getEdgeDatum(e):this.getNodeLikeDatum(e)}getNodeLikeDatum(e){const t=this.model.getNode(e);return On(t)}getNodeLikeData(e){return this.model.getAllNodes().reduce((t,n)=>{const i=On(n);return e?e.includes(Z(i))&&t.push(i):t.push(i),t},[])}getElementDataByState(e,t){return this.getElementsDataByType(e).filter(i=>{var a;return(a=i.states)===null||a===void 0?void 0:a.includes(t)})}getElementState(e){var t;return((t=this.getElementDataById(e))===null||t===void 0?void 0:t.states)||[]}hasNode(e){return this.model.hasNode(e)&&!this.isCombo(e)}hasEdge(e){return this.model.hasEdge(e)}hasCombo(e){return this.model.hasNode(e)&&this.isCombo(e)}getRelatedEdgesData(e,t="both"){return this.model.getRelatedEdges(e,t).map(On)}getNeighborNodesData(e){return this.model.getNeighbors(e).map(On)}setData(e){const{nodes:t=[],edges:n=[],combos:i=[]}=e,{nodes:a,edges:s,combos:o}=this.getData(),A=qa(a,t,u=>Z(u),po),l=qa(s,n,u=>Z(u),po),c=qa(o,i,u=>Z(u),po);this.batch(()=>{const u={nodes:A.enter,edges:l.enter,combos:c.enter};this.addData(u),this.computeZIndex(u,"add",!0);const h={nodes:A.update,edges:l.update,combos:c.update};this.updateData(h),this.computeZIndex(h,"update",!0);const d={nodes:A.exit.map(Z),edges:l.exit.map(Z),combos:c.exit.map(Z)};this.removeData(d)})}addData(e){const{nodes:t,edges:n,combos:i}=e;this.batch(()=>{this.addComboData(i),this.addNodeData(t),this.addEdgeData(n)}),this.computeZIndex(e,"add")}addNodeData(e=[]){e.length&&(this.model.addNodes(e.map(t=>(this.pushChange({value:t,type:Ut.NodeAdded}),uw(t)))),this.updateNodeLikeHierarchy(e),this.computeZIndex({nodes:e},"add"))}addEdgeData(e=[]){e.length&&(this.model.addEdges(e.map(t=>(this.pushChange({value:t,type:Ut.EdgeAdded}),uw(t)))),this.computeZIndex({edges:e},"add"))}addComboData(e=[]){if(!e.length)return;const{model:t}=this;t.hasTreeStructure(Et)||t.attachTreeStructure(Et),t.addNodes(e.map(n=>(this.comboIds.add(Z(n)),this.pushChange({value:n,type:Ut.ComboAdded}),uw(n)))),this.updateNodeLikeHierarchy(e),this.computeZIndex({combos:e},"add")}addChildrenData(e,t){const n=this.getNodeLikeDatum(e),i=t.map(Z);this.addNodeData(t),this.updateNodeData([{id:e,children:[...n.children||[],...i]}]),this.addEdgeData(i.map(a=>({source:e,target:a})))}computeZIndex(e,t,n=!1){!n&&this.isBatching()||this.batch(()=>{const{nodes:i=[],edges:a=[],combos:s=[]}=e;s.forEach(o=>{var A,l,c;const u=Z(o);if(t==="add"&&Be((A=o.style)===null||A===void 0?void 0:A.zIndex)||t==="update"&&!("combo"in o))return;const h=this.getParentData(u,Et),d=h?((c=(l=h.style)===null||l===void 0?void 0:l.zIndex)!==null&&c!==void 0?c:0)+1:0;this.preventUpdateNodeLikeHierarchy(()=>{this.updateComboData([{id:u,style:{zIndex:d}}])})}),i.forEach(o=>{var A,l,c;const u=Z(o);if(t==="add"&&Be((A=o.style)===null||A===void 0?void 0:A.zIndex)||t==="update"&&!("combo"in o)&&!("children"in o))return;let h=0;const d=this.getParentData(u,Et);if(d)h=(((l=d.style)===null||l===void 0?void 0:l.zIndex)||0)+1;else{const f=this.getParentData(u,Rr);f&&(h=((c=f==null?void 0:f.style)===null||c===void 0?void 0:c.zIndex)||0)}this.preventUpdateNodeLikeHierarchy(()=>{this.updateNodeData([{id:u,style:{zIndex:h}}])})}),a.forEach(o=>{var A,l,c,u,h;if(Be((A=o.style)===null||A===void 0?void 0:A.zIndex))return;let{id:d,source:f,target:g}=o;if(!d)d=Z(o);else{const y=this.getEdgeDatum(d);f=y.source,g=y.target}if(!f||!g)return;const v=((c=(l=this.getNodeLikeDatum(f))===null||l===void 0?void 0:l.style)===null||c===void 0?void 0:c.zIndex)||0,p=((h=(u=this.getNodeLikeDatum(g))===null||u===void 0?void 0:u.style)===null||h===void 0?void 0:h.zIndex)||0;this.updateEdgeData([{id:Z(o),style:{zIndex:Math.max(v,p)-1}}])})})}getFrontZIndex(e){var t;const n=this.getElementType(e),i=this.getElementDataById(e),a=this.getData();if(Object.assign(a,{[`${n}s`]:a[`${n}s`].filter(s=>Z(s)!==e)}),n==="combo"&&!xr(i)){const s=new Set(this.getAncestorsData(e,Et).map(Z));a.nodes=a.nodes.filter(o=>!s.has(Z(o))),a.combos=a.combos.filter(o=>!s.has(Z(o))),a.edges=a.edges.filter(({source:o,target:A})=>!s.has(o)&&!s.has(A))}return Math.max(((t=i.style)===null||t===void 0?void 0:t.zIndex)||0,0,...Object.values(a).flat().map(s=>{var o;return(((o=s==null?void 0:s.style)===null||o===void 0?void 0:o.zIndex)||0)+1}))}updateNodeLikeHierarchy(e){if(!this.enableUpdateNodeLikeHierarchy)return;const{model:t}=this;e.forEach(n=>{const i=Z(n),a=nu(n);a!==void 0&&(t.hasTreeStructure(Et)||t.attachTreeStructure(Et),a===null&&this.refreshComboData(i),this.setParent(i,nu(n),Et));const s=n.children||[];if(s.length){t.hasTreeStructure(Rr)||t.attachTreeStructure(Rr);const o=s.filter(A=>t.hasNode(A));o.forEach(A=>this.setParent(A,i,Rr)),o.length!==s.length&&this.updateNodeData([{id:i,children:o}])}})}preventUpdateNodeLikeHierarchy(e){this.enableUpdateNodeLikeHierarchy=!1,e(),this.enableUpdateNodeLikeHierarchy=!0}updateData(e){const{nodes:t,edges:n,combos:i}=e;this.batch(()=>{this.updateNodeData(t),this.updateComboData(i),this.updateEdgeData(n)}),this.computeZIndex(e,"update")}updateNodeData(e=[]){if(!e.length)return;const{model:t}=this;this.batch(()=>{const n=[];e.forEach(i=>{const a=Z(i),s=On(t.getNode(a));if(po(s,i))return;const o=ba(s,i);this.pushChange({value:o,original:s,type:Ut.NodeUpdated}),t.mergeNodeData(a,o),n.push(o)}),this.updateNodeLikeHierarchy(n)}),this.computeZIndex({nodes:e},"update")}refreshData(){const{nodes:e,edges:t,combos:n}=this.getData();e.forEach(i=>{this.pushChange({value:i,original:i,type:Ut.NodeUpdated})}),t.forEach(i=>{this.pushChange({value:i,original:i,type:Ut.EdgeUpdated})}),n.forEach(i=>{this.pushChange({value:i,original:i,type:Ut.ComboUpdated})})}syncNodeLikeDatum(e){const{model:t}=this,n=Z(e);if(!t.hasNode(n))return;const i=On(t.getNode(n)),a=ba(i,e);t.mergeNodeData(n,a)}syncEdgeDatum(e){const{model:t}=this,n=Z(e);if(!t.hasEdge(n))return;const i=On(t.getEdge(n)),a=ba(i,e);t.mergeEdgeData(n,a)}updateEdgeData(e=[]){if(!e.length)return;const{model:t}=this;this.batch(()=>{e.forEach(n=>{const i=Z(n),a=On(t.getEdge(i));if(po(a,n))return;n.source&&a.source!==n.source&&t.updateEdgeSource(i,n.source),n.target&&a.target!==n.target&&t.updateEdgeTarget(i,n.target);const s=ba(a,n);this.pushChange({value:s,original:a,type:Ut.EdgeUpdated}),t.mergeEdgeData(i,s)})}),this.computeZIndex({edges:e},"update")}updateComboData(e=[]){if(!e.length)return;const{model:t}=this;t.batch(()=>{const n=[];e.forEach(i=>{const a=Z(i),s=On(t.getNode(a));if(po(s,i))return;const o=ba(s,i);this.pushChange({value:o,original:s,type:Ut.ComboUpdated}),t.mergeNodeData(a,o),n.push(o)}),this.updateNodeLikeHierarchy(n)}),this.computeZIndex({combos:e},"update")}setParent(e,t,n,i=!0){if(e===t)return;const a=this.getNodeLikeDatum(e),s=nu(a);if(s!==t&&n===Et){const o={id:e,combo:t};this.isCombo(e)?this.syncNodeLikeDatum(o):this.syncNodeLikeDatum(o)}this.model.setParent(e,t,n),i&&n===Et&&lR([s,t]).forEach(o=>{o!==void 0&&this.refreshComboData(o)})}refreshComboData(e){const t=this.getComboData([e])[0],n=this.getAncestorsData(e,Et);t&&this.pushChange({value:t,original:t,type:Ut.ComboUpdated}),n.forEach(i=>{this.pushChange({value:i,original:i,type:Ut.ComboUpdated})})}getElementPosition(e){const t=this.getElementDataById(e);return Sn(t)}translateNodeLikeBy(e,t){this.isCombo(e)?this.translateComboBy(e,t):this.translateNodeBy(e,t)}translateNodeLikeTo(e,t){this.isCombo(e)?this.translateComboTo(e,t):this.translateNodeTo(e,t)}translateNodeBy(e,t){const n=this.getElementPosition(e),i=Ve(n,[...t,0].slice(0,3));this.translateNodeTo(e,i)}translateNodeTo(e,t){const[n=0,i=0,a=0]=t;this.preventUpdateNodeLikeHierarchy(()=>{this.updateNodeData([{id:e,style:{x:n,y:i,z:a}}])})}translateComboBy(e,t){const[n=0,i=0,a=0]=t;if([n,i,a].some(isNaN)||[n,i,a].every(A=>A===0))return;const s=this.getComboData([e])[0];if(!s)return;const o=new Set;Ns(s,A=>{const l=Z(A);if(o.has(l))return;o.add(l);const[c,u,h]=Sn(A),d=ba(A,{style:{x:c+n,y:u+i,z:h+a}});this.pushChange({value:d,original:A,type:this.isCombo(l)?Ut.ComboUpdated:Ut.NodeUpdated}),this.model.mergeNodeData(l,d)},A=>this.getChildrenData(Z(A)),"BT")}translateComboTo(e,t){var n;if(t.some(isNaN))return;const[i=0,a=0,s=0]=t,o=(n=this.getComboData([e]))===null||n===void 0?void 0:n[0];if(!o)return;const[A,l,c]=Sn(o),u=i-A,h=a-l,d=s-c;Ns(o,f=>{const g=Z(f),[v,p,y]=Sn(f),m=ba(f,{style:{x:v+u,y:p+h,z:y+d}});this.pushChange({value:m,original:f,type:this.isCombo(g)?Ut.ComboUpdated:Ut.NodeUpdated}),this.model.mergeNodeData(g,m)},f=>this.getChildrenData(Z(f)),"BT")}removeData(e){const{nodes:t,edges:n,combos:i}=e;this.batch(()=>{this.removeEdgeData(n),this.removeNodeData(t),this.removeComboData(i),this.latestRemovedComboIds=new Set(i)})}removeNodeData(e=[]){e.length&&this.batch(()=>{e.forEach(t=>{this.removeEdgeData(this.getRelatedEdgesData(t).map(Z)),this.pushChange({value:this.getNodeData([t])[0],type:Ut.NodeRemoved}),this.removeNodeLikeHierarchy(t)}),this.model.removeNodes(e)})}removeEdgeData(e=[]){e.length&&(e.forEach(t=>this.pushChange({value:this.getEdgeData([t])[0],type:Ut.EdgeRemoved})),this.model.removeEdges(e))}removeComboData(e=[]){e.length&&this.batch(()=>{e.forEach(t=>{this.pushChange({value:this.getComboData([t])[0],type:Ut.ComboRemoved}),this.removeNodeLikeHierarchy(t),this.comboIds.delete(t)}),this.model.removeNodes(e)})}removeNodeLikeHierarchy(e){if(this.model.hasTreeStructure(Et)){const t=nu(this.getNodeLikeDatum(e));this.setParent(e,void 0,Et,!1),this.model.getChildren(e,Et).forEach(n=>{const i=On(n),a=Z(i);this.setParent(Z(i),t,Et,!1);const s=ba(i,{id:Z(i),combo:t});this.pushChange({value:s,original:i,type:this.isCombo(a)?Ut.ComboUpdated:Ut.NodeUpdated}),this.model.mergeNodeData(Z(i),s)}),ke(t)||this.refreshComboData(t)}}getElementType(e){if(this.model.hasNode(e))return this.isCombo(e)?"combo":"node";if(this.model.hasEdge(e))return"edge";throw new Error(ha(`Unknown element type of id: ${e}`))}destroy(){const{model:e}=this,t=e.getAllNodes(),n=e.getAllEdges();e.removeEdges(n.map(i=>i.id)),e.removeNodes(t.map(i=>i.id)),this.context={}}}var bo=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class rse{constructor(e){this.elementMap={},this.shapeTypeMap={},this.paletteStyle={},this.defaultStyle={},this.stateStyle={},this.visibilityCache=new WeakMap,this.context=e}init(){this.initContainer()}initContainer(){if(!this.container||this.container.destroyed){const{canvas:e}=this.context;this.container=e.appendChild(new Tn({className:"elements"}))}}emit(e,t){t.silence||Cn(this.context.graph,e)}forEachElementData(e){Ws.forEach(t=>{const n=this.context.model.getElementsDataByType(t);e(t,n)})}getElementType(e,t){var n;const{options:i,graph:a}=this.context,s=Gx(t)&&((n=i[e])===null||n===void 0?void 0:n.type)||t.type;return s?typeof s=="string"?s:s.call(a,t):e==="edge"?"line":"circle"}getTheme(e){return Wk(this.context.options)[e]||{}}getThemeStyle(e){return this.getTheme(e).style||{}}getThemeStateStyle(e,t){const{state:n={}}=this.getTheme(e);return Object.assign({},...t.map(i=>n[i]||{}))}computePaletteStyle(){const{options:e}=this.context;this.paletteStyle={},this.forEachElementData((t,n)=>{var i,a;const s=Object.assign({},Ex((i=this.getTheme(t))===null||i===void 0?void 0:i.palette),Ex((a=e[t])===null||a===void 0?void 0:a.palette));s!=null&&s.field&&Object.assign(this.paletteStyle,uj(n,s))})}getPaletteStyle(e,t){const n=this.paletteStyle[t];return n?e==="edge"?{stroke:n}:{fill:n}:{}}computeElementDefaultStyle(e,t){var n;const{options:i}=this.context,a=((n=i[e])===null||n===void 0?void 0:n.style)||{};"transform"in a&&Array.isArray(a.transform)&&(a.transform=[...a.transform]),this.defaultStyle[Z(t.datum)]=bx(a,t)}computeElementsDefaultStyle(e){const{graph:t}=this.context;this.forEachElementData((n,i)=>{const a=i.length;for(let s=0;s<a;s++){const o=i[s];(e===void 0||e.includes(Z(o)))&&this.computeElementDefaultStyle(n,{datum:o,graph:t})}})}getDefaultStyle(e){return this.defaultStyle[e]||{}}getElementState(e){try{const{model:t}=this.context;return t.getElementState(e)}catch{return[]}}getElementStateStyle(e,t,n){var i,a;const{options:s}=this.context,o=((a=(i=s[e])===null||i===void 0?void 0:i.state)===null||a===void 0?void 0:a[t])||{};return bx(o,n)}computeElementStatesStyle(e,t,n){this.stateStyle[Z(n.datum)]=Object.assign({},...t.map(i=>this.getElementStateStyle(e,i,n)))}computeElementsStatesStyle(e){const{graph:t}=this.context;this.forEachElementData((n,i)=>{const a=i.length;for(let s=0;s<a;s++){const o=i[s];if(e===void 0||e.includes(Z(o))){const A=this.getElementState(Z(o));this.computeElementStatesStyle(n,A,{datum:o,graph:t})}}})}getStateStyle(e){return this.stateStyle[e]||{}}computeStyle(e,t){e&&["translate","zIndex"].includes(e)||(this.computePaletteStyle(),this.computeElementsDefaultStyle(t),this.computeElementsStatesStyle(t))}getElement(e){return this.elementMap[e]}getNodes(){return this.context.model.getNodeData().map(({id:e})=>this.elementMap[e])}getEdges(){return this.context.model.getEdgeData().map(e=>this.elementMap[Z(e)])}getCombos(){return this.context.model.getComboData().map(({id:e})=>this.elementMap[e])}getElementComputedStyle(e,t){const n=Z(t),i=this.getThemeStyle(e),a=this.getPaletteStyle(e,n),s=t.style||{},o=this.getDefaultStyle(n),A=this.getThemeStateStyle(e,this.getElementState(n)),l=this.getStateStyle(n),c=Gx(t)?Object.assign({},i,a,s,o,A,l):Object.assign({},s);if(e==="combo"){const u=this.context.model.getChildrenData(n),d=!!c.collapsed?[]:u.map(Z).filter(f=>this.getElement(f));Object.assign(c,{childrenNode:d,childrenData:u})}return c}getDrawData(e){this.init();const t=this.computeChangesAndDrawData(e);if(!t)return null;const{type:n="draw",stage:i=n}=e;return this.markDestroyElement(t.drawData),this.computeStyle(i),{type:n,stage:i,data:t}}draw(e={animation:!0}){const t=this.getDrawData(e);if(!t)return;const{data:{drawData:{add:n,update:i,remove:a}}}=t;return this.destroyElements(a,e),this.createElements(n,e),this.updateElements(i,e),this.setAnimationTask(e,t)}preLayoutDraw(){return bo(this,arguments,void 0,function*(e={animation:!0}){var t,n;const i=this.getDrawData(e);if(!i)return;const{data:{drawData:a}}=i;yield(n=(t=this.context.layout)===null||t===void 0?void 0:t.preLayout)===null||n===void 0?void 0:n.call(t,a);const{add:s,update:o,remove:A}=a;return this.destroyElements(A,e),this.createElements(s,e),this.updateElements(o,e),this.setAnimationTask(e,i)})}setAnimationTask(e,t){const{animation:n,silence:i}=e,{data:{dataChanges:a,drawData:s},stage:o,type:A}=t;return this.context.animation.animate(n,i?{}:{before:()=>this.emit(new yn(ge.BEFORE_DRAW,{dataChanges:a,animation:n,stage:o,render:A==="render"}),e),beforeAnimate:l=>this.emit(new Xr(ge.BEFORE_ANIMATE,mr.DRAW,l,s),e),afterAnimate:l=>this.emit(new Xr(ge.AFTER_ANIMATE,mr.DRAW,l,s),e),after:()=>this.emit(new yn(ge.AFTER_DRAW,{dataChanges:a,animation:n,stage:o,render:A==="render",firstRender:this.context.graph.rendered===!1}),e)})}computeChangesAndDrawData(e){const{model:t}=this.context,n=t.getChanges(),i=tb(n);if(i.length===0)return null;const{NodeAdded:a=[],NodeUpdated:s=[],NodeRemoved:o=[],EdgeAdded:A=[],EdgeUpdated:l=[],EdgeRemoved:c=[],ComboAdded:u=[],ComboUpdated:h=[],ComboRemoved:d=[]}=Nh(i,C=>C.type),f=(C,S)=>{const F=[];return C.forEach(T=>{const O=Z(T.value);this.getElement(O)?F.push(T):S.push(T)}),F},g=f(s,a),v=f(l,A),p=f(h,u),y=C=>new Map(C.map(S=>{const F=S.value;return[Z(F),F]})),m={add:{nodes:y(a),edges:y(A),combos:y(u)},update:{nodes:y(g),edges:y(v),combos:y(p)},remove:{nodes:y(o),edges:y(c),combos:y(d)}},B=this.transformData(m,e);return t.clearChanges(),{dataChanges:n,drawData:B}}transformData(e,t){const n=this.context.transform.getTransformInstance();return Object.values(n).reduce((i,a)=>a.beforeDraw(i,t),e)}createElement(e,t,n){var i;const a=Z(t);if(this.getElement(a))return;const o=this.getElementType(e,t),A=this.getElementComputedStyle(e,t),l=va(e,o);if(!l)return $i.warn(`The element ${o} of ${e} is not registered.`);this.emit(new Bo(ge.BEFORE_ELEMENT_CREATE,e,t),n);const c=this.container.appendChild(new l({id:a,context:this.context,style:A}));this.shapeTypeMap[a]=o,this.elementMap[a]=c;const{stage:u="enter"}=n;(i=this.context.animation)===null||i===void 0||i.add({element:c,elementType:e,stage:u,originalStyle:Object.assign({},c.attributes),updatedStyle:A},{after:()=>{var h;this.emit(new Bo(ge.AFTER_ELEMENT_CREATE,e,t),n),(h=c.onCreate)===null||h===void 0||h.call(c)}})}createElements(e,t){const{nodes:n,edges:i,combos:a}=e;[["node",n],["combo",a],["edge",i]].forEach(([o,A])=>{A.forEach(l=>this.createElement(o,l,t))})}getUpdateStageStyle(e,t,n){const{stage:i="update"}=n;if(i==="translate")if(e==="node"||e==="combo"){const{style:{x:a=0,y:s=0,z:o=0}={}}=t;return{x:a,y:s,z:o}}else return{};return this.getElementComputedStyle(e,t)}updateElement(e,t,n){var i;const a=Z(t),{stage:s="update"}=n,o=this.getElement(a);if(!o)return()=>null;this.emit(new Bo(ge.BEFORE_ELEMENT_UPDATE,e,t),n);const A=this.getElementType(e,t),l=this.getUpdateStageStyle(e,t,n);this.shapeTypeMap[a]!==A&&(o.destroy(),delete this.shapeTypeMap[a],delete this.elementMap[a],this.createElement(e,t,{animation:!1,silence:!0}));const c=s!=="visibility"?s:l.visibility==="hidden"?"hide":"show";c==="hide"&&delete l.visibility,(i=this.context.animation)===null||i===void 0||i.add({element:o,elementType:e,stage:c,originalStyle:Object.assign({},o.attributes),updatedStyle:l},{before:()=>{const u=this.elementMap[a];s!=="collapse"&&f1(u,l),s==="visibility"&&(Yae(u,"opacity")||$ae(u,"opacity"),this.visibilityCache.set(u,c==="show"?"visible":"hidden"),c==="show"&&Vs(u,"visible"))},after:()=>{var u;const h=this.elementMap[a];s==="collapse"&&f1(h,l),c==="hide"&&Vs(h,this.visibilityCache.get(h)),this.emit(new Bo(ge.AFTER_ELEMENT_UPDATE,e,t),n),(u=h.onUpdate)===null||u===void 0||u.call(h)}})}updateElements(e,t){const{nodes:n,edges:i,combos:a}=e;[["node",n],["combo",a],["edge",i]].forEach(([o,A])=>{A.forEach(l=>this.updateElement(o,l,t))})}markDestroyElement(e){Object.values(e.remove).forEach(t=>{t.forEach(n=>{const i=Z(n),a=this.getElement(i);a&&rW(a)})})}destroyElement(e,t,n){var i;const{stage:a="exit"}=n,s=Z(t),o=this.elementMap[s];if(!o)return()=>null;this.emit(new Bo(ge.BEFORE_ELEMENT_DESTROY,e,t),n),(i=this.context.animation)===null||i===void 0||i.add({element:o,elementType:e,stage:a,originalStyle:Object.assign({},o.attributes),updatedStyle:{}},{after:()=>{var A;this.clearElement(s),o.destroy(),(A=o.onDestroy)===null||A===void 0||A.call(o),this.emit(new Bo(ge.AFTER_ELEMENT_DESTROY,e,t),n)}})}destroyElements(e,t){const{nodes:n,edges:i,combos:a}=e;[["combo",a],["edge",i],["node",n]].forEach(([o,A])=>{A.forEach(l=>this.destroyElement(o,l,t))})}clearElement(e){delete this.paletteStyle[e],delete this.defaultStyle[e],delete this.stateStyle[e],delete this.elementMap[e],delete this.shapeTypeMap[e]}alignLayoutResultToElement(e,t){var n,i;const a=(n=e.nodes)===null||n===void 0?void 0:n.find(s=>Z(s)===t);if(a){const s=Sn(this.context.model.getNodeLikeDatum(t)),o=Sn(a),A=bt(s,o);(i=e.nodes)===null||i===void 0||i.forEach(l=>{var c,u,h;!((c=l.style)===null||c===void 0)&&c.x&&(l.style.x+=A[0]),!((u=l.style)===null||u===void 0)&&u.y&&(l.style.y+=A[1]),!((h=l.style)===null||h===void 0)&&h.z&&(l.style.z+=A[2]||0)})}}syncLayoutResult(e,t){return bo(this,void 0,void 0,function*(){const{layout:n,model:i}=this.context;if(!n)return;const a=this.context.options.layout,s=A=>Array.isArray(A)?A.map(l=>Object.assign(Object.assign({},l),{preLayout:!0})):Object.assign(Object.assign({},A),{preLayout:!0}),o=yield n.simulate(a?s(a):void 0);t&&this.alignLayoutResultToElement(o,e),i.updateData(o)})}collapseNode(e,t){return bo(this,void 0,void 0,function*(){var n;const{animation:i,align:a}=t;yield this.syncLayoutResult(e,a);const s=this.computeChangesAndDrawData({stage:"collapse",animation:i});if(!s)return;const{drawData:o}=s,{add:A,remove:l,update:c}=o;this.markDestroyElement(o);const u={animation:i,stage:"collapse",data:o};this.destroyElements(l,u),this.createElements(A,u),this.updateElements(c,u),yield(n=this.context.animation.animate(i,{beforeAnimate:h=>this.emit(new Xr(ge.BEFORE_ANIMATE,mr.COLLAPSE,h,o),u),afterAnimate:h=>this.emit(new Xr(ge.AFTER_ANIMATE,mr.COLLAPSE,h,o),u)},{collapse:{target:e,descendants:Array.from(l.nodes).map(([,h])=>Z(h)),position:Sn(c.nodes.get(e))}}))===null||n===void 0?void 0:n.finished})}expandNode(e,t){return bo(this,void 0,void 0,function*(){var n;const{model:i}=this.context,{animation:a,align:s}=t,o=Sn(i.getNodeData([e])[0]);yield this.syncLayoutResult(e,s);const A=this.computeChangesAndDrawData({stage:"expand",animation:a});if(this.createElements(A.drawData.add,{animation:!1,stage:"expand",target:e}),this.context.animation.clear(),this.computeStyle("expand"),!A)return;const{drawData:l}=A,{update:c,add:u}=l,h={animation:a,stage:"expand",data:l};u.edges.forEach(d=>c.edges.set(Z(d),d)),u.nodes.forEach(d=>c.nodes.set(Z(d),d)),this.updateElements(c,h),yield(n=this.context.animation.animate(a,{beforeAnimate:d=>this.emit(new Xr(ge.BEFORE_ANIMATE,mr.EXPAND,d,l),h),afterAnimate:d=>this.emit(new Xr(ge.AFTER_ANIMATE,mr.EXPAND,d,l),h)},{expand:{target:e,descendants:Array.from(u.nodes).map(([,d])=>Z(d)),position:o}}))===null||n===void 0?void 0:n.finished})}collapseCombo(e,t){return bo(this,void 0,void 0,function*(){var n;const{model:i,element:a}=this.context;if(i.getAncestorsData(e,Et).some(g=>xr(g)))return;const s=a.getElement(e),o=s.getComboPosition(Object.assign(Object.assign({},s.attributes),{collapsed:!0})),A=this.computeChangesAndDrawData({stage:"collapse",animation:t});if(!A)return;const{dataChanges:l,drawData:c}=A;this.markDestroyElement(c);const{update:u,remove:h}=c,d={animation:t,stage:"collapse",data:c};this.destroyElements(h,d),this.updateElements(u,d);const f=g=>Array.from(g).map(([,v])=>Z(v));yield(n=this.context.animation.animate(t,{before:()=>this.emit(new yn(ge.BEFORE_DRAW,{dataChanges:l,animation:t}),d),beforeAnimate:g=>this.emit(new Xr(ge.BEFORE_ANIMATE,mr.COLLAPSE,g,c),d),afterAnimate:g=>this.emit(new Xr(ge.AFTER_ANIMATE,mr.COLLAPSE,g,c),d),after:()=>this.emit(new yn(ge.AFTER_DRAW,{dataChanges:l,animation:t}),d)},{collapse:{target:e,descendants:[...f(h.nodes),...f(h.combos)],position:o}}))===null||n===void 0?void 0:n.finished})}expandCombo(e,t){return bo(this,void 0,void 0,function*(){var n;const{model:i}=this.context,a=Sn(i.getComboData([e])[0]);this.computeStyle("expand");const s=this.computeChangesAndDrawData({stage:"expand",animation:t});if(!s)return;const{dataChanges:o,drawData:A}=s,{add:l,update:c}=A,u={animation:t,stage:"expand",data:A,target:e};this.createElements(l,u),this.updateElements(c,u);const h=d=>Array.from(d).map(([,f])=>Z(f));yield(n=this.context.animation.animate(t,{before:()=>this.emit(new yn(ge.BEFORE_DRAW,{dataChanges:o,animation:t}),u),beforeAnimate:d=>this.emit(new Xr(ge.BEFORE_ANIMATE,mr.EXPAND,d,A),u),afterAnimate:d=>this.emit(new Xr(ge.AFTER_ANIMATE,mr.EXPAND,d,A),u),after:()=>this.emit(new yn(ge.AFTER_DRAW,{dataChanges:o,animation:t}),u)},{expand:{target:e,descendants:[...h(l.nodes),...h(l.combos)],position:a}}))===null||n===void 0?void 0:n.finished})}clear(){this.container.destroy(),this.initContainer(),this.elementMap={},this.shapeTypeMap={},this.defaultStyle={},this.stateStyle={},this.paletteStyle={}}destroy(){this.clear(),this.container.destroy(),this.context={}}}var Eo=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})},ise=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};class ase{get presetOptions(){return{animation:!!qk(this.context.options,!0)}}get options(){const{options:e}=this.context;return e.layout}constructor(e){this.instances=[],this.context=e}getLayoutInstance(){return this.instances}preLayout(e){return Eo(this,void 0,void 0,function*(){var t,n,i,a;const{graph:s,model:o}=this.context,{add:A}=e;Cn(s,new yn(ge.BEFORE_LAYOUT,{type:"pre"}));const l=yield(t=this.context.layout)===null||t===void 0?void 0:t.simulate();(n=l==null?void 0:l.nodes)===null||n===void 0||n.forEach(c=>{const u=Z(c),h=A.nodes.get(u);o.syncNodeLikeDatum(c),h&&Object.assign(h.style,c.style)}),(i=l==null?void 0:l.edges)===null||i===void 0||i.forEach(c=>{const u=Z(c),h=A.edges.get(u);o.syncEdgeDatum(c),h&&Object.assign(h.style,c.style)}),(a=l==null?void 0:l.combos)===null||a===void 0||a.forEach(c=>{const u=Z(c),h=A.combos.get(u);o.syncNodeLikeDatum(c),h&&Object.assign(h.style,c.style)}),Cn(s,new yn(ge.AFTER_LAYOUT,{type:"pre"})),this.transformDataAfterLayout("pre",e)})}postLayout(){return Eo(this,arguments,void 0,function*(e=this.options){if(!e)return;const t=Array.isArray(e)?e:[e],{graph:n}=this.context;Cn(n,new yn(ge.BEFORE_LAYOUT,{type:"post"}));for(let i=0;i<t.length;i++){const a=t[i],s=this.getLayoutData(a),o=Object.assign(Object.assign({},this.presetOptions),a);Cn(n,new yn(ge.BEFORE_STAGE_LAYOUT,{options:o,index:i}));const A=yield this.stepLayout(s,o,i);Cn(n,new yn(ge.AFTER_STAGE_LAYOUT,{options:o,index:i})),a.animation||this.updateElementPosition(A,!1)}Cn(n,new yn(ge.AFTER_LAYOUT,{type:"post"})),this.transformDataAfterLayout("post")})}transformDataAfterLayout(e,t){const n=this.context.transform.getTransformInstance();Object.values(n).forEach(i=>i.afterLayout(e,t))}simulate(){return Eo(this,arguments,void 0,function*(e=this.options){if(!e)return{};const t=Array.isArray(e)?e:[e];let n={};for(let i=0;i<t.length;i++){const a=t[i],s=this.getLayoutData(a);n=yield this.stepLayout(s,Object.assign(Object.assign(Object.assign({},this.presetOptions),a),{animation:!1}),i)}return n})}stepLayout(e,t,n){return Eo(this,void 0,void 0,function*(){return cW(t)?yield this.treeLayout(e,t,n):yield this.graphLayout(e,t,n)})}graphLayout(e,t,n){return Eo(this,void 0,void 0,function*(){const{animation:i,enableWorker:a,iterations:s=300}=t,o=this.initGraphLayout(t);if(!o)return{};if(this.instances[n]=o,this.instance=o,a){const l=o;return this.supervisor=new dee(l.graphData2LayoutModel(e),l.instance,{iterations:s}),Iu(yield this.supervisor.execute())}if(B1(o))return i?yield o.execute(e,{onTick:l=>{this.updateElementPosition(l,!1)}}):(o.execute(e),o.stop(),o.tick(s));const A=yield o.execute(e);if(i){const l=this.updateElementPosition(A,i);yield l==null?void 0:l.finished}return A})}treeLayout(e,t,n){return Eo(this,void 0,void 0,function*(){const{type:i,animation:a}=t,s=va("layout",i);if(!s)return{};const{nodes:o=[],edges:A=[]}=e,l=new Mn({nodes:o.map(f=>({id:Z(f),data:f.data||{}})),edges:A.map(f=>({id:Z(f),source:f.source,target:f.target,data:f.data||{}}))});tse(l);const c={nodes:[],edges:[]},u={nodes:[],edges:[]};l.getRoots(Rr).forEach(f=>{Ns(f,m=>{m.children=l.getSuccessors(m.id)},m=>l.getSuccessors(m.id),"TB");const g=s(f,t),{x:v,y:p,z:y=0}=g;Ns(g,m=>{const{id:B,x:C,y:S,z:F=0}=m;c.nodes.push({id:B,style:{x:v,y:p,z:y}}),u.nodes.push({id:B,style:{x:C,y:S,z:F}})},m=>m.children,"TB")});const d=this.inferTreeLayoutOffset(u);if(c_(u,d),a){c_(c,d),this.updateElementPosition(c,!1);const f=this.updateElementPosition(u,a);yield f==null?void 0:f.finished}return u})}inferTreeLayoutOffset(e){var t;let[n,i]=[1/0,-1/0],[a,s]=[1/0,-1/0];(t=e.nodes)===null||t===void 0||t.forEach(g=>{const{x:v=0,y:p=0}=g.style||{};n=Math.min(n,v),i=Math.max(i,v),a=Math.min(a,p),s=Math.max(s,p)});const{canvas:o}=this.context,A=o.getSize(),[l,c]=o.getCanvasByViewport([0,0]),[u,h]=o.getCanvasByViewport(A);if(n>=l&&i<=u&&a>=c&&s<=h)return[0,0];const d=(l+u)/2,f=(c+h)/2;return[d-(n+i)/2,f-(a+s)/2]}stopLayout(){this.instance&&B1(this.instance)&&(this.instance.stop(),this.instance=void 0),this.supervisor&&(this.supervisor.stop(),this.supervisor=void 0),this.animationResult&&(this.animationResult.finish(),this.animationResult=void 0)}getLayoutData(e){const{nodeFilter:t=()=>!0,comboFilter:n=()=>!0,preLayout:i=!1,isLayoutInvisibleNodes:a=!1}=e,{nodes:s,edges:o,combos:A}=this.context.model.getData(),{element:l,model:c}=this.context,u=p=>l.getElement(p),h=i?p=>{var y;return!a&&(((y=p.style)===null||y===void 0?void 0:y.visibility)==="hidden"||c.getAncestorsData(p.id,Rr).some(xr)||c.getAncestorsData(p.id,Et).some(xr))?!1:t(p)}:p=>{const y=Z(p),m=u(y);return!m||Gl(m)?!1:t(p)},d=s.filter(h),f=A.filter(n),g=new Map(d.map(p=>[Z(p),p]));f.forEach(p=>g.set(Z(p),p));const v=o.filter(({source:p,target:y})=>g.has(p)&&g.has(y));return{nodes:d,edges:v,combos:f}}initGraphLayout(e){var t;const{element:n,viewport:i}=this.context,{type:a,enableWorker:s,animation:o,iterations:A}=e,l=ise(e,["type","enableWorker","animation","iterations"]),[c,u]=i.getCanvasSize(),h=[c/2,u/2],d=(t=e==null?void 0:e.nodeSize)!==null&&t!==void 0?t:(y=>{const m=n==null?void 0:n.getElement(y.id);return m?m.attributes.size:n==null?void 0:n.getElementComputedStyle("node",y).size}),f=va("layout",a);if(!f)return $i.warn(`The layout of ${a} is not registered.`);const g=Object.getPrototypeOf(f.prototype)===vd.prototype?f:hW(f,this.context),v=new g(this.context),p={nodeSize:d,width:c,height:u,center:h};switch(v.id){case"d3-force":case"d3-force-3d":Object.assign(p,{center:{x:c/2,y:u/2,z:0}});break}return zn(v.options,p,l),v}updateElementPosition(e,t){const{model:n,element:i}=this.context;return i?(n.updateData(e),i.draw({animation:t,silence:!0})):null}destroy(){var e;this.stopLayout(),this.context={},(e=this.supervisor)===null||e===void 0||e.kill(),this.supervisor=void 0,this.instance=void 0,this.instances=[],this.animationResult=void 0}}const c_=(r,e)=>{var t;const[n,i]=e;(t=r.nodes)===null||t===void 0||t.forEach(a=>{if(a.style){const{x:s=0,y:o=0}=a.style;a.style.x=s+n,a.style.y=o+i}else a.style={x:n,y:i}})};function sse(r){return[ose].reduce((t,n)=>n(t),r)}function ose(r){return!r.layout||Array.isArray(r.layout)||"preLayout"in r.layout||["antv-dagre","combo-combined","compact-box","circular","concentric","dagre","fishbone","grid","indented","mds","radial","random","snake","dendrogram","mindmap"].includes(r.layout.type)&&(r.layout.preLayout=!0),r}class Ase extends pB{constructor(e){super(e),this.category="plugin",this.setPlugins(this.context.options.plugins||[])}setPlugins(e){this.setExtensions(e)}getPluginInstance(e){const t=this.extensionMap[e];if(t)return t;$i.warn(`Cannot find the plugin ${e}, will try to find it by type.`);const n=this.extensions.find(i=>i.type===e);if(n)return this.extensionMap[n.key]}}const xu=["update-related-edges","collapse-expand-node","collapse-expand-combo","get-edge-actual-ends","arrange-draw-order"];class lse extends pB{constructor(e){super(e),this.category="transform",this.setTransforms(this.context.options.transforms||[])}getTransforms(){}setTransforms(e){this.setExtensions([...xu.slice(0,xu.length-1),...e,xu[xu.length-1]])}getTransformInstance(e){return e?this.extensionMap[e]:this.extensionMap}}var FA=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class cse{get padding(){return ai(this.context.options.padding)}get paddingOffset(){const[e,t,n,i]=this.padding,[a,s,o]=[(i-t)/2,(e-n)/2,0];return[a,s,o]}constructor(e){this.landmarkCounter=0,this.context=e;const[t,n]=this.paddingOffset,{zoom:i,rotation:a,x:s=t,y:o=n}=e.options;this.transform({mode:"absolute",scale:i,translate:[s,o],rotate:a},!1)}get camera(){const{canvas:e}=this.context;return new Proxy(e.getCamera(),{get:(t,n)=>{const a=Object.entries(e.getLayers()).filter(([o])=>!["main"].includes(o)).map(([,o])=>o.getCamera()),s=t[n];if(typeof s=="function")return(...o)=>{const A=s.apply(t,o);return a.forEach(l=>{l[n].apply(l,o)}),A}}})}createLandmark(e){return this.camera.createLandmark(`landmark-${this.landmarkCounter++}`,e)}getAnimation(e){const t=qk(this.context.options,e);return t?Ds(Object.assign({},t),["easing","duration"]):!1}getCanvasSize(){const{canvas:e}=this.context,{width:t=0,height:n=0}=e.getConfig();return[t,n]}getCanvasCenter(){const{canvas:e}=this.context,{width:t=0,height:n=0}=e.getConfig();return[t/2,n/2,0]}getViewportCenter(){const[e,t]=this.camera.getPosition();return[e,t,0]}getGraphCenter(){return this.context.graph.getViewportByCanvas(this.getCanvasCenter())}getZoom(){return this.camera.getZoom()}getRotation(){return this.camera.getRoll()}getTranslateOptions(e){const{camera:t}=this,{mode:n,translate:i=[]}=e,a=this.getZoom(),s=t.getPosition(),o=t.getFocalPoint(),[A,l]=this.getCanvasCenter(),[c=0,u=0,h=0]=i,d=Bi([-c,-u,-h],a);return n==="relative"?{position:Ve(s,d),focalPoint:Ve(o,d)}:{position:Ve([A,l,s[2]],d),focalPoint:Ve([A,l,o[2]],d)}}getRotateOptions(e){const{mode:t,rotate:n=0}=e;return{roll:t==="relative"?this.camera.getRoll()+n:n}}getZoomOptions(e){const{zoomRange:t}=this.context.options,n=this.camera.getZoom(),{mode:i,scale:a=1}=e;return Yt(i==="relative"?n*a:a,...t)}transform(e,t){return FA(this,void 0,void 0,function*(){const{graph:n}=this.context,{translate:i,rotate:a,scale:s,origin:o}=e;this.cancelAnimation();const A=this.getAnimation(t);if(Cn(n,new Eu(ge.BEFORE_TRANSFORM,e)),!a&&s&&!i&&o&&!A){this.camera.setZoomByViewportPoint(this.getZoomOptions(e),o),Cn(n,new Eu(ge.AFTER_TRANSFORM,e));return}const l={};if(i&&Object.assign(l,this.getTranslateOptions(e)),Be(a)&&Object.assign(l,this.getRotateOptions(e)),Be(s)&&Object.assign(l,{zoom:this.getZoomOptions(e)}),A)return Cn(n,new Xr(ge.BEFORE_ANIMATE,mr.TRANSFORM,null,e)),new Promise(c=>{this.transformResolver=c,this.camera.gotoLandmark(this.createLandmark(l),Object.assign(Object.assign({},A),{onfinish:()=>{Cn(n,new Xr(ge.AFTER_ANIMATE,mr.TRANSFORM,null,e)),Cn(n,new Eu(ge.AFTER_TRANSFORM,e)),this.transformResolver=void 0,c()}}))});this.camera.gotoLandmark(this.createLandmark(l),{duration:0}),Cn(n,new Eu(ge.AFTER_TRANSFORM,e))})}fitView(e,t){return FA(this,void 0,void 0,function*(){const[n,i,a,s]=this.padding,{when:o="always",direction:A="both"}=e||{},[l,c]=this.context.canvas.getSize(),u=l-s-i,h=c-n-a,d=this.context.canvas.getBounds(),f=this.getBBoxInViewport(d),[g,v]=is(f),p=A==="x"&&g>=u||A==="y"&&v>=h||A==="both"&&g>=u&&v>=h;if(o==="overflow"&&!p)return yield this.fitCenter({animation:t});const y=u/g,m=h/v,B=A==="x"?y:A==="y"?m:Math.min(y,m),C=this.getAnimation(t);Number.isFinite(B)&&(yield this.transform({mode:"relative",scale:B,translate:Ve(bt(this.getCanvasCenter(),this.getBBoxInViewport(d).center),Bi(this.paddingOffset,B))},C))})}fitCenter(e){return FA(this,void 0,void 0,function*(){const t=this.context.canvas.getBounds();yield this.focus(t,e)})}focusElements(e){return FA(this,arguments,void 0,function*(t,n={}){const{element:i}=this.context;if(!i)return;const a=o=>n.shapes?o.getShape(n.shapes).getRenderBounds():o.getRenderBounds(),s=Ql(t.map(o=>a(i.getElement(o))));yield this.focus(s,n)})}focus(e,t){return FA(this,void 0,void 0,function*(){const n=this.context.graph.getViewportByCanvas(e.center),i=t.position||this.getCanvasCenter(),a=bt(i,n);yield this.transform({mode:"relative",translate:Ve(a,this.paddingOffset)},t.animation)})}getBBoxInViewport(e){const{min:t,max:n}=e,{graph:i}=this.context,[a,s]=i.getViewportByCanvas(t),[o,A]=i.getViewportByCanvas(n),l=new It;return l.setMinMax([a,s,0],[o,A,0]),l}isInViewport(e,t=!1,n=0){const{graph:i}=this.context,a=this.getCanvasSize(),[s,o]=i.getCanvasByViewport([0,0]),[A,l]=i.getCanvasByViewport(a);let c=new It;return c.setMinMax([s,o,0],[A,l,0]),n&&(c=as(c,n)),qo(e)?wi(e,c):t?wV(e,c):c.intersects(e)}cancelAnimation(){var e,t;!((e=this.camera.landmarks)===null||e===void 0)&&e.length&&this.camera.cancelLandmarkAnimation(),(t=this.transformResolver)===null||t===void 0||t.call(this)}}var Tt=function(r,e,t,n){function i(a){return a instanceof t?a:new t(function(s){s(a)})}return new(t||(t=Promise))(function(a,s){function o(c){try{l(n.next(c))}catch(u){s(u)}}function A(c){try{l(n.throw(c))}catch(u){s(u)}}function l(c){c.done?a(c.value):i(c.value).then(o,A)}l((n=n.apply(r,e||[])).next())})};class Bf extends gd{constructor(e){var t;super(),this.options={},this.rendered=!1,this.destroyed=!1,this.context={model:new nse},this.isCollapsingExpanding=!1,this.onResize=Sl(()=>{this.resize()},300),this._setOptions(Object.assign({},Bf.defaultOptions,e),!0),this.context.graph=this,this.options.autoResize&&((t=globalThis.addEventListener)===null||t===void 0||t.call(globalThis,"resize",this.onResize))}getOptions(){return this.options}setOptions(e){this._setOptions(e,!1)}_setOptions(e,t){if(this.updateCanvas(e),Object.assign(this.options,sse(e)),t){const{data:h}=e;h&&this.addData(h);return}const{behaviors:n,combo:i,data:a,edge:s,layout:o,node:A,plugins:l,theme:c,transforms:u}=e;n&&this.setBehaviors(n),a&&this.setData(a),A&&this.setNode(A),s&&this.setEdge(s),i&&this.setCombo(i),o&&this.setLayout(o),c&&this.setTheme(c),l&&this.setPlugins(l),u&&this.setTransforms(u)}getSize(){return this.context.canvas?this.context.canvas.getSize():[this.options.width||0,this.options.height||0]}setSize(e,t){e&&(this.options.width=e),t&&(this.options.height=t),this.resize(e,t)}setZoomRange(e){this.options.zoomRange=e}getZoomRange(){return this.options.zoomRange}setNode(e){this.options.node=e,this.context.model.refreshData()}setEdge(e){this.options.edge=e,this.context.model.refreshData()}setCombo(e){this.options.combo=e,this.context.model.refreshData()}getTheme(){return this.options.theme}setTheme(e){this.options.theme=Te(e)?e(this.getTheme()):e}setLayout(e){this.options.layout=Te(e)?e(this.getLayout()):e}getLayout(){return this.options.layout}setBehaviors(e){var t;this.options.behaviors=Te(e)?e(this.getBehaviors()):e,(t=this.context.behavior)===null||t===void 0||t.setBehaviors(this.options.behaviors)}updateBehavior(e){this.setBehaviors(t=>t.map(n=>typeof n=="object"&&n.key===e.key?Object.assign(Object.assign({},n),e):n))}getBehaviors(){return this.options.behaviors||[]}setPlugins(e){var t;this.options.plugins=Te(e)?e(this.getPlugins()):e,(t=this.context.plugin)===null||t===void 0||t.setPlugins(this.options.plugins)}updatePlugin(e){this.setPlugins(t=>t.map(n=>typeof n=="object"&&n.key===e.key?Object.assign(Object.assign({},n),e):n))}getPlugins(){return this.options.plugins||[]}getPluginInstance(e){return this.context.plugin.getPluginInstance(e)}setTransforms(e){var t;this.options.transforms=Te(e)?e(this.getTransforms()):e,(t=this.context.transform)===null||t===void 0||t.setTransforms(this.options.transforms)}updateTransform(e){this.setTransforms(t=>t.map(n=>typeof n=="object"&&n.key===e.key?Object.assign(Object.assign({},n),e):n)),this.context.model.refreshData()}getTransforms(){return this.options.transforms||[]}getData(){return this.context.model.getData()}hasNode(e){return this.context.model.hasNode(e)}hasEdge(e){return this.context.model.hasEdge(e)}hasCombo(e){return this.context.model.hasCombo(e)}getElementData(e){return Array.isArray(e)?e.map(t=>this.context.model.getElementDataById(t)):this.context.model.getElementDataById(e)}getNodeData(e){return e===void 0?this.context.model.getNodeData():Array.isArray(e)?this.context.model.getNodeData(e):this.context.model.getNodeLikeDatum(e)}getEdgeData(e){return e===void 0?this.context.model.getEdgeData():Array.isArray(e)?this.context.model.getEdgeData(e):this.context.model.getEdgeDatum(e)}getComboData(e){return e===void 0?this.context.model.getComboData():Array.isArray(e)?this.context.model.getComboData(e):this.context.model.getNodeLikeDatum(e)}setData(e){this.context.model.setData(Te(e)?e(this.getData()):e)}addData(e){this.context.model.addData(Te(e)?e(this.getData()):e)}addNodeData(e){this.context.model.addNodeData(Te(e)?e(this.getNodeData()):e)}addEdgeData(e){this.context.model.addEdgeData(Te(e)?e(this.getEdgeData()):e)}addComboData(e){this.context.model.addComboData(Te(e)?e(this.getComboData()):e)}addChildrenData(e,t){this.context.model.addChildrenData(e,t)}updateData(e){this.context.model.updateData(Te(e)?e(this.getData()):e)}updateNodeData(e){this.context.model.updateNodeData(Te(e)?e(this.getNodeData()):e)}updateEdgeData(e){this.context.model.updateEdgeData(Te(e)?e(this.getEdgeData()):e)}updateComboData(e){this.context.model.updateComboData(Te(e)?e(this.getComboData()):e)}removeData(e){this.context.model.removeData(Te(e)?e(this.getData()):e)}removeNodeData(e){this.context.model.removeNodeData(Te(e)?e(this.getNodeData()):e)}removeEdgeData(e){this.context.model.removeEdgeData(Te(e)?e(this.getEdgeData()):e)}removeComboData(e){this.context.model.removeComboData(Te(e)?e(this.getComboData()):e)}getElementType(e){return this.context.model.getElementType(e)}getRelatedEdgesData(e,t="both"){return this.context.model.getRelatedEdgesData(e,t)}getNeighborNodesData(e){return this.context.model.getNeighborNodesData(e)}getAncestorsData(e,t){return this.context.model.getAncestorsData(e,t)}getParentData(e,t){return this.context.model.getParentData(e,t)}getChildrenData(e){return this.context.model.getChildrenData(e)}getDescendantsData(e){return this.context.model.getDescendantsData(e)}getElementDataByState(e,t){return this.context.model.getElementDataByState(e,t)}initCanvas(){return Tt(this,void 0,void 0,function*(){var e;if(this.context.canvas)return yield this.context.canvas.ready;const{container:t="container",width:n,height:i,renderer:a,cursor:s,background:o,canvas:A,devicePixelRatio:l=(e=globalThis.devicePixelRatio)!==null&&e!==void 0?e:1}=this.options;if(t instanceof i_)this.context.canvas=t,s&&t.setCursor(s),a&&t.setRenderer(a),yield t.ready;else{const c=At(t)?document.getElementById(t):t,u=o_(c);this.emit(ge.BEFORE_CANVAS_INIT,{container:c,width:n,height:i});const h=Object.assign(Object.assign({},A),{container:c,width:n||u[0],height:i||u[1],background:o,renderer:a,cursor:s,devicePixelRatio:l}),d=new i_(h);this.context.canvas=d,yield d.ready,this.emit(ge.AFTER_CANVAS_INIT,{canvas:d})}})}updateCanvas(e){var t,n;const{renderer:i,cursor:a,height:s,width:o}=e,A=this.context.canvas;A&&(i&&(this.emit(ge.BEFORE_RENDERER_CHANGE,{renderer:this.options.renderer}),A.setRenderer(i),this.emit(ge.AFTER_RENDERER_CHANGE,{renderer:i})),a&&A.setCursor(a),(Be(o)||Be(s))&&this.setSize((t=o??this.options.width)!==null&&t!==void 0?t:0,(n=s??this.options.height)!==null&&n!==void 0?n:0))}initRuntime(){this.context.options=this.options,this.context.batch||(this.context.batch=new Zae(this.context)),this.context.plugin||(this.context.plugin=new Ase(this.context)),this.context.viewport||(this.context.viewport=new cse(this.context)),this.context.transform||(this.context.transform=new lse(this.context)),this.context.element||(this.context.element=new rse(this.context)),this.context.animation||(this.context.animation=new Xae(this.context)),this.context.layout||(this.context.layout=new ase(this.context)),this.context.behavior||(this.context.behavior=new Jae(this.context))}prepare(){return Tt(this,void 0,void 0,function*(){if(yield Promise.resolve(),this.destroyed){console.error(ha("The graph instance has been destroyed"));return}yield this.initCanvas(),this.initRuntime()})}render(){return Tt(this,void 0,void 0,function*(){if(yield this.prepare(),Cn(this,new yn(ge.BEFORE_RENDER)),this.options.layout)if(!this.rendered&&uW(this.options.layout)){const e=yield this.context.element.preLayoutDraw({type:"render"});yield Promise.all([e==null?void 0:e.finished,this.autoFit()])}else{const e=this.context.element.draw({type:"render"});yield Promise.all([e==null?void 0:e.finished,this.context.layout.postLayout()]),yield this.autoFit()}else{const e=this.context.element.draw({type:"render"});yield Promise.all([e==null?void 0:e.finished,this.autoFit()])}this.rendered=!0,Cn(this,new yn(ge.AFTER_RENDER))})}draw(){return Tt(this,void 0,void 0,function*(){var e;yield this.prepare(),yield(e=this.context.element.draw())===null||e===void 0?void 0:e.finished})}layout(e){return Tt(this,void 0,void 0,function*(){yield this.context.layout.postLayout(e)})}stopLayout(){this.context.layout.stopLayout()}clear(){return Tt(this,void 0,void 0,function*(){const{model:e,element:t}=this.context;e.setData({}),e.clearChanges(),t==null||t.clear()})}destroy(){var e;Cn(this,new yn(ge.BEFORE_DESTROY));const{layout:t,animation:n,element:i,model:a,canvas:s,behavior:o,plugin:A}=this.context;A==null||A.destroy(),o==null||o.destroy(),t==null||t.destroy(),n==null||n.destroy(),i==null||i.destroy(),a.destroy(),s==null||s.destroy(),this.options={},this.context={},this.off(),(e=globalThis.removeEventListener)===null||e===void 0||e.call(globalThis,"resize",this.onResize),this.destroyed=!0,Cn(this,new yn(ge.AFTER_DESTROY))}getCanvas(){return this.context.canvas}resize(e,t){var n;const i=o_((n=this.context.canvas)===null||n===void 0?void 0:n.getContainer()),a=[e||i[0],t||i[1]];if(!this.context.canvas)return;const s=this.context.canvas.getSize();Xt(a,s)||(Cn(this,new yn(ge.BEFORE_SIZE_CHANGE,{size:a})),this.context.canvas.resize(...a),Cn(this,new yn(ge.AFTER_SIZE_CHANGE,{size:a})))}fitView(e,t){return Tt(this,void 0,void 0,function*(){var n;yield(n=this.context.viewport)===null||n===void 0?void 0:n.fitView(e,t)})}fitCenter(e){return Tt(this,void 0,void 0,function*(){var t;yield(t=this.context.viewport)===null||t===void 0?void 0:t.fitCenter({animation:e})})}autoFit(){return Tt(this,void 0,void 0,function*(){const{autoFit:e}=this.context.options;if(e)if(At(e))e==="view"?yield this.fitView():e==="center"&&(yield this.fitCenter());else{const{type:t,animation:n}=e;t==="view"?yield this.fitView(e.options,n):t==="center"&&(yield this.fitCenter(n))}})}focusElement(e,t){return Tt(this,void 0,void 0,function*(){var n;yield(n=this.context.viewport)===null||n===void 0?void 0:n.focusElements(Array.isArray(e)?e:[e],{animation:t})})}zoomBy(e,t,n){return Tt(this,void 0,void 0,function*(){yield this.context.viewport.transform({mode:"relative",scale:e,origin:n},t)})}zoomTo(e,t,n){return Tt(this,void 0,void 0,function*(){yield this.context.viewport.transform({mode:"absolute",scale:e,origin:n},t)})}getZoom(){return this.context.viewport.getZoom()}rotateBy(e,t,n){return Tt(this,void 0,void 0,function*(){yield this.context.viewport.transform({mode:"relative",rotate:e,origin:n},t)})}rotateTo(e,t,n){return Tt(this,void 0,void 0,function*(){yield this.context.viewport.transform({mode:"absolute",rotate:e,origin:n},t)})}getRotation(){return this.context.viewport.getRotation()}translateBy(e,t){return Tt(this,void 0,void 0,function*(){yield this.context.viewport.transform({mode:"relative",translate:e},t)})}translateTo(e,t){return Tt(this,void 0,void 0,function*(){yield this.context.viewport.transform({mode:"absolute",translate:e},t)})}getPosition(){return bt([0,0],this.getCanvasByViewport([0,0]))}translateElementBy(e,t){return Tt(this,arguments,void 0,function*(n,i,a=!0){var s,o;const[A,l]=un(n)?[n,(s=i)!==null&&s!==void 0?s:!0]:[{[n]:i},a];Object.entries(A).forEach(([c,u])=>this.context.model.translateNodeLikeBy(c,u)),yield(o=this.context.element.draw({animation:l,stage:"translate"}))===null||o===void 0?void 0:o.finished})}translateElementTo(e,t){return Tt(this,arguments,void 0,function*(n,i,a=!0){var s,o;const[A,l]=un(n)?[n,(s=i)!==null&&s!==void 0?s:!0]:[{[n]:i},a];Object.entries(A).forEach(([c,u])=>this.context.model.translateNodeLikeTo(c,u)),yield(o=this.context.element.draw({animation:l,stage:"translate"}))===null||o===void 0?void 0:o.finished})}getElementPosition(e){return this.context.model.getElementPosition(e)}getElementRenderStyle(e){return V1(this.context.element.getElement(e).attributes,["context"])}setElementVisibility(e,t){return Tt(this,arguments,void 0,function*(n,i,a=!0){var s,o;const[A,l]=un(n)?[n,(s=i)!==null&&s!==void 0?s:!0]:[{[n]:i},a],c={nodes:[],edges:[],combos:[]};Object.entries(A).forEach(([d,f])=>{const g=this.getElementType(d);c[`${g}s`].push({id:d,style:{visibility:f}})});const{model:u,element:h}=this.context;u.preventUpdateNodeLikeHierarchy(()=>{u.updateData(c)}),yield(o=h.draw({animation:l,stage:"visibility"}))===null||o===void 0?void 0:o.finished})}showElement(e,t){return Tt(this,void 0,void 0,function*(){const n=Array.isArray(e)?e:[e];yield this.setElementVisibility(Object.fromEntries(n.map(i=>[i,"visible"])),t)})}hideElement(e,t){return Tt(this,void 0,void 0,function*(){const n=Array.isArray(e)?e:[e];yield this.setElementVisibility(Object.fromEntries(n.map(i=>[i,"hidden"])),t)})}getElementVisibility(e){var t,n;const i=this.context.element.getElement(e);return(n=(t=i==null?void 0:i.style)===null||t===void 0?void 0:t.visibility)!==null&&n!==void 0?n:"visible"}setElementZIndex(e,t){return Tt(this,void 0,void 0,function*(){var n;const i={nodes:[],edges:[],combos:[]},a=un(e)?e:{[e]:t};Object.entries(a).forEach(([A,l])=>{const c=this.getElementType(A);i[`${c}s`].push({id:A,style:{zIndex:l}})});const{model:s,element:o}=this.context;s.preventUpdateNodeLikeHierarchy(()=>s.updateData(i)),yield(n=o.draw({animation:!1,stage:"zIndex"}))===null||n===void 0?void 0:n.finished})}frontElement(e){return Tt(this,void 0,void 0,function*(){const t=Array.isArray(e)?e:[e],{model:n}=this.context,i={};t.map(a=>{const s=n.getFrontZIndex(a);if(n.getElementType(a)==="combo"){const A=n.getAncestorsData(a,Et).at(-1)||this.getComboData(a),l=[A,...n.getDescendantsData(Z(A))],c=s-A_(A);l.forEach(h=>{i[Z(h)]=this.getElementZIndex(Z(h))+c});const{internal:u}=h1(l.map(Z),h=>n.getRelatedEdgesData(h));u.forEach(h=>{const d=Z(h);i[d]=this.getElementZIndex(d)+c})}else i[a]=s}),yield this.setElementZIndex(i)})}getElementZIndex(e){return A_(this.context.model.getElementDataById(e))}setElementState(e,t){return Tt(this,arguments,void 0,function*(n,i,a=!0){var s,o;const[A,l]=un(n)?[n,(s=i)!==null&&s!==void 0?s:!0]:[{[n]:i},a],c=h=>h?Array.isArray(h)?h:[h]:[],u={nodes:[],edges:[],combos:[]};Object.entries(A).forEach(([h,d])=>{const f=this.getElementType(h);u[`${f}s`].push({id:h,states:c(d)})}),this.updateData(u),yield(o=this.context.element.draw({animation:l,stage:"state"}))===null||o===void 0?void 0:o.finished})}getElementState(e){return this.context.model.getElementState(e)}getElementRenderBounds(e){return this.context.element.getElement(e).getRenderBounds()}collapseElement(e){return Tt(this,arguments,void 0,function*(t,n=!0){const{model:i,element:a}=this.context;if(xr(i.getNodeLikeData([t])[0])||this.isCollapsingExpanding)return;typeof n=="boolean"&&(n={animation:n,align:!1});const s=i.getElementType(t);yield this.frontElement(t),this.isCollapsingExpanding=!0,i.updateData(s==="node"?{nodes:[{id:t,style:{collapsed:!0}}]}:{combos:[{id:t,style:{collapsed:!0}}]}),s==="node"?yield a.collapseNode(t,n):s==="combo"&&(yield a.collapseCombo(t,!!n.animation)),this.isCollapsingExpanding=!1})}expandElement(e){return Tt(this,arguments,void 0,function*(t,n=!0){const{model:i,element:a}=this.context;if(!xr(i.getNodeLikeData([t])[0])||this.isCollapsingExpanding)return;typeof n=="boolean"&&(n={animation:n,align:!1});const s=i.getElementType(t);this.isCollapsingExpanding=!0,i.updateData(s==="node"?{nodes:[{id:t,style:{collapsed:!1}}]}:{combos:[{id:t,style:{collapsed:!1}}]}),s==="node"?yield a.expandNode(t,n):s==="combo"&&(yield a.expandCombo(t,!!n.animation)),this.isCollapsingExpanding=!1})}setElementCollapsibility(e,t){const n=this.getElementType(e);n==="node"?this.updateNodeData([{id:e,style:{collapsed:t}}]):n==="combo"&&this.updateComboData([{id:e,style:{collapsed:t}}])}toDataURL(){return Tt(this,arguments,void 0,function*(e={}){return this.context.canvas.toDataURL(e)})}getCanvasByViewport(e){return this.context.canvas.getCanvasByViewport(e)}getViewportByCanvas(e){return this.context.canvas.getViewportByCanvas(e)}getClientByCanvas(e){return this.context.canvas.getClientByCanvas(e)}getCanvasByClient(e){return this.context.canvas.getCanvasByClient(e)}getViewportCenter(){return this.context.viewport.getViewportCenter()}getCanvasCenter(){return this.context.viewport.getCanvasCenter()}on(e,t,n){return super.on(e,t,n)}once(e,t){return super.once(e,t)}off(e,t){return super.off(e,t)}}Bf.defaultOptions={autoResize:!1,theme:"light",rotation:0,zoom:1,zoomRange:[.01,10]};var use=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t};function hse(r,e){const{getNodeData:t=(o,A)=>{if(o.depth=A,!o.children)return o;const{children:l}=o,c=use(o,["children"]);return Object.assign(Object.assign({},c),{children:l.map(u=>u.id)})},getEdgeData:n=(o,A)=>({source:o.id,target:A.id}),getChildren:i=o=>o.children||[]}={},a=[],s=[];return Ns(r,(o,A)=>{a.push(t(o,A));const l=i(o);for(const c of l)s.push(n(o,c))},o=>i(o),"TB"),{nodes:a,edges:s}}class dse extends ls{beforeDraw(e){const{add:t,update:n}=e,{model:i}=this.context;return[...t.edges.entries(),...n.edges.entries()].forEach(([,a])=>{_U(i,a)}),e}}const _U=(r,e)=>{const{source:t,target:n}=e,i=r.getElementDataById(t),a=r.getElementDataById(n),s=Qx(i,u=>r.getParentData(u,Et)),o=Qx(a,u=>r.getParentData(u,Et)),A=Z(s),l=Z(o),c={sourceNode:A,targetNode:l};return e.style?Object.assign(e.style,c):e.style=c,e},fse=(r,e,t)=>{const[n,i]=e,[a,s]=t;if(i===n)return a;const o=(r-n)/(i-n);return a+o*(s-a)},gse=(r,e,t)=>{const[n,i]=e,[a,s]=t,o=Math.log(r-n+1)/Math.log(i-n+1);return a+o*(s-a)},vse=(r,e,t,n=2)=>{const[i,a]=e,[s,o]=t,A=Math.pow((r-i)/(a-i),n);return s+A*(o-s)},pse=(r,e,t)=>{const[n,i]=e,[a,s]=t,o=Math.sqrt((r-n)/(i-n));return a+o*(s-a)};class bf extends ls{constructor(e,t){super(e,zn({},bf.defaultOptions,t)),this.assignSizeByCentrality=(n,i,a,s,o,A)=>{const l=[i,a],c=[s[0],o[0]],u=[s[1],o[1]],h=[s[2],o[2]],d=(f,g)=>{if(typeof A=="function")return A(f,l,g);switch(A){case"linear":return fse(f,l,g);case"log":return gse(f,l,g);case"pow":return vse(f,l,g,2);case"sqrt":return pse(f,l,g);default:return g[0]}};return[d(n,c),d(n,u),d(n,h)]}}beforeDraw(e){const{model:t}=this.context,n=t.getNodeData(),i=Gr(this.options.maxSize),a=Gr(this.options.minSize),s=this.getCentralities(this.options.centrality),o=s.size>0?Math.max(...s.values()):0,A=s.size>0?Math.min(...s.values()):0;return n.forEach(l=>{var c;const u=this.assignSizeByCentrality(s.get(Z(l))||0,A,o,a,i,this.options.scale),h=(c=this.context.element)===null||c===void 0?void 0:c.getElement(Z(l)),d={size:u};this.assignLabelStyle(d,u,l,h),(!h||!Du(d,h.attributes))&&Hr(e,h?"update":"add","node",zn(l,{style:d}),!0)}),e}assignLabelStyle(e,t,n,i){var a;const s=i?i.config.style:(a=this.context.element)===null||a===void 0?void 0:a.getElementComputedStyle("node",n);if(Object.assign(e,Ds(s,["labelFontSize","labelLineHeight"])),this.options.mapLabelSize){const o=this.getLabelSizeByNodeSize(t,1/0,Number(e.labelFontSize));Object.assign(e,{labelFontSize:o,labelLineHeight:o+mV(e.labelPadding)})}return e}getLabelSizeByNodeSize(e,t,n){const i=Math.min(...e)/2,[a,s]=Array.isArray(this.options.mapLabelSize)?this.options.mapLabelSize:[n,t];return Math.min(s,Math.max(i,a))}getCentralities(e){const{model:t}=this.context,n=t.getData();if(typeof e=="function")return e(n);const i=t.getRelatedEdgesData.bind(t);return aL(n,i,e)}}bf.defaultOptions={centrality:{type:"degree"},maxSize:80,minSize:20,scale:"linear",mapLabelSize:!1};class Ef extends ls{constructor(e,t){super(e,Object.assign({},Ef.defaultOptions,t))}get ref(){return this.context.model.getRootsData()[0]}afterLayout(){var e;const t=Sn(this.ref),{graph:n,model:i}=this.context;(e=i.getData().nodes)===null||e===void 0||e.forEach(s=>{var o;if(Z(s)===Z(this.ref))return;const A=oL(bt(Sn(s),t)),l=Math.abs(A)>Math.PI/2,c=!s.children||s.children.length===0,u=Z(s),h=(o=this.context.element)===null||o===void 0?void 0:o.getElement(u);if(!h||!h.isVisible())return;const d=Gr(n.getElementRenderStyle(u).size)[0]/2,f=(c?1:-1)*(d+this.options.offset),g=[["translate",f*Math.cos(A),f*Math.sin(A)],["rotate",l?Br(A)+180:Br(A)]];i.updateNodeData([{id:Z(s),style:{labelTextAlign:l===c?"right":"left",labelTextBaseline:"middle",labelTransform:g}}])}),n.draw()}}Ef.defaultOptions={offset:5};const yse="quadratic",u_=["top","top-right","right","right-bottom","bottom","bottom-left","left","left-top"];class xf extends ls{constructor(e,t){super(e,Object.assign({},xf.defaultOptions,t)),this.cacheMergeStyle=new Map,this.getAffectedParallelEdges=n=>{const{add:{edges:i},update:{nodes:a,edges:s,combos:o},remove:{edges:A}}=n,{model:l}=this.context,c=new Map,u=(f,g)=>{l.getRelatedEdgesData(g).forEach(p=>!c.has(Z(p))&&c.set(Z(p),p))};a.forEach(u),o.forEach(u);const h=f=>{const g=new Set(n.remove.edges.keys()),v=l.getEdgeData().filter(p=>!g.has(Z(p))).map(p=>_U(l,p));mse(f,v).forEach(p=>{const y=Z(p);c.has(y)||c.set(y,p)})};if(A.size&&A.forEach(h),i.size&&i.forEach(h),s.size){const f=KN(tb(l.getChanges())).update.edges;s.forEach(g=>{var v;h(g);const p=(v=f.find(y=>Z(y.value)===Z(g)))===null||v===void 0?void 0:v.original;p&&!vb(g,p)&&h(p)})}Qi(this.options.edges)||c.forEach((f,g)=>!this.options.edges.includes(g)&&c.delete(g));const d=l.getEdgeData().map(Z);return new Map([...c].sort((f,g)=>d.indexOf(f[0])-d.indexOf(g[0])))},this.applyBundlingStyle=(n,i,a)=>{const{edgeMap:s,reverses:o}=h_(i);s.forEach(A=>{A.forEach((l,c,u)=>{var h;const d=u.length,f=l.style||{};if(l.source===l.target){const p=u_.length;f.loopPlacement=u_[c%p],f.loopDist=Math.floor(c/p)*a+50}else if(d===1)f.curveOffset=0;else{const p=(c%2===0?1:-1)*(o[`${l.source}|${l.target}|${c}`]?-1:1);f.curveOffset=d%2===1?p*Math.ceil(c/2)*a*2:p*(Math.floor(c/2)*a*2+a)}const g=Object.assign(l,{type:yse,style:f}),v=(h=this.context.element)===null||h===void 0?void 0:h.getElement(Z(l));(!v||!Du(g.style,v.attributes))&&Hr(n,v?"update":"add","edge",g,!0)})})},this.resetEdgeStyle=n=>{const i=n.style||{},a=this.cacheMergeStyle.get(Z(n))||{};return Object.keys(a).forEach(s=>{Xt(i[s],a[s])&&(n[s]?i[s]=n[s]:delete i[s])}),Object.assign(n,{style:i})},this.applyMergingStyle=(n,i)=>{const{edgeMap:a,reverses:s}=h_(i);a.forEach(o=>{var A;if(o.length===1){const c=o[0],u=(A=this.context.element)===null||A===void 0?void 0:A.getElement(Z(c)),h=this.resetEdgeStyle(c);(!u||!Du(h,u.attributes))&&Hr(n,u?"update":"add","edge",h);return}const l=o.map(({source:c,target:u,style:h={}},d)=>{const{startArrow:f,endArrow:g}=h,v={},[p,y]=s[`${c}|${u}|${d}`]?["endArrow","startArrow"]:["startArrow","endArrow"];return sl(f)&&(v[p]=f),sl(g)&&(v[y]=g),v}).reduce((c,u)=>Object.assign(Object.assign({},c),u),{});o.forEach((c,u,h)=>{var d;if(u!==0){Hr(n,"remove","edge",c);return}const f=Object.assign({},Te(this.options.style)?this.options.style(h):this.options.style,{childrenData:h});this.cacheMergeStyle.set(Z(c),f);const g=Object.assign(Object.assign({},c),{type:"line",style:Object.assign(Object.assign(Object.assign({},c.style),l),f)}),v=(d=this.context.element)===null||d===void 0?void 0:d.getElement(Z(c));(!v||!Du(g.style,v.attributes))&&Hr(n,v?"update":"add","edge",g,!0)})})}}beforeDraw(e){const t=this.getAffectedParallelEdges(e);return t.size===0||(this.options.mode==="bundle"?this.applyBundlingStyle(e,t,this.options.distance):this.applyMergingStyle(e,t)),e}}xf.defaultOptions={mode:"bundle",distance:15};const h_=r=>{const e=new Map,t=new Set,n={},i=new Map;for(const[a,s]of r){if(t.has(a))continue;const{source:o,target:A}=s,l=`${o}-${A}`;e.has(l)||(e.set(l,[]),i.set(l,new Set));const c=e.get(l),u=i.get(l);c&&u&&!u.has(a)&&(c.push(s),u.add(a),t.add(a));for(const[h,d]of r)if(!(t.has(h)||h===a)&&vb(s,d)){const f=e.get(l),g=i.get(l);f&&g&&!g.has(h)&&(f.push(d),g.add(h),o===d.target&&A===d.source&&(n[`${d.source}|${d.target}|${f.length-1}`]=!0),t.add(h))}}return{edgeMap:e,reverses:n}},mse=(r,e,t)=>e.filter(n=>vb(n,r)),vb=(r,e)=>{const{sourceNode:t,targetNode:n}=r.style||{},{sourceNode:i,targetNode:a}=e.style||{};return t===i&&n===a||t===a&&n===i};class wse extends ls{beforeDraw(e,t){const{stage:n}=t;if(n==="visibility")return e;const{model:i}=this.context,{update:{nodes:a,edges:s,combos:o}}=e,A=(l,c)=>{i.getRelatedEdgesData(c).forEach(h=>!s.has(Z(h))&&s.set(Z(h),h))};return a.forEach(A),o.forEach(A),e}}const Bse={animation:{"combo-collapse":Zk,"combo-expand":vV,"node-collapse":Yk,"node-expand":fV,"path-in":Xk,"path-out":gV,fade:hV,translate:dV},behavior:{"brush-select":Nl,"click-select":nd,"collapse-expand":hd,"create-edge":dd,"drag-canvas":fd,"drag-element-force":fW,"drag-element":Kl,"fix-element-size":pd,"focus-element":yd,"hover-activate":md,"lasso-select":vW,"auto-adapt-label":Jh,"optimize-viewport-transform":wd,"scroll-canvas":Bd,"zoom-canvas":bd},combo:{circle:f9,rect:g9},edge:{cubic:Js,line:UL,polyline:ud,quadratic:Dl,"cubic-horizontal":Ad,"cubic-radial":ld,"cubic-vertical":cd},layout:{"antv-dagre":k$,"combo-combined":z7,"compact-box":CW,"d3-force":vY,"force-atlas2":LJ,circular:N$,concentric:w1,dagre:zd,dendrogram:_W,fishbone:Vd,force:mQ,fruchterman:UJ,grid:RJ,indented:QW,mds:BQ,mindmap:DW,radial:qJ,random:tee,snake:jd},node:{circle:Rl,diamond:bj,ellipse:ad,hexagon:Fj,html:sd,image:OL,rect:h9,star:d9,donut:id,triangle:od},palette:{spectral:pee,tableau:yee,oranges:mee,greens:wee,blues:Bee},theme:{dark:Rae,light:Hae},plugin:{"bubble-sets":$d,"edge-bundling":Xd,"edge-filter-lens":Zd,"grid-line":tf,background:Wd,contextmenu:Yd,fisheye:Jd,fullscreen:ef,history:nf,hull:af,legend:df,minimap:ff,snapline:gf,timebar:vf,title:Cae,toolbar:pf,tooltip:yf,watermark:mf},transform:{"arrange-draw-order":Gae,"collapse-expand-combo":Kae,"collapse-expand-node":zae,"get-edge-actual-ends":dse,"map-node-size":bf,"place-radial-labels":Ef,"process-parallel-edges":xf,"update-related-edges":wse},shape:{circle:zi,ellipse:_l,group:Tn,html:Ys,image:bB,line:Ks,path:rr,polygon:Xs,polyline:Dh,rect:Vn,text:Zs,label:ji,badge:Zo}};function bse(){Object.entries(Bse).forEach(([r,e])=>{Object.entries(e).forEach(([t,n])=>{MU(r,t,n)})})}bse();class Rs extends Dl{static tyoe="ant-quadratic";static lineDashGap=5;onCreate(){this.shapeMap.key.animate([{lineDashOffset:Rs.lineDashGap*2},{lineDashOffset:0}],{duration:500,iterations:1/0,delay:0})}}MU(Wo.EDGE,Rs.tyoe,Rs);const Ise=jU({__name:"TrackGraph",props:{nodes:{},queryResult:{},showUnitResults:{},filterUnitResults:{}},setup(r){const e=r,t=$U(),n=v=>e.nodes[v],i=uA(()=>lP(e.queryResult.unitResults.asJsReadonlyArrayView().flatMap(v=>v.context.toArray()),v=>v.id)),a=uA(()=>VU(e.nodes,i.value)),s=v=>({id:v.id.toString(),children:a.value.getChildren(v).map(s)}),o=uA(()=>hse(s(a.value.topNode))),A=v=>a.value.getChildren(v).length>0,l=uA(()=>{const v={},p={},y=O=>{const _=`#${O.source.id}-${O.target.id}`,k=v[_]||0;v[_]=k+1;const L=_+(k>0?`-${k}`:"");return p[L]=O,{id:L,source:String(O.source.id),target:String(O.target.id)}},B=e.showUnitResults.map(O=>({result:O,pathList:O.getNodeConnectPath(ZU).asJsReadonlyArrayView().concat()})).map(({result:O,pathList:_})=>{const k=_.map(L=>y(L));return{result:O,edgeGroup:k}}),C=B.flatMap(O=>O.edgeGroup),S=O=>p[O.id].formatConnectOffset,F=O=>B.findIndex(_=>_.edgeGroup.some(k=>k.id===O.id));return{groupList:B,edgeList:C,getLabel:S,getColor:O=>{const _=e.showUnitResults.indexOf(B[F(O)].result);return yb[_%yb.length]},getGroupIndex:F}}),c=v=>{var p;return((p=v.id)==null?void 0:p[0])==="#"},u=(v,p,y,m)=>Math.sqrt(Math.pow(Math.abs(v-y),2)+Math.pow(Math.abs(p-m),2)),h=(v,p)=>{var B,C,S,F;const y=v.getNodeData(p.source),m=v.getNodeData(p.target);return u(((B=y.style)==null?void 0:B.x)||0,((C=y.style)==null?void 0:C.y)||0,((S=m.style)==null?void 0:S.x)||0,((F=m.style)==null?void 0:F.y)||0)},d=/\d+/,f=qU();WU(()=>{f.value&&f.value.destroy()}),pb(t,async()=>{if(!t.value)return;const v=new Bf({container:t.value,data:o.value,autoFit:"view",padding:[24,48],animation:!1,node:{type(p){const y=n(p.id);return A(y)?"triangle":"rect"},style(p){const y=n(p.id),m=e.queryResult.target.id===y.id,B=a.value.isPlaceholder(y),C=zU(y);return{size:A(y)?4:1,direction:A(y)?"down":void 0,fill:A(y)?"#767C82":"#E3E3E3",pointerEvents:"none",labelPlacement:"right",labelText:a.value.getLabel(y),labelOffsetX:2,labelFontWeight:C&&!B?"bold":void 0,labelOpacity:B?.5:void 0,labelPointerEvents:"none",labelStroke:m?"#0FF":void 0}}},edge:{type(p){return c(p)?Rs.tyoe:"polyline"},style(p){if(c(p)){const y=h(v,p),m=l.value.getLabel(p),B=m.match(d);return{curveOffset:30*(Number(p.source)>Number(p.target)?1:-1),stroke:l.value.getColor(p)||"#FF7FFF",zIndex:1+l.value.getGroupIndex(p),pointerEvents:"none",endArrow:!0,endArrowOpacity:.5,endArrowPointerEvents:"none",labelText:m,labelFill:"#F00",labelFontSize:B&&y<50?8:12,labelBackground:!0,labelBackgroundStroke:"#FF00FF",labelPadding:B?[0,1,-2,0]:[0,0,-1,0],labelBackgroundLineWidth:1,labelBackgroundRadius:2,labelBackgroundPointerEvents:"none",labelOffsetX:y<50?-5:0,labelPointerEvents:"none",lineDash:[Rs.lineDashGap,Rs.lineDashGap]}}return{router:{type:"orth"},stroke:"#E3E3E3",pointerEvents:"none"}}},layout:{type:"indented",direction:"LR",indent:20,getHeight:()=>0},behaviors:["drag-canvas","zoom-canvas"]});await v.render(),f.value=v});const g=uA(()=>{const v=e.filterUnitResults;return v!=null&&v.length?l.value.groupList.filter(p=>v.includes(p.result)).flatMap(p=>p.edgeGroup):[]});return pb([f,g],async([v,p],[y,m])=>{if(v){if(p!==m){const B=m.filter(S=>!p.some(F=>F.id===S.id)),C=p.filter(S=>!m.some(F=>F.id===S.id));if(!B.length&&!C.length)return;v.removeEdgeData(B.map(S=>S.id)),await v.draw(),v.addEdgeData(C)}else v.addEdgeData(p);await v.draw()}}),(v,p)=>(XU(),YU("div",{ref_key:"el",ref:t,class:"TrackGraph"},null,512))}});export{Ise as default};
|
|
134
|
+
//# sourceMappingURL=TrackGraph-S8eceX9R.js.map
|