@linkurious/ogma-annotations-react 1.1.24 → 1.1.25

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/index.js CHANGED
@@ -1,44 +1,15 @@
1
- (function(B,X){typeof exports=="object"&&typeof module<"u"?X(exports,require("react"),require("@linkurious/ogma-react")):typeof define=="function"&&define.amd?define(["exports","react","@linkurious/ogma-react"],X):(B=typeof globalThis<"u"?globalThis:B||self,X((B["/home/jenkins/agent/workspace/_ogma-annotations-control_master/packages/ogma-annotations-react/src/index"]=B["/home/jenkins/agent/workspace/_ogma-annotations-control_master/packages/ogma-annotations-react/src/index"]||{},B["/home/jenkins/agent/workspace/_ogma-annotations-control_master/packages/ogma-annotations-react/src/index"].ts={}),B.React,B.OgmaReact))})(this,function(B,X,Zr){"use strict";var pe={exports:{}},Vt={};/**
2
- * @license React
3
- * react-jsx-runtime.production.min.js
4
- *
5
- * Copyright (c) Facebook, Inc. and its affiliates.
6
- *
7
- * This source code is licensed under the MIT license found in the
8
- * LICENSE file in the root directory of this source tree.
9
- */var vr;function Qr(){if(vr)return Vt;vr=1;var u=X,e=Symbol.for("react.element"),o=Symbol.for("react.fragment"),n=Object.prototype.hasOwnProperty,l=u.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,h={key:!0,ref:!0,__self:!0,__source:!0};function d(g,f,v){var y,A={},k=null,S=null;v!==void 0&&(k=""+v),f.key!==void 0&&(k=""+f.key),f.ref!==void 0&&(S=f.ref);for(y in f)n.call(f,y)&&!h.hasOwnProperty(y)&&(A[y]=f[y]);if(g&&g.defaultProps)for(y in f=g.defaultProps,f)A[y]===void 0&&(A[y]=f[y]);return{$$typeof:e,type:g,key:k,ref:S,props:A,_owner:l.current}}return Vt.Fragment=o,Vt.jsx=d,Vt.jsxs=d,Vt}var Gt={};/**
10
- * @license React
11
- * react-jsx-runtime.development.js
12
- *
13
- * Copyright (c) Facebook, Inc. and its affiliates.
14
- *
15
- * This source code is licensed under the MIT license found in the
16
- * LICENSE file in the root directory of this source tree.
17
- */var mr;function tn(){return mr||(mr=1,process.env.NODE_ENV!=="production"&&function(){var u=X,e=Symbol.for("react.element"),o=Symbol.for("react.portal"),n=Symbol.for("react.fragment"),l=Symbol.for("react.strict_mode"),h=Symbol.for("react.profiler"),d=Symbol.for("react.provider"),g=Symbol.for("react.context"),f=Symbol.for("react.forward_ref"),v=Symbol.for("react.suspense"),y=Symbol.for("react.suspense_list"),A=Symbol.for("react.memo"),k=Symbol.for("react.lazy"),S=Symbol.for("react.offscreen"),R=Symbol.iterator,C="@@iterator";function L(t){if(t===null||typeof t!="object")return null;var s=R&&t[R]||t[C];return typeof s=="function"?s:null}var I=u.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function _(t){{for(var s=arguments.length,c=new Array(s>1?s-1:0),p=1;p<s;p++)c[p-1]=arguments[p];z("error",t,c)}}function z(t,s,c){{var p=I.ReactDebugCurrentFrame,m=p.getStackAddendum();m!==""&&(s+="%s",c=c.concat([m]));var b=c.map(function(w){return String(w)});b.unshift("Warning: "+s),Function.prototype.apply.call(console[t],console,b)}}var W=!1,rt=!1,it=!1,Kt=!1,Zt=!1,_e;_e=Symbol.for("react.module.reference");function $t(t){return!!(typeof t=="string"||typeof t=="function"||t===n||t===h||Zt||t===l||t===v||t===y||Kt||t===S||W||rt||it||typeof t=="object"&&t!==null&&(t.$$typeof===k||t.$$typeof===A||t.$$typeof===d||t.$$typeof===g||t.$$typeof===f||t.$$typeof===_e||t.getModuleId!==void 0))}function zt(t,s,c){var p=t.displayName;if(p)return p;var m=s.displayName||s.name||"";return m!==""?c+"("+m+")":c}function Se(t){return t.displayName||"Context"}function at(t){if(t==null)return null;if(typeof t.tag=="number"&&_("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t;switch(t){case n:return"Fragment";case o:return"Portal";case h:return"Profiler";case l:return"StrictMode";case v:return"Suspense";case y:return"SuspenseList"}if(typeof t=="object")switch(t.$$typeof){case g:var s=t;return Se(s)+".Consumer";case d:var c=t;return Se(c._context)+".Provider";case f:return zt(t,t.render,"ForwardRef");case A:var p=t.displayName||null;return p!==null?p:at(t.type)||"Memo";case k:{var m=t,b=m._payload,w=m._init;try{return at(w(b))}catch{return null}}}return null}var $=Object.assign,ht=0,J,ct,Nt,Ce,Qt,Te,Re;function Tt(){}Tt.__reactDisabledLog=!0;function Oe(){{if(ht===0){J=console.log,ct=console.info,Nt=console.warn,Ce=console.error,Qt=console.group,Te=console.groupCollapsed,Re=console.groupEnd;var t={configurable:!0,enumerable:!0,value:Tt,writable:!0};Object.defineProperties(console,{info:t,log:t,warn:t,error:t,group:t,groupCollapsed:t,groupEnd:t})}ht++}}function rr(){{if(ht--,ht===0){var t={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:$({},t,{value:J}),info:$({},t,{value:ct}),warn:$({},t,{value:Nt}),error:$({},t,{value:Ce}),group:$({},t,{value:Qt}),groupCollapsed:$({},t,{value:Te}),groupEnd:$({},t,{value:Re})})}ht<0&&_("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var te=I.ReactCurrentDispatcher,ee;function Ht(t,s,c){{if(ee===void 0)try{throw Error()}catch(m){var p=m.stack.trim().match(/\n( *(at )?)/);ee=p&&p[1]||""}return`
18
- `+ee+t}}var re=!1,Rt;{var nr=typeof WeakMap=="function"?WeakMap:Map;Rt=new nr}function ne(t,s){if(!t||re)return"";{var c=Rt.get(t);if(c!==void 0)return c}var p;re=!0;var m=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var b;b=te.current,te.current=null,Oe();try{if(s){var w=function(){throw Error()};if(Object.defineProperty(w.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(w,[])}catch(P){p=P}Reflect.construct(t,[],w)}else{try{w.call()}catch(P){p=P}t.call(w.prototype)}}else{try{throw Error()}catch(P){p=P}t()}}catch(P){if(P&&p&&typeof P.stack=="string"){for(var E=P.stack.split(`
19
- `),D=p.stack.split(`
20
- `),T=E.length-1,O=D.length-1;T>=1&&O>=0&&E[T]!==D[O];)O--;for(;T>=1&&O>=0;T--,O--)if(E[T]!==D[O]){if(T!==1||O!==1)do if(T--,O--,O<0||E[T]!==D[O]){var F=`
21
- `+E[T].replace(" at new "," at ");return t.displayName&&F.includes("<anonymous>")&&(F=F.replace("<anonymous>",t.displayName)),typeof t=="function"&&Rt.set(t,F),F}while(T>=1&&O>=0);break}}}finally{re=!1,te.current=b,rr(),Error.prepareStackTrace=m}var U=t?t.displayName||t.name:"",M=U?Ht(U):"";return typeof t=="function"&&Rt.set(t,M),M}function ir(t,s,c){return ne(t,!1)}function or(t){var s=t.prototype;return!!(s&&s.isReactComponent)}function Bt(t,s,c){if(t==null)return"";if(typeof t=="function")return ne(t,or(t));if(typeof t=="string")return Ht(t);switch(t){case v:return Ht("Suspense");case y:return Ht("SuspenseList")}if(typeof t=="object")switch(t.$$typeof){case f:return ir(t.render);case A:return Bt(t.type,s,c);case k:{var p=t,m=p._payload,b=p._init;try{return Bt(b(m),s,c)}catch{}}}return""}var xt=Object.prototype.hasOwnProperty,De={},Pe=I.ReactDebugCurrentFrame;function Wt(t){if(t){var s=t._owner,c=Bt(t.type,t._source,s?s.type:null);Pe.setExtraStackFrame(c)}else Pe.setExtraStackFrame(null)}function sr(t,s,c,p,m){{var b=Function.call.bind(xt);for(var w in t)if(b(t,w)){var E=void 0;try{if(typeof t[w]!="function"){var D=Error((p||"React class")+": "+c+" type `"+w+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof t[w]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw D.name="Invariant Violation",D}E=t[w](s,w,p,c,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(T){E=T}E&&!(E instanceof Error)&&(Wt(m),_("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).",p||"React class",c,w,typeof E),Wt(null)),E instanceof Error&&!(E.message in De)&&(De[E.message]=!0,Wt(m),_("Failed %s type: %s",c,E.message),Wt(null))}}}var ar=Array.isArray;function ie(t){return ar(t)}function q(t){{var s=typeof Symbol=="function"&&Symbol.toStringTag,c=s&&t[Symbol.toStringTag]||t.constructor.name||"Object";return c}}function lr(t){try{return Le(t),!1}catch{return!0}}function Le(t){return""+t}function oe(t){if(lr(t))return _("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",q(t)),Le(t)}var yt=I.ReactCurrentOwner,je={key:!0,ref:!0,__self:!0,__source:!0},qt,Ie;function ur(t){if(xt.call(t,"ref")){var s=Object.getOwnPropertyDescriptor(t,"ref").get;if(s&&s.isReactWarning)return!1}return t.ref!==void 0}function se(t){if(xt.call(t,"key")){var s=Object.getOwnPropertyDescriptor(t,"key").get;if(s&&s.isReactWarning)return!1}return t.key!==void 0}function hr(t,s){typeof t.ref=="string"&&yt.current}function cr(t,s){{var c=function(){qt||(qt=!0,_("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",s))};c.isReactWarning=!0,Object.defineProperty(t,"key",{get:c,configurable:!0})}}function dr(t,s){{var c=function(){Ie||(Ie=!0,_("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",s))};c.isReactWarning=!0,Object.defineProperty(t,"ref",{get:c,configurable:!0})}}var ae=function(t,s,c,p,m,b,w){var E={$$typeof:e,type:t,key:s,ref:c,props:w,_owner:b};return E._store={},Object.defineProperty(E._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(E,"_self",{configurable:!1,enumerable:!1,writable:!1,value:p}),Object.defineProperty(E,"_source",{configurable:!1,enumerable:!1,writable:!1,value:m}),Object.freeze&&(Object.freeze(E.props),Object.freeze(E)),E};function Fe(t,s,c,p,m){{var b,w={},E=null,D=null;c!==void 0&&(oe(c),E=""+c),se(s)&&(oe(s.key),E=""+s.key),ur(s)&&(D=s.ref,hr(s,m));for(b in s)xt.call(s,b)&&!je.hasOwnProperty(b)&&(w[b]=s[b]);if(t&&t.defaultProps){var T=t.defaultProps;for(b in T)w[b]===void 0&&(w[b]=T[b])}if(E||D){var O=typeof t=="function"?t.displayName||t.name||"Unknown":t;E&&cr(w,O),D&&dr(w,O)}return ae(t,E,D,m,p,yt.current,w)}}var vt=I.ReactCurrentOwner,Me=I.ReactDebugCurrentFrame;function Et(t){if(t){var s=t._owner,c=Bt(t.type,t._source,s?s.type:null);Me.setExtraStackFrame(c)}else Me.setExtraStackFrame(null)}var Ot;Ot=!1;function K(t){return typeof t=="object"&&t!==null&&t.$$typeof===e}function At(){{if(vt.current){var t=at(vt.current.type);if(t)return`
22
-
23
- Check the render method of \``+t+"`."}return""}}function le(t){return""}var $e={};function ze(t){{var s=At();if(!s){var c=typeof t=="string"?t:t.displayName||t.name;c&&(s=`
24
-
25
- Check the top-level render call using <`+c+">.")}return s}}function ue(t,s){{if(!t._store||t._store.validated||t.key!=null)return;t._store.validated=!0;var c=ze(s);if($e[c])return;$e[c]=!0;var p="";t&&t._owner&&t._owner!==vt.current&&(p=" It was passed a child from "+at(t._owner.type)+"."),Et(t),_('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',c,p),Et(null)}}function Ne(t,s){{if(typeof t!="object")return;if(ie(t))for(var c=0;c<t.length;c++){var p=t[c];K(p)&&ue(p,s)}else if(K(t))t._store&&(t._store.validated=!0);else if(t){var m=L(t);if(typeof m=="function"&&m!==t.entries)for(var b=m.call(t),w;!(w=b.next()).done;)K(w.value)&&ue(w.value,s)}}}function he(t){{var s=t.type;if(s==null||typeof s=="string")return;var c;if(typeof s=="function")c=s.propTypes;else if(typeof s=="object"&&(s.$$typeof===f||s.$$typeof===A))c=s.propTypes;else return;if(c){var p=at(s);sr(c,t.props,"prop",p,t)}else if(s.PropTypes!==void 0&&!Ot){Ot=!0;var m=at(s);_("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",m||"Unknown")}typeof s.getDefaultProps=="function"&&!s.getDefaultProps.isReactClassApproved&&_("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function fr(t){{for(var s=Object.keys(t.props),c=0;c<s.length;c++){var p=s[c];if(p!=="children"&&p!=="key"){Et(t),_("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",p),Et(null);break}}t.ref!==null&&(Et(t),_("Invalid attribute `ref` supplied to `React.Fragment`."),Et(null))}}var ce={};function de(t,s,c,p,m,b){{var w=$t(t);if(!w){var E="";(t===void 0||typeof t=="object"&&t!==null&&Object.keys(t).length===0)&&(E+=" You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");var D=le();D?E+=D:E+=At();var T;t===null?T="null":ie(t)?T="array":t!==void 0&&t.$$typeof===e?(T="<"+(at(t.type)||"Unknown")+" />",E=" Did you accidentally export a JSX literal instead of a component?"):T=typeof t,_("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",T,E)}var O=Fe(t,s,c,m,b);if(O==null)return O;if(w){var F=s.children;if(F!==void 0)if(p)if(ie(F)){for(var U=0;U<F.length;U++)Ne(F[U],t);Object.freeze&&Object.freeze(F)}else _("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else Ne(F,t)}if(xt.call(s,"key")){var M=at(t),P=Object.keys(s).filter(function(Z){return Z!=="key"}),H=P.length>0?"{key: someKey, "+P.join(": ..., ")+": ...}":"{key: someKey}";if(!ce[M+H]){var N=P.length>0?"{"+P.join(": ..., ")+": ...}":"{}";_(`A props object containing a "key" prop is being spread into JSX:
26
- let props = %s;
27
- <%s {...props} />
28
- React keys must be passed directly to JSX without using spread:
29
- let props = %s;
30
- <%s key={someKey} {...props} />`,H,M,N,M),ce[M+H]=!0}}return t===n?fr(O):he(O),O}}function gr(t,s,c){return de(t,s,c,!0)}function r(t,s,c){return de(t,s,c,!1)}var i=r,a=gr;Gt.Fragment=n,Gt.jsx=i,Gt.jsxs=a}()),Gt}var wr;function en(){return wr||(wr=1,process.env.NODE_ENV==="production"?pe.exports=Qr():pe.exports=tn()),pe.exports}var rn=en(),nn=Object.defineProperty,on=(u,e,o)=>e in u?nn(u,e,{enumerable:!0,configurable:!0,writable:!0,value:o}):u[e]=o,x=(u,e,o)=>on(u,typeof e!="symbol"?e+"":e,o);let ye=(u=21)=>crypto.getRandomValues(new Uint8Array(u)).reduce((e,o)=>(o&=63,o<36?e+=o.toString(36):o<62?e+=(o-26).toString(36).toUpperCase():o>62?e+="-":e+="_",e),"");const Xt={strokeType:"plain",strokeColor:"#202020",strokeWidth:1,head:"none",tail:"none"},br={id:0,type:"Feature",properties:{type:"arrow",style:{...Xt}},geometry:{type:"LineString",coordinates:[[0,0],[100,100]]}},sn=(u=0,e=0,o=0,n=0,l={...Xt})=>({id:ye(),type:"Feature",properties:{type:"arrow",style:{...Xt,...l}},geometry:{type:"LineString",coordinates:[[u,e],[o,n]]}}),an="http://www.w3.org/2000/svg";function St(u){return document.createElementNS(an,u)}function xr(u){return u.geometry.bbox||ln(u),u.geometry.bbox}function ft(u){const e=xr(u);return{width:e[2]-e[0],height:e[3]-e[1]}}function gt(u){const e=xr(u);return{x:e[0],y:e[1]}}function ln(u){const[e,o]=u.geometry.coordinates[0][0],[n,l]=u.geometry.coordinates[0][2];u.geometry.bbox=[e,o,n,l]}function un(u,e,o,n,l){u.geometry.bbox=[e,o,e+n,o+l],u.geometry.coordinates=[[[e,o],[e+n,o],[e+n,o+l],[e,o+l],[e,o]]]}function Jt(u){const[e,o]=u.geometry.coordinates[0];return{x:e,y:o}}function ve(u,e){const[o,n]=u.geometry.coordinates[e==="start"?0:1];return{x:o,y:n}}function me(u){const[e,o]=u.geometry.coordinates[1];return{x:e,y:o}}function Er(u,e,o){u.geometry.coordinates[0]=[e,o]}function Ar(u,e,o){u.geometry.coordinates[1]=[e,o]}function we(u){return{start:Jt(u),end:me(u)}}function Lt(u,e,o,n){e==="start"?Er(u,o,n):Ar(u,o,n)}const kr=u=>parseInt(u.getAttribute("data-handle-id")||"-1");function hn(u){return Array.isArray(u)&&u.length===2&&u.every(isFinite)}function cn(u,e,o,n){for(let l=0;l<u.coordinates.length;l++){const h=u.coordinates[l];if(hn(h))h[0]=o+(h[0]-o)*e,h[1]=n+(h[1]-n)*e;else for(let d=0;d<h.length;d++){const g=h[d];g[0]=o+(g[0]-o)*e,g[1]=n+(g[1]-n)*e}}return u}function be(u,e,o){const n=Math.atan2(u.y-e.y,u.x-e.x);return{x:e.x+o*Math.cos(n),y:e.y+o*Math.sin(n)}}function xe(u,e){if(!e)return{x:u.clientX,y:u.clientY};const o=e.getBoundingClientRect();return{x:u.clientX-o.left-e.clientLeft,y:u.clientY-o.top-e.clientTop}}const Ct=(u,e)=>({x:u.x-e.x,y:u.y-e.y}),jt=u=>Math.sqrt(u.x*u.x+u.y*u.y),_r=u=>({x:-u.x,y:-u.y}),Sr=u=>{const e=jt(u);return e===0?{x:0,y:0}:{x:u.x/e,y:u.y/e}},It=(u,e)=>({x:u.x+e.x,y:u.y+e.y}),Cr=(u,e)=>({x:u.x*e,y:u.y*e}),Ee=(u,e)=>({x:u.x*e.x,y:u.y*e.y}),st=(u,e)=>{const o=Math.sin(e),n=Math.cos(e);return{x:u.x*n-u.y*o,y:u.x*o+u.y*n}},dn=(u,e)=>({x:u.x/e,y:u.y/e}),Tr=(u,e)=>u.x*e.x+u.y*e.y,fn=.5;function Rr(u,e=5,o=30){var n;const{start:l,end:h}=we(u),d=Ct(h,l),g=u.properties.style&&u.properties.style.strokeWidth?(n=u.properties.style)==null?void 0:n.strokeWidth:0;return Math.min(o,Math.max(3*g,jt(d)*.01,e))}function Or(u,e,o,n){const l=Cr(_r(Sr(e)),n);if(!o||o!=="arrow"&&o!=="arrow-plain")return"";const h=It(u,st(l,Math.PI/10)),d=It(u,st(l,-Math.PI/10)),g=`${u.x} ${u.y}`;return`M ${h.x} ${h.y} L ${g} ${d.x} ${d.y} ${o==="arrow"?"":`${h.x} ${h.y}`}`}function gn(u,e,o,n,l){const{start:h,end:d}=we(u),{tail:g,head:f,strokeColor:v,strokeWidth:y=0}=u.properties.style||o,A=Ct(d,h),k=Rr(u,n,l),S=St("g"),R=St("path");S.setAttribute("data-annotation",`${u.id}`),S.setAttribute("data-annotation-type","arrow");const C=f==="arrow-plain"||g==="arrow",L=v||"none";R.setAttribute("stroke",L),R.setAttribute("stroke-width",`${y}`),R.setAttribute("fill",C?v||"":"none"),R.setAttribute("stroke-linecap","round"),R.setAttribute("stroke-linejoin","round");const I=Or(h,_r(A),g,k),_=Or(d,A,f,k),z=I+`M ${h.x} ${h.y} ${d.x} ${d.y}`+_;R.setAttribute("d",z),S.appendChild(R),Dr(S,h,L,g,y),Dr(S,d,L,f,y),e.appendChild(S)}function Dr(u,e,o,n,l){n==="halo-dot"&&Pr(u,e,pn(o),fn,l*4),(n==="dot"||n==="halo-dot")&&Pr(u,e,o,1,l*2)}function pn(u){return u==="none"?"none":u}function Pr(u,e,o,n,l){const h=St("circle");h.setAttribute("cx",`${e.x}`),h.setAttribute("cy",`${e.y}`),h.setAttribute("r",`${l}`),h.setAttribute("fill-opacity",`${n}`),h.setAttribute("fill",o),u.appendChild(h)}const V=-1,Ae="dragging",ke="dragstart",Ft="dragend",We="select",qe="unselect",yn="hover",vn="unhover",Ue="remove",Ye="add",mn="cancelDrawing",Ve="update",wn="link";function Lr(u){return u&&u.__esModule&&Object.prototype.hasOwnProperty.call(u,"default")?u.default:u}var jr={exports:{}},Ir;function bn(){return Ir||(Ir=1,function(u){var e=Object.prototype.hasOwnProperty,o="~";function n(){}Object.create&&(n.prototype=Object.create(null),new n().__proto__||(o=!1));function l(f,v,y){this.fn=f,this.context=v,this.once=y||!1}function h(f,v,y,A,k){if(typeof y!="function")throw new TypeError("The listener must be a function");var S=new l(y,A||f,k),R=o?o+v:v;return f._events[R]?f._events[R].fn?f._events[R]=[f._events[R],S]:f._events[R].push(S):(f._events[R]=S,f._eventsCount++),f}function d(f,v){--f._eventsCount===0?f._events=new n:delete f._events[v]}function g(){this._events=new n,this._eventsCount=0}g.prototype.eventNames=function(){var f=[],v,y;if(this._eventsCount===0)return f;for(y in v=this._events)e.call(v,y)&&f.push(o?y.slice(1):y);return Object.getOwnPropertySymbols?f.concat(Object.getOwnPropertySymbols(v)):f},g.prototype.listeners=function(f){var v=o?o+f:f,y=this._events[v];if(!y)return[];if(y.fn)return[y.fn];for(var A=0,k=y.length,S=new Array(k);A<k;A++)S[A]=y[A].fn;return S},g.prototype.listenerCount=function(f){var v=o?o+f:f,y=this._events[v];return y?y.fn?1:y.length:0},g.prototype.emit=function(f,v,y,A,k,S){var R=o?o+f:f;if(!this._events[R])return!1;var C=this._events[R],L=arguments.length,I,_;if(C.fn){switch(C.once&&this.removeListener(f,C.fn,void 0,!0),L){case 1:return C.fn.call(C.context),!0;case 2:return C.fn.call(C.context,v),!0;case 3:return C.fn.call(C.context,v,y),!0;case 4:return C.fn.call(C.context,v,y,A),!0;case 5:return C.fn.call(C.context,v,y,A,k),!0;case 6:return C.fn.call(C.context,v,y,A,k,S),!0}for(_=1,I=new Array(L-1);_<L;_++)I[_-1]=arguments[_];C.fn.apply(C.context,I)}else{var z=C.length,W;for(_=0;_<z;_++)switch(C[_].once&&this.removeListener(f,C[_].fn,void 0,!0),L){case 1:C[_].fn.call(C[_].context);break;case 2:C[_].fn.call(C[_].context,v);break;case 3:C[_].fn.call(C[_].context,v,y);break;case 4:C[_].fn.call(C[_].context,v,y,A);break;default:if(!I)for(W=1,I=new Array(L-1);W<L;W++)I[W-1]=arguments[W];C[_].fn.apply(C[_].context,I)}}return!0},g.prototype.on=function(f,v,y){return h(this,f,v,y,!1)},g.prototype.once=function(f,v,y){return h(this,f,v,y,!0)},g.prototype.removeListener=function(f,v,y,A){var k=o?o+f:f;if(!this._events[k])return this;if(!v)return d(this,k),this;var S=this._events[k];if(S.fn)S.fn===v&&(!A||S.once)&&(!y||S.context===y)&&d(this,k);else{for(var R=0,C=[],L=S.length;R<L;R++)(S[R].fn!==v||A&&!S[R].once||y&&S[R].context!==y)&&C.push(S[R]);C.length?this._events[k]=C.length===1?C[0]:C:d(this,k)}return this},g.prototype.removeAllListeners=function(f){var v;return f?(v=o?o+f:f,this._events[v]&&d(this,v)):(this._events=new n,this._eventsCount=0),this},g.prototype.off=g.prototype.removeListener,g.prototype.addListener=g.prototype.on,g.prefixed=o,g.EventEmitter=g,u.exports=g}(jr)),jr.exports}var xn=bn();const Fr=Lr(xn);class Mr extends Fr{constructor(e,o){super(),x(this,"ogma"),x(this,"elements"),x(this,"layer"),x(this,"editor"),x(this,"selectedId",V),x(this,"hoveredId",V),x(this,"ogmaOptions"),x(this,"shouldDetect"),x(this,"isDragging"),x(this,"showeditorOnHover"),x(this,"_onKeyUp",n=>{n.code===27&&this.selectedId!==V?this.unselect():(n.code===46||n.code===8)&&this.selectedId!==V&&this._canRemove()&&this.remove(this.selectedId)}),x(this,"_onClickMouseMove",n=>{if(!n.domEvent||this.isDragging||!this.shouldDetect||n.domEvent.type!=="mousemove"&&n.domEvent.target&&n.domEvent.target.tagName==="a")return;const l=this.ogma.view.screenToGraphCoordinates(n),h=this.shouldDetect||!this.shouldDetect&&+this.selectedId>-1?this.detect(l,0):void 0;n.domEvent.type==="mousemove"?h?this.hover(h.id):this.hoveredId!==V&&this.unhover():h?this.select(h.id):this.selectedId!==V&&this.unselect()}),this.ogma=e,this.elements=[],this.shouldDetect=!0,this.isDragging=!1,this.showeditorOnHover=!0,this.ogmaOptions=e.getOptions(),e.events.on(["click","mousemove"],this._onClickMouseMove).on("keyup",this._onKeyUp).on("frame",()=>{this.refreshEditor(),this.refreshDrawing()}),this.layer=e.layers.addSVGLayer({draw:n=>this.draw(n)}),this.layer.moveToTop(),this.editor=e.layers.addLayer(o),this.editor.hide()}_canRemove(){return!0}add(e){const o=this.getDefaultOptions(),n=Object.assign(e,{id:e.id===void 0?ye():e.id,type:e.type,properties:{...o.properties,...e.properties||{},style:{...o.properties.style,...e.properties.style||{}}},geometry:{...o.geometry,...e.geometry}});return this.elements.push(n),this.layer.refresh(),this.emit(Ye,n),n}updateStyle(e,o){this.updateAnnotation(e,{properties:{style:o}})}updateGeometry(e,o){this.updateAnnotation(e,{geometry:o})}scale(e,o,n,l){this.updateGeometry(e,cn(e.geometry,o,n,l))}update(e,o){const n=this.getById(e);this.updateAnnotation(n,o)}updateAnnotation(e,o){if(!e)return;const n=e.id;Object.keys(o).forEach(l=>{if(l!=="id")if(l==="properties"){const h=o.properties||{style:{}};e.properties={...e.properties||{},...h||{},style:{...e.properties.style||{},...h.style||{}}}}else l==="geometry"?e.geometry={...e.geometry,...o.geometry}:e[l]=o[l]}),n===this.selectedId&&this.refreshEditor(),this.layer.refresh()}getById(e){const o=Number(e);for(let n=0;n<this.elements.length;n++){const l=this.elements[n];if(!(l.id!==e&&l.id!==o))return l}}select(e){const o=this.getById(e);o&&(this.editor.show(),this.selectedId=e,this.refreshEditor(),this.layer.refresh(),this.emit(We,o))}hover(e){const o=this.getById(e);o&&(this.showeditorOnHover&&this.editor.show(),this.hoveredId=e,this.refreshEditor(),this.layer.refresh(),this.emit(yn,o))}getSelectedFeature(){return this.selectedId===V?null:this.getById(this.selectedId)}unselect(){const e=this.getById(this.selectedId);return e&&this.emit(qe,e),this.selectedId=V,this.hoveredId===V&&this.editor.hide(),this.layer.refresh(),this}unhover(){const e=this.getById(this.hoveredId);return this.emit(vn,e),this.hoveredId=V,this.selectedId===V&&this.editor.hide(),this.layer.refresh(),this}remove(e){const o=this.getById(e);e===this.hoveredId&&this.unhover(),e===this.selectedId&&this.unselect(),this.elements=this.elements.filter(n=>n.id!==e),o&&this.emit(Ue,o),this.layer.refresh()}disableDragging(){this.ogma.setOptions({interactions:{drag:{enabled:!1},pan:{enabled:!1}},detect:{nodes:!1,edges:!1,nodeTexts:!1,edgeTexts:!1}})}restoreDragging(){this.ogma.setOptions(this.ogmaOptions)}enableDetection(){this.shouldDetect=!0}disableDetection(){this.shouldDetect=!1}refreshLayer(){this.layer.refresh()}refreshDrawing(){}getElements(){return[...this.elements]}destroy(){this.ogma.events.off(this._onClickMouseMove).off(this._onKeyUp),this.layer.destroy()}}const $r="handle-line",zr="handle-start",Nr="handle-end";class En extends Mr{constructor(e,o={}){super(e,`
1
+ (function(H,V){typeof exports=="object"&&typeof module<"u"?V(exports,require("react"),require("@linkurious/ogma-react")):typeof define=="function"&&define.amd?define(["exports","react","@linkurious/ogma-react"],V):(H=typeof globalThis<"u"?globalThis:H||self,V((H["/home/jenkins/agent/workspace/_ogma-annotations-control_master/packages/ogma-annotations-react/src/index"]=H["/home/jenkins/agent/workspace/_ogma-annotations-control_master/packages/ogma-annotations-react/src/index"]||{},H["/home/jenkins/agent/workspace/_ogma-annotations-control_master/packages/ogma-annotations-react/src/index"].ts={}),H.React,H.OgmaReact))})(this,function(H,V,fr){"use strict";var gr=Object.defineProperty,pr=(l,t,s)=>t in l?gr(l,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):l[t]=s,m=(l,t,s)=>pr(l,typeof t!="symbol"?t+"":t,s);let Ht=(l=21)=>crypto.getRandomValues(new Uint8Array(l)).reduce((t,s)=>(s&=63,s<36?t+=s.toString(36):s<62?t+=(s-26).toString(36).toUpperCase():s>62?t+="-":t+="_",t),"");const It={strokeType:"plain",strokeColor:"#202020",strokeWidth:1,head:"none",tail:"none"},ke={id:0,type:"Feature",properties:{type:"arrow",style:{...It}},geometry:{type:"LineString",coordinates:[[0,0],[100,100]]}},yr=(l=0,t=0,s=0,r=0,a={...It})=>({id:Ht(),type:"Feature",properties:{type:"arrow",style:{...It,...a}},geometry:{type:"LineString",coordinates:[[l,t],[s,r]]}}),mr="http://www.w3.org/2000/svg";function vt(l){return document.createElementNS(mr,l)}function Ee(l){return l.geometry.bbox||vr(l),l.geometry.bbox}function ut(l){const t=Ee(l);return{width:t[2]-t[0],height:t[3]-t[1]}}function ct(l){const t=Ee(l);return{x:t[0],y:t[1]}}function vr(l){const[t,s]=l.geometry.coordinates[0][0],[r,a]=l.geometry.coordinates[0][2];l.geometry.bbox=[t,s,r,a]}function wr(l,t,s,r,a){l.geometry.bbox=[t,s,t+r,s+a],l.geometry.coordinates=[[[t,s],[t+r,s],[t+r,s+a],[t,s+a],[t,s]]]}function $t(l){const[t,s]=l.geometry.coordinates[0];return{x:t,y:s}}function jt(l,t){const[s,r]=l.geometry.coordinates[t==="start"?0:1];return{x:s,y:r}}function Nt(l){const[t,s]=l.geometry.coordinates[1];return{x:t,y:s}}function Se(l,t,s){l.geometry.coordinates[0]=[t,s]}function Ce(l,t,s){l.geometry.coordinates[1]=[t,s]}function Bt(l){return{start:$t(l),end:Nt(l)}}function kt(l,t,s,r){t==="start"?Se(l,s,r):Ce(l,s,r)}const _e=l=>parseInt(l.getAttribute("data-handle-id")||"-1");function xr(l){return Array.isArray(l)&&l.length===2&&l.every(isFinite)}function br(l,t,s,r){for(let a=0;a<l.coordinates.length;a++){const h=l.coordinates[a];if(xr(h))h[0]=s+(h[0]-s)*t,h[1]=r+(h[1]-r)*t;else for(let c=0;c<h.length;c++){const f=h[c];f[0]=s+(f[0]-s)*t,f[1]=r+(f[1]-r)*t}}return l}function qt(l,t,s){const r=Math.atan2(l.y-t.y,l.x-t.x);return{x:t.x+s*Math.cos(r),y:t.y+s*Math.sin(r)}}function Rt(l,t){if(!t)return{x:l.clientX,y:l.clientY};const s=t.getBoundingClientRect();return{x:l.clientX-s.left-t.clientLeft,y:l.clientY-s.top-t.clientTop}}const wt=(l,t)=>({x:l.x-t.x,y:l.y-t.y}),Et=l=>Math.sqrt(l.x*l.x+l.y*l.y),De=l=>({x:-l.x,y:-l.y}),Le=l=>{const t=Et(l);return t===0?{x:0,y:0}:{x:l.x/t,y:l.y/t}},St=(l,t)=>({x:l.x+t.x,y:l.y+t.y}),Te=(l,t)=>({x:l.x*t,y:l.y*t}),Wt=(l,t)=>({x:l.x*t.x,y:l.y*t.y}),rt=(l,t)=>{const s=Math.sin(t),r=Math.cos(t);return{x:l.x*r-l.y*s,y:l.x*s+l.y*r}},Ar=(l,t)=>({x:l.x/t,y:l.y/t}),Ie=(l,t)=>l.x*t.x+l.y*t.y,kr=.5;function $e(l,t=5,s=30){var r;const{start:a,end:h}=Bt(l),c=wt(h,a),f=l.properties.style&&l.properties.style.strokeWidth?(r=l.properties.style)==null?void 0:r.strokeWidth:0;return Math.min(s,Math.max(3*f,Et(c)*.01,t))}function Me(l,t,s,r){const a=Te(De(Le(t)),r);if(!s||s!=="arrow"&&s!=="arrow-plain")return"";const h=St(l,rt(a,Math.PI/10)),c=St(l,rt(a,-Math.PI/10)),f=`${l.x} ${l.y}`;return`M ${h.x} ${h.y} L ${f} ${c.x} ${c.y} ${s==="arrow"?"":`${h.x} ${h.y}`}`}function Er(l,t,s,r,a){const{start:h,end:c}=Bt(l),{tail:f,head:d,strokeColor:g,strokeWidth:p=0}=l.properties.style||s,b=wt(c,h),A=$e(l,r,a),k=vt("g"),E=vt("path");k.setAttribute("data-annotation",`${l.id}`),k.setAttribute("data-annotation-type","arrow");const x=d==="arrow-plain"||f==="arrow",L=g||"none";E.setAttribute("stroke",L),E.setAttribute("stroke-width",`${p}`),E.setAttribute("fill",x?g||"":"none"),E.setAttribute("stroke-linecap","round"),E.setAttribute("stroke-linejoin","round");const O=Me(h,De(b),f,A),C=Me(c,b,d,A),P=O+`M ${h.x} ${h.y} ${c.x} ${c.y}`+C;E.setAttribute("d",P),k.appendChild(E),Oe(k,h,L,f,p),Oe(k,c,L,d,p),t.appendChild(k)}function Oe(l,t,s,r,a){r==="halo-dot"&&ze(l,t,Sr(s),kr,a*4),(r==="dot"||r==="halo-dot")&&ze(l,t,s,1,a*2)}function Sr(l){return l==="none"?"none":l}function ze(l,t,s,r,a){const h=vt("circle");h.setAttribute("cx",`${t.x}`),h.setAttribute("cy",`${t.y}`),h.setAttribute("r",`${a}`),h.setAttribute("fill-opacity",`${r}`),h.setAttribute("fill",s),l.appendChild(h)}const U=-1,Ut="dragging",Xt="dragstart",Ct="dragend",Qt="select",te="unselect",Cr="hover",_r="unhover",ee="remove",re="add",Dr="cancelDrawing",ne="update",Lr="link";function Pe(l){return l&&l.__esModule&&Object.prototype.hasOwnProperty.call(l,"default")?l.default:l}var Fe={exports:{}},He;function Tr(){return He||(He=1,function(l){var t=Object.prototype.hasOwnProperty,s="~";function r(){}Object.create&&(r.prototype=Object.create(null),new r().__proto__||(s=!1));function a(d,g,p){this.fn=d,this.context=g,this.once=p||!1}function h(d,g,p,b,A){if(typeof p!="function")throw new TypeError("The listener must be a function");var k=new a(p,b||d,A),E=s?s+g:g;return d._events[E]?d._events[E].fn?d._events[E]=[d._events[E],k]:d._events[E].push(k):(d._events[E]=k,d._eventsCount++),d}function c(d,g){--d._eventsCount===0?d._events=new r:delete d._events[g]}function f(){this._events=new r,this._eventsCount=0}f.prototype.eventNames=function(){var d=[],g,p;if(this._eventsCount===0)return d;for(p in g=this._events)t.call(g,p)&&d.push(s?p.slice(1):p);return Object.getOwnPropertySymbols?d.concat(Object.getOwnPropertySymbols(g)):d},f.prototype.listeners=function(d){var g=s?s+d:d,p=this._events[g];if(!p)return[];if(p.fn)return[p.fn];for(var b=0,A=p.length,k=new Array(A);b<A;b++)k[b]=p[b].fn;return k},f.prototype.listenerCount=function(d){var g=s?s+d:d,p=this._events[g];return p?p.fn?1:p.length:0},f.prototype.emit=function(d,g,p,b,A,k){var E=s?s+d:d;if(!this._events[E])return!1;var x=this._events[E],L=arguments.length,O,C;if(x.fn){switch(x.once&&this.removeListener(d,x.fn,void 0,!0),L){case 1:return x.fn.call(x.context),!0;case 2:return x.fn.call(x.context,g),!0;case 3:return x.fn.call(x.context,g,p),!0;case 4:return x.fn.call(x.context,g,p,b),!0;case 5:return x.fn.call(x.context,g,p,b,A),!0;case 6:return x.fn.call(x.context,g,p,b,A,k),!0}for(C=1,O=new Array(L-1);C<L;C++)O[C-1]=arguments[C];x.fn.apply(x.context,O)}else{var P=x.length,N;for(C=0;C<P;C++)switch(x[C].once&&this.removeListener(d,x[C].fn,void 0,!0),L){case 1:x[C].fn.call(x[C].context);break;case 2:x[C].fn.call(x[C].context,g);break;case 3:x[C].fn.call(x[C].context,g,p);break;case 4:x[C].fn.call(x[C].context,g,p,b);break;default:if(!O)for(N=1,O=new Array(L-1);N<L;N++)O[N-1]=arguments[N];x[C].fn.apply(x[C].context,O)}}return!0},f.prototype.on=function(d,g,p){return h(this,d,g,p,!1)},f.prototype.once=function(d,g,p){return h(this,d,g,p,!0)},f.prototype.removeListener=function(d,g,p,b){var A=s?s+d:d;if(!this._events[A])return this;if(!g)return c(this,A),this;var k=this._events[A];if(k.fn)k.fn===g&&(!b||k.once)&&(!p||k.context===p)&&c(this,A);else{for(var E=0,x=[],L=k.length;E<L;E++)(k[E].fn!==g||b&&!k[E].once||p&&k[E].context!==p)&&x.push(k[E]);x.length?this._events[A]=x.length===1?x[0]:x:c(this,A)}return this},f.prototype.removeAllListeners=function(d){var g;return d?(g=s?s+d:d,this._events[g]&&c(this,g)):(this._events=new r,this._eventsCount=0),this},f.prototype.off=f.prototype.removeListener,f.prototype.addListener=f.prototype.on,f.prefixed=s,f.EventEmitter=f,l.exports=f}(Fe)),Fe.exports}var Ir=Tr();const je=Pe(Ir);class Ne extends je{constructor(t,s){super(),m(this,"ogma"),m(this,"elements"),m(this,"layer"),m(this,"editor"),m(this,"selectedId",U),m(this,"hoveredId",U),m(this,"ogmaOptions"),m(this,"shouldDetect"),m(this,"isDragging"),m(this,"showeditorOnHover"),m(this,"_onKeyUp",r=>{r.code===27&&this.selectedId!==U?this.unselect():(r.code===46||r.code===8)&&this.selectedId!==U&&this._canRemove()&&this.remove(this.selectedId)}),m(this,"_onClickMouseMove",r=>{if(!r.domEvent||this.isDragging||!this.shouldDetect||r.domEvent.type!=="mousemove"&&r.domEvent.target&&r.domEvent.target.tagName==="a")return;const a=this.ogma.view.screenToGraphCoordinates(r),h=this.shouldDetect||!this.shouldDetect&&+this.selectedId>-1?this.detect(a,0):void 0;r.domEvent.type==="mousemove"?h?this.hover(h.id):this.hoveredId!==U&&this.unhover():h?this.select(h.id):this.selectedId!==U&&this.unselect()}),this.ogma=t,this.elements=[],this.shouldDetect=!0,this.isDragging=!1,this.showeditorOnHover=!0,this.ogmaOptions=t.getOptions(),t.events.on(["click","mousemove"],this._onClickMouseMove).on("keyup",this._onKeyUp).on("frame",()=>{this.refreshEditor(),this.refreshDrawing()}),this.layer=t.layers.addSVGLayer({draw:r=>this.draw(r)}),this.layer.moveToTop(),this.editor=t.layers.addLayer(s),this.editor.hide()}_canRemove(){return!0}add(t){const s=this.getDefaultOptions(),r=Object.assign(t,{id:t.id===void 0?Ht():t.id,type:t.type,properties:{...s.properties,...t.properties||{},style:{...s.properties.style,...t.properties.style||{}}},geometry:{...s.geometry,...t.geometry}});return this.elements.push(r),this.layer.refresh(),this.emit(re,r),r}updateStyle(t,s){this.updateAnnotation(t,{properties:{style:s}})}updateGeometry(t,s){this.updateAnnotation(t,{geometry:s})}scale(t,s,r,a){this.updateGeometry(t,br(t.geometry,s,r,a))}update(t,s){const r=this.getById(t);this.updateAnnotation(r,s)}updateAnnotation(t,s){if(!t)return;const r=t.id;Object.keys(s).forEach(a=>{if(a!=="id")if(a==="properties"){const h=s.properties||{style:{}};t.properties={...t.properties||{},...h||{},style:{...t.properties.style||{},...h.style||{}}}}else a==="geometry"?t.geometry={...t.geometry,...s.geometry}:t[a]=s[a]}),r===this.selectedId&&this.refreshEditor(),this.layer.refresh()}getById(t){const s=Number(t);for(let r=0;r<this.elements.length;r++){const a=this.elements[r];if(!(a.id!==t&&a.id!==s))return a}}select(t){const s=this.getById(t);s&&(this.editor.show(),this.selectedId=t,this.refreshEditor(),this.layer.refresh(),this.emit(Qt,s))}hover(t){const s=this.getById(t);s&&(this.showeditorOnHover&&this.editor.show(),this.hoveredId=t,this.refreshEditor(),this.layer.refresh(),this.emit(Cr,s))}getSelectedFeature(){return this.selectedId===U?null:this.getById(this.selectedId)}unselect(){const t=this.getById(this.selectedId);return t&&this.emit(te,t),this.selectedId=U,this.hoveredId===U&&this.editor.hide(),this.layer.refresh(),this}unhover(){const t=this.getById(this.hoveredId);return this.emit(_r,t),this.hoveredId=U,this.selectedId===U&&this.editor.hide(),this.layer.refresh(),this}remove(t){const s=this.getById(t);t===this.hoveredId&&this.unhover(),t===this.selectedId&&this.unselect(),this.elements=this.elements.filter(r=>r.id!==t),s&&this.emit(ee,s),this.layer.refresh()}disableDragging(){this.ogma.setOptions({interactions:{drag:{enabled:!1},pan:{enabled:!1}},detect:{nodes:!1,edges:!1,nodeTexts:!1,edgeTexts:!1}})}restoreDragging(){this.ogma.setOptions(this.ogmaOptions)}enableDetection(){this.shouldDetect=!0}disableDetection(){this.shouldDetect=!1}refreshLayer(){this.layer.refresh()}refreshDrawing(){}getElements(){return[...this.elements]}destroy(){this.ogma.events.off(this._onClickMouseMove).off(this._onKeyUp),this.layer.destroy()}}const Be="handle-line",qe="handle-start",Re="handle-end";class $r extends Ne{constructor(t,s={}){super(t,`
31
2
  <div class="arrow-handle">
32
- <div id="${$r}" data-handle-id="0" class="handle line"></div>
33
- <div id="${zr}" data-handle-id="1" class="handle point"></div>
34
- <div id="${Nr}" data-handle-id="2" class="handle point"></div>
3
+ <div id="${Be}" data-handle-id="0" class="handle line"></div>
4
+ <div id="${qe}" data-handle-id="1" class="handle point"></div>
5
+ <div id="${Re}" data-handle-id="2" class="handle point"></div>
35
6
  </div>
36
- `),x(this,"draggedHandle",V),x(this,"start",{x:0,y:0}),x(this,"end",{x:0,y:0}),x(this,"arrow",{...br}),x(this,"startX",0),x(this,"startY",0),x(this,"minArrowHeight",0),x(this,"maxArrowHeight",0),x(this,"handles",[]),x(this,"onHandleMouseDown",n=>{const l=this.getById(this.selectedId)||this.getById(this.hoveredId);if(!l)return;const{x:h,y:d}=xe(n,this.ogma.getContainer());this.startDragging(l,h,d),this.draggedHandle=kr(n.target)}),x(this,"onMouseUp",()=>{this.draggedHandle!==-1&&(this.restoreDragging(),this.isDragging=!1,this.draggedHandle=V,this.emit(Ft,this.arrow))}),x(this,"onMouseMove",n=>{if(!this.isDragging||this.draggedHandle===V)return;const{x:l,y:h}=xe(n,this.ogma.getContainer()),d=this.handles[this.draggedHandle],g=this.ogma.view.getAngle(),{x:f,y:v}=st(dn({x:l-this.startX,y:h-this.startY},this.ogma.view.getZoom()),g),y=d.id===$r,A=d.id===zr,k=d.id===Nr;(y||A)&&Er(this.arrow,this.start.x+f,this.start.y+v),(y||k)&&Ar(this.arrow,this.end.x+f,this.end.y+v),this.emit(Ae,this.arrow,y?"line":A?"start":"end"),this.refreshEditor(),this.layer.refresh()}),this.minArrowHeight=o.minArrowHeight||0,this.maxArrowHeight=o.maxArrowHeight||1e6,this.handles=Array.prototype.slice.call(this.editor.element.querySelectorAll(".arrow-handle>.handle")),this.handles.forEach(n=>n.addEventListener("mousedown",this.onHandleMouseDown)),document.addEventListener("mousemove",this.onMouseMove,!0),document.addEventListener("mouseup",this.onMouseUp)}startDrawing(e,o,n=sn(e,o,e,o,Xt)){var l;this.disableDragging(),this.add(n),this.hoveredId=n.id;const h=this.ogma.view.graphToScreenCoordinates({x:e,y:o}),d=((l=this.ogma.getContainer())==null?void 0:l.getBoundingClientRect())||{left:0,top:0};this.startDragging(this.getById(n.id),h.x+(d==null?void 0:d.left),h.y+d.top),this.draggedHandle=2}cancelDrawing(){this.isDragging&&(this.remove(this.arrow.id),this.emit(Ft,this.arrow),this.restoreDragging(),this.isDragging=!1,this.draggedHandle=V)}startDragging(e,o,n){this.selectedId!==e.id&&this.select(this.hoveredId),this.arrow=e,this.startX=o,this.startY=n,this.start=Jt(this.arrow),this.end=me(this.arrow),this.disableDragging(),this.emit(ke,this.arrow),this.isDragging=!0}detect(e,o=0){return this.elements.find(n=>{const{start:l,end:h}=we(n),d=Ct(e,{x:(l.x+h.x)/2,y:(l.y+h.y)/2}),g=Ct(h,l),f=jt(g),v=Sr(g),y=Rr(n);return Math.abs(Tr(v,d))<f/2+o&&Math.abs(Tr(st(v,Math.PI/2),d))<y/2+o})}refreshEditor(){if(+this.selectedId<0&&+this.hoveredId<0)return;const e=this.selectedId!==V?this.getById(this.selectedId):this.getById(this.hoveredId),o=we(e),n=this.ogma.view.graphToScreenCoordinates(o.start),l=this.ogma.view.graphToScreenCoordinates(o.end),[h,d,g]=Array.prototype.slice.call(this.editor.element.querySelectorAll(".handle"));d.style.transform=`translate(${n.x}px, ${n.y}px) translate(-50%, -50%)`,g.style.transform=`translate(${l.x}px, ${l.y}px) translate(-50%, -50%)`;const f={x:(l.x+n.x)/2,y:(l.y+n.y)/2},v=Ct(l,n),y=Cr(v,1/jt(v)),A=Math.atan2(y.y,y.x);h.style.width=`${jt(v)}px`,h.style.left=`${f.x}px`,h.style.top=`${f.y}px`,h.style.transform=`translate(-50%, -50%) rotate(${A}rad)`}getDefaultOptions(){return br}draw(e){e.innerHTML="";const o=St("g"),n=this.ogma.view.getAngle();n!==0&&o.setAttribute("transform",`rotate(${-n*(180/Math.PI)})`),this.elements.forEach(l=>gn(l,o,Xt,this.minArrowHeight,this.maxArrowHeight)),e.appendChild(o)}refreshDrawing(){const e=this.ogma.view.getAngle();this.layer.element!==null&&e!==0&&this.layer.element.children[0].setAttribute("transform",`rotate(${-e*(180/Math.PI)})`)}destroy(){super.destroy(),document.removeEventListener("mousemove",this.onMouseMove,!0),document.removeEventListener("mouseup",this.onMouseUp)}}const Mt={font:"sans-serif",fontSize:18,color:"#505050",background:"#f5f5f5",strokeWidth:0,borderRadius:8,padding:16,strokeType:"plain"},Ge={id:0,type:"Feature",properties:{type:"text",content:"",style:{...Mt}},geometry:{type:"Polygon",coordinates:[[[0,0],[100,0],[100,50],[0,50],[0,0]]]}},Hr={handleSize:3.5,placeholder:"Your text..."},An=(u=0,e=0,o=100,n=50,l="",h={...Mt})=>({id:ye(),type:"Feature",properties:{type:"text",content:l,style:{...Mt,...h}},geometry:{type:"Polygon",coordinates:[[[u,e],[u+o,e],[u+o,e+n],[u,e+n],[u,e]]]}});var Xe={exports:{}},kn=Xe.exports,Br;function _n(){return Br||(Br=1,function(u,e){(function(o,n){u.exports=n()})(kn,()=>(()=>{var o={d:(r,i)=>{for(var a in i)o.o(i,a)&&!o.o(r,a)&&Object.defineProperty(r,a,{enumerable:!0,get:i[a]})},o:(r,i)=>Object.prototype.hasOwnProperty.call(r,i)},n={};function l(r){return l=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(i){return typeof i}:function(i){return i&&typeof Symbol=="function"&&i.constructor===Symbol&&i!==Symbol.prototype?"symbol":typeof i},l(r)}o.d(n,{default:()=>gr});var h=/^((?:[a-z\d-]+\s+)*)([\d.]+(%|em|px)|(?:x+-)?large|(?:x+-)?small|medium)(?:\s*\/\s*(normal|[\d.]+(%|px|em)?))?(\s.+)?$/,d=/\bsmall-caps\b/,g=/\b(?:italic|oblique)\b/,f=/\bbold(?:er)?\b/,v=13.3333333,y={"xx-small":9,"x-small":10,smaller:13.3333,small:13,medium:16,large:18,larger:19.2,"x-large":24,"xx-large":32};function A(r){var i="",a=this;return a.style&&a.style!=="normal"&&(i+=a.style),a.variant&&a.variant!=="normal"&&(i+=(i?" ":"")+a.variant),a.weight&&a.weight!=="normal"&&(i+=(i?" ":"")+a.weight),a.size&&(i+=(i?" ":"")+a.size+"px",a.height!==a.size&&(i+="/"+a.height+"px")),a.family&&(i+=(i?" ":"")+a.family),r&&(i+="::"+a.baseline),r&&(i+="::"+a.color),i}var k={id:"",family:"sans-serif",height:14,size:12,variant:"",style:"",weight:"",baseline:"",color:null,toString:A,valueOf:A};function S(r){var i=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},a=h.exec(r);i.family=(a[6]||"").trim();var t=y[a[2]]||parseFloat(a[2]);a[3]==="%"?t*=.16:a[3]==="em"?t*=16:a[3]==="pt"&&(t*=v),i.size=t;var s=parseFloat(a[4]);if(s!=="normal"&&s!=="inherit"&&s?a[5]&&a[5]!=="em"?a[5]==="pt"?i.height=s*v:a[5]==="%"?i.height=.01*t:i.height=s:i.height=s*t:i.height=Math.round(t*(7/6)),d.test(a[1])&&(i.variant="small-caps"),g.test(a[1])&&(i.style="italic"),f.test(a[1]))i.weight="bold";else{var c=parseInt(/\b(\d+)\b/.exec(a[1]),10);c>=100&&c!==400&&(i.weight=c)}return i}function R(){var r,i,a,t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"12px/14px sans-serif",s=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},c=14,p=12,m=null,b=null,w="";if(t&&t.nodeType){var E=t&&(t.ownerDocument&&t.ownerDocument.defaultView||t.document&&t||t.defaultView),D=E.getComputedStyle(t,null);r=D.getPropertyValue("font-family")||"",p=parseFloat(D.getPropertyValue("font-size")),c=D.getPropertyValue("line-height"),m=D.getPropertyValue("font-weight"),b=D.getPropertyValue("font-style"),w=D.getPropertyValue("font-variant")||""}else if(typeof t=="string"){var T=S(t);r=T.family,p=T.size,c=T.height,w=T.variant,b=T.style,m=T.weight}else l(t)==="object"&&(r=t.family,p=t.size,c=t.height,w=t.variant,m=t.weight,b=t.style,i=t.baseline,a=t.color);s.size&&s.size<3&&(p*=s.size),c=c!=="normal"&&c?parseFloat(c):p*(7/6),s.height&&s.height<3&&(c*=s.height);var O=Object.create(k);return O.family=s.family||r||"sans-serif",O.height=c??14,O.size=p??12,O.variant=s.variant||w||"",O.style=s.style||b||"",O.weight=s.weight||m||"",O.baseline=i||0,s.baseline!=null&&(O.baseline=s.baseline),O.color=s.color||a||"",O.id=A.call(O,!0),O}const C={"\n":.28,"\r":.28," ":.28," ":.28," ":.28,"᠎":0," ":.5," ":1," ":.5," ":1," ":.33," ":.25," ":.16," ":.56," ":.28," ":.2," ":.15,"​":0," ":.16," ":.22," ":1,"\uFEFF":0};var L,I=function(r){var i=typeof OffscreenCanvas<"u"&&new OffscreenCanvas(100,100)||r&&r.createElement("canvas");if(i&&i.getContext){var a=i.getContext("2d");if(a&&typeof a.measureText=="function")return function(t,s){return a.font=String(s),a.measureText(t).width}}}(typeof document<"u"?document:null)||(L={},function(r,i){if(!L[i]){var a=R(i);L[i]=a,/\bmonospace\b/.test(a.family)?a.size*=.6:(a.size*=.45,a.weight&&(a.size*=1.18))}return r.length*L[i].size}),_={},z={trim:!0,collapse:!0};function W(r,i,a){var t=Object.assign({},z,a),s=String(r);if(!s)return 0;if(s in C){var c=i.id+"/"+s;return c in _||(_[c]=I("_".concat(s,"_"),i)-I("__",i)),_[c]}return t.trim&&t.collapse?t.trim?s=s.trim():t.collapse&&(s=s.replace(/\s+/g," ")):s=s.replace(/\n/g," "),I(s,i)+i.size*(r.tracking||0)}function rt(r){return rt=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(i){return typeof i}:function(i){return i&&typeof Symbol=="function"&&i.constructor===Symbol&&i!==Symbol.prototype?"symbol":typeof i},rt(r)}function it(r,i){if(typeof i!="function"&&i!==null)throw new TypeError("Super expression must either be null or a function");r.prototype=Object.create(i&&i.prototype,{constructor:{value:r,writable:!0,configurable:!0}}),Object.defineProperty(r,"prototype",{writable:!1}),i&&Kt(r,i)}function Kt(r,i){return Kt=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(a,t){return a.__proto__=t,a},Kt(r,i)}function Zt(r){var i=function(){if(typeof Reflect>"u"||!Reflect.construct||Reflect.construct.sham)return!1;if(typeof Proxy=="function")return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){})),!0}catch{return!1}}();return function(){var a,t=$t(r);if(i){var s=$t(this).constructor;a=Reflect.construct(t,arguments,s)}else a=t.apply(this,arguments);return _e(this,a)}}function _e(r,i){if(i&&(rt(i)==="object"||typeof i=="function"))return i;if(i!==void 0)throw new TypeError("Derived constructors may only return object or undefined");return function(a){if(a===void 0)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return a}(r)}function $t(r){return $t=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(i){return i.__proto__||Object.getPrototypeOf(i)},$t(r)}function zt(r,i){if(!(r instanceof i))throw new TypeError("Cannot call a class as a function")}function Se(r,i){for(var a=0;a<i.length;a++){var t=i[a];t.enumerable=t.enumerable||!1,t.configurable=!0,"value"in t&&(t.writable=!0),Object.defineProperty(r,(s=function(c,p){if(rt(c)!=="object"||c===null)return c;var m=c[Symbol.toPrimitive];if(m!==void 0){var b=m.call(c,p);if(rt(b)!=="object")return b;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(c)}(t.key,"string"),rt(s)==="symbol"?s:String(s)),t)}var s}function at(r,i,a){return i&&Se(r.prototype,i),Object.defineProperty(r,"prototype",{writable:!1}),r}var $=function(){function r(){var i=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"";zt(this,r),this.value=i,this.weight=null,this.style=null,this.font=null,this.href=null,this.sub=!1,this.sup=!1}return at(r,[{key:"clone",value:function(){var i=new r(this.value);return i.value=this.value,i.weight=this.weight,i.style=this.style,i.font=this.font,i.href=this.href,i.sub=this.sub,i.sup=this.sup,i}},{key:"valueOf",value:function(){return this.value}},{key:"toString",value:function(){return this.value}}]),r}(),ht=function(r){it(a,r);var i=Zt(a);function a(){return zt(this,a),i.apply(this,arguments)}return at(a)}($),J=function(r){it(a,r);var i=Zt(a);function a(){return zt(this,a),i.apply(this,arguments)}return at(a)}($),ct=function(r){it(a,r);var i=Zt(a);function a(){return zt(this,a),i.apply(this,arguments)}return at(a)}($),Nt=/^[\n\r\t\x20\xA0\u2000-\u200B\u205F\u3000]/,Ce=/^[^\n\r\t\u0020\u2000-\u200B\u205F\u3000]{2,}/,Qt=/^[\xA0\u2011\u202F\u2060\uFEFF]/,Te=/^(?:[;\xAD%?…]|,(?!\d))/,Re=/^[´±°¢£¤$¥\u2212]/;function Tt(r,i){i!==!1&&(r=r.trim());for(var a,t,s=[],c=r.charAt(0),p=0,m=1,b=r.length;m<b;m++){a=r.charAt(m),t=r.charAt(m+1);var w=Nt.test(c),E=Nt.test(a),D=E||w,T=void 0;if((Re.test(a)&&!Qt.test(c)||Te.test(c+t)&&!Qt.test(a))&&(D=!0),c!=="-"&&c!=="‐"&&c!=="–"&&c!=="—"||((T=Nt.test(r.charAt(m-2)))&&!E&&(D=!1),!T&&Ce.test(a+t)&&(D=!0)),D){var O=r.slice(p,m);/\u00AD$/.test(O)?(s.push(new $(O.slice(0,-1))),s.push(new ct)):(s.push(new $(O)),s.push(new ht)),p=m}c=a}return s.push(new $(r.slice(p))),s}const Oe={nbsp:" ",iexcl:"¡",cent:"¢",pound:"£",curren:"¤",yen:"¥",brvbar:"¦",sect:"§",uml:"¨",copy:"©",ordf:"ª",laquo:"«",not:"¬",shy:"­",reg:"®",macr:"¯",deg:"°",plusmn:"±",sup2:"²",sup3:"³",acute:"´",micro:"µ",para:"¶",middot:"·",cedil:"¸",sup1:"¹",ordm:"º",raquo:"»",frac14:"¼",frac12:"½",frac34:"¾",iquest:"¿",Agrave:"À",Aacute:"Á",Acirc:"Â",Atilde:"Ã",Auml:"Ä",Aring:"Å",AElig:"Æ",Ccedil:"Ç",Egrave:"È",Eacute:"É",Ecirc:"Ê",Euml:"Ë",Igrave:"Ì",Iacute:"Í",Icirc:"Î",Iuml:"Ï",ETH:"Ð",Ntilde:"Ñ",Ograve:"Ò",Oacute:"Ó",Ocirc:"Ô",Otilde:"Õ",Ouml:"Ö",times:"×",Oslash:"Ø",Ugrave:"Ù",Uacute:"Ú",Ucirc:"Û",Uuml:"Ü",Yacute:"Ý",THORN:"Þ",szlig:"ß",agrave:"à",aacute:"á",acirc:"â",atilde:"ã",auml:"ä",aring:"å",aelig:"æ",ccedil:"ç",egrave:"è",eacute:"é",ecirc:"ê",euml:"ë",igrave:"ì",iacute:"í",icirc:"î",iuml:"ï",eth:"ð",ntilde:"ñ",ograve:"ò",oacute:"ó",ocirc:"ô",otilde:"õ",ouml:"ö",divide:"÷",oslash:"ø",ugrave:"ù",uacute:"ú",ucirc:"û",uuml:"ü",yacute:"ý",thorn:"þ",yuml:"ÿ",fnof:"ƒ",Alpha:"Α",Beta:"Β",Gamma:"Γ",Delta:"Δ",Epsilon:"Ε",Zeta:"Ζ",Eta:"Η",Theta:"Θ",Iota:"Ι",Kappa:"Κ",Lambda:"Λ",Mu:"Μ",Nu:"Ν",Xi:"Ξ",Omicron:"Ο",Pi:"Π",Rho:"Ρ",Sigma:"Σ",Tau:"Τ",Upsilon:"Υ",Phi:"Φ",Chi:"Χ",Psi:"Ψ",Omega:"Ω",alpha:"α",beta:"β",gamma:"γ",delta:"δ",epsilon:"ε",zeta:"ζ",eta:"η",theta:"θ",iota:"ι",kappa:"κ",lambda:"λ",mu:"μ",nu:"ν",xi:"ξ",omicron:"ο",pi:"π",rho:"ρ",sigmaf:"ς",sigma:"σ",tau:"τ",upsilon:"υ",phi:"φ",chi:"χ",psi:"ψ",omega:"ω",thetasym:"ϑ",upsih:"ϒ",piv:"ϖ",bull:"•",hellip:"…",prime:"′",Prime:"″",oline:"‾",frasl:"⁄",weierp:"℘",image:"ℑ",real:"ℜ",trade:"™",alefsym:"ℵ",larr:"←",uarr:"↑",rarr:"→",darr:"↓",harr:"↔",crarr:"↵",lArr:"⇐",uArr:"⇑",rArr:"⇒",dArr:"⇓",hArr:"⇔",forall:"∀",part:"∂",exist:"∃",empty:"∅",nabla:"∇",isin:"∈",notin:"∉",ni:"∋",prod:"∏",sum:"∑",minus:"−",lowast:"∗",radic:"√",prop:"∝",infin:"∞",ang:"∠",and:"⊥",or:"⊦",cap:"∩",cup:"∪",int:"∫",there4:"∴",sim:"∼",cong:"≅",asymp:"≈",ne:"≠",equiv:"≡",le:"≤",ge:"≥",sub:"⊂",sup:"⊃",nsub:"⊄",sube:"⊆",supe:"⊇",oplus:"⊕",otimes:"⊗",perp:"⊥",sdot:"⋅",lceil:"⌈",rceil:"⌉",lfloor:"⌊",rfloor:"⌋",lang:"〈",rang:"〉",loz:"◊",spades:"♠",clubs:"♣",hearts:"♥",diams:"♦",quot:'"',amp:"&",lt:"<",gt:">",OElig:"Œ",oelig:"œ",Scaron:"Š",scaron:"š",Yuml:"Ÿ",circ:"ˆ",tilde:"˜",ensp:" ",emsp:" ",thinsp:" ",zwnj:"‌",zwj:"‍",lrm:"‎",rlm:"‏",ndash:"–",mdash:"—",lsquo:"‘",rsquo:"’",sbquo:"‚",ldquo:"“",rdquo:"”",bdquo:"„",dagger:"†",Dagger:"‡",permil:"‰",lsaquo:"‹",rsaquo:"›"};var rr=/^[\n\r\x20\u2000-\u200B\u205F\u3000]/,te=/^<\/([a-zA-Z0-9]+)([^>]*)>/,ee=/^<([a-zA-Z0-9]+)((?:\s[^=\s/]+(?:\s*=\s*(?:"[^"]+"|'[^']+'|[^>\\s]+))?)+)?\s*(\/?)>(\n*)/,Ht=/^<!--(.+?)-->/,re=/&(?:#(\d\d{2,})|#x([\da-fA-F]{2,})|([a-zA-Z][a-zA-Z1-4]{1,8}));/g,Rt={b:function(r){r.weight="bold"},strong:function(r){r.weight="bold"},i:function(r){r.style="italic"},em:function(r){r.style="italic"},dfn:function(r){r.style="italic"},cite:function(r){r.style="italic"},code:function(r){r.family="monospace"},kbd:function(r){r.family="monospace"},samp:function(r){r.family="monospace"},var:function(r){r.family="monospace"},tt:function(r){r.family="monospace"},sub:function(r){r.sub=!0},sup:function(r){r.sup=!0}},nr={div:1,li:1,blockquote:2,h1:2,h2:2,h3:2,h4:2,h5:2,h6:2,ul:2,ol:2,hr:2,p:2};function ne(r){return r.replace(re,function(i,a,t,s){if(a||t){var c=a?10:16;return String.fromCharCode(parseInt(a||t,c))}return s in Oe?Oe[s]:i})}function ir(r){return r&&r.length>1&&(r[0]==='"'&&r[r.length-1]==='"'||r[0]==="'"&&r[r.length-1]==="'")?r.slice(1,-1):r}var or=/^\s*([^=\s&]+)(?:\s*=\s*("[^"]+"|'[^']+'|[^>\s]+))?/;function Bt(r){var i,a={};if(r){do if(i=or.exec(r)){var t=ne(ir(i[2]||"")).replace(/[ \r\n\t]+/g," ").trim();if(a[i[1]]=t,(r=r.slice(i[0].length)).length&&/^\S/.test(r[0]))throw new Error("Attribute error")}while(i&&r.length);if(/\S/.test(r))throw new Error("Attribute error")}return a}const xt={copyright:"©",textcopyright:"©",dag:"†",textdagger:"†",ddag:"‡",textdaggerdbl:"‡",guillemotleft:"«",guillemotright:"»",guilsinglleft:"‹",guilsinglright:"›",ldots:"…",dots:"…",textellipsis:"…",lq:"‘",P:"¶",textparagraph:"¶",pounds:"£",textsterling:"£",quotedblbase:"„",quotesinglbase:"‚",rq:"’",S:"§",sim:"~",textasciicircum:"^",textasciitilde:"˜",texttildelow:"~",textasteriskcentered:"*",textbackslash:"'",textbar:"|",textbardbl:"╎",textbigcircle:"◯",textbraceleft:"{",textbraceright:"}",textbullet:"•",textdollar:"$",textemdash:"—",textendash:"—",texteuro:"€",eurosym:"€",euro:"€",textexclamdown:"¡",textgreater:">",textless:"<",textordfeminine:"ª",textordmasculine:"º",textperiodcentered:"·",cdot:"·",textquestiondown:"¿",textquotedblleft:"“",textquotedblright:"”",textquoteleft:"‘",textquoteright:"’",textquotestraightbase:"‚",textquotestraightdblbase:"„",textregistered:"®",textthreequartersemdash:"-",texttrademark:"™",texttwelveudash:"-",textunderscore:"_",textvisiblespace:"␣",gets:"←",textleftarrow:"←",to:"→",textrightarrow:"→",textdegree:"°",infty:"∞",triangle:"△",triangledown:"▽",blacktriangle:"▲",blacktriangledown:"▼",angle:"∠",sphericalangle:"∢",aleph:"ℵ",hbar:"ħ",imath:"𝚤",jmath:"𝚥",ell:"ℓ",wp:"℘",Re:"ℜ",Im:"ℑ",mho:"℧",prime:"′",emptyset:"∅",nabla:"∇",surd:"√",partial:"∂",top:"⟙",bot:"⟂",vdash:"⟝",dashv:"⟞",forall:"∀",exists:"∃",nexists:"∄",neg:"¬",lnot:"¬",flat:"♭",natural:"♮",sharp:"♯",backslash:"\\",Box:"□",Diamond:"♢",clubsuit:"♣",diamondsuit:"♦",heartsuit:"♥",spadesuit:"♠",Join:"⨝",blacksquare:"■",bigstar:"★",diagdown:"╲",diagup:"╱",blacklozenge:"⧫",rfloor:"⌋",lfloor:"⌊",rceil:"⌉",lceil:"⌈",rangle:"⟩",langle:"⟨",sum:"∑",int:"∫",oint:"∮",prod:"∏",coprod:"∏",bigcap:"∩",bigcup:"∪",bigsqcup:"⊔",bigvee:"∨",bigwedge:"∧",bigodot:"⊙",bigotimes:"⊗",bigoplus:"⊕",biguplus:"⊎",alpha:"α",beta:"β",chi:"χ",delta:"δ",epsilon:"ε",eta:"η",gamma:"γ",iota:"ι",kappa:"κ",lambda:"λ",mu:"μ",nu:"ν",omega:"ω",phi:"φ",pi:"π",psi:"ψ",rho:"ρ",sigma:"σ",tau:"τ",theta:"θ",upsilon:"υ",xi:"ξ",zeta:"ζ",Alpha:"Α",Beta:"Β",Chi:"Χ",Delta:"Δ",Epsilon:"Ε",Eta:"Η",Gamma:"Γ",Iota:"Ι",Kappa:"Κ",Lambda:"Λ",Mu:"Μ",Nu:"Ν",Omega:"Ω",Phi:"Φ",Pi:"Π",Psi:"Ψ",Rho:"Ρ",Sigma:"Σ",Tau:"Τ",Theta:"Θ",Upsilon:"Υ",Xi:"Ξ",Zeta:"Ζ",aa:"å",AA:"Å",ae:"æ",AE:"Æ",dh:"ð",DH:"Ð",dj:"đ",DJ:"Đ",ij:"ij",IJ:"IJ",l:"ł",L:"Ł",ng:"ŋ",NG:"Ŋ",o:"ø",O:"Ø",oe:"œ",OE:"Œ",ss:"ß",SS:"SS",th:"þ",TH:"Þ"};var De=/^(\^|_|\\[^#$%&~_^\\{}()\s]+)(\{)?/,Pe=/^%[^\n]+(?:\n|$)/,Wt=/^[^#$%&~_^\\{}]+/,sr=/^\\([&{}$%#_])/,ar=/(?:\\[\\@,!:;-]|-{2,3}|[!?]`|``?|,,|''?|~|<<|>>)/g,ie={"---":"—","--":"–","!`":"¡","?`":"¿","``":"“",",,":"„","''":"”","`":"‘","'":"’","<<":"«",">>":"»","~":" ","\\-":"­","\\,":" ","\\;":" ","\\:":" ","\\!":" ","\\@":"\uFEFF","\\\\":"\\newline{}"},q={bf:function(r){r.weight="bold"},it:function(r){r.style="italic"},sl:function(r){r.style="italic"},color:function(r,i){r.color=i},href:function(r,i){r.href=i},"^":function(r){r.sup=!0},_:function(r){r.sub=!0},par:function(r){this.tokens.push(new J,new J)},newline:function(r){this.tokens.push(new J)},url:function(r,i){this.open_context().href=i,this.add_token(new $(i)),this.close_context()}};q.textsuperscript=q["^"],q.textsubscript=q._,q.textsl=q.sl,q.mathbf=q.bf,q.mathit=q.it,q.textbf=q.bf,q.textit=q.it,q.textcolor=q.color;var lr=/[\r\n\xA0]+/g;function Le(r,i){r.sup&&(r.baseline=.45,r.size=.7),r.sub&&(r.baseline=-.3,r.size=.7);var a=i;return(r.style||r.weight||r.baseline||r.color||r.size||r.family)&&(a=R(i,r)),a}function oe(r,i,a){for(var t,s,c=r.width;c+a.width>i&&r.length;)s=(t=r[r.length-1]).width,t.width>a.width?(t.value=t.value.slice(0,-1),t.width=W(t,t.font),c+=t.width):r.pop(),c-=s;r[r.length-1]instanceof ct&&r.pop(),t=r[r.length-1]||t||{},a.font=R(a.font,t.bold,t.italic,""),a.href=r.length?t.href:null,a.rel=r.length?t.rel:null,a.target=r.length?t.target:null,r.push(a)}function yt(r){return Math.round(1e6*r)/1e6}function je(r){return function(i){if(Array.isArray(i))return qt(i)}(r)||function(i){if(typeof Symbol<"u"&&i[Symbol.iterator]!=null||i["@@iterator"]!=null)return Array.from(i)}(r)||function(i,a){if(i){if(typeof i=="string")return qt(i,a);var t=Object.prototype.toString.call(i).slice(8,-1);return t==="Object"&&i.constructor&&(t=i.constructor.name),t==="Map"||t==="Set"?Array.from(i):t==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?qt(i,a):void 0}}(r)||function(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
37
- In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}()}function qt(r,i){(i==null||i>r.length)&&(i=r.length);for(var a=0,t=new Array(i);a<i;a++)t[a]=r[a];return t}var Ie={center:"middle",right:"end"},ur={middle:.5,center:.5,bottom:1,end:1},se=function(r,i){return!r&&!i||r===i};function hr(r,i){var a=[],t=i.font(),s=t.size,c=t.family,p=i.align(),m=i.createElement();if(r.length){var b=t.height,w=i.valign(),E=i.height()(),D=i.width()(0),T=!isFinite(D)&&r.length===1,O=T?null:i.x(),F=yt(b/s),U=T?null:yt(b/(1.15*s+(b-s)/2));if(ur[w]&&isFinite(E)){var M=w==="bottom"?1:.5;U+=(E*M-b*r.length*M)/s}var P=p==="justify",H=0;p==="right"?H=D:p==="center"&&(H=D/2);for(var N=[],Z="tspan",Q=null,Y="",j=function(){if(Y){var Dt=m(Z,Q,Y);N.push(Dt)}Z="tspan",Q=null,Y=""},lt=0,ot=r.length;lt<ot;lt++){var mt="",kt="",dt=0,wt=r[lt];if(wt.length){N=[];for(var Ut=0,fe=0,bt=void 0,tt=0,He=wt.length;tt<He;tt++){var G=wt[tt],et=G.font;G.whitespace&&Ut++,fe+=G.width,tt&&!G.tracking&&!dt&&se(et.id,mt)&&se(G.class,kt)&&se(bt,G.href)?Y+=G.value:(j(),Y=G.value,Q={fontFamily:et.family!==c?et.family:null,fontSize:et.size!==s?et.size:null,fontWeight:et.weight||null,fontStyle:et.style||null,fontVariant:et.variant!=="normal"&&et.variant||null,fill:et.color||null,baselineShift:et.baseline?100*et.baseline+"%":null,className:G.class||null},dt&&(Q.dx=yt(dt),dt=0),G.tracking&&(dt=et.size*G.tracking),G.href&&!bt?(bt=G.href,Z="a",Q.href=bt,Q.rel=G.rel,Q.target=G.target):bt=null,mt=et.id,kt=G.class)}if(j(),T)a.push.apply(a,je(N));else{var Be=null,ge=lt===ot-1||wt[wt.length-1]instanceof J;P&&wt.length>1&&!ge&&(Be=yt((D-fe)/Ut)),a.push(m.apply(void 0,["tspan",{wordSpacing:Be,x:O(lt)+H,dy:yt(lt?F:U)+"em"}].concat(je(N))))}}else a.push(m("tspan",{x:O(lt),dy:yt(lt?F:U)+"em"}," "))}}return m.apply(void 0,["text",{fontFamily:c,fontSize:s,textAnchor:Ie[p]||"start"}].concat(a))}var cr={middle:.5,center:.5,bottom:1,end:1};function dr(r,i,a){if(r.length){a.textBaseline="middle";var t=i.font(),s=t.height,c=t.size,p=i.valign(),m=i.height()(),b=i.width()(0),w=i.align(),E=w==="justify",D=.5*s,T=cr[p];if(T&&isFinite(m)){var O=r.length*s;D+=m*T-O*T}r.forEach(function(F,U){var M=i.x()(U),P=U*s+D,H=0,N=0;F.forEach(function(Y){Y.whitespace&&H++,N+=Y.width});var Z=0,Q=U===r.length-1||F[F.length-1]instanceof J;E&&F.length>1&&!Q&&(Z=(b-N)/H),F.forEach(function(Y){a.font=Y.font;var j=Y.font,lt=j.baseline?c*-j.baseline+.15*c:0;a.fillStyle=function(kt,dt){return kt.color?kt.color:dt.href?"#00C":"#000"}(j,Y);var ot=0;if(w==="right"?ot+=b-N:w==="center"?ot+=b/2-N/2:w==="justify"&&(Y.whitespace||Y instanceof J)&&(M+=Z),a.fillText(Y.value,M+ot,P+lt),Y.href){a.beginPath(),a.strokeStyle=a.fillStyle;var mt=Math.floor(P+.45*c)+.5;a.moveTo(M+ot,mt),a.lineTo(M+ot+Y.width,mt),a.stroke()}M+=Y.width})})}}function ae(r){return ae=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(i){return typeof i}:function(i){return i&&typeof Symbol=="function"&&i.constructor===Symbol&&i!==Symbol.prototype?"symbol":typeof i},ae(r)}function Fe(r){for(var i={},a=0;a<r.length;a++){var t=r[a];typeof t!="number"&&t!=null&&(typeof t=="string"?i.text=t:typeof t=="function"?i.fn=t:ae(t)==="object"&&t._groups?i.d3=t:t&&t.nodeType&&t.getContext?i.ctx=t.getContext("2d"):t&&t.fillText&&t.beginPath?i.ctx=t:t&&(i.text=t))}return i}function vt(r){return vt=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(i){return typeof i}:function(i){return i&&typeof Symbol=="function"&&i.constructor===Symbol&&i!==Symbol.prototype?"symbol":typeof i},vt(r)}function Me(r,i){for(var a=0;a<i.length;a++){var t=i[a];t.enumerable=t.enumerable||!1,t.configurable=!0,"value"in t&&(t.writable=!0),Object.defineProperty(r,(s=function(c,p){if(vt(c)!=="object"||c===null)return c;var m=c[Symbol.toPrimitive];if(m!==void 0){var b=m.call(c,p);if(vt(b)!=="object")return b;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(c)}(t.key,"string"),vt(s)==="symbol"?s:String(s)),t)}var s}var Et=R(),Ot=function(r){return typeof r=="function"?r:function(){return r}},K=function(){function r(t){if(function(c,p){if(!(c instanceof p))throw new TypeError("Cannot call a class as a function")}(this,r),this.props={overflow:"ellipsis",lineclamp:null,align:"left",wordBreak:null,valign:"top",width:function(){return 1/0},height:function(){return 1/0},x:function(){return 0},font:null,tAnchor:0,parser:r.defaultparser},t)for(var s in t)typeof this[s]=="function"&&this[s](t[s])}var i,a;return i=r,a=[{key:"linebreak",value:function(t){var s=this,c=this.props.parser(String(t)),p=this.font(),m=function(b,w,E){if(!b.length)return[];var D=w.height(),T=w.width(),O=w.overflowLine(),F=w.overflowWrap(),U=R(E,!0,!1),M=isFinite(D())?Math.floor(D()/E.height):1/0;if(!D()&&!T(0)||!M)return[];for(var P=0,H=0,N=0,Z=[],Q=[],Y=!1;P<b.length&&H<M;){var j=b[P],lt=Le(j,E);if(j.width=W(j,lt),j.font=lt,j.line=H,j.whitespace=j.value in C,j.value&&(j.value=j.value.replace(lr," ")),!(!N&&j.whitespace||Y&&j.whitespace))if(j instanceof J)N=0,Q=[],Z.push(P+1),H++;else if(j instanceof ht||j instanceof ct)Q.push({index:P,width:N});else if(j.whitespace||N+j.width<T(H))N+=j.width;else if(Q.length){var ot=void 0,mt=void 0;do{mt=!0,ot=Q.pop();var kt=b[ot.index],dt=void 0;kt instanceof ct&&(dt=W("-",kt.font),ot.width+dt>T(H)&&(mt=!Q.length))}while(!mt);Z.push(ot.index+1),N=0,H++,P=ot.index,Q=[]}else if(F==="break-word"){var wt=T(H);if(N+j.width>wt){var Ut=j.clone();do j.value=j.value.slice(0,-1),j.width=W(j,j.font),N+=j.width;while(j.value&&j.width>wt);Ut.value=Ut.value.slice(j.value.length),b.splice(P+1,0,new ht,Ut)}Z.push(P+1),N=0,H++}else N+=j.width;P++,Y=j.whitespace}P!==Z[Z.length-1]&&Z.push(P);var fe=0,bt=0,tt=Z.map(function(Dt){for(var nt,Pt=fe;(nt=b[Pt])&&(nt.whitespace||!nt.value);)Pt++;for(var _t=Dt,pr=null;_t>Pt&&(nt=b[_t-1])&&(nt.whitespace||!(nt.value||nt instanceof ct));)nt instanceof J&&(pr=nt),_t--;nt instanceof ct&&(nt.value="-",nt.width=W("-",nt.font)),fe=Dt;var Yt=b.slice(Pt,_t).filter(function(yr){return yr.value});return pr&&Yt.push(pr),Yt.width=Yt.reduce(function(yr,Nn){return yr+Nn.width},0),Yt.width>bt&&(bt=Yt.width),Yt});if(tt.hasLineOverflow=!1,O){var He=O==="ellipsis"?"…":O;tt.forEach(function(Dt,nt){var Pt=T(nt);if(Dt.width>Pt){var _t=new $(He);_t.font=E,_t.width=W(He,U),oe(Dt,Pt,_t),tt.hasLineOverflow=!0}})}var G=w.overflow()==="ellipsis"?"…":w.overflow();if(G&&P!==b.length){var et=T(tt.length-1),Be=tt[tt.length-1],ge=new $(G);ge.font=E,ge.width=W(G,U),oe(Be,et,ge),tt.hasOverflow=!0}else tt.hasOverflow=!1;return tt.font=E,tt.width=bt,tt}(c,this,p);return m.height=m.length*p.height,m.render=function(b){return s.render(m,b)},m.svg=m.render,m.draw=m.render,m}},{key:"font",value:function(t){return arguments.length?(this.props.font=R(t),this):this.props.font||R(Et)}},{key:"overflow",value:function(t){return arguments.length?(this.props.overflow=String(t),this):this.props.overflow}},{key:"overflowLine",value:function(t){return arguments.length?(this.props.lineclamp=String(t),this):this.props.lineclamp}},{key:"valign",value:function(t){return arguments.length?(this.props.valign=t,this):this.props.valign}},{key:"align",value:function(t){if(!arguments.length)return this.props.align;var s=String(t).toLowerCase();return s==="left"||s==="start"?(this.props.align="left",this.props.tAnchor=0):s==="center"||s==="middle"?(this.props.align="center",this.props.tAnchor=-.5):s==="end"||s==="right"?(this.props.align="right",this.props.tAnchor=-1):s==="justify"&&(this.props.align=t,this.props.tAnchor=0),this}},{key:"overflowWrap",value:function(t){if(!arguments.length)return this.props.overflowWrap||"normal";var s=String(t).toLowerCase();return s==="break-word"?this.props.overflowWrap="break-word":s!=="normal"&&t!=null||(this.props.overflowWrap=null),this}},{key:"width",value:function(t){return arguments.length?(this.props.width=Ot(t),this):this.props.width}},{key:"height",value:function(t){return arguments.length?(this.props.height=Ot(t),this):this.props.height}},{key:"x",value:function(t){return arguments.length?(this.props.x=Ot(t),this):this.props.x}},{key:"parser",value:function(t){if(!arguments.length)return this.props.parser;if(typeof t=="string"){var s=r[t]||r[t+"parser"];typeof s=="function"&&(t=s)}if(typeof t!="function")throw new Error("Unknown parser: "+t);return this.props.parser=t,this}},{key:"createElement",value:function(t){return arguments.length?(this.props.createElement=t,this):this.props.createElement||r.createElement}},{key:"render",value:function(){var t=Fe(arguments);return typeof t.text=="string"&&(t.text=this.linebreak(t.text)),t.ctx?dr(t.text,this,t.ctx):hr(t.text,this)}}],a&&Me(i.prototype,a),Object.defineProperty(i,"prototype",{writable:!1}),r}();function At(r){return At=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(i){return typeof i}:function(i){return i&&typeof Symbol=="function"&&i.constructor===Symbol&&i!==Symbol.prototype?"symbol":typeof i},At(r)}function le(r,i){(i==null||i>r.length)&&(i=r.length);for(var a=0,t=new Array(i);a<i;a++)t[a]=r[a];return t}function $e(r,i){for(var a=0;a<i.length;a++){var t=i[a];t.enumerable=t.enumerable||!1,t.configurable=!0,"value"in t&&(t.writable=!0),Object.defineProperty(r,(s=function(c,p){if(At(c)!=="object"||c===null)return c;var m=c[Symbol.toPrimitive];if(m!==void 0){var b=m.call(c,p);if(At(b)!=="object")return b;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(c)}(t.key,"string"),At(s)==="symbol"?s:String(s)),t)}var s}var ze=function(r){return typeof r=="function"?r:function(){return r}},ue=function(){function r(t){if(function(c,p){if(!(c instanceof p))throw new TypeError("Cannot call a class as a function")}(this,r),this.props={width:function(){return 1/0},height:function(){return 1/0},rotation:0,vAnchor:0,hAnchor:0},t)for(var s in t)typeof this[s]=="function"&&this[s](t[s]);this.render=this.render.bind(this)}var i,a;return i=r,a=[{key:"anchor",value:function(t){var s=this.props,c=s.hAnchor,p=s.vAnchor,m=s.width,b=s.height;if(!arguments.length)return[c*m(0),p*b(0)];if(typeof t=="string"){var w=this.props;t.toLowerCase().trim().split(/\s+/).forEach(function(E){E==="top"&&(w.vAnchor=-0),E==="middle"&&(w.vAnchor=-.5),E==="bottom"&&(w.vAnchor=-1),E==="left"&&(w.hAnchor=-0),E==="center"&&(w.hAnchor=-.5),E==="right"&&(w.hAnchor=-1)})}return this}},{key:"width",value:function(t){return arguments.length?(this.props.width=ze(t),this):this.props.width}},{key:"height",value:function(t){return arguments.length?(this.props.height=ze(t),this):this.props.height}},{key:"rotate",value:function(t){return arguments.length?(this.props.rotation=t,this):this.props.rotation}},{key:"createElement",value:function(t){return arguments.length?(this.props.createElement=t,this):this.props.createElement||r.createElement}},{key:"canvas",value:function(t,s){var c,p=t.getContext?t.getContext("2d"):t;return p.save(),p.rotate(this.rotate()*Math.PI/180),p.translate.apply(p,function(m){if(Array.isArray(m))return le(m)}(c=this.anchor())||function(m){if(typeof Symbol<"u"&&m[Symbol.iterator]!=null||m["@@iterator"]!=null)return Array.from(m)}(c)||function(m,b){if(m){if(typeof m=="string")return le(m,b);var w=Object.prototype.toString.call(m).slice(8,-1);return w==="Object"&&m.constructor&&(w=m.constructor.name),w==="Map"||w==="Set"?Array.from(m):w==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(w)?le(m,b):void 0}}(c)||function(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
38
- In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}()),s(p),p.restore(),p}},{key:"render",value:function(){var t=Fe(arguments);if(t.d3)return t.d3.attr("transform","rotate(".concat(this.rotate(),") translate(").concat(this.anchor(),")"));if(t.ctx)return this.canvas(t.ctx,t.fn);if(t.text){var s=typeof t.text.render=="function"?t.text.render():t.text;return this.createElement()("g",{transform:"rotate(".concat(this.rotate(),") translate(").concat(this.anchor(),")")},s)}}}],a&&$e(i.prototype,a),Object.defineProperty(i,"prototype",{writable:!1}),r}(),Ne=Object.prototype.hasOwnProperty,he={};function fr(r){return he[r]||(he[r]=r.replace(/([a-z])([A-Z])/g,function(i,a,t){return a+"-"+t.toLowerCase()})),he[r]}function ce(r,i){if(Array.isArray(i))return i.forEach(function(a){return ce(r,a)});typeof i=="string"&&(i=document.createTextNode(i)),r.appendChild(i)}function de(r,i){if(typeof document<"u"){var a=typeof r=="string"?document.createElementNS("http://www.w3.org/2000/svg",r):r;if(i&&a.setAttribute)for(var t in i)Ne.call(i,t)&&i[t]!=null&&a.setAttribute(t==="className"?"class":fr(t),i[t]);for(var s=arguments.length,c=new Array(s>2?s-2:0),p=2;p<s;p++)c[p-2]=arguments[p];return c!=null&&c.length&&c.forEach(function(m){ce(a,m)}),a}}K.createElement=de,K.textparser=Tt,K.defaultparser=Tt,K.htmlparser=function(r){r=String(r||"").trim();for(var i,a,t={weight:null,style:null,sub:!1,sup:!1,href:null,color:null,rel:null,target:null},s=[],c=[],p=function(D){for(var T in t)t[T]&&(D[T]=t[T]);s.push(D)},m=function(D){var T=s.length,O=nr[D];if(T&&O){for(var F=T-1;s[F]&&(s[F]instanceof ht||rr.test(s[F].value));)F--;for(;O&&s[F]&&s[F]instanceof J;)F--,O--;for(;O-- >0;)s.push(new J)}};r.length;){if(i=/^[^<]+/.exec(r))Tt(ne(i[0]),!1).forEach(p);else if(!(i=Ht.exec(r)))if(i=te.exec(r))c.length&&(t=c.pop()),m(i[1]);else if(i=ee.exec(r)){var b=i[1];m(b),c.push(t),t=Object.create(t),Rt[b]&&Rt[b](t,"");var w=Bt(i[2]);b==="a"&&(w.href&&(t.href=w.href),w.rel&&(t.rel=w.rel),w.target&&(t.target=w.target)),w.class&&(t.class=t.class?t.class+" "+w.class:w.class),w.style&&(a=/(?:^|\s|;)color\s*:\s*([^;\s"']+)/.exec(w.style))&&a[1]&&(t.color=a[1]),b==="br"&&s.push(new J)}else i=[r.slice(0,1)],p(new $(i[0]));r=r.slice(i[0].length)}for(var E=s[s.length-1];E instanceof J;)s.pop(),E=s[s.length-1];return s},K.latexparser=function(r){r=String(r||"").trim();var i=[0];r=r.replace(/\\verb,(.*?),/,function(M,P){return i.push(P),"\\verb,"+(i.length-1)+","}).replace(/\\\\\n/g,function(){return"\\\\"}).replace(ar,function(M,P,H){return H.charAt(P-1)==="\\"?M:ie[M]}).replace(/\n\s+/g,function(M){return/\n/.test(M.slice(1))?"\\par ":M}).replace(/\\symbol\{(\d+)\}/,function(M,P,H,N){return N.charAt(H-1)==="\\"?M:String.fromCharCode(1*P)}).replace(/(^|[^\\])(\^|_)(\d|[^{]\S*)/g,function(M,P,H,N){return P+H+"{"+N+"}"}).replace(/\\verb,(.*?),/,function(M,P){return"\\verb,".concat(i[+P],",")});for(var a,t={weight:null,italic:null,variant:null,sub:!1,sup:!1,href:null},s=[],c=[],p=function(M){for(var P in t)t[P]&&(M[P]=t[P]);return s.push(M),M},m=function(){c.push(t),t=Object.create(t)},b=function(){if(!c.length)throw new Error("Unexpected }");t=c.pop()},w={tokens:s,open_context:m,close_context:b,add_token:p};r.length;){if(a=Wt.exec(r))Tt(a[0],!1).forEach(p);else if(a=sr.exec(r))p(new $(a[1]));else if(!(a=Pe.exec(r))){if(a=/^\{/.exec(r))m();else if(a=/^\}/.exec(r))b();else if(!(a=/^\$/.exec(r)))if(a=/^\\verb,([^,]+),/.exec(r))p(new $(a[1]));else if(a=De.exec(r)){var E=a[1].slice(1)||a[1],D=!!a[2];if(/^(La)?TeX$/i.test(E)){m(),t.family="serif";var T=void 0;E==="LaTeX"&&((T=p(new $("L"))).tracking=-.25,(T=p(new $("A"))).size=.7,T.baseline=.3,T.tracking=-.1),(T=p(new $("T"))).tracking=-.17,(T=p(new $("E"))).baseline=-.22,T.tracking=-.13,T=p(new $("X")),b()}else if(E in xt)p(new $(xt[E])),D&&m();else if(E in q){var O=[],F=q[E].length-1,U=void 0;if(F){for(D=!1,r=r.slice(a[0].length-1);F--;){if(!(U=/^\{([^}]+)\}/.exec(r)))throw new Error(E+" is missing an argument");O.push(U[1]),r=r.slice(U[0].length)}a[0]=/^\{/.exec(r)?"{":"",D=!!a[0]}D&&m(),q[E].apply(w,[t].concat(O))}else console.warn("unknown latex command",E),p(new $(a[1])),D&&m()}else a=[r.slice(0,1)],p(new $(a[0]))}r=r.slice(a[0].length)}return s},K.measureText=function(r,i,a){return W(r,R(i),a)},K.Token=$,K.Break=ht,K.LineBreak=J,K.SoftHyphen=ct,K.Rotator=ue,ue.createElement=de;const gr=K;return n.default})())}(Xe)),Xe.exports}var Sn=_n();const Wr=Lr(Sn);function Je(u){return u.replace(/…$/,"")}function Ke(u){return u.children[0].innerHTML}function Cn(u,e){const o=ft(u),{fontSize:n,font:l,padding:h=0}=u.properties.style||{};if(o.width===o.height&&o.width===0)return;const d=new Wr({font:`${n}px/${n}px ${l}`.replace(/(px)+/g,"px"),width:o.width-h*2,height:o.height-h*2,align:"left",valign:"top",x:0,overflow:"ellipsis",parser:"html",createElement:Wr.createElement});d.overflowWrap("break-word");const g=d.linebreak(u.properties.content.replaceAll(`
39
- `,"<br>")).render(),f=[...g.children];let v=0;const y=[];u.properties.content.split(`
40
- `).forEach(S=>{let R=S;for(;R.length&&v<f.length;){if(f[v].innerHTML==="&nbsp;"){R.startsWith(`
41
- `)||y.push(v),v++;break}const C=Je(Ke(f[v]));R.startsWith(C)&&(R=R.slice(C.length).trim()),v++}}),y.forEach(S=>g.removeChild(f[S]));const A=u.properties.content.match(/(https?:\/\/.*)/gm),k=A?A.map(S=>S.split(" ")[0]):[];g.setAttribute("transform",`translate(${h}, ${h})`),k.forEach(S=>{let R=S;const C=[];for(;R.length>0;){const L=f.find(_=>!!_.children[0]&&_.children[0].tagName==="tspan"&&R.startsWith(Je(Ke(_))));if(!L)break;C.push(L);const I=Je(L.children[0].innerHTML).length;if(!I)break;R=R.slice(I)}C.forEach(L=>{const I=document.createElementNS("http://www.w3.org/2000/svg","a");I.setAttribute("href",S),I.setAttribute("target","_blank"),I.innerHTML=Ke(L),L.children[0].innerHTML="",L.children[0].appendChild(I)})}),e.appendChild(g)}const qr=20;class Tn extends Mr{constructor(e,o={}){super(e,`
7
+ `),m(this,"draggedHandle",U),m(this,"start",{x:0,y:0}),m(this,"end",{x:0,y:0}),m(this,"arrow",{...ke}),m(this,"startX",0),m(this,"startY",0),m(this,"minArrowHeight",0),m(this,"maxArrowHeight",0),m(this,"handles",[]),m(this,"onHandleMouseDown",r=>{const a=this.getById(this.selectedId)||this.getById(this.hoveredId);if(!a)return;const{x:h,y:c}=Rt(r,this.ogma.getContainer());this.startDragging(a,h,c),this.draggedHandle=_e(r.target)}),m(this,"onMouseUp",()=>{this.draggedHandle!==-1&&(this.restoreDragging(),this.isDragging=!1,this.draggedHandle=U,this.emit(Ct,this.arrow))}),m(this,"onMouseMove",r=>{if(!this.isDragging||this.draggedHandle===U)return;const{x:a,y:h}=Rt(r,this.ogma.getContainer()),c=this.handles[this.draggedHandle],f=this.ogma.view.getAngle(),{x:d,y:g}=rt(Ar({x:a-this.startX,y:h-this.startY},this.ogma.view.getZoom()),f),p=c.id===Be,b=c.id===qe,A=c.id===Re;(p||b)&&Se(this.arrow,this.start.x+d,this.start.y+g),(p||A)&&Ce(this.arrow,this.end.x+d,this.end.y+g),this.emit(Ut,this.arrow,p?"line":b?"start":"end"),this.refreshEditor(),this.layer.refresh()}),this.minArrowHeight=s.minArrowHeight||0,this.maxArrowHeight=s.maxArrowHeight||1e6,this.handles=Array.prototype.slice.call(this.editor.element.querySelectorAll(".arrow-handle>.handle")),this.handles.forEach(r=>r.addEventListener("mousedown",this.onHandleMouseDown)),document.addEventListener("mousemove",this.onMouseMove,!0),document.addEventListener("mouseup",this.onMouseUp)}startDrawing(t,s,r=yr(t,s,t,s,It)){var a;this.disableDragging(),this.add(r),this.hoveredId=r.id;const h=this.ogma.view.graphToScreenCoordinates({x:t,y:s}),c=((a=this.ogma.getContainer())==null?void 0:a.getBoundingClientRect())||{left:0,top:0};this.startDragging(this.getById(r.id),h.x+(c==null?void 0:c.left),h.y+c.top),this.draggedHandle=2}cancelDrawing(){this.isDragging&&(this.remove(this.arrow.id),this.emit(Ct,this.arrow),this.restoreDragging(),this.isDragging=!1,this.draggedHandle=U)}startDragging(t,s,r){this.selectedId!==t.id&&this.select(this.hoveredId),this.arrow=t,this.startX=s,this.startY=r,this.start=$t(this.arrow),this.end=Nt(this.arrow),this.disableDragging(),this.emit(Xt,this.arrow),this.isDragging=!0}detect(t,s=0){return this.elements.find(r=>{const{start:a,end:h}=Bt(r),c=wt(t,{x:(a.x+h.x)/2,y:(a.y+h.y)/2}),f=wt(h,a),d=Et(f),g=Le(f),p=$e(r);return Math.abs(Ie(g,c))<d/2+s&&Math.abs(Ie(rt(g,Math.PI/2),c))<p/2+s})}refreshEditor(){if(+this.selectedId<0&&+this.hoveredId<0)return;const t=this.selectedId!==U?this.getById(this.selectedId):this.getById(this.hoveredId),s=Bt(t),r=this.ogma.view.graphToScreenCoordinates(s.start),a=this.ogma.view.graphToScreenCoordinates(s.end),[h,c,f]=Array.prototype.slice.call(this.editor.element.querySelectorAll(".handle"));c.style.transform=`translate(${r.x}px, ${r.y}px) translate(-50%, -50%)`,f.style.transform=`translate(${a.x}px, ${a.y}px) translate(-50%, -50%)`;const d={x:(a.x+r.x)/2,y:(a.y+r.y)/2},g=wt(a,r),p=Te(g,1/Et(g)),b=Math.atan2(p.y,p.x);h.style.width=`${Et(g)}px`,h.style.left=`${d.x}px`,h.style.top=`${d.y}px`,h.style.transform=`translate(-50%, -50%) rotate(${b}rad)`}getDefaultOptions(){return ke}draw(t){t.innerHTML="";const s=vt("g"),r=this.ogma.view.getAngle();r!==0&&s.setAttribute("transform",`rotate(${-r*(180/Math.PI)})`),this.elements.forEach(a=>Er(a,s,It,this.minArrowHeight,this.maxArrowHeight)),t.appendChild(s)}refreshDrawing(){const t=this.ogma.view.getAngle();this.layer.element!==null&&t!==0&&this.layer.element.children[0].setAttribute("transform",`rotate(${-t*(180/Math.PI)})`)}destroy(){super.destroy(),document.removeEventListener("mousemove",this.onMouseMove,!0),document.removeEventListener("mouseup",this.onMouseUp)}}const _t={font:"sans-serif",fontSize:18,color:"#505050",background:"#f5f5f5",strokeWidth:0,borderRadius:8,padding:16,strokeType:"plain"},ie={id:0,type:"Feature",properties:{type:"text",content:"",style:{..._t}},geometry:{type:"Polygon",coordinates:[[[0,0],[100,0],[100,50],[0,50],[0,0]]]}},We={handleSize:3.5,placeholder:"Your text..."},Mr=(l=0,t=0,s=100,r=50,a="",h={..._t})=>({id:Ht(),type:"Feature",properties:{type:"text",content:a,style:{..._t,...h}},geometry:{type:"Polygon",coordinates:[[[l,t],[l+s,t],[l+s,t+r],[l,t+r],[l,t]]]}});var se={exports:{}},Or=se.exports,Ue;function zr(){return Ue||(Ue=1,function(l,t){(function(s,r){l.exports=r()})(Or,()=>(()=>{var s={d:(e,n)=>{for(var o in n)s.o(n,o)&&!s.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:n[o]})},o:(e,n)=>Object.prototype.hasOwnProperty.call(e,n)},r={};function a(e){return a=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(n){return typeof n}:function(n){return n&&typeof Symbol=="function"&&n.constructor===Symbol&&n!==Symbol.prototype?"symbol":typeof n},a(e)}s.d(r,{default:()=>Ln});var h=/^((?:[a-z\d-]+\s+)*)([\d.]+(%|em|px)|(?:x+-)?large|(?:x+-)?small|medium)(?:\s*\/\s*(normal|[\d.]+(%|px|em)?))?(\s.+)?$/,c=/\bsmall-caps\b/,f=/\b(?:italic|oblique)\b/,d=/\bbold(?:er)?\b/,g=13.3333333,p={"xx-small":9,"x-small":10,smaller:13.3333,small:13,medium:16,large:18,larger:19.2,"x-large":24,"xx-large":32};function b(e){var n="",o=this;return o.style&&o.style!=="normal"&&(n+=o.style),o.variant&&o.variant!=="normal"&&(n+=(n?" ":"")+o.variant),o.weight&&o.weight!=="normal"&&(n+=(n?" ":"")+o.weight),o.size&&(n+=(n?" ":"")+o.size+"px",o.height!==o.size&&(n+="/"+o.height+"px")),o.family&&(n+=(n?" ":"")+o.family),e&&(n+="::"+o.baseline),e&&(n+="::"+o.color),n}var A={id:"",family:"sans-serif",height:14,size:12,variant:"",style:"",weight:"",baseline:"",color:null,toString:b,valueOf:b};function k(e){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},o=h.exec(e);n.family=(o[6]||"").trim();var i=p[o[2]]||parseFloat(o[2]);o[3]==="%"?i*=.16:o[3]==="em"?i*=16:o[3]==="pt"&&(i*=g),n.size=i;var u=parseFloat(o[4]);if(u!=="normal"&&u!=="inherit"&&u?o[5]&&o[5]!=="em"?o[5]==="pt"?n.height=u*g:o[5]==="%"?n.height=.01*i:n.height=u:n.height=u*i:n.height=Math.round(i*(7/6)),c.test(o[1])&&(n.variant="small-caps"),f.test(o[1])&&(n.style="italic"),d.test(o[1]))n.weight="bold";else{var y=parseInt(/\b(\d+)\b/.exec(o[1]),10);y>=100&&y!==400&&(n.weight=y)}return n}function E(){var e,n,o,i=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"12px/14px sans-serif",u=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},y=14,w=12,v=null,S=null,_="";if(i&&i.nodeType){var I=i&&(i.ownerDocument&&i.ownerDocument.defaultView||i.document&&i||i.defaultView),$=I.getComputedStyle(i,null);e=$.getPropertyValue("font-family")||"",w=parseFloat($.getPropertyValue("font-size")),y=$.getPropertyValue("line-height"),v=$.getPropertyValue("font-weight"),S=$.getPropertyValue("font-style"),_=$.getPropertyValue("font-variant")||""}else if(typeof i=="string"){var D=k(i);e=D.family,w=D.size,y=D.height,_=D.variant,S=D.style,v=D.weight}else a(i)==="object"&&(e=i.family,w=i.size,y=i.height,_=i.variant,v=i.weight,S=i.style,n=i.baseline,o=i.color);u.size&&u.size<3&&(w*=u.size),y=y!=="normal"&&y?parseFloat(y):w*(7/6),u.height&&u.height<3&&(y*=u.height);var M=Object.create(A);return M.family=u.family||e||"sans-serif",M.height=y??14,M.size=w??12,M.variant=u.variant||_||"",M.style=u.style||S||"",M.weight=u.weight||v||"",M.baseline=n||0,u.baseline!=null&&(M.baseline=u.baseline),M.color=u.color||o||"",M.id=b.call(M,!0),M}const x={"\n":.28,"\r":.28," ":.28," ":.28," ":.28,"᠎":0," ":.5," ":1," ":.5," ":1," ":.33," ":.25," ":.16," ":.56," ":.28," ":.2," ":.15,"​":0," ":.16," ":.22," ":1,"\uFEFF":0};var L,O=function(e){var n=typeof OffscreenCanvas<"u"&&new OffscreenCanvas(100,100)||e&&e.createElement("canvas");if(n&&n.getContext){var o=n.getContext("2d");if(o&&typeof o.measureText=="function")return function(i,u){return o.font=String(u),o.measureText(i).width}}}(typeof document<"u"?document:null)||(L={},function(e,n){if(!L[n]){var o=E(n);L[n]=o,/\bmonospace\b/.test(o.family)?o.size*=.6:(o.size*=.45,o.weight&&(o.size*=1.18))}return e.length*L[n].size}),C={},P={trim:!0,collapse:!0};function N(e,n,o){var i=Object.assign({},P,o),u=String(e);if(!u)return 0;if(u in x){var y=n.id+"/"+u;return y in C||(C[y]=O("_".concat(u,"_"),n)-O("__",n)),C[y]}return i.trim&&i.collapse?i.trim?u=u.trim():i.collapse&&(u=u.replace(/\s+/g," ")):u=u.replace(/\n/g," "),O(u,n)+n.size*(e.tracking||0)}function nt(e){return nt=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(n){return typeof n}:function(n){return n&&typeof Symbol=="function"&&n.constructor===Symbol&&n!==Symbol.prototype?"symbol":typeof n},nt(e)}function at(e,n){if(typeof n!="function"&&n!==null)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(n&&n.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),Object.defineProperty(e,"prototype",{writable:!1}),n&&de(e,n)}function de(e,n){return de=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(o,i){return o.__proto__=i,o},de(e,n)}function fe(e){var n=function(){if(typeof Reflect>"u"||!Reflect.construct||Reflect.construct.sham)return!1;if(typeof Proxy=="function")return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){})),!0}catch{return!1}}();return function(){var o,i=Gt(e);if(n){var u=Gt(this).constructor;o=Reflect.construct(i,arguments,u)}else o=i.apply(this,arguments);return Yr(this,o)}}function Yr(e,n){if(n&&(nt(n)==="object"||typeof n=="function"))return n;if(n!==void 0)throw new TypeError("Derived constructors may only return object or undefined");return function(o){if(o===void 0)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return o}(e)}function Gt(e){return Gt=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(n){return n.__proto__||Object.getPrototypeOf(n)},Gt(e)}function Vt(e,n){if(!(e instanceof n))throw new TypeError("Cannot call a class as a function")}function Jr(e,n){for(var o=0;o<n.length;o++){var i=n[o];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(e,(u=function(y,w){if(nt(y)!=="object"||y===null)return y;var v=y[Symbol.toPrimitive];if(v!==void 0){var S=v.call(y,w);if(nt(S)!=="object")return S;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(y)}(i.key,"string"),nt(u)==="symbol"?u:String(u)),i)}var u}function Zt(e,n,o){return n&&Jr(e.prototype,n),Object.defineProperty(e,"prototype",{writable:!1}),e}var B=function(){function e(){var n=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"";Vt(this,e),this.value=n,this.weight=null,this.style=null,this.font=null,this.href=null,this.sub=!1,this.sup=!1}return Zt(e,[{key:"clone",value:function(){var n=new e(this.value);return n.value=this.value,n.weight=this.weight,n.style=this.style,n.font=this.font,n.href=this.href,n.sub=this.sub,n.sup=this.sup,n}},{key:"valueOf",value:function(){return this.value}},{key:"toString",value:function(){return this.value}}]),e}(),Mt=function(e){at(o,e);var n=fe(o);function o(){return Vt(this,o),n.apply(this,arguments)}return Zt(o)}(B),it=function(e){at(o,e);var n=fe(o);function o(){return Vt(this,o),n.apply(this,arguments)}return Zt(o)}(B),xt=function(e){at(o,e);var n=fe(o);function o(){return Vt(this,o),n.apply(this,arguments)}return Zt(o)}(B),ge=/^[\n\r\t\x20\xA0\u2000-\u200B\u205F\u3000]/,Kr=/^[^\n\r\t\u0020\u2000-\u200B\u205F\u3000]{2,}/,er=/^[\xA0\u2011\u202F\u2060\uFEFF]/,Qr=/^(?:[;\xAD%?…]|,(?!\d))/,tn=/^[´±°¢£¤$¥\u2212]/;function Yt(e,n){n!==!1&&(e=e.trim());for(var o,i,u=[],y=e.charAt(0),w=0,v=1,S=e.length;v<S;v++){o=e.charAt(v),i=e.charAt(v+1);var _=ge.test(y),I=ge.test(o),$=I||_,D=void 0;if((tn.test(o)&&!er.test(y)||Qr.test(y+i)&&!er.test(o))&&($=!0),y!=="-"&&y!=="‐"&&y!=="–"&&y!=="—"||((D=ge.test(e.charAt(v-2)))&&!I&&($=!1),!D&&Kr.test(o+i)&&($=!0)),$){var M=e.slice(w,v);/\u00AD$/.test(M)?(u.push(new B(M.slice(0,-1))),u.push(new xt)):(u.push(new B(M)),u.push(new Mt)),w=v}y=o}return u.push(new B(e.slice(w))),u}const rr={nbsp:" ",iexcl:"¡",cent:"¢",pound:"£",curren:"¤",yen:"¥",brvbar:"¦",sect:"§",uml:"¨",copy:"©",ordf:"ª",laquo:"«",not:"¬",shy:"­",reg:"®",macr:"¯",deg:"°",plusmn:"±",sup2:"²",sup3:"³",acute:"´",micro:"µ",para:"¶",middot:"·",cedil:"¸",sup1:"¹",ordm:"º",raquo:"»",frac14:"¼",frac12:"½",frac34:"¾",iquest:"¿",Agrave:"À",Aacute:"Á",Acirc:"Â",Atilde:"Ã",Auml:"Ä",Aring:"Å",AElig:"Æ",Ccedil:"Ç",Egrave:"È",Eacute:"É",Ecirc:"Ê",Euml:"Ë",Igrave:"Ì",Iacute:"Í",Icirc:"Î",Iuml:"Ï",ETH:"Ð",Ntilde:"Ñ",Ograve:"Ò",Oacute:"Ó",Ocirc:"Ô",Otilde:"Õ",Ouml:"Ö",times:"×",Oslash:"Ø",Ugrave:"Ù",Uacute:"Ú",Ucirc:"Û",Uuml:"Ü",Yacute:"Ý",THORN:"Þ",szlig:"ß",agrave:"à",aacute:"á",acirc:"â",atilde:"ã",auml:"ä",aring:"å",aelig:"æ",ccedil:"ç",egrave:"è",eacute:"é",ecirc:"ê",euml:"ë",igrave:"ì",iacute:"í",icirc:"î",iuml:"ï",eth:"ð",ntilde:"ñ",ograve:"ò",oacute:"ó",ocirc:"ô",otilde:"õ",ouml:"ö",divide:"÷",oslash:"ø",ugrave:"ù",uacute:"ú",ucirc:"û",uuml:"ü",yacute:"ý",thorn:"þ",yuml:"ÿ",fnof:"ƒ",Alpha:"Α",Beta:"Β",Gamma:"Γ",Delta:"Δ",Epsilon:"Ε",Zeta:"Ζ",Eta:"Η",Theta:"Θ",Iota:"Ι",Kappa:"Κ",Lambda:"Λ",Mu:"Μ",Nu:"Ν",Xi:"Ξ",Omicron:"Ο",Pi:"Π",Rho:"Ρ",Sigma:"Σ",Tau:"Τ",Upsilon:"Υ",Phi:"Φ",Chi:"Χ",Psi:"Ψ",Omega:"Ω",alpha:"α",beta:"β",gamma:"γ",delta:"δ",epsilon:"ε",zeta:"ζ",eta:"η",theta:"θ",iota:"ι",kappa:"κ",lambda:"λ",mu:"μ",nu:"ν",xi:"ξ",omicron:"ο",pi:"π",rho:"ρ",sigmaf:"ς",sigma:"σ",tau:"τ",upsilon:"υ",phi:"φ",chi:"χ",psi:"ψ",omega:"ω",thetasym:"ϑ",upsih:"ϒ",piv:"ϖ",bull:"•",hellip:"…",prime:"′",Prime:"″",oline:"‾",frasl:"⁄",weierp:"℘",image:"ℑ",real:"ℜ",trade:"™",alefsym:"ℵ",larr:"←",uarr:"↑",rarr:"→",darr:"↓",harr:"↔",crarr:"↵",lArr:"⇐",uArr:"⇑",rArr:"⇒",dArr:"⇓",hArr:"⇔",forall:"∀",part:"∂",exist:"∃",empty:"∅",nabla:"∇",isin:"∈",notin:"∉",ni:"∋",prod:"∏",sum:"∑",minus:"−",lowast:"∗",radic:"√",prop:"∝",infin:"∞",ang:"∠",and:"⊥",or:"⊦",cap:"∩",cup:"∪",int:"∫",there4:"∴",sim:"∼",cong:"≅",asymp:"≈",ne:"≠",equiv:"≡",le:"≤",ge:"≥",sub:"⊂",sup:"⊃",nsub:"⊄",sube:"⊆",supe:"⊇",oplus:"⊕",otimes:"⊗",perp:"⊥",sdot:"⋅",lceil:"⌈",rceil:"⌉",lfloor:"⌊",rfloor:"⌋",lang:"〈",rang:"〉",loz:"◊",spades:"♠",clubs:"♣",hearts:"♥",diams:"♦",quot:'"',amp:"&",lt:"<",gt:">",OElig:"Œ",oelig:"œ",Scaron:"Š",scaron:"š",Yuml:"Ÿ",circ:"ˆ",tilde:"˜",ensp:" ",emsp:" ",thinsp:" ",zwnj:"‌",zwj:"‍",lrm:"‎",rlm:"‏",ndash:"–",mdash:"—",lsquo:"‘",rsquo:"’",sbquo:"‚",ldquo:"“",rdquo:"”",bdquo:"„",dagger:"†",Dagger:"‡",permil:"‰",lsaquo:"‹",rsaquo:"›"};var en=/^[\n\r\x20\u2000-\u200B\u205F\u3000]/,rn=/^<\/([a-zA-Z0-9]+)([^>]*)>/,nn=/^<([a-zA-Z0-9]+)((?:\s[^=\s/]+(?:\s*=\s*(?:"[^"]+"|'[^']+'|[^>\\s]+))?)+)?\s*(\/?)>(\n*)/,sn=/^<!--(.+?)-->/,on=/&(?:#(\d\d{2,})|#x([\da-fA-F]{2,})|([a-zA-Z][a-zA-Z1-4]{1,8}));/g,nr={b:function(e){e.weight="bold"},strong:function(e){e.weight="bold"},i:function(e){e.style="italic"},em:function(e){e.style="italic"},dfn:function(e){e.style="italic"},cite:function(e){e.style="italic"},code:function(e){e.family="monospace"},kbd:function(e){e.family="monospace"},samp:function(e){e.family="monospace"},var:function(e){e.family="monospace"},tt:function(e){e.family="monospace"},sub:function(e){e.sub=!0},sup:function(e){e.sup=!0}},an={div:1,li:1,blockquote:2,h1:2,h2:2,h3:2,h4:2,h5:2,h6:2,ul:2,ol:2,hr:2,p:2};function ir(e){return e.replace(on,function(n,o,i,u){if(o||i){var y=o?10:16;return String.fromCharCode(parseInt(o||i,y))}return u in rr?rr[u]:n})}function ln(e){return e&&e.length>1&&(e[0]==='"'&&e[e.length-1]==='"'||e[0]==="'"&&e[e.length-1]==="'")?e.slice(1,-1):e}var hn=/^\s*([^=\s&]+)(?:\s*=\s*("[^"]+"|'[^']+'|[^>\s]+))?/;function un(e){var n,o={};if(e){do if(n=hn.exec(e)){var i=ir(ln(n[2]||"")).replace(/[ \r\n\t]+/g," ").trim();if(o[n[1]]=i,(e=e.slice(n[0].length)).length&&/^\S/.test(e[0]))throw new Error("Attribute error")}while(n&&e.length);if(/\S/.test(e))throw new Error("Attribute error")}return o}const sr={copyright:"©",textcopyright:"©",dag:"†",textdagger:"†",ddag:"‡",textdaggerdbl:"‡",guillemotleft:"«",guillemotright:"»",guilsinglleft:"‹",guilsinglright:"›",ldots:"…",dots:"…",textellipsis:"…",lq:"‘",P:"¶",textparagraph:"¶",pounds:"£",textsterling:"£",quotedblbase:"„",quotesinglbase:"‚",rq:"’",S:"§",sim:"~",textasciicircum:"^",textasciitilde:"˜",texttildelow:"~",textasteriskcentered:"*",textbackslash:"'",textbar:"|",textbardbl:"╎",textbigcircle:"◯",textbraceleft:"{",textbraceright:"}",textbullet:"•",textdollar:"$",textemdash:"—",textendash:"—",texteuro:"€",eurosym:"€",euro:"€",textexclamdown:"¡",textgreater:">",textless:"<",textordfeminine:"ª",textordmasculine:"º",textperiodcentered:"·",cdot:"·",textquestiondown:"¿",textquotedblleft:"“",textquotedblright:"”",textquoteleft:"‘",textquoteright:"’",textquotestraightbase:"‚",textquotestraightdblbase:"„",textregistered:"®",textthreequartersemdash:"-",texttrademark:"™",texttwelveudash:"-",textunderscore:"_",textvisiblespace:"␣",gets:"←",textleftarrow:"←",to:"→",textrightarrow:"→",textdegree:"°",infty:"∞",triangle:"△",triangledown:"▽",blacktriangle:"▲",blacktriangledown:"▼",angle:"∠",sphericalangle:"∢",aleph:"ℵ",hbar:"ħ",imath:"𝚤",jmath:"𝚥",ell:"ℓ",wp:"℘",Re:"ℜ",Im:"ℑ",mho:"℧",prime:"′",emptyset:"∅",nabla:"∇",surd:"√",partial:"∂",top:"⟙",bot:"⟂",vdash:"⟝",dashv:"⟞",forall:"∀",exists:"∃",nexists:"∄",neg:"¬",lnot:"¬",flat:"♭",natural:"♮",sharp:"♯",backslash:"\\",Box:"□",Diamond:"♢",clubsuit:"♣",diamondsuit:"♦",heartsuit:"♥",spadesuit:"♠",Join:"⨝",blacksquare:"■",bigstar:"★",diagdown:"╲",diagup:"╱",blacklozenge:"⧫",rfloor:"⌋",lfloor:"⌊",rceil:"⌉",lceil:"⌈",rangle:"⟩",langle:"⟨",sum:"∑",int:"∫",oint:"∮",prod:"∏",coprod:"∏",bigcap:"∩",bigcup:"∪",bigsqcup:"⊔",bigvee:"∨",bigwedge:"∧",bigodot:"⊙",bigotimes:"⊗",bigoplus:"⊕",biguplus:"⊎",alpha:"α",beta:"β",chi:"χ",delta:"δ",epsilon:"ε",eta:"η",gamma:"γ",iota:"ι",kappa:"κ",lambda:"λ",mu:"μ",nu:"ν",omega:"ω",phi:"φ",pi:"π",psi:"ψ",rho:"ρ",sigma:"σ",tau:"τ",theta:"θ",upsilon:"υ",xi:"ξ",zeta:"ζ",Alpha:"Α",Beta:"Β",Chi:"Χ",Delta:"Δ",Epsilon:"Ε",Eta:"Η",Gamma:"Γ",Iota:"Ι",Kappa:"Κ",Lambda:"Λ",Mu:"Μ",Nu:"Ν",Omega:"Ω",Phi:"Φ",Pi:"Π",Psi:"Ψ",Rho:"Ρ",Sigma:"Σ",Tau:"Τ",Theta:"Θ",Upsilon:"Υ",Xi:"Ξ",Zeta:"Ζ",aa:"å",AA:"Å",ae:"æ",AE:"Æ",dh:"ð",DH:"Ð",dj:"đ",DJ:"Đ",ij:"ij",IJ:"IJ",l:"ł",L:"Ł",ng:"ŋ",NG:"Ŋ",o:"ø",O:"Ø",oe:"œ",OE:"Œ",ss:"ß",SS:"SS",th:"þ",TH:"Þ"};var cn=/^(\^|_|\\[^#$%&~_^\\{}()\s]+)(\{)?/,dn=/^%[^\n]+(?:\n|$)/,fn=/^[^#$%&~_^\\{}]+/,gn=/^\\([&{}$%#_])/,pn=/(?:\\[\\@,!:;-]|-{2,3}|[!?]`|``?|,,|''?|~|<<|>>)/g,yn={"---":"—","--":"–","!`":"¡","?`":"¿","``":"“",",,":"„","''":"”","`":"‘","'":"’","<<":"«",">>":"»","~":" ","\\-":"­","\\,":" ","\\;":" ","\\:":" ","\\!":" ","\\@":"\uFEFF","\\\\":"\\newline{}"},G={bf:function(e){e.weight="bold"},it:function(e){e.style="italic"},sl:function(e){e.style="italic"},color:function(e,n){e.color=n},href:function(e,n){e.href=n},"^":function(e){e.sup=!0},_:function(e){e.sub=!0},par:function(e){this.tokens.push(new it,new it)},newline:function(e){this.tokens.push(new it)},url:function(e,n){this.open_context().href=n,this.add_token(new B(n)),this.close_context()}};G.textsuperscript=G["^"],G.textsubscript=G._,G.textsl=G.sl,G.mathbf=G.bf,G.mathit=G.it,G.textbf=G.bf,G.textit=G.it,G.textcolor=G.color;var mn=/[\r\n\xA0]+/g;function vn(e,n){e.sup&&(e.baseline=.45,e.size=.7),e.sub&&(e.baseline=-.3,e.size=.7);var o=n;return(e.style||e.weight||e.baseline||e.color||e.size||e.family)&&(o=E(n,e)),o}function or(e,n,o){for(var i,u,y=e.width;y+o.width>n&&e.length;)u=(i=e[e.length-1]).width,i.width>o.width?(i.value=i.value.slice(0,-1),i.width=N(i,i.font),y+=i.width):e.pop(),y-=u;e[e.length-1]instanceof xt&&e.pop(),i=e[e.length-1]||i||{},o.font=E(o.font,i.bold,i.italic,""),o.href=e.length?i.href:null,o.rel=e.length?i.rel:null,o.target=e.length?i.target:null,e.push(o)}function Dt(e){return Math.round(1e6*e)/1e6}function ar(e){return function(n){if(Array.isArray(n))return pe(n)}(e)||function(n){if(typeof Symbol<"u"&&n[Symbol.iterator]!=null||n["@@iterator"]!=null)return Array.from(n)}(e)||function(n,o){if(n){if(typeof n=="string")return pe(n,o);var i=Object.prototype.toString.call(n).slice(8,-1);return i==="Object"&&n.constructor&&(i=n.constructor.name),i==="Map"||i==="Set"?Array.from(n):i==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?pe(n,o):void 0}}(e)||function(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
8
+ In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}()}function pe(e,n){(n==null||n>e.length)&&(n=e.length);for(var o=0,i=new Array(n);o<n;o++)i[o]=e[o];return i}var wn={center:"middle",right:"end"},xn={middle:.5,center:.5,bottom:1,end:1},ye=function(e,n){return!e&&!n||e===n};function bn(e,n){var o=[],i=n.font(),u=i.size,y=i.family,w=n.align(),v=n.createElement();if(e.length){var S=i.height,_=n.valign(),I=n.height()(),$=n.width()(0),D=!isFinite($)&&e.length===1,M=D?null:n.x(),q=Dt(S/u),Q=D?null:Dt(S/(1.15*u+(S-u)/2));if(xn[_]&&isFinite(I)){var F=_==="bottom"?1:.5;Q+=(I*F-S*e.length*F)/u}var z=w==="justify",R=0;w==="right"?R=$:w==="center"&&(R=$/2);for(var j=[],tt="tspan",Z=null,W="",T=function(){if(W){var bt=v(tt,Z,W);j.push(bt)}tt="tspan",Z=null,W=""},st=0,et=e.length;st<et;st++){var ft="",yt="",ht=0,gt=e[st];if(gt.length){j=[];for(var Lt=0,Pt=0,pt=void 0,Y=0,Jt=gt.length;Y<Jt;Y++){var X=gt[Y],J=X.font;X.whitespace&&Lt++,Pt+=X.width,Y&&!X.tracking&&!ht&&ye(J.id,ft)&&ye(X.class,yt)&&ye(pt,X.href)?W+=X.value:(T(),W=X.value,Z={fontFamily:J.family!==y?J.family:null,fontSize:J.size!==u?J.size:null,fontWeight:J.weight||null,fontStyle:J.style||null,fontVariant:J.variant!=="normal"&&J.variant||null,fill:J.color||null,baselineShift:J.baseline?100*J.baseline+"%":null,className:X.class||null},ht&&(Z.dx=Dt(ht),ht=0),X.tracking&&(ht=J.size*X.tracking),X.href&&!pt?(pt=X.href,tt="a",Z.href=pt,Z.rel=X.rel,Z.target=X.target):pt=null,ft=J.id,yt=X.class)}if(T(),D)o.push.apply(o,ar(j));else{var Kt=null,Ft=st===et-1||gt[gt.length-1]instanceof it;z&&gt.length>1&&!Ft&&(Kt=Dt(($-Pt)/Lt)),o.push(v.apply(void 0,["tspan",{wordSpacing:Kt,x:M(st)+R,dy:Dt(st?q:Q)+"em"}].concat(ar(j))))}}else o.push(v("tspan",{x:M(st),dy:Dt(st?q:Q)+"em"}," "))}}return v.apply(void 0,["text",{fontFamily:y,fontSize:u,textAnchor:wn[w]||"start"}].concat(o))}var An={middle:.5,center:.5,bottom:1,end:1};function kn(e,n,o){if(e.length){o.textBaseline="middle";var i=n.font(),u=i.height,y=i.size,w=n.valign(),v=n.height()(),S=n.width()(0),_=n.align(),I=_==="justify",$=.5*u,D=An[w];if(D&&isFinite(v)){var M=e.length*u;$+=v*D-M*D}e.forEach(function(q,Q){var F=n.x()(Q),z=Q*u+$,R=0,j=0;q.forEach(function(W){W.whitespace&&R++,j+=W.width});var tt=0,Z=Q===e.length-1||q[q.length-1]instanceof it;I&&q.length>1&&!Z&&(tt=(S-j)/R),q.forEach(function(W){o.font=W.font;var T=W.font,st=T.baseline?y*-T.baseline+.15*y:0;o.fillStyle=function(yt,ht){return yt.color?yt.color:ht.href?"#00C":"#000"}(T,W);var et=0;if(_==="right"?et+=S-j:_==="center"?et+=S/2-j/2:_==="justify"&&(W.whitespace||W instanceof it)&&(F+=tt),o.fillText(W.value,F+et,z+st),W.href){o.beginPath(),o.strokeStyle=o.fillStyle;var ft=Math.floor(z+.45*y)+.5;o.moveTo(F+et,ft),o.lineTo(F+et+W.width,ft),o.stroke()}F+=W.width})})}}function me(e){return me=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(n){return typeof n}:function(n){return n&&typeof Symbol=="function"&&n.constructor===Symbol&&n!==Symbol.prototype?"symbol":typeof n},me(e)}function lr(e){for(var n={},o=0;o<e.length;o++){var i=e[o];typeof i!="number"&&i!=null&&(typeof i=="string"?n.text=i:typeof i=="function"?n.fn=i:me(i)==="object"&&i._groups?n.d3=i:i&&i.nodeType&&i.getContext?n.ctx=i.getContext("2d"):i&&i.fillText&&i.beginPath?n.ctx=i:i&&(n.text=i))}return n}function Ot(e){return Ot=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(n){return typeof n}:function(n){return n&&typeof Symbol=="function"&&n.constructor===Symbol&&n!==Symbol.prototype?"symbol":typeof n},Ot(e)}function En(e,n){for(var o=0;o<n.length;o++){var i=n[o];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(e,(u=function(y,w){if(Ot(y)!=="object"||y===null)return y;var v=y[Symbol.toPrimitive];if(v!==void 0){var S=v.call(y,w);if(Ot(S)!=="object")return S;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(y)}(i.key,"string"),Ot(u)==="symbol"?u:String(u)),i)}var u}var Sn=E(),ve=function(e){return typeof e=="function"?e:function(){return e}},lt=function(){function e(i){if(function(y,w){if(!(y instanceof w))throw new TypeError("Cannot call a class as a function")}(this,e),this.props={overflow:"ellipsis",lineclamp:null,align:"left",wordBreak:null,valign:"top",width:function(){return 1/0},height:function(){return 1/0},x:function(){return 0},font:null,tAnchor:0,parser:e.defaultparser},i)for(var u in i)typeof this[u]=="function"&&this[u](i[u])}var n,o;return n=e,o=[{key:"linebreak",value:function(i){var u=this,y=this.props.parser(String(i)),w=this.font(),v=function(S,_,I){if(!S.length)return[];var $=_.height(),D=_.width(),M=_.overflowLine(),q=_.overflowWrap(),Q=E(I,!0,!1),F=isFinite($())?Math.floor($()/I.height):1/0;if(!$()&&!D(0)||!F)return[];for(var z=0,R=0,j=0,tt=[],Z=[],W=!1;z<S.length&&R<F;){var T=S[z],st=vn(T,I);if(T.width=N(T,st),T.font=st,T.line=R,T.whitespace=T.value in x,T.value&&(T.value=T.value.replace(mn," ")),!(!j&&T.whitespace||W&&T.whitespace))if(T instanceof it)j=0,Z=[],tt.push(z+1),R++;else if(T instanceof Mt||T instanceof xt)Z.push({index:z,width:j});else if(T.whitespace||j+T.width<D(R))j+=T.width;else if(Z.length){var et=void 0,ft=void 0;do{ft=!0,et=Z.pop();var yt=S[et.index],ht=void 0;yt instanceof xt&&(ht=N("-",yt.font),et.width+ht>D(R)&&(ft=!Z.length))}while(!ft);tt.push(et.index+1),j=0,R++,z=et.index,Z=[]}else if(q==="break-word"){var gt=D(R);if(j+T.width>gt){var Lt=T.clone();do T.value=T.value.slice(0,-1),T.width=N(T,T.font),j+=T.width;while(T.value&&T.width>gt);Lt.value=Lt.value.slice(T.value.length),S.splice(z+1,0,new Mt,Lt)}tt.push(z+1),j=0,R++}else j+=T.width;z++,W=T.whitespace}z!==tt[tt.length-1]&&tt.push(z);var Pt=0,pt=0,Y=tt.map(function(bt){for(var K,At=Pt;(K=S[At])&&(K.whitespace||!K.value);)At++;for(var mt=bt,be=null;mt>At&&(K=S[mt-1])&&(K.whitespace||!(K.value||K instanceof xt));)K instanceof it&&(be=K),mt--;K instanceof xt&&(K.value="-",K.width=N("-",K.font)),Pt=bt;var Tt=S.slice(At,mt).filter(function(Ae){return Ae.value});return be&&Tt.push(be),Tt.width=Tt.reduce(function(Ae,Tn){return Ae+Tn.width},0),Tt.width>pt&&(pt=Tt.width),Tt});if(Y.hasLineOverflow=!1,M){var Jt=M==="ellipsis"?"…":M;Y.forEach(function(bt,K){var At=D(K);if(bt.width>At){var mt=new B(Jt);mt.font=I,mt.width=N(Jt,Q),or(bt,At,mt),Y.hasLineOverflow=!0}})}var X=_.overflow()==="ellipsis"?"…":_.overflow();if(X&&z!==S.length){var J=D(Y.length-1),Kt=Y[Y.length-1],Ft=new B(X);Ft.font=I,Ft.width=N(X,Q),or(Kt,J,Ft),Y.hasOverflow=!0}else Y.hasOverflow=!1;return Y.font=I,Y.width=pt,Y}(y,this,w);return v.height=v.length*w.height,v.render=function(S){return u.render(v,S)},v.svg=v.render,v.draw=v.render,v}},{key:"font",value:function(i){return arguments.length?(this.props.font=E(i),this):this.props.font||E(Sn)}},{key:"overflow",value:function(i){return arguments.length?(this.props.overflow=String(i),this):this.props.overflow}},{key:"overflowLine",value:function(i){return arguments.length?(this.props.lineclamp=String(i),this):this.props.lineclamp}},{key:"valign",value:function(i){return arguments.length?(this.props.valign=i,this):this.props.valign}},{key:"align",value:function(i){if(!arguments.length)return this.props.align;var u=String(i).toLowerCase();return u==="left"||u==="start"?(this.props.align="left",this.props.tAnchor=0):u==="center"||u==="middle"?(this.props.align="center",this.props.tAnchor=-.5):u==="end"||u==="right"?(this.props.align="right",this.props.tAnchor=-1):u==="justify"&&(this.props.align=i,this.props.tAnchor=0),this}},{key:"overflowWrap",value:function(i){if(!arguments.length)return this.props.overflowWrap||"normal";var u=String(i).toLowerCase();return u==="break-word"?this.props.overflowWrap="break-word":u!=="normal"&&i!=null||(this.props.overflowWrap=null),this}},{key:"width",value:function(i){return arguments.length?(this.props.width=ve(i),this):this.props.width}},{key:"height",value:function(i){return arguments.length?(this.props.height=ve(i),this):this.props.height}},{key:"x",value:function(i){return arguments.length?(this.props.x=ve(i),this):this.props.x}},{key:"parser",value:function(i){if(!arguments.length)return this.props.parser;if(typeof i=="string"){var u=e[i]||e[i+"parser"];typeof u=="function"&&(i=u)}if(typeof i!="function")throw new Error("Unknown parser: "+i);return this.props.parser=i,this}},{key:"createElement",value:function(i){return arguments.length?(this.props.createElement=i,this):this.props.createElement||e.createElement}},{key:"render",value:function(){var i=lr(arguments);return typeof i.text=="string"&&(i.text=this.linebreak(i.text)),i.ctx?kn(i.text,this,i.ctx):bn(i.text,this)}}],o&&En(n.prototype,o),Object.defineProperty(n,"prototype",{writable:!1}),e}();function zt(e){return zt=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(n){return typeof n}:function(n){return n&&typeof Symbol=="function"&&n.constructor===Symbol&&n!==Symbol.prototype?"symbol":typeof n},zt(e)}function we(e,n){(n==null||n>e.length)&&(n=e.length);for(var o=0,i=new Array(n);o<n;o++)i[o]=e[o];return i}function Cn(e,n){for(var o=0;o<n.length;o++){var i=n[o];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(e,(u=function(y,w){if(zt(y)!=="object"||y===null)return y;var v=y[Symbol.toPrimitive];if(v!==void 0){var S=v.call(y,w);if(zt(S)!=="object")return S;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(y)}(i.key,"string"),zt(u)==="symbol"?u:String(u)),i)}var u}var hr=function(e){return typeof e=="function"?e:function(){return e}},ur=function(){function e(i){if(function(y,w){if(!(y instanceof w))throw new TypeError("Cannot call a class as a function")}(this,e),this.props={width:function(){return 1/0},height:function(){return 1/0},rotation:0,vAnchor:0,hAnchor:0},i)for(var u in i)typeof this[u]=="function"&&this[u](i[u]);this.render=this.render.bind(this)}var n,o;return n=e,o=[{key:"anchor",value:function(i){var u=this.props,y=u.hAnchor,w=u.vAnchor,v=u.width,S=u.height;if(!arguments.length)return[y*v(0),w*S(0)];if(typeof i=="string"){var _=this.props;i.toLowerCase().trim().split(/\s+/).forEach(function(I){I==="top"&&(_.vAnchor=-0),I==="middle"&&(_.vAnchor=-.5),I==="bottom"&&(_.vAnchor=-1),I==="left"&&(_.hAnchor=-0),I==="center"&&(_.hAnchor=-.5),I==="right"&&(_.hAnchor=-1)})}return this}},{key:"width",value:function(i){return arguments.length?(this.props.width=hr(i),this):this.props.width}},{key:"height",value:function(i){return arguments.length?(this.props.height=hr(i),this):this.props.height}},{key:"rotate",value:function(i){return arguments.length?(this.props.rotation=i,this):this.props.rotation}},{key:"createElement",value:function(i){return arguments.length?(this.props.createElement=i,this):this.props.createElement||e.createElement}},{key:"canvas",value:function(i,u){var y,w=i.getContext?i.getContext("2d"):i;return w.save(),w.rotate(this.rotate()*Math.PI/180),w.translate.apply(w,function(v){if(Array.isArray(v))return we(v)}(y=this.anchor())||function(v){if(typeof Symbol<"u"&&v[Symbol.iterator]!=null||v["@@iterator"]!=null)return Array.from(v)}(y)||function(v,S){if(v){if(typeof v=="string")return we(v,S);var _=Object.prototype.toString.call(v).slice(8,-1);return _==="Object"&&v.constructor&&(_=v.constructor.name),_==="Map"||_==="Set"?Array.from(v):_==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(_)?we(v,S):void 0}}(y)||function(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
9
+ In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}()),u(w),w.restore(),w}},{key:"render",value:function(){var i=lr(arguments);if(i.d3)return i.d3.attr("transform","rotate(".concat(this.rotate(),") translate(").concat(this.anchor(),")"));if(i.ctx)return this.canvas(i.ctx,i.fn);if(i.text){var u=typeof i.text.render=="function"?i.text.render():i.text;return this.createElement()("g",{transform:"rotate(".concat(this.rotate(),") translate(").concat(this.anchor(),")")},u)}}}],o&&Cn(n.prototype,o),Object.defineProperty(n,"prototype",{writable:!1}),e}(),_n=Object.prototype.hasOwnProperty,xe={};function Dn(e){return xe[e]||(xe[e]=e.replace(/([a-z])([A-Z])/g,function(n,o,i){return o+"-"+i.toLowerCase()})),xe[e]}function cr(e,n){if(Array.isArray(n))return n.forEach(function(o){return cr(e,o)});typeof n=="string"&&(n=document.createTextNode(n)),e.appendChild(n)}function dr(e,n){if(typeof document<"u"){var o=typeof e=="string"?document.createElementNS("http://www.w3.org/2000/svg",e):e;if(n&&o.setAttribute)for(var i in n)_n.call(n,i)&&n[i]!=null&&o.setAttribute(i==="className"?"class":Dn(i),n[i]);for(var u=arguments.length,y=new Array(u>2?u-2:0),w=2;w<u;w++)y[w-2]=arguments[w];return y!=null&&y.length&&y.forEach(function(v){cr(o,v)}),o}}lt.createElement=dr,lt.textparser=Yt,lt.defaultparser=Yt,lt.htmlparser=function(e){e=String(e||"").trim();for(var n,o,i={weight:null,style:null,sub:!1,sup:!1,href:null,color:null,rel:null,target:null},u=[],y=[],w=function($){for(var D in i)i[D]&&($[D]=i[D]);u.push($)},v=function($){var D=u.length,M=an[$];if(D&&M){for(var q=D-1;u[q]&&(u[q]instanceof Mt||en.test(u[q].value));)q--;for(;M&&u[q]&&u[q]instanceof it;)q--,M--;for(;M-- >0;)u.push(new it)}};e.length;){if(n=/^[^<]+/.exec(e))Yt(ir(n[0]),!1).forEach(w);else if(!(n=sn.exec(e)))if(n=rn.exec(e))y.length&&(i=y.pop()),v(n[1]);else if(n=nn.exec(e)){var S=n[1];v(S),y.push(i),i=Object.create(i),nr[S]&&nr[S](i,"");var _=un(n[2]);S==="a"&&(_.href&&(i.href=_.href),_.rel&&(i.rel=_.rel),_.target&&(i.target=_.target)),_.class&&(i.class=i.class?i.class+" "+_.class:_.class),_.style&&(o=/(?:^|\s|;)color\s*:\s*([^;\s"']+)/.exec(_.style))&&o[1]&&(i.color=o[1]),S==="br"&&u.push(new it)}else n=[e.slice(0,1)],w(new B(n[0]));e=e.slice(n[0].length)}for(var I=u[u.length-1];I instanceof it;)u.pop(),I=u[u.length-1];return u},lt.latexparser=function(e){e=String(e||"").trim();var n=[0];e=e.replace(/\\verb,(.*?),/,function(F,z){return n.push(z),"\\verb,"+(n.length-1)+","}).replace(/\\\\\n/g,function(){return"\\\\"}).replace(pn,function(F,z,R){return R.charAt(z-1)==="\\"?F:yn[F]}).replace(/\n\s+/g,function(F){return/\n/.test(F.slice(1))?"\\par ":F}).replace(/\\symbol\{(\d+)\}/,function(F,z,R,j){return j.charAt(R-1)==="\\"?F:String.fromCharCode(1*z)}).replace(/(^|[^\\])(\^|_)(\d|[^{]\S*)/g,function(F,z,R,j){return z+R+"{"+j+"}"}).replace(/\\verb,(.*?),/,function(F,z){return"\\verb,".concat(n[+z],",")});for(var o,i={weight:null,italic:null,variant:null,sub:!1,sup:!1,href:null},u=[],y=[],w=function(F){for(var z in i)i[z]&&(F[z]=i[z]);return u.push(F),F},v=function(){y.push(i),i=Object.create(i)},S=function(){if(!y.length)throw new Error("Unexpected }");i=y.pop()},_={tokens:u,open_context:v,close_context:S,add_token:w};e.length;){if(o=fn.exec(e))Yt(o[0],!1).forEach(w);else if(o=gn.exec(e))w(new B(o[1]));else if(!(o=dn.exec(e))){if(o=/^\{/.exec(e))v();else if(o=/^\}/.exec(e))S();else if(!(o=/^\$/.exec(e)))if(o=/^\\verb,([^,]+),/.exec(e))w(new B(o[1]));else if(o=cn.exec(e)){var I=o[1].slice(1)||o[1],$=!!o[2];if(/^(La)?TeX$/i.test(I)){v(),i.family="serif";var D=void 0;I==="LaTeX"&&((D=w(new B("L"))).tracking=-.25,(D=w(new B("A"))).size=.7,D.baseline=.3,D.tracking=-.1),(D=w(new B("T"))).tracking=-.17,(D=w(new B("E"))).baseline=-.22,D.tracking=-.13,D=w(new B("X")),S()}else if(I in sr)w(new B(sr[I])),$&&v();else if(I in G){var M=[],q=G[I].length-1,Q=void 0;if(q){for($=!1,e=e.slice(o[0].length-1);q--;){if(!(Q=/^\{([^}]+)\}/.exec(e)))throw new Error(I+" is missing an argument");M.push(Q[1]),e=e.slice(Q[0].length)}o[0]=/^\{/.exec(e)?"{":"",$=!!o[0]}$&&v(),G[I].apply(_,[i].concat(M))}else console.warn("unknown latex command",I),w(new B(o[1])),$&&v()}else o=[e.slice(0,1)],w(new B(o[0]))}e=e.slice(o[0].length)}return u},lt.measureText=function(e,n,o){return N(e,E(n),o)},lt.Token=B,lt.Break=Mt,lt.LineBreak=it,lt.SoftHyphen=xt,lt.Rotator=ur,ur.createElement=dr;const Ln=lt;return r.default})())}(se)),se.exports}var Pr=zr();const Xe=Pe(Pr);function oe(l){return l.replace(/…$/,"")}function ae(l){return l.children[0].innerHTML}function Fr(l,t){const s=ut(l),{fontSize:r,font:a,padding:h=0}=l.properties.style||{};if(s.width===s.height&&s.width===0)return;const c=new Xe({font:`${r}px/${r}px ${a}`.replace(/(px)+/g,"px"),width:s.width-h*2,height:s.height-h*2,align:"left",valign:"top",x:0,overflow:"ellipsis",parser:"html",createElement:Xe.createElement});c.overflowWrap("break-word");const f=c.linebreak(l.properties.content.replaceAll(`
10
+ `,"<br>")).render(),d=[...f.children];let g=0;const p=[];l.properties.content.split(`
11
+ `).forEach(k=>{let E=k;for(;E.length&&g<d.length;){if(d[g].innerHTML==="&nbsp;"){E.startsWith(`
12
+ `)||p.push(g),g++;break}const x=oe(ae(d[g]));E.startsWith(x)&&(E=E.slice(x.length).trim()),g++}}),p.forEach(k=>f.removeChild(d[k]));const b=l.properties.content.match(/(https?:\/\/.*)/gm),A=b?b.map(k=>k.split(" ")[0]):[];f.setAttribute("transform",`translate(${h}, ${h})`),A.forEach(k=>{let E=k;const x=[];for(;E.length>0;){const L=d.find(C=>!!C.children[0]&&C.children[0].tagName==="tspan"&&E.startsWith(oe(ae(C))));if(!L)break;x.push(L);const O=oe(L.children[0].innerHTML).length;if(!O)break;E=E.slice(O)}x.forEach(L=>{const O=document.createElementNS("http://www.w3.org/2000/svg","a");O.setAttribute("href",k),O.setAttribute("target","_blank"),O.innerHTML=ae(L),L.children[0].innerHTML="",L.children[0].appendChild(O)})}),t.appendChild(f)}const Ge=20;class Hr extends Ne{constructor(t,s={}){super(t,`
42
13
  <div class="annotation-text-handle" data-handle-id="8">
43
14
  <span class="handle line-handle top" data-handle-id="0"></span>
44
15
  <span class="handle line-handle bottom" data-handle-id="1"></span>
@@ -50,4 +21,4 @@ In order to be iterable, non-array objects must have a [Symbol.iterator]() metho
50
21
  <span class="handle left bottom left-handle point-handle bottom-left" data-handle-id="7"></span>
51
22
  <textarea wrap="on"></textarea>
52
23
  </div>
53
- `),x(this,"textArea"),x(this,"handleSize"),x(this,"rect",{x:0,y:0,width:0,height:0}),x(this,"annotation",{...Ge}),x(this,"startX",0),x(this,"startY",0),x(this,"handles",[]),x(this,"draggedHandle",V),x(this,"isFocused",!1),x(this,"placeholder","Type your text here..."),x(this,"_onFocus",()=>{this.textArea.value===this.placeholder&&(this.textArea.value=""),this.isFocused=!0}),x(this,"_onBlur",()=>{this.isFocused=!1}),x(this,"startDrawing",(l,h,d=An(l,h,0,0,"",Mt))=>{this.add(d);const g=this.ogma.view.graphToScreenCoordinates({x:l,y:h});this.select(d.id),this.startDragging(this.getById(d.id),g.x,g.y),this.draggedHandle=6}),x(this,"cancelDrawing",()=>{this.isDragging&&(this.remove(this.annotation.id),this.annotation={...Ge},this.draggedHandle=V,this.isDragging=!1,this.emit(Ft,this.annotation))}),x(this,"startDragging",(l,h,d)=>{this.annotation=l;const g=gt(this.annotation),f=ft(this.annotation);this.rect.x=g.x,this.rect.y=g.y,this.rect.width=f.width,this.rect.height=f.height,this.startX=h,this.startY=d,this.disableDragging(),this.textArea.classList.add("noevents"),this.textArea.setAttribute("disabled","disabled"),this.emit(ke,this.annotation),this.isDragging=!0}),x(this,"onHandleMouseDown",l=>{const h=this.getById(this.selectedId)||this.getById(this.hoveredId);if(!h)return;this.selectedId!==h.id&&this.select(this.hoveredId);const{x:d,y:g}=xe(l,this.ogma.getContainer());this.startDragging(h,d,g),this.draggedHandle=kr(l.target)}),x(this,"onMouseMove",l=>{requestAnimationFrame(()=>this._onMouseMove(l))}),x(this,"_onMouseMove",l=>{if(!this.isDragging)return;l.stopPropagation(),l.preventDefault();const h=this.handles[this.draggedHandle];let d=h.classList.contains("top");const g=h.classList.contains("left"),f=h.classList.contains("right"),v=h.classList.contains("bottom");let y=h.classList.contains("line-handle");!y&&!d&&!v&&!g&&!f&&(d=!0,y=!0);const{x:A,y:k}=xe(l,this.ogma.getContainer());let S=this.rect.x,R=this.rect.y,C=Math.max(this.rect.width,qr),L=Math.max(this.rect.height,qr);const I=this.ogma.view.getZoom(),_=(A-this.startX)/I,z=(k-this.startY)/I,W=this.ogma.view.getAngle(),rt=st({x:_,y:z},W),it=st({x:_,y:z},-W);y?(S=this.rect.x+rt.x,R=this.rect.y+rt.y):g&&d?(S+=rt.x,R+=rt.y,C-=_,L-=z):f&&v?(C+=_,L+=z):g&&v?(S+=it.x,C-=it.x,L+=it.y):f&&d&&(R+=it.y,C+=it.x,L-=it.y),un(this.annotation,S,R,C,L),this.emit(Ae,this.annotation,"text"),this.refreshEditor(),this.layer.refresh()}),x(this,"onMouseUp",()=>{!this.isDragging||this.draggedHandle===V||(this.restoreDragging(),this.textArea.classList.remove("noevents"),this.textArea.removeAttribute("disabled"),this.emit(Ft,this.annotation),this.isDragging=!1,this.draggedHandle=V)}),x(this,"_onMousedown",l=>{l.stopPropagation()}),x(this,"onViewChanged",()=>{const l=Math.max(2,this.handleSize/this.ogma.view.getZoom());document.documentElement.style.setProperty("--handle-scale",`${1/l}`),this.ogma.view.getAngle()===0?this.editor.element.classList.remove("rotated"):this.editor.element.classList.add("rotated")}),x(this,"_onInput",()=>{const l=this.getById(this.selectedId);l&&(this.textArea.value=this.textArea.value.replace(/ +(?= )/g,""),this.textArea.focus(),l.properties.content=this.textArea.value,this.emit(Ve,l),this.layer.refresh())}),this.showeditorOnHover=!1,this.handleSize=Hr.handleSize,this.placeholder=Hr.placeholder;const n=this.textArea=this.editor.element.querySelector("textarea");n.addEventListener("input",this._onInput),n.addEventListener("focus",this._onFocus),n.addEventListener("blur",this._onBlur),n.addEventListener("mousedown",this._onMousedown),n.spellcheck=!1,this.handles=Array.prototype.slice.call(this.editor.element.querySelectorAll(".annotation-text-handle > .handle")),this.handles.push(this.editor.element),this.handles.forEach(l=>l.addEventListener("mousedown",this.onHandleMouseDown)),document.addEventListener("mouseup",this.onMouseUp),document.addEventListener("mousemove",this.onMouseMove,!0),e.events.on(["viewChanged","zoom"],this.onViewChanged)}_canRemove(){return!this.isFocused}detect({x:e,y:o},n=0){const l={x:e,y:o},h=this.ogma.view.getAngle();return this.elements.find(d=>{const{x:g,y:f}=gt(d),{width:v,height:y}=ft(d),A={x:g,y:f},{x:k,y:S}=st(Ct(l,A),-h);return k>-n&&k<v+n&&S>-n&&S<y+n})}draw(e){e.innerHTML="";const o="",n=this.ogma.view.getAngle();for(let h=0;h<this.elements.length;h++){const d=this.elements[h],g=`class${h}`,f=ft(d),v=gt(d);if(d.id===this.selectedId)continue;const{color:y,fontSize:A,font:k,strokeColor:S,strokeWidth:R,strokeType:C,background:L,borderRadius:I}=d.properties.style||Mt,_=St("g");_.classList.add("annotation-text"),_.setAttribute("fill",`${y}`),_.setAttribute("font-size",`${A}px`),_.setAttribute("font-family",`${k}`);const z=St("rect");I&&(z.setAttribute("rx",`${I}`),z.setAttribute("ry",`${I}`));let W=!1;C&&C!=="none"&&(W=!0,z.setAttribute("stroke",S||"black"),z.setAttribute("stroke-width",`${R}`),C==="dashed"&&z.setAttribute("stroke-dasharray","5,5")),(L&&L.length||W)&&(W=!0,z.setAttribute("fill",L||"transparent")),W&&(z.setAttribute("width",`${f.width}`),z.setAttribute("height",`${f.height}`)),_.appendChild(z),Cn(d,_);const{x:rt,y:it}=st(v,-n);_.setAttribute("transform",`translate(${rt},${it})`),_.classList.add(g),_.setAttribute("data-annotation",`${d.id}`),_.setAttribute("data-annotation-type","text"),e.appendChild(_)}const l=St("style");l.innerHTML=o,e.firstChild&&e.insertBefore(l,e.firstChild)}refreshDrawing(){const e=this.ogma.view.getAngle(),o=this.layer.element.children;for(let n=0;n<o.length;n++){const l=o[n];if(!l.hasAttribute("data-annotation"))continue;const h=l.getAttribute("data-annotation"),d=gt(this.getById(h)),{x:g,y:f}=st(d,-e);l.setAttribute("transform",`translate(${g},${f})`)}}getDefaultOptions(){return Ge}refreshEditor(){if(+this.selectedId<0&&+this.hoveredId<0)return;const e=this.getById(this.selectedId)||this.getById(this.hoveredId),o=ft(e),n=this.ogma.view.graphToScreenCoordinates(gt(e)),l=this.ogma.view.getZoom(),{font:h,fontSize:d,color:g,background:f,padding:v=0}=e.properties.style||Mt,y=(d||1)*l;this.textArea.value=e.properties.content;const A=this.editor.element.style;A.transform=`translate(${n.x}px, ${n.y}px)translate(-50%, -50%)translate(${o.width/2*l}px, ${o.height/2*l}px)`,A.width=`${o.width*l}px`,A.height=`${o.height*l}px`;const k=this.textArea.style;k.font=`${y} ${h}`,k.fontFamily=h||"sans-serif",k.fontSize=`${y}px`,k.padding=`${l*v}px`,k.lineHeight=`${y}px`,k.boxSizing="border-box",k.color=g||"black",k.background=f||"transparent",this.textArea.placeholder=this.placeholder,this.layer.refresh()}select(e){super.select(e),this.textArea.classList.add("noevents")}destroy(){super.destroy(),document.removeEventListener("mouseup",this.onMouseUp),document.removeEventListener("mousemove",this.onMouseMove,!0),this.ogma.events.off(this.onViewChanged)}}class Rn{constructor(){x(this,"links",{}),x(this,"linksByTargetId",{}),x(this,"linksByArrowId",{})}add(e,o,n,l,h){const d=ye(),g=e.id,f={id:d,arrow:g,target:n,targetType:l,connectionPoint:h,side:o};return this.links[d]=f,this.linksByTargetId[n]||(this.linksByTargetId[n]=[]),this.linksByTargetId[n].push(d),this.linksByArrowId[g]||(this.linksByArrowId[g]={}),this.linksByArrowId[g][o]=d,e.properties.link=e.properties.link||{},e.properties.link[o]={id:n,side:o,type:l,magnet:h},this}arrowIsLinked(e,o){var n;return!!((n=this.linksByArrowId[e])!=null&&n[o])}remove(e,o){var n,l;const h=e.id,d=(n=this.linksByArrowId[h])==null?void 0:n[o];if((l=e.properties.link)==null||delete l[o],!d)return this;const g=this.links[d];delete this.links[d];const f=this.linksByTargetId[g.target];for(let v=0;v<f.length;v++)if(f[v]===d){f.splice(v,1);break}return delete this.linksByArrowId[h][o],this}getArrowLink(e,o){var n;const l=(n=this.linksByArrowId[e])==null?void 0:n[o];return l?this.links[l]:null}getTargetLinks(e,o){var n;return((n=this.linksByTargetId[e])==null?void 0:n.map(l=>this.links[l]).filter(l=>l.targetType===o))??[]}forEach(e){Object.values(this.links).forEach(e)}}const ut=u=>u.properties.type==="arrow",pt=u=>u.properties.type==="text",Ur=u=>u.type==="FeatureCollection",On={magnetColor:"#3e8",detectMargin:20,magnetHandleRadius:5,magnetRadius:10,textPlaceholder:"Type here",arrowHandleSize:3.5,textHandleSize:3.5,minArrowHeight:20,maxArrowHeight:30},Yr=["start","end"],Vr=[{x:0,y:0},{x:.5,y:0},{x:1,y:0},{x:0,y:.5},{x:1,y:.5},{x:0,y:1},{x:.5,y:1},{x:1,y:1}];class Dn extends Fr{constructor(e,o={}){super(),x(this,"arrows"),x(this,"texts"),x(this,"links",new Rn),x(this,"layer"),x(this,"annotations"),x(this,"ogma"),x(this,"options"),x(this,"selected",null),x(this,"updateTimeout",0),x(this,"hoveredNode",null),x(this,"dragged",null),x(this,"textToMagnet"),x(this,"activeLinks",[]),x(this,"_render",n=>{if(!this.dragged||this.textToMagnet===void 0)return;n.beginPath(),n.fillStyle="green";const l=this.ogma.view.getZoom();Vr.forEach(h=>{if(!this.textToMagnet)return;const d=ft(this.textToMagnet),g=gt(this.textToMagnet),f=Ee(h,{x:d.width,y:d.height}),v=st(f,this.ogma.view.getAngle()),{x:y,y:A}=It(v,g);n.moveTo(y,A),n.arc(y,A,this.options.magnetHandleRadius/l,0,Math.PI*2)}),n.fill(),n.closePath()}),x(this,"_onFeatureDrag",(n,l)=>{const h=l;if(ut(n)&&h==="line")["start","end"].find(d=>{const g=d==="start"?Jt(n):me(n);return this._snapToText(n,h,g)||this._findAndSnapToNode(n,d,g)});else if(ut(n)&&h!=="line"){const d=h==="start"?Jt(n):me(n);this._snapToText(n,h,d)||this._findAndSnapToNode(n,h,d)}else pt(n)&&(this.activeLinks.forEach(({arrow:d,side:g,connectionPoint:f})=>{const v=this.getAnnotation(d),y=ft(n),A=gt(n),k=Ee(f,{x:y.width,y:y.height}),S=st(k,this.ogma.view.getAngle()),R=It(S,A);v.geometry.coordinates[g==="start"?0:1]=[R.x,R.y]}),this.activeLinks.length&&this.arrows.refreshLayer());this.layer.refresh(),this.emit(Ae,n,l)}),x(this,"_onFeatureDragEnd",n=>{this.dragged!==null&&ut(n)&&Jt(this.dragged)&&Yr.forEach(l=>{this.links.getArrowLink(n.id,l)&&this.emit(wn,{arrow:n,link:this.links.getArrowLink(n.id,l)})}),(pt(n)||ut(n))&&this.onUpdate(n),this.dragged=null,this.activeLinks=[],this.textToMagnet=void 0,this.annotations.forEach(l=>l.enableDetection()),this.layer.refresh(),this.emit(Ft,n)}),x(this,"_onFeatureDragStart",n=>{this.textToMagnet=void 0,ut(n)?this.dragged=n:pt(n)&&this.activeLinks.push(...this.links.getTargetLinks(n.id,"text")),this.annotations.forEach(l=>{const h=l.getSelectedFeature();h&&h!==n&&l.unhover().unselect(),l.disableDetection()}),this.emit(ke,n)}),x(this,"_onNodesDragStart",()=>{this.arrows.unhover().unselect(),this.texts.unhover().unselect()}),x(this,"_onNodesDrag",n=>{const{dx:l,dy:h}=n;this._moveNodes(n.nodes,l,h)}),x(this,"_onLayoutEnd",n=>{n.ids.forEach((l,h)=>{this.links.getTargetLinks(l,"node").forEach(d=>{const g=this.getAnnotation(d.arrow),f=d.side,v=ve(g,f==="start"?"end":"start"),y=n.positions.current[h],A=this.ogma.getNode(l).getAttribute("radius"),k=be(v,y,+A);Lt(g,f,k.x,k.y)})}),this.arrows.refreshLayer(),this.texts.refreshLayer()}),x(this,"_onAdded",n=>{this.emit(Ye,n)}),x(this,"_onRemoved",n=>{this.emit(Ue,n)}),x(this,"_onUnselect",n=>{this.selected=null,this.emit(qe,n)}),x(this,"_onSelect",n=>{this.selected!==n&&(this.selected=n,this.emit(We,this.selected))}),x(this,"onUpdate",n=>{cancelAnimationFrame(this.updateTimeout),this.updateTimeout=requestAnimationFrame(()=>this._onUpdate(n))}),x(this,"_onUpdate",n=>{this.emit(Ve,n)}),this.options=this.setOptions({...On,...o}),this.ogma=e,this.arrows=new En(e,this.options),this.texts=new Tn(e,this.options),this.annotations=[this.arrows,this.texts],this.annotations.forEach(n=>{n.on(ke,this._onFeatureDragStart).on(Ae,this._onFeatureDrag).on(Ft,this._onFeatureDragEnd).on(Ve,this.onUpdate).on(qe,this._onUnselect).on(We,this._onSelect).on(Ye,this._onAdded).on(Ue,this._onRemoved)}),this.ogma.events.on("nodesDragStart",this._onNodesDragStart).on("nodesDragProgress",this._onNodesDrag).on("layoutEnd",this._onLayoutEnd).on(["viewChanged","rotate"],()=>{this.refreshTextLinks()}),this.layer=e.layers.addCanvasLayer(this._render),this.layer.moveToBottom()}_moveNodes(e,o,n){e.forEach(l=>{const h=this.links.getTargetLinks(l.getId(),"node"),d=l.getPosition();h.forEach(g=>{const f=this.getAnnotation(g.arrow),v=g.side,y=ve(f,v==="start"?"end":"start");let A=d;const k=+l.getAttribute("radius"),S=1e-6;(g.connectionPoint.x-(d.x-o)>S||g.connectionPoint.y-(d.y-n)>S)&&(A=be(y,d,k)),Lt(f,v,A.x,A.y)})}),this.arrows.refreshLayer()}_snapToText(e,o,n){const l=this.texts.detect(n,this.options.detectMargin);if(this.links.remove(e,o),!l)return!1;this.textToMagnet=l;const h=this.findMagnetPoint(Vr,l,n);return h?(Lt(e,o,h.point.x,h.point.y),this.links.add(e,o,l.id,"text",h.magnet),!0):!1}_findAndSnapToNode(e,o,n){var l,h;const d=this.ogma.view.graphToScreenCoordinates(n),g=this.ogma.view.getElementAt(d);this.links.remove(e,o),g&&g.isNode?((l=this.hoveredNode)==null||l.setSelected(!1),this.hoveredNode=g,g.setSelected(!0),this._snapToNode(e,o,g,d)):((h=this.hoveredNode)==null||h.setSelected(!1),this.hoveredNode=null)}_snapToNode(e,o,n,l){const h=n.getPositionOnScreen(),d=+n.getAttribute("radius"),g=d*this.ogma.view.getZoom(),f=l.x-h.x,v=l.y-h.y,y=Math.sqrt(f*f+v*v),A=n.getPosition();if(y<g+this.options.detectMargin){let k=A;if(y>g/2){const S=ve(e,o==="end"?"start":"end");k=be(S,k,d)}Lt(e,o,k.x,k.y),this.links.add(e,o,n.getId(),"node",k)}}refreshTextLinks(){let e=!1;this.links.forEach(({connectionPoint:o,targetType:n,target:l,arrow:h,side:d})=>{if(n!=="text")return;e=!0;const g=this.getAnnotation(l),f=this.getAnnotation(h),v=ft(g),y=gt(g),A=Ee(o,{x:v.width,y:v.height}),k=st(A,this.ogma.view.getAngle()),S=It(k,y);Lt(f,d,S.x,S.y)}),e&&this.arrows.refreshLayer()}getSelected(){return this.selected}findMagnetPoint(e,o,n){let l;for(const h of e){const d=ft(o),g=gt(o),f=Ee(h,{x:d.width,y:d.height}),v=st(f,this.ogma.view.getAngle()),y=It(v,g),A=jt(Ct(y,n)),k=Math.min(this.options.magnetRadius*this.ogma.view.getZoom(),d.width/2,d.height/2);if(A<Math.max(k,this.options.magnetHandleRadius)){l={point:y,magnet:h};break}}return l}setOptions(e={}){return this.options={...this.options||{},...e},this.options}select(e){const o=this.getAnnotations().features.find(n=>n.id===e);return o?(ut(o)?this.arrows.select(o.id):pt(o)&&this.texts.select(o.id),this):this}unselect(){return this.selected?(ut(this.selected)?this.arrows.unselect():pt(this.selected)&&this.texts.unselect(),this):this}add(e){if(Ur(e)){const[o,n]=e.features.reduce((l,h)=>(ut(h)?l[1].push(h):pt(h)&&l[0].push(h),l),[[],[]]);return o.forEach(l=>this.add(l)),n.forEach(l=>this.add(l)),this.arrows.refreshLayer(),this}switch(e.properties.type){case"text":this.texts.add(e);break;default:this.arrows.add(e),this.loadLink(e);break}return this}remove(e){return Ur(e)?(e.features.forEach(o=>this.remove(o)),this):(ut(e)?(this.links.remove(e,"start"),this.links.remove(e,"end"),this.arrows.remove(e.id)):this.texts.remove(e.id),this)}loadLink(e){if(e.properties.link)for(const o of Yr){const n=e.properties.link[o];if(!n)continue;const l=this.getAnnotation(n.id);if(n.type==="text"&&l)this.links.add(e,o,n.id,n.type,n.magnet);else if(n.type==="node"){const h=this.ogma.getNode(n.id);if(!h)continue;this.links.add(e,o,n.id,n.type,n.magnet);const d=h.getPosition(),g=h.getAttribute("radius")||0,f=ve(e,o==="start"?"end":"start"),v=be(f,d,+g);Lt(e,o,v.x,v.y)}}}startArrow(e,o,n){this.cancelDrawing(),this.arrows.startDrawing(e,o,n)}startText(e,o,n){this.cancelDrawing(),this.texts.startDrawing(e,o,n)}cancelDrawing(){this.annotations.forEach(e=>e.cancelDrawing()),this.emit(mn)}updateStyle(e,o){const n=this.getAnnotations().features.find(l=>l.id===e);return n?(ut(n)?this.arrows.updateStyle(n,o):pt(n)&&this.texts.updateStyle(n,o),this.onUpdate(n),this):this}setScale(e,o,n,l){const h=this.getAnnotations().features.find(d=>d.id===e);return h?(ut(h)?this.arrows.scale(h,o,n,l):pt(h)&&this.texts.scale(h,o,n,l),this.onUpdate(h),this):this}getAnnotations(){const e={type:"FeatureCollection",features:[]};return this.annotations.forEach(o=>{e.features=[...e.features,...o.getElements()]}),e}getAnnotation(e){return this.getAnnotations().features.find(o=>o.id===e)}destroy(){this.annotations.forEach(e=>e.destroy()),this.layer.destroy()}}const Ze=[8,10,12,14,16,24,32,48,64,72],Qe="none",tr="#333333",Pn=["#FFFFFF","#F44E3B","#FE9200","#FCDC00","#A4DD00","#68CCCA","#73D8FF","#AEA1FF","#1E88E5","#333333","#808080","#cccccc"],Ln=["Roboto","Helvetica Neue","Helvetica","Arial","sans-serif","Georgia, serif","Menlo","Monaco","Consolas","Courier New","monospace"].sort((u,e)=>u.toLocaleLowerCase().localeCompare(e.toLocaleLowerCase())),Gr={head:"arrow",strokeColor:tr,strokeWidth:5},Xr=.25,Jr={font:"Roboto",fontSize:Ze[2],padding:Ze[2]*Xr,color:tr,strokeType:Qe,background:Qe};function Kr(u){return u.reduce((e,o)=>e+o,0)/u.length}function jn(u,e=0,o=1){return e+(o-e)*u}function In(u,e=0,o=1){return(u-e)/(o-e)}function Fn(){return X.createContext(null)}const er=X.createContext(void 0),Mn=()=>X.useContext(er),$n=(u,e)=>{switch(e.type){case"add":return{...u,features:[...u.features,e.payload]};case"remove":return{...u,features:u.features.filter(o=>o.id!==e.payload.id)};case"update":return{...u,features:u.features.map(o=>o.id===e.payload.id?e.payload:o)};default:return u}},zn=({children:u})=>{const e=Zr.useOgma(),[o,n]=X.useReducer($n,{type:"FeatureCollection",features:[]}),[l,h]=X.useState(null),[d,g]=X.useState(Gr),[f,v]=X.useState(Jr),[y,A]=X.useState(),[k,S]=X.useState(1),[R,C]=X.useState(1);return X.useEffect(()=>{if(!e)return;const L=new Dn(e,{minArrowHeight:1}),I=Kr(e.getNodes().getAttribute("radius"))/5,_=k;return g({...d,strokeWidth:(d.strokeWidth||1)*_}),S(_),C(I),L.on("select",z=>{ut(z)?g({...z.properties.style||{}}):pt(z)&&v({...z.properties.style||{}}),h(z)}).on("unselect",()=>{h(null)}),A(L),()=>{L.destroy()}},[e]),X.useEffect(()=>{y&&l&&(l==null?void 0:l.properties.type)==="arrow"&&y.updateStyle(l.id,d)},[y,d,l]),X.useEffect(()=>{y&&l&&(l==null?void 0:l.properties.type)==="text"&&y.updateStyle(l.id,f)},[y,f,l]),rn.jsx(er.Provider,{value:{annotations:o,updateAnnotations:n,currentAnnotation:l,setCurrentAnnotation:h,textStyle:f,setTextStyle:v,arrowStyle:d,setArrowStyle:g,arrowWidthFactor:k,setArrowWidthFactor:S,textSizeFactor:R,setTextSizeFactor:C,editor:y,setEditor:A},children:u})};B.AnnotationsContext=er,B.AnnotationsContextProvider=zn,B.BLACK=tr,B.RELATIVE_PADDING=Xr,B.TRANSPARENT=Qe,B.createAnnotationsContext=Fn,B.defaultArrowStyle=Gr,B.defaultColors=Pn,B.defaultTextStyle=Jr,B.fontSizes=Ze,B.fonts=Ln,B.interpolate=jn,B.mean=Kr,B.normalize=In,B.useAnnotationsContext=Mn,Object.defineProperty(B,Symbol.toStringTag,{value:"Module"})});
24
+ `),m(this,"textArea"),m(this,"handleSize"),m(this,"rect",{x:0,y:0,width:0,height:0}),m(this,"annotation",{...ie}),m(this,"startX",0),m(this,"startY",0),m(this,"handles",[]),m(this,"draggedHandle",U),m(this,"isFocused",!1),m(this,"placeholder","Type your text here..."),m(this,"_onFocus",()=>{this.textArea.value===this.placeholder&&(this.textArea.value=""),this.isFocused=!0}),m(this,"_onBlur",()=>{this.isFocused=!1}),m(this,"startDrawing",(a,h,c=Mr(a,h,0,0,"",_t))=>{this.add(c);const f=this.ogma.view.graphToScreenCoordinates({x:a,y:h});this.select(c.id),this.startDragging(this.getById(c.id),f.x,f.y),this.draggedHandle=6}),m(this,"cancelDrawing",()=>{this.isDragging&&(this.remove(this.annotation.id),this.annotation={...ie},this.draggedHandle=U,this.isDragging=!1,this.emit(Ct,this.annotation))}),m(this,"startDragging",(a,h,c)=>{this.annotation=a;const f=ct(this.annotation),d=ut(this.annotation);this.rect.x=f.x,this.rect.y=f.y,this.rect.width=d.width,this.rect.height=d.height,this.startX=h,this.startY=c,this.disableDragging(),this.textArea.classList.add("noevents"),this.textArea.setAttribute("disabled","disabled"),this.emit(Xt,this.annotation),this.isDragging=!0}),m(this,"onHandleMouseDown",a=>{const h=this.getById(this.selectedId)||this.getById(this.hoveredId);if(!h)return;this.selectedId!==h.id&&this.select(this.hoveredId);const{x:c,y:f}=Rt(a,this.ogma.getContainer());this.startDragging(h,c,f),this.draggedHandle=_e(a.target)}),m(this,"onMouseMove",a=>{requestAnimationFrame(()=>this._onMouseMove(a))}),m(this,"_onMouseMove",a=>{if(!this.isDragging)return;a.stopPropagation(),a.preventDefault();const h=this.handles[this.draggedHandle];let c=h.classList.contains("top");const f=h.classList.contains("left"),d=h.classList.contains("right"),g=h.classList.contains("bottom");let p=h.classList.contains("line-handle");!p&&!c&&!g&&!f&&!d&&(c=!0,p=!0);const{x:b,y:A}=Rt(a,this.ogma.getContainer());let k=this.rect.x,E=this.rect.y,x=Math.max(this.rect.width,Ge),L=Math.max(this.rect.height,Ge);const O=this.ogma.view.getZoom(),C=(b-this.startX)/O,P=(A-this.startY)/O,N=this.ogma.view.getAngle(),nt=rt({x:C,y:P},N),at=rt({x:C,y:P},-N);p?(k=this.rect.x+nt.x,E=this.rect.y+nt.y):f&&c?(k+=nt.x,E+=nt.y,x-=C,L-=P):d&&g?(x+=C,L+=P):f&&g?(k+=at.x,x-=at.x,L+=at.y):d&&c&&(E+=at.y,x+=at.x,L-=at.y),wr(this.annotation,k,E,x,L),this.emit(Ut,this.annotation,"text"),this.refreshEditor(),this.layer.refresh()}),m(this,"onMouseUp",()=>{!this.isDragging||this.draggedHandle===U||(this.restoreDragging(),this.textArea.classList.remove("noevents"),this.textArea.removeAttribute("disabled"),this.emit(Ct,this.annotation),this.isDragging=!1,this.draggedHandle=U)}),m(this,"_onMousedown",a=>{a.stopPropagation()}),m(this,"onViewChanged",()=>{const a=Math.max(2,this.handleSize/this.ogma.view.getZoom());document.documentElement.style.setProperty("--handle-scale",`${1/a}`),this.ogma.view.getAngle()===0?this.editor.element.classList.remove("rotated"):this.editor.element.classList.add("rotated")}),m(this,"_onInput",()=>{const a=this.getById(this.selectedId);a&&(this.textArea.value=this.textArea.value.replace(/ +(?= )/g,""),this.textArea.focus(),a.properties.content=this.textArea.value,this.emit(ne,a),this.layer.refresh())}),this.showeditorOnHover=!1,this.handleSize=We.handleSize,this.placeholder=We.placeholder;const r=this.textArea=this.editor.element.querySelector("textarea");r.addEventListener("input",this._onInput),r.addEventListener("focus",this._onFocus),r.addEventListener("blur",this._onBlur),r.addEventListener("mousedown",this._onMousedown),r.spellcheck=!1,this.handles=Array.prototype.slice.call(this.editor.element.querySelectorAll(".annotation-text-handle > .handle")),this.handles.push(this.editor.element),this.handles.forEach(a=>a.addEventListener("mousedown",this.onHandleMouseDown)),document.addEventListener("mouseup",this.onMouseUp),document.addEventListener("mousemove",this.onMouseMove,!0),t.events.on(["viewChanged","zoom"],this.onViewChanged)}_canRemove(){return!this.isFocused}detect({x:t,y:s},r=0){const a={x:t,y:s},h=this.ogma.view.getAngle();return this.elements.find(c=>{const{x:f,y:d}=ct(c),{width:g,height:p}=ut(c),b={x:f,y:d},{x:A,y:k}=rt(wt(a,b),-h);return A>-r&&A<g+r&&k>-r&&k<p+r})}draw(t){t.innerHTML="";const s="",r=this.ogma.view.getAngle();for(let h=0;h<this.elements.length;h++){const c=this.elements[h],f=`class${h}`,d=ut(c),g=ct(c);if(c.id===this.selectedId)continue;const{color:p,fontSize:b,font:A,strokeColor:k,strokeWidth:E,strokeType:x,background:L,borderRadius:O}=c.properties.style||_t,C=vt("g");C.classList.add("annotation-text"),C.setAttribute("fill",`${p}`),C.setAttribute("font-size",`${b}px`),C.setAttribute("font-family",`${A}`);const P=vt("rect");O&&(P.setAttribute("rx",`${O}`),P.setAttribute("ry",`${O}`));let N=!1;x&&x!=="none"&&(N=!0,P.setAttribute("stroke",k||"black"),P.setAttribute("stroke-width",`${E}`),x==="dashed"&&P.setAttribute("stroke-dasharray","5,5")),(L&&L.length||N)&&(N=!0,P.setAttribute("fill",L||"transparent")),N&&(P.setAttribute("width",`${d.width}`),P.setAttribute("height",`${d.height}`)),C.appendChild(P),Fr(c,C);const{x:nt,y:at}=rt(g,-r);C.setAttribute("transform",`translate(${nt},${at})`),C.classList.add(f),C.setAttribute("data-annotation",`${c.id}`),C.setAttribute("data-annotation-type","text"),t.appendChild(C)}const a=vt("style");a.innerHTML=s,t.firstChild&&t.insertBefore(a,t.firstChild)}refreshDrawing(){const t=this.ogma.view.getAngle(),s=this.layer.element.children;for(let r=0;r<s.length;r++){const a=s[r];if(!a.hasAttribute("data-annotation"))continue;const h=a.getAttribute("data-annotation"),c=ct(this.getById(h)),{x:f,y:d}=rt(c,-t);a.setAttribute("transform",`translate(${f},${d})`)}}getDefaultOptions(){return ie}refreshEditor(){if(+this.selectedId<0&&+this.hoveredId<0)return;const t=this.getById(this.selectedId)||this.getById(this.hoveredId),s=ut(t),r=this.ogma.view.graphToScreenCoordinates(ct(t)),a=this.ogma.view.getZoom(),{font:h,fontSize:c,color:f,background:d,padding:g=0}=t.properties.style||_t,p=(c||1)*a;this.textArea.value=t.properties.content;const b=this.editor.element.style;b.transform=`translate(${r.x}px, ${r.y}px)translate(-50%, -50%)translate(${s.width/2*a}px, ${s.height/2*a}px)`,b.width=`${s.width*a}px`,b.height=`${s.height*a}px`;const A=this.textArea.style;A.font=`${p} ${h}`,A.fontFamily=h||"sans-serif",A.fontSize=`${p}px`,A.padding=`${a*g}px`,A.lineHeight=`${p}px`,A.boxSizing="border-box",A.color=f||"black",A.background=d||"transparent",this.textArea.placeholder=this.placeholder,this.layer.refresh()}select(t){super.select(t),this.textArea.classList.add("noevents")}destroy(){super.destroy(),document.removeEventListener("mouseup",this.onMouseUp),document.removeEventListener("mousemove",this.onMouseMove,!0),this.ogma.events.off(this.onViewChanged)}}class jr{constructor(){m(this,"links",{}),m(this,"linksByTargetId",{}),m(this,"linksByArrowId",{})}add(t,s,r,a,h){const c=Ht(),f=t.id,d={id:c,arrow:f,target:r,targetType:a,connectionPoint:h,side:s};return this.links[c]=d,this.linksByTargetId[r]||(this.linksByTargetId[r]=[]),this.linksByTargetId[r].push(c),this.linksByArrowId[f]||(this.linksByArrowId[f]={}),this.linksByArrowId[f][s]=c,t.properties.link=t.properties.link||{},t.properties.link[s]={id:r,side:s,type:a,magnet:h},this}arrowIsLinked(t,s){var r;return!!((r=this.linksByArrowId[t])!=null&&r[s])}remove(t,s){var r,a;const h=t.id,c=(r=this.linksByArrowId[h])==null?void 0:r[s];if((a=t.properties.link)==null||delete a[s],!c)return this;const f=this.links[c];delete this.links[c];const d=this.linksByTargetId[f.target];for(let g=0;g<d.length;g++)if(d[g]===c){d.splice(g,1);break}return delete this.linksByArrowId[h][s],this}getArrowLink(t,s){var r;const a=(r=this.linksByArrowId[t])==null?void 0:r[s];return a?this.links[a]:null}getTargetLinks(t,s){var r;return((r=this.linksByTargetId[t])==null?void 0:r.map(a=>this.links[a]).filter(a=>a.targetType===s))??[]}forEach(t){Object.values(this.links).forEach(t)}}const ot=l=>l.properties.type==="arrow",dt=l=>l.properties.type==="text",Ve=l=>l.type==="FeatureCollection",Nr={magnetColor:"#3e8",detectMargin:20,magnetHandleRadius:5,magnetRadius:10,textPlaceholder:"Type here",arrowHandleSize:3.5,textHandleSize:3.5,minArrowHeight:20,maxArrowHeight:30},Ze=["start","end"],Ye=[{x:0,y:0},{x:.5,y:0},{x:1,y:0},{x:0,y:.5},{x:1,y:.5},{x:0,y:1},{x:.5,y:1},{x:1,y:1}];class Br extends je{constructor(t,s={}){super(),m(this,"arrows"),m(this,"texts"),m(this,"links",new jr),m(this,"layer"),m(this,"annotations"),m(this,"ogma"),m(this,"options"),m(this,"selected",null),m(this,"updateTimeout",0),m(this,"hoveredNode",null),m(this,"dragged",null),m(this,"textToMagnet"),m(this,"activeLinks",[]),m(this,"_render",r=>{if(!this.dragged||this.textToMagnet===void 0)return;r.beginPath(),r.fillStyle="green";const a=this.ogma.view.getZoom();Ye.forEach(h=>{if(!this.textToMagnet)return;const c=ut(this.textToMagnet),f=ct(this.textToMagnet),d=Wt(h,{x:c.width,y:c.height}),g=rt(d,this.ogma.view.getAngle()),{x:p,y:b}=St(g,f);r.moveTo(p,b),r.arc(p,b,this.options.magnetHandleRadius/a,0,Math.PI*2)}),r.fill(),r.closePath()}),m(this,"_onFeatureDrag",(r,a)=>{const h=a;if(ot(r)&&h==="line")["start","end"].find(c=>{const f=c==="start"?$t(r):Nt(r);return this._snapToText(r,h,f)||this._findAndSnapToNode(r,c,f)});else if(ot(r)&&h!=="line"){const c=h==="start"?$t(r):Nt(r);this._snapToText(r,h,c)||this._findAndSnapToNode(r,h,c)}else dt(r)&&(this.activeLinks.forEach(({arrow:c,side:f,connectionPoint:d})=>{const g=this.getAnnotation(c),p=ut(r),b=ct(r),A=Wt(d,{x:p.width,y:p.height}),k=rt(A,this.ogma.view.getAngle()),E=St(k,b);g.geometry.coordinates[f==="start"?0:1]=[E.x,E.y]}),this.activeLinks.length&&this.arrows.refreshLayer());this.layer.refresh(),this.emit(Ut,r,a)}),m(this,"_onFeatureDragEnd",r=>{this.dragged!==null&&ot(r)&&$t(this.dragged)&&Ze.forEach(a=>{this.links.getArrowLink(r.id,a)&&this.emit(Lr,{arrow:r,link:this.links.getArrowLink(r.id,a)})}),(dt(r)||ot(r))&&this.onUpdate(r),this.dragged=null,this.activeLinks=[],this.textToMagnet=void 0,this.annotations.forEach(a=>a.enableDetection()),this.layer.refresh(),this.emit(Ct,r)}),m(this,"_onFeatureDragStart",r=>{this.textToMagnet=void 0,ot(r)?this.dragged=r:dt(r)&&this.activeLinks.push(...this.links.getTargetLinks(r.id,"text")),this.annotations.forEach(a=>{const h=a.getSelectedFeature();h&&h!==r&&a.unhover().unselect(),a.disableDetection()}),this.emit(Xt,r)}),m(this,"_onNodesDragStart",()=>{this.arrows.unhover().unselect(),this.texts.unhover().unselect()}),m(this,"_onNodesDrag",r=>{const{dx:a,dy:h}=r;this._moveNodes(r.nodes,a,h)}),m(this,"_onLayoutEnd",r=>{r.ids.forEach((a,h)=>{this.links.getTargetLinks(a,"node").forEach(c=>{const f=this.getAnnotation(c.arrow),d=c.side,g=jt(f,d==="start"?"end":"start"),p=r.positions.current[h],b=this.ogma.getNode(a).getAttribute("radius"),A=qt(g,p,+b);kt(f,d,A.x,A.y)})}),this.arrows.refreshLayer(),this.texts.refreshLayer()}),m(this,"_onAdded",r=>{this.emit(re,r)}),m(this,"_onRemoved",r=>{this.emit(ee,r)}),m(this,"_onUnselect",r=>{this.selected=null,this.emit(te,r)}),m(this,"_onSelect",r=>{this.selected!==r&&(this.selected=r,this.emit(Qt,this.selected))}),m(this,"onUpdate",r=>{cancelAnimationFrame(this.updateTimeout),this.updateTimeout=requestAnimationFrame(()=>this._onUpdate(r))}),m(this,"_onUpdate",r=>{this.emit(ne,r)}),this.options=this.setOptions({...Nr,...s}),this.ogma=t,this.arrows=new $r(t,this.options),this.texts=new Hr(t,this.options),this.annotations=[this.arrows,this.texts],this.annotations.forEach(r=>{r.on(Xt,this._onFeatureDragStart).on(Ut,this._onFeatureDrag).on(Ct,this._onFeatureDragEnd).on(ne,this.onUpdate).on(te,this._onUnselect).on(Qt,this._onSelect).on(re,this._onAdded).on(ee,this._onRemoved)}),this.ogma.events.on("nodesDragStart",this._onNodesDragStart).on("nodesDragProgress",this._onNodesDrag).on("layoutEnd",this._onLayoutEnd).on(["viewChanged","rotate"],()=>{this.refreshTextLinks()}),this.layer=t.layers.addCanvasLayer(this._render),this.layer.moveToBottom()}_moveNodes(t,s,r){t.forEach(a=>{const h=this.links.getTargetLinks(a.getId(),"node"),c=a.getPosition();h.forEach(f=>{const d=this.getAnnotation(f.arrow),g=f.side,p=jt(d,g==="start"?"end":"start");let b=c;const A=+a.getAttribute("radius"),k=1e-6;(f.connectionPoint.x-(c.x-s)>k||f.connectionPoint.y-(c.y-r)>k)&&(b=qt(p,c,A)),kt(d,g,b.x,b.y)})}),this.arrows.refreshLayer()}_snapToText(t,s,r){const a=this.texts.detect(r,this.options.detectMargin);if(this.links.remove(t,s),!a)return!1;this.textToMagnet=a;const h=this.findMagnetPoint(Ye,a,r);return h?(kt(t,s,h.point.x,h.point.y),this.links.add(t,s,a.id,"text",h.magnet),!0):!1}_findAndSnapToNode(t,s,r){var a,h;const c=this.ogma.view.graphToScreenCoordinates(r),f=this.ogma.view.getElementAt(c);this.links.remove(t,s),f&&f.isNode?((a=this.hoveredNode)==null||a.setSelected(!1),this.hoveredNode=f,f.setSelected(!0),this._snapToNode(t,s,f,c)):((h=this.hoveredNode)==null||h.setSelected(!1),this.hoveredNode=null)}_snapToNode(t,s,r,a){const h=r.getPositionOnScreen(),c=+r.getAttribute("radius"),f=c*this.ogma.view.getZoom(),d=a.x-h.x,g=a.y-h.y,p=Math.sqrt(d*d+g*g),b=r.getPosition();if(p<f+this.options.detectMargin){let A=b;if(p>f/2){const k=jt(t,s==="end"?"start":"end");A=qt(k,A,c)}kt(t,s,A.x,A.y),this.links.add(t,s,r.getId(),"node",A)}}refreshTextLinks(){let t=!1;this.links.forEach(({connectionPoint:s,targetType:r,target:a,arrow:h,side:c})=>{if(r!=="text")return;t=!0;const f=this.getAnnotation(a),d=this.getAnnotation(h),g=ut(f),p=ct(f),b=Wt(s,{x:g.width,y:g.height}),A=rt(b,this.ogma.view.getAngle()),k=St(A,p);kt(d,c,k.x,k.y)}),t&&this.arrows.refreshLayer()}getSelected(){return this.selected}findMagnetPoint(t,s,r){let a;for(const h of t){const c=ut(s),f=ct(s),d=Wt(h,{x:c.width,y:c.height}),g=rt(d,this.ogma.view.getAngle()),p=St(g,f),b=Et(wt(p,r)),A=Math.min(this.options.magnetRadius*this.ogma.view.getZoom(),c.width/2,c.height/2);if(b<Math.max(A,this.options.magnetHandleRadius)){a={point:p,magnet:h};break}}return a}setOptions(t={}){return this.options={...this.options||{},...t},this.options}select(t){const s=this.getAnnotations().features.find(r=>r.id===t);return s?(ot(s)?this.arrows.select(s.id):dt(s)&&this.texts.select(s.id),this):this}unselect(){return this.selected?(ot(this.selected)?this.arrows.unselect():dt(this.selected)&&this.texts.unselect(),this):this}add(t){if(Ve(t)){const[s,r]=t.features.reduce((a,h)=>(ot(h)?a[1].push(h):dt(h)&&a[0].push(h),a),[[],[]]);return s.forEach(a=>this.add(a)),r.forEach(a=>this.add(a)),this.arrows.refreshLayer(),this}switch(t.properties.type){case"text":this.texts.add(t);break;default:this.arrows.add(t),this.loadLink(t);break}return this}remove(t){return Ve(t)?(t.features.forEach(s=>this.remove(s)),this):(ot(t)?(this.links.remove(t,"start"),this.links.remove(t,"end"),this.arrows.remove(t.id)):this.texts.remove(t.id),this)}loadLink(t){if(t.properties.link)for(const s of Ze){const r=t.properties.link[s];if(!r)continue;const a=this.getAnnotation(r.id);if(r.type==="text"&&a)this.links.add(t,s,r.id,r.type,r.magnet);else if(r.type==="node"){const h=this.ogma.getNode(r.id);if(!h)continue;this.links.add(t,s,r.id,r.type,r.magnet);const c=h.getPosition(),f=h.getAttribute("radius")||0,d=jt(t,s==="start"?"end":"start"),g=qt(d,c,+f);kt(t,s,g.x,g.y)}}}startArrow(t,s,r){this.cancelDrawing(),this.arrows.startDrawing(t,s,r)}startText(t,s,r){this.cancelDrawing(),this.texts.startDrawing(t,s,r)}cancelDrawing(){this.annotations.forEach(t=>t.cancelDrawing()),this.emit(Dr)}updateStyle(t,s){const r=this.getAnnotations().features.find(a=>a.id===t);return r?(ot(r)?this.arrows.updateStyle(r,s):dt(r)&&this.texts.updateStyle(r,s),this.onUpdate(r),this):this}setScale(t,s,r,a){const h=this.getAnnotations().features.find(c=>c.id===t);return h?(ot(h)?this.arrows.scale(h,s,r,a):dt(h)&&this.texts.scale(h,s,r,a),this.onUpdate(h),this):this}getAnnotations(){const t={type:"FeatureCollection",features:[]};return this.annotations.forEach(s=>{t.features=[...t.features,...s.getElements()]}),t}getAnnotation(t){return this.getAnnotations().features.find(s=>s.id===t)}destroy(){this.annotations.forEach(t=>t.destroy()),this.layer.destroy()}}const le=[8,10,12,14,16,24,32,48,64,72],he="none",ue="#333333",qr=["#FFFFFF","#F44E3B","#FE9200","#FCDC00","#A4DD00","#68CCCA","#73D8FF","#AEA1FF","#1E88E5","#333333","#808080","#cccccc"],Rr=["Roboto","Helvetica Neue","Helvetica","Arial","sans-serif","Georgia, serif","Menlo","Monaco","Consolas","Courier New","monospace"].sort((l,t)=>l.toLocaleLowerCase().localeCompare(t.toLocaleLowerCase())),Je={head:"arrow",strokeColor:ue,strokeWidth:5},Ke=.25,Qe={font:"Roboto",fontSize:le[2],padding:le[2]*Ke,color:ue,strokeType:he,background:he};function tr(l){return l.reduce((t,s)=>t+s,0)/l.length}function Wr(l,t=0,s=1){return t+(s-t)*l}function Ur(l,t=0,s=1){return(l-t)/(s-t)}function Xr(){return V.createContext(null)}const ce=V.createContext(void 0),Gr=()=>V.useContext(ce),Vr=(l,t)=>{switch(t.type){case"add":return{...l,features:[...l.features,t.payload]};case"remove":return{...l,features:l.features.filter(s=>s.id!==t.payload.id)};case"update":return{...l,features:l.features.map(s=>s.id===t.payload.id?t.payload:s)};default:return l}},Zr=({children:l})=>{const t=fr.useOgma(),[s,r]=V.useReducer(Vr,{type:"FeatureCollection",features:[]}),[a,h]=V.useState(null),[c,f]=V.useState(Je),[d,g]=V.useState(Qe),[p,b]=V.useState(),[A,k]=V.useState(1),[E,x]=V.useState(1);return V.useEffect(()=>{if(!t)return;const L=new Br(t,{minArrowHeight:1}),O=tr(t.getNodes().getAttribute("radius"))/5,C=A;return f({...c,strokeWidth:(c.strokeWidth||1)*C}),k(C),x(O),L.on("select",P=>{ot(P)?f({...P.properties.style||{}}):dt(P)&&g({...P.properties.style||{}}),h(P)}).on("unselect",()=>{h(null)}),b(L),()=>{L.destroy()}},[t]),V.useEffect(()=>{p&&a&&(a==null?void 0:a.properties.type)==="arrow"&&p.updateStyle(a.id,c)},[p,c,a]),V.useEffect(()=>{p&&a&&(a==null?void 0:a.properties.type)==="text"&&p.updateStyle(a.id,d)},[p,d,a]),V.createElement(ce.Provider,{value:{annotations:s,updateAnnotations:r,currentAnnotation:a,setCurrentAnnotation:h,textStyle:d,setTextStyle:g,arrowStyle:c,setArrowStyle:f,arrowWidthFactor:A,setArrowWidthFactor:k,textSizeFactor:E,setTextSizeFactor:x,editor:p,setEditor:b}},l)};H.AnnotationsContext=ce,H.AnnotationsContextProvider=Zr,H.BLACK=ue,H.RELATIVE_PADDING=Ke,H.TRANSPARENT=he,H.createAnnotationsContext=Xr,H.defaultArrowStyle=Je,H.defaultColors=qr,H.defaultTextStyle=Qe,H.fontSizes=le,H.fonts=Rr,H.interpolate=Wr,H.mean=tr,H.normalize=Ur,H.useAnnotationsContext=Gr,Object.defineProperty(H,Symbol.toStringTag,{value:"Module"})});