@markgrafhq/markgraf-embed 0.1.17 → 0.1.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,18 +1,22 @@
1
- var $v=(function(Su){"use strict";function Qa(t){let e=0,n;return()=>{if(e===2)return n;if(e===1)throw new Error("Binding demanded before initialized");return e=1,n=t(),e=2,n}}function g(){throw new Error("Failed pattern match")}function Gn(t,e){return e>0?Math.floor(t/e):e<0?-Math.floor(t/-e):0}const Ee=t=>e=>t,O=function(t){return function(e){for(var n=e.length,r=new Array(n),i=0;i<n;i++)r[i]=t(e[i]);return r}},C1={map:O},Ra=t=>t,wt=typeof Array.prototype.flatMap=="function"?function(t){return function(e){return t.flatMap(e)}}:function(t){return function(e){for(var n=[],r=t.length,i=0;i<r;i++)for(var o=e(t[i]),u=o.length,s=0;s<u;s++)n.push(o[s]);return n}},ee=function(t){return t.toString()},Ma=function(t){var e=t.toString();return isNaN(e+".0")?e:e+".0"},S1=function(t){var e=t.length;return'"'+t.replace(/[\0-\x1F\x7F"\\]/g,function(n,r){switch(n){case'"':case"\\":return"\\"+n;case"\x07":return"\\a";case"\b":return"\\b";case"\f":return"\\f";case`
2
- `:return"\\n";case"\r":return"\\r";case" ":return"\\t";case"\v":return"\\v"}var i=r+1,o=i<e&&t[i]>="0"&&t[i]<="9"?"\\&":"";return"\\"+n.charCodeAt(0).toString(10)+o})+'"'},Gu=t=>t,Je=Gu("LT"),Te=Gu("GT"),De=Gu("EQ"),w=(t,e)=>({tag:t,_1:e}),J=w("Nothing"),Ut=t=>w("Just",t),za=t=>{if(t.tag==="Nothing")return!0;if(t.tag==="Just")return!1;g()},Ha=t=>{if(t.tag==="Nothing")return!1;if(t.tag==="Just")return!0;g()},Dt=(t,e)=>({tag:t,_1:e}),G1=t=>Dt("Right",t),P1={map:t=>e=>{if(e.tag==="Left")return Dt("Left",e._1);if(e.tag==="Right")return Dt("Right",t(e._1));g()}},Wa={apply:t=>e=>{if(t.tag==="Left")return Dt("Left",t._1);if(t.tag==="Right"){if(e.tag==="Left")return Dt("Left",e._1);if(e.tag==="Right")return Dt("Right",t._1(e._1))}g()},Functor0:()=>P1},D1={bind:t=>{if(t.tag==="Left"){const e=t._1;return n=>Dt("Left",e)}if(t.tag==="Right"){const e=t._1;return n=>n(e)}g()},Apply0:()=>Wa},I1={pure:G1,Apply0:()=>Wa},Oa={Applicative0:()=>I1,Bind1:()=>D1},A1=t=>t,F1={map:t=>e=>t(e)},Ya={apply:t=>e=>t(e),Functor0:()=>F1},B1={bind:t=>e=>e(t),Apply0:()=>Ya},Q1={pure:A1,Apply0:()=>Ya},qn={Applicative0:()=>Q1,Bind1:()=>B1},R1=function(t){return function(){return t}},M1={apply:t=>e=>()=>{const n=t(),r=e();return Pu.pure(n(r))()},Functor0:()=>z1},Pu={pure:R1,Apply0:()=>M1},z1={map:t=>e=>()=>{const n=e();return t(n)}},ri=(t,e)=>({tag:t,_1:e}),$a=t=>ri("Loop",t),H1={tailRecM:t=>{const e=n=>{let r=n,i=!0,o;for(;i;){const u=r;if(u.tag==="Loop"){r=t(u._1);continue}if(u.tag==="Done"){i=!1,o=u._1;continue}g()}return o};return n=>e(t(n))},Monad0:()=>qn},W1=function(t){return function(e){return function(){return t(e())}}},O1=function(t){return function(){return t}},Y1={map:W1},$1={apply:t=>e=>()=>{const n=t(),r=e();return qa.pure(n(r))()},Functor0:()=>Y1},qa={pure:O1,Apply0:()=>$1},q1=(function(t){return function(e){return function(n){return function(){return t(e,n)}}}})(function(t,e){return e.push(t)}),X1=(t,e)=>({tag:"Iterator",_1:t,_2:e}),V1=t=>e=>n=>()=>{let r=!1;const i=e._2;for(;!r;){const o=i.value,u=e._1(o);if(u.tag==="Just"&&t(u._1)){n.push(u._1),e._2.value;const s=e._2.value;e._2.value=s+1|0;continue}r=!0}},U1=t=>e=>()=>{let n=!1;const r=t._2;for(;!n;){const i=r.value,o=r.value;r.value=o+1|0;const u=t._1(i);if(u.tag==="Just"){e(u._1)();continue}if(u.tag==="Nothing"){n=!0;continue}g()}},ii=function(t){return function(e){return function(n){for(var r=e,i=n.length,o=i-1;o>=0;o--)r=t(n[o])(r);return r}}},T=function(t){return function(e){return function(n){for(var r=e,i=n.length,o=0;o<i;o++)r=t(r)(n[o]);return r}}},Du=t=>{const e=t.Apply0();return n=>r=>n.foldr(i=>{const o=r(i);return u=>e.apply(e.Functor0().map(s=>Ra)(o))(u)})(t.pure())},Xa=t=>{const e=Du(t);return n=>{const r=e(n);return i=>o=>r(o)(i)}},zt={foldr:ii,foldl:T,foldMap:t=>{const e=t.mempty;return n=>zt.foldr(r=>i=>t.Semigroup0().append(n(r))(i))(e)}},b=(t,e)=>({tag:"Tuple",_1:t,_2:e}),Pn=t=>e=>b(t,e),no=t=>t._2,ro=t=>t._1,Bt=function(t){return function(e){for(var n=e.length,r=Array(n),i=0;i<n;i++)r[i]=t(i)(e[i]);return r}};var Iu=function(t){return function(e){return t===e}};const K1=Iu,Z1=Iu,oi=Iu,Au=function(t){return function(e){return function(n){if(e.length!==n.length)return!1;for(var r=0;r<e.length;r++)if(!t(e[r])(n[r]))return!1;return!0}}},dn={eq:oi},j1={eq:Z1},Er={eq:K1};var Fu=function(t){return function(e){return function(n){return function(r){return function(i){return r<i?t:r===i?e:n}}}}};const td=Fu,ed=Fu,S={compare:Fu(Je)(De)(Te),Eq0:()=>dn},it={compare:ed(Je)(De)(Te),Eq0:()=>j1},nt={compare:td(Je)(De)(Te),Eq0:()=>Er},nd=function(t){return t},rd=(function(){function t(i){return[i]}function e(i){return function(o){return[i,o]}}function n(i){return function(o){return function(u){return[i,o,u]}}}function r(i){return function(o){return i.concat(o)}}return function(i){return function(o){return function(u){return function(s){return function(a){function c(f,d){switch(d-f){case 0:return u([]);case 1:return o(t)(s(a[f]));case 2:return i(o(e)(s(a[f])))(s(a[f+1]));case 3:return i(i(o(n)(s(a[f])))(s(a[f+1])))(s(a[f+2]));default:var l=f+Math.floor((d-f)/4)*2;return i(o(r)(c(f,l)))(c(l,d))}}return c(0,a.length)}}}}}})(),id=t=>t,cr={traverse:t=>{const e=t.Apply0();return rd(e.apply)(e.Functor0().map)(t.pure)},sequence:t=>cr.traverse(t)(id),Functor0:()=>C1,Foldable1:()=>zt},Ft=function(t,e){for(var n=t>e?-1:1,r=new Array(n*(e-t)+1),i=t,o=0;i!==e;)r[o++]=i,i+=n;return r[o]=i,r};var od=function(t,e){if(t<1)return[];var n=new Array(t);return n.fill(e)},ud=function(t,e){for(var n=[],r=0,i=0;i<t;i++)n[r++]=e;return n};const sd=typeof Array.prototype.fill=="function"?od:ud,Ct=(function(){function t(i,o){this.head=i,this.tail=o}var e={};function n(i){return function(o){return new t(i,o)}}function r(i){for(var o=[],u=0,s=i;s!==e;)o[u++]=s.head,s=s.tail;return o}return function(i,o){return r(i(n)(e)(o))}})(),Qt=function(t,e,n){return n.length===0?t({}):e(n[0])(n.slice(1))},Va=function(t,e,n,r){for(var i=0;i<r.length;i++){var o=n(r[i]);if(e(o))return o}return t},gr=function(t,e,n,r){for(var i=0,o=r.length;i<o;i++)if(n(r[i]))return t(i);return e},Ua=function(t,e,n,r){for(var i=r.length-1;i>=0;i--)if(n(r[i]))return t(i);return e},Ka=function(t,e,n,r,i){if(n<0||n>i.length)return e;var o=i.slice();return o.splice(n,0,r),t(o)},Za=function(t,e,n,r){if(n<0||n>=r.length)return e;var i=r.slice();return i.splice(n,1),t(i)},Xn=function(t,e,n,r,i){if(n<0||n>=i.length)return e;var o=i.slice();return o[n]=r,t(o)},we=function(t){return t.slice().reverse()},We=function(t){if(t.length<=1e4)return Array.prototype.concat.apply([],t);for(var e=[],n=0,r=t.length;n<r;n++)for(var i=t[n],o=0,u=i.length;o<u;o++)e.push(i[o]);return e},at=function(t,e){return e.filter(t)},ad=function(t,e,n){for(var r=n.length,i=e,o=new Array(r),u=0;u<r;u++)i=t(i)(n[u]),o[u]=i;return o},cd=(function(){function t(e,n,r,i,o,u){var s,a,c,f,d,l,_;for(s=o+(u-o>>1),s-o>1&&t(e,n,i,r,o,s),u-s>1&&t(e,n,i,r,s,u),a=o,c=s,f=o;a<s&&c<u;)d=i[a],l=i[c],_=n(e(d)(l)),_>0?(r[f++]=l,++c):(r[f++]=d,++a);for(;a<s;)r[f++]=i[a++];for(;c<u;)r[f++]=i[c++]}return function(e,n,r){var i;return r.length<2?r:(i=r.slice(0),t(e,n,i,r.slice(0),0,r.length),i)}})(),Lt=function(t,e,n){return n.slice(t,e)},ve=function(t,e,n){for(var r=e.length<n.length?e.length:n.length,i=new Array(r),o=0;o<r;o++)i[o]=t(e[o])(n[o]);return i},Oe=function(t,e){for(var n=e.length,r=0;r<n;r++)if(t(e[r]))return!0;return!1},ja=function(t,e){for(var n=e.length,r=0;r<n;r++)if(!t(e[r]))return!1;return!0},Et=t=>e=>cd(t,n=>{if(n==="GT")return 1;if(n==="EQ")return 0;if(n==="LT")return-1;g()},e),gd=t=>e=>Et(n=>r=>t.compare(e(n))(e(r))),Rt=t=>e=>(()=>{const n=q1(e);return()=>{const r=[...t];return n(r)(),r}})()(),fr=t=>{if(t.length===0)return t.length-1|0,J;const e=t.length-1|0;return e>=0&&e<t.length?w("Just",{init:Lt(0,t.length-1|0,t),last:t[e]}):J},fd=t=>e=>n=>t>=0&&t<n.length?Xn(Ut,J,t,e(n[t]),n):J,_r=t=>e=>{const n=(r=>{let i=r,o=!0,u;for(;o;){const s=i;if(s>=0&&s<e.length){if(t(e[s])){i=s+1|0;continue}o=!1,u=w("Just",s);continue}o=!1,u=J}return u})(0);if(n.tag==="Just")return n._1===0?{init:[],rest:e}:{init:Lt(0,n._1,e),rest:Lt(n._1,e.length,e)};if(n.tag==="Nothing")return{init:e,rest:[]};g()},Cr=t=>e=>{const n=Et(r=>i=>t(r._2)(i._2))(Bt(Pn)(e));return 0<n.length?O(no)(gd(nt)(ro)((()=>{const r=[n[0]];for(const i of n){const o=t((()=>{const u=r.length-1|0;if(u>=0&&u<r.length)return r[u]._2;g()})())(i._2);(o==="LT"||o==="GT"||o!=="EQ")&&r.push(i)}return r})())):[]},_d=t=>e=>{const n=[],r=X1(i=>i>=0&&i<e.length?w("Just",e[i]):J,{value:0});return U1(r)(i=>()=>{const o=[];o.push(i),V1(t(i))(r)(o)(),n.push(o)})(),n},Kt=t=>e=>{const n=gr(Ut,J,t,e);return n.tag==="Just"?w("Just",e[n._1]):J},tc=t=>e=>at(t,e),Ye=t=>e=>n=>{const r=gr(Ut,J,i=>t.eq(i)(e),n);if(r.tag==="Nothing")return!1;if(r.tag==="Just")return!0;g()},ec=t=>e=>wt(e)(t),xt=t=>ec(e=>{const n=t(e);if(n.tag==="Nothing")return[];if(n.tag==="Just")return[n._1];g()}),nc=isFinite;function dd(t,e,n,r){var i=parseFloat(t);return e(i)?n(i):r}const Vn=Math.abs,ld=Math.acos,dr=function(t){return function(e){return Math.atan2(t,e)}},io=Math.ceil,rn=Math.cos,oo=Math.exp,mn=Math.floor,rc=Math.log,hd=function(t){return function(e){return Math.min(t,e)}},Bu=function(t){return function(e){return Math.pow(t,e)}},Dn=Math.round,Ve=Math.sin,Ce=Math.sqrt,pd=Math.tan,md=function(t){return function(e){return function(n){return(n|0)===n?t(n):e}}},et=function(t){return t},yd=(function(t){return function(e){return function(n){var r;n<11?r="[0-"+(n-1).toString()+"]":n===11?r="[0-9a]":r="[0-9a-"+String.fromCharCode(86+n)+"]";var i=new RegExp("^[\\+\\-]?"+r+"+$","i");return function(o){if(i.test(o)){var u=parseInt(o,n);return(u|0)===u?t(u):e}else return e}}}})(Ut)(J)(10),ic=md(Ut)(J),ce=t=>{if(!nc(t))return 0;if(t>=et(2147483647))return 2147483647;if(t<=et(-2147483648))return-2147483648;const e=ic(t);if(e.tag==="Nothing")return 0;if(e.tag==="Just")return e._1;g()},$t=(t,e,n)=>({tag:t,_1:e,_2:n}),Xt=$t("Nil"),Vt={foldr:t=>e=>{const n=Vt.foldl(i=>o=>t(o)(i))(e),r=(i=>o=>{let u=i,s=o,a=!0,c;for(;a;){const f=u,d=s;if(d.tag==="Nil"){a=!1,c=f;continue}if(d.tag==="Cons"){u=$t("Cons",d._1,f),s=d._2;continue}g()}return c})(Xt);return i=>n(r(i))},foldl:t=>e=>n=>{let r=e,i=n,o=!0,u;for(;o;){const s=r,a=i;if(a.tag==="Nil"){o=!1,u=s;continue}if(a.tag==="Cons"){r=t(s)(a._1),i=a._2;continue}g()}return u},foldMap:t=>{const e=t.mempty;return n=>Vt.foldl(r=>{const i=t.Semigroup0().append(r);return o=>i(n(o))})(e)}},xd=function(t){return function(e){return function(n){return function(r){return function(i){return function(o){for(var u=[],s=o;;){var a=i(s);u.push(n(a));var c=r(a);if(t(c))return u;s=e(c)}}}}}}},Nd=t=>{if(t.tag==="Just")return t._1;g()},Jd={unfoldr1:xd(za)(Nd)(ro)(no)},Td=function(t){return function(e){return function(n){return function(r){return function(i){return function(o){for(var u=[],s=o;;){var a=i(s);if(t(a))return u;var c=e(a);u.push(n(c)),s=r(c)}}}}}}},wd=t=>{if(t.tag==="Just")return t._1;g()},Ue={unfoldr:Td(za)(wd)(ro)(no),Unfoldable10:()=>Jd},Yt=(t,e,n,r,i,o,u)=>({tag:t,_1:e,_2:n,_3:r,_4:i,_5:o,_6:u}),Ke=(t,e,n,r)=>({tag:t,_1:e,_2:n,_3:r}),uo=(t,e,n)=>({tag:"Split",_1:t,_2:e,_3:n}),oc=(t,e,n)=>({tag:"SplitLast",_1:t,_2:e,_3:n}),A=Yt("Leaf"),yn=Ke("IterLeaf"),ge=(t,e,n,r)=>{if(n.tag==="Leaf"){if(r.tag==="Leaf")return Yt("Node",1,1,t,e,n,r);if(r.tag==="Node")return Yt("Node",1+r._1|0,1+r._2|0,t,e,n,r);g()}if(n.tag==="Node"){if(r.tag==="Leaf")return Yt("Node",1+n._1|0,1+n._2|0,t,e,n,r);if(r.tag==="Node")return Yt("Node",n._1>r._1?1+n._1|0:1+r._1|0,(1+n._2|0)+r._2|0,t,e,n,r)}g()},$e=(t,e,n,r)=>{if(n.tag==="Leaf")return r.tag==="Leaf"?Yt("Node",1,1,t,e,A,A):r.tag==="Node"&&r._1>1?r._5.tag==="Node"&&(()=>{if(r._6.tag==="Leaf")return r._5._1>0;if(r._6.tag==="Node")return r._5._1>r._6._1;g()})()?ge(r._5._3,r._5._4,ge(t,e,n,r._5._5),ge(r._3,r._4,r._5._6,r._6)):ge(r._3,r._4,ge(t,e,n,r._5),r._6):ge(t,e,n,r);if(n.tag==="Node")return r.tag==="Node"?r._1>(n._1+1|0)?r._5.tag==="Node"&&(()=>{if(r._6.tag==="Leaf")return r._5._1>0;if(r._6.tag==="Node")return r._5._1>r._6._1;g()})()?ge(r._5._3,r._5._4,ge(t,e,n,r._5._5),ge(r._3,r._4,r._5._6,r._6)):ge(r._3,r._4,ge(t,e,n,r._5),r._6):n._1>(r._1+1|0)?n._6.tag==="Node"&&(()=>{if(n._5.tag==="Leaf")return 0<=n._6._1;if(n._5.tag==="Node")return n._5._1<=n._6._1;g()})()?ge(n._6._3,n._6._4,ge(n._3,n._4,n._5,n._6._5),ge(t,e,n._6._6,r)):ge(n._3,n._4,n._5,ge(t,e,n._6,r)):ge(t,e,n,r):r.tag==="Leaf"&&n._1>1?n._6.tag==="Node"&&(()=>{if(n._5.tag==="Leaf")return 0<=n._6._1;if(n._5.tag==="Node")return n._5._1<=n._6._1;g()})()?ge(n._6._3,n._6._4,ge(n._3,n._4,n._5,n._6._5),ge(t,e,n._6._6,r)):ge(n._3,n._4,n._5,ge(t,e,n._6,r)):ge(t,e,n,r);g()},Sr=(t,e,n)=>{if(n.tag==="Leaf")return uo(J,A,A);if(n.tag==="Node"){const r=t(e)(n._3);if(r==="LT"){const i=Sr(t,e,n._5);return uo(i._1,i._2,$e(n._3,n._4,i._3,n._6))}if(r==="GT"){const i=Sr(t,e,n._6);return uo(i._1,$e(n._3,n._4,n._5,i._2),i._3)}if(r==="EQ")return uo(w("Just",n._4),n._5,n._6)}g()},uc=(t,e,n,r)=>{if(r.tag==="Leaf")return oc(t,e,n);if(r.tag==="Node"){const i=uc(r._3,r._4,r._5,r._6);return oc(i._1,i._2,$e(t,e,n,i._3))}g()},ui=(t,e)=>{if(t.tag==="Leaf")return e;if(t.tag==="Node"){const n=uc(t._3,t._4,t._5,t._6);return $e(n._1,n._2,n._3,e)}g()},In=(t,e,n)=>{if(e.tag==="Leaf")return A;if(n.tag==="Leaf")return e;if(n.tag==="Node"){const r=Sr(t,n._3,e);return ui(In(t,r._2,n._5),In(t,r._3,n._6))}g()},so=(t,e,n,r)=>{if(n.tag==="Leaf"||r.tag==="Leaf")return A;if(r.tag==="Node"){const i=Sr(t,r._3,n),o=so(t,e,i._2,r._5),u=so(t,e,i._3,r._6);if(i._1.tag==="Just")return $e(r._3,e(i._1._1)(r._4),o,u);if(i._1.tag==="Nothing")return ui(o,u)}g()},Se=(t,e,n,r)=>{if(n.tag==="Leaf")return r;if(r.tag==="Leaf")return n;if(r.tag==="Node"){const i=Sr(t,r._3,n),o=Se(t,e,i._2,r._5),u=Se(t,e,i._3,r._6);if(i._1.tag==="Just")return $e(r._3,e(i._1._1)(r._4),o,u);if(i._1.tag==="Nothing")return $e(r._3,r._4,o,u)}g()},vd=t=>e=>{const n=r=>{if(r.tag==="Leaf")return A;if(r.tag==="Node"){const i=e(r._3)(r._4);if(i.tag==="Just")return $e(r._3,i._1,n(r._5),n(r._6));if(i.tag==="Nothing")return ui(n(r._5),n(r._6))}g()};return n},xn=(t=>e=>n=>{let r=n,i=!0,o;for(;i;){const u=r;if(u.tag==="IterLeaf"){i=!1,o=e();continue}if(u.tag==="IterEmit"){i=!1,o=t(u._1,u._2,u._3);continue}if(u.tag==="IterNode"){r=(s=>a=>{let c=s,f=a,d=!0,l;for(;d;){const _=c,h=f;if(h.tag==="Leaf"){d=!1,l=_;continue}if(h.tag==="Node"){if(h._6.tag==="Leaf"){c=Ke("IterEmit",h._3,h._4,_),f=h._5;continue}c=Ke("IterEmit",h._3,h._4,Ke("IterNode",h._6,_)),f=h._5;continue}g()}return l})(u._2)(u._1);continue}g()}return o})((t,e,n)=>w("Just",b(b(t,e),n)))(t=>J),bt=t=>e=>n=>r=>{const i=o=>{if(o.tag==="Leaf")return Yt("Node",1,1,n,r,A,A);if(o.tag==="Node"){const u=t.compare(n)(o._3);if(u==="LT")return $e(o._3,o._4,i(o._5),o._6);if(u==="GT")return $e(o._3,o._4,o._5,i(o._6));if(u==="EQ")return Yt("Node",o._1,o._2,n,e(o._4)(r),o._5,o._6)}g()};return i},tt=t=>e=>n=>{const r=i=>{if(i.tag==="Leaf")return Yt("Node",1,1,e,n,A,A);if(i.tag==="Node"){const o=t.compare(e)(i._3);if(o==="LT")return $e(i._3,i._4,r(i._5),i._6);if(o==="GT")return $e(i._3,i._4,i._5,r(i._6));if(o==="EQ")return Yt("Node",i._1,i._2,e,n,i._5,i._6)}g()};return r},te=t=>e=>e.foldl(n=>r=>tt(t)(r._1)(r._2)(n))(A),si=t=>e=>{const n=r=>{if(r.tag==="Leaf")return A;if(r.tag==="Node"){const i=t.compare(e)(r._3);if(i==="LT")return $e(r._3,r._4,n(r._5),r._6);if(i==="GT")return $e(r._3,r._4,r._5,n(r._6));if(i==="EQ")return ui(r._5,r._6)}g()};return n},sc=t=>{const e=t.compare;return n=>r=>i=>{const o=Sr(e,r,i),u=n(o._1);if(u.tag==="Nothing")return ui(o._2,o._3);if(u.tag==="Just")return $e(r,u._1,o._2,o._3);g()}},se=function(t){return function(e){return t+e|0}},Gr=function(t){return function(e){return t+e}},Un=function(t){return function(e){if(e===0)return 0;var n=Math.abs(e);return(t%n+n)%n}},bd=function(t){return function(e){return t+e}},re=function(t){return function(e){return t.length===0?e:e.length===0?t:t.concat(e)}},kd={append:bd},Ld={append:re},Ed={mempty:"",Semigroup0:()=>kd},Cd={mempty:[],Semigroup0:()=>Ld},Sd=null;function ac(t,e,n){return t==null?e:n(t)}function Yv(t){return t}function Qu(t){return function(e){return function(n){return t.apply(n,[e])}}}const Gd=Qu(Number.prototype.toPrecision),Pd=Qu(Number.prototype.toFixed),Dd=Qu(Number.prototype.toExponential),ai=(t,e)=>({tag:t,_1:e}),ci=t=>e=>n=>{const r=nt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=nt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},gi=t=>{if(t.tag==="Precision")return Gd(t._1);if(t.tag==="Fixed")return Pd(t._1);if(t.tag==="Exponential")return Dd(t._1);g()},cc=function(t){return function(){console.log(t)}};function Id(){return Date.now()}function Ad(t){return function(){return t.getContext("2d")}}function Fd(t){return function(){return t.width}}function Bd(t){return function(){return t.height}}function Qd(t){return function(e){return function(){t.width=e}}}function Rd(t){return function(e){return function(){t.height=e}}}function Ru(t){return function(e){return function(){t.lineWidth=e}}}function Md(t){return function(e){return function(){t.fillStyle=e}}}function zd(t){return function(e){return function(){t.strokeStyle=e}}}function Mu(t){return function(e){return function(){t.lineCap=e}}}function zu(t){return function(e){return function(){t.lineJoin=e}}}function Hd(t){return function(e){return function(){t.globalCompositeOperation=e}}}function Wd(t){return function(e){return function(){t.globalAlpha=e}}}function gc(t){return function(){t.beginPath()}}function Hu(t){return function(){t.stroke()}}function Wu(t){return function(){t.fill()}}function Od(t){return function(){t.clip()}}function fi(t){return function(e){return function(n){return function(){t.lineTo(e,n)}}}}function fc(t){return function(e){return function(n){return function(){t.moveTo(e,n)}}}}function _c(t){return function(){t.closePath()}}function Yd(t){return function(e){return function(){t.fillRect(e.x,e.y,e.width,e.height)}}}function $d(t){return function(e){return function(){t.clearRect(e.x,e.y,e.width,e.height)}}}function ao(t){return function(e){return function(){t.scale(e.scaleX,e.scaleY)}}}function Ou(t){return function(e){return function(){t.translate(e.translateX,e.translateY)}}}function qd(t){return function(e){return function(){t.transform(e.a,e.b,e.c,e.d,e.e,e.f)}}}function Xd(t){return function(e){return function(){t.textAlign=e}}}function Vd(t){return function(e){return function(){t.textBaseline=e}}}function Ud(t){return function(e){return function(){t.font=e}}}function Kd(t){return function(e){return function(n){return function(r){return function(){t.fillText(e,n,r)}}}}}function Kn(t){return function(){t.save()}}function Zn(t){return function(){t.restore()}}function _i(t){return function(e){return function(){t.quadraticCurveTo(e.cpx,e.cpy,e.x,e.y)}}}function Zd(t){return function(e){return function(){t.bezierCurveTo(e.cp1x,e.cp1y,e.cp2x,e.cp2y,e.x,e.y)}}}const dc=t=>t,Yu=t=>t,$u=t=>t,qu=t=>t,co=t=>t,jd=co("BaselineTop"),tl=co("BaselineMiddle"),el=co("BaselineAlphabetic"),nl=co("BaselineBottom"),rl=qu("AlignLeft"),il=qu("AlignRight"),ol=qu("AlignCenter"),Xu=$u("BevelJoin"),go=$u("RoundJoin"),Vu=$u("MiterJoin"),Uu=Yu("Round"),Ku=Yu("Square"),Zu=Yu("Butt"),ul=dc("SourceOver"),sl=dc("Difference"),al=t=>e=>Vd(t)((()=>{if(e==="BaselineTop")return"top";if(e==="BaselineHanging")return"hanging";if(e==="BaselineMiddle")return"middle";if(e==="BaselineAlphabetic")return"alphabetic";if(e==="BaselineIdeographic")return"ideographic";if(e==="BaselineBottom")return"bottom";g()})()),cl=t=>e=>Xd(t)((()=>{if(e==="AlignLeft")return"left";if(e==="AlignRight")return"right";if(e==="AlignCenter")return"center";if(e==="AlignStart")return"start";if(e==="AlignEnd")return"end";g()})()),fo=t=>e=>{if(e==="BevelJoin")return zu(t)("bevel");if(e==="RoundJoin")return zu(t)("round");if(e==="MiterJoin")return zu(t)("miter");g()},ju=t=>e=>{if(e==="Round")return Mu(t)("round");if(e==="Square")return Mu(t)("square");if(e==="Butt")return Mu(t)("butt");g()},lc=t=>e=>Hd(t)((()=>{if(e==="SourceOver")return"source-over";if(e==="SourceIn")return"source-in";if(e==="SourceOut")return"source-out";if(e==="SourceAtop")return"source-atop";if(e==="DestinationOver")return"destination-over";if(e==="DestinationIn")return"destination-in";if(e==="DestinationOut")return"destination-out";if(e==="DestinationAtop")return"destination-atop";if(e==="Lighter")return"lighter";if(e==="Copy")return"copy";if(e==="Xor")return"xor";if(e==="Multiply")return"multiply";if(e==="Screen")return"screen";if(e==="Overlay")return"overlay";if(e==="Darken")return"darken";if(e==="Lighten")return"lighten";if(e==="ColorDodge")return"color-dodge";if(e==="ColorBurn")return"color-burn";if(e==="HardLight")return"hard-light";if(e==="SoftLight")return"soft-light";if(e==="Difference")return"difference";if(e==="Exclusion")return"exclusion";if(e==="Hue")return"hue";if(e==="Saturation")return"saturation";if(e==="Color")return"color";if(e==="Luminosity")return"luminosity";g()})()),Qe={foldr:t=>e=>{const n=Vt.foldr(t)(e);return r=>n((()=>{const i=(o,u)=>{if(o.tag==="Leaf")return u;if(o.tag==="Node")return i(o._5,$t("Cons",o._3,i(o._6,u)));g()};return i(r,Xt)})())}},gl=t=>{const e={append:(()=>{const n=t.compare;return r=>i=>Se(n,Ee,r,i)})()};return{mempty:A,Semigroup0:()=>e}},di=function(t){return function(e){if(t>=0&&t<e.length)return e.charAt(t);throw new Error("Data.String.Unsafe.charAt: Invalid index.")}},lr=function(t){return t.join("")},hr=function(t){return t.split("")},_o=function(t){return t},jn=function(t){return t.length},hc=function(t){return function(e){return e.substr(0,t)}},li=function(t){return function(e){return e.substring(t)}},fl=function(t){return function(e){return{before:e.substring(0,t),after:e.substring(t)}}},_l=t=>e=>{const n=fl(jn(t))(e);return n.before===t?w("Just",n.after):J},dl=function(t){var e=null;return function(){return t===void 0||(e=t(),t=void 0),e}},ll=function(t){return t()},hl=t=>e=>n=>{try{var r=BigInt(n);return t(r)}catch{return e}},pl=t=>e=>n=>{try{var r=BigInt(n);return t(r)}catch{return e}},pr=t=>BigInt(t),ml=t=>Number(t),lo=t=>e=>t+e,ho=t=>e=>t*e,ts=t=>e=>t-e,pc=0n,po=1n,mc=t=>e=>t^e,hi=t=>e=>t&e,es=t=>e=>t<<e,ns=t=>e=>t>>e,yl=t=>e=>t==e,xl=t=>e=>t===e?0:t>e?1:-1,Nl={eq:yl},yc={compare:t=>e=>{const n=xl(t)(e);return n===1?Te:n===0?De:Je},Eq0:()=>Nl},Jl=hl(Ut)(J),Tl=pl(Ut)(J),xc=(()=>{const t={eq:e=>n=>e._1===n._1&&e._2===n._2};return{compare:e=>n=>{const r=it.compare(e._1)(n._1);return r==="LT"?Je:r==="GT"?Te:it.compare(e._2)(n._2)},Eq0:()=>t}})(),wl=t=>e=>Vn(t._1-e._1)+Vn(t._2-e._2),mr=t=>t,mo=t=>t,le=mo("North"),he=mo("South"),An=mo("East"),Fn=mo("West"),tr=mr("Rectangle"),vl=mr("Cylinder"),bl=mr("Parallelogram"),kl=mr("Diamond"),Ll=mr("Ellipse"),El=mr("Document"),Cl=mr("Cloud"),Nc=t=>t,Jc=T(Gr)(0),Sl=t=>e=>n=>{const r=it.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=it.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},ln=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Pr=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Tc=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},wc=t=>{const e={top:0,bottom:0,left:0,right:0},n=t.shape==="Cloud"?{...e,top:t.h*.38}:t.shape==="Cylinder"?{...e,bottom:5}:t.shape==="Document"?{...e,bottom:t.h*.05}:e;return[{x:t.x-n.left,y:t.y-n.top},{x:t.x+t.w+n.right,y:t.y+t.h+n.bottom}]},yr=t=>e=>{const n=ve(u=>s=>({a:u,b:s,len:(()=>{const a=s.y-u.y,c=s.x-u.x;return Ce(c*c+a*a)})()}),t,Lt(1,t.length,t)),r=Jc(O(u=>u.len)(n)),i=Sl(0)(r)(e*r),o=u=>s=>a=>{let c=u,f=s,d=a,l=!0,_;for(;l;){const h=c,p=f,m=d,y=Qt(x=>J,x=>N=>w("Just",{head:x,tail:N}),h);if(y.tag==="Nothing"){const x=t.length-1|0;if(x>=0&&x<t.length){l=!1,_=t[x];continue}l=!1,_=m;continue}if(y.tag==="Just"){if(p<=y._1.head.len){const x=y._1.head.len<=0?0:p/y._1.head.len;l=!1,_={x:y._1.head.a.x+(y._1.head.b.x-y._1.head.a.x)*x,y:y._1.head.a.y+(y._1.head.b.y-y._1.head.a.y)*x};continue}c=y._1.tail,f=p-y._1.head.len,d=m;continue}g()}return _};return 0<t.length?w("Just",o(n)(i)(t[0])):J},pi=t=>Jc(ve(e=>n=>{const r=n.y-e.y,i=n.x-e.x;return Ce(i*i+r*r)},t,Lt(1,t.length,t))),Gl=t=>e=>n=>r=>i=>{const o=0<t.length?w("Just",t[0]):J,u=(()=>{if(o.tag==="Nothing")return e;if(o.tag==="Just")return o._1;g()})(),s=t.length-1|0,a=s>=0&&s<t.length?w("Just",t[s]):J,c=(()=>{if(a.tag==="Nothing")return n;if(a.tag==="Just")return a._1;g()})(),f=ln(.05)(1-i.pre-i.post),d=r<i.pre?0:r>1-i.post?1:(r-i.pre)/f,l=c.x-n.x,_=2*(()=>{const v=c.y-n.y;return(l<0?-l:l)+(v<0?-v:v)})(),h=u.x-e.x,p=2*(()=>{const v=u.y-e.y;return(h<0?-h:h)+(v<0?-v:v)})(),m=p+pi(t)+_,y=m<=1e-4?1:1-_/m,x=m<=1e-4?0:p/m;if(d<=x){const v=x<=1e-4?1:d/x;return{x:e.x+(u.x-e.x)*v,y:e.y+(u.y-e.y)*v}}if(d>=y){const v=y>=1?0:(d-y)/(1-y);return{x:c.x+(n.x-c.x)*v,y:c.y+(n.y-c.y)*v}}const N=yr(t)((d-x)/ln(1e-4)(y-x));if(N.tag==="Nothing")return u;if(N.tag==="Just")return N._1;g()},Pl=t=>{const e=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return e(r._5,$t("Cons",r._4,e(r._6,i)));g()},n=Qt(r=>J,r=>i=>w("Just",{head:r,tail:i}),wt(Ct(Vt.foldr,e(t.nodes,Xt)))(wc));if(n.tag==="Nothing")return{x:0,y:0,w:0,h:0};if(n.tag==="Just"){const r=T(i=>o=>({minX:Pr(i.minX)(o.x),minY:Pr(i.minY)(o.y),maxX:ln(i.maxX)(o.x),maxY:ln(i.maxY)(o.y)}))({minX:n._1.head.x,minY:n._1.head.y,maxX:n._1.head.x,maxY:n._1.head.y})(n._1.tail);return{x:r.minX,y:r.minY,w:r.maxX-r.minX,h:r.maxY-r.minY}}g()},Dl=t=>e=>{const n=ln(4)(.15*Pr(e.w)(e.h)),r=ln(1)(t.w),i=ln(1)(t.h),o=ln(1)(e.w-2*n),u=ln(1)(e.h-2*n),s=Pr(o/r)(u/i);return{scale:s,tx:e.x+n+(o-r*s)/2-t.x*s,ty:e.y+n+(u-i*s)/2-t.y*s}},rs={scale:1,tx:0,ty:0},qe=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),[...(()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._4,n(r._6,i)));g()};return wt(Ct(Vt.foldr,n(t.nodes,Xt)))(wc)})(),...We((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._4,n(r._6,i)));g()};return Ct(Vt.foldr,n(t.edges,Xt))})()),...We((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._4,n(r._6,i)));g()};return Ct(Vt.foldr,n(t.chipExtras,Xt))})())]);if(e.tag==="Nothing")return{x:0,y:0,w:0,h:0};if(e.tag==="Just"){const n=T(r=>i=>({minX:Pr(r.minX)(i.x),minY:Pr(r.minY)(i.y),maxX:ln(r.maxX)(i.x),maxY:ln(r.maxY)(i.y)}))({minX:e._1.head.x,minY:e._1.head.y,maxX:e._1.head.x,maxY:e._1.head.y})(e._1.tail);return{x:n.minX,y:n.minY,w:n.maxX-n.minX,h:n.maxY-n.minY}}g()},Il=t=>e=>(n=>r=>i=>{let o=n,u=r,s=i,a=!0,c;for(;a;){const f=o,d=u,l=s,_=Qt(h=>J,h=>p=>w("Just",{head:h,tail:p}),d);if(_.tag==="Nothing"){a=!1,c=l;continue}if(_.tag==="Just"){const h=Tc(_._1.head)(f.interiors);if(h.tag==="Nothing"){a=!1,c=l;continue}if(h.tag==="Just"){o=h._1,u=_._1.tail,s=(()=>{const p=Dl(qe(h._1.layout))((()=>{const m=Tc(_._1.head)(f.layout.nodes);if(m.tag==="Nothing")return{x:0,y:0,w:1,h:1,label:"",shape:tr};if(m.tag==="Just")return m._1;g()})());return{scale:l.scale*p.scale,tx:l.scale*p.tx+l.tx,ty:l.scale*p.ty+l.ty}})();continue}}g()}return c})(t)(e)(rs),vc=t=>t,bc=(t,e)=>({tag:t,_1:e}),is=t=>t,mi=(t,e)=>({tag:t,_1:e}),os=(t,e)=>({tag:t,_1:e}),yi=is("Animated"),Al=is("StaticStill"),Fl=is("TitleCard"),Bl=os("First"),Ql=vc("Forward"),Rl=vc("Backward"),Ml=mi("ExitNode"),kc=te(S)(zt),zl=t=>ii(e=>n=>({nodes:Se(S.compare,Ee,e.nodes,n.nodes),edges:Se(S.compare,Ee,e.edges,n.edges)}))({nodes:A,edges:A})(t.keyframes),Hl=t=>e=>({entering:{nodes:In(S.compare,e.nodes,t.nodes),edges:In(S.compare,e.edges,t.edges)},leaving:{nodes:In(S.compare,t.nodes,e.nodes),edges:In(S.compare,t.edges,e.edges)},surviving:{nodes:so(S.compare,Ee,t.nodes,e.nodes),edges:so(S.compare,Ee,t.edges,e.edges)}}),yo=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Dr=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},xi=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},us=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Wl=T(t=>e=>tt(S)(e)()(t))(A),Ol=T(t=>e=>tt(S)(e)()(t))(A),Yl=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),Lc=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Ec=te(S)(zt),Ni=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return{x:0,y:0,w:0,h:0};if(e.tag==="Just"){const n=T(r=>i=>({minX:yo(r.minX)(i.x),minY:yo(r.minY)(i.y),maxX:Dr(r.maxX)(i.x),maxY:Dr(r.maxY)(i.y)}))({minX:e._1.head.x,minY:e._1.head.y,maxX:e._1.head.x,maxY:e._1.head.y})(e._1.tail);return{x:n.minX,y:n.minY,w:n.maxX-n.minX,h:n.maxY-n.minY}}g()},$l=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return J;if(e.tag==="Just")return w("Just",Ni(t));g()},ql=t=>e=>n=>Wl(wt(Ct(Qe.foldr,n))(r=>{const i=xi(r)(t);if(i.tag==="Just")return at(o=>!us(o)(e),[i._1.source,i._1.target]);if(i.tag==="Nothing")return[];g()})),Xl=t=>t.kind.tag==="SendToken"?w("Just",b(t.kind._1.edge,{source:t.kind._1.from,target:t.kind._1.to})):J,Vl=t=>t.tag==="DataFlow"?xt(Xl)(t._1.events):[],Ul=t=>e=>Ol(xt(n=>us(n._2.source)(e)||us(n._2.target)(e)?w("Just",n._1):J)(Yl(t))),Kl=t=>{const e=t.length-1|0;return e>=0&&e<t.length?0<t.length?t[0].x===t[e].x&&t[0].y===t[e].y?w("Just",Ni([t[0]])):w("Just",Ni([t[0],t[e]])):J:0<t.length?w("Just",Ni([t[0]])):J},xo=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return{x:0,y:0,w:0,h:0};if(e.tag==="Just"){const n=T(r=>i=>({minX:yo(r.minX)(i.x),minY:yo(r.minY)(i.y),maxX:Dr(r.maxX)(i.x+i.w),maxY:Dr(r.maxY)(i.y+i.h)}))({minX:e._1.head.x,minY:e._1.head.y,maxX:e._1.head.x+e._1.head.w,maxY:e._1.head.y+e._1.head.h})(e._1.tail);return{x:n.minX,y:n.minY,w:n.maxX-n.minX,h:n.maxY-n.minY}}g()},Cc=t=>e=>n=>{if(n.tag==="Leaf")return qe(t);const r=Ul(e)(n),i=[...xt(o=>{const u=Lc(o)(t.nodes);return u.tag==="Just"?w("Just",{x:u._1.x,y:u._1.y,w:u._1.w,h:u._1.h}):J})(Ct(Qe.foldr,Se(S.compare,Ee,n,ql(e)(n)(r)))),...xt(o=>{const u=xi(o)(t.edges);return u.tag==="Just"?w("Just",Ni(u._1)):J})(Ct(Qe.foldr,r)),...xt(o=>{const u=xi(o)(t.chipExtras);if(u.tag==="Just")return $l(u._1);if(u.tag==="Nothing")return J;g()})(Ct(Qe.foldr,r))];return i.length===0?qe(t):xo(i)},Ji=t=>e=>n=>{const r=[...xt(i=>i)([(()=>{const i=xi(n)(t.chipExtras);if(i.tag==="Just")return Kl(i._1);if(i.tag==="Nothing")return J;g()})()]),...(()=>{const i=xi(n)(e);if(i.tag==="Just")return xt(o=>{const u=Lc(o)(t.nodes);return u.tag==="Just"?w("Just",{x:u._1.x,y:u._1.y,w:u._1.w,h:u._1.h}):J})([i._1.source,i._1.target]);if(i.tag==="Nothing")return[];g()})()];return r.length===0?Cc(t)(e)(A):xo(r)},Sc=t=>e=>{const n=qe(t),r=n.w/Dr(1e-4)(e.zoom),i=n.h/Dr(1e-4)(e.zoom);return{x:e.center.x-r/2,y:e.center.y-i/2,w:r,h:i}},Zl=t=>Se(S.compare,Ee,Ec(O(e=>b(e.id,{source:e.from.node,target:e.to.node}))(t.graph.edges)),Ec(wt(t.scenes)(Vl))),No=t=>t,jl=t=>t,Ti=No("Linear"),th=No("EaseInOutQuad"),Jo=No("EaseInOutCubic"),eh=No("SpringBouncy"),wi=t=>e=>n=>{const r=Ce(1-e*e),i=t*r;return 1-oo(-e*t*n)*(rn(i*n)+e/r*Ve(i*n))},nh=t=>{const e=it.compare(0)(t),n=(()=>{if(e==="LT")return t;if(e==="EQ"||e==="GT")return 0;g()})(),r=it.compare(1)(n);if(r==="LT"||r==="EQ")return 1;if(r==="GT")return n;g()},vi=t=>e=>(()=>{if(t==="Linear")return jl;if(t==="EaseInQuad")return n=>n*n;if(t==="EaseOutQuad")return n=>1-(1-n)*(1-n);if(t==="EaseInOutQuad")return n=>n<.5?2*n*n:1-2*(1-n)*(1-n);if(t==="EaseInCubic")return n=>n*n*n;if(t==="EaseOutCubic")return n=>1-(1-n)*(1-n)*(1-n);if(t==="EaseInOutCubic")return n=>n<.5?4*n*n*n:1-(-2*n+2)*(-2*n+2)*(-2*n+2)/2;if(t==="EaseOutExpo")return n=>n>=1?1:1-Bu(2)(-10*n);if(t==="Spring")return n=>1-(1+6*n)*oo(-6*n);if(t==="SpringBouncy")return wi(6)(.7);g()})()(nh(e)),Gc=t=>t,ss=t=>t,To=t=>e=>n=>{const r=it.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=it.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},bi=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Pc=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},rh=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},ih=ss("Hold"),oh=ss("Gap"),uh=ss("Move"),ki=Gc("LinearLerp"),Dc=Gc("LogLerp"),sh=t=>e=>n=>{const r=n.center.y-e.center.y,i=n.center.x-e.center.x,o=Ce(i*i+r*r),u=n.zoom-e.zoom,s=u<0?-u:u;return To(t.minTransition)(t.maxTransition)(bi(t.panSpeed<=0?t.minTransition:o/t.panSpeed)(t.zoomSpeed<=0?t.minTransition:s/t.zoomSpeed))},ah=T(t=>e=>{const n=t.length-1|0;return n>=0&&n<t.length&&t[n]===e?t:Rt(t)(e)})([]),Ic=t=>e=>{const n={x:0,y:0},r=0<t.length?t[0].pos:n,i=Ua(Ut,J,o=>o.t<=e,t);if(i.tag==="Nothing")return r;if(i.tag==="Just"){const o=i._1+1|0;if(o>=0&&o<t.length){if(i._1>=0&&i._1<t.length){const u=To(0)(1)(t[o].t<=t[i._1].t?0:(e-t[i._1].t)/(t[o].t-t[i._1].t));return{x:t[i._1].pos.x+(t[o].pos.x-t[i._1].pos.x)*u,y:t[i._1].pos.y+(t[o].pos.y-t[i._1].pos.y)*u}}return n}return i._1>=0&&i._1<t.length?t[i._1].pos:n}g()},as=t=>e=>({center:{x:e.center.x*t.scale+t.tx,y:e.center.y*t.scale+t.ty},zoom:e.zoom/bi(1e-6)(t.scale)}),ch=t=>e=>n=>({center:{x:t.center.x+(e.center.x-t.center.x)*n,y:t.center.y+(e.center.y-t.center.y)*n},zoom:oo((()=>{const r=rc(bi(1e-6)(t.zoom));return r+(rc(bi(1e-6)(e.zoom))-r)*n})())}),gh=t=>e=>n=>{const r=vi(n.easing)(To(0)(1)(n.endT<=n.startT?1:(e-n.startT)/(n.endT-n.startT)));if(n.interp==="LinearLerp")return{center:{x:n.fromCam.center.x+(n.toCam.center.x-n.fromCam.center.x)*r,y:n.fromCam.center.y+(n.toCam.center.y-n.fromCam.center.y)*r},zoom:n.fromCam.zoom+(n.toCam.zoom-n.fromCam.zoom)*r};if(n.interp==="LogLerp")return ch(n.fromCam)(n.toCam)(r);g()},fh=t=>e=>n=>r=>{const i=(u,s)=>Pc(sh(t)(u.toCam)(s.toCam))(u.endT-u.startT),o=T(u=>s=>{if(u.pending.tag==="Nothing")return{acc:u.acc,pending:w("Just",s)};if(u.pending.tag==="Just")return!(s.fromCam.zoom===s.toCam.zoom&&s.fromCam.center.x===s.toCam.center.x&&s.fromCam.center.y===s.toCam.center.y)||(()=>{const a=u.pending._1.toCam.center.x-s.toCam.center.x;return(a<0?-a<8:a<8)&&(()=>{const c=u.pending._1.toCam.center.y-s.toCam.center.y;return(c<0?-c<8:c<8)&&(()=>{const f=u.pending._1.toCam.zoom-s.toCam.zoom;return f<0?-f<.08:f<.08})()})()})()||i(u.pending._1,s)<=0?{acc:Rt(u.acc)(u.pending._1),pending:w("Just",s)}:{acc:Rt(Rt(u.acc)({...u.pending._1,endT:s.startT-i(u.pending._1,s)}))({startT:s.startT-i(u.pending._1,s),endT:s.startT,fromCam:u.pending._1.toCam,toCam:s.toCam,easing:s.easing,interp:ki}),pending:w("Just",s)};g()})({acc:[],pending:J})(r);if(o.pending.tag==="Nothing")return o.acc;if(o.pending.tag==="Just")return Rt(o.acc)(o.pending._1);g()},_h=t=>e=>{const n=r=>{const i=Ua(Ut,J,o=>o.kind==="Hold"||o.kind==="Move",r<1?[]:Lt(0,r,e));if(i.tag==="Just")return i._1>=0&&i._1<e.length?w("Just",e[i._1].toCam):J;if(i.tag==="Nothing")return J;g()};return Bt(r=>i=>{if(i.kind==="Hold")return{startT:i.startT,endT:i.endT,fromCam:i.fromCam,toCam:i.toCam,easing:i.easing,interp:ki};if(i.kind==="Move")return{startT:i.startT,endT:i.endT,fromCam:i.fromCam,toCam:i.toCam,easing:Ti,interp:ki};if(i.kind==="Gap")return{startT:i.startT,endT:i.endT,fromCam:(()=>{const o=n(r);if(o.tag==="Nothing")return t;if(o.tag==="Just")return o._1;g()})(),toCam:(()=>{const o=n(r),u=(()=>{if(o.tag==="Nothing")return t;if(o.tag==="Just")return o._1;g()})(),s=r+1|0,a=gr(Ut,J,c=>c.kind==="Hold"||c.kind==="Move",s<1?e:Lt(s,e.length,e));if(a.tag==="Just"){const c=(r+1|0)+a._1|0;return c>=0&&c<e.length?e[c].fromCam:u}if(a.tag==="Nothing")return u;g()})(),easing:i.easing,interp:ki};g()})(e)},dh={padding:24,easing:Ti,minZoom:.9,maxZoom:2.5,tokenZoomFloor:0,panSpeed:1500,zoomSpeed:4,minTransition:.15,maxTransition:.6,cameraDecay:16},cs=t=>e=>n=>{const r=e.w+n*2,i=e.h+n*2,o=qe(t);return r<=0||i<=0||o.w<=0||o.h<=0?1:Pc(o.w/r)(o.h/i)},lh=T(t=>e=>{const n=t.length-1|0,r=n>=0&&n<t.length?w("Just",t[n]):J;return r.tag==="Just"&&r._1.fromCam.zoom===r._1.toCam.zoom&&r._1.fromCam.center.x===r._1.toCam.center.x&&r._1.fromCam.center.y===r._1.toCam.center.y&&e.fromCam.zoom===e.toCam.zoom&&e.fromCam.center.x===e.toCam.center.x&&e.fromCam.center.y===e.toCam.center.y&&(()=>{const i=r._1.toCam.center.x-e.toCam.center.x;return(i<0?-i<8:i<8)&&(()=>{const o=r._1.toCam.center.y-e.toCam.center.y;return(o<0?-o<8:o<8)&&(()=>{const u=r._1.toCam.zoom-e.toCam.zoom;return u<0?-u<.08:u<.08})()})()})()?Rt((()=>{const i=t.length-1|0;return i<1?[]:Lt(0,i,t)})())({...r._1,endT:e.endT}):Rt(t)(e)})([]),Li=t=>e=>n=>r=>({center:{x:n.x+n.w/2,y:n.y+n.h/2},zoom:bi(r)(To(t.minZoom)(t.maxZoom)(cs(e)(n)(t.padding)))}),hh=t=>e=>n=>r=>{const i=Et(s=>a=>nt.compare(a.priority)(s.priority)),o=Li(t)(e)(qe(e))(0),u=at(s=>s>=0&&s<=n,ah(Et(it.compare)([0,n,...wt(r)(s=>[s.startT,s.endT]),...wt(r)(s=>{if(s.pathFollow.tag==="Nothing")return[];if(s.pathFollow.tag==="Just")return O(a=>a.t)(s.pathFollow._1.samples);g()})])));return fh(t)(e)(o)(lh(_h(o)(xt(s=>{const a=(s._1+s._2)/2;if(s._2<=s._1)return J;const c=xt(d=>d.pathFollow)(i(at(d=>d.startT<=a&&a<d.endT,r)));if(0<c.length)return w("Just",{kind:uh,startT:s._1,endT:s._2,fromCam:{center:Ic(c[0].samples)(s._1),zoom:c[0].zoom},toCam:{center:Ic(c[0].samples)(s._2),zoom:c[0].zoom},easing:Ti});const f=O(d=>d.bbox)(at(d=>d.priority===T(rh)(0)(O(l=>l.priority)(at(l=>l.startT<=a&&a<l.endT,r))),at(d=>d.startT<=a&&a<d.endT,r)));return f.length===0?w("Just",{kind:oh,startT:s._1,endT:s._2,fromCam:o,toCam:o,easing:t.easing}):w("Just",{kind:ih,startT:s._1,endT:s._2,fromCam:Li(t)(e)(xo(f))(Oe(d=>d.priority>=1,at(d=>d.startT<=a&&a<d.endT,r))?t.tokenZoomFloor:0),toCam:Li(t)(e)(xo(f))(Oe(d=>d.priority>=1,at(d=>d.startT<=a&&a<d.endT,r))?t.tokenZoomFloor:0),easing:t.easing})})(ve(Pn,u,Lt(1,u.length,u))))))},Ac=t=>e=>n=>r=>{const i=Kt(o=>r>=o.startT&&r<o.endT)(n);if(i.tag==="Just")return gh()(r)(i._1);if(i.tag==="Nothing"){const o=n.length-1|0;if(o>=0&&o<n.length&&r>=n[o].endT)return n[o].toCam;const u=Li(t)(e)(qe(e))(0);return 0<n.length?n[0].fromCam:u}g()};function er(t){return t.charCodeAt(0)}function Fc(t){return String.fromCharCode(t)}const nr=function(t){return function(e){return function(n){return n.replace(new RegExp(t.replace(/[-\/\\^$*+?.()|[\]{}]/g,"\\$&"),"g"),e)}}},wo=function(t){return function(e){return e.split(t)}},ph=function(t){return t.trim()},vo=function(t){return function(e){return e.join(t)}};var mh=typeof Array.from=="function",yh=typeof Symbol<"u"&&Symbol!=null&&typeof Symbol.iterator<"u"&&typeof String.prototype[Symbol.iterator]=="function",xh=typeof String.prototype.fromCodePoint=="function",Nh=typeof String.prototype.codePointAt=="function";const Jh=function(t){return Nh?function(e){return e.codePointAt(0)}:t},Th=function(t){return xh?String.fromCodePoint:t},wh=function(t){return function(e){return yh?function(n){for(var r="",i=n[Symbol.iterator](),o=0;o<e;++o){var u=i.next();if(u.done)return r;r+=u.value}return r}:t(e)}},vh=function(t){return function(e){return mh?function(n){return Array.from(n,e)}:t}},bo=t=>{const e=jn(t);if(e===0)return J;if(e===1)return w("Just",{head:er(di(0)(t)),tail:""});const n=er(di(1)(t)),r=er(di(0)(t));return 55296<=r&&r<=56319&&56320<=n&&n<=57343?w("Just",{head:(((r-55296|0)*1024|0)+(n-56320|0)|0)+65536|0,tail:li(2)(t)}):w("Just",{head:r,tail:li(1)(t)})},bh=t=>{const e=bo(t);return e.tag==="Just"?w("Just",b(e._1.head,e._1.tail)):J},kh=t=>Ue.unfoldr(bh)(t),Bc=Jh(t=>{const e=er(di(0)(t));if(55296<=e&&e<=56319&&jn(t)>1){const n=er(di(1)(t));if(56320<=n&&n<=57343)return(((e-55296|0)*1024|0)+(n-56320|0)|0)+65536|0}return e}),ko=vh(kh)(Bc),gs=t=>_o(t>=0&&t<=65535?Fc(t):t<0?"\0":"\uFFFF"),Lh=Th(t=>t<=65535?gs(t):gs(Gn(t-65536|0,1024)+55296|0)+gs(Un(t-65536|0)(1024)+56320|0)),Qc=t=>e=>{if(t<1)return"";const n=bo(e);return n.tag==="Just"?Lh(n._1.head)+Qc(t-1|0)(n._1.tail):e},ye=wh(Qc),Eh=t=>e=>e===""?J:w("Just",Bc(e)),Lo=(t,e,n)=>({tag:t,_1:e,_2:n}),Ch=()=>({tag:"ExtendFromSource"}),Eo=(t,e)=>({tag:t,_1:e}),fs=t=>t,Co=(t,e)=>({tag:t,_1:e}),_s=Co("NotYet"),Rc=Co("Consumed"),Sh=fs("FromSource"),Mc=fs("FromTarget"),Gh=fs("FromBoth"),zc=Eo("Hidden"),Ph=Eo("Visible"),Hc=Ch(),Wc=Lo("Retracted"),Dh=Lo("Extended"),Oc=t=>t,ds=(t,e)=>({tag:t,_1:e}),xr=(t,e,n)=>({tag:t,_1:e,_2:n}),Yc=t=>t,rr=(t,e)=>({tag:t,_1:e}),Ir=(t,e,n,r,i,o,u,s,a)=>({tag:t,_1:e,_2:n,_3:r,_4:i,_5:o,_6:u,_7:s,_8:a}),Ei=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Nn=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},$c=te(S)(zt),ls=Au(oi),Ar=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},So=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Ci=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},qc=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Xc=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Fr=(()=>{const t=Ue.unfoldr(e=>{if(e.tag==="Nil")return J;if(e.tag==="Cons")return w("Just",b(e._1,e._2));g()});return e=>t((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._3,n(r._6,i)));g()};return n(e,Xt)})())})(),Ih=T(t=>e=>tt(S)(e)()(t))(A),hs=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Go=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Ah=rr("NoKeyframes"),Fh=t=>rr("DuplicateEventId",t),Bh=t=>rr("UnknownEvent",t),Vc=Yc("PlopIn"),Qh=Yc("PlopOut"),Rh=Oc("DiveIn"),Mh=Oc("DiveOut"),zh=t=>e=>n=>r=>{const i=Ei(r.edge)(e.edges),o=(()=>{if(i.tag==="Nothing")return 0;if(i.tag==="Just")return pi(i._1);g()})(),u=Nn(t.minTokenDuration)(Nn(et(T(s=>a=>s+ko(a).length|0)(0)(r.labels))*t.tokenReadSecPerChar)(t.tokenSpeed<=0?0:o/t.tokenSpeed))+n.pre+n.post;return{duration:u,holdPre:u<=0?0:n.pre/u,holdPost:u<=0?0:n.post/u}},Hh=t=>e=>$c(xt(n=>{if(n.kind.tag==="SendToken")return w("Just",b(n.id,{pre:(()=>{const r=n.when;return(()=>{const i=n.kind._1.from;return Oe(o=>{if(o.kind.tag==="SendToken")return(r.tag==="First"?!1:r.tag==="After"&&r._1===o.id)&&o.kind._1.to===i;if(o.kind.tag==="FillNodeWithoutTransition")return!1;g()},e)})()?0:t.tokenHold})(),post:(()=>{const r=n.id;return(()=>{const i=n.kind._1.to;return Oe(o=>{if(o.kind.tag==="SendToken")return(o.when.tag==="First"?!1:o.when.tag==="After"&&o.when._1===r)&&o.kind._1.from===i;if(o.kind.tag==="FillNodeWithoutTransition")return!1;g()},e)})()?0:t.tokenHold})()}));if(n.kind.tag==="FillNodeWithoutTransition")return J;g()})(e)),Wh=t=>{if(t.event.kind.tag==="SendToken")return w("Just",{startT:t.startT,endT:t.endT,target:Ir("TokenWindow",t.event.id,t.event.kind._1.edge,t.event.kind._1.direction,t.event.kind._1.from,t.event.kind._1.to,t.event.kind._1.labels,t.holdPre,t.holdPost)});if(t.event.kind.tag==="FillNodeWithoutTransition")return w("Just",{startT:t.startT,endT:t.endT,target:Ir("FillWindow",t.event.id,t.event.kind._1.node,t.event.kind._1.labels)});g()},Oh=t=>e=>n=>r=>{const i=Kt(o=>ls(o.path)(e)&&(Vn(o.endT-n)<1e-4||Vn(o.startT-r)<1e-4))(t.segments);if(i.tag==="Just")return w("Just",i._1);if(i.tag==="Nothing")return Kt(o=>ls(o.path)(e))(t.segments);g()},Yh=t=>e=>n=>xt(r=>{const i=xt(o=>Ci(o)(t.nodes))(Ct(Qe.foldr,(()=>{if(r.scene.tag==="Structural")return Se(S.compare,Ee,(()=>{const o=Ar(r.scene._1.from)(n);if(o.tag==="Nothing")return A;if(o.tag==="Just")return o._1.nodes;g()})(),(()=>{const o=Ar(r.scene._1.to)(n);if(o.tag==="Nothing")return A;if(o.tag==="Just")return o._1.nodes;g()})());if(r.scene.tag==="DataFlow"){const o=Ar(r.scene._1.keyframe)(n);if(o.tag==="Nothing")return A;if(o.tag==="Just")return o._1.nodes;g()}if(r.scene.tag==="Hold"){const o=Ar(r.scene._1)(n);if(o.tag==="Nothing")return A;if(o.tag==="Just")return o._1.nodes;g()}if(r.scene.tag==="EnterNode"||r.scene.tag==="ExitNode")return A;g()})()));return i.length===0?J:w("Just",{startT:r.startT,endT:r.endT,bbox:(()=>{const o=T(u=>s=>({minX:So(u.minX)(s.x),minY:So(u.minY)(s.y),maxX:Nn(u.maxX)(s.x+s.w),maxY:Nn(u.maxY)(s.y+s.h)}))(0<i.length?{minX:i[0].x,minY:i[0].y,maxX:i[0].x+i[0].w,maxY:i[0].y+i[0].h}:{minX:0,minY:0,maxX:0,maxY:0})(Lt(1,i.length,i));return{x:o.minX,y:o.minY,w:o.maxX-o.minX,h:o.maxY-o.minY}})(),priority:0,pathFollow:J})}),$h=t=>e=>n=>{const r=Ei(n)(t);if(r.tag==="Nothing")return Mc;if(r.tag==="Just"){const i=qc(r._1.target)(e);return qc(r._1.source)(e)?i?Gh:Sh:Mc}g()},qh={pre:0,post:0},Xh=t=>e=>n=>r=>i=>{const o=Xc(i.event.id)(n),u=(()=>{if(o.tag==="Nothing")return qh;if(o.tag==="Just")return o._1;g()})(),s=(()=>{if(i.event.when.tag==="First")return 0;if(i.event.when.tag==="At")return i.event.when._1;if(i.event.when.tag==="After"){const c=i.event.when._1,f=Kt(d=>d.event.id===c)(r);if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1.endT;g()}if(i.event.when.tag==="With"){const c=i.event.when._1,f=Kt(d=>d.event.id===c)(r);if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1.startT}g()})(),a=(()=>{if(i.event.kind.tag==="SendToken")return zh(t)(e)(u)(i.event.kind._1);if(i.event.kind.tag==="FillNodeWithoutTransition")return{duration:t.plop,holdPre:0,holdPost:0};g()})();return Rt(r)({startT:s,endT:s+a.duration,event:i.event,holdPre:a.holdPre,holdPost:a.holdPost})},Uc=t=>e=>n=>T(Xh(t)(e)(Hh(t)(n)))([])(Bt(r=>i=>({event:i}))(n)),Vh=t=>e=>{const n=Ci(e)(t.interiors);if(n.tag==="Nothing")return t;if(n.tag==="Just")return n._1;g()},Uh=t=>e=>({...e,fromCam:as(t)(e.fromCam),toCam:as(t)(e.toCam)}),Kh=t=>{if(t.when.tag==="First")return[];if(t.when.tag==="At")return[];if(t.when.tag==="After")return[t.when._1];if(t.when.tag==="With")return[t.when._1];g()},Kc={id:"",nodes:A,edges:A,kind:yi},Zh=t=>e=>Hl((()=>{const n=Ar(e.from)(t);if(n.tag==="Nothing")return Kc;if(n.tag==="Just")return n._1;g()})())((()=>{const n=Ar(e.to)(t);if(n.tag==="Nothing")return Kc;if(n.tag==="Just")return n._1;g()})()),jh=t=>e=>{const n=Ci(e)(t.interiors);if(n.tag==="Nothing")return{layout:t.layout,interiors:A};if(n.tag==="Just")return n._1;g()},ps=t=>e=>n=>r=>{const i=Ei(r)(n.edges);if(i.tag==="Just")return t<=0?e:Nn(e)(pi(i._1)/t);if(i.tag==="Nothing")return e;g()},Zc=t=>e=>n=>r=>i=>{const o=t.plop,u=Zh(n)(i),s=O(_=>({startT:0,endT:0+ps(t.edgeSpeed)(t.minEdgeDuration)(e)(_),target:Ir("EdgeWindow",_,ds("Extend",Hc))}))(Fr(u.entering.edges)),a=O(_=>({startT:0,endT:o,target:Ir("NodeWindow",_,Vc)}))(Fr(u.entering.nodes)),c=T(Nn)(0)(O(_=>ps(t.edgeSpeed)(t.minEdgeDuration)(e)(_))(Fr(u.leaving.edges))),f=_=>Oe(h=>{const p=Ei(h)(r);if(p.tag==="Just")return p._1.source===_||p._1.target===_;if(p.tag==="Nothing")return!1;g()},Fr(u.leaving.edges))?c:0,d=O(_=>({startT:f(_),endT:f(_)+t.plop,target:Ir("NodeWindow",_,Qh)}))(Fr(u.leaving.nodes)),l=O(_=>({startT:0,endT:ps(t.edgeSpeed)(t.minEdgeDuration)(e)(_),target:Ir("EdgeWindow",_,ds("Retract",$h(r)(u.leaving.nodes)(_)))}))(Fr(u.leaving.edges));return{duration:(()=>{const _=Et(it.compare)([...O(p=>p.endT)(l),...O(p=>p.endT)(d),...O(p=>p.endT)(a),...O(p=>p.endT)(s)]),h=_.length-1|0;return h>=0&&h<_.length?_[h]+t.gap:t.gap})(),windows:[...l,...d,...a,...s]}},t0=t=>e=>n=>r=>i=>o=>O((()=>{const u=i.startT;return s=>({...s,startT:s.startT+u,endT:s.endT+u})})())(Zc(t)(e)(n)(r)(o).windows),e0=t=>xt(e=>Ct(ii,e).length>1?w("Just",(()=>{const n=Qt(r=>J,r=>i=>w("Just",{head:r,tail:i}),Ct(ii,e));if(n.tag==="Just")return n._1.head;if(n.tag==="Nothing")return"";g()})()):J)(_d(oi)(Et(S.compare)(t))),n0=t=>{const e=O(r=>r.id)(t),n=Ih(e);return[...O(Fh)(e0(e)),...O(Bh)(at(r=>!hs(r)(n),wt(t)(Kh)))]},r0=t=>e=>n=>{const r=Nn(t.minZoom)(t.tokenZoomFloor);return xt(i=>{if(i.target.tag==="NodeWindow"||i.target.tag==="EdgeWindow")return J;if(i.target.tag==="TokenWindow")return w("Just",(()=>{const o={pre:i.target._7,post:i.target._8};if(t.tokenZoomFloor<=0)return{startT:i.startT,endT:i.endT,bbox:Ji(e)(n)(i.target._2),priority:1,pathFollow:J};const u=Ei(i.target._2)(e.edges);if(u.tag==="Just"){const s=Ci(i.target._4)(e.nodes);if(s.tag==="Just"){const a=Ci(i.target._5)(e.nodes);if(a.tag==="Just"){const c=a._1;return{startT:i.startT,endT:i.endT,bbox:Ji(e)(n)(i.target._2),priority:1,pathFollow:w("Just",{samples:(()=>{const f=i.startT+o.pre*(i.endT-i.startT),d=Nn(1e-4)(i.endT-o.post*(i.endT-i.startT)-f),l=i.endT-i.startT;return O(_=>{const h=f+et(_)/et(32)*d;return{t:h,pos:Gl(u._1)({x:s._1.x+s._1.w/2,y:s._1.y+s._1.h/2})({x:c.x+c.w/2,y:c.y+c.h/2})(l<=0?0:(h-i.startT)/l)(o)}})(Ft(0,32))})(),zoom:r})}}if(a.tag==="Nothing")return{startT:i.startT,endT:i.endT,bbox:Ji(e)(n)(i.target._2),priority:1,pathFollow:J};g()}if(s.tag==="Nothing")return{startT:i.startT,endT:i.endT,bbox:Ji(e)(n)(i.target._2),priority:1,pathFollow:J};g()}if(u.tag==="Nothing")return{startT:i.startT,endT:i.endT,bbox:Ji(e)(n)(i.target._2),priority:1,pathFollow:J};g()})());if(i.target.tag==="FillWindow")return w("Just",{startT:i.startT,endT:i.endT,bbox:Cc(e)(n)(Yt("Node",1,1,i.target._2,void 0,A,A)),priority:1,pathFollow:J});g()})},i0=t=>e=>n=>r=>i=>hh(t)(i.layout)(r.endT)([...Yh(i.layout)(n)(e)(at(o=>o.startT>=i.startT&&o.endT<=i.endT,r.spans)),...r0(t)(i.layout)(n)(i.windows)]),o0=t=>{const e=$c(O(r=>b(r.id,(()=>{if(r.when.tag==="First")return[];if(r.when.tag==="At")return[];if(r.when.tag==="After")return[r.when._1];if(r.when.tag==="With")return[r.when._1];g()})()))(t)),n=r=>i=>o=>{if(hs(o)(i))return[rr("ScheduleCycle",[...Ct(Qe.foldr,i),o])];if(hs(o)(r))return[];const u=Xc(o)(e);if(u.tag==="Nothing")return[];if(u.tag==="Just")return wt(u._1)(n(tt(S)(o)()(r))(tt(S)(o)()(i)));g()};return wt(t)(r=>n(A)(A)(r.id))},u0={plop:.5,gap:.5,edgeSpeed:350,minEdgeDuration:.3,tokenSpeed:250,minTokenDuration:1.8,tokenHold:.5,stillHold:1.8,hatchHold:.4,tokenReadSecPerChar:.06,nodeEasing:eh,edgeEasing:th,tokenEasing:Ti,diveDur:1.2,retreatDur:1.2},s0=t=>e=>n=>r=>O((()=>{const i=n.startT;return o=>({...o,startT:o.startT+i,endT:o.endT+i})})())(xt(Wh)(Uc(t)(e)(r.events))),a0=t=>e=>n=>r=>i=>{if(i.scene.tag==="Structural")return t0(t)(e)(n)(r)(i)(i.scene._1);if(i.scene.tag==="Hold")return[];if(i.scene.tag==="DataFlow")return s0(t)(e)(i)(i.scene._1);if(i.scene.tag==="EnterNode")return[];if(i.scene.tag==="ExitNode")return[];g()},c0=t=>e=>n=>{const r=Uc(t)(e)(n.events);return r.length===0?t.gap:T(Nn)(0)(O(i=>i.endT)(r))+t.gap},g0=t=>e=>n=>r=>i=>{if(i.tag==="Structural")return Zc(t)(e)(n)(r)(i._1).duration;if(i.tag==="Hold")return t.stillHold;if(i.tag==="DataFlow")return c0(t)(e)(i._1);if(i.tag==="EnterNode"||i.tag==="ExitNode")return 0;g()},jc=t=>e=>n=>r=>i=>o=>{const u=Il(e)(r),s=n.layout,a=kc(O(p=>b(p.id,p))(i.keyframes)),c=0<i.keyframes.length?w("Just",i.keyframes[0]):J,f=(()=>{if(c.tag==="Just")return c._1.id;if(c.tag==="Nothing")return"";g()})(),d=Zl(i),l=p=>({segments:p.runSpans.length===0?p.segments:Rt(p.segments)({startT:p.runStart,endT:p.t,path:r,layout:s,placement:u,windows:p.runWindows,spans:p.runSpans,keyframes:a,initialKeyframe:f,edgeEndpoints:d}),spans:p.spans,windows:p.windows,dives:p.dives}),_=T(p=>m=>{if(m.tag==="EnterNode"){const v=l(p),k=p.t+t.diveDur,L=Rt(r)(m._1),E=jc(t)(e)(jh(n)(m._1))(L)(Vh(i)(m._1))(k),B=E.endT+t.retreatDur;return{...p,t:B,runStart:B,runSpans:[],runWindows:[],segments:[...v.segments,...E.segments],spans:[...v.spans,...E.spans],windows:[...v.windows,...E.windows],dives:[...v.dives,{startT:p.t,endT:k,node:m._1,parentPath:r,childPath:L,direction:Rh},...E.dives,{startT:E.endT,endT:B,node:m._1,parentPath:r,childPath:L,direction:Mh}]}}if(m.tag==="ExitNode")return p;const y=p.t+g0(t)(s)(a)(d)(m),x={startT:p.t,endT:y,scene:m},N=a0(t)(s)(a)(d)(x);return{...p,t:y,runSpans:Rt(p.runSpans)(x),runWindows:[...p.runWindows,...N],spans:Rt(p.spans)(x),windows:[...p.windows,...N]}})({t:o,runStart:o,runSpans:[],runWindows:[],segments:[],spans:[],windows:[],dives:[]})(i.scenes),h=l(_);return{endT:_.t,spans:h.spans,windows:Et(p=>m=>it.compare(p.startT)(m.startT))(h.windows),segments:h.segments,dives:h.dives}},f0=t=>e=>n=>n.endT<=t||n.startT>=e?J:w("Just",{...n,startT:Nn(t)(n.startT),endT:So(e)(n.endT)}),ms=t=>e=>n=>{const r=qe(n.layout),i={x:r.x*n.placement.scale+n.placement.tx,y:r.y*n.placement.scale+n.placement.ty,w:r.w*n.placement.scale,h:r.h*n.placement.scale},o=40/(11*n.placement.scale),u=cs(e)(i)(t.padding*n.placement.scale);return{center:{x:i.x+i.w/2,y:i.y+i.h/2},zoom:(()=>{if(n.layout.nodes.tag==="Leaf")return!0;if(n.layout.nodes.tag==="Node")return n.layout.nodes._2<=1;g()})()?So(u)(o):u}},_0=t=>e=>n=>n.placement.scale===1&&n.placement.tx===0&&n.placement.ty===0?as(n.placement)(Li(t)(n.layout)(qe(n.layout))(0)):ms(t)(e)(n),d0=t=>e=>n=>r=>xt(i=>{const o=Oh(r)(i.parentPath)(i.startT)(i.endT);if(o.tag==="Just"){const u=i.childPath,s=Kt(a=>ls(a.path)(u))(r.segments);if(s.tag==="Just"){const a=_0(t)(e)(o._1),c=ms(t)(e)(s._1);if(i.direction==="DiveIn")return w("Just",{startT:i.startT,endT:i.endT,fromCam:a,toCam:c,easing:Jo,interp:Dc});if(i.direction==="DiveOut")return w("Just",{startT:i.startT,endT:i.endT,fromCam:c,toCam:a,easing:Jo,interp:Dc});g()}if(s.tag==="Nothing")return J;g()}if(o.tag==="Nothing")return J;g()})(r.dives),l0=t=>e=>{if(e.tag==="Structural")return xt(n=>n)([Go(e._1.from)(t)?J:w("Just",rr("UnknownKeyframe",e._1.from)),Go(e._1.to)(t)?J:w("Just",rr("UnknownKeyframe",e._1.to))]);if(e.tag==="Hold")return xt(n=>n)([Go(e._1)(t)?J:w("Just",rr("UnknownKeyframe",e._1))]);if(e.tag==="DataFlow")return[...xt(n=>n)([Go(e._1.keyframe)(t)?J:w("Just",rr("UnknownKeyframe",e._1.keyframe))]),...n0(e._1.events),...o0(e._1.events)];if(e.tag==="EnterNode")return[];if(e.tag==="ExitNode")return[];g()},h0=t=>e=>{const n=wt(e)(l0(t));return n.length===0?Dt("Right",void 0):Dt("Left",n)},p0=t=>e=>n=>r=>Et(i=>o=>it.compare(i.startT)(o.startT))(wt(r.segments)(i=>i.placement.scale===1&&i.placement.tx===0&&i.placement.ty===0?xt(f0(i.startT)(i.endT))(O(Uh(i.placement))(i0(t)(n)(i.edgeEndpoints)(r)(i))):[(()=>{const o=ms(t)(e)(i);return{startT:i.startT,endT:i.endT,fromCam:o,toCam:o,easing:Ti,interp:ki}})()])),m0=t=>e=>n=>r=>{if(0<n.keyframes.length){const i=n.keyframes[0],o=kc(O(s=>b(s.id,s))(n.keyframes)),u=h0(o)(n.scenes);return(()=>{if(u.tag==="Left"){const s=u._1;return a=>Dt("Left",s)}if(u.tag==="Right"){const s=u._1;return a=>a(s)}g()})()(()=>{const s=jc(e)(r)(r)([])(n)(0);return Dt("Right",{totalDuration:s.endT,windows:s.windows,spans:s.spans,keyframes:o,initialKeyframe:i.id,timing:e,layout:r.layout,cameraSpans:[...d0(t)(r.layout)(o)(s),...p0(t)(r.layout)(o)(s)],cameraConfig:t,levelTree:r,segments:s.segments,dives:s.dives,seed:n.seed})})}return Dt("Left",[Ah])},ys=t=>t,tg=te(S)(zt),hn=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Si={eq:Au(oi)},xs=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},eg=zt.foldMap(gl(S)),Ns=t=>e=>n=>{const r=it.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=it.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},y0=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},x0=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},N0=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),Br=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},J0=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},T0=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},w0=te(S)(zt),v0=te(S)(zt),ng=ys("Backdrop"),b0=ys("FlyThrough"),Po=ys("Active"),k0=t=>e=>n=>({...n,state:{...n.state,edgeFadeAlpha:tg(O(r=>b(r,e))(t))}}),rg=t=>e=>n=>{const r=(t+e)/2,i=n-r,o=i<0?-1:1,u=(e-t)/2,s=u*.15,a=u-s,c=i<0?-i:i;return e<=t?(t+e)/2:c<=a?n:r+o*(u-s*oo(-(c-a)/s))},L0=t=>e=>n=>r=>{const i=qe(t),o=i.w/hn(1e-4)(e.zoom)/2,u=i.h/hn(1e-4)(e.zoom)/2,s=n.y-e.center.y,a=n.x-e.center.x;return{...e,center:{x:o<=1e-4?e.center.x+0*r*.35:a<0?e.center.x+a/(1+-a/o)*r*.35:e.center.x+a/(1+a/o)*r*.35,y:u<=1e-4?e.center.y+0*r*.35:s<0?e.center.y+s/(1+-s/u)*r*.35:e.center.y+s/(1+s/u)*r*.35}}},Do=t=>e=>n=>{const r=Kt(i=>Si.eq(i.path)(e)&&n>=i.startT&&n<i.endT)(t.segments);if(r.tag==="Just")return w("Just",r._1);if(r.tag==="Nothing")return Kt(i=>Si.eq(i.path)(e))(t.segments);g()},E0=t=>({startT:0,endT:t.totalDuration,path:[],layout:t.layout,placement:rs,windows:t.windows,spans:t.spans,keyframes:t.keyframes,initialKeyframe:t.initialKeyframe,edgeEndpoints:A}),C0=t=>O(e=>e<1?[]:Lt(0,e,t))(Ft(0,t.length-1|0)),Js=t=>e=>{const n=xs(e)(t.keyframes);if(n.tag==="Nothing")return A;if(n.tag==="Just")return n._1.nodes;g()},Ts=t=>e=>{const n=xs(e)(t.keyframes);if(n.tag==="Nothing")return A;if(n.tag==="Just")return n._1.edges;g()},Io=t=>e=>{if(e<t.startT)return xr("AtKeyframe",t.initialKeyframe);const n=Kt(r=>e>=r.startT&&e<r.endT)(t.spans);if(n.tag==="Just"){if(n._1.scene.tag==="Structural")return xr("InTransition",n._1.scene._1.from,n._1.scene._1.to);if(n._1.scene.tag==="DataFlow")return xr("AtKeyframe",n._1.scene._1.keyframe);if(n._1.scene.tag==="Hold")return xr("AtKeyframe",n._1.scene._1);if(n._1.scene.tag==="EnterNode"||n._1.scene.tag==="ExitNode")return xr("AtKeyframe",t.initialKeyframe);g()}if(n.tag==="Nothing"){const r=t.spans.length-1|0;return r>=0&&r<t.spans.length?xr("AtKeyframe",(()=>{if(t.spans[r].scene.tag==="Structural")return t.spans[r].scene._1.to;if(t.spans[r].scene.tag==="DataFlow")return t.spans[r].scene._1.keyframe;if(t.spans[r].scene.tag==="Hold")return t.spans[r].scene._1;if(t.spans[r].scene.tag==="EnterNode"||t.spans[r].scene.tag==="ExitNode")return t.initialKeyframe;g()})()):xr("AtKeyframe",t.initialKeyframe)}g()},S0=T(t=>e=>{const n=fr(t);return n.tag==="Just"&&e.startT<=n._1.last.endT+1e-6?Rt(n._1.init)({...n._1.last,endT:hn(n._1.last.endT)(e.endT),windows:Rt(n._1.last.windows)(e)}):Rt(t)({endT:e.endT,windows:[e]})})([]),G0=t=>e=>n=>eg(r=>eg(i=>i.target.tag==="FillWindow"?i.startT<=n?Yt("Node",1,1,i.target._2,void 0,A,A):A:i.target.tag==="TokenWindow"&&i.startT+(i.endT-i.startT)*.25<=n?Yt("Node",1,1,i.target._4,void 0,A,A):A)(r.windows))(at(r=>n<=r.endT+t,S0(Et(r=>i=>it.compare(r.startT)(i.startT))(at(r=>r.target.tag==="FillWindow"||r.target.tag==="TokenWindow",e))))),P0=t=>e=>n=>Oe(r=>r.endT<=e&&r.target.tag==="EdgeWindow"&&r.target._2.tag==="Retract"&&r.target._1===n,t),D0=t=>e=>n=>Oe(r=>r.endT<=e&&r.target.tag==="NodeWindow"&&r.target._2==="PlopOut"&&r.target._1===n,t),I0=t=>e=>n=>Oe(r=>r.startT>e&&r.target.tag==="NodeWindow"&&r.target._2==="PlopIn"&&r.target._1===n,t),A0=t=>e=>n=>Oe(r=>r.startT>e&&r.target.tag==="EdgeWindow"&&r.target._2.tag==="Extend"&&r.target._1===n,t),F0=t=>e=>{const n=Io(t)(e);if(n.tag==="AtKeyframe")return ye(3)(n._1)==="kf-"?"":n._1;if(n.tag==="InTransition")return ye(3)(n._2)==="kf-"?"":n._2;g()},B0=t=>e=>{const n=Io(t)(e),r=xs((()=>{if(n.tag==="AtKeyframe")return n._1;if(n.tag==="InTransition")return n._2;g()})())(t.keyframes);if(r.tag==="Just")return r._1.kind;if(r.tag==="Nothing")return yi;g()},ig=t=>e=>n=>Kt(r=>n(r)&&e>=r.startT&&e<r.endT)(t),Q0=t=>{const e=Ns(0)(1)(t/.2),n=Ns(0)(1)((1-t)/.2);return e*e*(3-2*e)*n*n*(3-2*n)},R0=t=>e=>{if(e.tag==="Travelling"){const n=y0(e._1.edge)(t.edges);if(n.tag==="Just"){const r=yr(n._1)(e._1.progress);return r.tag==="Just"?w("Just",{dot:r._1,weight:Q0(e._1.progress)}):J}if(n.tag==="Nothing")return J;g()}return J},M0={segment:{startT:0,endT:0,path:[],layout:{nodes:A,edges:A,chipExtras:A,edgeLabels:A},placement:rs,windows:[],spans:[],keyframes:A,initialKeyframe:"",edgeEndpoints:A},state:{nodes:A,edges:A,tokens:A,camera:{center:{x:0,y:0},zoom:1},frameTitle:"",staticKind:yi,visited:A,nodeFadeAlpha:A,nodeLabelFadeAlpha:A,edgeFadeAlpha:A,nodeInvert:A},bgAlpha:1,blur:0,minis:[],role:Po},Ao=t=>{const e=t.levels.length-1|0;return e>=0&&e<t.levels.length?t.levels[e]:M0},z0=t=>e=>{const n=x0(e)(t.nodes);if(n.tag==="Nothing")return[];if(n.tag==="Just"){const r=n._1,i=o=>o.x>=r.x-1&&o.x<=r.x+r.w+1&&o.y>=r.y-1&&o.y<=r.y+r.h+1;return xt(o=>(()=>{if(0<o._2.length){const s=o._2.length-1|0;return i(o._2[0])||s>=0&&s<o._2.length&&i(o._2[s])}const u=o._2.length-1|0;return u>=0&&u<o._2.length&&i(o._2[u])})()?w("Just",o._1):J)(N0(t.edges))}g()},H0=t=>e=>{const n=Io(t)(e);if(n.tag==="AtKeyframe")return Js(t)(n._1);if(n.tag==="InTransition")return Se(S.compare,Ee,Js(t)(n._1),Js(t)(n._2));g()},W0=t=>e=>{const n=Io(t)(e);if(n.tag==="AtKeyframe")return Ts(t)(n._1);if(n.tag==="InTransition")return Se(S.compare,Ee,Ts(t)(n._1),Ts(t)(n._2));g()},O0=t=>e=>{const n=t.w/hn(1e-4)(e.zoom),r=t.h/hn(1e-4)(e.zoom);return{...e,center:{x:n>=t.w?t.x+t.w/2:rg(t.x+n/2)(t.x+t.w-n/2)(e.center.x),y:r>=t.h?t.y+t.h/2:rg(t.y+r/2)(t.y+t.h-r/2)(e.center.y)}}},Y0=t=>O0((()=>{const e=qe(t.layout),n=e.x*t.placement.scale+t.placement.tx,r=e.y*t.placement.scale+t.placement.ty;return{x:n,y:r,w:(e.x+e.w)*t.placement.scale+t.placement.tx-n,h:(e.y+e.h)*t.placement.scale+t.placement.ty-r}})()),$0=t=>e=>{const n=t.endT-t.startT;return n<=0?1:hn(0)(Br(1)((e-t.startT)/n))},Fo=t=>e=>{const n=t.endT-t.startT;return n<=0?1:hn(0)(Br(1)((e-t.startT)/n))},q0=t=>e=>n=>r=>i=>{const o=ig(e)(n)(u=>u.target.tag==="EdgeWindow"&&u.target._1===i);if(o.tag==="Just"){const u=vi(t.timing.edgeEasing)(Fo(o._1)(n)),s=o._1.target.tag==="EdgeWindow"?o._1.target._2:ds("Extend",Hc);if(s.tag==="Retract")return Lo("Retracting",s._1,u);if(s.tag==="Extend")return Lo("Extending",s._1,u);g()}if(o.tag==="Nothing")return A0(e)(n)(i)||P0(e)(n)(i)?Wc:J0(i)(r)?Dh:Wc;g()},X0=t=>e=>n=>{const r=W0(e)(n);return tg(O(i=>b(i,q0(t)(e.windows)(n)(r)(i)))((()=>{const i=o=>{if(o.tag==="Leaf")return A;if(o.tag==="Node")return Yt("Node",o._1,o._2,o._3,void 0,i(o._5),i(o._6));g()};return Ct(Qe.foldr,i(e.layout.edges))})()))},V0=t=>e=>n=>r=>{const i=ig(t)(e)(o=>o.target.tag==="NodeWindow"&&o.target._1===r);if(i.tag==="Just"){const o=Fo(i._1)(e),u=i._1.target.tag==="NodeWindow"?i._1.target._2:Vc;if(u==="PlopIn")return Eo("PloppingIn",o);if(u==="PlopOut")return Eo("PloppingOut",o);g()}if(i.tag==="Nothing")return I0(t)(e)(r)||D0(t)(e)(r)?zc:T0(r)(n)?Ph:zc;g()},U0=t=>e=>n=>{const r=H0(e)(n);return w0(O(i=>b(i,V0(e.windows)(n)(r)(i)))((()=>{const i=o=>{if(o.tag==="Leaf")return A;if(o.tag==="Node")return Yt("Node",o._1,o._2,o._3,void 0,i(o._5),i(o._6));g()};return Ct(Qe.foldr,i(e.layout.nodes))})()))},K0=t=>e=>n=>e.target.tag==="TokenWindow"?b(e.target._1,n<e.startT?_s:n>=e.endT?Rc:Co("Travelling",{edge:e.target._2,direction:e.target._3,progress:vi(t.timing.tokenEasing)(Fo(e)(n)),labels:e.target._6,source:e.target._4,target:e.target._5,holdPre:e.target._7,holdPost:e.target._8})):e.target.tag==="FillWindow"?b(e.target._1,n<e.startT?_s:n>=e.endT?Rc:Co("Filling",{node:e.target._2,progress:Fo(e)(n),labels:e.target._3})):b("",_s),Z0=t=>e=>n=>v0(O(r=>K0(t)(r)(n))(at(r=>r.target.tag==="TokenWindow"||r.target.tag==="FillWindow",e))),j0=t=>e=>n=>({nodes:U0()(e)(n),edges:X0(t)(e)(n),tokens:Z0(t)(e.windows)(n),camera:Ac(t.cameraConfig)(e.layout)(t.cameraSpans)(n),frameTitle:F0(e)(n),staticKind:B0(e)(n),visited:G0(t.timing.hatchHold)(e.windows)(n),nodeFadeAlpha:A,nodeLabelFadeAlpha:A,edgeFadeAlpha:A,nodeInvert:A}),Qr=t=>e=>n=>r=>({segment:n,state:j0(t)(n)(e),bgAlpha:1,blur:0,minis:tp(t)(e)(n),role:r}),tp=t=>e=>n=>xt(r=>{const i=Do(t)(Rt(n.path)(r))(e);if(i.tag==="Just")return w("Just",{...Qr(t)(Ns(i._1.startT)(i._1.endT-1e-4)(e))(i._1)(ng),bgAlpha:0});if(i.tag==="Nothing")return J;g()})((()=>{const r=i=>{if(i.tag==="Leaf")return A;if(i.tag==="Node")return Yt("Node",i._1,i._2,i._3,void 0,r(i._5),r(i._6));g()};return Ct(Qe.foldr,r(n.layout.nodes))})()),ep=t=>e=>n=>Va(J,Ha,r=>r.direction==="DiveIn"&&Si.eq(r.parentPath)(e.path)&&n>=r.startT-.7&&n<r.startT?w("Just",{node:r.node,phase:(n-(r.startT-.7))/.7}):J,t.dives),np=t=>e=>n=>r=>{const i=ep(t)(e)(n);if(i.tag==="Just"){const o=Ve(3.141592653589793*i._1.phase*3);return{...r,state:{...r.state,nodeInvert:Yt("Node",1,1,i._1.node,1*o*o,A,A)}}}if(i.tag==="Nothing")return r;g()},og=t=>e=>xt(n=>{const r=Kt(i=>i.direction==="DiveIn"&&Si.eq(i.childPath)((()=>{const o=n.length+1|0;return o<1?[]:Lt(0,o,e)})()))(t.dives);if(r.tag==="Just"){const i=Do(t)(n)(r._1.startT-1e-4);if(i.tag==="Just")return w("Just",(()=>{const o=Qr(t)(r._1.startT-1e-4)(i._1)(ng);return{...o,state:{...o.state,nodeFadeAlpha:Yt("Node",1,1,r._1.node,0,A,A)}}})());if(i.tag==="Nothing")return J;g()}if(r.tag==="Nothing")return J;g()})(C0(e)),ug=t=>e=>{const n=at(i=>e>=i.startT&&e<i.endT,t.segments),r=n.length-1|0;return r>=0&&r<n.length?n[r]:E0(t)},rp=t=>e=>n=>{const r=$0(n)(e),i=Do(t)(n.parentPath)((()=>{if(n.direction==="DiveIn")return n.startT-1e-4;if(n.direction==="DiveOut")return n.endT-1e-4;g()})()),o=Do(t)(n.childPath)((()=>{if(n.direction==="DiveIn")return n.endT;if(n.direction==="DiveOut")return n.startT-1e-4;g()})()),u=(()=>{if(n.direction==="DiveIn")return vi(Jo)(r);if(n.direction==="DiveOut")return 1-vi(Jo)(r);g()})(),s=1-hn(0)(Br(1)((u-.55)/.3)),a=1-hn(0)(Br(1)((u-.1)/.25)),c=1-hn(0)(Br(1)((u-.8)/.2)),f=l=>{const _=Qr(t)((()=>{if(n.direction==="DiveIn")return n.startT-1e-4;if(n.direction==="DiveOut")return n.endT-1e-4;g()})())(l)(b0);return{...k0(z0(l.layout)(n.node))(a)({..._,state:{..._.state,nodeFadeAlpha:Yt("Node",1,1,n.node,s,A,A),nodeLabelFadeAlpha:Yt("Node",1,1,n.node,a,A,A)}}),minis:at(h=>!Si.eq(h.segment.path)(n.childPath),_.minis),bgAlpha:c}},d=0+1*hn(0)(Br(1)((u-.1)/.5));return[...og(t)(n.parentPath),...(()=>{if(i.tag==="Just"){if(o.tag==="Just")return[f(i._1),{...Qr(t)((()=>{if(n.direction==="DiveIn")return n.endT;if(n.direction==="DiveOut")return n.startT-1e-4;g()})())(o._1)(Po),bgAlpha:d}];if(o.tag==="Nothing")return[f(i._1)];g()}if(i.tag==="Nothing")return[Qr(t)(e)(ug(t)(e))(Po)];g()})()]},ip=t=>e=>{const n=xt(R0(t))((()=>{const r=(i,o)=>{if(i.tag==="Leaf")return o;if(i.tag==="Node")return r(i._5,$t("Cons",i._4,r(i._6,o)));g()};return Ct(Vt.foldr,r(e.tokens,Xt))})());return 0<n.length?w("Just",n[0]):J},op=t=>e=>{const n=ip(t)(e);if(n.tag==="Nothing")return e.camera;if(n.tag==="Just")return L0(t)(e.camera)(n._1.dot)(n._1.weight);g()},up=t=>e=>t.placement.scale===1&&t.placement.tx===0&&t.placement.ty===0?op(t.layout)(e):e.camera,sp=t=>e=>Kt(n=>e>=n.startT&&e<n.endT)(t.dives),ap=t=>e=>{const n=ug(t)(e),r=Qr(t)(e)(n)(Po),i=t.dives.length!==0,o=Ac(t.cameraConfig)(t.layout)(t.cameraSpans)(e),u=Y0(n)(up(n)({...r.state,camera:o})),s=np(t)(n)(e)({...r,state:{...r.state,camera:u}}),a=og(t)(n.path),c=sp(t)(e);if(c.tag==="Just")return{levels:rp(t)(e)(c._1),camera:o,rootLayout:t.layout,hasDives:i,diving:!0};if(c.tag==="Nothing")return{levels:Rt(a)(s),camera:u,rootLayout:t.layout,hasDives:i,diving:!1};g()},sg=t=>t,ag=sg("RunText"),cp=sg("RunCode"),cg=t=>e=>n=>e.length===0?n:Rt(n)({style:t,text:lr(e)}),gp=t=>({style:(()=>{if(t.style==="RunText")return cp;if(t.style==="RunCode")return ag;g()})(),buf:[],runs:cg(t.style)(t.buf)(t.runs)}),fp=t=>e=>0<e.length?{...t,buf:Rt(t.buf)(e[0])}:{...t,buf:Rt(t.buf)("\\")},_p=t=>e=>{let n=t,r=e,i=!0,o;for(;i;){const u=n,s=Qt(a=>J,a=>c=>w("Just",{head:a,tail:c}),r);if(s.tag==="Nothing"){i=!1,o=u;continue}if(s.tag==="Just"){if(s._1.head==="\\"){n=fp(u)(s._1.tail),r=Lt(1,s._1.tail.length,s._1.tail);continue}if(s._1.head==="`"){n=gp(u),r=s._1.tail;continue}n={...u,buf:Rt(u.buf)(s._1.head)},r=s._1.tail;continue}g()}return o},gg=t=>{const e=_p({style:ag,buf:[],runs:[]})(hr(t));return cg(e.style)(e.buf)(e.runs)};let ws=null;function dp(){return ws||(typeof document>"u"?null:(ws=document.createElement("canvas").getContext("2d"),ws))}const fg=new Map,lp=t=>e=>n=>r=>()=>{const i=`${n} ${e}px ${t}|${r}`,o=fg.get(i);if(o!==void 0)return o;const u=dp();if(!u)return r.length*e*.62;u.font=`${n} ${e}px ${t}`;const s=u.measureText(r).width;return fg.set(i,s),s},hp=cr.traverse(Pu),pp=T(Gr)(0),Rr=(()=>{const t=nr(`\r
3
- `)(" "),e=nr(`
4
- `)(" "),n=(()=>{const r=nr("\r")(" "),i=(()=>{const o=nr(" ")(" ");return u=>o(r(u))})();return o=>i(e(o))})();return r=>n(t(r))})(),_g=t=>e=>{const n=hp(r=>{const i=(()=>{if(r.style==="RunText")return t.text;if(r.style==="RunCode")return t.code;g()})();return lp(i.family)(i.size)(i.weight)(Rr(r.text))})(gg(Rr(e)));return()=>{const r=n();return pp(r)}},dg={text:{family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:11,weight:"500"},code:{family:"'CommitMono', ui-monospace, SFMono-Regular, Menlo, monospace",size:11,weight:"400"}},mp=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Mr=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},yp=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},xp=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Np=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},lg=t=>lr(we(_r(e=>e===" ")(we(_r(e=>e===" ")(hr(t)).rest)).rest)),Jp=t=>T(e=>n=>n._1>0&&(n._2===" "||n._2==="-"||n._2==="_"||n._2===".")?w("Just",n._1):e)(J)(Bt(Pn)(t)),vs=t=>e=>{if(t<=0)return[e];if(jn(e)<=t)return[e];const n=hr(e),r=t<1?[]:Lt(0,t,n),i=Jp(r);if(i.tag==="Just"){const o=lg(hc(!(i._1>=0&&i._1<r.length)||r[i._1]===" "?i._1:i._1+1|0)(e)),u=lg(li(i._1+1|0)(e));return u===""?[o]:[o,...vs(t)(u)]}if(i.tag==="Nothing"){const o=hc(t)(e),u=li(t)(e);return u===""?[o]:[o,...vs(t)(u)]}g()},Tp={cellW:7,cellH:3,maxLineWidth:20},wp=t=>e=>{const n=O(o=>b((()=>{if(o.label.tag==="Just")return o.label._1;if(o.label.tag==="Nothing")return o.id;g()})(),o))(e.nodes),r=Mr(1)(Gn((yp(t.maxLineWidth)(T(o=>u=>Mr(o)(jn(u._1)))(0)(n))+2|0)+t.cellW|0,t.cellW)),i=(r*t.cellW|0)-1|0;return{...e,nodes:O(o=>{if(!(o._2.size._1===1&&o._2.size._2===1))return o._2;const u=wt(wo(`
5
- `)(o._1))(vs(i)),s=T(c=>f=>Mr(c)(jn(f)))(0)(u),a=o._2.shape==="Cylinder"?Mr(1)(Gn((s+2|0)+t.cellW|0,t.cellW)):r;return{...o._2,size:b(et(s>i?Gn((s+2|0)+t.cellW|0,t.cellW):a),et(Mr(1)(Gn(u.length+t.cellH|0,t.cellH))+(o._2.shape==="Cylinder"||o._2.shape==="Document"?1:0)|0))}})(n)}},vp=t=>e=>n=>({...n,nodes:O(r=>{const i=Np(r.id)(e);if(i.tag==="Nothing")return r;if(i.tag==="Just")return{...r,size:b(xp(r.size._1)(et(Mr(1)(ce(io(r.shape==="Cylinder"?(i._1+0)/t:(i._1+32)/t))))),r.size._2)};g()})(n.nodes)}),bp=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},kp=t=>{const e=t.length;return(n=>r=>{let i=n,o=r,u=!0,s;for(;u;){const a=i,c=o;if(a>=e){u=!1,s=c;continue}const f=d=>l=>{let _=d,h=l,p=!0,m;for(;p;){const y=_,x=h;if(y>=e){p=!1,m=x;continue}if(a>=0&&a<t.length){if(y>=0&&y<t.length){_=y+1|0,h=(()=>{const N=t[a].position,v=t[a].size,k=t[y].position,L=t[y].size;return N._1<k._1+L._1&&k._1<N._1+v._1&&N._2<k._2+L._2&&k._2<N._2+v._2})()?x+1|0:x;continue}_=y+1|0,h=x;continue}p=!1,m=x}return m};i=a+1|0,o=f(a+1|0)(c)}return s})(0)(0)},hg=t=>T(e=>n=>e+wl(n.start)(n.end))(0)(t.segments),Lp=t=>e=>n=>({crossingCount:T(r=>i=>r+i.jumps.length|0)(0)(e),bendCount:T(r=>i=>r+i.bends.length|0)(0)(e),totalEdgeLength:T(r=>i=>r+hg(i))(0)(e),maxEdgeLength:T(r=>i=>bp(r)(hg(i)))(0)(e),nodeOverlapCount:kp(t),constraintViolations:n,jumpCount:T(r=>i=>r+i.jumps.length|0)(0)(e)}),bs=t=>t,Zt=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},ks=bs("LEFT"),Ep=bs("RIGHT"),pg=bs("UNDEFINED"),Cp={eq:t=>e=>t==="LEFT"?e==="LEFT":t==="RIGHT"?e==="RIGHT":t==="UP"?e==="UP":t==="DOWN"?e==="DOWN":t==="UNDEFINED"&&e==="UNDEFINED"},Sp={compare:t=>e=>{if(t==="LEFT")return e==="LEFT"?De:Je;if(e==="LEFT")return Te;if(t==="RIGHT")return e==="RIGHT"?De:Je;if(e==="RIGHT")return Te;if(t==="UP")return e==="UP"?De:Je;if(e==="UP")return Te;if(t==="DOWN")return e==="DOWN"?De:Je;if(e==="DOWN")return Te;if(t==="UNDEFINED"&&e==="UNDEFINED")return De;g()},Eq0:()=>Cp},Gp=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){if(t==="LEFT"){if(o._3==="LEFT"){r=!1,i=!0;continue}n=o._5;continue}if(o._3==="LEFT"){n=o._6;continue}if(t==="RIGHT"){if(o._3==="RIGHT"){r=!1,i=!0;continue}n=o._5;continue}if(o._3==="RIGHT"){n=o._6;continue}if(t==="UP"){if(o._3==="UP"){r=!1,i=!0;continue}n=o._5;continue}if(o._3==="UP"){n=o._6;continue}if(t==="DOWN"){if(o._3==="DOWN"){r=!1,i=!0;continue}n=o._5;continue}if(o._3==="DOWN"){n=o._6;continue}if(t==="UNDEFINED"&&o._3==="UNDEFINED"){r=!1,i=!0;continue}}g()}return i},Pp={x:0,y:0},Ze=t=>e=>n=>{const r=Zt(t)(n.cNodes);if(r.tag==="Nothing")return n;if(r.tag==="Just")return{...n,cNodes:tt(nt)(t)(e(r._1))(n.cNodes)};g()},Gi=t=>e=>n=>{const r=Zt(t)(n.cGroups);if(r.tag==="Nothing")return n;if(r.tag==="Just")return{...n,cGroups:tt(nt)(t)(e(r._1))(n.cGroups)};g()},Dp=t=>T(e=>n=>Ze(n)(r=>({...r,hitboxPreCompaction:r.hitbox}))(e))(t)(t.cNodeOrder),Ip=t=>{const e=T(n=>r=>{const i=Zt(r)(t.cNodes);if(i.tag==="Nothing")return n;if(i.tag==="Just")return T(o=>u=>bt(nt)(re)(u)([r])(o))(n)(i._1.constraints);g()})(A)(t.cNodeOrder);return T(n=>r=>Ze(r)(i=>({...i,constraints:(()=>{const o=Zt(r)(e);if(o.tag==="Nothing")return[];if(o.tag==="Just")return o._1;g()})()}))(n))(t)(t.cNodeOrder)},Ap=t=>e=>Ze(t)(n=>({...n,ignoreSpacing:{left:n.ignoreSpacing.left||e.left,right:n.ignoreSpacing.right||e.right,up:n.ignoreSpacing.up||e.up,down:n.ignoreSpacing.down||e.down}})),Fp=t=>{const e=T(n=>r=>Gi(r)(i=>({...i,outDegree:i.outDegreeReal}))(n))(t)(t.cGroupOrder);return T(n=>r=>Ze(r)(i=>({...i,startPos:-1e308}))(n))(e)(e.cNodeOrder)},cn={left:!1,right:!1,up:!1,down:!1},Bp={horizontalSpacing:t=>e=>0,verticalSpacing:t=>e=>0},Ls=t=>T(e=>n=>{const r=Zt(n)(e.cGroups);if(r.tag==="Nothing")return e;if(r.tag==="Just"){const i=T(u=>s=>{const a=Zt(s)(e.cNodes);if(a.tag==="Nothing")return u;if(a.tag==="Just"){if(u.tag==="Nothing")return w("Just",s);if(u.tag==="Just"){const c=Zt(u._1)(e.cNodes);if(c.tag==="Nothing")return w("Just",s);if(c.tag==="Just")return a._1.hitbox.x<c._1.hitbox.x?w("Just",s):w("Just",u._1)}}g()})(J)(r._1.cNodes),o=Gi(n)(u=>({...u,reference:i}))(e);if(i.tag==="Nothing")return o;if(i.tag==="Just"){const u=Zt(i._1)(o.cNodes);if(u.tag==="Nothing")return o;if(u.tag==="Just"){const s=u._1;return T(a=>c=>Ze(c)(f=>({...f,cGroupOffset:{x:f.hitbox.x-s.hitbox.x,y:f.hitbox.y-s.hitbox.y}}))(a))(o)(r._1.cNodes)}}}g()})(t)(t.cGroupOrder),je=t=>Ls({...t,cNodes:(()=>{const e=n=>{if(n.tag==="Leaf")return A;if(n.tag==="Node")return Yt("Node",n._1,n._2,n._3,{...n._4,hitbox:{...n._4.hitbox,x:-n._4.hitbox.x-n._4.hitbox.width}},e(n._5),e(n._6));g()};return e(t.cNodes)})()}),Jn=t=>Ls({...t,cNodes:(()=>{const e=n=>{if(n.tag==="Leaf")return A;if(n.tag==="Node")return Yt("Node",n._1,n._2,n._3,{...n._4,hitbox:{x:n._4.hitbox.y,y:n._4.hitbox.x,width:n._4.hitbox.height,height:n._4.hitbox.width},cGroupOffset:{x:n._4.cGroupOffset.y,y:n._4.cGroupOffset.x}},e(n._5),e(n._6));g()};return e(t.cNodes)})()}),mg=t=>{const e=T(n=>r=>Gi(r)(i=>({...i,outDegree:0,outDegreeReal:0,incomingConstraints:[]}))(n))(t)(t.cGroupOrder);return T(n=>r=>{const i=Zt(r)(n.cNodes);if(i.tag==="Nothing")return n;if(i.tag==="Just"){if(i._1.cGroup.tag==="Nothing")return n;if(i._1.cGroup.tag==="Just"){const o=i._1.cGroup._1;return T(u=>s=>{const a=Zt(s)(u.cNodes);if(a.tag==="Nothing")return u;if(a.tag==="Just")return a._1.cGroup.tag==="Just"&&a._1.cGroup._1!==o?Gi(a._1.cGroup._1)(c=>({...c,outDegree:c.outDegree+1|0,outDegreeReal:c.outDegreeReal+1|0}))(Gi(o)(c=>Ye(Er)(s)(c.incomingConstraints)?c:{...c,incomingConstraints:[...c.incomingConstraints,s]})(u)):u;g()})(n)(i._1.constraints)}}g()})(e)(e.cNodeOrder)},Bo=t=>{const e=Ip(t.cGraph);return{...t,cGraph:mg(T(n=>r=>Ze(r)(i=>({...i,startPos:-1e308}))(n))(e)(e.cNodeOrder))}},Qp=t=>e=>T(n=>r=>{if(t==="LEFT"||t==="UP"){const o=r._2;return Ze(r._1)(u=>({...u,constraints:[...u.constraints,o]}))(n)}const i=r._1;return Ze(r._2)(o=>({...o,constraints:[...o.constraints,i]}))(n)})(e)(t==="LEFT"||t==="RIGHT"?e.predefinedHorizontalConstraints:e.predefinedVerticalConstraints),gn=t=>{const e={...t,cGraph:Qp(t.direction)({...t.cGraph,cNodes:(()=>{const n=r=>{if(r.tag==="Leaf")return A;if(r.tag==="Node")return Yt("Node",r._1,r._2,r._3,{...r._4,constraints:[]},n(r._5),n(r._6));g()};return n(t.cGraph.cNodes)})()})};return{...e,cGraph:mg((()=>{if(e.constraintAlgorithm.tag==="Nothing")return e.cGraph;if(e.constraintAlgorithm.tag==="Just")return e.constraintAlgorithm._1(e);g()})())}},Rp=t=>e=>n=>{const r={...n,direction:e};if(t==="UNDEFINED")return e==="LEFT"?gn(r):e==="RIGHT"?gn({...r,cGraph:je(r.cGraph)}):e==="UP"?gn({...r,cGraph:Jn(r.cGraph)}):e==="DOWN"?gn({...r,cGraph:je(Jn(r.cGraph))}):r;if(t==="LEFT")return e==="RIGHT"?Bo({...r,cGraph:je(r.cGraph)}):e==="UP"?gn({...r,cGraph:Jn(r.cGraph)}):e==="DOWN"?gn({...r,cGraph:je(Jn(r.cGraph))}):r;if(t==="RIGHT")return e==="LEFT"?Bo({...r,cGraph:je(r.cGraph)}):e==="UP"?gn({...r,cGraph:Jn(je(r.cGraph))}):e==="DOWN"?gn({...r,cGraph:je(Jn(je(r.cGraph)))}):r;if(t==="UP")return e==="LEFT"?gn({...r,cGraph:Jn(r.cGraph)}):e==="RIGHT"?gn({...r,cGraph:je(Jn(r.cGraph))}):e==="DOWN"?Bo({...r,cGraph:je(r.cGraph)}):r;if(t==="DOWN")return e==="LEFT"?gn({...r,cGraph:Jn(je(r.cGraph))}):e==="RIGHT"?gn({...r,cGraph:je(Jn(je(r.cGraph)))}):e==="UP"?Bo({...r,cGraph:je(r.cGraph)}):r;g()},yg=t=>e=>e.finished||!Gp(t)(e.cGraph.supportedDirections)||(t==="LEFT"?e.direction==="LEFT":t==="RIGHT"?e.direction==="RIGHT":t==="UP"?e.direction==="UP":t==="DOWN"?e.direction==="DOWN":t==="UNDEFINED"&&e.direction==="UNDEFINED")?e:Rp(e.direction)(t)(e),Mp=t=>{if(t.finished)return t;const e=t.direction==="UNDEFINED"?yg(ks)(t):t,n={...e,cGraph:Fp(e.cGraph)};if(n.compactionAlgorithm.tag==="Nothing")return n;if(n.compactionAlgorithm.tag==="Just")return n.compactionAlgorithm._1(n);g()},xg=t=>e=>n=>{const r=Zt(t)(n.cNodes),i=Zt(e)(n.cGroups);return r.tag==="Just"&&i.tag==="Just"?(()=>{if(r._1.cGroup.tag==="Nothing")return!1;if(r._1.cGroup.tag==="Just")return!0;g()})()&&(r._1.cGroup.tag==="Nothing"||!(r._1.cGroup.tag==="Just"&&r._1.cGroup._1===e))?n:{...n,cNodes:tt(nt)(t)({...r._1,cGroup:w("Just",e)})(n.cNodes),cGroups:tt(nt)(e)({...i._1,cNodes:Ye(Er)(t)(i._1.cNodes)?i._1.cNodes:[...i._1.cNodes,t],reference:(()=>{if(i._1.reference.tag==="Nothing")return w("Just",t);if(i._1.reference.tag==="Just")return w("Just",i._1.reference._1);g()})()})(n.cGroups)}:n},Ng=t=>e=>({id:e.nextCNodeId,graph:{...e,cNodes:tt(nt)(e.nextCNodeId)({id:e.nextCNodeId,origin:t.origin,kind:t.kind,cGroup:J,cGroupOffset:Pp,hitbox:t.hitbox,hitboxPreCompaction:t.hitbox,constraints:[],startPos:-1e308,ignoreSpacing:cn})(e.cNodes),cNodeOrder:[...e.cNodeOrder,e.nextCNodeId],nextCNodeId:e.nextCNodeId+1|0}}),Es=t=>e=>{const n=e.nextCGroupId;return{id:n,graph:T(r=>i=>xg(i)(n)(r))({...e,cGroups:tt(nt)(n)({id:n,master:t.master,cNodes:[],startPos:-1e308,incomingConstraints:[],outDegree:0,outDegreeReal:0,reference:J,delta:0,deltaNormalized:0})(e.cGroups),cGroupOrder:[...e.cGroupOrder,n],nextCGroupId:n+1|0})(t.nodes)}},zp=t=>T(e=>n=>{const r=Zt(n)(e.cNodes);return r.tag==="Just"&&r._1.cGroup.tag==="Nothing"?Es({master:J,nodes:[n]})(e).graph:e})(t)(t.cNodeOrder),Hp=t=>({cGraph:Dp(zp(Ls(t))),direction:pg,compactionAlgorithm:J,constraintAlgorithm:J,spacingsHandler:Bp,lockFun:J,finished:!1}),Wp=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Op=t=>e=>{const n=it.compare(t._1)(e._1);return n==="LT"?Je:n==="GT"?Te:nt.compare(t._2)(e._2)},Yp=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),Jg=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Tg=t=>t.kind.tag==="Nothing"?!1:t.kind.tag==="Just"&&t.kind._1==="vs",wg=t=>t.kind.tag==="Nothing"||!(t.kind.tag==="Just"&&t.kind._1==="vs"),Qo=t=>e=>Op(b(t.hitbox.x+t.hitbox.width/2,t.id))(b(e.hitbox.x+e.hitbox.width/2,e.id)),$p=t=>e=>{const n=gr(Ut,J,r=>Qo(t)(r)==="LT",e);if(n.tag==="Just"){const r=Ka(Ut,J,n._1,t,e);if(r.tag==="Nothing")return e;if(r.tag==="Just")return r._1;g()}if(n.tag==="Nothing")return Rt(e)(t);g()},vg=t=>e=>{const n=at(i=>Qo(i)(t)==="LT",e),r=n.length-1|0;return r>=0&&r<n.length?w("Just",n[r]):J},qp=t=>e=>{const n=$p(e)(t.intervals),r=Kt(o=>Qo(e)(o)==="LT")(n),i=tt(nt)(e.id)((()=>{const o=vg(e)(n);return o.tag==="Just"?w("Just",o._1.id):J})())(t.cand);return{...t,intervals:n,cand:(()=>{if(r.tag==="Just")return tt(nt)(r._1.id)(w("Just",e.id))(i);if(r.tag==="Nothing")return i;g()})()}},Xp=t=>e=>{const n=it.compare(t.low?t.node.hitbox.y:t.node.hitbox.y+t.node.hitbox.height)(e.low?e.node.hitbox.y:e.node.hitbox.y+e.node.hitbox.height);return n==="EQ"?t.low?t.low&&!e.low?Te:De:e.low?Je:De:n},Vp=t=>T(e=>n=>Ze(n.id)(r=>({...r,constraints:[]}))(e))(t)(xt(e=>Zt(e)(t.cNodes))(t.cNodeOrder)),Cs=t=>e=>T(n=>r=>{const i=Zt(r._1)(n.cNodes);if(i.tag==="Just")return Ze(r._1)(o=>({...o,constraints:[...o.constraints,...r._2]}))(n);if(i.tag==="Nothing")return n;g()})(e)(Yp(t)),bg=t=>e=>e.kind.tag!=="Nothing"&&e.kind.tag==="Just"&&e.kind._1==="vs"?e.ignoreSpacing.up?e.ignoreSpacing.down?e:{...e,hitbox:{...e.hitbox,height:e.hitbox.height+t+.01}}:{...e,hitbox:{...e.hitbox,y:e.hitbox.y-t-.01,height:e.hitbox.height+t+.01}}:{...e,hitbox:{...e.hitbox,y:e.hitbox.y-t,height:e.hitbox.height+2*t}},kg=t=>e=>n=>T(r=>i=>n(i)?Ze(i.id)(bg(t))(r):r)(e)(xt(r=>Zt(r)(e.cNodes))(e.cNodeOrder)),Up=t=>e=>{const n=(r,i,o)=>{const u=Ze(o)(bg(t))(r);return i.length<=1?u:T(s=>a=>a===o?s:Ze(a)(c=>c.ignoreSpacing.up?{...c,hitbox:{...c.hitbox,y:c.hitbox.y+t+.01,height:c.hitbox.height-t-.01}}:c.ignoreSpacing.down?{...c,hitbox:{...c.hitbox,height:c.hitbox.height-t-.01}}:c)(s))(u)(i)};return T(r=>i=>{if(i.master.tag==="Nothing")return 0<i.cNodes.length?n(r,i.cNodes,i.cNodes[0]):r;if(i.master.tag==="Just")return n(r,i.cNodes,i.master._1);g()})(e)(xt(r=>Zt(r)(e.cGroups))(e.cGroupOrder))},Kp=t=>e=>{const n=vg(e)(t.intervals),r=Kt(o=>Qo(e)(o)==="LT")(t.intervals),i=n.tag==="Just"&&(()=>{const o=Jg(e.id)(t.cand);return(o.tag==="Nothing"?!1:o.tag==="Just"&&(o._1.tag==="Nothing"?!1:o._1.tag==="Just"&&o._1._1===n._1.id))&&n._1.cGroup.tag==="Just"&&e.cGroup.tag==="Just"&&n._1.cGroup._1!==e.cGroup._1})()?bt(nt)(re)(n._1.id)([e.id])(t.constraints):t.constraints;return{...t,constraints:r.tag==="Just"&&(()=>{const o=Jg(r._1.id)(t.cand);return(o.tag==="Nothing"?!1:o.tag==="Just"&&(o._1.tag==="Nothing"?!1:o._1.tag==="Just"&&o._1._1===e.id))&&e.cGroup.tag==="Just"&&r._1.cGroup.tag==="Just"&&e.cGroup._1!==r._1.cGroup._1})()?bt(nt)(re)(e.id)([r._1.id])(i):i,intervals:at(o=>o.id!==e.id,t.intervals)}},Zp=t=>e=>e.low?qp(t)(e.node):Kp(t)(e.node),Ss=t=>e=>T(Zp)({intervals:[],cand:A,constraints:A})(Et(Xp)(wt(at(t,xt(n=>Zt(n)(e.cNodes))(e.cNodeOrder)))(n=>[{node:n,low:!0},{node:n,low:!1}]))).constraints,jp=t=>e=>{const n=Wp(0)(t/2-.5),r=Cs(Ss(Tg)(kg(n)(e)(Tg)))(e),i=Cs(Ss(wg)(kg(n)(r)(wg)))(r);return Cs(Ss(o=>!0)(Up(n)(i)))(i)},tm=t=>e=>jp(t)(Vp(e.cGraph)),Ro=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Lg=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Gs=t=>e=>n=>r=>i=>({id:t,representedEdges:[i],affectedBends:[e,n],hitbox:{x:Ro(e._1)(n._1),y:Ro(e._2)(n._2),width:Vn(e._1-n._1),height:Vn(e._2-n._2)},ignoreSpacing:cn,potentialGroupParents:(()=>{if(r.tag==="Nothing")return[];if(r.tag==="Just")return[r._1];g()})(),aPort:J}),em=t=>e=>{const n=Ro(t.hitbox.x)(e.hitbox.x),r=Ro(t.hitbox.y)(e.hitbox.y);return{...t,representedEdges:[...t.representedEdges,...e.representedEdges],affectedBends:[...t.affectedBends,...e.affectedBends],potentialGroupParents:[...t.potentialGroupParents,...e.potentialGroupParents],hitbox:{x:n,y:r,width:Lg(t.hitbox.x+t.hitbox.width)(e.hitbox.x+e.hitbox.width)-n,height:Lg(t.hitbox.y+t.hitbox.height)(e.hitbox.y+e.hitbox.height)-r},ignoreSpacing:{left:t.ignoreSpacing.left||e.ignoreSpacing.left,right:t.ignoreSpacing.right||e.ignoreSpacing.right,up:t.ignoreSpacing.up||e.ignoreSpacing.up,down:t.ignoreSpacing.down||e.ignoreSpacing.down},aPort:(()=>{if(t.aPort.tag==="Just")return t.aPort;if(t.aPort.tag==="Nothing")return e.aPort;g()})()}},nm=t=>e=>Vn(t.hitbox.x-e.hitbox.x)<=1e-4&&e.hitbox.y-(t.hitbox.y+t.hitbox.height)<=1e-4&&t.hitbox.y-(e.hitbox.y+e.hitbox.height)<=1e-4,rm=t=>e=>Vn(t.hitbox.x-e.hitbox.x)<=1e-4?it.compare(t.hitbox.y)(e.hitbox.y):t.hitbox.x<e.hitbox.x?Je:Te,Eg=(t,e)=>({tag:t,_1:e}),Ps=te(S)(zt),Mo=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Cg=(()=>{const t={eq:n=>r=>n._1===r._1&&(n._2.tag==="Nothing"?r._2.tag==="Nothing":n._2.tag==="Just"&&r._2.tag==="Just"&&n._2._1===r._2._1)},e={compare:n=>r=>{const i=S.compare(n._1)(r._1);if(i==="LT")return Je;if(i==="GT")return Te;if(n._2.tag==="Nothing")return r._2.tag==="Nothing"?De:Je;if(r._2.tag==="Nothing")return Te;if(n._2.tag==="Just"&&r._2.tag==="Just")return S.compare(n._2._1)(r._2._1);g()},Eq0:()=>t};return T(n=>r=>tt(e)(r)()(n))(A)})(),Bn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},im=T(t=>e=>tt(Sp)(e)()(t))(A),Ds=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=xc.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},om=t=>e=>{const n=Ps(O(o=>b(o.id,o))(t)),r=xt(o=>Mo(o)(n))(e),i=nt.compare((()=>{const o=Cg(O(u=>b(u.from.node,u.from.port))(r));if(o.tag==="Leaf")return 0;if(o.tag==="Node")return o._2;g()})())((()=>{const o=Cg(O(u=>b(u.to.node,u.to.port))(r));if(o.tag==="Leaf")return 0;if(o.tag==="Node")return o._2;g()})());if(i==="LT")return{...cn,left:!0,right:!1};if(i==="GT")return{...cn,left:!1,right:!0};if(i==="EQ")return cn;g()},um=t=>xt(e=>{if(e.direction==="V")return w("Just",{start:e.start,end:e.end});if(e.direction==="H")return J;g()})(t.segments),zo=t=>e=>n=>r=>{if(r.tag==="Just"){const i=Bn(n)(e);if(i.tag==="Just"){const o=Kt(u=>u.id===r._1)(i._1);if(o.tag==="Just")return o._1.side;if(o.tag==="Nothing")return t;g()}if(i.tag==="Nothing")return t;g()}if(r.tag==="Nothing")return t;g()},sm=t=>e=>n=>{const r=Ng({origin:w("Just",Eg("SegmentOrigin",n)),kind:w("Just","vs"),hitbox:n.hitbox})(e.cGraph),i=Ap(r.id)(n.ignoreSpacing)(r.graph);return{...e,cGraph:(()=>{if(0<n.potentialGroupParents.length){const o=Zt(n.potentialGroupParents[0])(i.cNodes);if(o.tag==="Just"){if(o._1.cGroup.tag==="Just")return xg(r.id)(o._1.cGroup._1)(i);if(o._1.cGroup.tag==="Nothing")return i;g()}if(o.tag==="Nothing")return i;g()}return Es({master:w("Just",r.id),nodes:[r.id]})(i).graph})(),edgeToCs:T(o=>u=>bt(S)(re)(u)([r.id])(o))(e.edgeToCs)(n.representedEdges),lockMap:tt(nt)(r.id)(om(t)(n.representedEdges))(e.lockMap)}},am=t=>e=>n=>{const r=Qt(i=>J,i=>o=>w("Just",{head:i,tail:o}),Et(rm)(e));if(r.tag==="Nothing")return n;if(r.tag==="Just"){const i=T(o=>u=>nm(o.survivor)(u)?{...o,survivor:em(o.survivor)(u)}:{survivor:u,merged:[...o.merged,o.survivor]})({survivor:r._1.head,merged:[]})(r._1.tail);return T(sm(t))(n)([...i.merged,i.survivor])}g()},cm=t=>({cGraph:{cNodes:A,cNodeOrder:[],cGroups:A,cGroupOrder:[],supportedDirections:im([pg,ks,Ep]),predefinedHorizontalConstraints:[],predefinedVerticalConstraints:[],nextCNodeId:0,nextCGroupId:0},nodeToC:A,edgeToCs:A,lockMap:A}),gm=t=>{const e=et(4);return{x:t.position._1*e,y:t.position._2*e,width:t.size._1*e,height:t.size._2*e}},fm=t=>e=>n=>T(r=>i=>{const o=Ng({origin:w("Just",Eg("NodeOrigin",i.node)),kind:J,hitbox:gm(i)})(r.cGraph),u=Bn(i.node)(t),s=(()=>{if(u.tag==="Nothing")return b(0,0);if(u.tag==="Just")return u._1;g()})();return{...r,cGraph:Es({master:w("Just",o.id),nodes:[o.id]})(o.graph).graph,nodeToC:tt(S)(i.node)(o.id)(r.nodeToC),lockMap:tt(nt)(o.id)((()=>{const a=s._1-s._2|0;return a<0?{...cn,left:!0}:a>0?{...cn,right:!0}:cn})())(r.lockMap)}})(n)(e),_m=t=>T(e=>n=>bt(S)(r=>i=>b(r._1+i._1|0,r._2+i._2|0))(n.to.node)(b(1,0))(bt(S)(r=>i=>b(r._1+i._1|0,r._2+i._2|0))(n.from.node)(b(0,1))(e)))(A)(t),dm=t=>T(e=>n=>n.origin.tag==="Just"&&n.origin._1.tag==="NodeOrigin"?tt(S)(n.origin._1._1)(n.hitbox.x)(e):e)(A)(xt(e=>Zt(e)(t.cNodes))(t.cNodeOrder)),lm=t=>T(e=>n=>n.origin.tag==="Just"&&n.origin._1.tag==="NodeOrigin"?tt(S)(n.origin._1._1)(n.hitbox.x-n.hitboxPreCompaction.x)(e):e)(A)(xt(e=>Zt(e)(t.cNodes))(t.cNodeOrder)),hm=t=>T(e=>n=>{if(n.origin.tag==="Just"&&n.origin._1.tag==="SegmentOrigin"){const r=n.hitbox.x-n.hitboxPreCompaction.x;return T(i=>o=>tt(xc)(o)(r)(i))(e)(n.origin._1._1.affectedBends)}return e})(A)(xt(e=>Zt(e)(t.cNodes))(t.cNodeOrder)),Sg=t=>{const e=Ps(O(n=>b(n.id,n))(t.edges));return xt(n=>{const r=Mo(n.edge)(e);if(r.tag==="Just")return n.reversed?w("Just",{edgeId:n.edge,src:r._1.to.node,tgt:r._1.from.node,srcSide:zo(An)(t.ports)(r._1.to.node)(r._1.to.port),tgtSide:zo(Fn)(t.ports)(r._1.from.node)(r._1.from.port),path:n}):w("Just",{edgeId:n.edge,src:r._1.from.node,tgt:r._1.to.node,srcSide:zo(An)(t.ports)(r._1.from.node)(r._1.from.port),tgtSide:zo(Fn)(t.ports)(r._1.to.node)(r._1.to.port),path:n});if(r.tag==="Nothing")return J;g()})(t.paths)},pm=t=>e=>{const n=wt(e)(r=>{if(r.src===r.tgt)return[];if((r.srcSide==="North"||r.srcSide==="South")&&(r.tgtSide==="North"||r.tgtSide==="South"))return[];const i=Bn(r.tgt)(t.nodeToC),o=(()=>{if(i.tag==="Just")return Zt(i._1)(t.cGraph.cNodes);if(i.tag==="Nothing")return J;g()})(),u=Bn(r.src)(t.nodeToC),s=(()=>{if(u.tag==="Just")return Zt(u._1)(t.cGraph.cNodes);if(u.tag==="Nothing")return J;g()})(),a=(()=>{if(s.tag==="Just"){if(o.tag==="Just"){if(s._1.cGroup.tag==="Just"){if(o._1.cGroup.tag==="Just")return w("Just",{srcGroup:s._1.cGroup._1,tgtGroup:o._1.cGroup._1,delta:0,weight:100});if(o._1.cGroup.tag==="Nothing")return J;g()}if(s._1.cGroup.tag==="Nothing")return J;g()}if(o.tag==="Nothing")return J;g()}if(s.tag==="Nothing")return J;g()})(),c=_=>h=>p=>{if(s.tag==="Just"){if(s._1.cGroup.tag==="Just"){if(p.cGroup.tag==="Just")return _(p.hitbox.x)&&p.cGroup._1!==s._1.cGroup._1?w("Just",h(p.cGroup._1)(s._1.cGroup._1)):J;if(p.cGroup.tag==="Nothing")return J;g()}if(s._1.cGroup.tag==="Nothing")return J;g()}if(s.tag==="Nothing")return J;g()},f=xt(_=>Zt(_)(t.cGraph.cNodes))((()=>{const _=Mo(r.edgeId)(t.edgeToCs);if(_.tag==="Nothing")return[];if(_.tag==="Just")return _._1;g()})()),d=(()=>{if(s.tag==="Just"&&r.srcSide==="West"){const _=s._1;return xt(c(h=>h<_.hitbox.x)(h=>p=>({srcGroup:h,tgtGroup:p,delta:1,weight:100})))(f)}return[]})(),l=(()=>{if(s.tag==="Just"&&r.tgtSide==="East"){const _=s._1;return xt(c(h=>h>_.hitbox.x)(h=>p=>({srcGroup:p,tgtGroup:h,delta:1,weight:100})))(f)}return[]})();if(a.tag==="Nothing")return[];if(a.tag==="Just")return[a._1,...d,...l];g()});return{sameEdgeVerticalSegments:r=>i=>r.origin.tag==="Just"&&r.origin._1.tag==="SegmentOrigin"&&i.origin.tag==="Just"&&i.origin._1.tag==="SegmentOrigin"&&(()=>{const o=i.origin._1._1;return Oe(u=>Ye(dn)(u)(o.representedEdges),r.origin._1._1.representedEdges)})(),vsLNodePair:r=>i=>r.origin.tag==="Just"&&i.origin.tag==="Just"&&(r.origin._1.tag==="SegmentOrigin"?i.origin._1.tag==="NodeOrigin":r.origin._1.tag==="NodeOrigin"&&i.origin._1.tag==="SegmentOrigin"),edgeLengthEdges:r=>n}},mm=t=>e=>{const n=et(4),r=dm(t),i=lm(t),o=Ps(O(s=>b(s.id,b(s.from.node,s.to.node)))(e.edges)),u=hm(t);return{nodes:O(s=>{const a=Bn(s.node)(r);if(a.tag==="Just")return{...s,position:b(a._1/n,s.position._2)};if(a.tag==="Nothing")return s;g()})(e.nodes),edges:O(s=>{const a=Mo(s.edge)(o),c=(()=>{if(a.tag==="Nothing")return s.segments;if(a.tag==="Just"){const f=Bn(a._1._1)(i),d=(()=>{if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1;g()})(),l=Bn(a._1._2)(i),_=(()=>{if(l.tag==="Nothing")return 0;if(l.tag==="Just")return l._1;g()})();return Bt((()=>{const h=s.reversed?_:d,p=s.reversed?d:_,m=s.segments.length;return y=>x=>{if(x.direction==="V"){const N=(()=>{if(y===0)return h;if(y===(m-1|0))return p;const v=Ds(x.start)(u);if(v.tag==="Nothing")return 0;if(v.tag==="Just")return v._1;g()})();return{...x,start:b(x.start._1+N,x.start._2),end:b(x.end._1+N,x.end._2)}}if(x.direction==="H")return{...x,start:b((()=>{if(y===0)return x.start._1+h;const N=Ds(x.start)(u);if(N.tag==="Nothing")return x.start._1+0;if(N.tag==="Just")return x.start._1+N._1;g()})(),x.start._2),end:b((()=>{if(y===(m-1|0))return x.end._1+p;const N=Ds(x.end)(u);if(N.tag==="Nothing")return x.end._1+0;if(N.tag==="Just")return x.end._1+N._1;g()})(),x.end._2)};g()}})())(s.segments)}g()})();return{...s,segments:c,bends:ve(f=>d=>f.end,c,Lt(1,c.length,c))}})(e.paths)}},ym=t=>e=>n=>r=>i=>o=>{const u=Gs(i.nextId)(o._2.start)(o._2.end)(J)(t.edgeId),s=(()=>{if(o._1===0){if(e.tag==="Nothing")return u;if(e.tag==="Just")return{...u,ignoreSpacing:o._2.end._2<e._1.y?{...u.ignoreSpacing,down:!0}:o._2.end._2>e._1.y+e._1.height?{...u.ignoreSpacing,up:!0}:{...u.ignoreSpacing,up:!0,down:!0}};g()}return u})();return{nextId:i.nextId+1|0,segments:[...i.segments,(()=>{if(o._1===r){if(n.tag==="Nothing")return s;if(n.tag==="Just")return{...s,ignoreSpacing:o._2.start._2<n._1.y?{...s.ignoreSpacing,down:!0}:o._2.start._2>n._1.y+n._1.height?{...s.ignoreSpacing,up:!0}:{...s.ignoreSpacing,up:!0,down:!0}};g()}return s})()]}},Gg=t=>e=>n=>r=>i=>o=>({nextId:o.nextId+1|0,segments:[...o.segments,{...Gs(o.nextId)(r.start)(b(r.start._1,i.down?n.y:n.y+n.height))(w("Just",e))(t.edgeId),aPort:w("Just",{node:t.src,side:i.side}),ignoreSpacing:i.down?{...cn,down:!0}:{...cn,up:!0}}]}),Ho=t=>e=>n=>r=>i=>o=>({nextId:o.nextId+1|0,segments:[...o.segments,{...Gs(o.nextId)(r.end)(b(r.end._1,i.down?n.y:n.y+n.height))(w("Just",e))(t.edgeId),aPort:w("Just",{node:t.tgt,side:i.side}),ignoreSpacing:i.down?{...cn,down:!0}:{...cn,up:!0}}]}),xm=t=>e=>n=>{if(n.src===n.tgt)return e;const r=Bn(n.src)(t.nodeToC),i=Bn(n.tgt)(t.nodeToC),o=(()=>{if(r.tag==="Just"){const f=Zt(r._1)(t.cGraph.cNodes);return f.tag==="Just"?w("Just",f._1.hitbox):J}if(r.tag==="Nothing")return J;g()})(),u=(()=>{if(i.tag==="Just"){const f=Zt(i._1)(t.cGraph.cNodes);return f.tag==="Just"?w("Just",f._1.hitbox):J}if(i.tag==="Nothing")return J;g()})(),s=um(n.path),a=T(ym(n)(o)(u)(s.length-1|0))(e)(Bt(f=>d=>b(f,d))(s));if(0<s.length){const f=(()=>{if(r.tag==="Just"&&o.tag==="Just"){if(n.srcSide==="North")return Gg(n)(r._1)(o._1)(s[0])({side:le,down:!0})(a);if(n.srcSide==="South")return Gg(n)(r._1)(o._1)(s[0])({side:he,down:!1})(a)}return a})(),d=s.length-1|0;if(d>=0&&d<s.length&&i.tag==="Just"&&u.tag==="Just"){if(n.tgtSide==="North")return Ho(n)(i._1)(u._1)(s[d])({side:le,down:!0})(f);if(n.tgtSide==="South")return Ho(n)(i._1)(u._1)(s[d])({side:he,down:!1})(f)}return f}const c=s.length-1|0;if(c>=0&&c<s.length&&i.tag==="Just"&&u.tag==="Just"){if(n.tgtSide==="North")return Ho(n)(i._1)(u._1)(s[c])({side:le,down:!0})(a);if(n.tgtSide==="South")return Ho(n)(i._1)(u._1)(s[c])({side:he,down:!1})(a)}return a},Nm=t=>e=>n=>am(t)(T(xm(n))({nextId:0,segments:[]})(e).segments)(n),Jm=t=>Nm(t.edges)(Sg(t))(fm(_m(t.edges))(t.nodes)(cm())),Qn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Is=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},As=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Tm=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},wm=t=>{const e=t.Eq0();return n=>r=>{const i=s=>{let a=s,c=!0,f;for(;c;){const d=a,l=Qt(_=>J,_=>h=>w("Just",{head:_,tail:h}),d.queue);if(l.tag==="Nothing"){c=!1,f=d;continue}if(l.tag==="Just"){const _=l._1.head;if((p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=!1;continue}if(N.tag==="Node"){const v=t.compare(_)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=!0;continue}}g()}return x})(d.removedNodes)){a={...d,queue:l._1.tail};continue}const h=Kt(p=>!Qn(p.eid)(d.removedEdges)&&(e.eq(p.src)(_)||e.eq(p.tgt)(_)))(r);if(h.tag==="Nothing"){a={...d,queue:l._1.tail};continue}if(h.tag==="Just"){const p=e.eq(h._1.src)(_)?h._1.tgt:h._1.src,m={...d,degree:tt(t)(p)((()=>{const y=(x=>{let N=x,v=!0,k;for(;v;){const L=N;if(L.tag==="Leaf"){v=!1,k=J;continue}if(L.tag==="Node"){const E=t.compare(p)(L._3);if(E==="LT"){N=L._5;continue}if(E==="GT"){N=L._6;continue}if(E==="EQ"){v=!1,k=w("Just",L._4);continue}}g()}return k})(d.degree);if(y.tag==="Nothing")return-1;if(y.tag==="Just")return y._1-1|0;g()})())(d.degree),removedNodes:tt(t)(_)()(d.removedNodes),removedEdges:tt(nt)(h._1.eid)()(d.removedEdges),record:[...d.record,{node:_,neighbour:p,viaSrc:e.eq(h._1.src)(_)}],queue:l._1.tail};if((()=>{const y=(N=>{let v=N,k=!0,L;for(;k;){const E=v;if(E.tag==="Leaf"){k=!1,L=J;continue}if(E.tag==="Node"){const B=t.compare(p)(E._3);if(B==="LT"){v=E._5;continue}if(B==="GT"){v=E._6;continue}if(B==="EQ"){k=!1,L=w("Just",E._4);continue}}g()}return L})(m.degree),x=N=>{let v=N,k=!0,L;for(;k;){const E=v;if(E.tag==="Leaf"){k=!1,L=!1;continue}if(E.tag==="Node"){const B=t.compare(p)(E._3);if(B==="LT"){v=E._5;continue}if(B==="GT"){v=E._6;continue}if(B==="EQ"){k=!1,L=!0;continue}}g()}return L};return(()=>{if(y.tag==="Nothing")return!1;if(y.tag==="Just")return y._1===1;g()})()&&!x(m.removedNodes)})()){a={...m,queue:[...m.queue,p]};continue}a=m;continue}}g()}return f},o=T(s=>a=>bt(t)(se)(a.src)(1)(bt(t)(se)(a.tgt)(1)(s)))(A)(r),u=i({degree:o,removedNodes:A,removedEdges:A,record:[],queue:at(s=>{const a=(c=>{let f=c,d=!0,l;for(;d;){const _=f;if(_.tag==="Leaf"){d=!1,l=J;continue}if(_.tag==="Node"){const h=t.compare(s)(_._3);if(h==="LT"){f=_._5;continue}if(h==="GT"){f=_._6;continue}if(h==="EQ"){d=!1,l=w("Just",_._4);continue}}g()}return l})(o);if(a.tag==="Nothing")return!1;if(a.tag==="Just")return a._1===1;g()},n)});return{coreNodes:at(s=>!(a=>{let c=a,f=!0,d;for(;f;){const l=c;if(l.tag==="Leaf"){f=!1,d=!1;continue}if(l.tag==="Node"){const _=t.compare(s)(l._3);if(_==="LT"){c=l._5;continue}if(_==="GT"){c=l._6;continue}if(_==="EQ"){f=!1,d=!0;continue}}g()}return d})(u.removedNodes),n),coreEdges:at(s=>!Qn(s.eid)(u.removedEdges),r),removed:u.record}}},vm=t=>e=>n=>T(r=>i=>{const o=i.neighbour,u=(()=>{const s=(a=>{let c=a,f=!0,d;for(;f;){const l=c;if(l.tag==="Leaf"){f=!1,d=J;continue}if(l.tag==="Node"){const _=t.compare(o)(l._3);if(_==="LT"){c=l._5;continue}if(_==="GT"){c=l._6;continue}if(_==="EQ"){f=!1,d=w("Just",l._4);continue}}g()}return d})(r);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})();return tt(t)(i.node)(i.viaSrc?u-1|0:u+1|0)(r)})(n)(we(e)),Fs=t=>{const e=t.Eq0();return n=>r=>i=>{const o={...i,treeNode:tt(t)(r)()(i.treeNode)};return T(u=>s=>{if(Qn(s.eid)(u.st.edgeVisited))return u;const a={...u.st,edgeVisited:tt(nt)(s.eid)()(u.st.edgeVisited)},c=e.eq(s.src)((()=>{const f=s.src,d=_=>{let h=_,p=!0,m;for(;p;){const y=h;if(y.tag==="Leaf"){p=!1,m=!1;continue}if(y.tag==="Node"){const x=t.compare(f)(y._3);if(x==="LT"){h=y._5;continue}if(x==="GT"){h=y._6;continue}if(x==="EQ"){p=!1,m=!0;continue}}g()}return m},l=s.tgt;return d(a.treeNode)&&!(_=>{let h=_,p=!0,m;for(;p;){const y=h;if(y.tag==="Leaf"){p=!1,m=!1;continue}if(y.tag==="Node"){const x=t.compare(l)(y._3);if(x==="LT"){h=y._5;continue}if(x==="GT"){h=y._6;continue}if(x==="EQ"){p=!1,m=!0;continue}}g()}return m})(a.treeNode)})()?s.src:(()=>{const f=s.tgt,d=_=>{let h=_,p=!0,m;for(;p;){const y=h;if(y.tag==="Leaf"){p=!1,m=!1;continue}if(y.tag==="Node"){const x=t.compare(f)(y._3);if(x==="LT"){h=y._5;continue}if(x==="GT"){h=y._6;continue}if(x==="EQ"){p=!1,m=!0;continue}}g()}return m},l=s.src;return d(a.treeNode)&&!(_=>{let h=_,p=!0,m;for(;p;){const y=h;if(y.tag==="Leaf"){p=!1,m=!1;continue}if(y.tag==="Node"){const x=t.compare(l)(y._3);if(x==="LT"){h=y._5;continue}if(x==="GT"){h=y._6;continue}if(x==="EQ"){p=!1,m=!0;continue}}g()}return m})(a.treeNode)})()?s.tgt:s.src)?s.tgt:s.src;if(Qn(s.eid)(a.treeEdge)){if((d=>{let l=d,_=!0,h;for(;_;){const p=l;if(p.tag==="Leaf"){_=!1,h=!1;continue}if(p.tag==="Node"){const m=t.compare(c)(p._3);if(m==="LT"){l=p._5;continue}if(m==="GT"){l=p._6;continue}if(m==="EQ"){_=!1,h=!0;continue}}g()}return h})(a.treeNode))return{...u,st:a};const f=Fs(t)(n)(c)(a);return{count:u.count+f.count|0,st:f.st}}if((()=>{const f=l=>{let _=l,h=!0,p;for(;h;){const m=_;if(m.tag==="Leaf"){h=!1,p=!1;continue}if(m.tag==="Node"){const y=t.compare(c)(m._3);if(y==="LT"){_=m._5;continue}if(y==="GT"){_=m._6;continue}if(y==="EQ"){h=!1,p=!0;continue}}g()}return p},d=s.tgt;return!f(a.treeNode)&&(()=>{const l=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(d)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=w("Just",N._4);continue}}g()}return x})(a.layer),_=s.src,h=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(_)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=w("Just",N._4);continue}}g()}return x})(a.layer);if(l.tag==="Nothing"){if(h.tag==="Nothing")return s.delta===0;if(h.tag==="Just")return s.delta===-h._1;g()}if(l.tag==="Just"){if(h.tag==="Nothing")return s.delta===(l._1-0|0);if(h.tag==="Just")return s.delta===(l._1-h._1|0)}g()})()})()){const f=Fs(t)(n)(c)({...a,treeEdge:tt(nt)(s.eid)()(a.treeEdge)});return{count:u.count+f.count|0,st:f.st}}return{...u,st:a}})({count:1,st:o})(at(u=>(e.eq(u.src)(r)||e.eq(u.tgt)(r))&&!Qn(u.eid)(o.edgeVisited),n))}},Wo=t=>e=>n=>r=>{const i=r.src,o=(l=>{let _=l,h=!0,p;for(;h;){const m=_;if(m.tag==="Leaf"){h=!1,p=J;continue}if(m.tag==="Node"){const y=t.compare(i)(m._3);if(y==="LT"){_=m._5;continue}if(y==="GT"){_=m._6;continue}if(y==="EQ"){h=!1,p=w("Just",m._4);continue}}g()}return p})(e.poID),u=(()=>{if(o.tag==="Nothing")return 0;if(o.tag==="Just")return o._1;g()})(),s=r.tgt,a=(l=>{let _=l,h=!0,p;for(;h;){const m=_;if(m.tag==="Leaf"){h=!1,p=J;continue}if(m.tag==="Node"){const y=t.compare(s)(m._3);if(y==="LT"){_=m._5;continue}if(y==="GT"){_=m._6;continue}if(y==="EQ"){h=!1,p=w("Just",m._4);continue}}g()}return p})(e.poID),c=(()=>{if(a.tag==="Nothing")return 0;if(a.tag==="Just")return a._1;g()})(),f=(l=>{let _=l,h=!0,p;for(;h;){const m=_;if(m.tag==="Leaf"){h=!1,p=J;continue}if(m.tag==="Node"){const y=t.compare(n)(m._3);if(y==="LT"){_=m._5;continue}if(y==="GT"){_=m._6;continue}if(y==="EQ"){h=!1,p=w("Just",m._4);continue}}g()}return p})(e.poID),d=(()=>{if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1;g()})();return(()=>{const l=r.src,_=(h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=J;continue}if(x.tag==="Node"){const N=t.compare(l)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=w("Just",x._4);continue}}g()}return y})(e.lowestPoID);return(()=>{if(_.tag==="Nothing")return 0<=d;if(_.tag==="Just")return _._1<=d;g()})()&&(()=>{const h=r.tgt;return d<=u&&(()=>{const p=(m=>{let y=m,x=!0,N;for(;x;){const v=y;if(v.tag==="Leaf"){x=!1,N=J;continue}if(v.tag==="Node"){const k=t.compare(h)(v._3);if(k==="LT"){y=v._5;continue}if(k==="GT"){y=v._6;continue}if(k==="EQ"){x=!1,N=w("Just",v._4);continue}}g()}return N})(e.lowestPoID);return(()=>{if(p.tag==="Nothing")return 0<=d;if(p.tag==="Just")return p._1<=d;g()})()&&d<=c})()})()})()?u>=c:u<c},bm=t=>{const e=te(t)(zt);return n=>({layer:e(O(r=>b(r,0))(n)),treeNode:A,treeEdge:A,poID:A,lowestPoID:A,cutvalue:A,postOrder:1,edgeVisited:A})},km=t=>e=>n=>T(r=>i=>{if((()=>{const f=i.src,d=h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=!1;continue}if(x.tag==="Node"){const N=t.compare(f)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=!0;continue}}g()}return y},l=i.tgt,_=h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=!1;continue}if(x.tag==="Node"){const N=t.compare(l)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=!0;continue}}g()}return y};return d(n.treeNode)===_(n.treeNode)})())return r;const o=i.tgt,u=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(o)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=w("Just",h._4);continue}}g()}return _})(n.layer),s=i.src,a=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(s)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=w("Just",h._4);continue}}g()}return _})(n.layer),c=(()=>{if(u.tag==="Nothing"){if(a.tag==="Nothing")return-i.delta;if(a.tag==="Just")return-a._1-i.delta|0;g()}if(u.tag==="Just"){if(a.tag==="Nothing")return(u._1-0|0)-i.delta|0;if(a.tag==="Just")return(u._1-a._1|0)-i.delta|0}g()})();return c<r.slack?{edge:w("Just",i),slack:c}:r})({edge:J,slack:1e9})(e).edge,Lm=t=>{const e=te(t)(zt);return n=>r=>{const i=T(o=>u=>Is(o)((()=>{const s=(a=>{let c=a,f=!0,d;for(;f;){const l=c;if(l.tag==="Leaf"){f=!1,d=J;continue}if(l.tag==="Node"){const _=t.compare(u)(l._3);if(_==="LT"){c=l._5;continue}if(_==="GT"){c=l._6;continue}if(_==="EQ"){f=!1,d=w("Just",l._4);continue}}g()}return d})(r);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})()))(1e9)(n);return e(O(o=>b(o,(()=>{const u=(s=>{let a=s,c=!0,f;for(;c;){const d=a;if(d.tag==="Leaf"){c=!1,f=J;continue}if(d.tag==="Node"){const l=t.compare(o)(d._3);if(l==="LT"){a=d._5;continue}if(l==="GT"){a=d._6;continue}if(l==="EQ"){c=!1,f=w("Just",d._4);continue}}g()}return f})(r);if(u.tag==="Nothing")return-i;if(u.tag==="Just")return u._1-i|0;g()})()))(n))}},Pg=t=>{const e=t.Eq0();return n=>r=>i=>{const o=T(s=>a=>{const c=Pg(t)(n)(e.eq(a.src)(r)?a.tgt:a.src)({...s.st,edgeVisited:tt(nt)(a.eid)()(s.st.edgeVisited)});return{lowest:Is(s.lowest)(c.lowest),st:c.st}})({lowest:1e9,st:i})(at(s=>Qn(s.eid)(i.treeEdge)&&(e.eq(s.src)(r)||e.eq(s.tgt)(r))&&!Qn(s.eid)(i.edgeVisited),n)),u=Is(o.lowest)(o.st.postOrder);return{lowest:u,st:{...o.st,poID:tt(t)(r)(o.st.postOrder)(o.st.poID),lowestPoID:tt(t)(r)(u)(o.st.lowestPoID),postOrder:o.st.postOrder+1|0}}}},Dg=t=>{const e=Pg(t);return n=>r=>i=>0<n.length?e(r)(n[0])({...i,edgeVisited:A,postOrder:1,poID:A,lowestPoID:A}).st:i},Em=t=>{const e=t.Eq0();return n=>r=>i=>at(o=>Qn(o.eid)(r.treeEdge)&&(e.eq(o.src)(i)||e.eq(o.tgt)(i)),n)},Cm=t=>e=>Kt(n=>{const r=As(n.eid)(e.cutvalue);return Qn(n.eid)(e.treeEdge)&&(()=>{if(r.tag==="Nothing")return!1;if(r.tag==="Just")return r._1<-1e-10;g()})()})(t),Ig=t=>{const e=Fs(t);return n=>r=>i=>{const o=0<n.length?w("Just",n[0]):J;if(o.tag==="Nothing")return i;if(o.tag==="Just"){const u=e(r)(o._1)({...i,edgeVisited:A,treeNode:A,treeEdge:A});if(u.count>=n.length)return u.st;const s=km(t)(r)(u.st);if(s.tag==="Nothing")return u.st;if(s.tag==="Just"){const a=s._1.tgt,c=(h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=J;continue}if(x.tag==="Node"){const N=t.compare(a)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=w("Just",x._4);continue}}g()}return y})(u.st.layer),f=s._1.src,d=(h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=J;continue}if(x.tag==="Node"){const N=t.compare(f)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=w("Just",x._4);continue}}g()}return y})(u.st.layer),l=(()=>{if(c.tag==="Nothing"){if(d.tag==="Nothing")return-s._1.delta;if(d.tag==="Just")return-d._1-s._1.delta|0;g()}if(c.tag==="Just"){if(d.tag==="Nothing")return(c._1-0|0)-s._1.delta|0;if(d.tag==="Just")return(c._1-d._1|0)-s._1.delta|0}g()})(),_=(()=>{const h=s._1.tgt;return(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=!1;continue}if(N.tag==="Node"){const v=t.compare(h)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=!0;continue}}g()}return x})(u.st.treeNode)})()?-l:l;return Ig(t)(n)(r)({...u.st,layer:T(h=>p=>(m=>{let y=m,x=!0,N;for(;x;){const v=y;if(v.tag==="Leaf"){x=!1,N=!1;continue}if(v.tag==="Node"){const k=t.compare(p)(v._3);if(k==="LT"){y=v._5;continue}if(k==="GT"){y=v._6;continue}if(k==="EQ"){x=!1,N=!0;continue}}g()}return N})(u.st.treeNode)?tt(t)(p)((()=>{const m=(y=>{let x=y,N=!0,v;for(;N;){const k=x;if(k.tag==="Leaf"){N=!1,v=J;continue}if(k.tag==="Node"){const L=t.compare(p)(k._3);if(L==="LT"){x=k._5;continue}if(L==="GT"){x=k._6;continue}if(L==="EQ"){N=!1,v=w("Just",k._4);continue}}g()}return v})(u.st.layer);if(m.tag==="Nothing")return 0+_|0;if(m.tag==="Just")return m._1+_|0;g()})())(h):h)(u.st.layer)(n)})}}g()}},Sm=t=>e=>n=>r=>T(i=>o=>{if(Wo(t)(r)(o.src)(n)&&!Wo(t)(r)(o.tgt)(n)){const u=o.tgt,s=(d=>{let l=d,_=!0,h;for(;_;){const p=l;if(p.tag==="Leaf"){_=!1,h=J;continue}if(p.tag==="Node"){const m=t.compare(u)(p._3);if(m==="LT"){l=p._5;continue}if(m==="GT"){l=p._6;continue}if(m==="EQ"){_=!1,h=w("Just",p._4);continue}}g()}return h})(r.layer),a=o.src,c=(d=>{let l=d,_=!0,h;for(;_;){const p=l;if(p.tag==="Leaf"){_=!1,h=J;continue}if(p.tag==="Node"){const m=t.compare(a)(p._3);if(m==="LT"){l=p._5;continue}if(m==="GT"){l=p._6;continue}if(m==="EQ"){_=!1,h=w("Just",p._4);continue}}g()}return h})(r.layer),f=(()=>{if(s.tag==="Nothing"){if(c.tag==="Nothing")return-o.delta;if(c.tag==="Just")return-c._1-o.delta|0;g()}if(s.tag==="Just"){if(c.tag==="Nothing")return(s._1-0|0)-o.delta|0;if(c.tag==="Just")return(s._1-c._1|0)-o.delta|0}g()})();if(f<i.slack)return{edge:w("Just",o),slack:f}}return i})({edge:J,slack:1e9})(e).edge,Gm=t=>{const e=t.Eq0();return n=>r=>i=>o=>{const u=o.tgt,s=o.src;return T(a=>c=>{if((()=>{const f=As(c.eid)(r.cutvalue);if(f.tag==="Just")return!0;if(f.tag==="Nothing")return!1;g()})()){const f=As(c.eid)(r.cutvalue),d=(()=>{if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1;g()})();return e.eq(s)(c.src)||e.eq(u)(c.tgt)?a-(d-c.weight):a+(d-c.weight)}return e.eq(i)(s)?e.eq(c.src)(i)?a+c.weight:a-c.weight:e.eq(c.src)(i)?a-c.weight:a+c.weight})(o.weight)(at(a=>a.eid!==o.eid&&(e.eq(a.src)(i)||e.eq(a.tgt)(i)),n))}},Pm=t=>{const e=Gm(t);return n=>r=>i=>{const o=(u,s,a)=>{const c=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(u)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=w("Just",h._4);continue}}g()}return _})(a);if(c.tag==="Just")return tt(t)(u)(at(f=>f.eid!==s.eid,c._1))(a);if(c.tag==="Nothing")return a;g()};return(u=>s=>{let a=u,c=s,f=!0,d;for(;f;){const l=a,_=c,h=(m=>{let y=m,x=!0,N;for(;x;){const v=y;if(v.tag==="Leaf"){x=!1,N=J;continue}if(v.tag==="Node"){const k=t.compare(_)(v._3);if(k==="LT"){y=v._5;continue}if(k==="GT"){y=v._6;continue}if(k==="EQ"){x=!1,N=w("Just",v._4);continue}}g()}return N})(l.unknown),p=(()=>{if(h.tag==="Nothing")return[];if(h.tag==="Just")return h._1;g()})();if(p.length===1){const m=t.Eq0().eq(p[0].src)(_)?p[0].tgt:p[0].src;a={unknown:o(_,p[0],o(m,p[0],l.unknown)),cutvalue:tt(nt)(p[0].eid)(e(n)(l)(_)(p[0]))(l.cutvalue)},c=m;continue}f=!1,d=l}return d})(r)(i)}},Ag=t=>{const e=t.Eq0(),n=t.Eq0(),r={eq:c=>f=>c.delta===f.delta&&c.eid===f.eid&&n.eq(c.src)(f.src)&&e.eq(c.tgt)(f.tgt)&&c.weight===f.weight},i={compare:c=>f=>{const d=nt.compare(c.delta)(f.delta);if(d==="LT"||d==="GT"||d!=="EQ")return d;const l=nt.compare(c.eid)(f.eid);if(l==="LT"||l==="GT"||l!=="EQ")return l;const _=t.compare(c.src)(f.src);if(_==="LT"||_==="GT"||_!=="EQ")return _;const h=t.compare(c.tgt)(f.tgt);if(h==="LT"||h==="GT"||h!=="EQ")return h;const p=it.compare(c.weight)(f.weight);return p==="LT"||p==="GT"||p!=="EQ"?p:De},Eq0:()=>r},o=T(c=>f=>tt(i)(f)()(c))(A),u=Em(t),s=te(t)(zt),a=Pm(t);return c=>f=>d=>{const l={unknown:s(O(_=>b(_,Ct(Qe.foldr,o(u(f)(d)(_)))))(c)),cutvalue:A};return{...d,cutvalue:T(a(f))(l)(at(_=>{const h=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(_)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=w("Just",N._4);continue}}g()}return x})(l.unknown);if(h.tag==="Nothing")return!1;if(h.tag==="Just")return h._1.length===1;g()},c)).cutvalue}}},Dm=t=>{const e=Dg(t),n=Ag(t);return r=>i=>o=>u=>s=>{const a={...s,treeEdge:tt(nt)(u.eid)()(si(nt)(o.eid)(s.treeEdge))},c=u.tgt,f=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(c)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=w("Just",N._4);continue}}g()}return x})(a.layer),d=u.src,l=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(d)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=w("Just",N._4);continue}}g()}return x})(a.layer),_=(()=>{if(f.tag==="Nothing"){if(l.tag==="Nothing")return-u.delta;if(l.tag==="Just")return-l._1-u.delta|0;g()}if(f.tag==="Just"){if(l.tag==="Nothing")return(f._1-0|0)-u.delta|0;if(l.tag==="Just")return(f._1-l._1|0)-u.delta|0}g()})(),h=Wo(t)(a)(u.tgt)(o)?_:-_;return n(r)(i)(e(r)(i)({...a,layer:T(p=>m=>Wo(t)(a)(m)(o)?p:tt(t)(m)((()=>{const y=(x=>{let N=x,v=!0,k;for(;v;){const L=N;if(L.tag==="Leaf"){v=!1,k=J;continue}if(L.tag==="Node"){const E=t.compare(m)(L._3);if(E==="LT"){N=L._5;continue}if(E==="GT"){N=L._6;continue}if(E==="EQ"){v=!1,k=w("Just",L._4);continue}}g()}return k})(a.layer);if(y.tag==="Nothing")return 0+h|0;if(y.tag==="Just")return y._1+h|0;g()})())(p))(a.layer)(r)}))}},Im=t=>{const e=Dm(t);return n=>r=>i=>o=>(u=>s=>{let a=u,c=s,f=!0,d;for(;f;){const l=a,_=c;if(l===0){f=!1,d=_;continue}const h=Cm(i)(_);if(h.tag==="Nothing"){f=!1,d=_;continue}if(h.tag==="Just"){const p=Sm(t)(i)(h._1)(_);if(p.tag==="Nothing"){f=!1,d=_;continue}if(p.tag==="Just"){a=l-1|0,c=e(r)(i)(h._1)(p._1)(_);continue}}g()}return d})(n)(o)},Am=t=>{const e=Ag(t),n=Dg(t),r=Ig(t);return i=>o=>u=>e(i)(o)(n(i)(o)(r(i)(o)(u)))},Fg=t=>e=>T(n=>r=>bt(t)(re)(e(r))([r])(n))(A),Fm=t=>{const e=te(t)(zt);return n=>r=>i=>{const o=a=>c=>f=>d=>{let l=a,_=c,h=f,p=d,m=!0,y;for(;m;){const x=l,N=_,v=h,k=p,L=Qt(E=>J,E=>B=>w("Just",{head:E,tail:B}),v);if(L.tag==="Nothing"){m=!1,y=k;continue}if(L.tag==="Just"){const E=L._1.head,B=(G=>{let P=G,V=!0,U;for(;V;){const M=P;if(M.tag==="Leaf"){V=!1,U=J;continue}if(M.tag==="Node"){const H=t.compare(E)(M._3);if(H==="LT"){P=M._5;continue}if(H==="GT"){P=M._6;continue}if(H==="EQ"){V=!1,U=w("Just",M._4);continue}}g()}return U})(k.layer),q=(()=>{if(B.tag==="Nothing")return 0;if(B.tag==="Just")return B._1;g()})(),j=T(G=>P=>{const V=P.tgt,U=(H=>{let R=H,C=!0,D;for(;C;){const F=R;if(F.tag==="Leaf"){C=!1,D=J;continue}if(F.tag==="Node"){const I=t.compare(V)(F._3);if(I==="LT"){R=F._5;continue}if(I==="GT"){R=F._6;continue}if(I==="EQ"){C=!1,D=w("Just",F._4);continue}}g()}return D})(G.incident),M=(()=>{if(U.tag==="Nothing")return-1;if(U.tag==="Just")return U._1-1|0;g()})();return{st:{...G.st,layer:tt(t)(P.tgt)(Tm((()=>{const H=P.tgt,R=(C=>{let D=C,F=!0,I;for(;F;){const z=D;if(z.tag==="Leaf"){F=!1,I=J;continue}if(z.tag==="Node"){const $=t.compare(H)(z._3);if($==="LT"){D=z._5;continue}if($==="GT"){D=z._6;continue}if($==="EQ"){F=!1,I=w("Just",z._4);continue}}g()}return I})(G.st.layer);if(R.tag==="Nothing")return 0;if(R.tag==="Just")return R._1;g()})())(q+P.delta|0))(G.st.layer)},incident:tt(t)(P.tgt)(M)(G.incident),queue:M===0?[...G.queue,P.tgt]:G.queue}})({st:k,incident:N,queue:L._1.tail})((()=>{const G=(P=>{let V=P,U=!0,M;for(;U;){const H=V;if(H.tag==="Leaf"){U=!1,M=J;continue}if(H.tag==="Node"){const R=t.compare(E)(H._3);if(R==="LT"){V=H._5;continue}if(R==="GT"){V=H._6;continue}if(R==="EQ"){U=!1,M=w("Just",H._4);continue}}g()}return M})(x);if(G.tag==="Nothing")return[];if(G.tag==="Just")return G._1;g()})());l=x,_=j.incident,h=j.queue,p=j.st;continue}g()}return y},u=Fg(t)(a=>a.tgt)(r),s=e(O(a=>b(a,(()=>{const c=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(a)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=w("Just",h._4);continue}}g()}return _})(u);if(c.tag==="Nothing")return 0;if(c.tag==="Just")return c._1.length;g()})()))(n));return o(Fg(t)(a=>a.src)(r))(s)(at(a=>{const c=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(a)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=w("Just",h._4);continue}}g()}return _})(s);if(c.tag==="Nothing")return!0;if(c.tag==="Just")return c._1===0;g()},n))(i)}},Bm=t=>{const e=bm(t),n=Fm(t),r=Am(t),i=Im(t);return o=>u=>{const s=n(o)(u)(e(o));return u.length===0?s.layer:i(4*o.length|0)(o)(u)(r(o)(u)(s)).layer}},Bg=t=>{const e=Lm(t),n=Bm(t),r=wm(t);return i=>o=>{if(i.length===0)return A;if(i.length<40)return e(i)(n(i)(o));const u=r(i)(o);return e(i)(vm(t)(u.removed)(n(u.coreNodes)(u.coreEdges)))}},Qg=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Bs=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Qm=Bg(nt),Pi=t=>e=>({...e,edges:[...e.edges,{src:t.src,tgt:t.tgt,delta:t.delta,weight:t.weight,eid:e.nextEid}],nextEid:e.nextEid+1|0}),Rm=t=>e=>n=>{if(n.cGroup.tag==="Nothing")return e;if(n.cGroup.tag==="Just"){const r=et((()=>{const i=Qg(n.cGroup._1)(t);if(i.tag==="Nothing")return 0;if(i.tag==="Just")return i._1;g()})());return Ze(n.id)(i=>({...i,hitbox:{...i.hitbox,x:r+i.cGroupOffset.x}}))(e)}g()},Mm=t=>e=>({...e,cGraph:T(Rm(t))(e.cGraph)((()=>{const n=e.cGraph;return xt(r=>Zt(r)(n.cNodes))(n.cNodeOrder)})())}),zm=t=>e=>n=>r=>i=>{const o=ce(io(e.cGroupOffset.x-t.cGroupOffset.x));return Pi({src:i.nextNodeId,tgt:r,delta:Bs(0)(-o),weight:1})(Pi({src:i.nextNodeId,tgt:n,delta:Bs(0)(o),weight:1})({...i,nodes:[...i.nodes,i.nextNodeId],nextNodeId:i.nextNodeId+1|0}))},Hm=t=>e=>n=>r=>i=>o=>u=>{const s=Bs(0)(ce(io(n.cGroupOffset.x+n.hitbox.width+(e.direction==="LEFT"||e.direction==="RIGHT"?e.spacingsHandler.horizontalSpacing(n)(r):e.spacingsHandler.verticalSpacing(n)(r))-r.cGroupOffset.x)));return t.sameEdgeVerticalSegments(n)(r)?zm(n)(r)(i)(o)(u):Pi({src:i,tgt:o,delta:s,weight:t.vsLNodePair(n)(r)?2:1})(u)},Wm=t=>e=>n=>r=>i=>{const o=Zt(i)(e.cGraph.cNodes);if(o.tag==="Nothing")return r;if(o.tag==="Just")return(n.cGroup.tag==="Nothing"?o._1.cGroup.tag==="Nothing":n.cGroup.tag==="Just"&&o._1.cGroup.tag==="Just"&&n.cGroup._1===o._1.cGroup._1)?r:n.cGroup.tag==="Just"&&o._1.cGroup.tag==="Just"?Hm(t)(e)(n)(o._1)(n.cGroup._1)(o._1.cGroup._1)(r):r;g()},Om=t=>e=>n=>r=>T(Wm(t)(e)(r))(n)(r.constraints),Ym=t=>e=>Pi({src:e.srcGroup,tgt:e.tgtGroup,delta:e.delta,weight:e.weight})(t),$m=t=>{const e=T(i=>o=>bt(nt)(se)(o.tgt)(1)(i))(A)(t.edges),n=at(i=>{const o=Qg(i)(e);if(o.tag==="Nothing")return!0;if(o.tag==="Just")return o._1===0;g()},t.nodes);if(n.length<=1)return t;const r=t.nextNodeId;return T(i=>o=>Pi({src:r,tgt:o,delta:1,weight:0})(i))({...t,nodes:[...t.nodes,r],nextNodeId:r+1|0})(n)},qm=t=>e=>{const n=$m(T(Ym)(T(Om(t)(e))({nodes:e.cGraph.cGroupOrder,edges:[],nextNodeId:e.cGraph.nextCGroupId,nextEid:0})((()=>{const r=e.cGraph;return xt(i=>Zt(i)(r.cNodes))(r.cNodeOrder)})()))(t.edgeLengthEdges(e.cGraph)));return{nodes:n.nodes,edges:n.edges}},Xm=t=>e=>{const n=qm(t)(e);return Mm(Qm(n.nodes)(n.edges))(e)},Rg=t=>t,ie=Rg("H"),oe=Rg("V"),Vm=t=>b(t._2,t._1),Mg=t=>({...t,position:b(t.position._2,t.position._1),size:b(t.size._2,t.size._1)}),Um=t=>({start:b(t.start._2,t.start._1),end:b(t.end._2,t.end._1),direction:(()=>{if(t.direction==="H")return oe;if(t.direction==="V")return ie;g()})()}),zg=t=>({...t,segments:O(Um)(t.segments),bends:O(Vm)(t.bends)}),Km=t=>({nodes:O(Mg)(t.nodes),edges:t.edges,paths:O(zg)(t.paths),ports:t.ports}),Zm={nodeNode:8,edgeNode:4,edgeEdge:10},jm=t=>e=>({horizontalSpacing:n=>r=>{if(e.sameEdgeVerticalSegments(n)(r)||n.ignoreSpacing.right||r.ignoreSpacing.left)return 0;const i=r.kind.tag==="Nothing"?!1:r.kind.tag==="Just"&&r.kind._1==="vs";return n.kind.tag!=="Nothing"&&n.kind.tag==="Just"&&n.kind._1==="vs"?i?t.edgeEdge:t.edgeNode:i?t.edgeNode:t.nodeNode},verticalSpacing:n=>r=>{if(e.sameEdgeVerticalSegments(n)(r))return 1;if(n.hitbox.y<=r.hitbox.y?n.ignoreSpacing.down||r.ignoreSpacing.up:n.ignoreSpacing.up||r.ignoreSpacing.down)return 0;const i=r.kind.tag==="Nothing"?!1:r.kind.tag==="Just"&&r.kind._1==="vs";return n.kind.tag!=="Nothing"&&n.kind.tag==="Just"&&n.kind._1==="vs"?i?t.edgeEdge:t.edgeNode:i?t.edgeNode:t.nodeNode}}),ty=t=>e=>Xm(e),ey=t=>e=>n=>{const r=Km(n),i=Jm(r),o=pm(i)(Sg(r)),u=mm(yg(ks)(Mp({...Hp(i.cGraph),compactionAlgorithm:w("Just",ty()(o)),constraintAlgorithm:w("Just",tm(e.edgeEdge)),spacingsHandler:jm(e)(o)})).cGraph)({nodes:r.nodes,edges:r.edges,paths:r.paths});return{nodes:O(Mg)(u.nodes),edges:O(zg)(u.edges)}},Hg=t=>t,zr=te(nt)(zt),It=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Wg=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},lt=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},ht=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Hr=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},ny=t=>e=>{const n=nt.compare(t._1)(e._1);return n==="LT"?Je:n==="GT"?Te:nt.compare(t._2)(e._2)},Wr=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},ry=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),iy=t=>t,Og=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},oy=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Oo=Hg("Regular"),Yo=Hg("Critical"),Yg=t=>e=>{const n=T(u=>s=>tt(S)(s.node)(s)(u))(A)(e),r=1.25*et(4),i=(u,s,a)=>(c=>f=>d=>{let l=c,_=f,h=d,p=!0,m;for(;p;){const y=l,x=_,N=h;if(N.critical){p=!1,m=N;continue}const v=Qt(L=>J,L=>E=>w("Just",{head:L,tail:E}),y),k=Qt(L=>J,L=>E=>w("Just",{head:L,tail:E}),x);if(v.tag==="Just"&&k.tag==="Just"){const L=v._1.head>k._1.head-u&&v._1.head<k._1.head+u?{...N,critical:!0}:v._1.head>k._1.head-r&&v._1.head<k._1.head+r?{...N,conflicts:N.conflicts+1|0}:N;if(L.critical){p=!1,m=L;continue}if(v._1.head<=k._1.head){l=v._1.tail,_=x,h=L;continue}l=y,_=k._1.tail,h=L;continue}p=!1,m=N}return m})(s)(a)({conflicts:0,critical:!1}),o=(u,s,a)=>{if(ht(T(ht)(-1e18)(s.incoming))(T(ht)(-1e18)(s.outgoing))-lt(T(lt)(1e18)(s.incoming))(T(lt)(1e18)(s.outgoing))<.001||ht(T(ht)(-1e18)(a.incoming))(T(ht)(-1e18)(a.outgoing))-lt(T(lt)(1e18)(a.incoming))(T(lt)(1e18)(a.outgoing))<.001)return[];const c=i(u,s.outgoing,a.incoming),f=i(u,a.outgoing,s.incoming);if(c.critical||f.critical)return[...c.critical?[{src:a.id,tgt:s.id,weight:1,kind:Yo}]:[],...f.critical?[{src:s.id,tgt:a.id,weight:1,kind:Yo}]:[]];const d=lt(T(lt)(1e18)(s.incoming))(T(lt)(1e18)(s.outgoing)),l=ht(T(ht)(-1e18)(s.incoming))(T(ht)(-1e18)(s.outgoing)),_=lt(T(lt)(1e18)(a.incoming))(T(lt)(1e18)(a.outgoing)),h=ht(T(ht)(-1e18)(a.incoming))(T(ht)(-1e18)(a.outgoing)),p=(1*c.conflicts|0)+(16*(T(y=>x=>x>h?y:x>=_?y+1|0:y)(0)(s.outgoing)+T(y=>x=>x>l?y:x>=d?y+1|0:y)(0)(a.incoming)|0)|0)|0,m=(1*f.conflicts|0)+(16*(T(y=>x=>x>l?y:x>=d?y+1|0:y)(0)(a.outgoing)+T(y=>x=>x>h?y:x>=_?y+1|0:y)(0)(s.incoming)|0)|0)|0;return p<m?[{src:s.id,tgt:a.id,weight:m-p|0,kind:Oo}]:p>m?[{src:a.id,tgt:s.id,weight:p-m|0,kind:Oo}]:p>0?[{src:s.id,tgt:a.id,weight:0,kind:Oo},{src:a.id,tgt:s.id,weight:0,kind:Oo}]:[]};return T(u=>s=>T(a=>c=>tt(S)(c._1)(c._2)(a))(u)((()=>{const a=T(G=>P=>{const V=P.edge.from.node+"|"+(()=>{if(P.edge.from.port.tag==="Just")return P.edge.from.port._1;if(P.edge.from.port.tag==="Nothing")return"_auto_"+P.edge.id;g()})(),U=Og(V)(G.entries);if(U.tag==="Nothing")return{...G,entries:tt(S)(V)({id:0,members:[P.edge.id],incoming:[P.fromPos._1],outgoing:[P.toPos._1],slot:0,mark:0,splitBy:J,splitPartner:J})(G.entries),order:[...G.order,V]};if(U.tag==="Just")return{...G,entries:tt(S)(V)({...U._1,members:[...U._1.members,P.edge.id],incoming:[..._r(M=>M<P.fromPos._1)(U._1.incoming).init,P.fromPos._1,..._r(M=>M<=P.fromPos._1)(U._1.incoming).rest],outgoing:[..._r(M=>M<P.toPos._1)(U._1.outgoing).init,P.toPos._1,..._r(M=>M<=P.toPos._1)(U._1.outgoing).rest]})(G.entries)};g()})({entries:A,order:[]})(s._2),c=Bt(G=>P=>({...P,id:G}))(xt(G=>Og(G)(a.entries))(a.order));if(c.length===0)return[];const f=T(G=>P=>G.prev.tag==="Just"&&P-G.prev._1<1e-9?G:{prev:w("Just",P),out:[...G.out,P]})({prev:J,out:[]})(Et(it.compare)([...wt(c)(G=>G.incoming),...wt(c)(G=>G.outgoing)])).out,d=f.length<2?.2*r:.2*T(G=>P=>{if(G.prev.tag==="Nothing")return{prev:w("Just",P),mn:G.mn};if(G.prev.tag==="Just")return{prev:w("Just",P),mn:lt(G.mn)(P-G.prev._1)};g()})({prev:J,mn:1e18})(f).mn,l={segments:c,deps:(()=>{const G=c.length;return wt(wt(Ft(0,G-2|0))(P=>wt(Ft(P+1|0,G-1|0))(V=>[b(P,V)])))(P=>P._1>=0&&P._1<c.length?P._2>=0&&P._2<c.length?o(d,c[P._1],c[P._2]):[]:[])})()},_=at(G=>{if(G.kind==="Critical")return!0;if(G.kind==="Regular")return!1;g()},l.deps),h=(()=>{if(_.length<2)return l;const G=zr((()=>{const H=l.segments;return O(R=>b(R.id,R.mark))((()=>{const R=H.length,C=F=>{let I=F,z=!0,$;for(;z;){const X=I,Y=Kt(W=>{const K=It(W)(X.inWeight);if(K.tag==="Nothing")return!0;if(K.tag==="Just")return K._1===0;g()})(X.remaining);if(Y.tag==="Nothing"){z=!1,$=X;continue}if(Y.tag==="Just"){const W=Y._1;I={...X,inWeight:T(K=>Z=>bt(nt)(se)(Z.tgt)(-Z.weight)(K))(X.inWeight)((()=>{const K=It(W)(X.depsBySrc);if(K.tag==="Nothing")return[];if(K.tag==="Just")return K._1;g()})()),marks:tt(nt)(W)(X.nextSource)(X.marks),nextSource:X.nextSource+1|0,outWeight:T(K=>Z=>bt(nt)(se)(Z.src)(-Z.weight)(K))(X.outWeight)((()=>{const K=It(W)(X.depsByTgt);if(K.tag==="Nothing")return[];if(K.tag==="Just")return K._1;g()})()),remaining:at(K=>K!==W,X.remaining)};continue}g()}return $},D=F=>{let I=F,z=!0,$;for(;z;){const X=I,Y=Kt(W=>{const K=It(W)(X.outWeight);if(K.tag==="Nothing")return!0;if(K.tag==="Just")return K._1===0;g()})(X.remaining);if(Y.tag==="Nothing"){z=!1,$=X;continue}if(Y.tag==="Just"){const W=Y._1;I={...X,inWeight:T(K=>Z=>bt(nt)(se)(Z.tgt)(-Z.weight)(K))(X.inWeight)((()=>{const K=It(W)(X.depsBySrc);if(K.tag==="Nothing")return[];if(K.tag==="Just")return K._1;g()})()),marks:tt(nt)(W)(X.nextSink)(X.marks),nextSink:X.nextSink-1|0,outWeight:T(K=>Z=>bt(nt)(se)(Z.src)(-Z.weight)(K))(X.outWeight)((()=>{const K=It(W)(X.depsByTgt);if(K.tag==="Nothing")return[];if(K.tag==="Just")return K._1;g()})()),remaining:at(K=>K!==W,X.remaining)};continue}g()}return $};return(F=>{let I=F,z=!0,$;for(;z;){const X=C(D(I));if(X.remaining.length===0){z=!1,$=O(Y=>{const W=It(Y.id)(X.marks),K=(()=>{if(W.tag==="Nothing")return Y.id;if(W.tag==="Just")return W._1;g()})();return{...Y,mark:K<R?(K+R|0)+1|0:K}})(H);continue}I=(()=>{const Y=K=>{const Z=It(K)(X.outWeight),ct=It(K)(X.inWeight);return(()=>{if(Z.tag==="Nothing")return 0;if(Z.tag==="Just")return Z._1;g()})()-(()=>{if(ct.tag==="Nothing")return 0;if(ct.tag==="Just")return ct._1;g()})()|0},W=Et(K=>Z=>nt.compare(Y(Z))(Y(K)))(X.remaining);if(0<W.length){const K=W[0];return{...X,inWeight:T(Z=>ct=>bt(nt)(se)(ct.tgt)(-ct.weight)(Z))(X.inWeight)((()=>{const Z=It(K)(X.depsBySrc);if(Z.tag==="Nothing")return[];if(Z.tag==="Just")return Z._1;g()})()),marks:tt(nt)(K)(X.nextSource)(X.marks),nextSource:X.nextSource+1|0,outWeight:T(Z=>ct=>bt(nt)(se)(ct.src)(-ct.weight)(Z))(X.outWeight)((()=>{const Z=It(K)(X.depsByTgt);if(Z.tag==="Nothing")return[];if(Z.tag==="Just")return Z._1;g()})()),remaining:at(Z=>Z!==K,X.remaining)}}return X})()}return $})({remaining:O(F=>F.id)(H),marks:A,inWeight:T(F=>I=>bt(nt)(se)(I.tgt)(I.weight)(F))(A)(_),outWeight:T(F=>I=>bt(nt)(se)(I.src)(I.weight)(F))(A)(_),depsBySrc:T(F=>I=>bt(nt)(re)(I.src)([I])(F))(A)(_),depsByTgt:T(F=>I=>bt(nt)(re)(I.tgt)([I])(F))(A)(_),nextSink:R-1|0,nextSource:R+1|0})})())})()),P=at(H=>{const R=It(H.src)(G),C=It(H.tgt)(G);return(()=>{if(R.tag==="Nothing")return 0;if(R.tag==="Just")return R._1;g()})()>(()=>{if(C.tag==="Nothing")return 0;if(C.tag==="Just")return C._1;g()})()},_);if(P.length===0)return l;const V=T(H=>R=>{if(Ye(Er)(R.src)(H.decisions)||Ye(Er)(R.tgt)(H.decisions))return H;const C=It(R.src)(H.segMap),D=It(R.tgt)(H.segMap);if(C.tag==="Just"&&D.tag==="Just"){const F=(C._1.incoming.length+C._1.outgoing.length|0)>2&&(D._1.incoming.length+D._1.outgoing.length|0)<=2,I=F?D._1:C._1;return{decisions:[...H.decisions,I.id],segMap:tt(nt)(I.id)({...I,splitBy:w("Just",F?C._1.id:D._1.id)})(H.segMap)}}return H})({decisions:[],segMap:zr(O(H=>b(H.id,H))(l.segments))})(P),U=V.segMap,M=T(H=>R=>{const C=lt(T(lt)(1e18)(R.incoming))(T(lt)(1e18)(R.outgoing)),D=ht(T(ht)(-1e18)(R.incoming))(T(ht)(-1e18)(R.outgoing)),F=at(Y=>Y.a.startPosition<=D&&Y.a.endPosition>=C,Bt(Y=>W=>({i:Y,a:W}))(H.freeAreas));if(F.length===0){const Y={...R,incoming:Et(it.compare)(R.incoming),outgoing:Et(it.compare)([(C+D)/2]),splitPartner:w("Just",H.nextId)},W={id:H.nextId,incoming:Et(it.compare)([(C+D)/2]),mark:0,members:R.members,outgoing:Et(it.compare)(R.outgoing),slot:0,splitBy:J,splitPartner:w("Just",R.id)};return{segMap:tt(nt)(W.id)(W)(tt(nt)(Y.id)(Y)(H.segMap)),freeAreas:H.freeAreas,nextId:H.nextId+1|0}}const I=0<F.length?w("Just",F[0]):J,z=(()=>{if(I.tag==="Nothing")return{i:0,a:{startPosition:0,endPosition:0,size:0}};if(I.tag==="Just"){if(F.length===1)return I._1;const Y=O(W=>({c:W,rating:(()=>{const K=(W.a.startPosition+W.a.endPosition)/2,Z=[K],ct=[K],_t=T((()=>{const yt=H.segMap;return St=>Ht=>{const pt=It(Ht.tgt)(yt);if(pt.tag==="Nothing")return St;if(pt.tag==="Just"){const Wt=lt(T(lt)(1e18)(pt._1.incoming))(T(lt)(1e18)(pt._1.outgoing)),Tt=ht(T(ht)(-1e18)(pt._1.incoming))(T(ht)(-1e18)(pt._1.outgoing)),mt=lt(T(lt)(1e18)(R.incoming))(T(lt)(1e18)(Z)),ft=(()=>{const Pt=ht(T(ht)(-1e18)(R.incoming))(T(ht)(-1e18)(Z)),At=T(qt=>de=>de>Tt?qt:de>=Wt?qt+1|0:qt)(0)(Z)+T(qt=>de=>de>Pt?qt:de>=mt?qt+1|0:qt)(0)(pt._1.incoming)|0,Be=lt(T(lt)(1e18)(R.incoming))(T(lt)(1e18)(Z)),an=ht(T(ht)(-1e18)(R.incoming))(T(ht)(-1e18)(Z)),Xe=lt(T(lt)(1e18)(pt._1.incoming))(T(lt)(1e18)(pt._1.outgoing)),nn=ht(T(ht)(-1e18)(pt._1.incoming))(T(ht)(-1e18)(pt._1.outgoing)),Pe=T(qt=>de=>de>an?qt:de>=Be?qt+1|0:qt)(0)(pt._1.outgoing)+T(qt=>de=>de>nn?qt:de>=Xe?qt+1|0:qt)(0)(R.incoming)|0;return At===Pe?At>0?{...St,deps:St.deps+2|0,crossings:St.crossings+At|0}:St:{...St,deps:St.deps+1|0,crossings:St.crossings+Wr(At)(Pe)|0}})(),ot=lt(T(lt)(1e18)(pt._1.incoming))(T(lt)(1e18)(pt._1.outgoing)),dt=ht(T(ht)(-1e18)(pt._1.incoming))(T(ht)(-1e18)(pt._1.outgoing)),ut=lt(T(lt)(1e18)(ct))(T(lt)(1e18)(R.outgoing)),st=ht(T(ht)(-1e18)(ct))(T(ht)(-1e18)(R.outgoing)),Nt=T(Pt=>At=>At>dt?Pt:At>=ot?Pt+1|0:Pt)(0)(R.outgoing)+T(Pt=>At=>At>st?Pt:At>=ut?Pt+1|0:Pt)(0)(pt._1.incoming)|0,Jt=lt(T(lt)(1e18)(ct))(T(lt)(1e18)(R.outgoing)),kt=ht(T(ht)(-1e18)(ct))(T(ht)(-1e18)(R.outgoing)),Ot=lt(T(lt)(1e18)(pt._1.incoming))(T(lt)(1e18)(pt._1.outgoing)),_n=ht(T(ht)(-1e18)(pt._1.incoming))(T(ht)(-1e18)(pt._1.outgoing)),Fe=T(Pt=>At=>At>kt?Pt:At>=Jt?Pt+1|0:Pt)(0)(pt._1.outgoing)+T(Pt=>At=>At>_n?Pt:At>=Ot?Pt+1|0:Pt)(0)(ct)|0;return Nt===Fe?Nt>0?{...ft,deps:ft.deps+2|0,crossings:ft.crossings+Nt|0}:ft:{...ft,deps:ft.deps+1|0,crossings:ft.crossings+Wr(Nt)(Fe)|0}}g()}})())(T((()=>{const yt=H.segMap;return St=>Ht=>{const pt=It(Ht.src)(yt);if(pt.tag==="Nothing")return St;if(pt.tag==="Just"){const Wt=lt(T(lt)(1e18)(pt._1.incoming))(T(lt)(1e18)(pt._1.outgoing)),Tt=ht(T(ht)(-1e18)(pt._1.incoming))(T(ht)(-1e18)(pt._1.outgoing)),mt=lt(T(lt)(1e18)(R.incoming))(T(lt)(1e18)(Z)),ft=(()=>{const Pt=ht(T(ht)(-1e18)(R.incoming))(T(ht)(-1e18)(Z)),At=T(qt=>de=>de>Tt?qt:de>=Wt?qt+1|0:qt)(0)(Z)+T(qt=>de=>de>Pt?qt:de>=mt?qt+1|0:qt)(0)(pt._1.incoming)|0,Be=lt(T(lt)(1e18)(R.incoming))(T(lt)(1e18)(Z)),an=ht(T(ht)(-1e18)(R.incoming))(T(ht)(-1e18)(Z)),Xe=lt(T(lt)(1e18)(pt._1.incoming))(T(lt)(1e18)(pt._1.outgoing)),nn=ht(T(ht)(-1e18)(pt._1.incoming))(T(ht)(-1e18)(pt._1.outgoing)),Pe=T(qt=>de=>de>an?qt:de>=Be?qt+1|0:qt)(0)(pt._1.outgoing)+T(qt=>de=>de>nn?qt:de>=Xe?qt+1|0:qt)(0)(R.incoming)|0;return At===Pe?At>0?{...St,deps:St.deps+2|0,crossings:St.crossings+At|0}:St:{...St,deps:St.deps+1|0,crossings:St.crossings+Wr(At)(Pe)|0}})(),ot=lt(T(lt)(1e18)(pt._1.incoming))(T(lt)(1e18)(pt._1.outgoing)),dt=ht(T(ht)(-1e18)(pt._1.incoming))(T(ht)(-1e18)(pt._1.outgoing)),ut=lt(T(lt)(1e18)(ct))(T(lt)(1e18)(R.outgoing)),st=ht(T(ht)(-1e18)(ct))(T(ht)(-1e18)(R.outgoing)),Nt=T(Pt=>At=>At>dt?Pt:At>=ot?Pt+1|0:Pt)(0)(R.outgoing)+T(Pt=>At=>At>st?Pt:At>=ut?Pt+1|0:Pt)(0)(pt._1.incoming)|0,Jt=lt(T(lt)(1e18)(ct))(T(lt)(1e18)(R.outgoing)),kt=ht(T(ht)(-1e18)(ct))(T(ht)(-1e18)(R.outgoing)),Ot=lt(T(lt)(1e18)(pt._1.incoming))(T(lt)(1e18)(pt._1.outgoing)),_n=ht(T(ht)(-1e18)(pt._1.incoming))(T(ht)(-1e18)(pt._1.outgoing)),Fe=T(Pt=>At=>At>kt?Pt:At>=Jt?Pt+1|0:Pt)(0)(pt._1.outgoing)+T(Pt=>At=>At>_n?Pt:At>=Ot?Pt+1|0:Pt)(0)(ct)|0;return Nt===Fe?Nt>0?{...ft,deps:ft.deps+2|0,crossings:ft.crossings+Nt|0}:ft:{...ft,deps:ft.deps+1|0,crossings:ft.crossings+Wr(Nt)(Fe)|0}}g()}})())({crossings:0,deps:0})(at(yt=>yt.tgt===R.id,l.deps)))(at(yt=>yt.src===R.id,l.deps)),gt=(()=>{if(R.splitBy.tag==="Just")return It(R.splitBy._1)(H.segMap);if(R.splitBy.tag==="Nothing")return J;g()})();if(gt.tag==="Just")return{..._t,deps:_t.deps+2|0,crossings:(()=>{const yt=lt(T(lt)(1e18)(gt._1.incoming))(T(lt)(1e18)(gt._1.outgoing)),St=lt(T(lt)(1e18)(ct))(T(lt)(1e18)(R.outgoing)),Ht=ht(T(ht)(-1e18)(gt._1.incoming))(T(ht)(-1e18)(gt._1.outgoing)),pt=ht(T(ht)(-1e18)(ct))(T(ht)(-1e18)(R.outgoing)),Wt=lt(T(lt)(1e18)(R.incoming))(T(lt)(1e18)(Z));return _t.crossings+(()=>{const Tt=lt(T(lt)(1e18)(gt._1.incoming))(T(lt)(1e18)(gt._1.outgoing)),mt=ht(T(ht)(-1e18)(R.incoming))(T(ht)(-1e18)(Z)),ft=ht(T(ht)(-1e18)(gt._1.incoming))(T(ht)(-1e18)(gt._1.outgoing));return((T(ot=>dt=>dt>Ht?ot:dt>=yt?ot+1|0:ot)(0)(Z)+T(ot=>dt=>dt>mt?ot:dt>=Wt?ot+1|0:ot)(0)(gt._1.incoming)|0)+T(ot=>dt=>dt>pt?ot:dt>=St?ot+1|0:ot)(0)(gt._1.outgoing)|0)+T(ot=>dt=>dt>ft?ot:dt>=Tt?ot+1|0:ot)(0)(ct)|0})()|0})()};if(gt.tag==="Nothing")return _t;g()})()}))(F);return T(W=>K=>K.rating.crossings<W.rating.crossings||!(K.rating.crossings>W.rating.crossings)&&(K.rating.deps<W.rating.deps||!(K.rating.deps>W.rating.deps)&&K.c.a.size>W.c.a.size)?K:W)(0<Y.length?Y[0]:{c:I._1,rating:{crossings:1e6,deps:1e6}})(Y).c}g()})(),$={...R,incoming:Et(it.compare)(R.incoming),outgoing:Et(it.compare)([(z.a.startPosition+z.a.endPosition)/2]),splitPartner:w("Just",H.nextId)},X={id:H.nextId,incoming:Et(it.compare)([(z.a.startPosition+z.a.endPosition)/2]),mark:0,members:R.members,outgoing:Et(it.compare)(R.outgoing),slot:0,splitBy:J,splitPartner:w("Just",R.id)};return{segMap:tt(nt)(X.id)(X)(tt(nt)($.id)($)(H.segMap)),freeAreas:(()=>{if(z.i>=0&&z.i<H.freeAreas.length){const Y=Za(Ut,J,z.i,H.freeAreas),W=(()=>{if(Y.tag==="Nothing")return H.freeAreas;if(Y.tag==="Just")return Y._1;g()})();if(H.freeAreas[z.i].size/2<d)return W;const K=(H.freeAreas[z.i].startPosition+H.freeAreas[z.i].endPosition)/2,Z=K-d,ct=K+d;return[...z.i<1?[]:Lt(0,z.i,W),...H.freeAreas[z.i].startPosition<=Z?[{startPosition:H.freeAreas[z.i].startPosition,endPosition:Z,size:Z-H.freeAreas[z.i].startPosition}]:[],...ct<=H.freeAreas[z.i].endPosition?[{startPosition:ct,endPosition:H.freeAreas[z.i].endPosition,size:H.freeAreas[z.i].endPosition-ct}]:[],...z.i<1?W:Lt(z.i,W.length,W)]}return H.freeAreas})(),nextId:H.nextId+1|0}})({segMap:U,freeAreas:(()=>{const H=Et(it.compare)([...wt(l.segments)(R=>R.incoming),...wt(l.segments)(R=>R.outgoing)]);return xt(iy)(ve(R=>C=>C-R>=2*d?w("Just",{startPosition:R+d,endPosition:C-d,size:C-R-2*d}):J,H,Lt(1,H.length,H)))})(),nextId:l.segments.length})(Et(H=>R=>it.compare(ht(T(ht)(-1e18)(H.incoming))(T(ht)(-1e18)(H.outgoing))-lt(T(lt)(1e18)(H.incoming))(T(lt)(1e18)(H.outgoing)))(ht(T(ht)(-1e18)(R.incoming))(T(ht)(-1e18)(R.outgoing))-lt(T(lt)(1e18)(R.incoming))(T(lt)(1e18)(R.outgoing))))(xt(H=>It(H)(U))(V.decisions)));return{segments:(()=>{const H=(R,C)=>{if(R.tag==="Leaf")return C;if(R.tag==="Node")return H(R._5,$t("Cons",R._4,H(R._6,C)));g()};return Ct(Vt.foldr,H(M.segMap,Xt))})(),deps:(()=>{const H=M.segMap,R=(F,I)=>{if(F.tag==="Leaf")return I;if(F.tag==="Node")return R(F._5,$t("Cons",F._4,R(F._6,I)));g()},C=Ct(Vt.foldr,R(H,Xt)),D=C.length;return[...wt(wt(Ft(0,D-2|0))(F=>wt(Ft(F+1|0,D-1|0))(I=>[b(F,I)])))(F=>F._1>=0&&F._1<C.length?F._2>=0&&F._2<C.length?C[F._1].splitPartner.tag!=="Nothing"&&C[F._1].splitPartner.tag==="Just"&&C[F._1].splitPartner._1===C[F._2].id||C[F._2].splitPartner.tag!=="Nothing"&&C[F._2].splitPartner.tag==="Just"&&C[F._2].splitPartner._1===C[F._1].id?[]:o(d,C[F._1],C[F._2]):[]:[]),...wt(C)(F=>F.splitBy.tag==="Just"&&F.splitPartner.tag==="Just"&&(()=>{const I=It(F.splitPartner._1)(H);if(I.tag==="Nothing")return!1;if(I.tag==="Just")return!0;g()})()&&(()=>{const I=It(F.splitBy._1)(H);if(I.tag==="Nothing")return!1;if(I.tag==="Just")return!0;g()})()?[{src:F.id,tgt:F.splitBy._1,weight:1,kind:Yo},{src:F.splitBy._1,tgt:F.splitPartner._1,weight:1,kind:Yo}]:[])]})()}})(),p=h.segments,m=p.length,y=G=>{let P=G,V=!0,U;for(;V;){const M=P,H=Kt(R=>{const C=It(R)(M.inWeight);if(C.tag==="Nothing")return!0;if(C.tag==="Just")return C._1===0;g()})(M.remaining);if(H.tag==="Nothing"){V=!1,U=M;continue}if(H.tag==="Just"){const R=H._1;P={...M,inWeight:T(C=>D=>bt(nt)(se)(D.tgt)(-D.weight)(C))(M.inWeight)((()=>{const C=It(R)(M.depsBySrc);if(C.tag==="Nothing")return[];if(C.tag==="Just")return C._1;g()})()),marks:tt(nt)(R)(M.nextSource)(M.marks),nextSource:M.nextSource+1|0,outWeight:T(C=>D=>bt(nt)(se)(D.src)(-D.weight)(C))(M.outWeight)((()=>{const C=It(R)(M.depsByTgt);if(C.tag==="Nothing")return[];if(C.tag==="Just")return C._1;g()})()),remaining:at(C=>C!==R,M.remaining)};continue}g()}return U},x=G=>{let P=G,V=!0,U;for(;V;){const M=P,H=Kt(R=>{const C=It(R)(M.outWeight);if(C.tag==="Nothing")return!0;if(C.tag==="Just")return C._1===0;g()})(M.remaining);if(H.tag==="Nothing"){V=!1,U=M;continue}if(H.tag==="Just"){const R=H._1;P={...M,inWeight:T(C=>D=>bt(nt)(se)(D.tgt)(-D.weight)(C))(M.inWeight)((()=>{const C=It(R)(M.depsBySrc);if(C.tag==="Nothing")return[];if(C.tag==="Just")return C._1;g()})()),marks:tt(nt)(R)(M.nextSink)(M.marks),nextSink:M.nextSink-1|0,outWeight:T(C=>D=>bt(nt)(se)(D.src)(-D.weight)(C))(M.outWeight)((()=>{const C=It(R)(M.depsByTgt);if(C.tag==="Nothing")return[];if(C.tag==="Just")return C._1;g()})()),remaining:at(C=>C!==R,M.remaining)};continue}g()}return U},N=(G=>{let P=G,V=!0,U;for(;V;){const M=y(x(P));if(M.remaining.length===0){V=!1,U=O(H=>{const R=It(H.id)(M.marks),C=(()=>{if(R.tag==="Nothing")return H.id;if(R.tag==="Just")return R._1;g()})();return{...H,mark:C<m?(C+m|0)+1|0:C}})(p);continue}P=(()=>{const H=C=>{const D=It(C)(M.outWeight),F=It(C)(M.inWeight);return(()=>{if(D.tag==="Nothing")return 0;if(D.tag==="Just")return D._1;g()})()-(()=>{if(F.tag==="Nothing")return 0;if(F.tag==="Just")return F._1;g()})()|0},R=Et(C=>D=>nt.compare(H(D))(H(C)))(M.remaining);if(0<R.length){const C=R[0];return{...M,inWeight:T(D=>F=>bt(nt)(se)(F.tgt)(-F.weight)(D))(M.inWeight)((()=>{const D=It(C)(M.depsBySrc);if(D.tag==="Nothing")return[];if(D.tag==="Just")return D._1;g()})()),marks:tt(nt)(C)(M.nextSource)(M.marks),nextSource:M.nextSource+1|0,outWeight:T(D=>F=>bt(nt)(se)(F.src)(-F.weight)(D))(M.outWeight)((()=>{const D=It(C)(M.depsByTgt);if(D.tag==="Nothing")return[];if(D.tag==="Just")return D._1;g()})()),remaining:at(D=>D!==C,M.remaining)}}return M})()}return U})({remaining:O(G=>G.id)(p),marks:A,inWeight:T(G=>P=>bt(nt)(se)(P.tgt)(P.weight)(G))(A)(h.deps),outWeight:T(G=>P=>bt(nt)(se)(P.src)(P.weight)(G))(A)(h.deps),depsBySrc:T(G=>P=>bt(nt)(re)(P.src)([P])(G))(A)(h.deps),depsByTgt:T(G=>P=>bt(nt)(re)(P.tgt)([P])(G))(A)(h.deps),nextSink:m-1|0,nextSource:m+1|0}),v=(()=>{const G=(()=>{const U=zr(O(M=>b(M.id,M.mark))(N));return{segments:N,deps:xt(M=>(()=>{if(M.kind==="Critical")return!0;if(M.kind==="Regular")return!1;g()})()?w("Just",M):(()=>{const H=It(M.src)(U),R=It(M.tgt)(U);return(()=>{if(H.tag==="Nothing")return 0;if(H.tag==="Just")return H._1;g()})()>(()=>{if(R.tag==="Nothing")return 0;if(R.tag==="Just")return R._1;g()})()})()?M.weight===0?J:w("Just",{src:M.tgt,tgt:M.src,weight:M.weight,kind:M.kind}):w("Just",M))(h.deps)}})(),P=T(U=>M=>bt(nt)(se)(M.tgt)(1)(U))(A)(G.deps),V=(U=>{let M=U,H=!0,R;for(;H;){const C=M,D=Qt(F=>J,F=>I=>w("Just",{head:F,tail:I}),C.queue);if(D.tag==="Nothing"){H=!1,R=C;continue}if(D.tag==="Just"){M=T((()=>{const F=It(D._1.head)(C.slots),I=(()=>{if(F.tag==="Nothing")return 0;if(F.tag==="Just")return F._1;g()})();return z=>$=>{const X=It($)(z.inDegree),Y=(()=>{if(X.tag==="Nothing")return-1;if(X.tag==="Just")return X._1-1|0;g()})();return{...z,slots:tt(nt)($)(Wg((()=>{const W=It($)(z.slots);if(W.tag==="Nothing")return 0;if(W.tag==="Just")return W._1;g()})())(I+1|0))(z.slots),inDegree:tt(nt)($)(Y)(z.inDegree),queue:Y===0?[...z.queue,$]:z.queue}}})())({...C,queue:D._1.tail})((()=>{const F=It(D._1.head)(C.adj);if(F.tag==="Nothing")return[];if(F.tag==="Just")return F._1;g()})());continue}g()}return R})({slots:zr(O(U=>b(U.id,0))(G.segments)),inDegree:P,adj:T(U=>M=>bt(nt)(re)(M.src)([M.tgt])(U))(A)(G.deps),queue:O(U=>U.id)(at(U=>{const M=It(U.id)(P);if(M.tag==="Nothing")return!0;if(M.tag==="Just")return M._1===0;g()},G.segments))});return Et(U=>M=>nt.compare(U.slot)(M.slot))(O(U=>({...U,slot:(()=>{const M=It(U.id)(V.slots);if(M.tag==="Nothing")return 0;if(M.tag==="Just")return M._1;g()})()}))(G.segments))})(),k=1+T(G=>P=>Wg(G)(P.slot))(0)(v)|0,L=wt(v)(G=>G.members),E=at(G=>Ye(dn)(G.edge.id)(L),t),B=T(ht)(-1e18)(O(G=>G.fromPos._2)(E)),q=T(lt)(1e18)(O(G=>G.toPos._2)(E));if(B>q){const G=zr(O(P=>b(P.id,P))(v));return We(O(P=>O(V=>b(V,{slot:P.slot,slotCount:k,gapTop:q,gapBottom:B,partner:(()=>{if(P.splitPartner.tag==="Just"){const U=It(P.splitPartner._1)(G);if(U.tag==="Just")return w("Just",{slot:U._1.slot,splitX:0<U._1.incoming.length?U._1.incoming[0]:0});if(U.tag==="Nothing")return J;g()}if(P.splitPartner.tag==="Nothing")return J;g()})()}))(P.members))(at(P=>{if(P.splitPartner.tag==="Just"){const V=It(P.splitPartner._1)(G);return!(V.tag==="Just"&&(()=>{if(V._1.splitBy.tag==="Nothing")return!1;if(V._1.splitBy.tag==="Just")return!0;g()})())}if(P.splitPartner.tag==="Nothing")return!0;g()},v)))}const j=zr(O(G=>b(G.id,G))(v));return We(O(G=>O(P=>b(P,{slot:G.slot,slotCount:k,gapTop:B,gapBottom:q,partner:(()=>{if(G.splitPartner.tag==="Just"){const V=It(G.splitPartner._1)(j);if(V.tag==="Just")return w("Just",{slot:V._1.slot,splitX:0<V._1.incoming.length?V._1.incoming[0]:0});if(V.tag==="Nothing")return J;g()}if(G.splitPartner.tag==="Nothing")return J;g()})()}))(G.members))(at(G=>{if(G.splitPartner.tag==="Just"){const P=It(G.splitPartner._1)(j);return!(P.tag==="Just"&&(()=>{if(P._1.splitBy.tag==="Nothing")return!1;if(P._1.splitBy.tag==="Just")return!0;g()})())}if(G.splitPartner.tag==="Nothing")return!0;g()},v)))})()))(A)(ry(T(u=>s=>{const a=Hr(s.edge.from.node)(n);if(a.tag==="Just"){const c=Hr(s.edge.to.node)(n);return c.tag==="Just"&&a._1.layer!==c._1.layer?bt(nt)(re)(Wr(a._1.layer)(c._1.layer))([s])(u):u}return u})(A)((()=>{const u=s=>b((()=>{const a=Hr(s.edge.from.node)(n);return a.tag==="Just"?a._1.layer:1e6})(),(()=>{const a=Hr(s.edge.from.node)(n);return a.tag==="Just"?a._1.order:1e6})());return Et(s=>a=>ny(u(s))(u(a)))(t)})())))},uy=t=>e=>{const n=Yg(t)(e),r=T(i=>o=>tt(S)(o.node)(o)(i))(A)(e);return T(i=>o=>{const u=Hr(o.edge.from.node)(r);if(u.tag==="Just"){const s=Hr(o.edge.to.node)(r);if(s.tag==="Just"&&u._1.layer!==s._1.layer){const a=oy(o.edge.id)(n);if(a.tag==="Just")return tt(nt)(Wr(u._1.layer)(s._1.layer))(a._1.slotCount)(i)}return i}return i})(A)(t)},$g=zt.foldMap((()=>{const t={append:e=>n=>e||n};return{mempty:!1,Semigroup0:()=>t}})()),fe=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},_e=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Di=t=>e=>n=>r=>$g(i=>n>=i.x&&n<i.x+i.w&&e>i.y&&t<i.y+i.h)(r),$o=t=>e=>n=>r=>Di(fe(e)(n))(_e(e)(n))(r)(t),qo=et(4),sy=ec(t=>{if(t.direction==="H"){const e=fe(t.start._1)(t.end._1);return[{x:e,y:t.start._2-1,w:_e(t.start._1)(t.end._1)-e,h:2}]}if(t.direction==="V"){const e=fe(t.start._2)(t.end._2);return[{x:t.start._1-1,y:e,w:2,h:_e(t.start._2)(t.end._2)-e}]}g()}),Ii=tc(t=>{const e=t.start._1-t.end._1;return!((e<0?-e<1e-6:e<1e-6)&&(()=>{const n=t.start._2-t.end._2;return n<0?-n<1e-6:n<1e-6})())}),ay=t=>e=>n=>{const r=Qt(i=>J,i=>o=>w("Just",{head:i,tail:o}),e);if(r.tag==="Nothing")return[{start:t.start,end:n.end,direction:t.direction}];if(r.tag==="Just"){const i=(r._1.head.direction==="H"?t.direction==="H":r._1.head.direction==="V"&&t.direction==="V")?[{start:t.start,end:r._1.head.end,direction:t.direction}]:[t,r._1.head],o=fr(r._1.tail);if(o.tag==="Nothing"){const u=i.length-1|0;return u>=0&&u<i.length&&(i[u].direction==="H"?n.direction==="H":i[u].direction==="V"&&n.direction==="V")?[...(()=>{const s=i.length-1|0;return s<1?[]:Lt(0,s,i)})(),{start:i[u].start,end:n.end,direction:n.direction}]:[...i,n]}if(o.tag==="Just")return(o._1.last.direction==="H"?n.direction==="H":o._1.last.direction==="V"&&n.direction==="V")?[...i,...o._1.init,{start:o._1.last.start,end:n.end,direction:n.direction}]:[...i,...r._1.tail,n]}g()},Ai=t=>{const e=r=>i=>{const o=Qt(u=>J,u=>s=>w("Just",{head:u,tail:s}),i);if(o.tag==="Nothing")return[r];if(o.tag==="Just")return(r.direction==="H"?o._1.head.direction==="H":r.direction==="V"&&o._1.head.direction==="V")&&(()=>{if(r.direction==="H")return r.end._1-r.start._1>=0==o._1.head.end._1-o._1.head.start._1>=0;if(r.direction==="V")return r.end._2-r.start._2>=0==o._1.head.end._2-o._1.head.start._2>=0;g()})()?e({start:r.start,end:o._1.head.end,direction:r.direction})(o._1.tail):[r,...e(o._1.head)(o._1.tail)];g()},n=Qt(r=>J,r=>i=>w("Just",{head:r,tail:i}),t);if(n.tag==="Nothing")return[];if(n.tag==="Just")return e(n._1.head)(n._1.tail);g()},Fi=t=>e=>n=>r=>$g(i=>n>=i.y&&n<i.y+i.h&&e>i.x&&t<i.x+i.w)(r),Bi=t=>e=>n=>r=>Fi(fe(e)(n))(_e(e)(n))(r)(t),cy=t=>e=>n=>r=>{const i=n+2|0,o=i<1?e:Lt(i,e.length,e),u=n<1?[]:Lt(0,n,e),s=(n+1|0)===(r-1|0),a=n===0,c=n>=0&&n<e.length?w("Just",e[n]):J;if(c.tag==="Just"){const f=n+1|0,d=f>=0&&f<e.length?w("Just",e[f]):J;if(d.tag==="Just"){const l=c._1.start._1===d._1.end._1&&(!a||c._1.direction==="V")&&(!s||d._1.direction==="V")&&!$o(t)(fe(c._1.start._2)(d._1.end._2))(_e(c._1.start._2)(d._1.end._2))(c._1.start._1)?w("Just",[...u,{start:c._1.start,end:d._1.end,direction:oe},...o]):J,_=c._1.start._2===d._1.end._2&&(!a||c._1.direction==="H")&&(!s||d._1.direction==="H")&&!Bi(t)(fe(c._1.start._1)(d._1.end._1))(_e(c._1.start._1)(d._1.end._1))(c._1.start._2)?w("Just",[...u,{start:c._1.start,end:d._1.end,direction:ie},...o]):J;return l.tag==="Nothing"?_:l}if(d.tag==="Nothing")return J;g()}if(c.tag==="Nothing")return J;g()},gy=t=>e=>{const n=e.length;return(r=>{let i=r,o=!0,u;for(;o;){const s=i;if((s+1|0)>=n){o=!1,u=e;continue}const a=cy(t)(e)(s)(n);if(a.tag==="Just"){o=!1,u=a._1;continue}if(a.tag==="Nothing"){i=s+1|0;continue}g()}return u})(0)},fy=t=>e=>n=>r=>{const i=(l,_,h)=>!$o(t)(fe(_)(h))(_e(_)(h))(l),o=n+3|0,u=o<1?e:Lt(o,e.length,e),s=n<1?[]:Lt(0,n,e),a=(n+2|0)===(r-1|0),c=n===0,f=(l,_,h)=>!Bi(t)(fe(_)(h))(_e(_)(h))(l),d=n>=0&&n<e.length?w("Just",e[n]):J;if(d.tag==="Just"){const l=n+2|0,_=l>=0&&l<e.length?w("Just",e[l]):J;if(_.tag==="Just"){const h=d._1.start._1===_._1.end._1&&(!c||d._1.direction==="V")&&(!a||_._1.direction==="V")&&i(d._1.start._1,d._1.start._2,_._1.end._2)?w("Just",[...s,{start:d._1.start,end:_._1.end,direction:oe},...u]):d._1.start._2===_._1.end._2&&(!c||d._1.direction==="H")&&(!a||_._1.direction==="H")&&f(d._1.start._2,d._1.start._1,_._1.end._1)?w("Just",[...s,{start:d._1.start,end:_._1.end,direction:ie},...u]):J,p=(!c||d._1.direction==="V")&&(!a||_._1.direction==="H")&&i(d._1.start._1,d._1.start._2,_._1.end._2)&&f(_._1.end._2,d._1.start._1,_._1.end._1)?w("Just",[...s,{start:d._1.start,end:b(d._1.start._1,_._1.end._2),direction:oe},{start:b(d._1.start._1,_._1.end._2),end:_._1.end,direction:ie},...u]):J,m=(!c||d._1.direction==="H")&&(!a||_._1.direction==="V")&&f(d._1.start._2,d._1.start._1,_._1.end._1)&&i(_._1.end._1,d._1.start._2,_._1.end._2)?w("Just",[...s,{start:d._1.start,end:b(_._1.end._1,d._1.start._2),direction:ie},{start:b(_._1.end._1,d._1.start._2),end:_._1.end,direction:oe},...u]):J,y=p.tag==="Nothing"?m:p;return h.tag==="Nothing"?y:h}if(_.tag==="Nothing")return J;g()}if(d.tag==="Nothing")return J;g()},_y=t=>e=>{const n=e.length;return(r=>{let i=r,o=!0,u;for(;o;){const s=i;if((s+2|0)>=n){o=!1,u=e;continue}const a=fy(t)(e)(s)(n);if(a.tag==="Just"){o=!1,u=a._1;continue}if(a.tag==="Nothing"){i=s+1|0;continue}g()}return u})(0)},dy=t=>{const e=n=>{let r=n,i=!0,o;for(;i;){const u=r,s=Ai(Ii(gy(t)(_y(t)(u))));if(s.length<u.length){r=s;continue}i=!1,o=s}return o};return n=>e(Ai(Ii(n)))},ly=t=>e=>n=>r=>{const i=fe(n)(r),o=_e(n)(r),u=at(a=>e>=a.y&&e<a.y+a.h&&a.x+a.w>i&&a.x<o,t);if(r>n){const a=Et(c=>f=>it.compare(c.x)(f.x))(u);return 0<a.length?a[0].x-1:(n+r)/2}const s=Et(a=>c=>it.compare(c.x)(a.x))(O(a=>({...a,x:a.x+a.w}))(u));return 0<s.length?s[0].x+1:(n+r)/2},hy=t=>e=>n=>r=>{const i=fe(n)(r),o=_e(n)(r),u=at(a=>e>=a.x&&e<a.x+a.w&&a.y+a.h>i&&a.y<o,t);if(r>n){const a=Et(c=>f=>it.compare(c.y)(f.y))(u);return 0<a.length?a[0].y-1:(n+r)/2}const s=Et(a=>c=>it.compare(c.y)(a.y))(O(a=>({...a,y:a.y+a.h}))(u));return 0<s.length?s[0].y+1:(n+r)/2},py=t=>e=>n=>r=>{const i=fe(n)(r),o=_e(n)(r),u=at(a=>e>=a.y&&e<a.y+a.h&&a.x+a.w>i&&a.x<o,t);if(r>n){const a=Et(c=>f=>it.compare(f.x)(c.x))(O(c=>({...c,x:c.x+c.w}))(u));return 0<a.length?a[0].x:(n+r)/2}const s=Et(a=>c=>it.compare(a.x)(c.x))(u);return 0<s.length?s[0].x-1:(n+r)/2},my=t=>e=>n=>r=>{const i=fe(n)(r),o=_e(n)(r),u=at(a=>e>=a.x&&e<a.x+a.w&&a.y+a.h>i&&a.y<o,t);if(r>n){const a=Et(c=>f=>it.compare(f.y)(c.y))(O(c=>({...c,y:c.y+c.h}))(u));return 0<a.length?a[0].y:(n+r)/2}const s=Et(a=>c=>it.compare(a.y)(c.y))(u);return 0<s.length?s[0].y-1:(n+r)/2},qg=t=>e=>n=>{let r=t,i=e,o=n,u=!0,s;for(;u;){const a=r,c=i,f=o;if(f>100){u=!1,s=c;continue}if(!a(c+f)){u=!1,s=c+f;continue}if(!a(c-f)){u=!1,s=c-f;continue}r=a,i=c,o=f+1}return s},Xg=t=>e=>n=>r=>i=>{const o=fe(e)(n),u=_e(e)(n);if(!Di(o)(u)(r)(t))return r;if(!Di(o)(u)(i)(t))return i;const s=(r+i)/2;return Di(o)(u)(s)(t)?qg(a=>Di(o)(u)(a)(t))(s)(1):s},yy=t=>e=>n=>r=>i=>{const o=fe(e)(n),u=_e(e)(n);if(!Fi(o)(u)(r)(t))return r;if(!Fi(o)(u)(i)(t))return i;const s=(r+i)/2;return Fi(o)(u)(s)(t)?qg(a=>Fi(o)(u)(a)(t))(s)(1):s},xy=t=>e=>n=>r=>{const i=fe(e)(n),o=_e(e)(n),u=at(c=>r>=c.x&&r<c.x+c.w&&c.y+c.h>i&&c.y<o,t),s=T(c=>f=>_e(c)(f.x+f.w+4))(r+4)(u),a=T(c=>f=>fe(c)(f.x-4))(r-4)(u);return(()=>{const c=s-r,f=a-r;return(c<0?-c:c)<=(f<0?-f:f)})()?s:a},Ny=t=>e=>n=>r=>{const i=fe(e)(n),o=_e(e)(n),u=at(c=>r>=c.y&&r<c.y+c.h&&c.x+c.w>i&&c.x<o,t),s=T(c=>f=>_e(c)(f.y+f.h+4))(r+4)(u),a=T(c=>f=>fe(c)(f.y-4))(r-4)(u);return(()=>{const c=s-r,f=a-r;return(c<0?-c:c)<=(f<0?-f:f)})()?s:a},Jy=t=>e=>n=>r=>i=>o=>u=>{const s=(()=>{if(r==="South")return b(i._1,i._2+4);if(r==="North")return b(i._1,i._2-4);if(r==="East")return b(i._1+4,i._2);if(r==="West")return b(i._1-4,i._2);g()})(),a=(()=>{if(o==="South")return b(u._1,u._2+4);if(o==="North")return b(u._1,u._2-4);if(o==="East")return b(u._1+4,u._2);if(o==="West")return b(u._1-4,u._2);g()})(),c=(k,L,E)=>!$o(e)(fe(L)(E))(_e(L)(E))(k),f=(k,L,E)=>!$o(n)(fe(L)(E))(_e(L)(E))(k),d=(k,L,E,B)=>t.tag==="Just"&&!Bi(n)(fe(k)(L))(_e(k)(L))(t._1)?t._1:yy(e)(k)(L)(E)(B),l=(k,L,E,B)=>{if(k===E){const j=xy(e)(L)(B)(k),G=hy(e)(k)(L)(B),P=my(e)(k)(L)(B);return[{start:b(k,L),end:b(k,G),direction:oe},{start:b(k,G),end:b(j,G),direction:ie},{start:b(j,G),end:b(j,P),direction:oe},{start:b(j,P),end:b(E,P),direction:ie},{start:b(E,P),end:b(E,B),direction:oe}]}const q=d(k,E,L,B);return[{start:b(k,L),end:b(k,q),direction:oe},{start:b(k,q),end:b(E,q),direction:ie},{start:b(E,q),end:b(E,B),direction:oe}]},_=(k,L,E,B)=>{if(L===B){const j=Ny(e)(k)(E)(L),G=ly(e)(L)(k)(E),P=py(e)(L)(k)(E);return[{start:b(k,L),end:b(G,L),direction:ie},{start:b(G,L),end:b(G,j),direction:oe},{start:b(G,j),end:b(P,j),direction:ie},{start:b(P,j),end:b(P,B),direction:oe},{start:b(P,B),end:b(E,B),direction:ie}]}const q=Xg(e)(L)(B)(k)(E);return[{start:b(k,L),end:b(q,L),direction:ie},{start:b(q,L),end:b(q,B),direction:oe},{start:b(q,B),end:b(E,B),direction:ie}]},h=(k,L,E)=>!Bi(e)(fe(L)(E))(_e(L)(E))(k),p=(k,L,E)=>!Bi(n)(fe(L)(E))(_e(L)(E))(k),m=(k,L,E,B)=>{if(p(L,k,E)&&f(E,L,B))return[{start:b(k,L),end:b(E,L),direction:ie},{start:b(E,L),end:b(E,B),direction:oe}];const q=Xg(e)(L)(B)(k)(E);return[{start:b(k,L),end:b(q,L),direction:ie},{start:b(q,L),end:b(q,B),direction:oe},{start:b(q,B),end:b(E,B),direction:ie}]},y=(k,L,E,B)=>{if(f(k,L,B)&&p(B,k,E))return[{start:b(k,L),end:b(k,B),direction:oe},{start:b(k,B),end:b(E,B),direction:ie}];const q=d(k,E,L,B);return[{start:b(k,L),end:b(k,q),direction:oe},{start:b(k,q),end:b(E,q),direction:ie},{start:b(E,q),end:b(E,B),direction:oe}]},x=(()=>{if(r==="South")return o==="North"?s._1===a._1&&c(s._1,s._2,a._2)?[{start:b(s._1,s._2),end:b(a._1,a._2),direction:oe}]:l(s._1,s._2,a._1,a._2):o==="East"||o==="West"?y(s._1,s._2,a._1,a._2):l(s._1,s._2,a._1,a._2);if(r==="North")return o==="South"?s._1===a._1&&c(s._1,s._2,a._2)?[{start:b(s._1,s._2),end:b(a._1,a._2),direction:oe}]:l(s._1,s._2,a._1,a._2):o==="East"||o==="West"?y(s._1,s._2,a._1,a._2):l(s._1,s._2,a._1,a._2);if(r==="East")return o==="West"?s._2===a._2&&h(s._2,s._1,a._1)?[{start:b(s._1,s._2),end:b(a._1,a._2),direction:ie}]:_(s._1,s._2,a._1,a._2):o==="North"||o==="South"?m(s._1,s._2,a._1,a._2):l(s._1,s._2,a._1,a._2);if(r==="West"){if(o==="East")return s._2===a._2&&h(s._2,s._1,a._1)?[{start:b(s._1,s._2),end:b(a._1,a._2),direction:ie}]:_(s._1,s._2,a._1,a._2);if(o==="North"||o==="South")return m(s._1,s._2,a._1,a._2)}return l(s._1,s._2,a._1,a._2)})(),N=(()=>{if(r==="South"||r==="North")return oe;if(r==="East"||r==="West")return ie;g()})(),v={start:b(a._1,a._2),end:b(u._1,u._2),direction:(()=>{if(o==="South"||o==="North")return oe;if(o==="East"||o==="West")return ie;g()})()};return s._1===a._1&&s._2===a._2?[{start:b(i._1,i._2),end:b(u._1,u._2),direction:N}]:ay({start:b(i._1,i._2),end:b(s._1,s._2),direction:N})(x)(v)},Ty=O(t=>({x:t.position._1*qo-2,y:t.position._2*qo-2,w:t.size._1*qo+4,h:t.size._2*qo+4})),Qs=te(S)(zt),Rn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Rs=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},wy=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t._1)(o._3._1);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(t._2==="North"){if(o._3._2==="North"){r=!1,i=w("Just",o._4);continue}n=o._5;continue}if(o._3._2==="North"){n=o._6;continue}if(t._2==="South"){if(o._3._2==="South"){r=!1,i=w("Just",o._4);continue}n=o._5;continue}if(o._3._2==="South"){n=o._6;continue}if(t._2==="East"){if(o._3._2==="East"){r=!1,i=w("Just",o._4);continue}n=o._5;continue}if(o._3._2==="East"){n=o._6;continue}if(t._2==="West"&&o._3._2==="West"){r=!1,i=w("Just",o._4);continue}}g()}return i},Vg=t=>e=>{const n=e.position._1+e.size._1,r=e.position._2*2+e.size._2,i=e.position._1*2+e.size._1,o=e.position._2+e.size._2;if(t==="South")return b(i,o*2);if(t==="North")return b(i,e.position._2*2);if(t==="East")return b(n*2,r);if(t==="West")return b(e.position._1*2,r);g()},Ms=t=>e=>{const n=et(4);if(t==="South")return{lo:e.position._1*n,hi:(e.position._1+e.size._1)*n};if(t==="North")return{lo:e.position._1*n,hi:(e.position._1+e.size._1)*n};if(t==="East")return{lo:e.position._2*n,hi:(e.position._2+e.size._2)*n};if(t==="West")return{lo:e.position._2*n,hi:(e.position._2+e.size._2)*n};g()},Ug=t=>e=>T(n=>r=>bt(t)(re)(e(r))([r])(n))(A),Kg=t=>e=>n=>r=>{const i=(t==="South"||t==="North")&&(e==="East"||e==="West")&&(()=>{if(t==="South")return r._2>n._2;if(t==="North")return r._2<n._2;if(t==="East")return r._2>n._2;if(t==="West")return r._2<n._2;g()})()&&(()=>{if(e==="East")return n._1>r._1;if(e==="West"||e==="North")return n._1<r._1;if(e==="South")return n._1>r._1;g()})(),o=(t==="East"||t==="West")&&(e==="North"||e==="South")&&(()=>{if(t==="South")return r._1>n._1;if(t==="North")return r._1<n._1;if(t==="East")return r._1>n._1;if(t==="West")return r._1<n._1;g()})()&&(()=>{if(e==="East")return n._2>r._2;if(e==="West"||e==="North")return n._2<r._2;if(e==="South")return n._2>r._2;g()})();return(t==="South"?e==="North"&&n._1===r._1&&r._2>n._2:t==="North"?e==="South"&&n._1===r._1&&r._2<n._2:t==="East"?e==="West"&&n._2===r._2&&r._1>n._1:t==="West"&&e==="East"&&n._2===r._2&&r._1<n._1)?0:i||o?1:2},Zg=t=>e=>{const n=t.hi-t.lo,r=(t.lo+t.hi)/2,i=e.length;return i===0?A:Qs(i===1?O(o=>b(o,r))(e):Bt(o=>u=>b(u,t.lo+et(o+1|0)*n/et(i+1|0)))(e))},jg=t=>e=>n=>r=>i=>{const o=Ug(S)(_=>_.to.node)(t),u=Ug(S)(_=>_.from.node)(t),s=T(_=>h=>tt(S)(h.node)(h)(_))(A)(e),a=(_,h,p)=>{const m=Rn(_)(s);if(m.tag==="Nothing")return b(0,0);if(m.tag==="Just"){const y=Rn(_)(n);if(y.tag==="Nothing"){const x=et(4);if(p==="South")return b(m._1.position._1*x+m._1.size._1*x/2,(m._1.position._2+m._1.size._2)*x);if(p==="North")return b(m._1.position._1*x+m._1.size._1*x/2,m._1.position._2*x);if(p==="East")return b((m._1.position._1+m._1.size._1)*x,m._1.position._2*x+m._1.size._2*x/2);if(p==="West")return b(m._1.position._1*x,m._1.position._2*x+m._1.size._2*x/2);g()}if(y.tag==="Just"){const x=Kt(N=>N.id===h)(y._1);if(x.tag==="Nothing"){const N=et(4);if(p==="South")return b(m._1.position._1*N+m._1.size._1*N/2,(m._1.position._2+m._1.size._2)*N);if(p==="North")return b(m._1.position._1*N+m._1.size._1*N/2,m._1.position._2*N);if(p==="East")return b((m._1.position._1+m._1.size._1)*N,m._1.position._2*N+m._1.size._2*N/2);if(p==="West")return b(m._1.position._1*N,m._1.position._2*N+m._1.size._2*N/2);g()}if(x.tag==="Just"){const N=et(4);if(x._1.side==="North")return b(m._1.position._1*N+et(x._1.offset)*N,m._1.position._2*N);if(x._1.side==="South")return b(m._1.position._1*N+et(x._1.offset)*N,(m._1.position._2+m._1.size._2)*N);if(x._1.side==="East")return b((m._1.position._1+m._1.size._1)*N,m._1.position._2*N+et(x._1.offset)*N);if(x._1.side==="West")return b(m._1.position._1*N,m._1.position._2*N+et(x._1.offset)*N)}}}g()},c=Qs(wt(r)(_=>{if(_.nodes.length<=2)return[];const h=et(4);if(1<_.nodes.length){const p=Rn(_.nodes[1])(s);if(p.tag==="Nothing")return[];if(p.tag==="Just"){const m=p._1.position._1*h+p._1.size._1*h/2;return O(y=>b(y,m))(ve(y=>x=>_.edgeId+":"+y+"->"+x,_.nodes,Lt(1,_.nodes.length,_.nodes)))}g()}return[]})),f=_=>{const h=Rn(_.from.node)(s),p=Rn(_.to.node)(s);if(h.tag==="Just"&&p.tag==="Just"){const m=h._1,y=p._1,x=Et(N=>v=>nt.compare(N.score)(v.score))(O(N=>{const v=N._1,k=N._2;return{from:v,to:k,score:(()=>{const L=(j,G,P,V,U)=>{const M=Ms(j)(G),H=Ms(j)(P);return M.lo<H.hi&&H.lo<M.hi&&(v==="South"?k==="North"&&U._2>V._2:v==="North"?k==="South"&&U._2<V._2:v==="East"?k==="West"&&U._1>V._1:v==="West"&&k==="East"&&U._1<V._1)?0:Kg(v)(k)(V)(U)},E=Vg(v)(m),B=Vg(k)(y),q=Kg(v)(k)(E)(B);return(()=>{if(q>0){if(v==="South")return k==="North"?L(he,m,y,E,B)*10|0:q*10|0;if(v==="North")return k==="South"?L(le,m,y,E,B)*10|0:q*10|0;if(v==="East")return k==="West"?L(An,m,y,E,B)*10|0:q*10|0;if(v==="West"&&k==="East")return L(Fn,m,y,E,B)*10|0}return q*10|0})()+(v==="South"?k==="North"?0:15:v==="North"?k==="South"?0:15:v==="East"?k==="West"?5:15:v==="West"&&k==="East"?5:15)|0})()}})([b(he,le),b(An,le),b(Fn,le),b(he,An),b(he,Fn),b(le,he),b(le,An),b(le,Fn),b(An,he),b(Fn,he),b(An,Fn),b(Fn,An)]));if(0<x.length)return{from:x[0].from,to:x[0].to}}return{from:he,to:le}},d=Qs(O(_=>b(_.id,f(_)))(t)),l=(_,h,p,m,y,x)=>{const N=et(4),v=Rn(h)(s);if(v.tag==="Nothing")return b(0,0);if(v.tag==="Just"){const k=wy(b(p,_))(i);if(k.tag==="Just"){const L=v._1.position._1*N+k._1,E=et(4);if(_==="South")return b(L,(v._1.position._2+v._1.size._2)*E);if(_==="North")return b(L,v._1.position._2*E);if(_==="East")return b((v._1.position._1+v._1.size._1)*E,L);if(_==="West")return b(v._1.position._1*E,L);g()}if(k.tag==="Nothing"){const L=Ms(_)(v._1),E=(L.lo+L.hi)/2,B=Rs(p)(Zg(L)(O(G=>G.id)(Et(G=>P=>it.compare(y(_)(G))(y(_)(P)))(at(G=>{const P=Rs(G.id)(d);if(P.tag==="Just"){const V=x(P._1);return V==="North"?_==="North":V==="South"?_==="South":V==="East"?_==="East":V==="West"&&_==="West"}if(P.tag==="Nothing")return!0;g()},(()=>{const G=Rn(h)(m);if(G.tag==="Nothing")return[];if(G.tag==="Just")return G._1;g()})()))))),q=(()=>{if(B.tag==="Nothing")return E;if(B.tag==="Just")return B._1;g()})(),j=et(4);if(_==="South")return b(q,(v._1.position._2+v._1.size._2)*j);if(_==="North")return b(q,v._1.position._2*j);if(_==="East")return b((v._1.position._1+v._1.size._1)*j,q);if(_==="West")return b(v._1.position._1*j,q)}}g()};return O(_=>{const h=Rs(_.edge.id)(c);if(h.tag==="Nothing")return _;if(h.tag==="Just")return{..._,fromPos:ye(3)(_.edge.from.node)==="$d:"?b(h._1,_.fromPos._2):_.fromPos,toPos:ye(3)(_.edge.to.node)==="$d:"?b(h._1,_.toPos._2):_.toPos};g()})(O(_=>{if(_.from.port.tag==="Just"&&_.to.port.tag==="Just")return{edge:_,fromPos:a(_.from.node,_.from.port._1,he),toPos:a(_.to.node,_.to.port._1,le),fromSide:he,toSide:le};const h=f(_);return{edge:_,fromPos:l(h.from,_.from.node,_.id,u,p=>m=>{const y=Rn(m.to.node)(s);if(y.tag==="Nothing")return 0;if(y.tag==="Just"){const x=et(4);if(p==="South"||p==="North")return y._1.position._1*x+y._1.size._1*x/2;if(p==="East"||p==="West")return y._1.position._2*x+y._1.size._2*x/2}g()},p=>p.from),toPos:l(h.to,_.to.node,_.id,o,p=>m=>{const y=Rn(m.from.node)(s);if(y.tag==="Nothing")return 0;if(y.tag==="Just"){const x=et(4);if(p==="South"||p==="North")return y._1.position._1*x+y._1.size._1*x/2;if(p==="East"||p==="West")return y._1.position._2*x+y._1.size._2*x/2}g()},p=>p.to),fromSide:h.from,toSide:h.to}})(t))},tf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Or=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},vy=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),zs=t=>e=>t.gapTop+1*et(4)+et(e)*2.5*et(4),by=t=>e=>{const n=tf(e.edge.id)(t);if(n.tag==="Just"){if(n._1.partner.tag==="Just")return w("Just",{slot1Y:zs(n._1)(n._1.slot),splitX:n._1.partner._1.splitX,slot2Y:zs(n._1)(n._1.partner._1.slot)});if(n._1.partner.tag==="Nothing")return J;g()}if(n.tag==="Nothing")return J;g()},ky=t=>e=>{const n=T(r=>i=>tt(S)(i.node)(i)(r))(A)(e);return We(Bt(r=>i=>{const o=Or(i.node)(n);if(o.tag==="Nothing")return[];if(o.tag==="Just"){const u=o._1;return Bt(s=>a=>{const c=i.edges.length,f=et(4),d=u.position._1*f,l=u.position._2*f,_=u.size._2*f,h=et((2*c|0)+1|0),p=l+_*et(c-s|0)/h,m=l+_*et((c+1|0)+s|0)/h,y=d-f*2.5*et(s+1|0),x=[{start:b(d,p),end:b(y,p),direction:ie},{start:b(y,p),end:b(y,m),direction:oe},{start:b(y,m),end:b(d,m),direction:ie}];return{edge:a.id,segments:x,bends:ve(N=>v=>N.end,x,Lt(1,3,x)),bendType:[],jumps:[],reversed:!1}})(i.edges)}g()})(O(r=>({node:r._1,edges:r._2}))(vy(T(r=>i=>bt(S)(re)(i.from.node)([i])(r))(A)(t)))))},Ly=t=>e=>{const n=T(o=>u=>tt(S)(u.node)(u)(o))(A)(e),r=o=>{const u=Or(o)(n);if(u.tag==="Nothing")return 0;if(u.tag==="Just")return u._1.position._1;g()},i=o=>{const u=Or(o)(n);if(u.tag==="Nothing")return 0;if(u.tag==="Just")return u._1.layer;g()};return Et(o=>u=>{const s=nt.compare(i(o.edge.from.node))(i(u.edge.from.node));if(s==="EQ"){const a=it.compare(r(o.edge.from.node))(r(u.edge.from.node));return a==="EQ"?it.compare(r(o.edge.to.node))(r(u.edge.to.node)):a}return s})(t)},Re=t=>{const e=et(4);return{x:t.position._1*e-2,y:t.position._2*e-2,w:t.size._1*e+4,h:t.size._2*e+4}},Ey=t=>t.from.node===t.to.node,Cy=t=>e=>n=>r=>{const i=dy(n)(Jy(t)(e)(n)(r.fromSide)(r.fromPos)(r.toSide)(r.toPos));return{edge:r.edge.id,segments:i,bends:ve(o=>u=>o.end,i,Lt(1,i.length,i)),bendType:[],jumps:[],reversed:!1}},Sy=t=>e=>n=>r=>{const i=[{start:b(r.fromPos._1,r.fromPos._2),end:b(r.fromPos._1,t.slot1Y),direction:oe},{start:b(r.fromPos._1,t.slot1Y),end:b(t.splitX,t.slot1Y),direction:ie},{start:b(t.splitX,t.slot1Y),end:b(t.splitX,t.slot2Y),direction:oe},{start:b(t.splitX,t.slot2Y),end:b(r.toPos._1,t.slot2Y),direction:ie},{start:b(r.toPos._1,t.slot2Y),end:b(r.toPos._1,r.toPos._2),direction:oe}];return{edge:r.edge.id,segments:i,bends:ve(o=>u=>o.end,i,Lt(1,5,i)),bendType:[],jumps:[],reversed:!1}},Gy=t=>e=>n=>{const r=Or(t.edge.from.node)(n);if(r.tag==="Just"){const o=Or(t.edge.to.node)(n);return o.tag==="Just"?at(u=>!(u.h===Re(r._1).h&&u.w===Re(r._1).w&&u.x===Re(r._1).x&&u.y===Re(r._1).y)&&!(u.h===Re(o._1).h&&u.w===Re(o._1).w&&u.x===Re(o._1).x&&u.y===Re(o._1).y),e):at(u=>!(u.h===Re(r._1).h&&u.w===Re(r._1).w&&u.x===Re(r._1).x&&u.y===Re(r._1).y),e)}const i=Or(t.edge.to.node)(n);return i.tag==="Just"?at(o=>!(o.h===Re(i._1).h&&o.w===Re(i._1).w&&o.x===Re(i._1).x&&o.y===Re(i._1).y),e):at(o=>!0,e)},Py=t=>e=>{const n=tf(e.edge.id)(t);if(n.tag==="Just")return w("Just",zs(n._1)(n._1.slot));if(n.tag==="Nothing")return J;g()},Dy=t=>e=>n=>r=>i=>{const o=T(c=>f=>tt(S)(f.node)(f)(c))(A)(e),u=Ty(e),s=jg(at(c=>c.from.node!==c.to.node,t))(e)(n)(r)(i),a=Yg(s)(e);return[...ky(at(Ey,t))(e),...T(c=>f=>{const d=Gy(f)(u)(o),l=[...d,...c.edgeObstacles],_=by(a)(f),h=(()=>{if(_.tag==="Just")return Sy(_._1)(d)(l)(f);if(_.tag==="Nothing")return Cy(Py(a)(f))(d)(l)(f);g()})();return{results:[...c.results,h],edgeObstacles:[...c.edgeObstacles,...sy(h.segments)]}})({results:[],edgeObstacles:[]})(Ly(s)(e)).results]},ir=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},or=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Iy=t=>e=>n=>{if(t.start._1!==e.start._1)return J;const r=or(ir(t.start._2)(t.end._2))(ir(e.start._2)(e.end._2)),i=ir(or(t.start._2)(t.end._2))(or(e.start._2)(e.end._2));return r<i?w("Just",{position:b(t.start._1,(r+i)/2),crossingEdge:n}):J},Ay=t=>e=>n=>{if(t.start._2!==e.start._2)return J;const r=or(ir(t.start._1)(t.end._1))(ir(e.start._1)(e.end._1)),i=ir(or(t.start._1)(t.end._1))(or(e.start._1)(e.end._1));return r<i?w("Just",{position:b((r+i)/2,t.start._2),crossingEdge:n}):J},Fy=t=>e=>n=>{if(t.direction==="H")return Ay(t)(e)(n);if(t.direction==="V")return Iy(t)(e)(n);g()},By=t=>e=>n=>{const r=t+1|0,i=r<1?n:Lt(r,n.length,n);return wt(e.segments)(o=>wt(i)(u=>xt(s=>Fy(o)(s)(u.edge))(at(s=>s.direction==="H"?o.direction==="H":s.direction==="V"&&o.direction==="V",u.segments))))},Qy=t=>e=>n=>e.start._1>ir(t.start._1)(t.end._1)&&e.start._1<or(t.start._1)(t.end._1)&&t.start._2>ir(e.start._2)(e.end._2)&&t.start._2<or(e.start._2)(e.end._2)?w("Just",{position:b(e.start._1,t.start._2),crossingEdge:n}):J,Ry=t=>e=>wt(at(n=>n.direction==="H",t.segments))(n=>wt(e)(r=>xt(i=>Qy(n)(i)(r.edge))(at(i=>i.direction==="V",r.segments)))),My=t=>e=>n=>[...Ry(e)(at(r=>r.edge!==e.edge,n)),...By(t)(e)(n)],ef=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},nf=t=>ye(3)(t)==="$d:",zy=t=>e=>n=>T(r=>i=>{const o=ef(i.from.node)(t),u=(()=>{if(o.tag==="Nothing")return 0;if(o.tag==="Just")return o._1;g()})(),s=ef(i.to.node)(t),a=(()=>{if(s.tag==="Nothing")return-u;if(s.tag==="Just")return s._1-u|0;g()})();if(a<=1)return{...r,edges:[...r.edges,i],chains:[...r.chains,{edgeId:i.id,nodes:[i.from.node,i.to.node]}]};const c=i.id,f=O(l=>"$d:"+c+":"+ee(l))(Ft(1,a-1|0)),d=[i.from.node,...f,i.to.node];return{...r,layers:T(l=>_=>{const h=_._2,p=fd(u+_._1|0)(m=>[...m,h])(l);if(p.tag==="Nothing")return l;if(p.tag==="Just")return p._1;g()})(r.layers)(ve(Pn,Ft(1,a-1|0),f)),edges:[...r.edges,...ve(l=>_=>({id:c+":"+l+"->"+_,from:{node:l,port:i.from.port},to:{node:_,port:i.to.port},label:J}),d,Lt(1,d.length,d))],chains:[...r.chains,{edgeId:i.id,nodes:d}]}})({layers:n,edges:[],chains:[]})(e),Xo=(()=>{const t={eq:e=>n=>e._1===n._1&&(e._2==="North"?n._2==="North":e._2==="South"?n._2==="South":e._2==="East"?n._2==="East":e._2==="West"&&n._2==="West")};return{compare:e=>n=>{const r=S.compare(e._1)(n._1);if(r==="LT")return Je;if(r==="GT")return Te;if(e._2==="North")return n._2==="North"?De:Je;if(n._2==="North")return Te;if(e._2==="South")return n._2==="South"?De:Je;if(n._2==="South")return Te;if(e._2==="East")return n._2==="East"?De:Je;if(n._2==="East")return Te;if(e._2==="West"&&n._2==="West")return De;g()},Eq0:()=>t}})(),Hy=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=Xo.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Wy=te(S)(zt),Hs=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Oy=te(Xo)(zt),rf=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),Yr=t=>e=>n=>r=>{const i=Hy(b(e,n))(t);if(i.tag==="Nothing")return r;if(i.tag==="Just")return i._1;g()},of=t=>e=>n=>{const r=Wy(We(O(u=>Bt(s=>a=>b(a,s))(u))(t))),i=(u,s)=>{if(u==="South"){const a=Hs(s.to.node)(r);if(a.tag==="Nothing")return 0;if(a.tag==="Just")return a._1;g()}if(u==="North"){const a=Hs(s.from.node)(r);if(a.tag==="Nothing")return 0;if(a.tag==="Just")return a._1;g()}return 0},o=u=>T(s=>a=>Se(Xo.compare,Ee,Oy(O(c=>b(b(c._1,u),c._2))(rf(Zg({lo:0,hi:(()=>{const c=Hs(a._1)(n);if(c.tag==="Just")return c._1._1;if(c.tag==="Nothing")return ye(3)(a._1)==="$d:"?0:1;g()})()})(O(c=>c.id)(Et(c=>f=>nt.compare(i(u,c))(i(u,f)))(a._2)))))),s))(A)(rf(T(s=>a=>a.from.node===a.to.node?s:u==="South"?bt(S)(re)(a.from.node)([a])(s):u==="North"?bt(S)(re)(a.to.node)([a])(s):s)(A)(e)));return Se(Xo.compare,Ee,o(le),o(he))},uf=t=>t,sf=t=>t,af=t=>t,Yy=T(t=>e=>tt(S)(e)()(t))(A),$y=(()=>{const t=Ue.unfoldr(e=>{if(e.tag==="Nil")return J;if(e.tag==="Cons")return w("Just",b(e._1,e._2));g()});return e=>t((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._3,n(r._6,i)));g()};return n(e,Xt)})())})(),rt=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},on=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Tn=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},wn=te(S)(zt),Ws=sc(S),Os=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),qy=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Xy=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},cf=af("VDown"),gf=af("VUp"),Vy=sf("ForwardPhase"),Uy=sf("StackPhase"),ff=uf("HRight"),_f=uf("HLeft"),df=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Ky=t=>e=>n=>{const r=T(u=>s=>bt(S)(se)(s.tgt)(1)(u))(A)(t),i=$y(Yy([...O(u=>u.src)(t),...O(u=>u.tgt)(t),...(()=>{const u=(s,a)=>{if(s.tag==="Leaf")return a;if(s.tag==="Node")return u(s._5,$t("Cons",s._4,u(s._6,a)));g()};return Ct(Vt.foldr,u(e,Xt))})()])),o=T(u=>s=>bt(S)(re)(s.src)([{target:s.tgt,sep:s.sep}])(u))(A)(t);return(u=>s=>a=>{let c=u,f=s,d=a,l=!0,_;for(;l;){const h=c,p=f,m=d,y=Qt(x=>J,x=>N=>w("Just",{head:x,tail:N}),h);if(y.tag==="Nothing"){l=!1,_=m;continue}if(y.tag==="Just"){const x=rt(y._1.head)(m),N=(()=>{if(x.tag==="Nothing")return 0;if(x.tag==="Just")return x._1;g()})(),v=T(k=>L=>{const E=rt(L.target)(k.result),B=N+L.sep,q=rt(L.target)(k.indeg),j=(()=>{if(q.tag==="Nothing")return-1;if(q.tag==="Just")return q._1-1|0;g()})();return{newQueue:j===0?[...k.newQueue,L.target]:k.newQueue,result:tt(S)(L.target)((()=>{if(E.tag==="Nothing")return B;if(E.tag==="Just"){if(n==="VDown")return on(E._1)(B);if(n==="VUp")return Tn(E._1)(B)}g()})())(k.result),indeg:tt(S)(L.target)(j)(k.indeg)}})({newQueue:[],result:m,indeg:p})((()=>{const k=rt(y._1.head)(o);if(k.tag==="Nothing")return[];if(k.tag==="Just")return k._1;g()})());c=[...y._1.tail,...v.newQueue],f=v.indeg,d=v.result;continue}g()}return _})(at(u=>{const s=rt(u)(r);if(s.tag==="Nothing")return!0;if(s.tag==="Just")return s._1===0;g()},i))(r)(T(u=>s=>tt(S)(s)(0)(u))(A)(i))},Zy=t=>{const e=(o,u)=>{if(o.tag==="Leaf")return u;if(o.tag==="Node")return e(o._5,$t("Cons",o._4,e(o._6,u)));g()},n=Ct(Vt.foldr,e(t,Xt)),r=T(on)(999999)(n);if(r===0||n.length===0)return t;const i=o=>{if(o.tag==="Leaf")return A;if(o.tag==="Node")return Yt("Node",o._1,o._2,o._3,o._4-r,i(o._5),i(o._6));g()};return i(t)},lf=t=>{const e=(o,u)=>{if(o.tag==="Leaf")return u;if(o.tag==="Node")return e(o._5,$t("Cons",o._4,e(o._6,u)));g()},n=e(t,Xt),r=o=>u=>{let s=o,a=u,c=!0,f;for(;c;){const d=s,l=a;if(l.tag==="Nil"){c=!1,f=d;continue}if(l.tag==="Cons"){s=Tn(d)(l._1),a=l._2;continue}g()}return f},i=o=>u=>{let s=o,a=u,c=!0,f;for(;c;){const d=s,l=a;if(l.tag==="Nil"){c=!1,f=d;continue}if(l.tag==="Cons"){s=on(d)(l._1),a=l._2;continue}g()}return f};return r(-999999)(n)-i(999999)(n)},Qi=t=>e=>(n=>r=>{let i=n,o=r,u=!0,s;for(;u;){const a=i,c=o;if(a===e){u=!1,s=c;continue}i=(()=>{const f=rt(a)(t.align);if(f.tag==="Nothing")return e;if(f.tag==="Just")return f._1;g()})(),o=[...c,a]}return s})((()=>{const n=rt(e)(t.align);if(n.tag==="Nothing")return e;if(n.tag==="Just")return n._1;g()})())([e]),jy=t=>e=>n=>r=>i=>o=>u=>s=>a=>c=>f=>{const d=(C,D,F)=>{const I=C.from.node===D?C.from.port:C.to.node===D?C.to.port:J;if(I.tag==="Just"){const z=rt(D)(i);if(z.tag==="Just"){const $=Kt(X=>X.id===I._1)(z._1);if($.tag==="Just"){const X=et($._1.offset)*et(4);return F==="North"||F==="South"?X:0}if($.tag==="Nothing"){const X=rt(D)(r),Y=Yr(u)(C.id)(F)((()=>{if(X.tag==="Nothing")return .5;if(X.tag==="Just")return X._1._1/2;g()})());return F==="North"||F==="South"?Y:0}g()}if(z.tag==="Nothing"){const $=rt(D)(r),X=Yr(u)(C.id)(F)((()=>{if($.tag==="Nothing")return .5;if($.tag==="Just")return $._1._1/2;g()})());return F==="North"||F==="South"?X:0}g()}if(I.tag==="Nothing"){const z=rt(D)(r),$=Yr(u)(C.id)(F)((()=>{if(z.tag==="Nothing")return .5;if(z.tag==="Just")return z._1._1/2;g()})());return F==="North"||F==="South"?$:0}g()},l=(C,D)=>{if(C.from.node===D){if(f==="HRight")return he;if(f==="HLeft")return le;g()}if(f==="HRight")return le;if(f==="HLeft")return he;g()},_=(C,D,F)=>T(I=>z=>tt(S)(z)((()=>{const $=rt(z)(I);if($.tag==="Nothing")return 0+D;if($.tag==="Just")return $._1+D;g()})())(I))(F)(Qi(a)(C)),h=(()=>{if(f==="HRight")return n;if(f==="HLeft")return we(n);g()})(),p=C=>{const D=rt(C)(r);if(D.tag==="Nothing")return 1;if(D.tag==="Just")return D._1._1;g()},m=wn(We(Bt(C=>D=>O(F=>b(F,C))(D))(n))),y=(C,D)=>ye(3)(C)==="$d:"&&ye(3)(D)==="$d:"||ye(3)(C)==="$d:"||ye(3)(D)==="$d:"?10:et(t.nodeGap),x=T(C=>D=>Ws(F=>w("Just",[...(()=>{if(F.tag==="Nothing")return[];if(F.tag==="Just")return F._1;g()})(),D]))(D.to.node)(C))(A)(o),N=T(C=>D=>Ws(F=>w("Just",[...(()=>{if(F.tag==="Nothing")return[];if(F.tag==="Just")return F._1;g()})(),D]))(D.from.node)(C))(A)(o),v=We(n),k=T(C=>D=>{const F=rt(D)(a.root),I=(()=>{if(F.tag==="Nothing")return D;if(F.tag==="Just")return F._1;g()})();return D===I?C:Ws(z=>w("Just",(()=>{if(z.tag==="Nothing")return!0;if(z.tag==="Just")return z._1;g()})()&&ye(3)(D)==="$d:"))(I)(C)})(wn(O(C=>b(C,!0))(Cr(S.compare)((()=>{const C=(D,F)=>{if(D.tag==="Leaf")return F;if(D.tag==="Node")return C(D._5,$t("Cons",D._4,C(D._6,F)));g()};return Ct(Vt.foldr,C(a.root,Xt))})()))))(v),L=(C,D)=>{const F=C.free,I=rt(F)(a.root),z=(()=>{if(I.tag==="Nothing")return F;if(I.tag==="Just")return I._1;g()})(),$=rt(z)(k),X=(()=>{if($.tag==="Nothing")return!0;if($.tag==="Just")return $._1;g()})();return T(Y=>W=>{if(Y.edge.tag==="Just")return Y;if(Y.edge.tag==="Nothing"){if((()=>{const gt=rt(z)(D.su);return!X&&(()=>{const yt=rt(W.from.node)(m);return W.from.node!==W.to.node&&(()=>{const St=rt(W.to.node)(m);return(()=>{if(yt.tag==="Nothing")return-1;if(yt.tag==="Just")return yt._1;g()})()===(()=>{if(St.tag==="Nothing")return-1;if(St.tag==="Just")return St._1;g()})()})()})()||(()=>{if(gt.tag==="Nothing")return!1;if(gt.tag==="Just")return gt._1;g()})()})())return Y;const K=W.from.node===F?W.to.node:W.from.node,Z=rt(K)(a.root),ct=(()=>{if(Z.tag==="Nothing")return K;if(Z.tag==="Just")return Z._1;g()})(),_t=ct!==z;return _t&&(()=>{const gt=rt(ct)(D.blockFinished);if(gt.tag==="Nothing")return!1;if(gt.tag==="Just")return gt._1;g()})()?{...Y,edge:w("Just",W),hasEdges:!0}:{...Y,hasEdges:Y.hasEdges||_t}}g()})({edge:J,hasEdges:!1})((()=>{if(C.isRoot){if(f==="HRight"){const Y=rt(F)(x);if(Y.tag==="Nothing")return[];if(Y.tag==="Just")return Y._1;g()}if(f==="HLeft"){const Y=rt(F)(N);if(Y.tag==="Nothing")return[];if(Y.tag==="Just")return Y._1}g()}if(f==="HRight"){const Y=rt(F)(N);if(Y.tag==="Nothing")return[];if(Y.tag==="Just")return Y._1;g()}if(f==="HLeft"){const Y=rt(F)(x);if(Y.tag==="Nothing")return[];if(Y.tag==="Just")return Y._1}g()})())},E=(C,D,F,I)=>{const z=(()=>{if(c==="VDown")return-1e18;if(c==="VUp")return 1e18;g()})(),$={free:D,isRoot:F},X=L($,I);if(X.edge.tag==="Nothing")return X.hasEdges?{thresh:z,state:{...I,queue:[...I.queue,$]}}:{thresh:z,state:I};if(X.edge.tag==="Just"){const Y=X.edge._1.from.node===D?X.edge._1.to.node:X.edge._1.from.node;return{thresh:(()=>{const W=rt((()=>{const _t=rt(Y)(a.root);if(_t.tag==="Nothing")return Y;if(_t.tag==="Just")return _t._1;g()})())(I.x),K=rt(Y)(s),Z=rt(D)(s),ct=(()=>{if(W.tag==="Just")return W._1;if(W.tag==="Nothing")return J;g()})();return(()=>{if(ct.tag==="Nothing")return 0;if(ct.tag==="Just")return ct._1;g()})()+(()=>{if(K.tag==="Nothing")return 0;if(K.tag==="Just")return K._1;g()})()+d(X.edge._1,Y,(()=>{if(F){if(f==="HRight")return he;if(f==="HLeft")return le;g()}if(f==="HRight")return le;if(f==="HLeft")return he;g()})())-(()=>{if(Z.tag==="Nothing")return 0;if(Z.tag==="Just")return Z._1;g()})()-d(X.edge._1,D,(()=>{if(F){if(f==="HRight")return le;if(f==="HLeft")return he;g()}if(f==="HRight")return he;if(f==="HLeft")return le;g()})())})(),state:{...I,su:tt(S)((()=>{const W=rt(X.edge._1.from.node)(a.root);if(W.tag==="Nothing")return X.edge._1.from.node;if(W.tag==="Just")return W._1;g()})())(!0)(tt(S)((()=>{const W=rt(X.edge._1.to.node)(a.root);if(W.tag==="Nothing")return X.edge._1.to.node;if(W.tag==="Just")return W._1;g()})())(!0)(I.su))}}}g()},B=(C,D,F,I)=>{const z=D===C,$=rt(D)(a.align),X=(()=>{if($.tag==="Nothing")return D===C;if($.tag==="Just")return $._1===C;g()})();if(!(z||X))return{thresh:F,state:I};const Y=(()=>{if(c==="VDown")return z&&F<=-1e18;if(c==="VUp")return z&&F>=1e18;g()})()?E(C,D,!0,I):{thresh:F,state:I};return(()=>{if(c==="VDown")return Y.thresh<=-1e18&&X;if(c==="VUp")return Y.thresh>=1e18&&X;g()})()?E(C,D,!1,Y.state):Y},q=C=>D=>F=>{const I=rt(F)(e.nodeIndex),z=(()=>{if(I.tag==="Nothing")return 0;if(I.tag==="Just")return I._1;g()})(),$=Kt(Z=>Ye(dn)(F)(Z))(h),X=(()=>{if($.tag==="Nothing")return[];if($.tag==="Just")return $._1;g()})(),Y=X.length;if((()=>{if(c==="VDown")return z<=0;if(c==="VUp")return z>=(Y-1|0);g()})()){const Z=B(C,F,D.thresh,D.st);return{...D,st:Z.state,thresh:Z.thresh}}const W=(()=>{if(c==="VDown")return z-1|0;if(c==="VUp")return z+1|0;g()})(),K=W>=0&&W<X.length?w("Just",X[W]):J;if(K.tag==="Nothing")return D;if(K.tag==="Just"){const Z=rt(K._1)(a.root),ct=(()=>{if(Z.tag==="Nothing")return K._1;if(Z.tag==="Just")return Z._1;g()})(),_t=B(C,F,D.thresh,j(ct)(D.st)),gt=(()=>{const kt=rt(C)(_t.state.sink);if(kt.tag==="Nothing")return C===C;if(kt.tag==="Just")return kt._1===C;g()})()?{..._t.state,sink:tt(S)(C)((()=>{const kt=rt(ct)(_t.state.sink);if(kt.tag==="Nothing")return ct;if(kt.tag==="Just")return kt._1;g()})())(_t.state.sink)}:_t.state,yt=rt(ct)(gt.sink),St=(()=>{if(yt.tag==="Nothing")return ct;if(yt.tag==="Just")return yt._1;g()})(),Ht=rt(C)(gt.sink),pt=(()=>{if(Ht.tag==="Nothing")return C;if(Ht.tag==="Just")return Ht._1;g()})();if(pt===St){const kt=rt(ct)(gt.x),Ot=(()=>{if(kt.tag==="Just")return kt._1;if(kt.tag==="Nothing")return J;g()})(),_n=(()=>{if(Ot.tag==="Nothing")return 0;if(Ot.tag==="Just")return Ot._1;g()})(),Fe=rt(C)(gt.x),Pt=(()=>{if(Fe.tag==="Just")return Fe._1;if(Fe.tag==="Nothing")return J;g()})(),At=(()=>{if(Pt.tag==="Nothing")return 0;if(Pt.tag==="Just")return Pt._1;g()})(),Be=y(F,K._1),an=rt(K._1)(s),Xe=rt(F)(s),nn=(()=>{if(an.tag==="Nothing")return 0;if(an.tag==="Just")return an._1;g()})()-(()=>{if(Xe.tag==="Nothing")return 0;if(Xe.tag==="Just")return Xe._1;g()})();if(c==="VDown"){const Pe=Tn(_n+nn+p(K._1)+Be)(_t.thresh);return{st:{...gt,x:tt(S)(C)(w("Just",D.initial?Pe:Tn(At)(Pe)))(gt.x)},initial:!1,thresh:_t.thresh}}if(c==="VUp"){const Pe=on(_n+nn-Be-p(F))(_t.thresh);return{st:{...gt,x:tt(S)(C)(w("Just",D.initial?Pe:on(At)(Pe)))(gt.x)},initial:!1,thresh:_t.thresh}}g()}const Wt=rt(ct)(gt.x),Tt=(()=>{if(Wt.tag==="Just")return Wt._1;if(Wt.tag==="Nothing")return J;g()})(),mt=(()=>{if(Tt.tag==="Nothing")return 0;if(Tt.tag==="Just")return Tt._1;g()})(),ft=rt(C)(gt.x),ot=(()=>{if(ft.tag==="Just")return ft._1;if(ft.tag==="Nothing")return J;g()})(),dt=(()=>{if(ot.tag==="Nothing")return 0;if(ot.tag==="Just")return ot._1;g()})(),ut=et(t.nodeGap),st=rt(F)(s),Nt=rt(K._1)(s),Jt=(()=>{if(st.tag==="Nothing")return 0;if(st.tag==="Just")return st._1;g()})()-(()=>{if(Nt.tag==="Nothing")return 0;if(Nt.tag==="Just")return Nt._1;g()})();return{st:{...gt,classEdges:[...gt.classEdges,{src:pt,tgt:St,sep:(()=>{if(c==="VDown")return dt+Jt-mt-p(K._1)-ut;if(c==="VUp")return dt+Jt+p(F)+ut-mt;g()})()}]},initial:D.initial,thresh:_t.thresh}}g()},j=C=>D=>{const F=rt(C)(D.x),I=(()=>{if(F.tag==="Just")return F._1;if(F.tag==="Nothing")return J;g()})();if(I.tag==="Just")return D;if(I.tag==="Nothing"){const z=T(q(C))({st:{...D,x:tt(S)(C)(w("Just",0))(D.x)},initial:!0,thresh:(()=>{if(c==="VDown")return-1e18;if(c==="VUp")return 1e18;g()})()})(Qi(a)(C));return{...z.st,blockFinished:tt(S)(C)(!0)(z.st.blockFinished)}}g()},G=T(C=>D=>T(F=>I=>{const z=rt(I)(a.root),$=(()=>{if(z.tag==="Nothing")return I;if(z.tag==="Just")return z._1;g()})();return $===I?j($)(F):F})(C)((()=>{if(c==="VDown")return D;if(c==="VUp")return we(D);g()})()))({x:wn(O(C=>b(C,J))(v)),sink:wn(O(C=>b(C,C))(v)),classEdges:[],su:A,blockFinished:A,queue:[]})(h),P=Ky(G.classEdges)(G.sink)(c),V=(C,D,F,I)=>{const z=rt(D)(I),$=rt(D)(s);return(()=>{if(z.tag==="Nothing")return 0;if(z.tag==="Just")return z._1;g()})()+(()=>{if($.tag==="Nothing")return 0;if($.tag==="Just")return $._1;g()})()+d(C,D,F)},U=wn(O(C=>b(C,!0))(Cr(S.compare)((()=>{const C=(D,F)=>{if(D.tag==="Leaf")return F;if(D.tag==="Node")return C(D._5,$t("Cons",D._4,C(D._6,F)));g()};return Ct(Vt.foldr,C(a.root,Xt))})()))),M=C=>D=>F=>{const I=L(F,{su:D.su,blockFinished:U}),z={phase:C,ppFree:F.free,ppIsRoot:F.isRoot,edgeId:J,delta:0,avail:0,shift:0,freeSu:(()=>{const $=rt((()=>{const X=rt(F.free)(a.root);if(X.tag==="Nothing")return F.free;if(X.tag==="Just")return X._1;g()})())(D.su);if($.tag==="Nothing")return!1;if($.tag==="Just")return $._1;g()})(),hasEdges:I.hasEdges,candCount:(()=>{if(F.isRoot){if(f==="HRight"){const $=rt(F.free)(x);if($.tag==="Nothing")return 0;if($.tag==="Just")return $._1.length;g()}if(f==="HLeft"){const $=rt(F.free)(N);if($.tag==="Nothing")return 0;if($.tag==="Just")return $._1.length}g()}if(f==="HRight"){const $=rt(F.free)(N);if($.tag==="Nothing")return 0;if($.tag==="Just")return $._1.length;g()}if(f==="HLeft"){const $=rt(F.free)(x);if($.tag==="Nothing")return 0;if($.tag==="Just")return $._1.length}g()})()};if(I.edge.tag==="Nothing")return{...D,stack:[...D.stack,F],trace:[...D.trace,z],x:D.x};if(I.edge.tag==="Just"){const $=I.edge._1.from.node===F.free?b(I.edge._1.from.node,I.edge._1.to.node):b(I.edge._1.to.node,I.edge._1.from.node),X=V(I.edge._1,$._1,l(I.edge._1,$._1),D.x)-V(I.edge._1,$._2,l(I.edge._1,$._2),D.x),Y=rt($._1)(a.root),W=(()=>{if(Y.tag==="Nothing")return $._1;if(Y.tag==="Just")return Y._1;g()})(),K={...z,edgeId:w("Just",I.edge._1.id),delta:X};if(X>0&&X<1e300){const Z=T(gt=>yt=>{const St=rt(yt)(m),Ht=(()=>{if(St.tag==="Nothing")return-1;if(St.tag==="Just")return St._1;g()})();if(Ht>=0&&Ht<n.length){const Tt=n[Ht],mt=rt(yt)(e.nodeIndex),ft=(()=>{if(mt.tag==="Nothing")return-2;if(mt.tag==="Just")return mt._1-1|0;g()})();return ft>=0&&ft<Tt.length?on(gt)((()=>{const ot=rt(yt)(D.x),dt=rt(yt)(s),ut=rt(Tt[ft])(D.x),st=rt(Tt[ft])(s);return(()=>{if(ot.tag==="Nothing")return 0;if(ot.tag==="Just")return ot._1;g()})()+(()=>{if(dt.tag==="Nothing")return 0;if(dt.tag==="Just")return dt._1;g()})()-((()=>{if(ut.tag==="Nothing")return 0;if(ut.tag==="Just")return ut._1;g()})()+(()=>{if(st.tag==="Nothing")return 0;if(st.tag==="Just")return st._1;g()})()+p(Tt[ft])+y(yt,Tt[ft]))})()):gt}const pt=rt(yt)(e.nodeIndex),Wt=(()=>{if(pt.tag==="Nothing")return-2;if(pt.tag==="Just")return pt._1-1|0;g()})();return Wt>=0&&Wt<0?on(gt)((()=>{const Tt=rt(yt)(D.x),mt=rt(yt)(s),ft=rt([][Wt])(D.x),ot=rt([][Wt])(s);return(()=>{if(Tt.tag==="Nothing")return 0;if(Tt.tag==="Just")return Tt._1;g()})()+(()=>{if(mt.tag==="Nothing")return 0;if(mt.tag==="Just")return mt._1;g()})()-((()=>{if(ft.tag==="Nothing")return 0;if(ft.tag==="Just")return ft._1;g()})()+(()=>{if(ot.tag==="Nothing")return 0;if(ot.tag==="Just")return ot._1;g()})()+p([][Wt])+y(yt,[][Wt]))})()):gt})(X)(Qi(a)(W)),ct=Z>0?-Z:0,_t={...D,x:Z>0?_(W,ct,D.x):D.x,trace:[...D.trace,{...K,avail:Z,shift:ct}]};return Z>0?_t:{..._t,stack:[..._t.stack,F]}}if(X<0&&-X<1e300){const Z=T(gt=>yt=>{const St=rt(yt)(m),Ht=(()=>{if(St.tag==="Nothing")return-1;if(St.tag==="Just")return St._1;g()})();if(Ht>=0&&Ht<n.length){const Tt=n[Ht],mt=rt(yt)(e.nodeIndex),ft=(()=>{if(mt.tag==="Nothing")return 0;if(mt.tag==="Just")return mt._1+1|0;g()})();return ft>=0&&ft<Tt.length?on(gt)((()=>{const ot=rt(Tt[ft])(D.x),dt=rt(Tt[ft])(s),ut=rt(yt)(D.x),st=rt(yt)(s);return(()=>{if(ot.tag==="Nothing")return 0;if(ot.tag==="Just")return ot._1;g()})()+(()=>{if(dt.tag==="Nothing")return 0;if(dt.tag==="Just")return dt._1;g()})()-((()=>{if(ut.tag==="Nothing")return 0;if(ut.tag==="Just")return ut._1;g()})()+(()=>{if(st.tag==="Nothing")return 0;if(st.tag==="Just")return st._1;g()})()+p(yt)+y(yt,Tt[ft]))})()):gt}const pt=rt(yt)(e.nodeIndex),Wt=(()=>{if(pt.tag==="Nothing")return 0;if(pt.tag==="Just")return pt._1+1|0;g()})();return Wt>=0&&Wt<0?on(gt)((()=>{const Tt=rt([][Wt])(D.x),mt=rt([][Wt])(s),ft=rt(yt)(D.x),ot=rt(yt)(s);return(()=>{if(Tt.tag==="Nothing")return 0;if(Tt.tag==="Just")return Tt._1;g()})()+(()=>{if(mt.tag==="Nothing")return 0;if(mt.tag==="Just")return mt._1;g()})()-((()=>{if(ft.tag==="Nothing")return 0;if(ft.tag==="Just")return ft._1;g()})()+(()=>{if(ot.tag==="Nothing")return 0;if(ot.tag==="Just")return ot._1;g()})()+p(yt)+y(yt,[][Wt]))})()):gt})(-X)(Qi(a)(W)),ct=Z>0?Z:0,_t={...D,x:Z>0?_(W,ct,D.x):D.x,trace:[...D.trace,{...K,avail:Z,shift:ct}]};return Z>0?_t:{..._t,stack:[..._t.stack,F]}}return{...D,stack:[...D.stack,F],trace:[...D.trace,K],x:D.x}}g()},H=T(M(Vy))({x:wn(O(C=>b(C,(()=>{const D=rt(C)(a.root),F=(()=>{if(D.tag==="Nothing")return C;if(D.tag==="Just")return D._1;g()})(),I=rt(F)(G.x),z=rt((()=>{const X=rt(F)(G.sink);if(X.tag==="Nothing")return F;if(X.tag==="Just")return X._1;g()})())(P),$=(()=>{if(I.tag==="Just")return I._1;if(I.tag==="Nothing")return J;g()})();return(()=>{if($.tag==="Nothing")return 0;if($.tag==="Just")return $._1;g()})()+(()=>{if(z.tag==="Nothing")return 0;if(z.tag==="Just")return z._1;g()})()})()))(v)),su:G.su,stack:[],trace:[]})(G.queue),R=T(M(Uy))({...H,stack:[]})(we(H.stack));return{x:R.x,queue:G.queue,trace:R.trace}},t2=t=>e=>n=>r=>i=>o=>u=>s=>a=>c=>f=>jy(t)(e)(n)(r)(i)(o)(u)(s)(a)(c)(f).x,e2=t=>e=>n=>r=>i=>o=>{const u=(a,c,f)=>{const d=rt(c)(n),l=(()=>{if(d.tag==="Nothing")return .5;if(d.tag==="Just")return d._1._1/2;g()})(),_=a.from.node===c?a.from.port:a.to.node===c?a.to.port:J;if(_.tag==="Just"){const h=rt(c)(e);if(h.tag==="Just"){const p=Kt(m=>m.id===_._1)(h._1);if(p.tag==="Just"){const m=et(p._1.offset)*et(4);return f==="North"||f==="South"?m:0}if(p.tag==="Nothing"){const m=Yr(i)(a.id)(f)(l);return f==="North"||f==="South"?m:0}g()}if(h.tag==="Nothing"){const p=Yr(i)(a.id)(f)(l);return f==="North"||f==="South"?p:0}g()}if(_.tag==="Nothing"){const h=Yr(i)(a.id)(f)(l);return f==="North"||f==="South"?h:0}g()},s=a=>c=>f=>d=>{let l=a,_=c,h=f,p=d,m=!0,y;for(;m;){const x=l,N=_,v=h,k=Qt(L=>J,L=>E=>w("Just",{head:L,tail:E}),p);if(k.tag==="Nothing"){m=!1,y=x;continue}if(k.tag==="Just"){const L=k._1.head,E=Kt(q=>q.from.node===v&&q.to.node===L||q.from.node===L&&q.to.node===v)(r),B=(()=>{if(E.tag==="Nothing")return N+0;if(E.tag==="Just")return N+(u(E._1,v,E._1.from.node===v?he:le)-u(E._1,L,E._1.from.node===L?he:le));g()})();l=tt(S)(L)(B)(x),_=B,h=L,p=k._1.tail;continue}g()}return y};return T(a=>c=>{const f=Qt(_=>J,_=>h=>w("Just",{head:_,tail:h}),Qi(t)(c)),d=(()=>{if(f.tag==="Nothing")return tt(S)(c)(0)(A);if(f.tag==="Just")return s(tt(S)(f._1.head)(0)(A))(0)(f._1.head)(f._1.tail);g()})(),l=T(_=>h=>Tn(_)(-h._2))(0)(Os(d));return T(_=>h=>tt(S)(h._1)(h._2+l)(_))(a)(Os(d))})(A)(Cr(S.compare)((()=>{const a=(c,f)=>{if(c.tag==="Leaf")return f;if(c.tag==="Node")return a(c._5,$t("Cons",c._4,a(c._6,f)));g()};return Ct(Vt.foldr,a(t.root,Xt))})()))},n2=t=>e=>{const n=(i,o,u)=>ye(3)(o)==="$d:"&&ja(nf,(()=>{const s=rt(o)(t.preds);if(s.tag==="Nothing")return[];if(s.tag==="Just")return s._1;g()})()),r=i=>o=>u=>s=>a=>c=>f=>{let d=i,l=o,_=s,h=c,p=f,m=!0,y;for(;m;){const x=d,N=l,v=_,k=h,L=p,E=N.length;if(L>=E){m=!1,y=x;continue}const B=L>=0&&L<N.length?w("Just",N[L]):J,q=(()=>{if(B.tag==="Nothing")return"";if(B.tag==="Just")return B._1;g()})(),j=n(t,q);if(L===(E-1|0)||j){const G=(()=>{if(j){const P=rt(q)(t.preds),V=(()=>{if(P.tag==="Nothing")return[];if(P.tag==="Just")return P._1;g()})();if(0<V.length){const U=v-1|0,M=rt(V[0])(t.nodeIndex);if(M.tag==="Nothing")return U;if(M.tag==="Just")return M._1;g()}}return v-1|0})();d=T(P=>V=>{if(V>=0&&V<N.length){const U=N[V];return n(t,U)?P:T(M=>H=>{const R=rt(H)(t.nodeIndex),C=(()=>{if(R.tag==="Nothing")return 0;if(R.tag==="Just")return R._1;g()})();return C<k||C>G?tt(S)(H+"\u2192"+U)()(M):M})(P)((()=>{const M=rt(U)(t.preds);if(M.tag==="Nothing")return[];if(M.tag==="Just")return M._1;g()})())}return n(t,"")?P:T(U=>M=>{const H=rt(M)(t.nodeIndex),R=(()=>{if(H.tag==="Nothing")return 0;if(H.tag==="Just")return H._1;g()})();return R<k||R>G?tt(S)(M+"\u2192")()(U):U})(P)((()=>{const U=rt("")(t.preds);if(U.tag==="Nothing")return[];if(U.tag==="Just")return U._1;g()})())})(x)(Ft(0,L)),l=N,_=v,h=G,p=L+1|0;continue}d=x,l=N,_=v,h=k,p=L+1|0}return y};return e.length<3?A:T(i=>o=>{if(o>=0&&o<e.length){const u=e[o];return r(i)((()=>{const s=o+1|0;return s>=0&&s<e.length?e[s]:[]})())(u)(u.length)(o)(0)(0)}return r(i)((()=>{const u=o+1|0;return u>=0&&u<e.length?e[u]:[]})())([])(0)(o)(0)(0)})(A)(Ft(1,e.length-2|0))},r2=t=>e=>n=>r=>i=>{const o=We(e),u=T(s=>a=>{const c=T(f=>d=>{const l=(()=>{if(i==="HRight"){const m=rt(d)(t.preds);if(m.tag==="Nothing")return[];if(m.tag==="Just")return m._1;g()}if(i==="HLeft"){const m=rt(d)(t.succs);if(m.tag==="Nothing")return[];if(m.tag==="Just")return m._1}g()})(),_=l.length;if(_===0)return f;const h=Gn(_-1|0,2),p=Gn(_,2);return T(m=>y=>{if((()=>{const x=rt(d)(m.align);if(x.tag==="Nothing")return d!==d;if(x.tag==="Just")return x._1!==d;g()})())return m;if(y>=0&&y<l.length){const x=rt(l[y])(t.nodeIndex),N=(()=>{if(x.tag==="Nothing")return 0;if(x.tag==="Just")return x._1;g()})();if(!(df(l[y]+"\u2192"+d)(n)||df(d+"\u2192"+l[y])(n))&&(()=>{if(r==="VDown")return m.r<N;if(r==="VUp")return m.r>N;g()})()){const v=rt(l[y])(m.root),k=(()=>{if(v.tag==="Nothing")return l[y];if(v.tag==="Just")return v._1;g()})();return{root:tt(S)(d)(k)(m.root),align:tt(S)(l[y])(d)(tt(S)(d)(k)(m.align)),r:N}}}return m})(f)((()=>{if(r==="VDown")return Ft(h,p);if(r==="VUp")return we(Ft(h,p));g()})())})({root:s.root,align:s.align,r:(()=>{if(r==="VDown")return-1;if(r==="VUp")return 999999;g()})()})((()=>{if(r==="VDown")return a;if(r==="VUp")return we(a);g()})());return{root:c.root,align:c.align}})({root:wn(O(s=>b(s,s))(o)),align:wn(O(s=>b(s,s))(o))})((()=>{if(i==="HRight")return e;if(i==="HLeft")return we(e);g()})());return{root:u.root,align:u.align}},Vo=t=>e=>n=>r=>i=>o=>u=>s=>a=>c=>{const f=r2(e)(n)(s)(a)(c),d=e2(f)(i)(r)(o)(u)(c);return vd()(l=>_=>w("Just",(()=>{const h=rt(l)(d);if(h.tag==="Nothing")return _+0;if(h.tag==="Just")return _+h._1;g()})()))(t2(t)(e)(n)(r)(i)(o)(u)(d)(f)(a)(c))},hf=t=>e=>Bt(n=>r=>T(i=>o=>o>=0&&o<e.length?o>=0&&o<t.length?i+e[o]+t[o]:i+e[o]+0:o>=0&&o<t.length?i+1+t[o]:i+1)(0)((()=>{const i=Ft(0,e.length-1|0);return n<1?[]:Lt(0,n,i)})()))(e),i2=t=>e=>n=>r=>i=>o=>u=>{const s=qy(0)(e.length-1|0),a=et(t.layerGap),c=u(sd(s,a)),f=uy(jg(i)(c)(r)(o)(A))(c);return O(d=>{const l=Xy(d)(f);return l.tag==="Just"&&l._1>0?Tn(a)(2+et(l._1-1|0)*2.5):a})(Ft(0,s-1|0))},pf=t=>e=>n=>r=>ja(i=>T(o=>u=>{if(!o.ok)return o;const s=rt(u)(r),a=(()=>{if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})(),c=rt(u)(n),f=(()=>{if(c.tag==="Nothing")return a+1;if(c.tag==="Just")return a+c._1._1;g()})();return a+1e-4>o.pos&&f+1e-4>o.pos?{ok:!0,pos:f}:{ok:!1,pos:o.pos}})({ok:!0,pos:-1e18})(i).ok,e),o2=t=>e=>n=>r=>{const i=Et(o=>u=>it.compare(o.w)(u.w))(O(o=>({l:o,w:lf(o)}))(at(pf()(e)(n),r)));return 0<i.length?w("Just",i[0].l):J},u2=t=>e=>{const n=wn(We(O(Bt(i=>o=>b(o,i)))(t))),r=i=>Et(o=>u=>nt.compare((()=>{const s=rt(o)(n);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})())((()=>{const s=rt(u)(n);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})()))(i);return{preds:(()=>{const i=o=>{if(o.tag==="Leaf")return A;if(o.tag==="Node")return Yt("Node",o._1,o._2,o._3,r(o._4),i(o._5),i(o._6));g()};return i(T(o=>u=>bt(S)(re)(u.to.node)([u.from.node])(o))(A)(e))})(),succs:(()=>{const i=o=>{if(o.tag==="Leaf")return A;if(o.tag==="Node")return Yt("Node",o._1,o._2,o._3,r(o._4),i(o._5),i(o._6));g()};return i(T(o=>u=>bt(S)(re)(u.from.node)([u.to.node])(o))(A)(e))})(),nodeIndex:n}},s2=t=>e=>{const n=Et(d=>l=>it.compare(d.w)(l.w))(Bt(d=>l=>({i:d,l,w:lf(l)}))(e)),r=0<n.length?w("Just",n[0]):J,i=(()=>{if(r.tag==="Just")return r._1.i;if(r.tag==="Nothing")return 0;g()})(),o=i>=0&&i<e.length?w("Just",e[i]):J,u=(()=>{if(o.tag==="Just")return(d=>l=>{let _=d,h=l,p=!0,m;for(;p;){const y=_,x=h;if(x.tag==="Nil"){p=!1,m=y;continue}if(x.tag==="Cons"){_=on(y)(x._1),h=x._2;continue}g()}return m})(999999)((()=>{const d=(l,_)=>{if(l.tag==="Leaf")return _;if(l.tag==="Node")return d(l._5,$t("Cons",l._4,d(l._6,_)));g()};return d(o._1,Xt)})());if(o.tag==="Nothing")return 0;g()})(),s=d=>T(l=>_=>Tn(l)((()=>{const h=rt(_._1)(t);if(h.tag==="Nothing")return _._2+1;if(h.tag==="Just")return _._2+h._1._1;g()})()))(-999999)(Os(d)),a=i>=0&&i<e.length?w("Just",e[i]):J,c=(()=>{if(a.tag==="Just")return s(a._1);if(a.tag==="Nothing")return 0;g()})(),f=ve(d=>l=>{const _=h=>{if(h.tag==="Leaf")return A;if(h.tag==="Node")return Yt("Node",h._1,h._2,h._3,h._4+l,_(h._5),_(h._6));g()};return _(d)},e,Bt(d=>l=>Un(d)(2)===0?u-(_=>h=>{let p=_,m=h,y=!0,x;for(;y;){const N=p,v=m;if(v.tag==="Nil"){y=!1,x=N;continue}if(v.tag==="Cons"){p=on(N)(v._1),m=v._2;continue}g()}return x})(999999)((()=>{const _=(h,p)=>{if(h.tag==="Leaf")return p;if(h.tag==="Node")return _(h._5,$t("Cons",h._4,_(h._6,p)));g()};return _(l,Xt)})()):c-s(l))(e));return Zy(T(d=>l=>{const _=Et(it.compare)(xt(rt(l))(f));return tt(S)(l)(_.length===4?1<_.length&&2<_.length?(_[1]+_[2])/2:0:0<_.length?_[0]:0)(d)})(A)(Cr(S.compare)(We(O(d=>{const l=_=>{if(_.tag==="Leaf")return A;if(_.tag==="Node")return Yt("Node",_._1,_._2,_._3,void 0,l(_._5),l(_._6));g()};return Ct(Qe.foldr,l(d))})(f)))))},a2=t=>e=>n=>r=>i=>o=>{const u=u2(e)(i),s=n2(u)(e),a={nodeGap:t.nodeGap*4|0},c=Se(S.compare,Ee,wn(O(_=>b(_,b(1,1)))(at(nf,We(e)))),(()=>{const _=h=>{if(h.tag==="Leaf")return A;if(h.tag==="Node")return Yt("Node",h._1,h._2,h._3,b(h._4._1*et(4),h._4._2),_(h._5),_(h._6));g()};return _(n)})()),f=[Vo(a)(u)(e)(c)(r)(i)(o)(s)(cf)(ff),Vo(a)(u)(e)(c)(r)(i)(o)(s)(gf)(ff),Vo(a)(u)(e)(c)(r)(i)(o)(s)(cf)(_f),Vo(a)(u)(e)(c)(r)(i)(o)(s)(gf)(_f)],d=s2(c)(f);if(pf()(e)(c)(d))return d;const l=o2()(e)(c)(f);if(l.tag==="Just")return l._1;if(l.tag==="Nothing")return f[0];g()},c2=t=>e=>n=>r=>{const i=Va(J,Ha,o=>o.node===e?w("Just",o.position):J,t);if(i.tag==="Nothing")return t;if(i.tag==="Just"){const o=i._1;return O(u=>u.node===n?{...u,position:b(o._1+r._1,o._2+r._2)}:u)(t)}g()},g2=t=>e=>n=>r=>{const i=at(u=>Ye(dn)(u.node)(e),t),o=(()=>{if(n==="Vertical"){if(r==="Start")return T(u=>s=>on(u)(s.position._1))(99999)(i);if(r==="End")return T(u=>s=>Tn(u)(s.position._1))(0)(i);if(r==="Center"){const u=T(s=>a=>s+a.position._1)(0)(i);return i.length===0?0:u/et(i.length)}g()}if(n==="Horizontal"){if(r==="Start")return T(u=>s=>on(u)(s.position._2))(99999)(i);if(r==="End")return T(u=>s=>Tn(u)(s.position._2))(0)(i);if(r==="Center"){const u=T(s=>a=>s+a.position._2)(0)(i);return i.length===0?0:u/et(i.length)}}g()})();return O(u=>{if(Ye(dn)(u.node)(e)){if(n==="Vertical")return{...u,position:b(o,u.position._2)};if(n==="Horizontal")return{...u,position:b(u.position._1,o)};g()}return u})(t)},f2=t=>e=>T(n=>r=>r.tag==="AlignGroup"?g2(n)(r._1.nodes)(r._1.axis)(r._1.alignment):r.tag==="RelativePosition"?c2(n)(r._1.anchor)(r._1.target)(r._1.offset):n)(e)(t),_2=t=>e=>n=>r=>i=>o=>u=>s=>{const a=O(d=>T(l=>_=>Tn(l)((()=>{const h=rt(_)(r);if(h.tag==="Nothing")return 1;if(h.tag==="Just")return h._1._2;g()})()))(1)(d))(n),c=a2(t)(n)(r)(i)(o)(s),f=hf(i2(t)(n)(r)(i)(o)(u)(d=>{const l=hf(d)(a);return We(Bt(_=>h=>Bt(p=>m=>({node:m,position:b((()=>{const y=rt(m)(c);return(()=>{if(y.tag==="Nothing")return 0;if(y.tag==="Just")return y._1;g()})()/et(4)})(),_>=0&&_<l.length?l[_]:0),size:(()=>{const y=ye(3)(m)==="$d:"?b(0,1):b(1,1),x=rt(m)(r);if(x.tag==="Nothing")return y;if(x.tag==="Just")return x._1;g()})(),layer:_,order:p}))(h))(n))}))(a);return f2(e)(We(Bt(d=>l=>Bt(_=>h=>({node:h,position:b((()=>{const p=rt(h)(c);return(()=>{if(p.tag==="Nothing")return 0;if(p.tag==="Just")return p._1;g()})()/et(4)})(),d>=0&&d<f.length?f[d]:0),size:(()=>{const p=ye(3)(h)==="$d:"?b(0,1):b(1,1),m=rt(h)(r);if(m.tag==="Nothing")return p;if(m.tag==="Just")return m._1;g()})(),layer:d,order:_}))(l))(n)))},Ys=es(po)(pr(32)),mf=es(po)(pr(31)),Ri=(()=>{const t=Jl("25214903917");if(t.tag==="Nothing")return pc;if(t.tag==="Just")return t._1;g()})(),Mi=ts(es(po)(pr(48)))(po),d2=t=>{const e=Tl(t);return hi(mc((()=>{if(e.tag==="Nothing")return pc;if(e.tag==="Just")return e._1;g()})())(Ri))(Mi)},$s=pr(11),Uo=t=>e=>{const n=hi(lo(ho(e)(Ri))($s))(Mi);return b((()=>{const r=ic(ml(ns(n)(pr(48-t|0))));if(r.tag==="Nothing")return 0;if(r.tag==="Just")return r._1;g()})(),n)},l2=t=>{const e=Uo(26)(t),n=Uo(27)(e._2);return b((et(e._1)*Bu(2)(27)+et(n._1))/Bu(2)(53),n._2)},h2=t=>e=>{const n=T(r=>i=>{const o=l2(r.finalR);return{rs:[...r.rs,o._1],finalR:o._2}})({rs:[],finalR:t})(e);return b(O(r=>r.x)(Et(r=>i=>it.compare(r.k)(i.k))(ve(r=>i=>({x:r,k:i}),e,n.rs))),n.finalR)},p2=t=>{const e=hi(lo(ho(t)(Ri))($s))(Mi),n=hi(lo(ho(e)(Ri))($s))(Mi);return b(lo(ho((()=>{const r=ns(e)(pr(16));return yc.compare(r)(mf)!=="LT"?ts(r)(Ys):r})())(Ys))((()=>{const r=ns(n)(pr(16));return yc.compare(r)(mf)!=="LT"?ts(r)(Ys):r})()),n)},zi=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Ko=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},qs=te(S)(zt),$r=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Zo=te(S)(zt),m2=Au(oi),y2=T(Gr)(0),x2=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},yf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},N2=t=>e=>n=>{if(t>=0&&t<n.length){const r=n[t];if(e>=0&&e<n.length){const i=Xn(Ut,J,t,n[e],n);if(i.tag==="Just")return Xn(Ut,J,e,r,i._1);if(i.tag==="Nothing")return J;g()}}return J},J2=t=>e=>n=>r=>i=>qs(T(o=>u=>{const s=Et(a=>c=>nt.compare((()=>{const f=zi(a.id)(i);if(f.tag==="Nothing")return 1e6;if(f.tag==="Just")return f._1;g()})())((()=>{const f=zi(c.id)(i);if(f.tag==="Nothing")return 1e6;if(f.tag==="Just")return f._1;g()})()))(at(a=>Ko(a.to.node)(n),at(a=>a.from.node===u,r)));return{ranks:[...o.ranks,...Bt(a=>c=>b(c.id,et((o.rankSum+a|0)+1|0)))(s)],rankSum:o.rankSum+s.length|0}})({ranks:[],rankSum:0})(t).ranks),T2=t=>e=>n=>r=>i=>qs(T(o=>u=>{const s=Et(c=>f=>{const d=nt.compare((()=>{const l=$r(f.from.node)(n);if(l.tag==="Nothing")return-1;if(l.tag==="Just")return l._1;g()})())((()=>{const l=$r(c.from.node)(n);if(l.tag==="Nothing")return-1;if(l.tag==="Just")return l._1;g()})());return d==="EQ"?nt.compare((()=>{const l=zi(c.id)(i);if(l.tag==="Nothing")return 1e6;if(l.tag==="Just")return l._1;g()})())((()=>{const l=zi(f.id)(i);if(l.tag==="Nothing")return 1e6;if(l.tag==="Just")return l._1;g()})()):d})(at(c=>Ko(c.from.node)(n),at(c=>c.to.node===u,r))),a=s.length;return{ranks:[...o.ranks,...Bt(c=>f=>b(f.id,et((o.rankSum+a|0)-c|0)))(s)],rankSum:o.rankSum+a|0}})({ranks:[],rankSum:0})(t).ranks),Xs=t=>e=>n=>{const r=Zo(Bt(s=>a=>b(a,s))(t)),i=Zo(Bt(s=>a=>b(a,s))(e)),o=xt(s=>{const a=$r(s.from.node)(r),c=$r(s.to.node)(i);if(a.tag==="Just"&&c.tag==="Just")return w("Just",b(a._1,c._1));const f=$r(s.from.node)(i),d=$r(s.to.node)(r);return f.tag==="Just"&&d.tag==="Just"?w("Just",b(d._1,f._1)):J})(n),u=o.length;return T(s=>a=>T(c=>f=>a>=0&&a<o.length&&f>=0&&f<o.length&&((o[a]._1-o[f]._1|0)*(o[a]._2-o[f]._2|0)|0)<0?c+1|0:c)(s)(Ft(a+1|0,u-1|0)))(0)(Ft(0,u-2|0))},w2=t=>e=>n=>r=>{const i=o=>u=>{let s=o,a=u,c=!0,f;for(;c;){const d=s,l=a;if(l>=(d.length-1|0)){c=!1,f=d;continue}if(l>=0&&l<d.length){const _=l+1|0;if(_>=0&&_<d.length){const h=d[l],p=d[_];if(Oe(N=>N.before===h&&N.after===p,r)){s=d,a=l+1|0;continue}const m=Xn(Ut,J,l,p,d),y=(()=>{if(m.tag==="Just")return Xn(Ut,J,l+1|0,h,m._1);if(m.tag==="Nothing")return J;g()})(),x=(()=>{if(y.tag==="Nothing")return d;if(y.tag==="Just")return y._1;g()})();if(Xs(e)(x)(n)<Xs(e)(d)(n)){s=x,a=l+1|0;continue}s=d,a=l+1|0;continue}c=!1,f=d;continue}c=!1,f=d}return f};return(o=>{let u=o,s=!0,a;for(;s;){const c=u,f=i(c)(0);if(m2(f)(c)){s=!1,a=c;continue}u=f}return a})(t)},jo=t=>e=>T(n=>r=>{if(r>=0&&r<t.length){const i=t[r],o=r+1|0;if(o>=0&&o<t.length)return n+Xs(i)(t[o])(e)|0}return n})(0)(Ft(0,t.length-2|0)),v2=(()=>{const t=e=>{if(e.length<7){const o=u=>s=>{let a=u,c=s,f=!0,d;for(;f;){const l=a,_=c,h=_-1|0;if(h>=0&&h<l.length){if(_>=0&&_<l.length&&_>0&&l[h].key>l[_].key){const p=N2(_-1|0)(_)(l);if(p.tag==="Just"){a=p._1,c=_-1|0;continue}if(p.tag==="Nothing"){f=!1,d=l;continue}g()}f=!1,d=l;continue}f=!1,d=l}return d};return T(u=>s=>o(u)(s))(e)(Ft(1,e.length-1|0))}const n=Gn(e.length,2),r=t(Lt(0,n,e)),i=t(Lt(n,e.length,e));return(o=>u=>s=>{let a=o,c=u,f=s,d=!0,l;for(;d;){const _=a,h=c,p=f;if(h>=0&&h<r.length){if(p>=0&&p<i.length){if(r[h].key>i[p].key){a=Rt(_)(i[p]),c=h,f=p+1|0;continue}a=Rt(_)(r[h]),c=h+1|0,f=p;continue}d=!1,l=[..._,...h<1?r:Lt(h,r.length,r)];continue}d=!1,l=[..._,...p<1?i:Lt(p,i.length,i)]}return l})([])(0)(0)};return t})(),b2=t=>e=>n=>{const r=xt(c=>c.tag==="OrderConstraint"?w("Just",{before:c._1.before,after:c._1.after}):J)(t.constraints),i=c=>T(f=>d=>{const l=d.after,_=d.before,h=gr(Ut,J,m=>m===_,f),p=gr(Ut,J,m=>m===l,f);if(h.tag==="Just"&&p.tag==="Just"&&h._1>p._1){const m=Za(Ut,J,h._1,f),y=(()=>{if(m.tag==="Nothing")return f;if(m.tag==="Just")return m._1;g()})(),x=Ka(Ut,J,p._1,_,y);if(x.tag==="Nothing")return y;if(x.tag==="Just")return x._1;g()}return f})(c)(r),o=qs(Bt(c=>f=>b(f.id,c))(n)),u=(c,f,d)=>{const l=c.length;return T(_=>h=>{const p=f?h-1|0:h+1|0,m=p>=0&&p<_._1.length?w("Just",_._1[p]):J;if(m.tag==="Just"){const y=h>=0&&h<_._1.length?w("Just",_._1[h]):J;if(y.tag==="Just"){const x=Zo(Bt(E=>B=>b(B,E))(m._1)),N=Zo(Bt(E=>B=>b(B,E))(y._1)),v=f?J2(m._1)(x)(N)(n)(o):T2(m._1)(x)(N)(n)(o),k=T(E=>B=>{const q=xt(G=>zi(G.id)(v))(at(f?G=>G.to.node===B._2&&Ko(G.from.node)(x):G=>G.from.node===B._2&&Ko(G.to.node)(x),n));if(q.length===0)return{...E,items:[...E.items,{n:B._2,key:J,origIdx:B._1}]};const j=Uo(24)(E.r);return{items:[...E.items,{n:B._2,key:w("Just",(y2(q)+(et(j._1)*4172325152040912e-24-.03500000014901161))/et(q.length)),origIdx:B._1}],r:j._2}})({items:[],r:_._2})(Bt(Pn)(y._1)),L=Xn(Ut,J,h,w2(i(O(E=>E.n)(v2((()=>{const E=k.items,B=q=>j=>{let G=q,P=j,V=!0,U;for(;V;){const M=G,H=P;if(M>=0&&M<E.length){if(E[M].key.tag==="Just"){V=!1,U=E[M].key._1;continue}if(E[M].key.tag==="Nothing"){G=M+1|0,P=H;continue}g()}V=!1,U=H}return U};return(q=>j=>G=>{let P=q,V=j,U=G,M=!0,H;for(;M;){const R=P,C=V,D=U;if(R>=0&&R<E.length){if(E[R].key.tag==="Just"){P=R+1|0,V=E[R].key._1,U=[...D,{n:E[R].n,key:E[R].key._1,origIdx:E[R].origIdx}];continue}if(E[R].key.tag==="Nothing"){const F=(C+B(R+1|0)(C+1))/2;P=R+1|0,V=F,U=[...D,{n:E[R].n,key:F,origIdx:E[R].origIdx}];continue}g()}M=!1,H=D}return H})(0)(-1)([])})()))))(m._1)(n)(r),_._1);if(L.tag==="Just")return b(L._1,k.r);if(L.tag==="Nothing")return b(_._1,_._2);g()}if(y.tag==="Nothing")return b(_._1,_._2);g()}if(m.tag==="Nothing")return b(_._1,_._2);g()})(b(c,d))(f?Ft(1,l-1|0):we(Ft(0,l-2|0)))},s=T(c=>f=>tt(S)(f.from.node)()(tt(S)(f.to.node)()(c)))(A)(n),a=T(c=>f=>{if(c.result.crossings===0)return c;const d=x=>N=>v=>k=>{let L=x,E=N,B=v,q=k,j=!0,G;for(;j;){const P=L,V=E,U=B,M=q;if(U===0){j=!1,G={layout:P,crossings:0,random:M};continue}const H=u(P,V,M),R=jo(H._1)(n);if(R<U){L=H._1,E=!V,B=R,q=H._2;continue}j=!1,G={layout:P,crossings:U,random:H._2}}return G},l=Uo(1)(c.result.random),_=l._1!==0,h=t.modelOrder.tag==="Leaf",p=(c.firstTry||c.secondTry)&&!h?c.firstTry:_,m=(()=>{if(!h){const k=u(e,p,l._2);return d(k._1)(!p)(jo(k._1)(n))(k._2)}const x=p?0:x2(0)(e.length-1|0),N=x>=0&&x<e.length?w("Just",e[x]):J;if(N.tag==="Just"&&N._1.length>1){const k=at(L=>yf(L)(s),N._1);if(k.length>1){const L=h2(l._2)(k),E=L._1,B=Xn(Ut,J,x,i(T(q=>j=>yf(j)(s)?q.idx>=0&&q.idx<E.length?{idx:q.idx+1|0,result:[...q.result,E[q.idx]]}:{idx:q.idx,result:[...q.result,j]}:{idx:q.idx,result:[...q.result,j]})({idx:0,result:[]})(N._1).result),e);if(B.tag==="Just"){const q=u(B._1,p,L._2);return d(q._1)(!p)(jo(q._1)(n))(q._2)}}}const v=u(e,p,l._2);return d(v._1)(!p)(jo(v._1)(n))(v._2)})(),y=c.secondTry?!1:c.secondTry;return c.firstTry?{result:m.crossings<c.result.crossings?{layout:m.layout,crossings:m.crossings,random:m.random}:{...c.result,random:m.random},firstTry:!1,secondTry:!0}:{result:m.crossings<c.result.crossings?{layout:m.layout,crossings:m.crossings,random:m.random}:{...c.result,random:m.random},firstTry:c.firstTry,secondTry:y}})({result:{layout:e,crossings:1e9,random:hi(mc(p2(d2(1))._1)(Ri))(Mi)},firstTry:t.modelOrder.tag!=="Leaf",secondTry:!1})(Ft(1,t.iterations)).result;return e.length<=0||t.iterations<=0?e:a.layout},k2=t=>t,xf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Me=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},qr=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Hi=(()=>{const t={eq:e=>n=>e._1===n._1&&e._2===n._2};return{compare:e=>n=>{const r=S.compare(e._1)(n._1);return r==="LT"?Je:r==="GT"?Te:S.compare(e._2)(n._2)},Eq0:()=>t}})(),L2=te(S)(zt),E2=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=Hi.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},C2=k2("Greedy"),Vs=t=>e=>n=>T(r=>i=>{if(i.from.node===i.to.node)return r;if(i.from.node===e&&!xf(i.to.node)(r.marks)){const o=Me(i.to.node)(r.inDeg),u=(()=>{if(o.tag==="Nothing")return-1;if(o.tag==="Just")return o._1-1|0;g()})(),s=tt(S)(i.to.node)(u)(r.inDeg);return(()=>{const a=Me(i.to.node)(r.outDeg);return u<=0&&(()=>{if(a.tag==="Nothing")return!1;if(a.tag==="Just")return a._1>0;g()})()&&!Ye(dn)(i.to.node)(r.sources)})()?{...r,inDeg:s,sources:[...r.sources,i.to.node]}:{...r,inDeg:s}}if(i.to.node===e&&!xf(i.from.node)(r.marks)){const o=Me(i.from.node)(r.outDeg),u=(()=>{if(o.tag==="Nothing")return-1;if(o.tag==="Just")return o._1-1|0;g()})(),s=tt(S)(i.from.node)(u)(r.outDeg);return(()=>{const a=Me(i.from.node)(r.inDeg);return u<=0&&(()=>{if(a.tag==="Nothing")return!1;if(a.tag==="Just")return a._1>0;g()})()&&!Ye(dn)(i.from.node)(r.sinks)})()?{...r,outDeg:s,sinks:[...r.sinks,i.from.node]}:{...r,outDeg:s}}return r})({...n,remaining:at(r=>r!==e,n.remaining)})(t),S2=T(t=>e=>{if(e.tag==="LayerConstraint"){if(e._1.pin.tag==="SpecificLayer")return tt(S)(e._1.node)(e._1.pin._1)(t);if(e._1.pin.tag==="FirstLayer")return tt(S)(e._1.node)(0)(t);if(e._1.pin.tag==="LastLayer")return tt(S)(e._1.node)(99999)(t)}return t})(A),Nf=t=>e=>n=>{const r=Me(e)(t),i=Me(n)(t);return r.tag==="Just"&&i.tag==="Just"&&r._1>i._1},Jf=t=>e=>n=>r=>{if(qr(n)(r.visited)||qr(n)(r.visiting))return r;const i=T(G2(t)(e)(n))({...r,visiting:tt(S)(n)()(r.visiting)})((()=>{const o=Me(n)(e);if(o.tag==="Nothing")return[];if(o.tag==="Just")return o._1;g()})());return{...i,visiting:si(S)(n)(i.visiting),visited:tt(S)(n)()(i.visited)}},G2=t=>e=>n=>r=>i=>Nf(t)(n)(i)?{...r,backEdges:tt(Hi)(b(n,i))()(r.backEdges)}:qr(i)(r.visiting)?{...r,backEdges:tt(Hi)(b(n,i))()(r.backEdges)}:qr(i)(r.visited)?r:Jf(t)(e)(i)(r),P2=t=>e=>n=>{const r=l=>{let _=l,h=!0,p;for(;h;){const m=_,y=Qt(x=>J,x=>N=>w("Just",{head:x,tail:N}),m.sinks);if(y.tag==="Just"){_=Vs(n)(y._1.head)({...m,sinks:y._1.tail,marks:tt(S)(y._1.head)(m.nextRight)(m.marks),nextRight:m.nextRight-1|0});continue}if(y.tag==="Nothing"){const x=Qt(N=>J,N=>v=>w("Just",{head:N,tail:v}),m.sources);if(x.tag==="Just"){_=Vs(n)(x._1.head)({...m,sources:x._1.tail,marks:tt(S)(x._1.head)(m.nextLeft)(m.marks),nextLeft:m.nextLeft+1|0});continue}if(x.tag==="Nothing"){const N=k=>{const L=Me(k)(m.outDeg),E=Me(k)(m.inDeg);return(()=>{if(L.tag==="Nothing")return 0;if(L.tag==="Just")return L._1;g()})()-(()=>{if(E.tag==="Nothing")return 0;if(E.tag==="Just")return E._1;g()})()|0},v=Et(k=>L=>{const E=nt.compare(N(L))(N(k));return E==="EQ"?nt.compare((()=>{const B=Me(k)(e);if(B.tag==="Nothing")return 1e6;if(B.tag==="Just")return B._1;g()})())((()=>{const B=Me(L)(e);if(B.tag==="Nothing")return 1e6;if(B.tag==="Just")return B._1;g()})()):E})(m.remaining);if(0<v.length){const k=v[0];_=Vs(n)(k)({...m,remaining:at(L=>L!==k,m.remaining),marks:tt(S)(k)(m.nextLeft)(m.marks),nextLeft:m.nextLeft+1|0});continue}h=!1,p=m;continue}}g()}return p},i=Cr(S.compare)([...O(l=>l.from.node)(n),...O(l=>l.to.node)(n)]),o=at(l=>l.from.node!==l.to.node,n),u=T(l=>_=>bt(S)(se)(_.to.node)(1)(l))(A)(o),s=T(l=>_=>bt(S)(se)(_.from.node)(1)(l))(A)(o),a=at(l=>{const _=Me(l)(u);if(_.tag==="Nothing")return!0;if(_.tag==="Just")return _._1===0;g()},i),c=at(l=>{const _=Me(l)(s);if(_.tag==="Nothing")return!0;if(_.tag==="Just")return _._1===0;g()},i),f=i.length+1|0,d=T(l=>_=>{const h=Me(_)(l);return h.tag==="Just"&&h._1<0?tt(S)(_)(h._1+f|0)(l):l})(r({remaining:at(l=>!Ye(dn)(l)(a)&&!Ye(dn)(l)(c),i),marks:A,inDeg:u,outDeg:s,sources:a,sinks:c,nextLeft:1,nextRight:-1}).marks)(i);return T(l=>_=>{if(_.from.node===_.to.node)return l;if(Nf(t)(_.from.node)(_.to.node))return tt(Hi)(b(_.from.node,_.to.node))()(l);const h=Me(_.from.node)(d),p=Me(_.to.node)(d);return h.tag==="Just"&&p.tag==="Just"&&h._1>p._1?tt(Hi)(b(_.from.node,_.to.node))()(l):l})(A)(n)},D2=T(t=>e=>bt(S)(re)(e.from.node)([e.to.node])(t))(A),I2=t=>e=>{const n=D2(e),r=Cr(S.compare)([...O(o=>o.from.node)(e),...O(o=>o.to.node)(e)]),i=T(o=>u=>tt(S)(u.to.node)()(o))(A)(e);return T(o=>u=>Jf(t)(n)(u)(o))({visiting:A,visited:A,backEdges:A})([...at(o=>!qr(o)(i),r),...at(o=>qr(o)(i),r)]).backEdges},A2=t=>e=>n=>r=>{const i=L2(Bt(s=>a=>b(a,s))(e)),o=S2(n),u=(()=>{if(t==="DepthFirst")return I2(o)(r);if(t==="Greedy")return P2(o)(i)(r);g()})();return{edges:O(s=>E2(b(s.from.node,s.to.node))(u)?{...s,from:s.to,to:s.from}:s)(r),reversedEdges:u}},Tf=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},F2=T(t=>e=>tt(S)(e)()(t))(A),tu=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},B2=Bg(S),vn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},wf=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Us=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Q2=te(nt)(zt),R2=t=>e=>Se(S.compare,Ee,t,e),vf=Bt(t=>e=>({src:e.src,tgt:e.tgt,delta:1,weight:1,eid:t})),M2=t=>T(e=>n=>({base:(()=>{const r=i=>o=>{let u=i,s=o,a=!0,c;for(;a;){const f=u,d=s;if(d.tag==="Nil"){a=!1,c=f;continue}if(d.tag==="Cons"){u=Tf(f)(d._1),s=d._2;continue}g()}return c};return(e.base+r(0)((()=>{const i=(o,u)=>{if(o.tag==="Leaf")return u;if(o.tag==="Node")return i(o._5,$t("Cons",o._4,i(o._6,u)));g()};return i(n,Xt)})())|0)+1|0})(),result:[...e.result,(()=>{if(e.base===0)return n;const r=i=>{if(i.tag==="Leaf")return A;if(i.tag==="Node")return Yt("Node",i._1,i._2,i._3,i._4+e.base|0,r(i._5),r(i._6));g()};return r(n)})()]}))({base:0,result:[]})(t).result,z2=t=>e=>{const n=F2(t);return B2(t)(vf(at(r=>tu(r.src)(n)&&tu(r.tgt)(n),e)))},H2=t=>e=>{const n=T(i=>o=>bt(S)(re)(o.tgt)([o.src])(bt(S)(re)(o.src)([o.tgt])(i)))(A)(e),r=i=>o=>u=>{let s=i,a=o,c=u,f=!0,d;for(;f;){const l=s,_=a,h=c,p=Qt(m=>J,m=>y=>w("Just",{head:m,tail:y}),l);if(p.tag==="Nothing"){f=!1,d={nodes:h};continue}if(p.tag==="Just"){if(tu(p._1.head)(_)){s=p._1.tail,a=_,c=h;continue}s=[...p._1.tail,...(()=>{const m=vn(p._1.head)(n);if(m.tag==="Nothing")return[];if(m.tag==="Just")return m._1;g()})()],a=tt(S)(p._1.head)()(_),c=[...h,p._1.head];continue}g()}return d};return T(i=>o=>{if(tu(o)(i.visited))return i;const u=r([o])(i.visited)([]);return{...i,visited:T(s=>a=>tt(S)(a)()(s))(i.visited)(u.nodes),components:[...i.components,u.nodes]}})({visited:A,components:[]})(t).components},W2=t=>e=>n=>{const r=T(o=>u=>bt(S)(se)(u.tgt)(1)(o))(A)(e),i=T(o=>u=>bt(S)(se)(u.src)(1)(o))(A)(e);return T(o=>u=>{const s=vn(u)(r),a=(()=>{if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})();if((()=>{const x=vn(u)(i);return(()=>{if(x.tag==="Nothing")return a!==0;if(x.tag==="Just")return a!==x._1;g()})()||a===0})())return o;const c=vn(u)(o.layers),f=(()=>{if(c.tag==="Nothing")return 0;if(c.tag==="Just")return c._1;g()})(),d=o.layers,l=T(x=>N=>N.tgt===u?{...x,mIn:wf(x.mIn)((()=>{const v=vn(u)(d),k=vn(N.src)(d);return(()=>{if(v.tag==="Nothing")return 0;if(v.tag==="Just")return v._1;g()})()-(()=>{if(k.tag==="Nothing")return 0;if(k.tag==="Just")return k._1;g()})()|0})())}:N.src===u?{...x,mOut:wf(x.mOut)((()=>{const v=vn(N.tgt)(d),k=vn(u)(d);return(()=>{if(v.tag==="Nothing")return 0;if(v.tag==="Just")return v._1;g()})()-(()=>{if(k.tag==="Nothing")return 0;if(k.tag==="Just")return k._1;g()})()|0})())}:x)({mIn:1e9,mOut:1e9})(e),_=l.mIn===1e9?-1:l.mIn,h=l.mOut===1e9?-1:l.mOut;if(_<0||h<0)return o;const p=(f-_|0)+1|0,m=(f+h|0)-1|0;if(m<p)return o;const y=T(x=>N=>{const v=Us(N)(o.filling),k=(()=>{if(v.tag==="Nothing")return 0;if(v.tag==="Just")return v._1;g()})();return k<x.bestFill?{best:N,bestFill:k}:x})({best:f,bestFill:(()=>{const x=Us(f)(o.filling);if(x.tag==="Nothing")return 0;if(x.tag==="Just")return x._1;g()})()})(Ft(p,m));return y.best===f?o:{layers:tt(S)(u)(y.best)(o.layers),filling:tt(nt)(f)((()=>{const x=Us(f)(o.filling);if(x.tag==="Nothing")return-1;if(x.tag==="Just")return x._1-1|0;g()})())(tt(nt)(y.best)(y.bestFill+1|0)(o.filling))}})({layers:n,filling:Q2(O(o=>b(o,T(u=>s=>(()=>{const a=vn(s)(n);return a.tag==="Nothing"?!1:a.tag==="Just"&&a._1===o})()?u+1|0:u)(0)(t)))(Ft(0,T(o=>u=>Tf(o)((()=>{const s=vn(u)(n);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})()))(0)(t))))})(t).layers},O2=t=>e=>W2(t)(vf(e))(T(R2)(A)(M2(O(n=>z2(n)(e))(H2(t)(e))))),Y2=t=>t,Nr=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},eu=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},bf=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),$2=Y2("NetworkSimplex"),q2=t=>e=>T(n=>r=>{const i=T(eu)(0)(xt(o=>Nr(o)(n))(r));return T(o=>u=>tt(S)(u)(i)(o))(n)(r)})(e)(t),X2=t=>e=>({layers:O(n=>at(r=>{const i=Nr(r)(e);return i.tag==="Nothing"?!1:i.tag==="Just"&&i._1===n},t))(Ft(0,(n=>r=>{let i=n,o=r,u=!0,s;for(;u;){const a=i,c=o;if(c.tag==="Nil"){u=!1,s=a;continue}if(c.tag==="Cons"){i=eu(a)(c._1),o=c._2;continue}g()}return s})(0)((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._4,n(r._6,i)));g()};return n(e,Xt)})()))),nodeLayer:e}),V2=t=>e=>n=>{const r=T(i=>o=>tt(S)(o)(!0)(i))(A)(e);return T(i=>o=>tt(S)(o._1)(o._2)(i))(O2(e)(xt(i=>i.from.node===i.to.node||(()=>{const o=Nr(i.from.node)(r);if(o.tag==="Nothing")return!0;if(o.tag==="Just")return!o._1;g()})()||(()=>{const o=Nr(i.to.node)(r);if(o.tag==="Nothing")return!0;if(o.tag==="Just")return!o._1;g()})()?J:w("Just",{src:i.from.node,tgt:i.to.node}))(t)))(bf(n))},U2=t=>e=>n=>r=>{const i=s=>a=>{const c=Nr(a)(s);if(c.tag==="Just")return s;if(c.tag==="Nothing"){const f=at(l=>l!==a,(()=>{const l=Nr(a)(t);if(l.tag==="Nothing")return[];if(l.tag==="Just")return l._1;g()})()),d=T(i)(s)(f);return tt(S)(a)(1+T(eu)(0)(xt(l=>Nr(l)(d))(f))|0)(d)}g()},o=T(i)(A)(n),u=(s=>a=>{let c=s,f=a,d=!0,l;for(;d;){const _=c,h=f;if(h.tag==="Nil"){d=!1,l=_;continue}if(h.tag==="Cons"){c=eu(_)(h._1),f=h._2;continue}g()}return l})(1)((()=>{const s=(a,c)=>{if(a.tag==="Leaf")return c;if(a.tag==="Node")return s(a._5,$t("Cons",a._4,s(a._6,c)));g()};return s(o,Xt)})());return T(s=>a=>tt(S)(a._1)(a._2)(s))((()=>{const s=a=>{if(a.tag==="Leaf")return A;if(a.tag==="Node")return Yt("Node",a._1,a._2,a._3,u-a._4|0,s(a._5),s(a._6));g()};return s(o)})())(bf(r))},K2=T(t=>e=>{if(e.tag==="LayerConstraint"){if(e._1.pin.tag==="SpecificLayer")return tt(S)(e._1.node)(e._1.pin._1)(t);if(e._1.pin.tag==="FirstLayer")return tt(S)(e._1.node)(0)(t)}return t})(A),Z2=T(t=>e=>bt(S)(re)(e.to.node)([e.from.node])(t))(A),j2=T(t=>e=>bt(S)(re)(e.from.node)([e.to.node])(t))(A),tx=t=>e=>n=>r=>{const i=j2(n),o=Z2(n),u=K2(e);return X2(r)(q2(xt(s=>s.tag==="SameLayer"?w("Just",s._1.nodes):J)(e))((()=>{if(t==="LongestPath")return U2(i)(o)(r)(u);if(t==="NetworkSimplex")return V2(n)(r)(u);g()})()))},ex=te(S)(zt),nx=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},kf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Lf=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Wi=te(S)(zt),rx=te(S)(zt),Ef=(()=>{const t=O(e=>({start:e.end,end:e.start,direction:e.direction}));return e=>we(t(e))})(),ix=t=>e=>n=>r=>{const i=ex(O(u=>b(u.edge,u))(r)),o=u=>0<u.nodes.length&&(()=>{const s=nx(u.edgeId)(n);return s.tag==="Just"&&u.nodes[0]!==s._1._1})();return O(u=>{if(u.nodes.length<=2){const f=kf(u.edgeId)(i);if(f.tag==="Just"){const d=o(u),l=Ai(Ii(d?Ef(f._1.segments):f._1.segments));return{...f._1,edge:u.edgeId,segments:l,bends:ve(_=>h=>_.end,l,Lt(1,l.length,l)),reversed:d}}if(f.tag==="Nothing")return{edge:u.edgeId,segments:[],bends:[],bendType:[],jumps:[],reversed:!1};g()}const s=wt(xt(f=>kf(f)(i))(ve(f=>d=>u.edgeId+":"+f+"->"+d,u.nodes,Lt(1,u.nodes.length,u.nodes))))(f=>f.segments),a=o(u),c=Ai(Ii(a?Ef(s):s));return{edge:u.edgeId,segments:c,bends:ve(f=>d=>f.end,c,Lt(1,c.length,c)),bendType:[],jumps:[],reversed:a}})(t)},ox={layers:[],edges:[],chains:[]},ux={nodeGap:3,layerGap:2,iterations:8,layerer:$2,cycleBreaker:C2,compactPostRouting:!0,compactionSpacings:Zm},sx=t=>({pos:b(0,0),size:b(T(e=>n=>Lf(e)(n.position._1+n.size._1))(0)(t),T(e=>n=>Lf(e)(n.position._2+n.size._2))(0)(t))}),ax=t=>e=>n=>{const r=Wi(O(c=>b(c.id,c.ports))(e.nodes)),i=at(c=>ye(3)(c.node)!=="$d:",n.placements),o=ix(n.withDummies.chains)(n.acyclic.reversedEdges)(rx(O(c=>b(c.id,b(c.from.node,c.to.node)))(e.edges)))(Dy(n.withDummies.edges)(n.placements)(r)(n.withDummies.chains)(of(n.ordered)(at(c=>c.from.node!==c.to.node,n.withDummies.edges))((()=>{const c=f=>{if(f.tag==="Leaf")return A;if(f.tag==="Node")return Yt("Node",f._1,f._2,f._3,b(f._4._1*4,f._4._2),c(f._5),c(f._6));g()};return c(Wi(O(f=>b(f.id,f.size))(e.nodes)))})()))),u=t.compactPostRouting?ey()(t.compactionSpacings)({nodes:i,edges:e.edges,paths:o,ports:r}):{nodes:i,edges:o},s=O(c=>{const f=Ai(Ii(c.segments));return{...c,segments:f,bends:ve(d=>l=>d.end,f,Lt(1,f.length,f))}})(u.edges),a=Bt(c=>f=>({...f,jumps:My(c)(f)(s)}))(s);return{nodes:u.nodes,edges:a,boundingBox:sx(u.nodes),metrics:Lp(u.nodes)(a)(0)}},cx=t=>e=>n=>{const r=Wi(O(o=>b(o.id,o.size))(e.nodes)),i={...n,placements:_2({nodeGap:t.nodeGap,layerGap:t.layerGap})(e.constraints)(n.ordered)(r)(Wi(O(o=>b(o.id,o.ports))(e.nodes)))(n.withDummies.edges)(n.withDummies.chains)(of(n.ordered)(n.withDummies.edges)((()=>{const o=u=>{if(u.tag==="Leaf")return A;if(u.tag==="Node")return Yt("Node",u._1,u._2,u._3,b(u._4._1*4,u._4._2),o(u._5),o(u._6));g()};return o(r)})()))};return{pipeline:i,result:ax(t)(e)(i)}},gx=t=>e=>n=>cx(t)(e)({...n,ordered:b2({iterations:t.iterations,constraints:e.constraints,modelOrder:Wi(Bt(r=>i=>b(i.id,r))(e.nodes))})(n.withDummies.layers)(n.withDummies.edges)}),fx=t=>e=>n=>gx(t)(e)({...n,withDummies:zy(n.layered.nodeLayer)(n.acyclic.edges)(n.layered.layers)}),_x=t=>e=>{const n=O(i=>i.id)(e.nodes),r=A2(t.cycleBreaker)(n)(e.constraints)(e.edges);return fx(t)(e)({acyclic:r,layered:tx(t.layerer)(e.constraints)(r.edges)(n),withDummies:ox,ordered:[],placements:[]})},nu=t=>t,dx=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Jr=nu("TopSide"),Tr=nu("BottomSide"),wr=nu("LeftSide"),vr=nu("RightSide"),lx=t=>{const e=it.compare(0)(t),n=(()=>{if(e==="LT")return t;if(e==="EQ"||e==="GT")return 0;g()})(),r=it.compare(1)(n);if(r==="LT"||r==="EQ")return 1;if(r==="GT")return n;g()},Cf=t=>e=>n=>{const r=dx(t.h*.12)(t.w*.2),i=t.w/2;return(e<0?t.y+r:t.y+t.h-r)+e*r*Ce(lx((()=>{const o=(n-(t.x+i))/i;return 1-o*o})()))},ze=t=>e=>n=>r=>{let i=t,o=e,u=n,s=r,a=!0,c;for(;a;){const f=i,d=o,l=u,_=s;if(f==="Rectangle"){if(l==="TopSide"){a=!1,c=d.y;continue}if(l==="BottomSide"){a=!1,c=d.y+d.h;continue}if(l==="LeftSide"){a=!1,c=d.x;continue}if(l==="RightSide"){a=!1,c=d.x+d.w;continue}i=tr,o=d,u=l,s=_;continue}if(f==="Cylinder"){if(l==="TopSide"){a=!1,c=Cf(d)(-1)(_);continue}if(l==="BottomSide"){a=!1,c=Cf(d)(1)(_);continue}if(l==="LeftSide"){a=!1,c=d.x;continue}if(l==="RightSide"){a=!1,c=d.x+d.w;continue}}i=tr,o=d,u=l,s=_}return c},Sf=t=>e=>{const n=e.y-t.y,r=n<0?-n:n,i=e.x-(t.x+t.w),o=i<0?-i:i,u=e.x-t.x,s=u<0?-u:u,a=e.y-(t.y+t.h),c=a<0?-a:a;return r<=c&&r<=s&&r<=o?Jr:c<=s&&c<=o?Tr:s<=o?wr:vr},hx=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),Ks=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Oi=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Yi=te(S)(zt),px=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},mx=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},yx=T(t=>e=>tt(S)(e)()(t))(A),xx=T(t=>e=>tt(S)(e)()(t))(A),ru=cr.traverse(Pu),iu=te(S)(zt),Nx=t=>e=>Se(S.compare,Ee,t,e),Jx=T(t=>e=>tt(S)(e)()(t))(A),Tx=te(S)(zt),wx=t=>e=>Se(S.compare,Ee,t,e),vx=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Gf=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},bx=t=>e=>({...e,edges:Yi(O(n=>b(n._1,(()=>{const r=Ks(n._1)(t);if(r.tag==="Nothing")return n._2;if(r.tag==="Just"){const i=Oi(r._1._2)(e.nodes),o=Oi(r._1._1)(e.nodes),u=(()=>{if(o.tag==="Nothing")return n._2;if(o.tag==="Just"){const s=Qt(a=>J,a=>c=>w("Just",{head:a,tail:c}),n._2);if(s.tag==="Nothing")return n._2;if(s.tag==="Just")return[(()=>{const a=Qt(l=>J,l=>_=>w("Just",{head:l,tail:_}),s._1.tail),c=a.tag==="Just"?w("Just",a._1.head):J,f={x:o._1.x,y:o._1.y,w:o._1.w,h:o._1.h},d=(()=>{if(c.tag==="Just"){if((c._1.x>s._1.head.x?c._1.x-s._1.head.x<.5:s._1.head.x-c._1.x<.5)&&s._1.head.x>=f.x-.5&&s._1.head.x<=f.x+f.w+.5)return c._1.y>=f.y+f.h?w("Just",Tr):c._1.y<=f.y?w("Just",Jr):J;if((c._1.y>s._1.head.y?c._1.y-s._1.head.y<.5:s._1.head.y-c._1.y<.5)&&s._1.head.y>=f.y-.5&&s._1.head.y<=f.y+f.h+.5){if(c._1.x>=f.x+f.w)return w("Just",vr);if(c._1.x<=f.x)return w("Just",wr)}return J}if(c.tag==="Nothing")return J;g()})();if(d.tag==="Just"){if(d._1==="TopSide")return{...s._1.head,y:ze(o._1.shape)(f)(Jr)(s._1.head.x)};if(d._1==="BottomSide")return{...s._1.head,y:ze(o._1.shape)(f)(Tr)(s._1.head.x)};if(d._1==="LeftSide")return{...s._1.head,x:ze(o._1.shape)(f)(wr)(s._1.head.y)};if(d._1==="RightSide")return{...s._1.head,x:ze(o._1.shape)(f)(vr)(s._1.head.y)};g()}if(d.tag==="Nothing"){const l={x:o._1.x,y:o._1.y,w:o._1.w,h:o._1.h},_=Sf(l)(s._1.head);if(_==="TopSide")return{...s._1.head,y:ze(o._1.shape)(l)(Jr)(s._1.head.x)};if(_==="BottomSide")return{...s._1.head,y:ze(o._1.shape)(l)(Tr)(s._1.head.x)};if(_==="LeftSide")return{...s._1.head,x:ze(o._1.shape)(l)(wr)(s._1.head.y)};if(_==="RightSide")return{...s._1.head,x:ze(o._1.shape)(l)(vr)(s._1.head.y)}}g()})(),...s._1.tail]}g()})();if(i.tag==="Nothing")return u;if(i.tag==="Just"){const s=fr(u);if(s.tag==="Nothing")return u;if(s.tag==="Just")return Rt(s._1.init)((()=>{const a=fr(s._1.init),c=a.tag==="Just"?w("Just",a._1.last):J,f={x:i._1.x,y:i._1.y,w:i._1.w,h:i._1.h},d=(()=>{if(c.tag==="Just"){if((c._1.x>s._1.last.x?c._1.x-s._1.last.x<.5:s._1.last.x-c._1.x<.5)&&s._1.last.x>=f.x-.5&&s._1.last.x<=f.x+f.w+.5)return c._1.y>=f.y+f.h?w("Just",Tr):c._1.y<=f.y?w("Just",Jr):J;if((c._1.y>s._1.last.y?c._1.y-s._1.last.y<.5:s._1.last.y-c._1.y<.5)&&s._1.last.y>=f.y-.5&&s._1.last.y<=f.y+f.h+.5){if(c._1.x>=f.x+f.w)return w("Just",vr);if(c._1.x<=f.x)return w("Just",wr)}return J}if(c.tag==="Nothing")return J;g()})();if(d.tag==="Just"){if(d._1==="TopSide")return{...s._1.last,y:ze(i._1.shape)(f)(Jr)(s._1.last.x)};if(d._1==="BottomSide")return{...s._1.last,y:ze(i._1.shape)(f)(Tr)(s._1.last.x)};if(d._1==="LeftSide")return{...s._1.last,x:ze(i._1.shape)(f)(wr)(s._1.last.y)};if(d._1==="RightSide")return{...s._1.last,x:ze(i._1.shape)(f)(vr)(s._1.last.y)};g()}if(d.tag==="Nothing"){const l={x:i._1.x,y:i._1.y,w:i._1.w,h:i._1.h},_=Sf(l)(s._1.last);if(_==="TopSide")return{...s._1.last,y:ze(i._1.shape)(l)(Jr)(s._1.last.x)};if(_==="BottomSide")return{...s._1.last,y:ze(i._1.shape)(l)(Tr)(s._1.last.x)};if(_==="LeftSide")return{...s._1.last,x:ze(i._1.shape)(l)(wr)(s._1.last.y)};if(_==="RightSide")return{...s._1.last,x:ze(i._1.shape)(l)(vr)(s._1.last.y)}}g()})())}}g()})()))(hx(e.edges)))}),kx=t=>e=>n=>{const r=Kt(i=>i.id===n)(t.graph.edges);if(r.tag==="Just")return w("Just",r._1);if(r.tag==="Nothing")return Ks(n)(e);g()},Lx=t=>e=>n=>r=>({x:r.position._1*t,y:r.position._2*t,w:r.size._1*t,h:r.size._2*t,label:(()=>{const i=Oi(r.node)(e);if(i.tag==="Just")return i._1;if(i.tag==="Nothing")return r.node;g()})(),shape:(()=>{const i=Oi(r.node)(n);if(i.tag==="Nothing")return tr;if(i.tag==="Just")return i._1;g()})()}),Ex=t=>({id:t,size:b(1,1),ports:[],label:w("Just",t),shape:tr}),Cx=t=>e=>n=>r=>b(r.node,Lx(t)(e)(n)(r)),Pf=t=>{const e=wo(`
6
- `)(t);return e.length===0?[""]:e},Df=t=>{const e=(n,r)=>{if(n.tag==="Leaf")return r;if(n.tag==="Node")return e(n._5,$t("Cons",n._4,e(n._6,r)));g()};return Ct(Vt.foldr,e(t.interiors,Xt))},Sx=t=>Yi(xt(e=>w("Just",b(e.edge,{id:e.edge,from:{node:e.from,port:J},to:{node:e.to,port:J},label:J})))(wt(t.scenes)(e=>e.tag==="DataFlow"?xt(n=>n.kind.tag==="SendToken"?w("Just",n.kind._1):J)(e._1.events):[]))),If=t=>{const e=zl(t),n=at(i=>px(i.id)(e.nodes),t.graph.nodes),r=at(i=>mx(i.id)(e.edges),t.graph.edges);return{nodes:[...n,...O(Ex)(Ct(Qe.foldr,In(S.compare,e.nodes,yx(O(i=>i.id)(n)))))],edges:[...r,...xt(kx(t)(Sx(t)))(Ct(Qe.foldr,In(S.compare,e.edges,xx(O(i=>i.id)(r)))))],constraints:t.graph.constraints}},Gx=t=>{const e=ru(n=>{const r=_g(dg)((()=>{if(n.label.tag==="Just")return n.label._1;if(n.label.tag==="Nothing")return n.id;g()})());return()=>{const i=r();return b(n.id,i)}})(If(t).nodes);return()=>{const n=e();return iu(n)}},Af=t=>{const e=Gx(t);return()=>{const n=e(),r=ru(Af)(Df(t))();return T(Nx)(n)(r)}},Px=t=>e=>{const n=Qt(r=>J,r=>i=>w("Just",{head:r,tail:i}),e.segments);if(n.tag==="Nothing")return[];if(n.tag==="Just")return[{x:n._1.head.start._1*t,y:n._1.head.start._2*t},...O(r=>({x:r.end._1*t,y:r.end._2*t}))([n._1.head,...n._1.tail])];g()},Dx=t=>e=>b(e.edge,Px(t)(e)),Ix=t=>e=>n=>r=>({nodes:iu(O(Cx(et(4)*t)(e)(n))(r.nodes)),edges:Yi(O(Dx(t))(r.edges)),chipExtras:A,edgeLabels:A}),Ax=t=>T(e=>n=>{if(n.tag==="Structural")return e;if(n.tag==="DataFlow")return T(r=>i=>{if(i.kind.tag==="SendToken")return T(o=>u=>tt(S)(u)()(o))(r)(i.kind._1.labels);if(i.kind.tag==="FillNodeWithoutTransition")return T(o=>u=>tt(S)(u)()(o))(r)(i.kind._1.labels);g()})(e)(n._1.events);if(n.tag==="Hold"||n.tag==="EnterNode"||n.tag==="ExitNode")return e;g()})(A)(t.scenes),Fx=t=>{const e=ru(n=>{const r=_g(dg)(n);return()=>{const i=r();return b(n,{labelW:i,charCount:jn(Rr(n)),lineCount:1})}})(Ct(Qe.foldr,Jx(wt(Ct(Qe.foldr,Ax(t)))(Pf))));return()=>{const n=e();return Tx(n)}},Ff=t=>{const e=Fx(t);return()=>{const n=e(),r=ru(Ff)(Df(t))();return T(wx)(n)(r)}},Bx=et(4)*8,Qx=t=>e=>{const n=vp(Bx)(t)(wp(Tp)(If(e)));return{...bx(Yi(O(r=>b(r.id,b(r.from.node,r.to.node)))(n.edges)))(Ix(8)(iu(O(r=>b(r.id,(()=>{if(r.label.tag==="Just")return r.label._1;if(r.label.tag==="Nothing")return r.id;g()})()))(n.nodes)))(iu(O(r=>b(r.id,r.shape))(n.nodes)))(_x(ux)(n).result)),edgeLabels:Yi(xt(r=>r.label.tag==="Just"?w("Just",b(r.id,r.label._1)):J)(n.edges))}},Rx=t=>wt(t.scenes)(e=>{if(e.tag==="Structural")return[];if(e.tag==="DataFlow")return e._1.events;if(e.tag==="Hold")return[];if(e.tag==="EnterNode")return[];if(e.tag==="ExitNode")return[];g()}),Mx=t=>e=>n=>{const r=i=>{const o=xt(u=>{const s=vx(u)(t);return s.tag==="Just"?w("Just",{w:s._1.labelW+28,h:et(mp(1)(s._1.lineCount))*13.2+12}):J})(wt(i)(Pf));return o.length===0?J:w("Just",{w:T(Gf)(0)(O(u=>u.w)(o)),h:T(Gf)(0)(O(u=>u.h)(o))})};return T(i=>o=>{if(o.kind.tag==="SendToken"){const u=Ks(o.kind._1.edge)(n.edges),s=r(o.kind._1.labels);if(s.tag==="Just"&&u.tag==="Just"){const a=s._1;return bt(S)(re)(o.kind._1.edge)(O(c=>({x:c.x+14+a.w,y:c.y-6-8-a.h}))(u._1))(i)}return i}if(o.kind.tag==="FillNodeWithoutTransition"){const u=Oi(o.kind._1.node)(n.nodes),s=r(o.kind._1.labels);return s.tag==="Just"&&u.tag==="Just"?bt(S)(re)("__fill__:"+o.kind._1.node)((()=>{const a=u._1.y-s._1.h-14,c=u._1.x+u._1.w/2,f=c-s._1.w/2,d=c+s._1.w/2,l=u._1.y-14;return[{x:f,y:a},{x:d,y:a},{x:f,y:l},{x:d,y:l}]})())(i):i}g()})(A)(Rx(e))},Bf=t=>e=>n=>({layout:(()=>{const r=Qx(t)(n);return{...r,chipExtras:Mx(e)(n)(r)}})(),interiors:(()=>{const r=Bf(t)(e),i=o=>{if(o.tag==="Leaf")return A;if(o.tag==="Node")return Yt("Node",o._1,o._2,o._3,r(o._4),i(o._5),i(o._6));g()};return i(n.interiors)})()}),Qf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Zs=t=>e=>n=>{const r=t<.05?t:.05,i=(u,s)=>{if(s.tag==="Leaf")return u;if(s.tag==="Node")return i((()=>{const a=Qf(s._3)(n),c=(()=>{if(a.tag==="Just")return a._1;if(a.tag==="Nothing")return{x:s._4.x,y:s._4.y,vx:0,vy:0};g()})(),f=c.vx+(180*(s._4.x-c.x)-22*c.vx)*r,d=c.vy+(180*(s._4.y-c.y)-22*c.vy)*r;return tt(S)(s._3)({x:c.x+f*r,y:c.y+d*r,vx:f,vy:d})(i(u,s._5))})(),s._6);g()},o=i(A,e);return{springs:o,applied:(()=>{const u=(s,a)=>{if(a.tag==="Leaf")return s;if(a.tag==="Node")return u((()=>{const c=u(s,a._5),f=Qf(a._3)(o);if(f.tag==="Just")return tt(S)(a._3)({...a._4,x:f._1.x,y:f._1.y})(c);if(f.tag==="Nothing")return tt(S)(a._3)(a._4)(c);g()})(),a._6);g()};return u(A,e)})()}};(function(){var t={},e="Pure",n="Throw",r="Catch",i="Sync",o="Async",u="Bind",s="Bracket",a="Fork",c="Sequential",f="Map",d="Apply",l="Alt",_="Cons",h="Resume",p="Release",m="Finalizer",y="Finalized",x="Forked";function N(I,z,$,X){this.tag=I,this._1=z,this._2=$,this._3=X}function v(I){var z=function($,X,Y){return new N(I,$,X,Y)};return z.tag=I,z}function k(I){return new N(e,void 0)}function L(I){try{I()}catch(z){setTimeout(function(){throw z},0)}}function E(I,z,$){try{return z($())}catch(X){return I(X)}}function B(I,z,$){try{return z($)()}catch(X){return $(I(X))(),k}}var q=(function(){var I=1024,z=0,$=0,X=new Array(I),Y=!1;function W(){var K;for(Y=!0;z!==0;)z--,K=X[$],X[$]=void 0,$=($+1)%I,K();Y=!1}return{isDraining:function(){return Y},enqueue:function(K){var Z;z===I&&(Z=Y,W(),Y=Z),X[($+z)%I]=K,z++,Y||W()}}})();function j(I){var z={},$=0,X=0;return{register:function(Y){var W=$++;Y.onComplete({rethrow:!0,handler:function(K){return function(){X--,delete z[W]}}})(),z[W]=Y,X++},isEmpty:function(){return X===0},killAll:function(Y,W){return function(){if(X===0)return W();var K=0,Z={};function ct(gt){Z[gt]=z[gt].kill(Y,function(yt){return function(){delete Z[gt],K--,I.isLeft(yt)&&I.fromLeft(yt)&&setTimeout(function(){throw I.fromLeft(yt)},0),K===0&&W()}})()}for(var _t in z)z.hasOwnProperty(_t)&&(K++,ct(_t));return z={},$=0,X=0,function(gt){return new N(i,function(){for(var yt in Z)Z.hasOwnProperty(yt)&&Z[yt]()})}}}}}var G=0,P=1,V=2,U=3,M=4,H=5,R=6;function C(I,z,$){var X=0,Y=G,W=$,K=null,Z=null,ct=null,_t=null,gt=null,yt=0,St=0,Ht=null,pt=!0;function Wt(ot){for(var dt,ut,st;;)switch(dt=null,ut=null,st=null,Y){case V:Y=P;try{W=ct(W),_t===null?ct=null:(ct=_t._1,_t=_t._2)}catch(Jt){Y=H,K=I.left(Jt),W=null}break;case U:I.isLeft(W)?(Y=H,K=W,W=null):ct===null?Y=H:(Y=V,W=I.fromRight(W));break;case P:switch(W.tag){case u:ct&&(_t=new N(_,ct,_t)),ct=W._2,Y=P,W=W._1;break;case e:ct===null?(Y=H,W=I.right(W._1)):(Y=V,W=W._1);break;case i:Y=U,W=E(I.left,I.right,W._1);break;case o:Y=M,W=B(I.left,W._1,function(Jt){return function(){X===ot&&(X++,q.enqueue(function(){X===ot+1&&(Y=U,W=Jt,Wt(X))}))}});return;case n:Y=H,K=I.left(W._1),W=null;break;case r:ct===null?gt=new N(_,W,gt,Z):gt=new N(_,W,new N(_,new N(h,ct,_t),gt,Z),Z),ct=null,_t=null,Y=P,W=W._1;break;case s:yt++,ct===null?gt=new N(_,W,gt,Z):gt=new N(_,W,new N(_,new N(h,ct,_t),gt,Z),Z),ct=null,_t=null,Y=P,W=W._1;break;case a:Y=U,dt=C(I,z,W._2),z&&z.register(dt),W._1&&dt.run(),W=I.right(dt);break;case c:Y=P,W=F(I,z,W._1);break}break;case H:if(ct=null,_t=null,gt===null)Y=R,W=Z||K||W;else switch(dt=gt._3,st=gt._1,gt=gt._2,st.tag){case r:Z&&Z!==dt&&yt===0?Y=H:K&&(Y=P,W=st._2(I.fromLeft(K)),K=null);break;case h:Z&&Z!==dt&&yt===0||K?Y=H:(ct=st._1,_t=st._2,Y=V,W=I.fromRight(W));break;case s:yt--,K===null&&(ut=I.fromRight(W),gt=new N(_,new N(p,st._2,ut),gt,dt),(Z===dt||yt>0)&&(Y=P,W=st._3(ut)));break;case p:gt=new N(_,new N(y,W,K),gt,Z),Y=P,Z&&Z!==dt&&yt===0?W=st._1.killed(I.fromLeft(Z))(st._2):K?W=st._1.failed(I.fromLeft(K))(st._2):W=st._1.completed(I.fromRight(W))(st._2),K=null,yt++;break;case m:yt++,gt=new N(_,new N(y,W,K),gt,Z),Y=P,W=st._1;break;case y:yt--,Y=H,W=st._1,K=st._2;break}break;case R:for(var Nt in Ht)Ht.hasOwnProperty(Nt)&&(pt=pt&&Ht[Nt].rethrow,L(Ht[Nt].handler(W)));Ht=null,Z&&K?setTimeout(function(){throw I.fromLeft(K)},0):I.isLeft(W)&&pt&&setTimeout(function(){if(pt)throw I.fromLeft(W)},0);return;case G:Y=P;break;case M:return}}function Tt(ot){return function(){if(Y===R)return pt=pt&&ot.rethrow,ot.handler(W)(),function(){};var dt=St++;return Ht=Ht||{},Ht[dt]=ot,function(){Ht!==null&&delete Ht[dt]}}}function mt(ot,dt){return function(){if(Y===R)return dt(I.right(void 0))(),function(){};var ut=Tt({rethrow:!1,handler:function(){return dt(I.right(void 0))}})();switch(Y){case G:Z=I.left(ot),Y=R,W=Z,Wt(X);break;case M:Z===null&&(Z=I.left(ot)),yt===0&&(Y===M&&(gt=new N(_,new N(m,W(ot)),gt,Z)),Y=H,W=null,K=null,Wt(++X));break;default:Z===null&&(Z=I.left(ot)),yt===0&&(Y=H,W=null,K=null)}return ut}}function ft(ot){return function(){var dt=Tt({rethrow:!1,handler:ot})();return Y===G&&Wt(X),dt}}return{kill:mt,join:ft,onComplete:Tt,isSuspended:function(){return Y===G},run:function(){Y===G&&(q.isDraining()?Wt(X):q.enqueue(function(){Wt(X)}))}}}function D(I,z,$,X){var Y=0,W={},K=0,Z={},ct=new Error("[ParAff] Early exit"),_t=null,gt=t;function yt(Tt,mt,ft){var ot=mt,dt=null,ut=null,st=0,Nt={},Jt,kt;t:for(;;)switch(Jt=null,ot.tag){case x:if(ot._3===t&&(Jt=W[ot._1],Nt[st++]=Jt.kill(Tt,function(Ot){return function(){st--,st===0&&ft(Ot)()}})),dt===null)break t;ot=dt._2,ut===null?dt=null:(dt=ut._1,ut=ut._2);break;case f:ot=ot._2;break;case d:case l:dt&&(ut=new N(_,dt,ut)),dt=ot,ot=ot._1;break}if(st===0)ft(I.right(void 0))();else for(kt=0,Jt=st;kt<Jt;kt++)Nt[kt]=Nt[kt]();return Nt}function St(Tt,mt,ft){var ot,dt,ut,st,Nt,Jt;for(I.isLeft(Tt)?(ot=Tt,dt=null):(dt=Tt,ot=null);;){if(ut=null,st=null,Nt=null,Jt=null,_t!==null)return;if(mt===null){X(ot||dt)();return}if(mt._3!==t)return;switch(mt.tag){case f:ot===null?(mt._3=I.right(mt._1(I.fromRight(dt))),dt=mt._3):mt._3=ot;break;case d:if(ut=mt._1._3,st=mt._2._3,ot){if(mt._3=ot,Nt=!0,Jt=K++,Z[Jt]=yt(ct,ot===ut?mt._2:mt._1,function(){return function(){delete Z[Jt],Nt?Nt=!1:ft===null?St(ot,null,null):St(ot,ft._1,ft._2)}}),Nt){Nt=!1;return}}else{if(ut===t||st===t)return;dt=I.right(I.fromRight(ut)(I.fromRight(st))),mt._3=dt}break;case l:if(ut=mt._1._3,st=mt._2._3,ut===t&&I.isLeft(st)||st===t&&I.isLeft(ut))return;if(ut!==t&&I.isLeft(ut)&&st!==t&&I.isLeft(st))ot=dt===ut?st:ut,dt=null,mt._3=ot;else if(mt._3=dt,Nt=!0,Jt=K++,Z[Jt]=yt(ct,dt===ut?mt._2:mt._1,function(){return function(){delete Z[Jt],Nt?Nt=!1:ft===null?St(dt,null,null):St(dt,ft._1,ft._2)}}),Nt){Nt=!1;return}break}ft===null?mt=null:(mt=ft._1,ft=ft._2)}}function Ht(Tt){return function(mt){return function(){delete W[Tt._1],Tt._3=mt,St(mt,Tt._2._1,Tt._2._2)}}}function pt(){var Tt=P,mt=$,ft=null,ot=null,dt,ut;t:for(;;)switch(dt=null,ut=null,Tt){case P:switch(mt.tag){case f:ft&&(ot=new N(_,ft,ot)),ft=new N(f,mt._1,t,t),mt=mt._2;break;case d:ft&&(ot=new N(_,ft,ot)),ft=new N(d,t,mt._2,t),mt=mt._1;break;case l:ft&&(ot=new N(_,ft,ot)),ft=new N(l,t,mt._2,t),mt=mt._1;break;default:ut=Y++,Tt=H,dt=mt,mt=new N(x,ut,new N(_,ft,ot),t),dt=C(I,z,dt),dt.onComplete({rethrow:!1,handler:Ht(mt)})(),W[ut]=dt,z&&z.register(dt)}break;case H:if(ft===null)break t;ft._1===t?(ft._1=mt,Tt=P,mt=ft._2,ft._2=t):(ft._2=mt,mt=ft,ot===null?ft=null:(ft=ot._1,ot=ot._2))}for(gt=mt,ut=0;ut<Y;ut++)W[ut].run()}function Wt(Tt,mt){_t=I.left(Tt);var ft;for(var ot in Z)if(Z.hasOwnProperty(ot)){ft=Z[ot];for(ot in ft)ft.hasOwnProperty(ot)&&ft[ot]()}Z=null;var dt=yt(Tt,gt,mt);return function(ut){return new N(o,function(st){return function(){for(var Nt in dt)dt.hasOwnProperty(Nt)&&dt[Nt]();return k}})}}return pt(),function(Tt){return new N(o,function(mt){return function(){return Wt(Tt,mt)}})}}function F(I,z,$){return new N(o,function(X){return function(){return D(I,z,$,X)}})}return N.EMPTY=t,N.Pure=v(e),N.Throw=v(n),N.Catch=v(r),N.Sync=v(i),N.Async=v(o),N.Bind=v(u),N.Bracket=v(s),N.Fork=v(a),N.Seq=v(c),N.ParMap=v(f),N.ParApply=v(d),N.ParAlt=v(l),N.Fiber=C,N.Supervisor=j,N.Scheduler=q,N.nonCanceler=k,N})();let Rf=null;function zx(){return Rf||(typeof document>"u"?null:Rf=document.createElement("canvas").getContext("2d"))}const js=new Map;function Mf(t,e,n,r,i,o){const u=`${n} ${e}px ${t}`,s=u+"|"+r;if(js.has(s))return js.get(s);const a=zx();if(!a)return o;a.font=u;const c=i(a.measureText(r)),f=typeof document<"u"?document.fonts:null;if(!f||f.check(u))js.set(s,c);else if(f&&f.load)try{f.load(u)}catch{}return c}const Hx=(t,e,n,r)=>Mf(t,e,n,r,i=>i.width,-1),Wx=(t,e,n,r)=>Mf(t,e,n,r,i=>({ascent:i.actualBoundingBoxAscent,descent:i.actualBoundingBoxDescent}),{ascent:-1,descent:-1}),zf=t=>e=>{const n=Hx(t.family,t.size,t.weight,Rr(e));return n<0?et(ko(e).length)*t.size*.62:n},Hf=t=>e=>{const n=Wx(t.family,t.size,t.weight,Rr(e));return n.ascent<0?{ascent:t.size*.72,descent:t.size*.2}:n},Wf=t=>t,Of=t=>t,ou=t=>t,Yf=t=>t,Ox=t=>t,$f=t=>t,qf=t=>t,Yx=qf("BaselineTop"),ur=qf("BaselineMiddle"),ta=$f("AlignLeft"),Xr=$f("AlignCenter"),be=Ox("RoundJoin"),pn=Yf("ButtCap"),bn=Yf("RoundCap"),$x=ou("LayerPolyOut"),qx=ou("LayerPolyIn"),Xx=ou("LayerNodeMask"),Vx=ou("LayerOverlay"),uu=Of("NonZero"),Ux=Of("EvenOdd"),Xf=Wf("Normal"),su=Wf("Difference"),ue={r:255,g:255,b:255,a:255},Mn={r:26,g:26,b:26,a:255},ea=t=>e=>Math.imul(t,e),Vr=t=>{const e=t+1831565813|0,n=ea(e^e>>>15)(e|1),r=n^(n+ea(n^n>>>7)(n|61)|0),i=r^r>>>14;return{prng:i,value:i<0?(et(i)+4294967296)/4294967296:et(i)/4294967296}},pe=t=>e=>n=>{const r=Vr(n);return{prng:r.prng,value:t+r.value*(e-t)}},na=t=>e=>T(n=>r=>ea(n^r)(-2048144789))(e)(O(er)(hr(t))),Kx=t=>t,Vf=t=>t,Zx=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},un=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Uf=t=>e=>n=>{const r=nt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=nt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},ra=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},jx=t=>e=>n=>{const r=it.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=it.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},tN=Vf("FlatLevel"),eN=Vf("NestedLevel"),Kf=Kx("GenieSilhouette"),nN=t=>e=>n=>r=>{if(e)return{prng:t,yLift:0};const i=Vr(t);return{prng:i.prng,yLift:i.value*n.yJitter*r}},rN=t=>e=>n=>r=>{if(e)return{prng:t,dx:0};const i=Vr(t);return{prng:i.prng,dx:(i.value*2-1)*n.xJitter*r}},Zf=t=>e=>{const n=e.cy-t.cy,r=e.cx-t.cx,i=Ce(r*r+n*n),o=(t.r*t.r-e.r*e.r+i*i)/(2*i),u=Ce(Zx(0)(t.r*t.r-o*o)),s=t.cx+o*r/i,a=t.cy+o*n/i,c={x:s-u*n/i,y:a+u*r/i},f={x:s+u*n/i,y:a-u*r/i};return i===0||i>t.r+e.r?{x:(t.cx+e.cx)/2,y:t.cy}:c.y<f.y?c:f},iN=t=>e=>{const n=un(e)(un(t.w/2)(t.h/2));return[1,t.x+n,t.y,2,t.x+t.w-n,t.y,3,t.x+t.w,t.y,t.x+t.w,t.y+n,2,t.x+t.w,t.y+t.h-n,3,t.x+t.w,t.y+t.h,t.x+t.w-n,t.y+t.h,2,t.x+n,t.y+t.h,3,t.x,t.y+t.h,t.x,t.y+t.h-n,2,t.x,t.y+n,3,t.x,t.y,t.x+n,t.y,5]},oN=t=>e=>n=>r=>i=>o=>{if(e)return{prng:t,r:i};if(n)return{prng:t,r:i*(1+o.rJitter)};if(r)return{prng:t,r:i*o.smallScale};const u=Vr(t);return{prng:u.prng,r:i*(1+u.value*o.rJitter)}},jf=t=>{const e=un(t.w)(t.h)/2;return[1,t.x+e,t.y,2,t.x+t.w-e,t.y,4,t.x+t.w-e+.5522847498307936*e,t.y,t.x+t.w,t.y+e-.5522847498307936*e,t.x+t.w,t.y+e,4,t.x+t.w,t.y+e+.5522847498307936*e,t.x+t.w-e+.5522847498307936*e,t.y+t.h,t.x+t.w-e,t.y+t.h,2,t.x+e,t.y+t.h,4,t.x+e-.5522847498307936*e,t.y+t.h,t.x,t.y+e+.5522847498307936*e,t.x,t.y+e,4,t.x,t.y+e-.5522847498307936*e,t.x+e-.5522847498307936*e,t.y,t.x+e,t.y,5]},uN=t=>e=>n=>{const r=Vr(t),i=e.length;return i===0?{prng:t,idx:-1}:{prng:r.prng,idx:(()=>{const o=Uf(0)(i-1|0)(ce(mn(r.value*et(n))));return o>=0&&o<e.length?e[o]:-1})()}},sN=t=>e=>{const n=Vr(t),r=e.length;return r===0?{prng:t,idx:-1}:{prng:n.prng,idx:(()=>{const i=Uf(0)(r-1|0)(ce(mn(n.value*et(r))));return i>=0&&i<e.length?e[i]:-1})()}},t_=t=>{const e=un(t.w*.18)(t.h*.6);return[1,t.x+e,t.y,2,t.x+t.w,t.y,2,t.x+t.w-e,t.y+t.h,2,t.x,t.y+t.h,5]},e_=t=>[1,t.x,t.y,2,t.x+t.w,t.y,2,t.x+t.w,t.y+t.h*.85,4,t.x+t.w*.66,t.y+t.h*1.05,t.x+t.w*.34,t.y+t.h*.65,t.x,t.y+t.h*.85,5],n_={rBase:1.2,stepRatio:.7,rJitter:.35,yJitter:.2,xJitter:.2,heroShift:.2,smallScale:.85,smallShift:.15,seed:7,minN:3},aN=t=>{const e=un(t.h*.075)(t.w*.075),n=t.w/2,r=t.y+e,i=t.x+n;return[1,t.x,r,4,t.x,r+.5522847498*e,i-.5522847498*n,r+e,i,r+e,4,i+.5522847498*n,r+e,t.x+t.w,r+.5522847498*e,t.x+t.w,r]},r_=t=>{const e=un(t.h*.075)(t.w*.075),n=t.w/2,r=t.y+t.h+5,i=t.y+e,o=r-e,u=t.x+n;return[1,t.x,i,4,t.x,i-.5522847498*e,u-.5522847498*n,t.y,u,t.y,4,u+.5522847498*n,t.y,t.x+t.w,i-.5522847498*e,t.x+t.w,i,2,t.x+t.w,o,4,t.x+t.w,o+.5522847498*e,u+.5522847498*n,r,u,r,4,u-.5522847498*n,r,t.x,o+.5522847498*e,t.x,o,5]},i_=t=>e=>{const n=e.y+e.h,r=hd(t.rBase*e.h)(e.w/(2*(1+(et(t.minN)-1)*t.stepRatio))),i=e.w-2*r,o=2*r*t.stepRatio,u=ra(t.minN)(i<=0||o<=0?t.minN:ce(Dn(i/o))+1|0),s=u>=3?Ft(1,u-2|0):[],a=s.length,c=Gn(a+1|0,2),f=c<1?[]:Lt(0,c,s),d=sN(t.seed)((()=>{const m=a-c|0;return m<1?s:Lt(m,s.length,s)})()),l=d.idx,_=uN(d.prng)(at(m=>m!==l,f))(ra(1)(f.length-(Ye(Er)(l)(f)?1:0)|0)),h=_.idx,p=u>=2?i/(et(u)-1):0;return T(m=>y=>{const x=y===h,N=y===l,v=y===0||y===(u-1|0),k=oN(m.prng)(v)(N)(x)(r)(t),L=nN(k.prng)(v)(t)(e.h),E=rN(L.prng)(v)(t)(p);return{prng:E.prng,circles:Rt(m.circles)({cx:e.x+jx(k.r)(e.w-k.r)((u>=2?r+et(y)/(et(u)-1)*i+E.dx:r+0*i+E.dx)+(N?t.heroShift*p:x?-1*t.smallShift*p:0)),cy:n-L.yLift,r:k.r})}})({prng:_.prng,circles:[]})(Ft(0,u-1|0)).circles},o_=t=>e=>{const n=t.length;return Bt(r=>i=>({c:i,p1:(()=>{if(r===0)return{x:i.cx-i.r,y:e};const o=r-1|0;return o>=0&&o<t.length?Zf(t[o])(i):{x:i.cx-i.r,y:e}})(),p2:(()=>{if(r===(n-1|0))return{x:i.cx+i.r,y:e};const o=r+1|0;return o>=0&&o<t.length?Zf(i)(t[o]):{x:i.cx+i.r,y:e}})()}))(t)},u_=t=>{const e=un(t.h*.4)(t.w*.2);return[1,t.x+e,t.y,2,t.x+t.w-e,t.y,2,t.x+t.w,t.y+t.h/2,2,t.x+t.w-e,t.y+t.h,2,t.x+e,t.y+t.h,2,t.x,t.y+t.h/2,5]},cN=t=>e=>n=>{const r=dr(e.y-t.cy)(e.x-t.cx),i=dr(n.y-t.cy)(n.x-t.cx),o=i>r?i-r:i+6.283185307179586-r,u=ra(1)(ce(io(o/1.5707963267948966))),s=o/et(u),a=1.3333333333333333*pd(s/4);return wt(Ft(0,u-1|0))(c=>{const f=r+et(c+1|0)*s,d=t.cx+t.r*rn(f),l=t.cy+t.r*Ve(f),_=r+et(c)*s;return[4,t.cx+t.r*rn(_)-a*t.r*Ve(_),t.cy+t.r*Ve(_)+a*t.r*rn(_),d+a*t.r*Ve(f),l-a*t.r*rn(f),d,l]})},s_=t=>e=>{const n=t.h*.38,r=o_(i_(n_)({x:t.x,y:t.y-n,w:t.w,h:n}))(t.y),i=un(e)(un(t.w/2)(t.h/2));return 0<r.length?[1,r[0].p1.x,r[0].p1.y,...wt(r)(o=>cN(o.c)(o.p1)(o.p2)),2,t.x+t.w,t.y+t.h-i,3,t.x+t.w,t.y+t.h,t.x+t.w-i,t.y+t.h,2,t.x+i,t.y+t.h,3,t.x,t.y+t.h,t.x,t.y+t.h-i,2,r[0].p1.x,r[0].p1.y,5]:iN(t)(e)},ia=t=>e=>n=>r=>i=>o=>{if(e==="Rectangle")return t.drawRoundedRect(n)(r)(i)(o);if(e==="Cylinder"){const u=r_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Parallelogram"){const u=t_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Diamond"){const u=u_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Ellipse"){const u=jf(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Document"){const u=e_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Cloud"){const u=s_(n)(r);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}return t.drawRoundedRect(n)(r)(i)(o)},gN=t=>()=>t.clip("evenodd"),fN=t=>e=>()=>{t.filter=`blur(${e}px)`},_N=t=>e=>()=>{const n=Math.max(8,Math.ceil(8/Math.max(e.tile,.001))),r=Math.max(2,Math.round(e.tile*n)),i=document.createElement("canvas");i.width=r,i.height=r;const o=i.getContext("2d");o.scale(n,n),o.fillStyle=e.bgCss,o.fillRect(0,0,e.tile,e.tile),o.fillStyle=e.dotCss,o.beginPath(),o.arc(e.tile/2,e.tile/2,e.dotR,0,2*Math.PI),o.fill();const u=t.createPattern(i,"repeat");u&&typeof u.setTransform=="function"&&u.setTransform(new DOMMatrix().translateSelf(e.ox,e.oy).scaleSelf(1/n,1/n)),t.save(),t.fillStyle=u,t.fillRect(e.vx,e.vy,e.vw,e.vh),t.restore()},oa=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},ua=t=>e=>n=>{const r=e.stroke;return()=>{const i=r.value,o=zd(t)(n);if(i!==n)return o(),e.stroke.value=n}},dN=t=>e=>n=>{const r=e.font;return()=>{const i=r.value,o=Ud(t)(n);if(i!==n)return o(),e.font.value=n}},$i=t=>e=>n=>{const r=e.fill;return()=>{const i=r.value,o=Md(t)(n);if(i!==n)return o(),e.fill.value=n}},au=t=>e=>{const n=e.length,r=o=>{if(o>=n)return()=>{};const u=o>=0&&o<e.length?e[o]:0;if(u===1){const s=fc(t)((()=>{const c=o+1|0;return c>=0&&c<e.length?e[c]:0})())((()=>{const c=o+2|0;return c>=0&&c<e.length?e[c]:0})()),a=r(o+3|0);return()=>(s(),a())}if(u===2){const s=fi(t)((()=>{const c=o+1|0;return c>=0&&c<e.length?e[c]:0})())((()=>{const c=o+2|0;return c>=0&&c<e.length?e[c]:0})()),a=r(o+3|0);return()=>(s(),a())}if(u===3){const s=_i(t)({cpx:(()=>{const c=o+1|0;return c>=0&&c<e.length?e[c]:0})(),cpy:(()=>{const c=o+2|0;return c>=0&&c<e.length?e[c]:0})(),x:(()=>{const c=o+3|0;return c>=0&&c<e.length?e[c]:0})(),y:(()=>{const c=o+4|0;return c>=0&&c<e.length?e[c]:0})()}),a=r(o+5|0);return()=>(s(),a())}if(u===4){const s=Zd(t)({cp1x:(()=>{const c=o+1|0;return c>=0&&c<e.length?e[c]:0})(),cp1y:(()=>{const c=o+2|0;return c>=0&&c<e.length?e[c]:0})(),cp2x:(()=>{const c=o+3|0;return c>=0&&c<e.length?e[c]:0})(),cp2y:(()=>{const c=o+4|0;return c>=0&&c<e.length?e[c]:0})(),x:(()=>{const c=o+5|0;return c>=0&&c<e.length?e[c]:0})(),y:(()=>{const c=o+6|0;return c>=0&&c<e.length?e[c]:0})()}),a=r(o+7|0);return()=>(s(),a())}if(u===5){const s=_c(t),a=r(o+1|0);return()=>(s(),a())}return()=>{}},i=gc(t);return()=>(i(),r(0)())},lN=t=>e=>n=>r=>i=>o=>{const u=oa(o)(oa(r/2)(i/2)),s=fc(t)(e+u)(n);return()=>(s(),fi(t)(e+r-u)(n)(),_i(t)({cpx:e+r,cpy:n,x:e+r,y:n+u})(),fi(t)(e+r)(n+i-u)(),_i(t)({cpx:e+r,cpy:n+i,x:e+r-u,y:n+i})(),fi(t)(e+u)(n+i)(),_i(t)({cpx:e,cpy:n+i,x:e,y:n+i-u})(),fi(t)(e)(n+u)(),_i(t)({cpx:e,cpy:n,x:e+u,y:n})(),_c(t)())},hN=()=>({font:{value:""},fill:{value:""},stroke:{value:""}}),pN=t=>e=>{const n=$d(t)({x:0,y:0,width:e.width,height:e.height});return()=>{n();const r=hN();return{ctx:t,surface:e,styleCache:r,maskDepth:{value:0},groupAlpha:{value:1},alphaSaves:{value:[]}}}},mN={map:t=>e=>n=>{const r=e(n);return()=>{const i=r();return t(i)}}},yN=t=>ee(t.weight)+" "+Ma(t.size)+"px "+t.family,kn=t=>{const e=Ma(et(t.a)/255);return t.a>=255?"rgb("+ee(t.r)+","+ee(t.g)+","+ee(t.b)+")":"rgba("+ee(t.r)+","+ee(t.g)+","+ee(t.b)+","+e+")"},xN=t=>e=>n=>r=>{const i=$i(t)(n)(kn(r));return()=>(i(),Yd(t)({x:0,y:0,width:e.width,height:e.height})())},NN=t=>e=>n=>{const r=e.font;return()=>(r.value="",e.fill.value="",e.stroke.value="",_N(t)({vx:n.viewport.vx,vy:n.viewport.vy,vw:n.viewport.vw,vh:n.viewport.vh,bgCss:kn(n.bgColor),dotCss:kn(n.dotColor),tile:n.tile,dotR:n.dotRadius,ox:n.origin.x,oy:n.origin.y})())},JN=t=>e=>n=>r=>{const i=$i(t)(e)(kn(r));return()=>(i(),au(t)(n)(),Wu(t)())},TN=t=>e=>n=>r=>i=>{const o=$i(t)(e)(kn(r));return()=>(o(),ua(t)(e)(kn(i.color))(),Ru(t)(i.width)(),fo(t)((()=>{if(i.lineJoin==="RoundJoin")return go;if(i.lineJoin==="BevelJoin")return Xu;if(i.lineJoin==="MiterJoin")return Vu;g()})())(),ju(t)((()=>{if(i.lineCap==="ButtCap")return Zu;if(i.lineCap==="RoundCap")return Uu;if(i.lineCap==="SquareCap")return Ku;g()})())(),au(t)(n)(),Wu(t)(),Hu(t)())},wN=t=>e=>n=>r=>i=>o=>{const u=gc(t);return()=>{if(u(),lN(t)(n.x)(n.y)(n.w)(n.h)(r)(),i.tag==="Just"?($i(t)(e)(kn(i._1.color))(),Wu(t)()):i.tag==="Nothing"||g(),o.tag==="Just")return ua(t)(e)(kn(o._1.color))(),Ru(t)(o._1.width)(),fo(t)((()=>{if(o._1.lineJoin==="RoundJoin")return go;if(o._1.lineJoin==="BevelJoin")return Xu;if(o._1.lineJoin==="MiterJoin")return Vu;g()})())(),ju(t)((()=>{if(o._1.lineCap==="ButtCap")return Zu;if(o._1.lineCap==="RoundCap")return Uu;if(o._1.lineCap==="SquareCap")return Ku;g()})())(),Hu(t)();o.tag!=="Nothing"&&g()}},vN=t=>e=>n=>r=>{const i=ua(t)(e)(kn(r.color));return()=>(i(),Ru(t)(r.width)(),fo(t)((()=>{if(r.lineJoin==="RoundJoin")return go;if(r.lineJoin==="BevelJoin")return Xu;if(r.lineJoin==="MiterJoin")return Vu;g()})())(),ju(t)((()=>{if(r.lineCap==="ButtCap")return Zu;if(r.lineCap==="RoundCap")return Uu;if(r.lineCap==="SquareCap")return Ku;g()})())(),au(t)(n)(),Hu(t)())},a_=t=>e=>n=>{const r=$i(t)(e)(kn(n.color));return()=>(r(),dN(t)(e)(yN(n.font))(),cl(t)((()=>{if(n.align==="AlignLeft")return rl;if(n.align==="AlignCenter")return ol;if(n.align==="AlignRight")return il;g()})())(),al(t)((()=>{if(n.baseline==="BaselineTop")return jd;if(n.baseline==="BaselineMiddle")return tl;if(n.baseline==="BaselineAlphabetic")return el;if(n.baseline==="BaselineBottom")return nl;g()})())(),Kd(t)(n.content)(n.x)(n.y)())},c_={apply:t=>e=>n=>{const r=t(n),i=e(n);return()=>{const o=r(),u=i();return o(u)}},Functor0:()=>mN},bN={bind:t=>e=>n=>{const r=t(n);return()=>{const i=r();return e(i)(n)()}},Apply0:()=>c_},kN=t=>e=>n=>{const r=oa(e.width/n.vw)(e.height/n.vh),i=Ou(t)({translateX:(e.width-n.vw*r)/2-n.vx*r,translateY:(e.height-n.vh*r)/2-n.vy*r});return()=>(i(),ao(t)({scaleX:r,scaleY:r})(),fo(t)(go)())},LN={pure:t=>e=>()=>t,Apply0:()=>c_},EN={Applicative0:()=>LN,Bind1:()=>bN},g_={fillPath:t=>e=>n=>{const r=JN(n.ctx)(n.styleCache)(t)(e.color),i=n.maskDepth;return()=>{if(i.value===0)return r()}},strokePath:t=>e=>n=>{const r=vN(n.ctx)(n.styleCache)(t)(e),i=n.maskDepth;return()=>{if(i.value===0)return r()}},fillStrokePath:t=>e=>n=>r=>{const i=TN(r.ctx)(r.styleCache)(t)(e.color)(n),o=r.maskDepth;return()=>{if(o.value===0)return i()}},drawRoundedRect:t=>e=>n=>r=>i=>{const o=wN(i.ctx)(i.styleCache)(t)(e)(n)(r),u=i.maskDepth;return()=>{if(u.value===0)return o()}},drawText:t=>e=>{const n=a_(e.ctx)(e.styleCache)(t),r=e.maskDepth;return()=>{if(r.value===0)return n()}},drawTextAffine:t=>e=>n=>{const r=Kn(n.ctx),i=n.maskDepth;return()=>{if(i.value===0)return r(),n.styleCache.font.value="",n.styleCache.fill.value="",n.styleCache.stroke.value="",qd(n.ctx)(t)(),a_(n.ctx)(n.styleCache)(e)(),Zn(n.ctx)(),n.styleCache.font.value="",n.styleCache.fill.value="",n.styleCache.stroke.value=""}},pushTransform:t=>e=>{const n=Kn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0)return n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="",Ou(e.ctx)({translateX:t.tx,translateY:t.ty})(),ao(e.ctx)({scaleX:t.sx,scaleY:t.sy})()}},popTransform:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushBakedTransform:t=>e=>{const n=Kn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0)return n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="",Ou(e.ctx)({translateX:t.tx,translateY:t.ty})(),ao(e.ctx)({scaleX:t.sx,scaleY:t.sy})()}},popBakedTransform:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushClip:t=>e=>n=>{const r=Kn(n.ctx),i=n.maskDepth;return()=>{if(i.value===0){if(r(),n.styleCache.font.value="",n.styleCache.fill.value="",n.styleCache.stroke.value="",au(n.ctx)(t)(),e==="NonZero")return Od(n.ctx)();if(e==="EvenOdd")return gN(n.ctx)();g()}}},popClip:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushBlend:t=>e=>{const n=Kn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0){if(n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="",t==="Normal")return lc(e.ctx)(ul)();if(t==="Difference")return lc(e.ctx)(sl)();g()}}},popBlend:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushAlpha:t=>e=>{const n=Kn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0){n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="";const i=e.groupAlpha.value,o=e.alphaSaves.value;e.alphaSaves.value=[...o,i];const u=i*t;return e.groupAlpha.value=u,Wd(e.ctx)(u)()}}},popAlpha:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0){e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value="";const r=t.alphaSaves.value,i=fr(r);if(i.tag==="Just")return t.alphaSaves.value=i._1.init,t.groupAlpha.value=i._1.last;if(i.tag==="Nothing")return t.groupAlpha.value=1;g()}}},pushBlur:t=>e=>{const n=Kn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0){n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="";const i=fN(e.ctx)(t);if(t>=.01)return i()}}},popBlur:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushLayer:t=>e=>{if(t==="LayerNodeMask"){const n=e.maskDepth;return()=>{const r=n.value;n.value=r+1|0}}return()=>{}},popLayer:t=>{const e=t.maskDepth;return()=>{const n=e.value,r=n-1|0;if(n>0)return t.maskDepth.value=r}},setViewport:t=>e=>{const n=kN(e.ctx)(e.surface)(t),r=e.maskDepth;return()=>{if(r.value===0)return n()}},clearBackground:t=>e=>{const n=xN(e.ctx)(e.surface)(e.styleCache)(t),r=e.maskDepth;return()=>{if(r.value===0)return n()}},backgroundDots:t=>e=>{const n=NN(e.ctx)(e.styleCache)(t),r=e.maskDepth;return()=>{if(r.value===0)return n()}},measureText:t=>e=>n=>{const r=zf(t)(e);return()=>r},measureInk:t=>e=>n=>{const r=Hf(t)(e);return()=>r},insideTokenStyle:t=>e=>()=>Kf,Monad0:()=>EN},CN=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Ur=t=>e=>n=>{const r=CN(.05)(1-t-e);return n<t?0:n>1-e?1:(n-t)/r},f_=t=>{const e=it.compare(0)(t),n=(()=>{if(e==="LT")return t;if(e==="EQ"||e==="GT")return 0;g()})(),r=it.compare(1)(n);if(r==="LT"||r==="EQ")return 1;if(r==="GT")return n;g()},cu=t=>{if(t.tag==="Hidden")return{alpha:0,scale:0};if(t.tag==="Visible")return{alpha:1,scale:1};if(t.tag==="PloppingIn")return{alpha:t._1>0?1:0,scale:wi(8)(.6)(f_(t._1))};if(t.tag==="PloppingOut")return{alpha:t._1<1?1:0,scale:wi(8)(.6)(f_(1-t._1))};g()};function SN(t,e){const n=e.x-t.x,r=e.y-t.y;return Math.sqrt(n*n+r*r)}function GN(t){const e=t.length,n=new Array(e);for(let r=0;r<e;r++){const i=t[r],o=t[(r+1)%e];n[r]={a:i,b:o,len:SN(i,o)}}return n}function PN(t,e,n){let r=0;for(let i=0;i<t.length;i++){const o=t[i],u=r,s=u+o.len;if(n<=s){const a=o.len>1e-6?(n-u)/o.len:0;return{x:o.a.x+(o.b.x-o.a.x)*a,y:o.a.y+(o.b.y-o.a.y)*a}}r=s}return e.length>0?e[e.length-1]:{x:0,y:0}}function __(t,e){if(e.length===0)return[];const n=GN(e);let r=0;for(let o=0;o<n.length;o++)r+=n[o].len;const i=new Array(t);for(let o=0;o<t;o++)i[o]=PN(n,e,o*r/t);return i}function DN(t,e){const n=e.length;if(n===0)return e;const r=(t%n+n)%n|0,i=new Array(n);for(let o=0;o<n;o++)i[o]=e[(o+r)%n];return i}function IN(t,e){const n=e.length;if(n===0)return e;let r=0,i=1/0;for(let o=0;o<n;o++){let u=0;for(let s=0;s<n;s++){const a=t[s]||{x:0,y:0},c=e[(s+o)%n]||{x:0,y:0},f=a.x-c.x,d=a.y-c.y;u+=f*f+d*d}u<i&&(i=u,r=o)}return DN(r,e)}const d_=t=>e=>n=>{const r=__(t,e),i=__(t,n),o=IN(r,i);return{from:r,to:o}};function l_(t){const e=t.length;if(e===0)return{x:0,y:0};let n=0,r=0;for(let i=0;i<e;i++)n+=t[i].x,r+=t[i].y;return{x:n/e,y:r/e}}function AN(t,e){const n=e.x-t.x,r=e.y-t.y,i=Math.sqrt(n*n+r*r);return i<=1e-4?{x:1,y:0}:{x:n/i,y:r/i}}function FN(t,e){const n=e.length;if(n===0)return e;const r=new Array(n);for(let i=0;i<n;i++){const o=e[((i-1)%n+n)%n],u=e[((i+1)%n+n)%n],s=e[i];r[i]={x:s.x+((o.x+u.x)/2-s.x)*t,y:s.y+((o.y+u.y)/2-s.y)*t}}return r}function BN(t){return t<0?0:t>1?1:t}const h_=t=>e=>n=>r=>{const i=e.length;if(i===0)return[];const o=l_(e),u=l_(n),s=AN(o,u),a=new Array(i);let c=1/0,f=-1/0;for(let _=0;_<i;_++){const h=e[_],p=(h.x-o.x)*s.x+(h.y-o.y)*s.y;a[_]=p,p<c&&(c=p),p>f&&(f=p)}const d=f-c;let l=new Array(i);for(let _=0;_<i;_++){const h=e[_],p=n[_];if(p===void 0){l[_]=h;continue}const m=d<=1e-4?0:r.maxDelay*(1-(a[_]-c)/d),y=Math.max(1e-4,1-m),x=BN((t-m)/y),N=x*x*(3-2*x);l[_]={x:h.x+(p.x-h.x)*N,y:h.y+(p.y-h.y)*N}}for(let _=0;_<r.smoothPasses;_++)l=FN(.5,l);return l},Ln=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},p_=T(Gr)(0),m_=t=>e=>n=>{const r=it.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=it.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},QN=T(t=>e=>t+e.len)(0),sa=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return[];if(e.tag==="Just")return[1,e._1.head.x,e._1.head.y,...wt(Lt(1,t.length,t))(n=>[2,n.x,n.y]),5];g()},RN=t=>e=>{const n=Ln(e)(Ln(t.w/2)(t.h/2));return[1,t.x+n,t.y,2,t.x+t.w-n,t.y,3,t.x+t.w,t.y,t.x+t.w,t.y+n,2,t.x+t.w,t.y+t.h-n,3,t.x+t.w,t.y+t.h,t.x+t.w-n,t.y+t.h,2,t.x+n,t.y+t.h,3,t.x,t.y+t.h,t.x,t.y+t.h-n,2,t.x,t.y+n,3,t.x,t.y,t.x+n,t.y,5]},MN=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return[];if(e.tag==="Just")return[1,e._1.head.x,e._1.head.y,...wt(e._1.tail)(n=>[2,n.x,n.y])];g()},zN=t=>{const e={x:t.x,y:t.y,w:t.w,h:t.h};if(t.shape==="Cylinder")return r_(e);if(t.shape==="Parallelogram")return t_(e);if(t.shape==="Diamond")return u_(e);if(t.shape==="Ellipse")return jf(e);if(t.shape==="Document")return e_(e);if(t.shape==="Cloud")return s_(e)(7);if(t.shape==="Rectangle")return RN(e)(7);g()},me=t=>e=>n=>O(r=>{const i=et(r)/et(n);return{x:t.x+(e.x-t.x)*i,y:t.y+(e.y-t.y)*i}})(Ft(0,n-1|0)),HN=t=>{const e=un(t.w*.18)(t.h*.6);return[...me({x:t.x+e,y:t.y})({x:t.x+t.w,y:t.y})(16),...me({x:t.x+t.w,y:t.y})({x:t.x+t.w-e,y:t.y+t.h})(16),...me({x:t.x+t.w-e,y:t.y+t.h})({x:t.x,y:t.y+t.h})(16),...me({x:t.x,y:t.y+t.h})({x:t.x+e,y:t.y})(16)]},Kr=t=>e=>{const n=Ln(t)(Ln(e.w/2)(e.h/2));return{...e,x:e.x+n,y:e.y+n,w:e.w-2*n,h:e.h-2*n}},aa=t=>e=>{const n=e.y-t.y,r=e.x-t.x;return Ce(r*r+n*n)},WN=t=>ve(e=>n=>({a:e,b:n,len:aa(e)(n)}),t,Lt(1,t.length,t)),ON=t=>e=>{const n=e.length-1|0,r=n>=0&&n<e.length?w("Just",e[n]):J,i=(()=>{if(r.tag==="Just")return[r._1];if(r.tag==="Nothing")return[];g()})(),o=0<e.length?w("Just",e[0]):J,u=(()=>{if(o.tag==="Just")return o._1;if(o.tag==="Nothing")return{x:0,y:0};g()})(),s=e.length;return s<3?e:[u,...wt(Ft(1,s-2|0))(a=>{const c=a+1|0,f=c>=0&&c<e.length?w("Just",e[c]):J,d=a>=0&&a<e.length?w("Just",e[a]):J,l=a-1|0,_=l>=0&&l<e.length?w("Just",e[l]):J;if(_.tag==="Just"&&d.tag==="Just"&&f.tag==="Just"){const h=d._1,p=aa(h)(f._1),m=aa(_._1)(h),y=Ln(t)(p/2),x=Ln(t)(m/2),N=p>0?y/p:0,v=h.x+(f._1.x-h.x)*N,k=h.y+(f._1.y-h.y)*N,L=m>0?x/m:0,E=h.x+(_._1.x-h.x)*L,B=h.y+(_._1.y-h.y)*L;return O(q=>{const j=et(q)/et(10),G=1-j;return{x:G*G*E+2*G*j*h.x+j*j*v,y:G*G*B+2*G*j*h.y+j*j*k}})(Ft(0,10))}return[]}),...i]},YN=t=>e=>n=>r=>i=>O(o=>{const u=et(o)/et(i),s=1-u,a=u*u*u,c=3*s*u*u,f=3*s*s*u,d=s*s*s;return{x:d*t.x+f*e.x+c*n.x+a*r.x,y:d*t.y+f*e.y+c*n.y+a*r.y}})(Ft(0,i-1|0)),$N=t=>[...me({x:t.x,y:t.y})({x:t.x+t.w,y:t.y})(12),...me({x:t.x+t.w,y:t.y})({x:t.x+t.w,y:t.y+t.h*.85})(12),...YN({x:t.x+t.w,y:t.y+t.h*.85})({x:t.x+t.w*.66,y:t.y+t.h*1.05})({x:t.x+t.w*.34,y:t.y+t.h*.65})({x:t.x,y:t.y+t.h*.85})(32),...me({x:t.x,y:t.y+t.h*.85})({x:t.x,y:t.y})(12)],y_=t=>e=>O(n=>{const r=6.283185307179586*et(n)/et(64);return{x:t.x+e*rn(r),y:t.y+e*Ve(r)}})(Ft(0,63)),gu=t=>e=>{const n=.5522847498*e;return[1,t.x+e,t.y,4,t.x+e,t.y+n,t.x+n,t.y+e,t.x,t.y+e,4,t.x-n,t.y+e,t.x-e,t.y+n,t.x-e,t.y,4,t.x-e,t.y-n,t.x-n,t.y-e,t.x,t.y-e,4,t.x+n,t.y-e,t.x+e,t.y-n,t.x+e,t.y,5]},qN=t=>{const e=t.y+t.h/2,n=un(t.h*.4)(t.w*.2);return[...me({x:t.x+n,y:t.y})({x:t.x+t.w-n,y:t.y})(10),...me({x:t.x+t.w-n,y:t.y})({x:t.x+t.w,y:e})(8),...me({x:t.x+t.w,y:e})({x:t.x+t.w-n,y:t.y+t.h})(8),...me({x:t.x+t.w-n,y:t.y+t.h})({x:t.x+n,y:t.y+t.h})(10),...me({x:t.x+n,y:t.y+t.h})({x:t.x,y:e})(8),...me({x:t.x,y:e})({x:t.x+n,y:t.y})(8)]},x_=t=>{const e=t.length;return e===0?{x:0,y:0}:{x:p_(O(n=>n.x)(t))/et(e),y:p_(O(n=>n.y)(t))/et(e)}},fu=t=>e=>n=>r=>i=>O(o=>{const u=n+(r-n)*(et(o)/et(i));return{x:t.x+e*rn(u),y:t.y+e*Ve(u)}})(Ft(0,i-1|0)),N_=t=>e=>{const n=Ln(t)(Ln(e.w/2)(e.h/2));return[...me({x:e.x+n,y:e.y})({x:e.x+e.w-n,y:e.y})(6),...fu({x:e.x+e.w-n,y:e.y+n})(n)(4.71238898038469)(6.283185307179586)(12),...me({x:e.x+e.w,y:e.y+n})({x:e.x+e.w,y:e.y+e.h-n})(6),...fu({x:e.x+e.w-n,y:e.y+e.h-n})(n)(0)(1.5707963267948966)(12),...me({x:e.x+e.w-n,y:e.y+e.h})({x:e.x+n,y:e.y+e.h})(6),...fu({x:e.x+n,y:e.y+e.h-n})(n)(1.5707963267948966)(3.141592653589793)(12),...me({x:e.x,y:e.y+e.h-n})({x:e.x,y:e.y+n})(6),...fu({x:e.x+n,y:e.y+n})(n)(3.141592653589793)(4.71238898038469)(12)]},_u=t=>e=>n=>r=>i=>o=>O(u=>{const s=r+(i-r)*(et(u)/et(o));return{x:t.x+e*rn(s),y:t.y+n*Ve(s)}})(Ft(0,o-1|0)),XN=t=>{const e=t.h*.38;return[...wt(o_(i_(n_)({x:t.x,y:t.y-e,w:t.w,h:e}))(t.y))(n=>{const r=dr(n.p2.y-n.c.cy)(n.p2.x-n.c.cx),i=dr(n.p1.y-n.c.cy)(n.p1.x-n.c.cx);return _u({x:n.c.cx,y:n.c.cy})(n.c.r)(n.c.r)(i)(r>i?r:r+6.283185307179586)(16)}),...me({x:t.x+t.w,y:t.y})({x:t.x+t.w,y:t.y+t.h})(8),...me({x:t.x+t.w,y:t.y+t.h})({x:t.x,y:t.y+t.h})(12),...me({x:t.x,y:t.y+t.h})({x:t.x,y:t.y})(8)]},VN=t=>{const e=Ln(t.h*.075)(t.w*.075),n=t.w/2,r=t.y+e,i=t.y+t.h+5-e-2,o=t.x+n;return[..._u({x:o,y:r})(n)(e)(3.141592653589793)(6.283185307179586)(24),...me({x:t.x+t.w,y:r})({x:t.x+t.w,y:i})(12),..._u({x:o,y:i})(n)(e)(0)(3.141592653589793)(24),...me({x:t.x,y:i})({x:t.x,y:r})(12)]},br=t=>e=>e.shape==="Cylinder"?VN(e):e.shape==="Parallelogram"?HN(e):e.shape==="Diamond"?qN(e):e.shape==="Ellipse"?N_(un(e.w)(e.h)/2)(e):e.shape==="Document"?$N(e):e.shape==="Cloud"?XN(e):N_(t)(e),UN=t=>{const e=Ln(t.h*.075)(t.w*.075),n=t.w/2;return _u({x:t.x+n,y:t.y+e})(n)(e)(0)(3.141592653589793)(24)},KN=t=>e=>n=>T(r=>i=>{const o=r.pos+i.len,u=n<o?(n-r.pos)/i.len:1,s={x:i.a.x+(i.b.x-i.a.x)*u,y:i.a.y+(i.b.y-i.a.y)*u},a=e>r.pos?(e-r.pos)/i.len:0,c={x:i.a.x+(i.b.x-i.a.x)*a,y:i.a.y+(i.b.y-i.a.y)*a},f=r.points.length-1|0,d=f>=0&&f<r.points.length?(()=>{const l=r.points[f].x-c.x;return(l<0?-l<1e-4:l<1e-4)&&(()=>{const _=r.points[f].y-c.y;return _<0?-_<1e-4:_<1e-4})()})()?Rt(r.points)(s):[...r.points,c,s]:[c,s];return i.len<=0||o<=e||r.pos>=n?{...r,pos:o}:{pos:o,points:d}})({pos:0,points:[]})(t).points,ZN=t=>e=>n=>{const r=Qt(i=>J,i=>o=>w("Just",{head:i,tail:o}),t);if(r.tag==="Nothing")return[];if(r.tag==="Just"){const i=WN(t),o=QN(i),u=m_(0)(o)(e*o),s=m_(0)(o)(n*o);return s<=u?[]:KN(i)(u)(s)}g()},jN=t=>e=>n=>r=>{const i=r.x-n.x,o=r.y-n.y,u=e.x-t.x,s=e.y-t.y,a=n.x-t.x,c=n.y-t.y,f=u*o-s*i,d=(a*o-c*i)/f,l=(a*s-c*u)/f;return(f<0?-f<1e-9:f<1e-9)?J:d>=0&&d<=1&&l>=0&&l<=1?w("Just",d):J},tJ=t=>e=>n=>{const r=Et(i=>o=>it.compare(i.t)(o.t))(xt(i=>{const o=jN(e)(n)(i._1)(i._2);return o.tag==="Just"?w("Just",{t:o._1,p:{x:e.x+(n.x-e.x)*o._1,y:e.y+(n.y-e.y)*o._1}}):J})(ve(Pn,t,[...Lt(1,t.length,t),...Lt(0,1,t)])));return 0<r.length?w("Just",r[0].p):J},J_=t=>e=>{const n=fr(e);if(n.tag==="Nothing")return e;if(n.tag==="Just"){const r=n._1.init.length-1|0;if(r>=0&&r<n._1.init.length){const i=tJ(t)(n._1.init[r])(n._1.last);if(i.tag==="Just")return Rt(n._1.init)(i._1);if(i.tag==="Nothing")return e;g()}return e}g()},ca=t=>t,zn=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},kr=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},eJ=Xa(qa)(zt),nJ=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},rJ=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},T_=ca("SegMove"),iJ=ca("SegLine"),oJ=ca("SegQuad"),w_={offset:.4,passes:1,rMax:1.5},v_=t=>ce(mn(t.x*7919+t.y*3001+t.w*113+t.h*17+1))*-1640531535|0,du=t=>e=>n=>()=>{t.push(3),t.push(e.x),t.push(e.y),t.push(n.x),t.push(n.y)},lu=t=>e=>()=>{t.push(1),t.push(e.x),t.push(e.y)},Hn=t=>e=>()=>{t.push(2),t.push(e.x),t.push(e.y)},qi=(()=>{const t=T(e=>n=>((e*31|0)+ce(mn(n.x*100))|0)+ce(mn(n.y*100))|0)(1);return e=>t(e)*-1640531535|0})(),uJ=t=>{const e=[];let n=0,r={x:0,y:0};for(;n<t.length;){const i=n,o=r,u=i>=0&&i<t.length?w("Just",t[i]):J;if(u.tag==="Nothing"){n=t.length;continue}if(u.tag==="Just"){if(u._1===1){const s={x:(()=>{const a=i+1|0;return a>=0&&a<t.length?t[a]:0})(),y:(()=>{const a=i+2|0;return a>=0&&a<t.length?t[a]:0})()};e.push({kind:T_,m:o,c:o,p:s,len:0}),r=s,n=i+3|0;continue}if(u._1===2){const s={x:(()=>{const f=i+1|0;return f>=0&&f<t.length?t[f]:0})(),y:(()=>{const f=i+2|0;return f>=0&&f<t.length?t[f]:0})()},a=s.x-o.x,c=s.y-o.y;e.push({kind:iJ,m:o,c:o,p:s,len:Ce(a*a+c*c)}),r=s,n=i+3|0;continue}if(u._1===3){const s={x:(()=>{const f=i+3|0;return f>=0&&f<t.length?t[f]:0})(),y:(()=>{const f=i+4|0;return f>=0&&f<t.length?t[f]:0})()},a=s.x-o.x,c=s.y-o.y;e.push({kind:oJ,m:o,c:{x:(()=>{const f=i+1|0;return f>=0&&f<t.length?t[f]:0})(),y:(()=>{const f=i+2|0;return f>=0&&f<t.length?t[f]:0})()},p:s,len:Ce(a*a+c*c)*1.05}),r=s,n=i+5|0;continue}if(u._1===5){e.push({kind:T_,m:o,c:o,p:o,len:0}),n=i+1|0;continue}n=t.length;continue}g()}return e},sJ=t=>e=>{const n=e.length-1|0,r=n<1?[]:Lt(0,n,e),i=(()=>{const u=r.length-1|0;return u>=0&&u<r.length?w("Just",r[u]):J})(),o=e.length-1|0;if(o>=0&&o<e.length&&i.tag==="Just"){const u=e[o].y-i._1.y,s=e[o].x-i._1.x,a=Ce(s*s+u*u);return a<=1e-4?e:Rt((()=>{const c=e.length-1|0;return c<1?[]:Lt(0,c,e)})())({x:e[o].x+s/a*t,y:e[o].y+u/a*t})}return e},aJ=t=>e=>n=>we(T(r=>i=>{const o=pe(0)(t)(r.prng),u=pe(0)(6.283185307179586)(o.prng);return{prng:u.prng,out:[{x:i.x+o.value*rn(u.value),y:i.y+o.value*Ve(u.value)},...r.out]}})({prng:e,out:[]})(n).out),cJ=t=>e=>n=>{if(e.kind==="SegMove")return lu(t)(e.p);if(e.kind==="SegLine")return Hn(t)({x:e.m.x+(e.p.x-e.m.x)*n,y:e.m.y+(e.p.y-e.m.y)*n});if(e.kind==="SegQuad")return Hn(t)({x:e.m.x+(e.p.x-e.m.x)*n,y:e.m.y+(e.p.y-e.m.y)*n});g()},gJ=t=>e=>{if(e.kind==="SegMove")return lu(t)(e.p);if(e.kind==="SegLine")return Hn(t)(e.p);if(e.kind==="SegQuad")return du(t)(e.c)(e.p);g()},b_=t=>e=>{const n=uJ(e),r=T(s=>a=>s+a.len)(0)(n)*zn(0)(kr(1)(t)),i=[];let o=0,u=0;for(;u<n.length;){const s=u,a=o;if(s>=0&&s<n.length){if(a+n[s].len<=r){const c=n[s];gJ(i)(c)(),o=a+c.len,u=s+1|0;continue}if(a>=r){u=n.length;continue}cJ(i)(n[s])((r-a)/zn(n[s].len)(1e-4))()}u=n.length}return i},k_={offset:1.5,passes:2,rMax:14,overshoot:2.5},L_=t=>e=>n=>r=>{const i=r.y-n.y,o=n.y-e.y,u=r.x-n.x,s=Ce(u*u+i*i),a=n.x-e.x,c=Ce(a*a+o*o),f=kr(t.rMax*(ld(c>0&&s>0?zn(-1)(kr(1)((a*u+o*i)/(c*s))):1)/3.141592653589793))(.4*kr(c)(s));return{inP:c>0?{x:n.x-a/c*f,y:n.y-o/c*f}:n,curr:n,outP:s>0?{x:n.x+u/s*f,y:n.y+i/s*f}:n}},E_=t=>e=>{const n=e.length,r=[],i=0<e.length?w("Just",e[0]):J;if(i.tag==="Just"?lu(r)(i._1)():i.tag==="Nothing"||g(),n>=3){let u=1;for(;u<=(n-2|0);){const s=u,a=s+1|0;if(a>=0&&a<e.length){if(s>=0&&s<e.length){const c=s-1|0;if(c>=0&&c<e.length){const f=L_(t)(e[c])(e[s])(e[a]);Hn(r)(f.inP)(),du(r)(f.curr)(f.outP)()}}u=s+1|0;continue}u=s+1|0}}const o=e.length-1|0;return o>=0&&o<e.length&&n>=2&&Hn(r)(e[o])(),r},fJ=t=>e=>n=>r=>i=>{if(i.length<4)return E_(t)(i);const o=0<i.length?w("Just",i[0]):J,u=(()=>{if(o.tag==="Nothing")return{x:0,y:0};if(o.tag==="Just")return o._1;g()})(),s=i.length-1|0,a=Un(Un(e)(s)+s|0)(s),c=_=>{const h=Un(_+s|0)(s);return h>=0&&h<i.length?i[h]:u},f=O(_=>L_(t)(c((a+_|0)-1|0))(c(a+_|0))(c((a+_|0)+1|0)))(Ft(0,s-1|0)),d=[],l=0<f.length?w("Just",f[0]):J;if(l.tag==="Just")if(lu(d)(l._1.outP)(),eJ((()=>{const _=Qt(h=>J,h=>p=>w("Just",p),f);if(_.tag==="Nothing")return[];if(_.tag==="Just")return _._1;g()})())(_=>{const h=Hn(d)(_.inP);return()=>(h(),du(d)(_.curr)(_.outP)())})(),n)Hn(d)(l._1.inP)(),du(d)(l._1.curr)(l._1.outP)(),d.push(5);else{const _=f.length-1|0;_>=0&&_<f.length?Hn(d)((()=>{const h=1-r;return{x:f[_].outP.x+(l._1.inP.x-f[_].outP.x)*h,y:f[_].outP.y+(l._1.inP.y-f[_].outP.y)*h}})())():Hn(d)(l._1.inP)()}else l.tag==="Nothing"||g();return d},Zr=t=>e=>n=>r=>{const i=nJ(1)(r.length-1|0),o=pe(0)(et(i))(na("shape")(e)),u=rJ(i-1|0)(ce(mn(o.value))),s=o.prng;return O(a=>{const c=pe(0)(1)(na(ee(a))(s)),f=pe(-.18)(.3)(c.prng),d=c.value<.7,l=pe(.5)(.85)(f.prng),_=aJ(t.offset)(l.prng)(r);return{path:n?fJ(t)(u)(d)(f.value)(_):E_(t)(_),alpha:l.value}})(Ft(0,t.passes-1|0))},_J=t=>e=>n=>Zr(t)(e)(!0)([{x:n.x,y:n.y},{x:n.x+n.w,y:n.y},{x:n.x+n.w,y:n.y+n.h},{x:n.x,y:n.y+n.h},{x:n.x,y:n.y}]),dJ=t=>e=>n=>{const r=zn(0)(kr(1)(n)),i=e.h/et(4),o=zn(6)(i*1.4);return xt(u=>u)(O(u=>{if(r<zn(0)(et(u)/et(4)-.05))return J;const s=na(ee(u))(t),a=zn(0)(et(u)/et(4)-.05),c=Un(u)(2)===0,f=c?e.x-2:e.x+e.w+2,d=c?e.x+e.w+2:e.x-2,l=e.y+(et(u)+.5)*i;return w("Just",{path:b_(zn(0)(kr(1)((r-a)/zn(1e-4)(kr(1)(et(u+1|0)/et(4)+.05)-a))))((()=>{const _={rMax:2,offset:.6,passes:1},h=we(T(m=>y=>{const x=pe(-i*.08)(i*.08)(m.prng);return{prng:x.prng,out:[{x:f+(d-f)*(et(y)/et(4)),y:l+x.value},...m.out]}})({prng:s,out:[]})(Ft(0,4)).out),p=h.length<2?[]:Zr(_)(s)(!1)(h);return 0<p.length?p[0].path:[]})()),width:o,alpha:1})})(Ft(0,3)))},ga=(t,e,n)=>({tag:t,_1:e,_2:n}),C_=t=>t,fa=(t,e,n)=>({tag:t,_1:e,_2:n}),hu=t=>e=>n=>{const r=it.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=it.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},S_=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Xi=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},G_=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},ae=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},Ie=(()=>{const t=Ue.unfoldr(xn);return e=>t(Ke("IterNode",e,yn))})(),En=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},lJ=zt.foldMap(Cd),pu=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},P_=te(S)(zt),hJ=sc(S),pJ=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},_a=C_("LabelsShown"),mJ=C_("LabelsHidden"),D_=t=>{const e=t.Monad0().Bind1(),n=t.popTransform,r=t.popAlpha;return i=>o=>u=>s=>a=>e.bind(t.pushAlpha(i.fadeAlpha))(()=>e.bind(t.pushTransform({tx:o*(1-i.popScale),ty:u*(1-i.popScale),sx:i.popScale,sy:i.popScale}))(()=>e.bind(t.pushTransform({tx:0,ty:s.y*(1-i.flipY),sx:1,sy:i.flipY}))(()=>e.bind(a)(()=>e.bind(n)(()=>e.bind(n)(()=>r))))))},tn=t=>{const e=t.Apply0();return n=>T(r=>i=>e.apply(e.Functor0().map(o=>Ra)(r))(n(i)))(t.pure())},I_=t=>e=>n=>r=>i=>o=>{const u={x:n.x+n.w/2,y:n.y+n.h/2},s={x:e.x+e.w/2,y:e.y+e.h/2},a=Ur(i)(o)(r),c=0<t.length?w("Just",t[0]):J,f=(()=>{if(c.tag==="Just")return c._1;if(c.tag==="Nothing")return s;g()})(),d=t.length-1|0,l=d>=0&&d<t.length?w("Just",t[d]):J,_=(()=>{if(l.tag==="Just")return l._1;if(l.tag==="Nothing")return u;g()})(),h=d_(128)(br(4)(Kr(2)(e)))(y_(f)(6)),p=f.x-s.x,m=2*(()=>{const V=f.y-s.y;return(p<0?-p:p)+(V<0?-V:V)})(),y=_.x-u.x,x=2*(()=>{const V=_.y-u.y;return(y<0?-y:y)+(V<0?-V:V)})(),N=m+pi(t)+x,v=N<=1e-4?1:1-x/N,k=N<=1e-4?0:m/N,L=v-k,E=d_(128)(y_(_)(6))(br(4)(Kr(2)(n))),B={maxDelay:.4,smoothPasses:2},q=yr(t)(hu(0)(1)(L<=1e-4?0:(a-k)/L)),j=(()=>{if(q.tag==="Just")return q._1;if(q.tag==="Nothing")return f;g()})(),G=(()=>{if(v>=1)return 0;const V=(a-v)/(1-v),U=V<0?0:V>1?1:V;return U*U*(3-2*U)})(),P=(()=>{if(k<=1e-4)return 1;const V=a/k,U=V<0?0:V>1?1:V;return U*U*(3-2*U)})();return a<k?fa("PolyShape",h_(P)(h.from)(h.to)(B)):a>=v?fa("PolyShape",h_(G)(E.from)(E.to)(B)):fa("CircleShape",j,6)},A_=t=>e=>n=>r=>i=>o=>{const u=I_(t)(e)(n)(r)(i)(o);if(u.tag==="PolyShape")return x_(u._1);if(u.tag==="CircleShape")return u._1;g()},yJ=t=>e=>{const n=t.y+t.h-6,r=t.y+6,i=t.x+14,o=t.x+t.w-14,u=T(Xi)(0)(O(s=>i-10<s.x+s.w+12&&o+10>s.x-12&&r-10<s.y+s.h+12&&n+10>s.y-12?S_((s.x+s.w+12-(i-10))/.7071067811865476)((n+10-(s.y-12))/.7071067811865476):0)(e));return{...t,x:t.x+u*.7071067811865476,y:t.y-u*.7071067811865476}},xJ=t=>e=>n=>T(r=>i=>{const o=G_(i)(e);if(o.tag==="Nothing")return r;if(o.tag==="Just"){const u=yJ(o._1)(r.obstacles);return{acc:tt(S)(i)(u)(r.acc),obstacles:Rt(r.obstacles)(u)}}g()})({acc:A,obstacles:n})(t).acc,da=(()=>{const t={r:24,g:24,b:27,a:255},e={r:244,g:244,b:245,a:255},n={r:248,g:249,b:246,a:255},r={r:26,g:26,b:26,a:255},i={r:28,g:101,b:192,a:255},o={r:247,g:248,b:250,a:255},u={r:42,g:48,b:60,a:255},s={r:120,g:130,b:146,a:255};return a=>{if(a==="Light")return{bg:{r:255,g:255,b:255,a:255},bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:214,g:211,b:209,a:255},shadowFill:{r:255,g:255,b:255,a:255},shadowDot:{r:26,g:26,b:26,a:255},chip:{r:255,g:235,b:130,a:255},chipShadow:{r:214,g:211,b:209,a:255},chipText:Mn,nodeFill:ue,nodeStroke:Mn,text:Mn,edge:Mn,arrowFill:Mn,tokenOutsideFill:Mn,tokenOutsideStroke:ue,tokenInside:ue,tokenInsideStroke:ue,tokenInsideBlend:su,tokenInsideAlpha:1,chipPillFill:Mn,chipPillText:ue,chipHairline:{r:26,g:26,b:26,a:90},trailDot:Mn,wobble:!1,fontFamily:"Ilisarniq, ui-sans-serif, system-ui, sans-serif"};if(a==="Dark")return{bg:t,bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:63,g:63,b:70,a:255},shadowFill:t,shadowDot:e,chip:{r:234,g:179,b:8,a:255},chipShadow:{r:0,g:0,b:0,a:120},chipText:t,nodeFill:Mn,nodeStroke:e,text:e,edge:e,arrowFill:e,tokenOutsideFill:ue,tokenOutsideStroke:ue,tokenInside:ue,tokenInsideStroke:ue,tokenInsideBlend:su,tokenInsideAlpha:1,chipPillFill:e,chipPillText:t,chipHairline:{r:244,g:244,b:245,a:120},trailDot:e,wobble:!1,fontFamily:"Ilisarniq, ui-sans-serif, system-ui, sans-serif"};if(a==="Blueprint")return{bg:i,bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:90,g:160,b:230,a:255},shadowFill:i,shadowDot:ue,chip:ue,chipShadow:{r:0,g:0,b:0,a:120},chipText:i,nodeFill:i,nodeStroke:ue,text:ue,edge:ue,arrowFill:ue,tokenOutsideFill:ue,tokenOutsideStroke:ue,tokenInside:ue,tokenInsideStroke:ue,tokenInsideBlend:Xf,tokenInsideAlpha:.35,chipPillFill:ue,chipPillText:i,chipHairline:{r:255,g:255,b:255,a:120},trailDot:ue,wobble:!1,fontFamily:"Ilisarniq, ui-sans-serif, system-ui, sans-serif"};if(a==="Whiteboard")return{bg:n,bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:0,g:0,b:0,a:0},shadowFill:n,shadowDot:r,chip:{r:217,g:74,b:56,a:255},chipShadow:{r:26,g:26,b:26,a:60},chipText:n,nodeFill:n,nodeStroke:r,text:r,edge:r,arrowFill:r,tokenOutsideFill:r,tokenOutsideStroke:n,tokenInside:n,tokenInsideStroke:n,tokenInsideBlend:Xf,tokenInsideAlpha:1,chipPillFill:r,chipPillText:n,chipHairline:{r:26,g:26,b:26,a:90},trailDot:r,wobble:!0,fontFamily:"Supermarker, Ilisarniq, ui-sans-serif, system-ui, sans-serif"};if(a==="Isometric")return{bg:o,bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:214,g:218,b:224,a:255},shadowFill:o,shadowDot:u,chip:{r:255,g:235,b:130,a:255},chipShadow:{r:100,g:110,b:125,a:90},chipText:u,nodeFill:{r:236,g:239,b:244,a:255},nodeStroke:u,text:u,edge:s,arrowFill:s,tokenOutsideFill:u,tokenOutsideStroke:ue,tokenInside:ue,tokenInsideStroke:ue,tokenInsideBlend:su,tokenInsideAlpha:1,chipPillFill:u,chipPillText:ue,chipHairline:{r:60,g:66,b:78,a:90},trailDot:u,wobble:!1,fontFamily:"Ilisarniq, ui-sans-serif, system-ui, sans-serif"};g()}})(),la=t=>e=>wt(Ie(t.nodes))(n=>{const r=ae(n._1)(e.nodes);return r.tag==="Just"&&cu(r._1).alpha>0?zN(n._2):[]}),NJ=t=>e=>n=>[1,t.vx,t.vy,2,t.vx+t.vw,t.vy,2,t.vx+t.vw,t.vy+t.vh,2,t.vx,t.vy+t.vh,5,...la(e)(n)],JJ=t=>{const e=t.Monad0(),n=e.Bind1(),r=e.Applicative0(),i=cr.traverse(r);return o=>u=>{const s=hr(u),a=.32*o.size;return i(c=>n.bind(c===0?r.pure(0):t.measureText(o)(ye(c)(u)))(f=>n.bind(t.measureText(o)(ye(c+1|0)(u)))(d=>n.bind(t.measureInk(o)(c>=0&&c<s.length?_o(s[c]):" "))(l=>r.pure({x:f,w:d-f,up:l.ascent-a,down:l.descent+a})))))(Ft(0,s.length-1|0))}},TJ=t=>e=>{const n=i=>(i.x-e.x)*(i.x-e.x)+(i.y-e.y)*(i.y-e.y),r=T(i=>o=>n(o)<n(i)?o:i)({x:t.x,y:t.y})([{x:t.x,y:t.y},{x:t.x+t.w,y:t.y},{x:t.x,y:t.y+t.h},{x:t.x+t.w,y:t.y+t.h}]);return O(i=>{const o=et(i)/5;return{x:r.x+(e.x-r.x)*o,y:r.y+(e.y-r.y)*o}})([1,2,3,4])},ha=t=>{const e=wo(`
7
- `)(t);return e.length===0?[""]:e},wJ=t=>e=>n=>r=>i=>o=>{const u={x:n.x+n.w/2,y:n.y+n.h/2},s={x:e.x+e.w/2,y:e.y+e.h/2},a=Ur(i)(o)(r),c=0<t.length?w("Just",t[0]):J,f=(()=>{if(c.tag==="Just")return c._1;if(c.tag==="Nothing")return s;g()})(),d=t.length-1|0,l=d>=0&&d<t.length?w("Just",t[d]):J,_=(()=>{if(l.tag==="Just")return l._1;if(l.tag==="Nothing")return u;g()})(),h=f.x-s.x,p=2*(()=>{const B=f.y-s.y;return(h<0?-h:h)+(B<0?-B:B)})(),m=_.x-u.x,y=2*(()=>{const B=_.y-u.y;return(m<0?-m:m)+(B<0?-B:B)})(),x=p+pi(t)+y,N=x<=1e-4?1:1-y/x,v=x<=1e-4?0:p/x,k=N-v,L=yr(t)(hu(0)(1)(k<=1e-4?0:(a-v)/k)),E=(()=>{if(L.tag==="Just")return L._1;if(L.tag==="Nothing")return f;g()})();return a<v?ga("InsideRect",Kr(2)(e)):a>=N?ga("InsideRect",Kr(2)(n)):ga("InsideBall",E,6)},vJ={offset:.8,passes:2,rMax:5},bJ=t=>{const e=t.Monad0().Applicative0(),n=tn(e);return r=>i=>o=>u=>{const s={color:u,width:1,lineJoin:be,lineCap:pn},a={color:o,flat:!0},c=f=>t.drawRoundedRect({x:f.x,y:f.y,w:f.w,h:f.h})(4)(w("Just",a))(w("Just",s));return n(f=>{if(f._2.tag==="Travelling"){const d=En(f._2._1.edge)(r.edges),l=ae(f._2._1.target)(r.nodes),_=ae(f._2._1.source)(r.nodes);if(_.tag==="Just"&&l.tag==="Just"&&d.tag==="Just"){const h=wJ((()=>{if(f._2._1.direction==="Forward")return d._1;if(f._2._1.direction==="Backward")return we(d._1);g()})())(_._1)(l._1)(f._2._1.progress)(f._2._1.holdPre)(f._2._1.holdPost);if(h.tag==="InsideRect")return c(h._1);if(h.tag==="InsideBall")return t.fillStrokePath(gu(h._1)(h._2))(a)(s);g()}return e.pure()}if(f._2.tag==="Filling"){const d=ae(f._2._1.node)(r.nodes);if(d.tag==="Just")return c(Kr(2)(d._1));if(d.tag==="Nothing")return e.pure();g()}return e.pure()})(Ie(i.tokens))}},F_=t=>e=>n=>r=>t.strokePath((()=>{const i=Qt(o=>J,o=>u=>w("Just",{head:o,tail:u}),O(o=>o.pt)(ad(o=>u=>{const s=et(u)/et(72),a=pe(-.18)(.18)(o.prng),c=pe(-.1)(.1)(a.prng),f=pe(-.07)(.07)(c.prng),d=n*(.05+.55*s)*(1+c.value),l=s*28.274333882308138+a.value;return{prng:f.prng,pt:{x:e.x+rn(l)*d+f.value*n,y:e.y+Ve(l)*d+f.value*n}}},{prng:137,pt:{x:e.x,y:e.y}},Ft(0,72))));if(i.tag==="Just")return[1,i._1.head.x,i._1.head.y,...lJ(o=>[2,o.x,o.y])(i._1.tail)];if(i.tag==="Nothing")return[];g()})())({color:r,width:5.5,lineJoin:be,lineCap:bn}),kJ=t=>{const e=t.Monad0(),n=e.Bind1(),r=t.popAlpha,i=tn(e.Applicative0());return o=>u=>s=>i(a=>n.bind(t.pushAlpha(a.alpha))(()=>n.bind(t.strokePath(a.path)({color:o.nodeFill,width:a.width,lineJoin:be,lineCap:bn}))(()=>r)))(dJ(v_(u)+7777|0)(u)(s))},B_=t=>{const e=t.Monad0(),n=e.Bind1(),r=t.popAlpha,i=e.Applicative0(),o=tn(i),u=t.popClip,s=tn(i),a=cr.traverse(i),c=JJ(t),f=kJ(t),d=t.popTransform;return l=>_=>h=>p=>m=>y=>x=>N=>v=>{const k=D=>n.bind(t.pushAlpha(D.alpha))(()=>n.bind(t.strokePath(D.path)({color:h.nodeStroke,width:2,lineJoin:be,lineCap:bn}))(()=>r)),L={family:h.fontFamily,size:h.wobble?15:11,weight:h.wobble?800:500},E=wo(`
8
- `)(N.label===""?x:N.label),B=E.length===0?[""]:E,q=L.size*1.2,j=N.shape==="Cylinder"?t.strokePath(aN({x:N.x,y:N.y,w:N.w,h:N.h}))({color:h.nodeStroke,width:1.25,lineJoin:be,lineCap:pn}):i.pure(),G=(N.shape==="Cylinder"?(N.y+(N.y+N.h+5-2*un(N.h*.075)(N.w*.075)))/2:(N.y+N.y+N.h)/2)-et(B.length)*q/2+q/2,P=v.tag==="PloppingOut"&&h.wobble?v._1:-1,V=P>=0,U=cu(v),M=V?{alpha:1,scale:1}:U,H=N.x+N.w/2,R=N.y+N.h/2,C=n.bind(t.pushAlpha(M.alpha*p))(()=>n.bind(t.pushTransform({tx:H*(1-M.scale),ty:R*(1-M.scale),sx:M.scale,sy:M.scale}))(()=>{const D={x:N.x,y:N.y,w:N.w,h:N.h},F={color:h.nodeStroke,width:h.wobble?2:1.25*_,lineJoin:be,lineCap:h.wobble?bn:pn};return n.bind((()=>{if(h.wobble){if(N.shape==="Rectangle")return o(k)(_J(k_)(v_(D))(D));const I=br(7)(N);return n.bind(o(k)((()=>{const z=qi(I);return I.length<4?[]:Zr(w_)(z)(!0)(I)})()))(()=>s(z=>o(k)((()=>{const $=qi(z);return z.length<2?[]:Zr(w_)($)(!1)(z)})()))(N.shape==="Cylinder"?[UN(N)]:[]))}return n.bind(ia(t)(N.shape)(D)(7)(w("Just",{color:h.nodeFill,flat:!1}))(w("Just",F)))(()=>j)})())(()=>n.bind((()=>{if(y.tag==="Just"&&h.wobble&&!V){const I=y._1;return n.bind(a(c(L))(B))(z=>{const $=Et(ut=>st=>it.compare(ut.x)(st.x)),X=ce(mn(N.x*7919+N.y*3001))*-1640531535|0,Y=pe(5)(7.5)(X),W=pe(0)(Y.value)(Y.prng),K=-(1+2*pe(-1)(1)(W.prng).value*3.141592653589793/180),Z=(ut,st,Nt,Jt,kt)=>$(xt(Ot=>Ot)([K*st+ut>=Jt&&K*st+ut<=kt?w("Just",{x:st,y:K*st+ut}):J,K*Nt+ut>=Jt&&K*Nt+ut<=kt?w("Just",{x:Nt,y:K*Nt+ut}):J,(()=>{const Ot=(Jt-ut)/K;return Ot>=st&&Ot<=Nt?w("Just",{x:Ot,y:Jt}):J})(),(()=>{const Ot=(kt-ut)/K;return Ot>=st&&Ot<=Nt?w("Just",{x:Ot,y:kt}):J})()])),ct=Y.value,_t=Un(I.frameHash)(3),gt=_t===0?{r:200,g:35,b:30,a:220}:_t===1?{r:35,g:150,b:80,a:220}:{r:30,g:80,b:200,a:220},yt=N.x+N.w/2,St=We(Bt(ut=>st=>Bt((()=>{const Nt=G+et(ut)*q,Jt=yt-T(kt=>Ot=>kt+Ot.w)(0)(st)/2;return kt=>Ot=>{const _n=L.size*.1,Fe=kt-1|0,Pt=Fe>=0&&Fe<st.length&&kt>0?(st[Fe].x+st[Fe].w+Ot.x)/2:Ot.x-_n;return{x:Jt+Pt-1,y:Nt-Ot.up-1,w:Xi(0)((()=>{const At=kt+1|0;return At>=0&&At<st.length&&kt<(st.length-1|0)?(Ot.x+Ot.w+st[At].x)/2-Pt:Ot.x+Ot.w+_n-Pt})())+2,h:Ot.up+Ot.down+2}}})())(st))(z)),Ht=N.y+4,pt=N.x+N.w-4,Wt=N.x+4,Tt=Ht-K*Wt+W.value,mt=N.y+N.h-4,ft=wt(wt(Bt(ut=>st=>{const Nt=(st.from.x+st.to.x)/2,Jt=(st.from.y+st.to.y)/2,kt=pe(-1)(1)(X+(911*(ut+1|0)|0)|0),Ot=pe(-3)(5)(kt.prng),_n=kt.value*3.141592653589793/180,Fe=rn(_n),Pt=Ve(_n),At=Be=>({x:Nt+(Be.x-Nt)*Fe-(Be.y-Jt)*Pt,y:Jt+(Be.x-Nt)*Pt+(Be.y-Jt)*Fe});return{from:(()=>{const Be=At(st.from),an=Be.y-Jt,Xe=Be.x-Nt,nn=Ce(Xe*Xe+an*an),Pe=nn<1e-4?1:(nn+Ot.value)/nn;return{x:Nt+Xe*Pe,y:Jt+an*Pe}})(),to:(()=>{const Be=At(st.to),an=pe(-3)(5)(Ot.prng).value,Xe=Be.y-Jt,nn=Be.x-Nt,Pe=Ce(nn*nn+Xe*Xe),qt=Pe<1e-4?1:(Pe+an)/Pe;return{x:Nt+nn*qt,y:Jt+Xe*qt}})()}})(xt(ut=>{const st=Z(Tt+et(ut)*ct,Wt,pt,Ht,mt);return st.length===2?w("Just",{from:st[0],to:st[1]}):J})(Ft(0,pu(1)(ce(mn((mt-K*pt-Tt)/ct)))))))(ut=>at(st=>st.to.x-st.from.x>1,T(st=>Nt=>wt(st)(Jt=>{const kt=Z(Jt.from.y-K*Jt.from.x,Nt.x,Nt.x+Nt.w,Nt.y,Nt.y+Nt.h);return kt.length===2?kt[0].x>Jt.from.x+.001&&kt[1].x<Jt.to.x-.001?[{from:Jt.from,to:kt[0]},{from:kt[1],to:Jt.to}]:kt[0].x<=Jt.from.x+.001&&kt[1].x<Jt.to.x-.001?[{from:kt[1],to:Jt.to}]:kt[0].x>Jt.from.x+.001&&kt[1].x>=Jt.to.x-.001?[{from:Jt.from,to:kt[0]}]:[]:[Jt]}))([ut])(St))))(ut=>(()=>{const st=ut.to.x-ut.from.x;return Ce(2)*(st>=0?st:-st)<=28})()?[ut]:[{from:ut.from,to:{x:ut.from.x+(ut.to.x-ut.from.x)*.495,y:ut.from.y+(ut.to.y-ut.from.y)*.495}},{from:{x:ut.from.x+(ut.to.x-ut.from.x)*.505,y:ut.from.y+(ut.to.y-ut.from.y)*.505},to:ut.to}]),ot=ft.length,dt=ut=>Xi(0)(S_(1)(I.t*et(ot)-et(ut)));return n.bind(t.pushClip(sa(br(7)(N)))(uu))(()=>n.bind(o(ut=>{const st=ut._1,Nt=pe(1.4)(1.9)(X+(1303*(st+1|0)|0)|0),Jt=pe(.35)(.8)(Nt.prng),kt=o(Ot=>n.bind(t.pushAlpha(Ot.alpha*Jt.value))(()=>n.bind(t.strokePath(b_(dt(st))(Ot.path))({color:gt,width:Nt.value,lineJoin:be,lineCap:bn}))(()=>r)))(Zr({...k_,rMax:0,offset:.5})(X+(53*(st+1|0)|0)|0)(!1)([ut._2.from,ut._2.to]));return dt(st)>0?kt:i.pure()})(Bt(Pn)(ft)))(()=>u))})}return i.pure()})())(()=>n.bind((()=>{if(l==="LabelsShown"){const I=n.bind(t.pushAlpha(m))(()=>n.bind(o(z=>t.drawText({x:N.x+N.w/2,y:G+et(z._1)*q,content:z._2,font:L,color:h.text,align:Xr,baseline:ur}))(Bt(Pn)(B)))(()=>r));return m>0?I:i.pure()}if(l==="LabelsHidden")return i.pure();g()})())(()=>n.bind((()=>{const I=f(h)(D)(P);return V?I:i.pure()})())(()=>n.bind(d)(()=>r)))))}));return M.alpha*p>0?C:i.pure()}},Q_=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=B_(t),o=t.popAlpha,u=tn(n);return s=>a=>c=>{const f={...s,nodeFill:s.text,text:s.nodeFill,nodeStroke:s.nodeFill};return u(d=>{const l=ae(d._1)(c.nodes),_=ae(d._1)(a.nodes),h=(()=>{if(_.tag==="Just"&&l.tag==="Just"){const p=l._1,m=_._1;return r.bind(t.pushAlpha(d._2))(()=>r.bind(i(_a)(1)(f)(1)(1)(J)(d._1)(m)(p))(()=>o))}return n.pure()})();return d._2>0?h:n.pure()})(Ie(c.nodeInvert))}},LJ=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=tn(n);return o=>u=>s=>{const a={family:o.fontFamily,size:11,weight:500};return i(c=>{if(c._2===""||(()=>{const l=En(c._1)(s.edges);return l.tag==="Nothing"||!(l.tag==="Just"&&l._1.tag==="Extended")})())return n.pure();const f=En(c._1)(u.edges),d=(()=>{if(f.tag==="Just")return yr(f._1)(.5);if(f.tag==="Nothing")return J;g()})();if(d.tag==="Nothing")return n.pure();if(d.tag==="Just"){const l=d._1;return r.bind(t.measureText(a)(c._2))(_=>{const h=_+12;return r.bind(t.drawRoundedRect({x:l.x-h/2,y:l.y-8.5,w:h,h:17})(3)(w("Just",{color:o.chipPillFill,flat:!0}))(J))(()=>t.drawText({x:l.x,y:l.y,content:c._2,font:a,color:o.chipPillText,align:Xr,baseline:ur}))})}g()})(Ie(u.edgeLabels))}},EJ=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=t.popAlpha;return o=>u=>s=>a=>c=>f=>d=>l=>_=>{const h=(()=>{if(_>1e-4&&d>1-_){const m=(1-d)/_;return m<0?0:m>1?1:m}if(l>1e-4&&d<l){const m=d/l;return m<0?0:m>1?1:m}return 1})(),p=I_(a)(c)(f)(d)(l)(_);if(p.tag==="CircleShape")return o?F_(t)(p._1)(p._2)({r:200,g:35,b:30,a:220}):t.fillStrokePath(gu(p._1)(p._2))({color:u,flat:!0})({color:s,width:1,lineJoin:be,lineCap:pn});if(p.tag==="PolyShape"&&o&&p._1.length>=3)return r.bind(t.pushAlpha(h))(()=>r.bind(F_(t)(x_(p._1))(6)({r:200,g:35,b:30,a:220}))(()=>i));if(p.tag==="PolyShape")return o?n.pure():p._1.length>=3?t.fillStrokePath(sa(p._1))({color:u,flat:!0})({color:s,width:1,lineJoin:be,lineCap:pn}):n.pure();g()}},CJ=t=>{const e=t.Monad0().Bind1(),n=t.popAlpha;return r=>i=>o=>u=>s=>a=>c=>{const f=Ur(a)(c)(s),d={x:o.x+o.w/2,y:o.y+o.h/2},l={x:u.x+u.w/2,y:u.y+u.h/2},_=(h,p)=>e.bind(t.pushAlpha(p))(()=>e.bind(t.fillStrokePath(gu(h)(6))({color:r,flat:!0})({color:i,width:1,lineJoin:be,lineCap:pn}))(()=>n));return f<.5?_(d,(()=>{const h=f*2;return 1-(h<0?0:h>1?1:h)*(h<0?0:h>1?1:h)*(h<0?3:h>1?1:3-2*h)})()):_(l,(()=>{const h=(f-.5)*2;return(h<0?0:h>1?1:h)*(h<0?0:h>1?1:h)*(h<0?3:h>1?1:3-2*h)})())}},mu=t=>{const e=EJ(t),n=CJ(t),r=t.Monad0().Applicative0(),i=tn(r);return o=>u=>s=>a=>c=>i(f=>{if(f._2.tag==="Travelling"){const d=ae(f._2._1.target)(u.nodes),l=ae(f._2._1.source)(u.nodes);if(l.tag==="Just"&&d.tag==="Just"){const _=En(f._2._1.edge)(u.edges);if(_.tag==="Just")return e(o)(a)(c)((()=>{if(f._2._1.direction==="Forward")return _._1;if(f._2._1.direction==="Backward")return we(_._1);g()})())(l._1)(d._1)(f._2._1.progress)(f._2._1.holdPre)(f._2._1.holdPost);if(_.tag==="Nothing")return n(a)(c)(l._1)(d._1)(f._2._1.progress)(f._2._1.holdPre)(f._2._1.holdPost);g()}return r.pure()}if(f._2.tag==="Filling"){if(o)return r.pure();const d=ae(f._2._1.node)(u.nodes);if(d.tag==="Just")return t.fillStrokePath(sa(br(4)(Kr(2)(d._1))))({color:a,flat:!0})({color:c,width:1,lineJoin:be,lineCap:pn});if(d.tag==="Nothing")return r.pure();g()}return r.pure()})(Ie(s.tokens))},R_=t=>{const e=mu(t),n=t.Monad0(),r=n.Bind1(),i=mu(t),o=bJ(t),u=t.popClip,s=t.popBlend,a=t.popLayer,c=n.Applicative0(),f=tn(c),d=t.popAlpha;return l=>_=>h=>p=>{const m=_.wobble?e(!0)(h)(p)(_.tokenInside)(_.tokenInsideStroke):r.bind(t.insideTokenStyle(l))(y=>{if(y==="GenieSilhouette")return i(!1)(h)(p)(_.tokenInside)(_.tokenInsideStroke);if(y==="ConvexAbsorb")return o(h)(p)(_.tokenInside)(_.tokenInsideStroke);g()});if(_.tokenInsideBlend==="Difference")return r.bind(t.pushLayer(qx))(()=>r.bind(t.pushBlend(su))(()=>r.bind(t.pushClip(la(h)(p))(uu))(()=>r.bind(m)(()=>r.bind(u)(()=>r.bind(s)(()=>r.bind(a)(()=>r.bind(t.pushLayer(Xx))(()=>r.bind(f(y=>{const x=ae(y._1)(p.nodes);return x.tag==="Just"&&cu(x._1).alpha>0?ia(t)(y._2.shape)({x:y._2.x,y:y._2.y,w:y._2.w,h:y._2.h})(7)(w("Just",{color:ue,flat:!1}))(J):c.pure()})(Ie(h.nodes)))(()=>a)))))))));if(_.tokenInsideBlend==="Normal")return r.bind(t.pushClip(la(h)(p))(uu))(()=>r.bind(t.pushAlpha(_.tokenInsideAlpha))(()=>r.bind(m)(()=>r.bind(d)(()=>u))));g()}},M_=t=>{const e=t.Monad0().Bind1(),n=mu(t),r=mu(t),i=t.popClip,o=t.popLayer;return u=>s=>a=>c=>e.bind(t.pushLayer($x))(()=>e.bind(t.pushClip(NJ(s)(a)(c))(Ux))(()=>e.bind(u.wobble?n(!0)(a)(c)(u.tokenOutsideFill)(u.tokenOutsideStroke):r(!1)(a)(c)(u.tokenOutsideFill)(u.tokenOutsideStroke))(()=>e.bind(i)(()=>o))))},SJ=t=>{const e=t.Monad0(),n=e.Bind1(),r=e.Applicative0(),i=tn(r);return o=>u=>s=>a=>c=>f=>{const d=ko(f).length,l=et(d+1|0),_=m=>{const y=(s*l-et(m))/1.5,x=y<0?0:y>1?1:y;return x*x*(3-2*x)},h=(m=>{let y=m,x=!0,N;for(;x;){const v=y;if(v>=d){x=!1,N=v;continue}if(_(v)>=1){y=v+1|0;continue}x=!1,N=v}return N})(0),p=h>=d?[]:_r(m=>_(m)>0)(Ft(h,d-1|0)).init;return n.bind((()=>{const m=t.drawText({x:a,y:c,content:ye(h)(f),font:o,color:u,align:ta,baseline:ur});return h>0?m:r.pure()})())(()=>i(m=>n.bind(t.measureText(o)(ye(m)(f)))(y=>{const x=_(m);return t.drawText({x:a+y,y:c-(1-x)*10,content:ye(1)(li(jn(ye(m)(f)))(f)),font:o,color:{...u,a:ce(mn(x*et(u.a)))},align:ta,baseline:ur})}))(p))}},yu=t=>e=>n=>r=>{const i=O(_=>et(pu(1)(ko(_).length)))(r),o=Xi(1)(T(Gr)(0)(i)),u=Ur(e)(n)(t),s=u*o,a=pu(1)(r.length),c=(_=>h=>p=>{let m=_,y=h,x=p,N=!0,v;for(;N;){const k=m,L=y,E=Qt(B=>J,B=>q=>w("Just",{head:B,tail:q}),x);if(E.tag==="Nothing"){N=!1,v=pu(0)(a-1|0);continue}if(E.tag==="Just"){if(L+E._1.head>=s){N=!1,v=k;continue}m=k+1|0,y=L+E._1.head,x=E._1.tail;continue}g()}return v})(0)(0)(i),f=T(Gr)(0)(c<1?[]:Lt(0,c,i)),d=f/o;if(c>=0&&c<i.length){const _=(f+i[c])/o;return{line:c>=0&&c<r.length?r[c]:"",phaseInLabel:(()=>{if(_<=d)return 1;const h=(u-d)/(_-d);return h<0?0:h>1?1:h})()}}const l=(f+1)/o;return{line:c>=0&&c<r.length?r[c]:"",phaseInLabel:(()=>{if(l<=d)return 1;const _=(u-d)/(l-d);return _<0?0:_>1?1:_})()}},GJ=t=>{const e=t.Monad0();return n=>r=>i=>e.Bind1().bind(t.measureText({family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:11,weight:500})(yu(r)(0)(0)(O(nd)(i)).line))(o=>{const u=o+28;return e.Applicative0().pure({x:n.x+n.w/2-u/2,y:n.y-25.2-14,w:u,h:25.2})})},PJ=t=>{const e=t.Monad0(),n=e.Bind1(),r=GJ(t),i=e.Applicative0(),o=cr.traverse(i);return u=>s=>n.Apply0().Functor0().map(a=>P_(xt(c=>c)(a)))(o(a=>{if(a._2.tag==="Filling"&&a._2._1.labels.length!==0){const c=ae(a._2._1.node)(u.nodes);if(c.tag==="Just")return n.bind(r(c._1)(a._2._1.progress)(a._2._1.labels))(f=>i.pure(w("Just",b(a._1,f))));if(c.tag==="Nothing")return i.pure(J);g()}return i.pure(J)})(Ie(s.tokens)))},DJ=t=>{const e=t.Monad0();return n=>r=>i=>o=>u=>s=>a=>{const c=A_(n)(r)(i)(o)(u)(s);return e.Bind1().bind(t.measureText({family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:11,weight:500})(yu(o)(u)(s)(wt(a)(ha)).line))(f=>e.Applicative0().pure({x:c.x+14+f/2-f/2-14,y:c.y-6-8-6.6-6,w:f+28,h:25.2}))}},IJ=t=>{const e=t.Monad0(),n=e.Bind1(),r=DJ(t),i=e.Applicative0(),o=cr.traverse(i);return u=>s=>n.Apply0().Functor0().map(a=>P_(xt(c=>c)(a)))(o(a=>{if(a._2.tag==="Travelling"&&a._2._1.labels.length!==0){const c=ae(a._2._1.target)(u.nodes),f=ae(a._2._1.source)(u.nodes),d=En(a._2._1.edge)(u.edges);if(d.tag==="Just"&&f.tag==="Just"&&c.tag==="Just")return n.bind(r((()=>{if(a._2._1.direction==="Forward")return d._1;if(a._2._1.direction==="Backward")return we(d._1);g()})())(f._1)(c._1)(a._2._1.progress)(a._2._1.holdPre)(a._2._1.holdPost)(a._2._1.labels))(l=>i.pure(w("Just",b(a._1,l))))}return i.pure(J)})(Ie(s.tokens)))},pa=t=>{const e=t.Monad0(),n=e.Bind1(),r=IJ(t),i=PJ(t);return o=>u=>n.bind(r(o)(u))(s=>n.bind(i(o)(u))(a=>e.Applicative0().pure(xJ((()=>{const c=f=>{if(f.tag==="Leaf")return A;if(f.tag==="Node")return Yt("Node",f._1,f._2,f._3,void 0,c(f._5),c(f._6));g()};return Et(S.compare)(Ct(Qe.foldr,c(s)))})())(s)([...xt(c=>{const f=ae(c._1)(u.nodes);return f.tag==="Just"&&cu(f._1).alpha>0?w("Just",{x:c._2.x,y:c._2.y,w:c._2.w,h:c._2.h}):J})(Ie(o.nodes)),...(()=>{const c=(f,d)=>{if(f.tag==="Leaf")return d;if(f.tag==="Node")return c(f._5,$t("Cons",f._4,c(f._6,d)));g()};return Ct(Vt.foldr,c(a,Xt))})()]))))},z_=t=>e=>n=>{const r=wi(6)(.55)(hu(0)(1)((1-t)/.06)),i=t>.94,o=i&&n>1e-4,u=wi(6)(.55)(hu(0)(1)(t/.06)),s=t<.06,a=s&&e>1e-4,c=i&&n<=1e-4;return{popScale:a?u:o?r:1,flipY:s&&e<=1e-4?u:c?r:1,fadeAlpha:(()=>{if(a){const f=t/.06;return f<0?.55:f>1?1:.55+.44999999999999996*f}if(o){const f=(1-t)/.06;return f<0?.55:f>1?1:.55+.44999999999999996*f}return 1})()}},AJ=t=>{const e=t.Monad0().Bind1(),n=D_(t);return r=>i=>o=>u=>s=>{const a=z_(u)(0)(0),c={family:r.fontFamily,size:11,weight:500},f=yu(u)(0)(0)(wt(s)(ha));return e.bind(t.measureText(c)(f.line))(d=>{const l=o.x+o.w/2,_=d+28,h=o.y-25.2-14,p=l-_/2,m=[1,l,h+25.2,2,l,o.y],y={x:l,y:h+12.6};return n(a)(l-_/2)(h+25.2)(y)(e.bind(t.drawRoundedRect({x:l-_/2,y:h+1.5,w:_,h:25.2})(6)(w("Just",{color:r.chipShadow,flat:!0}))(J))(()=>e.bind(t.drawRoundedRect({x:p,y:h,w:_,h:25.2})(6)(w("Just",{color:r.chip,flat:!0}))(w("Just",{color:r.chipHairline,width:1,lineJoin:be,lineCap:pn})))(()=>e.bind(t.strokePath(m)({color:r.chipHairline,width:1,lineJoin:be,lineCap:pn}))(()=>t.drawText({x:l,y:y.y,content:f.line,font:c,color:r.chipText,align:Xr,baseline:ur})))))})}},FJ=t=>{const e=D_(t),n=t.Monad0(),r=n.Bind1(),i=tn(n.Applicative0()),o=SJ(t);return u=>s=>a=>c=>f=>d=>l=>_=>h=>{const p=yu(f)(d)(l)(wt(_)(ha)),m=p.line,y=p.phaseInLabel/.45,x=y<0?0:y>1?1:y,N=h.w,v=h.y,k=h.x,L=k+14,E=h.h,B=v+E/2;return e(z_(f)(d)(l))(k)(v+E)({x:k+N/2,y:B})(r.bind(i(q=>t.fillPath(gu(q)(1.5))({color:u.trailDot,flat:!0}))(TJ(h)(A_(s)(a)(c)(f)(d)(l))))(()=>r.bind(t.drawRoundedRect({x:k,y:v,w:N,h:E})(3)(w("Just",{color:u.chipPillFill,flat:!0}))(J))(()=>o({family:u.fontFamily,size:11,weight:500})(u.chipPillText)(x)(L)(B)(m))))}},ma=t=>{const e=FJ(t),n=t.Monad0(),r=n.Applicative0(),i=AJ(t),o=n.Bind1(),u=tn(r),s=t.popLayer;return a=>c=>f=>d=>o.bind(t.pushLayer(Vx))(()=>o.bind(u(l=>{if(l._2.tag==="Travelling"){if(l._2._1.labels.length!==0){const _=ae(l._2._1.target)(c.nodes),h=ae(l._2._1.source)(c.nodes),p=En(l._2._1.edge)(c.edges),m=G_(l._1)(d);if(m.tag==="Just"&&p.tag==="Just"&&h.tag==="Just"&&_.tag==="Just")return e(a)((()=>{if(l._2._1.direction==="Forward")return p._1;if(l._2._1.direction==="Backward")return we(p._1);g()})())(h._1)(_._1)(l._2._1.progress)(l._2._1.holdPre)(l._2._1.holdPost)(l._2._1.labels)(m._1)}return r.pure()}if(l._2.tag==="Filling"&&l._2._1.labels.length!==0){const _=ae(l._2._1.node)(c.nodes);if(_.tag==="Just")return i(a)(c)(_._1)(l._2._1.progress)(l._2._1.labels);if(_.tag==="Nothing")return r.pure();g()}return r.pure()})(Ie(f.tokens)))(()=>s))},H_=t=>{const e=pa(t),n=ma(t);return r=>i=>o=>t.Monad0().Bind1().bind(e(i)(o))(u=>n(r)(i)(o)(u))},BJ=t=>{const e=t.Monad0(),n=e.Applicative0();return r=>i=>{const o=i.length-1|0,u=o<1?[]:Lt(0,o,i),s=u.length-1|0,a=s>=0&&s<u.length?w("Just",u[s]):J,c=i.length-1|0,f=c>=0&&c<i.length?w("Just",i[c]):J;if(f.tag==="Just"&&a.tag==="Just"){const d=pe(.78)(1.18)(qi(i)+19|0),l=pe(.4)(.62)(d.prng),_=r.wobble?8.75*l.value:4.375,h=pe(.4)(.62)(l.prng),p=r.wobble?8.75*h.value:4.375,m=f._1.y-a._1.y,y=f._1.x-a._1.x,x=Ce(y*y+m*m),N=m/x,v=-N,k=y/x,L=f._1.x+k*.875,E=f._1.y+N*.875,B=r.wobble?8.75*d.value:8.75,q=L-k*B,j=E-N*B,G=q+v*_,P=j+k*_,V=[1,L,E,2,q+v*4.375,j+k*4.375,2,q-v*4.375,j-k*4.375,5],U=q-v*p,M=j-k*p,H={color:r.arrowFill,width:2,lineJoin:be,lineCap:bn};return x<=1e-4?n.pure():r.wobble?e.Bind1().bind(t.strokePath([1,G,P,2,L,E])(H))(()=>t.strokePath([1,U,M,2,L,E])(H)):t.fillPath(V)({color:r.arrowFill,flat:!0})}return n.pure()}},QJ=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=tn(n),o=t.popAlpha,u=BJ(t);return s=>a=>c=>f=>{const d=ON(8)(c);if(f.hi<=f.lo)return n.pure();const l=ZN(d)(f.lo)(f.hi);if(l.length===0)return n.pure();const _={color:s.edge,width:s.wobble?2:.9375,lineJoin:be,lineCap:bn},h=s.wobble?pe(-10)(4)(qi(l)).value:0,p=s.wobble?sJ(h)(l):l;return r.bind(s.wobble?i(m=>r.bind(t.pushAlpha(m.alpha))(()=>r.bind(t.strokePath(m.path)(_))(()=>o)))((()=>{const m=qi(l);return p.length<2?[]:Zr(vJ)(m)(!1)(p)})()):t.strokePath(MN(l))(_))(()=>{const m=u(s)(p);return f.hi>=.999?m:n.pure()})}},W_=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=QJ(t),o=t.popAlpha,u=tn(n);return s=>a=>c=>{const f=d=>{const l=Kt(_=>d.x>=_._2.x-1&&d.x<=_._2.x+_._2.w+1&&d.y>=_._2.y-1&&d.y<=_._2.y+_._2.h+1)(Ie(a.nodes));return l.tag==="Just"?w("Just",l._1._2):J};return u(d=>{const l=En(d._1)(c.edges);if(l.tag==="Just"){const _=l._1,h=En(d._1)(c.edgeFadeAlpha),p=(()=>{if(h.tag==="Nothing")return 1;if(h.tag==="Just")return h._1;g()})(),m=r.bind(t.pushAlpha(p))(()=>r.bind(i(s)(d._1)((()=>{const y=(()=>{if(0<d._2.length){const N=f(d._2[0]);if(N.tag==="Just")return we(J_(br(7)(N._1))(we(d._2)))}return d._2})(),x=y.length-1|0;if(x>=0&&x<y.length){const N=f(y[x]);if(N.tag==="Just")return J_(br(7)(N._1))(y)}return y})())((()=>{if(_.tag==="Retracted")return{lo:0,hi:0};if(_.tag==="Extended")return{lo:0,hi:1};if(_.tag==="Extending")return{lo:0,hi:_._2};if(_.tag==="Retracting"){if(_._1==="FromSource")return{lo:_._2,hi:1};if(_._1==="FromTarget")return{lo:0,hi:1-_._2};if(_._1==="FromBoth")return{lo:_._2/2,hi:1-_._2/2}}g()})()))(()=>o));return p>0?m:n.pure()}if(l.tag==="Nothing")return n.pure();g()})(Ie(a.edges))}},RJ=t=>e=>{const n=o=>{const u=ae(o)(t.nodes);if(u.tag==="Nothing")return!1;if(u.tag==="Just"){const s=u._1;return!Oe(a=>0<a._2.length&&a._2[0].x>=s.x&&a._2[0].x<=s.x+s.w&&a._2[0].y>=s.y&&a._2[0].y<=s.y+s.h,Ie(t.edges))}g()},r=T(o=>u=>(o*31|0)+er(u)|0)(5381)(hr(e.frameTitle)),i=o=>{const u=ae(o)(t.nodes);if(u.tag==="Nothing")return!1;if(u.tag==="Just"){const s=u._1;return!Oe(a=>{const c=a._2.length-1|0;return c>=0&&c<a._2.length&&a._2[c].x>=s.x&&a._2[c].x<=s.x+s.w&&a._2[c].y>=s.y&&a._2[c].y<=s.y+s.h},Ie(t.edges))}g()};return T(o=>u=>{const s=u._2;return hJ(a=>{if(a.tag==="Nothing")return w("Just",s);if(a.tag==="Just")return w("Just",{t:Xi(a._1.t)(s.t),angle:s.t>=a._1.t?s.angle:a._1.angle,bigCircle:a._1.bigCircle||s.bigCircle,frameHash:a._1.frameHash});g()})(u._1)(o)})(A)(wt(Ie(e.tokens))(o=>{if(o._2.tag==="Filling"){const u=o._2._1.node;return[b(u,{t:1,angle:(()=>{const s=xt(a=>(()=>{const c=ae(u)(t.nodes),f=a._2.length-1|0;return f>=0&&f<a._2.length&&c.tag==="Just"&&a._2[f].x>=c._1.x&&a._2[f].x<=c._1.x+c._1.w&&a._2[f].y>=c._1.y&&a._2[f].y<=c._1.y+c._1.h})()?w("Just",a._2):J)(Ie(t.edges));if(0<s.length){const a=s[0].length-1|0,c=a<1?[]:Lt(0,a,s[0]),f=c.length-1|0;if(f>=0&&f<c.length){const d=s[0].length-1|0;return d>=0&&d<s[0].length?dr(s[0][d].y-c[f].y)(s[0][d].x-c[f].x):0}s[0].length-1|0}return 0})(),bigCircle:n(u)||i(u),frameHash:r})]}if(o._2.tag==="Travelling"){if(o._2._1.progress>=.75)return[b(o._2._1.target,{t:(o._2._1.progress-.75)/.25,angle:(()=>{const u=En(o._2._1.edge)(t.edges);if(u.tag==="Just"){const s=u._1.length-1|0,a=s<1?[]:Lt(0,s,u._1),c=a.length-1|0;if(c>=0&&c<a.length){const f=u._1.length-1|0;return f>=0&&f<u._1.length?dr(u._1[f].y-a[c].y)(u._1[f].x-a[c].x):0}return u._1.length-1|0,0}if(u.tag==="Nothing")return 0;g()})(),bigCircle:n(o._2._1.target)||i(o._2._1.target),frameHash:r})];if(o._2._1.progress<.25)return[b(o._2._1.source,{t:o._2._1.progress/.25,angle:(()=>{const u=En(o._2._1.edge)(t.edges);if(u.tag==="Just")return 1<u._1.length&&0<u._1.length?dr(u._1[1].y-u._1[0].y)(u._1[1].x-u._1[0].x):0;if(u.tag==="Nothing")return 0;g()})(),bigCircle:n(o._2._1.source)||i(o._2._1.source),frameHash:r})]}return[]}))},MJ=t=>T(e=>n=>(e*31|0)+er(n)|0)(5381)(hr(t.frameTitle)),O_=t=>{const e=B_(t),n=t.Monad0().Applicative0(),r=tn(n);return i=>o=>u=>s=>a=>{const c=MJ(a),f=RJ(s)(a);return r(d=>{const l=ae(d._1)(a.nodes);if(l.tag==="Just")return e(i)(o)(u)((()=>{const _=ae(d._1)(a.nodeFadeAlpha);if(_.tag==="Nothing")return 1;if(_.tag==="Just")return _._1;g()})())((()=>{const _=ae(d._1)(a.nodeLabelFadeAlpha);if(_.tag==="Nothing")return 1;if(_.tag==="Just")return _._1;g()})())((()=>{const _=ae(d._1)(f);return _.tag==="Just"?w("Just",_._1):_.tag==="Nothing"&&pJ(d._1)(a.visited)?w("Just",{t:1,angle:0,bigCircle:!1,frameHash:c}):J})())(d._1)(d._2)(l._1);if(l.tag==="Nothing")return n.pure();g()})(Ie(s.nodes))}},zJ=t=>t,HJ=t=>e=>{const n=e.vw/e.vh,r=e.vh*t,i={...e,vx:e.vx-(r-e.vw)/2,vw:r},o=e.vw/t,u={...e,vy:e.vy-(o-e.vh)/2,vh:o};return t<=0||e.vw<=0||e.vh<=0?e:t>n?i:t<n?u:e},WJ=t=>e=>n=>{const r=nt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=nt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},Y_=t=>e=>n=>{const r=it.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=it.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},$_=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},ya=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},OJ=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},YJ=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},$J=t=>e=>{const n=Ve(t.angle),r=rn(t.angle);return{a:r,b:n,c:0,d:1,e:-e*r,f:e*n-t.boxHeight/2}},qJ=t=>[t.box.ground.a,t.box.ground.b,t.box.ground.c,t.box.ground.d,t.box.top.a,t.box.top.b,t.box.top.c,t.box.top.d],jr=t=>e=>{const n=r=>WJ(0)(255)(ce(Dn(et(r)*t)));return{r:n(e.r),g:n(e.g),b:n(e.b),a:e.a}},Ge=t=>e=>n=>r=>({x:(e-n)*rn(t.angle),y:(e+n)*Ve(t.angle)-r}),Lr=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return[];if(e.tag==="Just")return[1,e._1.head.x,e._1.head.y,...wt(e._1.tail)(n=>[2,n.x,n.y]),5];g()},XJ=t=>e=>n=>r=>i=>{const o=(()=>{if(t==="Forward")return i;if(t==="Backward")return we(i);g()})();if(0<o.length){const s=yr(o)(Y_(0)(1)(Ur(n)(r)(e)));if(s.tag==="Nothing")return o[0];if(s.tag==="Just")return s._1;g()}const u=yr(o)(Y_(0)(1)(Ur(n)(r)(e)));if(u.tag==="Nothing")return{x:0,y:0};if(u.tag==="Just")return u._1;g()},VJ=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return[];if(e.tag==="Just")return[1,e._1.head.x,e._1.head.y,...wt(e._1.tail)(n=>[2,n.x,n.y])];g()},UJ=t=>{const e=Qt(n=>J,n=>r=>w("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return{vx:0,vy:0,vw:0,vh:0};if(e.tag==="Just"){const n=T(r=>i=>({minX:$_(r.minX)(i.x),minY:$_(r.minY)(i.y),maxX:ya(r.maxX)(i.x),maxY:ya(r.maxY)(i.y)}))({minX:e._1.head.x,minY:e._1.head.y,maxX:e._1.head.x,maxY:e._1.head.y})(e._1.tail);return{vx:n.minX-40,vy:n.minY-40,vw:n.maxX-n.minX+80,vh:n.maxY-n.minY+80}}g()},KJ=t=>{const e=t.Monad0().Bind1();return n=>r=>i=>{const o=i.box,u=i.np,s={color:r.nodeStroke,width:1,lineJoin:be,lineCap:pn};return e.bind(t.fillStrokePath(Lr([o.ground.d,o.ground.c,o.top.c,o.top.d]))({color:jr(.66)(r.nodeFill),flat:!0})(s))(()=>e.bind(t.fillStrokePath(Lr([o.ground.b,o.ground.c,o.top.c,o.top.b]))({color:jr(.82)(r.nodeFill),flat:!0})(s))(()=>e.bind(t.fillStrokePath(Lr([o.top.a,o.top.b,o.top.c,o.top.d]))({color:jr(1)(r.nodeFill),flat:!0})(s))(()=>t.drawTextAffine($J(n)(u.y+u.h))({x:u.x+u.w/2,y:0,content:u.label,font:{family:r.fontFamily,size:11,weight:600},color:r.text,align:Xr,baseline:ur}))))}},ZJ=t=>{const e=t.Monad0().Bind1();return n=>r=>i=>o=>{const u={color:r.tokenOutsideStroke,width:1,lineJoin:be,lineCap:pn},s=o.x-5.5,a=o.x+5.5,c=o.y-5.5,f=o.y+5.5,d=i+11,l=Ge(n)(s)(c)(d),_=Ge(n)(a)(c)(d),h=Ge(n)(a)(f)(d),p=Ge(n)(s)(f)(d),m=Ge(n)(a)(f)(i),y=Ge(n)(a)(c)(i);return e.bind(t.fillStrokePath(Lr([Ge(n)(s)(f)(i),m,h,p]))({color:jr(.66)(r.tokenOutsideFill),flat:!0})(u))(()=>e.bind(t.fillStrokePath(Lr([y,m,h,_]))({color:jr(.82)(r.tokenOutsideFill),flat:!0})(u))(()=>t.fillStrokePath(Lr([l,_,h,p]))({color:jr(1)(r.tokenOutsideFill),flat:!0})(u)))}},jJ=t=>{const e=ZJ(t);return n=>r=>i=>o=>{if(o.tag==="Travelling"){const u=OJ(o._1.edge)(i.edges);return u.tag==="Just"?w("Just",(()=>{const s=XJ(o._1.direction)(o._1.progress)(o._1.holdPre)(o._1.holdPost)(u._1);return{depth:s.x+s.y,draw:e(n)(r)(0)(s)}})()):J}if(o.tag==="Filling"){const u=YJ(o._1.node)(i.nodes);if(u.tag==="Just")return w("Just",(()=>{const s={x:u._1.x+u._1.w/2,y:u._1.y+u._1.h/2};return{depth:s.x+s.y,draw:e(n)(r)(n.boxHeight)(s)}})())}return J}},tT={angle:.5235987755982988,boxHeight:26,transparentBg:!0},eT=t=>e=>{const n=e.y+e.h,r=e.x+e.w;return{ground:{a:Ge(t)(e.x)(e.y)(0),b:Ge(t)(r)(e.y)(0),c:Ge(t)(r)(n)(0),d:Ge(t)(e.x)(n)(0)},top:{a:Ge(t)(e.x)(e.y)(t.boxHeight),b:Ge(t)(r)(e.y)(t.boxHeight),c:Ge(t)(r)(n)(t.boxHeight),d:Ge(t)(e.x)(n)(t.boxHeight)},depth:(e.x+r)/2+(e.y+n)/2}},q_=t=>e=>O(n=>({np:n,box:eT(t)(n)}))((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._4,n(r._6,i)));g()};return Ct(Vt.foldr,n(e.nodes,Xt))})()),nT=t=>e=>[...wt(q_(t)(e))(qJ),...(()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._4,n(r._6,i)));g()};return wt(Ct(Vt.foldr,n(e.edges,Xt)))(O(r=>Ge(t)(r.x)(r.y)(0)))})()],rT=t=>{const e=t.to.y-t.from.y,n=t.to.x-t.from.x,r=ya(1e-4)(Ce(n*n+e*e)),i=e/r,o=n/r,u=t.to.y-i*7,s=t.to.x-o*7;return Lr([t.to,{x:s-i*3,y:u+o*3},{x:s+i*3,y:u-o*3}])},iT=t=>{const e=t.Monad0(),n=e.Applicative0();return r=>i=>o=>u=>s=>{const a=Ge(r)(s.x)(s.y)(0),c=Ge(r)(u.x)(u.y)(0);return e.Bind1().bind(t.strokePath(VJ([c,a]))({color:i.edge,width:1.5,lineJoin:be,lineCap:bn}))(()=>{const f=t.fillPath(rT({from:c,to:a}))({color:i.arrowFill,flat:!0});return o?f:n.pure()})}},oT=t=>{const e=iT(t);return n=>r=>i=>{const o=ve(Pn,i,Lt(1,i.length,i)),u=o.length-1|0;return Bt(s=>a=>({depth:(a._1.x+a._1.y+a._2.x+a._2.y)/2,draw:e(n)(r)(s===u)(a._1)(a._2)}))(o)}},uT=t=>{const e=KJ(t),n=jJ(t),r=oT(t),i=t.Monad0(),o=Du(i.Applicative0())(zt);return u=>s=>a=>c=>{const f=da(s),d=[...(()=>{const l=(_,h)=>{if(_.tag==="Leaf")return h;if(_.tag==="Node")return l(_._5,$t("Cons",_._4,l(_._6,h)));g()};return wt(Ct(Vt.foldr,l(a.edges,Xt)))(r(u)(f))})(),...O(l=>({depth:l.box.depth,draw:e(u)(f)(l)}))(q_(u)(a)),...xt(n(u)(f)(a))((()=>{const l=(_,h)=>{if(_.tag==="Leaf")return h;if(_.tag==="Node")return l(_._5,$t("Cons",_._4,l(_._6,h)));g()};return Ct(Vt.foldr,l(c.tokens,Xt))})())];return i.Bind1().bind((()=>{const l=UJ(nT(u)(a));return t.Monad0().Bind1().bind(t.clearBackground(u.transparentBg?f.bgTransparent:f.bg))(()=>t.setViewport(l))})())(()=>o(l=>l.draw)(Et(l=>_=>it.compare(l.depth)(_.depth))(d)))}},X_=(t,e)=>({tag:t,_1:e}),xu=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},sT=t=>e=>n=>{const r=it.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=it.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},xa=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},aT=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},cT=X_("ResolvedLabels"),gT=t=>{const e=Kt(n=>n.role==="FlyThrough")(t.levels);if(e.tag==="Just")return e._1;if(e.tag==="Nothing")return Ao(t);g()},Nu=t=>e=>{const n=xu(1)(qe(e.rootLayout).w),r=Sc(e.rootLayout)(e.camera),i=!e.diving&&e.levels.length===1?1:sT(0)(1)(r.w/n),o=Ao(e).state.frameTitle===""?0*i:40*i,u=t.padding*i;return(()=>{if(t.outputAspect.tag==="Nothing")return zJ;if(t.outputAspect.tag==="Just")return HJ(t.outputAspect._1);g()})()({vx:r.x-u,vy:r.y-u-o,vw:r.w+2*u,vh:r.h+2*u+o})},fT=t=>e=>{if(e.tag==="Nothing")return[];if(e.tag==="Just"){const n=xa(e._1)(t.segment.layout.nodes);if(n.tag==="Nothing")return[];if(n.tag==="Just"){const r=n._1.x*t.segment.placement.scale+t.segment.placement.tx,i=n._1.y*t.segment.placement.scale+t.segment.placement.ty,o=n._1.w*t.segment.placement.scale,u=n._1.h*t.segment.placement.scale;return[1,r,i,2,r+o,i,2,r+o,i+u,2,r,i+u,5]}}g()},_T=t=>{const e=t.Monad0(),n=e.Bind1();return r=>i=>{if(r==="")return e.Applicative0().pure();const o=i.vh/720,u=56*o;return n.bind(t.measureText({family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:56,weight:700})(r))(s=>{const a=u+16*o*2,c=s*o+28*o*2,f=i.vy+i.vh/2,d=i.vx+i.vw/2;return n.bind(t.drawRoundedRect({x:d-c/2,y:f-a/2,w:c,h:a})(16*o)(w("Just",{color:{r:255,g:255,b:255,a:235},flat:!0}))(w("Just",{color:{r:0,g:0,b:0,a:255},width:1.5*o,lineJoin:be,lineCap:bn})))(()=>t.drawText({x:d,y:f,content:r,font:{family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:u,weight:700},color:{r:28,g:30,b:36,a:255},align:Xr,baseline:ur}))})}},dT=t=>{const e=t.Monad0(),n=e.Bind1();return r=>i=>{if(r==="")return e.Applicative0().pure();const o=i.vh/720,u=15*o;return n.bind(t.measureText({family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:15,weight:600})(r))(s=>{const a=i.vy+12*o,c=u+6*o*2,f=s*o+11*o*2,d=i.vx+i.vw/2;return n.bind(t.drawRoundedRect({x:d-f/2,y:a,w:f,h:c})(c/2)(w("Just",{color:{r:255,g:255,b:255,a:240},flat:!0}))(w("Just",{color:{r:0,g:0,b:0,a:255},width:1*o,lineJoin:be,lineCap:bn})))(()=>t.drawText({x:d,y:a+c/2,content:r,font:{family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:u,weight:600},color:{r:28,g:30,b:36,a:255},align:Xr,baseline:ur}))})}},lT=t=>{const e=H_(t),n=ma(t),r=t.Monad0(),i=r.Bind1(),o=r.Applicative0(),u=W_(t),s=O_(t)(_a)(1),a=Q_(t),c=M_(t),f=R_(t),d=LJ(t),l=t.popBlur,_=t.popAlpha,h=_T(t),p=dT(t);return m=>y=>x=>N=>v=>k=>L=>E=>{const B=da(m.theme),q=(()=>{if(E.tag==="ResolvedLabels")return e(B)(k)(L);if(E.tag==="SpringLabels")return n(B)(k)(L)(E._1);g()})();return i.bind(t.Monad0().Bind1().bind(t.clearBackground(m.transparentBg?B.bgTransparent:B.bg))(()=>t.setViewport(v)))(()=>i.bind((()=>{const j=i.bind((()=>{const G=t.pushAlpha(x);return x<1?G:o.pure()})())(()=>i.bind((()=>{const G=t.pushBlur(N);return N>0?G:o.pure()})())(()=>i.bind(u(B)(k)(L))(()=>i.bind(s(B)(k)(L))(()=>i.bind(a(B)(k)(L))(()=>i.bind(c(B)(v)(k)(L))(()=>i.bind(f(tN)(B)(k)(L))(()=>i.bind(q)(()=>i.bind((()=>{const G=d(B)(k)(L);return L.staticKind!=="Animated"?G:o.pure()})())(()=>i.bind(N>0?l:o.pure())(()=>x<1?_:o.pure()))))))))));return x>0?j:o.pure()})())(()=>i.bind(m.watermark===""?t.Monad0().Applicative0().pure():t.drawText({x:v.vx+6,y:v.vy+6,content:m.watermark,font:{family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:9,weight:600},color:{r:180,g:180,b:180,a:255},align:ta,baseline:Yx}))(()=>L.staticKind==="TitleCard"?h(L.frameTitle)(v):p(L.frameTitle)(v))))}},V_=t=>{const e=t.Monad0().Applicative0(),n=Xa(e)(zt);return r=>i=>o=>u=>n(u.minis)(s=>{const a=U_(t)(r)(i)(o)(A)(u)(s);return(()=>{const c=s.segment.path.length-1|0;return s.bgAlpha>0&&c>=0&&c<s.segment.path.length&&(()=>{const f=xa(s.segment.path[c])(u.state.nodes);if(f.tag==="Just")return f._1.tag==="Hidden"?!1:f._1.tag!=="PloppingOut";if(f.tag==="Nothing")return!1;g()})()})()?a:e.pure()})},U_=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=t.popTransform,o=H_(t),u=ma(t),s=W_(t),a=O_(t),c=Q_(t),f=M_(t),d=R_(t),l=t.popBakedTransform,_=t.popClip,h=t.popBlur,p=t.popAlpha;return m=>y=>x=>N=>v=>k=>{const L=k.blur>0,E=k.segment.placement,B=k.state,q={tx:E.tx,ty:E.ty,sx:E.scale,sy:E.scale},j=da(m.theme),G=k.segment.layout,P=qe(G),V={vx:P.x-1e3,vy:P.y-1e3,vw:P.w+2e3,vh:P.h+2e3},U=k.segment.path.length-1|0,M=U>=0&&U<k.segment.path.length?xa(k.segment.path[U])(v.segment.layout.nodes):J,H=k.segment.placement.scale*x,R=aT(8)(xu(1)(1/(1.25*xu(1e-6)(H)))),C=11*H>=5?_a:mJ,D=(()=>{if(M.tag==="Nothing")return n.pure();if(M.tag==="Just"){const z=M._1;return r.bind(t.pushTransform({tx:v.segment.placement.tx,ty:v.segment.placement.ty,sx:v.segment.placement.scale,sy:v.segment.placement.scale}))(()=>r.bind(ia(t)(z.shape)({x:z.x+1,y:z.y+1,w:z.w-2,h:z.h-2})(7)(w("Just",{color:j.bg,flat:!0}))(J))(()=>i))}g()})(),F=(()=>{if(C==="LabelsHidden")return n.pure();if(C==="LabelsShown")return N.tag==="Leaf"?o(j)(G)(B):u(j)(G)(B)(N);g()})(),I=fT(v)((()=>{const z=k.segment.path.length-1|0;return z>=0&&z<k.segment.path.length?w("Just",k.segment.path[z]):J})());return r.bind(t.pushAlpha(k.bgAlpha))(()=>r.bind((()=>{const z=t.pushBlur(k.blur*E.scale);return L?z:n.pure()})())(()=>r.bind(t.pushClip(I)(uu))(()=>r.bind(v.role==="Active"||v.role==="FlyThrough"?D:n.pure())(()=>r.bind(t.pushTransform(q))(()=>r.bind(s(j)(G)(B))(()=>r.bind(a(C)(R)(j)(G)(B))(()=>r.bind(c(j)(G)(B))(()=>r.bind(f(j)(V)(G)(B))(()=>r.bind(i)(()=>r.bind(t.pushBakedTransform(q))(()=>r.bind(d(eN)(j)(G)(B))(()=>r.bind(l)(()=>r.bind(t.pushTransform(q))(()=>r.bind(F)(()=>r.bind(i)(()=>r.bind(_)(()=>r.bind(V_(t)(m)(y)(x)(k))(()=>r.bind(L?h:n.pure())(()=>p)))))))))))))))))))}},K_=t=>{const e=uT(t),n=t.Monad0(),r=n.Applicative0(),i=n.Bind1(),o=U_(t),u=lT(t),s=V_(t);return a=>c=>f=>{if(a.theme==="Isometric")return e({...tT,transparentBg:a.transparentBg})(a.theme)(Ao(f).segment.layout)(Ao(f).state);const d=Nu(a)(f),l=m=>f.hasDives?d.vw/xu(1)(qe(f.rootLayout).w):1,_={tileScale:l(),viewport:d},h=m=>y=>{if(y.length===0)return r.pure();const x=Qt(N=>J,N=>v=>w("Just",{head:N,tail:v}),y);if(x.tag==="Nothing")return r.pure();if(x.tag==="Just"){const N=x._1.head,v=x._1.tail;return i.bind((()=>{const k=o(a)(_)(f.camera.zoom)(N.role==="Active"?c:A)(m)(N);return f.diving||N.role==="Active"?k:r.pure()})())(()=>h(N)(v))}g()},p=Qt(m=>J,m=>y=>w("Just",{head:m,tail:y}),f.levels);if(p.tag==="Nothing")return r.pure();if(p.tag==="Just"){const m=p._1.tail,y=p._1.head;return i.bind((()=>{const x=m.length===0;return u(a)(l())(y.role==="Active"||y.role==="FlyThrough"?y.bgAlpha:0)(y.blur)(d)(y.segment.layout)(gT(f).state)(x&&c.tag!=="Leaf"?X_("SpringLabels",c):cT)})())(()=>i.bind((()=>{const x=s(a)(_)(f.camera.zoom)(y);return y.role==="Active"||y.role==="FlyThrough"?x:r.pure()})())(()=>h(y)(m)))}g()}},hT=pa(g_),Z_=K_(g_),pT=t=>e=>n=>r=>i=>o=>u=>{const s={padding:24,transparentBg:(()=>{if(e==="TransparentBackground")return!0;if(e==="PaintBackground")return!1;g()})(),halftoneShadows:!0,watermark:"",theme:t,outputAspect:r.width<=0||r.height<=0?J:w("Just",r.width/r.height)},a=pN(n)(r);return()=>{const c=a(),f=i.levels.length-1|0;if(f>=0&&f<i.levels.length){const l=hT(i.levels[f].segment.layout)(i.levels[f].state)(c)(),_=Zs(o)(l)(u);return Z_(s)(_.applied)(i)(c)(),_.springs}const d=Zs(o)(A)(u);return Z_(s)(d.applied)(i)(c)(),d.springs}},mT=t=>t,Vi=t=>t,Na=Vi("Light"),yT=Vi("Dark"),xT=Vi("Blueprint"),NT=Vi("Whiteboard"),JT=Vi("Isometric"),TT=mT("TransparentBackground"),sr=t=>"rgb("+ee(t.r)+","+ee(t.g)+","+ee(t.b)+")",Cn=gi(ai("Fixed",ci(0)(20)(4))),wT=t=>"translate("+Cn(t.tx)+","+Cn(t.ty)+") scale("+Cn(t.sx)+","+Cn(t.sy)+")",vt=gi(ai("Fixed",ci(0)(20)(2))),Ja=t=>{const e=[];let n=0;for(;n<t.length;){const r=n,i=r>=0&&r<t.length?w("Just",t[r]):J;if(i.tag==="Nothing"){n=t.length;continue}if(i.tag==="Just"){if(i._1===1){e.push("M"),e.push(vt((()=>{const o=r+1|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+2|0;return o>=0&&o<t.length?t[o]:0})())),n=r+3|0;continue}if(i._1===2){e.push("L"),e.push(vt((()=>{const o=r+1|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+2|0;return o>=0&&o<t.length?t[o]:0})())),n=r+3|0;continue}if(i._1===3){e.push("Q"),e.push(vt((()=>{const o=r+1|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+2|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+3|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+4|0;return o>=0&&o<t.length?t[o]:0})())),n=r+5|0;continue}if(i._1===4){e.push("C"),e.push(vt((()=>{const o=r+1|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+2|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+3|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+4|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+5|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+6|0;return o>=0&&o<t.length?t[o]:0})())),n=r+7|0;continue}if(i._1===5){e.push("Z"),n=r+1|0;continue}n=t.length;continue}g()}return vo(" ")(e)},vT={map:t=>e=>n=>{const r=e(n);return()=>{const i=r();return t(i)}}},Ta=(()=>{const t=nr("&")("&amp;"),e=nr("<")("&lt;"),n=(()=>{const r=nr(">")("&gt;"),i=(()=>{const o=nr('"')("&quot;");return u=>o(r(u))})();return o=>i(e(o))})();return r=>n(t(r))})(),bT=t=>{if(t.style==="RunText")return"<tspan>"+Ta(t.text)+"</tspan>";if(t.style==="RunCode")return`<tspan font-family="'CommitMono', ui-monospace, SFMono-Regular, Menlo, monospace" font-weight="400">`+Ta(t.text)+"</tspan>";g()},ke=t=>e=>{const n=e.maskDepth;return()=>{n.value===0&&e.out.push(t)}},kT=t=>e=>{const n=[];let r=0;const i=o=>{const u=o>=0&&o<e.length?t.sx*e[o]+t.tx:t.sx*0+t.tx;return()=>{n.push(u),n.push((()=>{const s=o+1|0;return s>=0&&s<e.length?t.sy*e[s]+t.ty:t.sy*0+t.ty})())}};for(;r<e.length;){const o=r,u=o>=0&&o<e.length?w("Just",e[o]):J;if(u.tag==="Nothing"){r=e.length;continue}if(u.tag==="Just"){if(u._1===1){n.push(u._1),i(o+1|0)(),r=o+3|0;continue}if(u._1===2){n.push(u._1),i(o+1|0)(),r=o+3|0;continue}if(u._1===3){n.push(u._1),i(o+1|0)(),i(o+3|0)(),r=o+5|0;continue}if(u._1===4){n.push(u._1),i(o+1|0)(),i(o+3|0)(),i(o+5|0)(),r=o+7|0;continue}if(u._1===5){n.push(u._1),r=o+1|0;continue}r=e.length;continue}g()}return n},Ju=t=>e=>{const n=t.bake;return()=>{const r=n.value;if(r.tag==="Nothing")return e;if(r.tag==="Just")return kT(r._1)(e);g()}},j_={apply:t=>e=>n=>{const r=t(n),i=e(n);return()=>{const o=r(),u=i();return o(u)}},Functor0:()=>vT},LT={bind:t=>e=>n=>{const r=t(n);return()=>{const i=r();return e(i)(n)()}},Apply0:()=>j_},ET={pure:t=>e=>()=>t,Apply0:()=>j_},CT={Applicative0:()=>ET,Bind1:()=>LT},ST=t=>e=>'<defs><pattern id="'+t+'" x="'+vt(e.origin.x)+'" y="'+vt(e.origin.y)+'" width="'+vt(e.tile)+'" height="'+vt(e.tile)+'" patternUnits="userSpaceOnUse">'+(e.bgColor.a===0?"":'<rect width="'+vt(e.tile)+'" height="'+vt(e.tile)+'" fill="'+sr(e.bgColor)+'" fill-opacity="'+vt(et(e.bgColor.a)/255)+'"/>')+'<circle cx="'+vt(e.tile/2)+'" cy="'+vt(e.tile/2)+'" r="'+vt(e.dotRadius)+'" fill="'+sr(e.dotColor)+'"/></pattern></defs><rect x="'+vt(e.viewport.vx)+'" y="'+vt(e.viewport.vy)+'" width="'+vt(e.viewport.vw)+'" height="'+vt(e.viewport.vh)+'" fill="url(#'+t+')"/>',t1=t=>e=>'<path d="'+Ja(t)+'" fill="'+sr(e)+'" fill-opacity="'+vt(et(e.a)/255)+'"/>',GT=t=>e=>n=>r=>'<rect x="'+vt(t.x)+'" y="'+vt(t.y)+'" width="'+vt(t.w)+'" height="'+vt(t.h)+'" rx="'+vt(e)+'"'+(()=>{if(n.tag==="Just")return' fill="'+sr(n._1.color)+'" fill-opacity="'+vt(et(n._1.color.a)/255)+'"';if(n.tag==="Nothing")return' fill="none"';g()})()+(()=>{if(r.tag==="Just")return' stroke="'+sr(r._1.color)+'" stroke-opacity="'+vt(et(r._1.color.a)/255)+'" stroke-width="'+vt(r._1.width)+'" stroke-linejoin="'+(()=>{if(r._1.lineJoin==="RoundJoin")return"round";if(r._1.lineJoin==="BevelJoin")return"bevel";if(r._1.lineJoin==="MiterJoin")return"miter";g()})()+'" stroke-linecap="'+(()=>{if(r._1.lineCap==="ButtCap")return"butt";if(r._1.lineCap==="RoundCap")return"round";if(r._1.lineCap==="SquareCap")return"square";g()})()+'"';if(r.tag==="Nothing")return"";g()})()+"/>",e1=t=>e=>'<path d="'+Ja(t)+'" fill="none" stroke="'+sr(e.color)+'" stroke-opacity="'+vt(et(e.color.a)/255)+'" stroke-width="'+vt(e.width)+'" stroke-linejoin="'+(()=>{if(e.lineJoin==="RoundJoin")return"round";if(e.lineJoin==="BevelJoin")return"bevel";if(e.lineJoin==="MiterJoin")return"miter";g()})()+'" stroke-linecap="'+(()=>{if(e.lineCap==="ButtCap")return"butt";if(e.lineCap==="RoundCap")return"round";if(e.lineCap==="SquareCap")return"square";g()})()+'"/>',n1=t=>{const e=gg(Rr(t.content));return'<text x="'+vt(t.x)+'" y="'+vt(t.y)+'"'+(()=>{if(t.baseline==="BaselineTop")return' dy="0.8em"';if(t.baseline==="BaselineMiddle")return' dy="0.32em"';if(t.baseline==="BaselineAlphabetic"||t.baseline==="BaselineBottom")return"";g()})()+' fill="'+sr(t.color)+'" fill-opacity="'+vt(et(t.color.a)/255)+'" font-size="'+vt(t.font.size)+'" font-family="Ilisarniq, ui-sans-serif, system-ui, sans-serif" font-weight="'+ee(t.font.weight)+'" text-anchor="'+(()=>{if(t.align==="AlignLeft")return"start";if(t.align==="AlignCenter")return"middle";if(t.align==="AlignRight")return"end";g()})()+'">'+(e.length===1&&e[0].style==="RunText"?Ta(e[0].text):vo("")(O(bT)(e)))+"</text>"},PT=t=>"matrix("+Cn(t.a)+" "+Cn(t.b)+" "+Cn(t.c)+" "+Cn(t.d)+" "+Cn(t.e)+" "+Cn(t.f)+")",r1={fillPath:t=>e=>n=>{const r=Ju(n)(t);return()=>{const i=r();return ke(t1(i)(e.color))(n)()}},strokePath:t=>e=>n=>{const r=Ju(n)(t);return()=>{const i=r(),o=n.bake.value;return ke(e1(i)((()=>{if(o.tag==="Nothing")return e;if(o.tag==="Just")return{...e,width:o._1.sx*e.width};g()})()))(n)()}},fillStrokePath:t=>e=>n=>r=>{const i=Ju(r)(t);return()=>{const o=i(),u=r.bake.value;return ke(t1(o)(e.color)+e1(o)((()=>{if(u.tag==="Nothing")return n;if(u.tag==="Just")return{...n,width:u._1.sx*n.width};g()})()))(r)()}},drawRoundedRect:t=>e=>n=>r=>i=>{const o=i.bake;return()=>{const u=o.value;return ke(GT((()=>{if(u.tag==="Nothing")return t;if(u.tag==="Just")return{x:u._1.sx*t.x+u._1.tx,y:u._1.sy*t.y+u._1.ty,w:u._1.sx*t.w,h:u._1.sy*t.h};g()})())((()=>{if(u.tag==="Nothing")return e;if(u.tag==="Just")return u._1.sx*e;g()})())(n)(r.tag==="Just"?w("Just",(()=>{if(u.tag==="Nothing")return r._1;if(u.tag==="Just")return{...r._1,width:u._1.sx*r._1.width};g()})()):J))(i)()}},drawText:t=>e=>{const n=e.bake;return()=>{const r=n.value;return ke(n1((()=>{if(r.tag==="Nothing")return t;if(r.tag==="Just")return{...t,x:r._1.sx*t.x+r._1.tx,y:r._1.sy*t.y+r._1.ty,font:{...t.font,size:r._1.sx*t.font.size}};g()})()))(e)()}},drawTextAffine:t=>e=>ke((()=>{const n='transform="'+PT(t)+'"';return(n===""?"<g>":"<g "+n+">")+n1(e)+"</g>"})()),pushTransform:t=>ke((()=>{const e='transform="'+wT(t)+'"';return e===""?"<g>":"<g "+e+">"})()),popTransform:ke("</g>"),pushBakedTransform:t=>e=>{const n=e.bake;return()=>{n.value=w("Just",t)}},popBakedTransform:t=>{const e=t.bake;return()=>{e.value=J}},pushClip:t=>e=>n=>{const r=n.clipCounter;return()=>{const i=r.value;n.clipCounter.value=i+1|0;const o=Ju(n)(t)(),u="clip"+ee(i);return ke((()=>{const s='clip-path="url(#'+u+')"';return'<defs><clipPath id="'+u+'"><path d="'+Ja(o)+'"'+(()=>{if(e==="EvenOdd")return' clip-rule="evenodd"';if(e==="NonZero")return"";g()})()+"/></clipPath></defs>"+(s===""?"<g>":"<g "+s+">")})())(n)()}},popClip:ke("</g>"),pushBlend:t=>ke((()=>{const e=(()=>{if(t==="Normal")return'style="mix-blend-mode: normal"';if(t==="Difference")return'style="mix-blend-mode: difference"';g()})();return e===""?"<g>":"<g "+e+">"})()),popBlend:ke("</g>"),pushAlpha:t=>ke((()=>{const e='opacity="'+vt(t)+'"';return e===""?"<g>":"<g "+e+">"})()),popAlpha:ke("</g>"),pushBlur:t=>e=>{if(t<.01)return ke("<g>")(e);const n=e.patternCounter;return()=>{const r=n.value;e.patternCounter.value=r+1|0;const i="lvl-blur-"+ee(r);return ke((()=>{const o='filter="url(#'+i+')"';return'<defs><filter id="'+i+'" x="-20%" y="-20%" width="140%" height="140%"><feGaussianBlur stdDeviation="'+vt(t)+'"/></filter></defs>'+(o===""?"<g>":"<g "+o+">")})())(e)()}},popBlur:ke("</g>"),pushLayer:t=>e=>{const n=(()=>{if(t==="LayerNodeMask"){const r=e.maskDepth;return()=>{const i=r.value;e.maskDepth.value=i+1|0}}return()=>{}})();return()=>{n(),e.out.push("<g>")}},popLayer:t=>{const e=t.maskDepth;return()=>{const n=e.value,r=n-1|0;n>0&&(t.maskDepth.value=r),t.out.push("</g>")}},setViewport:t=>e=>()=>{},clearBackground:t=>e=>ke('<rect x="'+vt(e.viewport.vx)+'" y="'+vt(e.viewport.vy)+'" width="'+vt(e.viewport.vw)+'" height="'+vt(e.viewport.vh)+'" fill="'+sr(t)+'" opacity="'+vt(et(t.a)/255)+'"/>')(e),backgroundDots:t=>e=>{const n=e.patternCounter;return()=>{const r=n.value;return e.patternCounter.value=r+1|0,ke(ST("bg-dots-"+ee(r))(t))(e)()}},measureText:t=>e=>n=>{const r=zf(t)(e);return()=>r},measureInk:t=>e=>n=>{const r=Hf(t)(e);return()=>r},insideTokenStyle:t=>e=>()=>Kf,Monad0:()=>CT},DT=K_(r1),IT=pa(r1),AT=t=>e=>n=>r=>i=>{const o={padding:24,transparentBg:(()=>{if(r==="TransparentBackground")return!0;if(r==="PaintBackground")return!1;g()})(),halftoneShadows:!0,watermark:"",theme:n,outputAspect:t},u=Nu(o)(i);return{viewBox:vt(u.vx)+" "+vt(u.vy)+" "+vt(u.vw)+" "+vt(u.vh),body:(()=>{const s=[],a={value:0},c={value:0},f={value:0},d={value:J};return DT(o)(e)(i)({out:s,maskDepth:a,clipCounter:c,patternCounter:f,viewport:u,bake:d})(),vo("")(s)})(),vx:u.vx,vy:u.vy,vw:u.vw,vh:u.vh}},FT=t=>e=>n=>r=>i=>o=>{const u={padding:24,transparentBg:(()=>{if(n==="TransparentBackground")return!0;if(n==="PaintBackground")return!1;g()})(),outputAspect:t},s=Zs(i)((()=>{const a=[],c={value:0},f={value:0},d={value:0},l={value:J},_=r.levels.length-1|0;return _>=0&&_<r.levels.length?IT(r.levels[_].segment.layout)(r.levels[_].state)({out:a,maskDepth:c,clipCounter:f,patternCounter:d,viewport:Nu(u)(r),bake:l})():A})())(o);return{parts:AT(t)(s.applied)(e)(n)(r),springs:s.springs}},Ui=t=>({bind:e=>n=>r=>t.Bind1().bind(e(r))(i=>n(i._1)(i._2)),Apply0:()=>i1(t)}),i1=t=>{const e=t.Bind1().Apply0().Functor0(),n={map:r=>i=>o=>e.map(u=>b(r(u._1),u._2))(i(o))};return{apply:(()=>{const r=Ui(t);return i=>o=>r.bind(i)(u=>r.bind(o)(s=>Ki(t).pure(u(s))))})(),Functor0:()=>n}},Ki=t=>({pure:e=>n=>t.Applicative0().pure(b(e,n)),Apply0:()=>i1(t)}),BT=t=>{const e={Applicative0:()=>Ki(t),Bind1:()=>Ui(t)};return{state:n=>r=>t.Applicative0().pure(n(r)),Monad0:()=>e}},wa=(t,e)=>({tag:t,_1:e}),va=t=>t,Wn=(t,e)=>({tag:t,_1:e}),xe=BT(qn),Mt=Ui(qn),Ae=xe.state(t=>b(t,t)),ne=Ki(qn),On=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},o1=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Tu=Du(ne)(zt),Yn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},QT=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},RT=(()=>{const t=Ue.unfoldr(e=>{if(e.tag==="Nil")return J;if(e.tag==="Cons")return w("Just",b(e._1,e._2));g()});return e=>t((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._3,n(r._6,i)));g()};return n(e,Xt)})())})(),MT=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},wu=t=>e=>n=>T(r=>i=>t.Bind1().bind(r)(o=>e(o)(i)))(t.Applicative0().pure(n)),zT=T(t=>e=>tt(S)(e)()(t))(A),HT=(()=>{const t=(e=>n=>{let r=e,i=n,o=!0,u;for(;o;){const s=r,a=i;if(a.tag==="Nil"){o=!1,u=s;continue}if(a.tag==="Cons"){r=tt(S)(a._1)()(s),i=a._2;continue}g()}return u})(A);return e=>t((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,$t("Cons",r._3,n(r._6,i)));g()};return n(e,Xt)})())})(),WT=Wn("Exit"),OT=va("AnimatedKeyframe"),YT=va("Still"),$T=va("Title"),qT=t=>wa("Par",t),u1=t=>wa("Seq",t),XT=t=>e=>n=>{const r=gr(Ut,J,i=>i._1===t,n);if(r.tag==="Just"){const i=Xn(Ut,J,r._1,b(t,e),n);if(i.tag==="Nothing")return n;if(i.tag==="Just")return i._1;g()}if(r.tag==="Nothing")return Rt(n)(b(t,e));g()},VT=t=>e=>O(n=>n._1===t?b(n._1,{...n._2,label:w("Just",e)}):b(n._1,n._2)),Ne=t=>xe.state(e=>b(void 0,(()=>{if(e.error.tag==="Just")return e;if(e.error.tag==="Nothing")return{...e,error:w("Just",{msg:t,line:e.currentLine,column:e.currentColumn})};g()})())),UT=t=>Mt.bind(xe.state(e=>b(void 0,{...e,currentLine:t.line,currentColumn:t.column})))(()=>Mt.bind(Ae)(e=>{if(e.error.tag==="Just")return ne.pure();if(e.error.tag==="Nothing"){if(t.op.tag==="Enter"){if(!On(t.op._1.id)(e.currNodes))return Ne("cannot enter node "+t.op._1.id+": does not exist");if(!o1(t.op._1.id)(e.interiorOf))return Ne("cannot enter node "+t.op._1.id+": it has no `inside` block");if(Ye(dn)(t.op._1.id)(e.enterStack))return Ne("cannot enter node "+t.op._1.id+": already entered");const n=t.op._1;return xe.state(r=>b(void 0,{...r,enterStack:Rt(r.enterStack)(n.id),scenes:Rt(r.scenes)(mi("EnterNode",n.id))}))}if(t.op.tag==="Exit"){const n=fr(e.enterStack);if(n.tag==="Nothing")return Ne("`exit` without a matching `enter`");if(n.tag==="Just"){const r=n._1.init;return xe.state(i=>b(void 0,{...i,enterStack:r,scenes:Rt(i.scenes)(Ml)}))}g()}return ne.pure()}g()})),KT=t=>Mt.bind(Ae)(e=>{const n=t.tag==="Just"&&t._1!==""?t._1:"kf-"+ee(e.kfCounter);if(Oe(i=>i.id===n,e.keyframes))return Ne("duplicate frame name "+n);const r={...e,keyframes:Rt(e.keyframes)({id:n,nodes:e.currNodes,edges:e.currEdges,kind:yi}),kfCounter:e.kfCounter+1|0,currentKf:w("Just",n)};return xe.state(i=>b(void 0,r))}),ZT=Tu(t=>Mt.bind(Ae)(e=>{if(e.error.tag==="Just")return ne.pure();if(e.error.tag==="Nothing")return o1(t.node)(e.interiorOf)?Ne("node "+t.node+" has more than one `inside` block"):xe.state(n=>b(void 0,{...n,interiorOf:tt(S)(t.node)(t.doc)(n.interiorOf)}));g()})),jT=t=>e=>{const n=e.from+"->"+e.to,r=e.newFrom+"->"+e.newTo,i=Dt("Left","cannot repoint "+e.from+"\u2192"+e.to+": edge does not exist"),o=Yn(n)(t.currEdges)?Dt("Right",void 0):i;return(()=>{if(o.tag==="Left"){const u=o._1;return s=>Dt("Left",u)}if(o.tag==="Right"){const u=o._1;return s=>s(u)}g()})()(()=>{const u="cannot repoint "+e.from+"\u2192"+e.to+" to "+e.newFrom+"\u2192"+e.newTo+": unknown node "+e.newFrom;if(!On(e.newFrom)(t.currNodes))return Dt("Left",u);const s="cannot repoint "+e.from+"\u2192"+e.to+" to "+e.newFrom+"\u2192"+e.newTo+": unknown node "+e.newTo;if(!On(e.newTo)(t.currNodes))return Dt("Left",s);const a="cannot repoint "+e.from+"\u2192"+e.to+" to "+e.newFrom+"\u2192"+e.newTo+": target edge already exists";return n!==r&&Yn(r)(t.currEdges)?Dt("Left",a):Dt("Right",{nextCurrEdges:tt(S)(r)()(si(S)(n)(t.currEdges)),newId:r,newEdge:{id:r,from:{node:e.newFrom,port:J},to:{node:e.newTo,port:J},label:J}})})},s1={graphNodes:[],graphEdges:A,currNodes:A,currEdges:A,keyframes:[],scenes:[],kfCounter:0,eventCounter:0,currentKf:J,currentLine:0,currentColumn:0,error:J,enterStack:[],interiorOf:A},tw=Mt.bind(Ae)(t=>{if(t.error.tag==="Just")return ne.pure();if(t.error.tag==="Nothing"){if(t.currentKf.tag==="Just"){const e=t.currentKf._1;return xe.state(n=>b(void 0,{...n,scenes:Rt(n.scenes)(mi("Hold",e))}))}if(t.currentKf.tag==="Nothing")return ne.pure()}g()}),a1=t=>e=>Mt.bind(Ae)(n=>{const r="ev-"+ee(n.eventCounter);return Mt.bind((()=>{const i={...n,eventCounter:n.eventCounter+1|0};return xe.state(o=>b(void 0,i))})())(()=>ne.pure({events:[{id:r,kind:e,when:t}],firstId:w("Just",r),lastId:w("Just",r)}))}),ew=t=>e=>{if(e.tag==="Token"){const n=e._1;return Mt.bind(Ae)(r=>{const i=!On(n.from)(r.currNodes),o=!On(n.to)(r.currNodes);if(i||o)return Mt.bind(Ne(i?o?"token references unknown node: "+n.from+", "+n.to:"token references unknown node: "+n.from:o?"token references unknown node: "+n.to:"token references unknown node: "))(()=>ne.pure({events:[],firstId:J,lastId:J}));const u=n.to+"->"+n.from,s=n.from+"->"+n.to;return Yn(s)(r.currEdges)?a1(t)(bc("SendToken",{from:n.from,to:n.to,edge:s,direction:Ql,labels:n.labels})):Yn(u)(r.currEdges)?a1(t)(bc("SendToken",{from:n.from,to:n.to,edge:u,direction:Rl,labels:n.labels})):Mt.bind(Ne("token "+n.from+"\u2192"+n.to+": no edge between "+n.from+" and "+n.to))(()=>ne.pure({events:[],firstId:J,lastId:J}))})}return ne.pure({events:[],firstId:J,lastId:J})},nw=t=>e=>{if(0<t.length){const n=t[0];return Mt.bind(xe.state(r=>b(void 0,{...r,currentLine:n.line,currentColumn:n.column})))(()=>Ne(e))}return Ne(e)},rw=t=>xt(e=>QT(e)(t.graphEdges))(Ct(ii,RT(t.currEdges))),iw=t=>e=>{const n=at(i=>i.from.node===e.id||i.to.node===e.id,rw(t)),r=wu(Oa)(i=>o=>{const u=o.from+"->"+e.id,s=e.id+"->"+o.to,a=o.from+"->"+o.to,c="via "+o.from+" "+o.to+": no edge "+o.from+"\u2192"+e.id;if(!Yn(u)(t.currEdges))return Dt("Left",c);const f="via "+o.from+" "+o.to+": no edge "+e.id+"\u2192"+o.to;if(!Yn(s)(t.currEdges))return Dt("Left",f);const d="via "+o.from+" "+o.to+": would create "+o.from+"\u2192"+o.to+" but it already exists";return Yn(a)(t.currEdges)||MT(a)(i.synthesized)?Dt("Left",d):Dt("Right",{consumed:tt(S)(u)()(tt(S)(s)()(i.consumed)),synthesized:tt(S)(a)({id:a,from:{node:o.from,port:J},to:{node:o.to,port:J},label:J})(i.synthesized)})})({consumed:A,synthesized:A})(e.via);return(()=>{if(r.tag==="Left"){const i=r._1;return o=>Dt("Left",i)}if(r.tag==="Right"){const i=r._1;return o=>o(i)}g()})()(i=>{const o=i.consumed,u=at(s=>!Yn(s.id)(o),n);return u.length===0?Dt("Right",{nextCurrEdges:Se(S.compare,Ee,In(S.compare,t.currEdges,zT(O(s=>s.id)(n))),HT((()=>{const s=a=>{if(a.tag==="Leaf")return A;if(a.tag==="Node")return Yt("Node",a._1,a._2,a._3,void 0,s(a._5),s(a._6));g()};return s(i.synthesized)})())),synthesized:i.synthesized}):Dt("Left","cannot delete node "+e.id+": still connected ("+vo(", ")(O(s=>s.from.node+"\u2192"+s.to.node)(u))+"). Use -edge to drop them or `via a b` to merge "+e.id+"'s endpoints.")})},ba=t=>{if(t.tag==="Leaf")return[t._1];if(t.tag==="Par"||t.tag==="Seq")return wt(t._1)(ba);g()},ow=Mt.bind(Ae)(t=>{if(t.error.tag==="Just")return ne.pure();if(t.error.tag==="Nothing"){const e=t.enterStack.length-1|0;return e>=0&&e<t.enterStack.length?Ne("entered node "+t.enterStack[e]+" was never exited"):ne.pure()}g()}),uw=t=>({nodes:O(no)(t.graphNodes),edges:(()=>{const e=(n,r)=>{if(n.tag==="Leaf")return r;if(n.tag==="Node")return e(n._5,$t("Cons",n._4,e(n._6,r)));g()};return Ct(Vt.foldr,e(t.graphEdges,Xt))})(),constraints:[]}),sw=t=>{if(t.tag==="AddNode"){const e=t._1;return xe.state(n=>b(void 0,{...n,graphNodes:XT(e.id)({id:e.id,size:b(1,1),ports:[],label:w("Just",e.label),shape:e.shape})(n.graphNodes),currNodes:tt(S)(e.id)()(n.currNodes)}))}if(t.tag==="DelNode"){const e=t._1;return Mt.bind(Ae)(n=>{if(!On(e.id)(n.currNodes))return Ne("cannot delete node "+e.id+": does not exist");const r=iw(n)(e);if(r.tag==="Left")return Ne(r._1);if(r.tag==="Right"){const i=r._1;return xe.state(o=>b(void 0,{...o,currNodes:si(S)(e.id)(o.currNodes),currEdges:i.nextCurrEdges,graphEdges:Se(S.compare,Ee,i.synthesized,o.graphEdges)}))}g()})}if(t.tag==="ModNode"){const e=t._1;return Mt.bind(Ae)(n=>{if(!On(e.id)(n.currNodes))return Ne("cannot modify node "+e.id+": does not exist");if(e.label.tag==="Just"){const r=e.label._1;return xe.state(i=>b(void 0,{...i,graphNodes:VT(e.id)(r)(i.graphNodes)}))}if(e.label.tag==="Nothing")return ne.pure();g()})}if(t.tag==="AddEdge"){const e=t._1;return Mt.bind(Ae)(n=>{const r=!On(e.from)(n.currNodes),i=!On(e.to)(n.currNodes);if(r||i)return Ne("cannot add edge "+e.from+"\u2192"+e.to+": unknown node "+(r?i?e.from+", "+e.to:e.from:i?e.to:""));const o=e.from+"->"+e.to;return xe.state(u=>b(void 0,{...u,graphEdges:tt(S)(o)({id:o,from:{node:e.from,port:J},to:{node:e.to,port:J},label:e.label})(u.graphEdges),currEdges:tt(S)(o)()(u.currEdges)}))})}if(t.tag==="DelEdge"){const e=t._1;return Mt.bind(Ae)(n=>{const r=e.from+"->"+e.to;return Yn(r)(n.currEdges)?xe.state(i=>b(void 0,{...i,currEdges:si(S)(r)(i.currEdges)})):Ne("cannot delete edge "+e.from+"\u2192"+e.to+": does not exist")})}if(t.tag==="RepointEdge"){const e=t._1;return Mt.bind(Ae)(n=>{const r=jT(n)(e);if(r.tag==="Left")return Ne(r._1);if(r.tag==="Right"){const i=r._1;return xe.state(o=>b(void 0,{...o,currEdges:i.nextCurrEdges,graphEdges:tt(S)(i.newId)(i.newEdge)(o.graphEdges)}))}g()})}return ne.pure()},aw=t=>Mt.bind(xe.state(e=>b(void 0,{...e,currentLine:t.line,currentColumn:t.column})))(()=>sw(t.op)),c1=t=>e=>n=>Mt.bind(Tu(aw)(n))(()=>Mt.bind(Ae)(r=>{const i=e.tag==="Just"&&e._1!==""?e._1:"kf-"+ee(r.kfCounter);if(Oe(u=>u.id===i,r.keyframes))return Ne("duplicate frame name "+i);const o={...r,keyframes:Rt(r.keyframes)({id:i,nodes:r.currNodes,edges:r.currEdges,kind:t}),kfCounter:r.kfCounter+1|0,currentKf:w("Just",i),scenes:(()=>{if(r.currentKf.tag==="Nothing")return r.scenes;if(r.currentKf.tag==="Just")return Rt(r.scenes)(mi("Structural",{from:r.currentKf._1,to:i,focus:J}));g()})()};return xe.state(u=>b(void 0,o))})),g1=t=>e=>{const n=ba(e.ops),r=at(o=>o.op.tag==="AddNode"||o.op.tag==="DelNode"||o.op.tag==="ModNode"||o.op.tag==="AddEdge"||o.op.tag==="DelEdge"||o.op.tag==="RepointEdge",n),i=at(o=>!(o.op.tag==="AddNode"||o.op.tag==="DelNode"||o.op.tag==="ModNode"||o.op.tag==="AddEdge"||o.op.tag==="DelEdge"||o.op.tag==="RepointEdge"),n);if(0<i.length){const o=i[0];return Mt.bind(xe.state(u=>b(void 0,{...u,currentLine:o.line,currentColumn:o.column})))(()=>Ne("still/title blocks hold a static snapshot; they cannot contain tokens (a -> b) or enter/exit"))}return t==="TitleCard"&&r.length===0?Ne(e.name.tag==="Just"&&e.name._1!==""?'title "'+e.name._1+'" has an empty body; give it nodes/edges to title, or use a still':"title has an empty body; give it nodes/edges to title, or use a still"):Mt.bind(c1(t)(e.name)(r))(()=>tw)},cw=t=>e=>{const n=Qt(r=>J,r=>i=>w("Just",{head:r,tail:i}),e);if(n.tag==="Nothing")return ne.pure({events:[],firstId:J,lastId:J});if(n.tag==="Just"){const r=n._1.tail;return Mt.bind(Zi(t)(n._1.head))(i=>Mt.bind(wu({Applicative0:()=>Ki(qn),Bind1:()=>Ui(qn)})(o=>u=>Mt.bind(Zi((()=>{if(o.lastId.tag==="Just")return os("After",o.lastId._1);if(o.lastId.tag==="Nothing")return t;g()})())(u))(s=>ne.pure({events:[...o.events,...s.events],firstId:(()=>{if(o.firstId.tag==="Just")return w("Just",o.firstId._1);if(o.firstId.tag==="Nothing")return s.firstId;g()})(),lastId:(()=>{if(s.lastId.tag==="Just")return w("Just",s.lastId._1);if(s.lastId.tag==="Nothing")return o.lastId;g()})()})))(i)(r))(o=>ne.pure(o)))}g()},gw=t=>e=>{const n=Qt(r=>J,r=>i=>w("Just",{head:r,tail:i}),e);if(n.tag==="Nothing")return ne.pure({events:[],firstId:J,lastId:J});if(n.tag==="Just"){const r=n._1.tail;return Mt.bind(Zi(t)(n._1.head))(i=>Mt.bind(fw((()=>{if(i.firstId.tag==="Just")return os("With",i.firstId._1);if(i.firstId.tag==="Nothing")return t;g()})())(r))(o=>ne.pure({events:[...i.events,...o.events],firstId:i.firstId,lastId:(()=>{if(i.lastId.tag==="Just")return w("Just",i.lastId._1);if(i.lastId.tag==="Nothing")return o.lastId;g()})()})))}g()},Zi=t=>e=>{if(e.tag==="Leaf"){const n=e._1;return Mt.bind(xe.state(r=>b(void 0,{...r,currentLine:n.line,currentColumn:n.column})))(()=>ew(t)(n.op))}if(e.tag==="Seq")return cw(t)(e._1);if(e.tag==="Par")return gw(t)(e._1);g()},fw=t=>wu({Applicative0:()=>Ki(qn),Bind1:()=>Ui(qn)})(e=>n=>Mt.bind(Zi(t)(n))(r=>ne.pure({events:[...e.events,...r.events],firstId:(()=>{if(e.firstId.tag==="Just")return w("Just",e.firstId._1);if(e.firstId.tag==="Nothing")return r.firstId;g()})(),lastId:(()=>{if(r.lastId.tag==="Just")return w("Just",r.lastId._1);if(r.lastId.tag==="Nothing")return e.lastId;g()})()})))({events:[],firstId:J,lastId:J}),_w=t=>Mt.bind(Ae)(e=>{if(e.currentKf.tag==="Nothing")return Ne("flow ops before any structural frame");if(e.currentKf.tag==="Just"){const n=e.currentKf._1;return Mt.bind(Zi(Bl)(t))(r=>Mt.bind(Ae)(i=>{const o={...i,scenes:Rt(i.scenes)(mi("DataFlow",{keyframe:n,events:r.events,focus:J}))};return xe.state(u=>b(void 0,o))}))}g()}),dw=t=>{const e=ba(t.ops),n=at(o=>o.op.tag==="AddNode"||o.op.tag==="DelNode"||o.op.tag==="ModNode"||o.op.tag==="AddEdge"||o.op.tag==="DelEdge"||o.op.tag==="RepointEdge",e),r=at(o=>o.op.tag==="Enter"||o.op.tag==="Exit",e),i=at(o=>!(o.op.tag==="AddNode"||o.op.tag==="DelNode"||o.op.tag==="ModNode"||o.op.tag==="AddEdge"||o.op.tag==="DelEdge"||o.op.tag==="RepointEdge")&&!(o.op.tag==="Enter"||o.op.tag==="Exit"),e);return r.length!==0&&i.length!==0?nw(r)("`enter`/`exit` cannot be mixed with flow tokens in the same frame"):Mt.bind((()=>{const o=c1(yi)(t.name)(n);return n.length!==0?o:ne.pure()})())(()=>Mt.bind((()=>{const o=KT(t.name);return n.length===0&&i.length!==0?o:ne.pure()})())(()=>Mt.bind((()=>{const o=_w(t.ops);return i.length!==0?o:ne.pure()})())(()=>Tu(UT)(r))))},lw=t=>Mt.bind(Ae)(e=>{if(e.error.tag==="Just")return ne.pure();if(e.error.tag==="Nothing"){if(t.kind==="AnimatedKeyframe")return dw(t);if(t.kind==="Still")return g1(Al)(t);if(t.kind==="Title")return g1(Fl)(t)}g()}),f1=t=>Mt.bind(ZT(t.interiors))(()=>Mt.bind(Tu(lw)(t.frames))(()=>Mt.bind(ow)(()=>Mt.bind(Ae)(e=>{if(e.error.tag==="Just")return ne.pure(Dt("Left",e.error._1));if(e.error.tag==="Nothing"){const n=hw(t.interiors);if(n.tag==="Left")return ne.pure(Dt("Left",n._1));if(n.tag==="Right")return ne.pure(Dt("Right",{seed:t.seed,graph:uw(e),keyframes:e.keyframes,scenes:e.scenes,interiors:n._1}))}g()})))),hw=t=>{const e=wu(Oa)(n=>r=>{const i=f1(r.doc)(s1)._1;return(()=>{if(i.tag==="Left"){const o=i._1;return u=>Dt("Left",o)}if(i.tag==="Right"){const o=i._1;return u=>u(o)}g()})()(o=>Dt("Right",tt(S)(r.node)(o)(n)))})(A)(t);if(e.tag==="Left")return Dt("Left",e._1);if(e.tag==="Right")return Dt("Right",e._1);g()},ti=(t,e)=>({tag:"ParseError",_1:t,_2:e}),Q=(t,e,n)=>({tag:"ParseState",_1:t,_2:e,_3:n}),vu=(t,e,n)=>({tag:t,_1:e,_2:n}),pw=t=>vu("More",t),mw=t=>vu("Lift",t),yw={defer:t=>{const e=dl(t);return(n,r,i,o,u)=>ll(e)(n,r,i,o,u)}},_1={map:t=>e=>(n,r,i,o,u)=>r(s=>e(n,r,i,o,(a,c)=>r(f=>u(a,t(c)))))},xw={alt:t=>e=>(n,r,i,o,u)=>{const s=n._1,a=n._2;return r(c=>t(Q(s,a,!1),r,i,(f,d)=>{const l=f._3;return r(_=>l?o(f,d):e(n,r,i,o,u))},u))},Functor0:()=>_1},Nw=t=>{const e=t.Monad0();return n=>r=>{const i=o=>{let u=o,s=!0,a;for(;s;){const c=u();if(c.tag==="More"){u=c._1;continue}if(c.tag==="Lift"){s=!1,a=e.Bind1().Apply0().Functor0().map($a)(c._1);continue}if(c.tag==="Stop"){s=!1,a=e.Applicative0().pure(ri("Done",b(c._2,c._1)));continue}g()}return a};return t.tailRecM(i)(o=>r(n,pw,mw,(u,s)=>vu("Stop",u,Dt("Left",s)),(u,s)=>vu("Stop",u,Dt("Right",s))))}},d1=(t,e,n,r,i)=>i(t,t._2),Jw={index:0,line:1,column:1},Tw=(t=>{const e=Nw(t);return n=>r=>t.Monad0().Bind1().Apply0().Functor0().map(ro)(e(Q(n,Jw,!1))(r))})(H1),l1={apply:t=>e=>(n,r,i,o,u)=>r(s=>t(n,r,i,o,(a,c)=>r(f=>{const d=n._3&&!a._3?Q(a._1,a._2,!0):a;return e(d,r,i,o,(l,_)=>r(h=>u(d._3&&!l._3?Q(l._1,l._2,!0):l,c(_))))}))),Functor0:()=>_1},h1={pure:t=>(e,n,r,i,o)=>o(e,t),Apply0:()=>l1},ww={bind:t=>e=>(n,r,i,o,u)=>r(s=>t(n,r,i,o,(a,c)=>r(f=>e(c)(n._3&&!a._3?Q(a._1,a._2,!0):a,r,i,o,u)))),Apply0:()=>l1},vw={Applicative0:()=>h1,Bind1:()=>ww},bu=t=>(e,n,r,i,o)=>n(u=>d1(e,n,r,i,(s,a)=>n(c=>i(e._3&&!s._3?Q(s._1,s._2,!0):s,ti(t,a))))),bw={empty:bu("No alternative"),Alt0:()=>xw},kw={Applicative0:()=>h1,Plus1:()=>bw},sn=(t=>e=>{const n=e.Plus1().Alt0(),r=e.Applicative0();return i=>t.tailRecM(o=>t.Monad0().Bind1().bind(n.alt(n.Functor0().map($a)(i))(r.pure(ri("Done",void 0))))(u=>r.pure((()=>{if(u.tag==="Loop")return ri("Loop",$t("Cons",u._1,o));if(u.tag==="Done")return ri("Done",(s=>a=>{let c=s,f=a,d=!0,l;for(;d;){const _=c,h=f;if(h.tag==="Nil"){d=!1,l=_;continue}if(h.tag==="Cons"){c=$t("Cons",h._1,_),f=h._2;continue}g()}return l})(Xt)(o));g()})())))(Xt)})({tailRecM:t=>e=>(n,r,i,o,u)=>{const s=(a,c,f)=>t(c)(a,r,i,o,(d,l)=>{const _=a._3&&!d._3?Q(d._1,d._2,!0):d;if(l.tag==="Loop")return f===0?r(h=>s(_,l._1,30)):s(_,l._1,f-1|0);if(l.tag==="Done")return u(_,l._1);g()});return s(n,e,30)},Monad0:()=>vw})(kw),Gt=t=>e=>{const n=bu("Expected "+e);return(r,i,o,u,s)=>{const a=r._1,c=r._2;return i(f=>t(Q(a,c,!1),i,o,(d,l)=>{const _=d._3;return i(h=>_?u(d,l):n(r,i,o,u,s))},s))}},ka=t=>(e,n,r,i,o)=>{const u=e._3,s=e._1,a=e._2;return n(c=>{const f=(d,l)=>{const _=d._3;return n(h=>_?i(Q(d._1,d._2,u),l):o(e,void 0))};return n(d=>n(l=>t(Q(s,a,!1),n,r,(_,h)=>f(Q(_._1,_._2,!1),h),(_,h)=>n(p=>n(m=>bu("Negated parser succeeded")(_,n,r,f,(y,x)=>n(N=>o(_._3&&!y._3?Q(y._1,y._2,!0):y,x))))))))})},Lw=t=>{const e=t.foldr(n=>r=>{if(r.tag==="Nothing")return w("Just",n);if(r.tag==="Just")return w("Just",(i,o,u,s,a)=>{const c=i._1,f=i._2;return o(d=>n(Q(c,f,!1),o,u,(l,_)=>{const h=l._3;return o(p=>h?s(l,_):r._1(i,o,u,s,a))},a))});g()})(J);return n=>{const r=e(n);if(r.tag==="Nothing")return bu("No alternative");if(r.tag==="Just")return r._1;g()}},Ew=t=>e=>n=>(r,i,o,u,s)=>i(a=>i(c=>i(f=>i(d=>t(r,i,o,u,(l,_)=>i(h=>i(p=>{const m=r._3&&!l._3?Q(l._1,l._2,!0):l;return n(m,i,o,u,(y,x)=>i(N=>{const v=m._3&&!y._3?Q(y._1,y._2,!0):y;return i(k=>i(L=>{const E=r._3&&!v._3?Q(v._1,v._2,!0):v;return e(E,i,o,u,(B,q)=>i(j=>s(E._3&&!B._3?Q(B._1,B._2,!0):B,x)))}))}))}))))))),La=t=>e=>n=>{if(e===10)return{index:t.index+1|0,line:t.line+1|0,column:1};if(e===13){const r=Eh()(n);return r.tag==="Just"&&r._1===10?{index:t.index+1|0,line:t.line,column:t.column}:{index:t.index+1|0,line:t.line+1|0,column:1}}return e===9?{index:t.index+1|0,line:t.line,column:(t.column+8|0)-Un(t.column-1|0)(8)|0}:{index:t.index+1|0,line:t.line,column:t.column+1|0}},Cw=t=>e=>n=>{let r=t,i=e,o=n,u=!0,s;for(;u;){const a=r,c=i,f=o,d=bo(c);if(d.tag==="Nothing"){u=!1,s=a;continue}if(d.tag==="Just"){r=d._1.tail===""?La(a)(d._1.head)(f):La(a)(d._1.head)(d._1.tail),i=d._1.tail,o=f;continue}g()}return s},jt=t=>(e,n,r,i,o)=>{const u=bo(e._1);if(u.tag==="Nothing")return i(e,ti("Unexpected EOF",e._2));if(u.tag==="Just"){if(u._1.head<0||u._1.head>65535)return i(e,ti("Expected Char",e._2));if(u._1.head>=0&&u._1.head<=65535){const s=Fc(u._1.head);return t(s)?o(Q(u._1.tail,La(e._2)(u._1.head)(u._1.tail),!0),s):i(e,ti("Predicate unsatisfied",e._2))}}g()},Ea=(t,e,n,r,i)=>t._1===""?i(Q(t._1,t._2,!0),void 0):r(t,ti("Expected EOF",t._2)),Sw=t=>(e,n,r,i,o)=>{const u=t(e._1);if(u.tag==="Left")return i(e,ti(u._1,e._2));if(u.tag==="Right")return o(Q(u._1.remainder,Cw(e._2)(u._1.consumed)(u._1.remainder),u._1.consumed!==""),u._1.value);g()},ei=t=>Sw(e=>{const n=_l(t)(e);return n.tag==="Just"?Dt("Right",{value:t,consumed:t,remainder:n._1}):Dt("Left","Expected "+S1(t))}),Gw=jt(t=>!0),p1=(t,e)=>({tag:t,_1:e}),Pw=te(S)(zt),Dw=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=S.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=w("Just",o._4);continue}}g()}return i},m1=Lw(zt),y1=(()=>{const t=jt(e=>e===" "||e===" "||e===`
9
- `||e==="\r");return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>o(e._3&&!s._3?Q(s._1,s._2,!0):s,void 0))))})(),Ca=(t,e,n,r,i)=>e(o=>ei("#")(t,e,n,r,(u,s)=>e(a=>{const c=sn(jt(d=>d!==`
10
- `)),f=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>i(f._3&&!l._3?Q(l._1,l._2,!0):l,void 0))))}))),Iw=Gt((()=>{const t=Gt(jt(n=>n==="}"))("'}'"),e=jt(n=>n===`
11
- `||n==="\r");return(n,r,i,o,u)=>{const s=n._1,a=n._2;return r(c=>r(f=>t(Q(s,a,!1),r,i,(d,l)=>r(_=>{const h=n._1,p=n._2;return r(m=>r(y=>Ca(Q(h,p,!1),r,i,(x,N)=>{const v=x._3;return r(k=>{if(v)return o(x,N);const L=n._1,E=n._2;return r(B=>r(q=>e(Q(L,E,!1),r,i,(j,G)=>{const P=j._3;return r(V=>P?o(j,G):Ea(n,r,i,o,u))},(j,G)=>r(P=>u(j,void 0)))))})},(x,N)=>r(v=>u(x,void 0)))))}),(d,l)=>r(_=>u(Q(s,a,!1),void 0)))))}})())("newline or '}' (statements end at the end of the line)"),en=(()=>{const t=sn((e,n,r,i,o)=>{const u=e._1,s=e._2;return n(a=>y1(Q(u,s,!1),n,r,(c,f)=>{const d=c._3;return n(l=>d?i(c,f):Ca(e,n,r,i,o))},o))});return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>o(e._3&&!s._3?Q(s._1,s._2,!0):s,void 0))))})(),fn=(t,e,n,r,i)=>e(o=>{const u=(c,f)=>e(d=>en(t._3&&!c._3?Q(c._1,c._2,!0):c,e,n,r,i)),s=t._1,a=t._2;return e(c=>y1(Q(s,a,!1),e,n,(f,d)=>{const l=f._3;return e(_=>l?r(f,d):Ca(t,e,n,r,u))},u))}),x1=(()=>{const t=Gt(jt(e=>e==="|"))("'|'");return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>{const f=sn(jt(l=>l!=="|")),d=e._3&&!s._3?Q(s._1,s._2,!0):s;return n(l=>f(d,n,r,i,(_,h)=>n(p=>{const m=Gt(Gt(jt(x=>x==="|"))("'|'"))("closing '|'"),y=d._3&&!_._3?Q(_._1,_._2,!0):_;return n(x=>m(y,n,r,i,(N,v)=>n(k=>o(y._3&&!N._3?Q(N._1,N._2,!0):N,lr(Ct(Vt.foldr,h))))))})))})))})(),ku=jt(t=>t>="a"&&t<="z"||t>="A"&&t<="Z"),He=(()=>{const t=sn(jt(e=>e===" "||e===" "));return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>o(e._3&&!s._3?Q(s._1,s._2,!0):s,void 0))))})(),Aw=(()=>{const t=Gt(jt(e=>e==="\\"))("'\\\\'");return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>{const f=e._3&&!s._3?Q(s._1,s._2,!0):s;return n(d=>Gw(f,n,r,i,(l,_)=>n(h=>o(f._3&&!l._3?Q(l._1,l._2,!0):l,_==="n"?`
12
- `:_==="t"?" ":_==="r"?"\r":_))))})))})(),Fw=(()=>{const t=jt(e=>e!=='"'&&e!=="\\"&&e!==`
13
- `);return(e,n,r,i,o)=>{const u=e._1,s=e._2;return n(a=>Aw(Q(u,s,!1),n,r,(c,f)=>n(d=>t(e,n,r,i,o)),o))}})(),Sa=(()=>{const t=Gt(jt(e=>e==='"'))(`'"'`);return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>{const f=sn(Fw),d=e._3&&!s._3?Q(s._1,s._2,!0):s;return n(l=>f(d,n,r,i,(_,h)=>n(p=>{const m=Gt(Gt(jt(x=>x==='"'))(`'"'`))(`closing '"' (unterminated string)`),y=d._3&&!_._3?Q(_._1,_._2,!0):_;return n(x=>m(y,n,r,i,(N,v)=>n(k=>o(y._3&&!N._3?Q(N._1,N._2,!0):N,lr(Ct(Vt.foldr,h))))))})))})))})(),Bw=(()=>{const t=Gt(jt(e=>e===":"))("':'");return(e,n,r,i,o)=>n(u=>He(e,n,r,i,(s,a)=>n(c=>Gt((f,d,l,_,h)=>{const p=f._1,m=f._2;return d(y=>{const x=(N,v)=>{const k=N._3;return d(L=>{if(k)return _(N,v);const E=f._1,B=f._2;return d(q=>x1(Q(E,B,!1),d,l,(j,G)=>{const P=j._3;return d(V=>P?_(j,G):Sa(f,d,l,_,h))},h))})};return d(N=>t(Q(p,m,!1),d,l,x,(v,k)=>d(L=>d(E=>He(v,d,l,x,(B,q)=>d(j=>{const G=sn(jt(V=>V!==`
14
- `&&V!=="\r"&&V!=="#"&&V!=="}")),P=v._3&&!B._3?Q(B._1,B._2,!0):B;return d(V=>G(P,d,l,x,(U,M)=>d(H=>h(P._3&&!U._3?Q(U._1,U._2,!0):U,ph(lr(Ct(Vt.foldr,M)))))))}))))))})})('label ("\u2026", : rest-of-line, or |\u2026|)')(e._3&&!s._3?Q(s._1,s._2,!0):s,n,r,i,o))))})(),N1=(t,e,n,r,i)=>{const o=t._1,u=t._2;return e(s=>x1(Q(o,u,!1),e,n,(a,c)=>{const f=a._3;return e(d=>f?r(a,c):Sa(t,e,n,r,i))},i))},ji=jt(t=>t>="0"&&t<="9"),Le=(()=>{const t=Gt(jt(e=>e==="_"))("'_'");return(e,n,r,i,o)=>n(u=>{const s=(f,d)=>n(l=>{const _=sn((()=>{const p=Gt(jt(y=>y==="_"))("'_'"),m=Gt(jt(y=>y==="-"))("'-'");return(y,x,N,v,k)=>{const L=y._1,E=y._2;return x(B=>ku(Q(L,E,!1),x,N,(q,j)=>{const G=q._3;return x(P=>{if(G)return v(q,j);const V=y._1,U=y._2;return x(M=>ji(Q(V,U,!1),x,N,(H,R)=>{const C=H._3;return x(D=>{if(C)return v(H,R);const F=y._1,I=y._2;return x(z=>p(Q(F,I,!1),x,N,($,X)=>{const Y=$._3;return x(W=>Y?v($,X):m(y,x,N,v,k))},k))})},k))})},k))}})()),h=e._3&&!f._3?Q(f._1,f._2,!0):f;return n(p=>_(h,n,r,i,(m,y)=>n(x=>o(h._3&&!m._3?Q(m._1,m._2,!0):m,_o(d)+lr(Ct(Vt.foldr,y))))))}),a=e._1,c=e._2;return n(f=>ku(Q(a,c,!1),n,r,(d,l)=>{const _=d._3;return n(h=>_?i(d,l):t(e,n,r,i,s))},s))})})(),Qw=Gt((t,e,n,r,i)=>{const o=t._1,u=t._2;return e(s=>Sa(Q(o,u,!1),e,n,(a,c)=>{const f=a._3;return e(d=>f?r(a,c):Le(t,e,n,r,i))},i))})("frame name (identifier or quoted string)"),J1=(t,e,n,r,i)=>e(o=>He(t,e,n,r,(u,s)=>e(a=>{const c=Gt(Le)("attribute key"),f=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>{const p=f._3&&!l._3?Q(l._1,l._2,!0):l;return e(m=>He(p,e,n,r,(y,x)=>e(N=>{const v=Gt(Gt(jt(L=>L===":"))("':'"))("':'"),k=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(L=>v(k,e,n,r,(E,B)=>e(q=>{const j=k._3&&!E._3?Q(E._1,E._2,!0):E;return e(G=>He(j,e,n,r,(P,V)=>e(U=>{const M=Gt(Le)("attribute value"),H=j._3&&!P._3?Q(P._1,P._2,!0):P;return e(R=>M(H,e,n,r,(C,D)=>e(F=>{const I=H._3&&!C._3?Q(C._1,C._2,!0):C;return e(z=>He(I,e,n,r,($,X)=>e(Y=>i(I._3&&!$._3?Q($._1,$._2,!0):$,b(_,D)))))})))})))})))})))})))}))),Rw=(t,e,n,r,i)=>e(o=>Le(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>He(c,e,n,r,(d,l)=>e(_=>{const h=Gt((m,y,x,N,v)=>{const k=m._1,L=m._2;return y(E=>ei("->")(Q(k,L,!1),y,x,(B,q)=>{const j=B._3;return y(G=>j?N(B,q):ei("<-")(m,y,x,N,v))},v))})("'->' or '<-'"),p=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(k=>He(v,e,n,r,(L,E)=>e(B=>{const q=Gt(Le)("target node identifier"),j=v._3&&!L._3?Q(L._1,L._2,!0):L;return e(G=>q(j,e,n,r,(P,V)=>e(U=>{const M=sn((R,C,D,F,I)=>{const z=R._3;return C($=>C(X=>He(R,C,D,(Y,W)=>F(Q(Y._1,Y._2,z),W),(Y,W)=>C(K=>C(Z=>{const ct=R._3&&!Y._3?Q(Y._1,Y._2,!0):Y;return N1(ct,C,D,(_t,gt)=>F(Q(_t._1,_t._2,z),gt),(_t,gt)=>C(yt=>I(ct._3&&!_t._3?Q(_t._1,_t._2,!0):_t,gt)))})))))}),H=j._3&&!P._3?Q(P._1,P._2,!0):P;return e(R=>M(H,e,n,r,(C,D)=>e(F=>(()=>{if(x==="<-"){const z=Wn("Token",{from:V,to:s,labels:O(Nc)(Ct(Vt.foldr,D))});return($,X,Y,W,K)=>K($,z)}const I=Wn("Token",{from:s,to:V,labels:O(Nc)(Ct(Vt.foldr,D))});return(z,$,X,Y,W)=>W(z,I)})()(H._3&&!C._3?Q(C._1,C._2,!0):C,e,n,r,i))))})))})))})))})))}))),Mw=(t,e,n,r,i)=>e(o=>ji(t,e,n,r,(u,s)=>e(a=>{const c=sn(ji),f=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>{const p=yd(_o(s)+lr(Ct(Vt.foldr,_)));return(()=>{if(p.tag==="Just"){const m=p._1;return(y,x,N,v,k)=>k(y,m)}if(p.tag==="Nothing")return(m,y,x,N,v)=>v(m,0);g()})()(f._3&&!l._3?Q(l._1,l._2,!0):l,e,n,r,i)})))}))),to=t=>(e,n,r,i,o)=>{const u=e._3;return n(s=>ei(t)(e,n,r,(a,c)=>i(Q(a._1,a._2,u),c),(a,c)=>n(f=>{const d=ka((()=>{const _=Gt(jt(p=>p==="_"))("'_'"),h=Gt(jt(p=>p==="-"))("'-'");return(p,m,y,x,N)=>{const v=p._1,k=p._2;return m(L=>ku(Q(v,k,!1),m,y,(E,B)=>{const q=E._3;return m(j=>{if(q)return x(E,B);const G=p._1,P=p._2;return m(V=>ji(Q(G,P,!1),m,y,(U,M)=>{const H=U._3;return m(R=>{if(H)return x(U,M);const C=p._1,D=p._2;return m(F=>_(Q(C,D,!1),m,y,(I,z)=>{const $=I._3;return m(X=>$?x(I,z):h(p,m,y,x,N))},N))})},N))})},N))}})()),l=e._3&&!a._3?Q(a._1,a._2,!0):a;return n(_=>d(l,n,r,(h,p)=>i(Q(h._1,h._2,u),p),(h,p)=>n(m=>{const y=l._3&&!h._3?Q(h._1,h._2,!0):h;return n(x=>en(y,n,r,(N,v)=>i(Q(N._1,N._2,u),v),(N,v)=>n(k=>o(y._3&&!N._3?Q(N._1,N._2,!0):N,t))))})))})))},zw=(t,e,n,r,i)=>e(o=>fn(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>to("via")(c,e,n,r,(d,l)=>e(_=>{const h=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(p=>Le(h,e,n,r,(m,y)=>e(x=>{const N=h._3&&!m._3?Q(m._1,m._2,!0):m;return e(v=>fn(N,e,n,r,(k,L)=>e(E=>{const B=N._3&&!k._3?Q(k._1,k._2,!0):k;return e(q=>Le(B,e,n,r,(j,G)=>e(P=>i(B._3&&!j._3?Q(j._1,j._2,!0):j,{from:y,to:G}))))})))})))})))}))),ar=t=>(e,n,r,i,o)=>{const u=e._3;return n(s=>ei(t)(e,n,r,(a,c)=>i(Q(a._1,a._2,u),c),(a,c)=>n(f=>{const d=ka((()=>{const _=Gt(jt(p=>p==="_"))("'_'"),h=Gt(jt(p=>p==="-"))("'-'");return(p,m,y,x,N)=>{const v=p._1,k=p._2;return m(L=>ku(Q(v,k,!1),m,y,(E,B)=>{const q=E._3;return m(j=>{if(q)return x(E,B);const G=p._1,P=p._2;return m(V=>ji(Q(G,P,!1),m,y,(U,M)=>{const H=U._3;return m(R=>{if(H)return x(U,M);const C=p._1,D=p._2;return m(F=>_(Q(C,D,!1),m,y,(I,z)=>{const $=I._3;return m(X=>$?x(I,z):h(p,m,y,x,N))},N))})},N))})},N))}})()),l=e._3&&!a._3?Q(a._1,a._2,!0):a;return n(_=>d(l,n,r,(h,p)=>i(Q(h._1,h._2,u),p),(h,p)=>n(m=>o(l._3&&!h._3?Q(h._1,h._2,!0):h,void 0))))})))},Hw=(t,e,n,r,i)=>e(o=>ar("+edge")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=Gt(Le)("source node identifier"),p=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(k=>fn(v,e,n,r,(L,E)=>e(B=>{const q=Gt(Le)("target node identifier"),j=v._3&&!L._3?Q(L._1,L._2,!0):L;return e(G=>q(j,e,n,r,(P,V)=>e(U=>{const M=j._3&&!P._3?Q(P._1,P._2,!0):P;return e(H=>{const R=(F,I)=>e(z=>i(M._3&&!F._3?Q(F._1,F._2,!0):F,Wn("AddEdge",{from:x,to:V,label:I.tag==="Just"?w("Just",I._1):J}))),C=M._1,D=M._2;return e(F=>e(I=>{const z=($,X)=>{const Y=$._3;return e(W=>Y?r($,X):R(M,J))};return e($=>e(X=>He(Q(C,D,!1),e,n,(Y,W)=>z(Q(Y._1,Y._2,!1),W),(Y,W)=>e(K=>e(Z=>N1(Y,e,n,(ct,_t)=>z(Q(ct._1,ct._2,!1),_t),(ct,_t)=>e(gt=>{const yt=Y._3&&!ct._3?Q(ct._1,ct._2,!0):ct;return e(St=>R(yt,w("Just",_t)))})))))))}))})})))})))})))})))}))),Ww=(t,e,n,r,i)=>e(o=>ar("-edge")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=Gt(Le)("source node identifier"),p=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(k=>fn(v,e,n,r,(L,E)=>e(B=>{const q=Gt(Le)("target node identifier"),j=v._3&&!L._3?Q(L._1,L._2,!0):L;return e(G=>q(j,e,n,r,(P,V)=>e(U=>i(j._3&&!P._3?Q(P._1,P._2,!0):P,Wn("DelEdge",{from:x,to:V})))))})))})))})))}))),Ow=(t,e,n,r,i)=>e(o=>ar("-node")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=Gt(Le)("node identifier"),p=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=sn((L,E,B,q,j)=>{const G=L._3;return zw(L,E,B,(P,V)=>q(Q(P._1,P._2,G),V),j)}),k=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(L=>v(k,e,n,r,(E,B)=>e(q=>i(k._3&&!E._3?Q(E._1,E._2,!0):E,Wn("DelNode",{id:x,via:Ct(Vt.foldr,B)})))))})))})))}))),Yw=(t,e,n,r,i)=>e(o=>ar("enter")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=Gt(Le)("node identifier"),p=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>i(p._3&&!y._3?Q(y._1,y._2,!0):y,Wn("Enter",{id:x})))))})))}))),$w=(t,e,n,r,i)=>e(o=>ar("exit")(t,e,n,r,(u,s)=>e(a=>i(t._3&&!u._3?Q(u._1,u._2,!0):u,WT)))),qw=(t,e,n,r,i)=>e(o=>ar("~edge")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=Gt(Le)("source node identifier"),p=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(k=>fn(v,e,n,r,(L,E)=>e(B=>{const q=Gt(Le)("target node identifier"),j=v._3&&!L._3?Q(L._1,L._2,!0):L;return e(G=>q(j,e,n,r,(P,V)=>e(U=>{const M=j._3&&!P._3?Q(P._1,P._2,!0):P;return e(H=>en(M,e,n,r,(R,C)=>e(D=>{const F=Gt(ei("->"))("'->'"),I=M._3&&!R._3?Q(R._1,R._2,!0):R;return e(z=>F(I,e,n,r,($,X)=>e(Y=>{const W=I._3&&!$._3?Q($._1,$._2,!0):$;return e(K=>en(W,e,n,r,(Z,ct)=>e(_t=>{const gt=Gt(Le)("new source node identifier"),yt=W._3&&!Z._3?Q(Z._1,Z._2,!0):Z;return e(St=>gt(yt,e,n,r,(Ht,pt)=>e(Wt=>{const Tt=yt._3&&!Ht._3?Q(Ht._1,Ht._2,!0):Ht;return e(mt=>fn(Tt,e,n,r,(ft,ot)=>e(dt=>{const ut=Gt(Le)("new target node identifier"),st=Tt._3&&!ft._3?Q(ft._1,ft._2,!0):ft;return e(Nt=>ut(st,e,n,r,(Jt,kt)=>e(Ot=>i(st._3&&!Jt._3?Q(Jt._1,Jt._2,!0):Jt,Wn("RepointEdge",{from:x,to:V,newFrom:pt,newTo:kt})))))})))})))})))})))})))})))})))})))})))}))),Xw=(t,e,n,r,i)=>e(o=>ar("seed")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>He(c,e,n,r,(d,l)=>e(_=>{const h=Gt(Mw)("integer (seed value)"),p=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(k=>en(v,e,n,r,(L,E)=>e(B=>i(v._3&&!L._3?Q(L._1,L._2,!0):L,x))))})))})))}))),eo=Ew((()=>{const t=Gt(jt(e=>e==="{"))("'{'");return(e,n,r,i,o)=>n(u=>n(s=>t(e,n,r,i,(a,c)=>n(f=>n(d=>{const l=e._3&&!a._3?Q(a._1,a._2,!0):a;return en(l,n,r,i,(_,h)=>n(p=>o(l._3&&!_._3?Q(_._1,_._2,!0):_,h)))})))))})())(Gt((()=>{const t=Gt(jt(e=>e==="}"))("'}'");return(e,n,r,i,o)=>n(u=>n(s=>en(e,n,r,i,(a,c)=>n(f=>n(d=>{const l=e._3&&!a._3?Q(a._1,a._2,!0):a;return t(l,n,r,i,(_,h)=>n(p=>o(l._3&&!_._3?Q(_._1,_._2,!0):_,h)))})))))})())("closing '}'")),Vw=eo((t,e,n,r,i)=>e(o=>{const u=(c,f)=>e(d=>(()=>{if(f.tag==="Nothing")return(l,_,h,p,m)=>m(l,A);if(f.tag==="Just"){const l=f._1,_=sn((()=>{const h=Gt(jt(p=>p===","))("','");return(p,m,y,x,N)=>{const v=p._3;return m(k=>m(L=>m(E=>m(B=>m(q=>m(j=>He(p,m,y,(G,P)=>x(Q(G._1,G._2,v),P),(G,P)=>m(V=>m(U=>{const M=p._3&&!G._3?Q(G._1,G._2,!0):G;return h(M,m,y,(H,R)=>x(Q(H._1,H._2,v),R),(H,R)=>m(C=>{const D=M._3&&!H._3?Q(H._1,H._2,!0):H;return m(F=>m(I=>{const z=p._3&&!D._3?Q(D._1,D._2,!0):D;return He(z,m,y,($,X)=>x(Q($._1,$._2,v),X),($,X)=>m(Y=>{const W=z._3&&!$._3?Q($._1,$._2,!0):$;return m(K=>m(Z=>{const ct=p._3&&!W._3?Q(W._1,W._2,!0):W;return J1(ct,m,y,(_t,gt)=>x(Q(_t._1,_t._2,v),gt),(_t,gt)=>m(yt=>N(ct._3&&!_t._3?Q(_t._1,_t._2,!0):_t,gt)))}))}))}))}))})))))))))}})());return(h,p,m,y,x)=>p(N=>_(h,p,m,y,(v,k)=>p(L=>x(h._3&&!v._3?Q(v._1,v._2,!0):v,Pw([l,...Ct(Vt.foldr,k)])))))}g()})()(t._3&&!c._3?Q(c._1,c._2,!0):c,e,n,r,i)),s=t._1,a=t._2;return e(c=>e(f=>J1(Q(s,a,!1),e,n,(d,l)=>e(_=>u(t,J)),(d,l)=>e(_=>u(d,w("Just",l))))))})),Uw=(t,e,n,r,i)=>e(o=>ar("+node")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=Gt(Le)("node identifier"),p=c._3&&!d._3?Q(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(k=>e(L=>He(v,e,n,r,(E,B)=>e(q=>{const j=jt(P=>P===`
15
- `||P==="\r"||P==="#"||P==="}"||P==="{"),G=v._3&&!E._3?Q(E._1,E._2,!0):E;return e(P=>{const V=(H,R)=>e(C=>(R?((D,F,I,z,$)=>$(D,"")):Bw)(G._3&&!H._3?Q(H._1,H._2,!0):H,e,n,r,(D,F)=>e(I=>{const z=v._3&&!D._3?Q(D._1,D._2,!0):D;return e($=>{const X=(K,Z)=>e(ct=>i(z._3&&!K._3?Q(K._1,K._2,!0):K,Wn("AddNode",{id:x,label:F,shape:(()=>{const _t=Dw("shape")(Z);if(_t.tag==="Just")return _t._1==="rectangle"||_t._1==="rect"?tr:_t._1==="cylinder"||_t._1==="cyl"?vl:_t._1==="parallelogram"?bl:_t._1==="diamond"?kl:_t._1==="ellipse"?Ll:_t._1==="document"||_t._1==="doc"?El:_t._1==="cloud"?Cl:tr;if(_t.tag==="Nothing")return tr;g()})()}))),Y=z._1,W=z._2;return e(K=>{const Z=(ct,_t)=>{const gt=ct._3;return e(yt=>gt?r(ct,_t):X(z,A))};return e(ct=>e(_t=>He(Q(Y,W,!1),e,n,(gt,yt)=>Z(Q(gt._1,gt._2,!1),yt),(gt,yt)=>e(St=>e(Ht=>Vw(gt,e,n,(pt,Wt)=>Z(Q(pt._1,pt._2,!1),Wt),(pt,Wt)=>e(Tt=>X(gt._3&&!pt._3?Q(pt._1,pt._2,!0):pt,Wt))))))))})})}))),U=G._1,M=G._2;return e(H=>{const R=(C,D)=>{const F=C._3;return e(I=>F?r(C,D):V(G,!1))};return e(C=>e(D=>e(F=>Ea(Q(U,M,!1),e,n,(I,z)=>{const $=I._3;return e(X=>$?R(Q(U,M,!1),z):e(Y=>j(Q(U,M,!1),e,n,(W,K)=>R(Q(U,M,!1),K),(W,K)=>e(Z=>e(ct=>V(Q(U,M,!1),!0))))))},(I,z)=>e($=>e(X=>V(Q(U,M,!1),!0)))))))})})}))))})))})))}))),Kw=(t,e,n,r,i)=>e(o=>d1(t,e,n,r,(u,s)=>e(a=>{const c=Gt(m1([Uw,Ow,qw,Hw,Ww,Yw,$w,Rw]))("statement (+node, -node, +edge, -edge, ~edge, enter, exit, or 'a -> b')"),f=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>i(f._3&&!l._3?Q(l._1,l._2,!0):l,wa("Leaf",{op:_,line:s.line,column:s.column})))))}))),Zw=(t,e,n,r,i)=>e(o=>to("seq")(t,e,n,r,(u,s)=>e(a=>eo(Ga(u1))(t._3&&!u._3?Q(u._1,u._2,!0):u,e,n,r,i)))),jw=(t,e,n,r,i)=>e(o=>to("par")(t,e,n,r,(u,s)=>e(a=>eo(Ga(qT))(t._3&&!u._3?Q(u._1,u._2,!0):u,e,n,r,i)))),Ga=t=>{const e=sn(tv());return(n,r,i,o,u)=>r(s=>e(n,r,i,o,(a,c)=>r(f=>u(n._3&&!a._3?Q(a._1,a._2,!0):a,t(Ct(Vt.foldr,c))))))},tv=Qa(()=>{const t=ka(Gt(jt(e=>e==="}"))("'}'"));return(e,n,r,i,o)=>n(u=>{const s=e._3;return n(a=>n(c=>en(e,n,r,(f,d)=>i(Q(f._1,f._2,s),d),(f,d)=>n(l=>n(_=>{const h=e._3&&!f._3?Q(f._1,f._2,!0):f;return t(h,n,r,(p,m)=>i(Q(p._1,p._2,s),m),(p,m)=>n(y=>{const x=h._3&&!p._3?Q(p._1,p._2,!0):p;return n(N=>{const v=m1([(L,E,B,q,j)=>{const G=L._3;return jw(L,E,B,(P,V)=>q(Q(P._1,P._2,G),V),j)},(L,E,B,q,j)=>{const G=L._3;return Zw(L,E,B,(P,V)=>q(Q(P._1,P._2,G),V),j)},Kw]),k=e._3&&!x._3?Q(x._1,x._2,!0):x;return n(L=>v(k,n,r,i,(E,B)=>n(q=>{const j=k._3&&!E._3?Q(E._1,E._2,!0):E;return n(G=>He(j,n,r,i,(P,V)=>n(U=>{const M=j._3&&!P._3?Q(P._1,P._2,!0):P;return n(H=>Iw(M,n,r,i,(R,C)=>n(D=>o(M._3&&!R._3?Q(R._1,R._2,!0):R,B))))})))})))})}))})))))})}),Pa=t=>e=>(n,r,i,o,u)=>r(s=>to(t)(n,r,i,o,(a,c)=>r(f=>{const d=n._3&&!a._3?Q(a._1,a._2,!0):a;return r(l=>Qw(d,r,i,o,(_,h)=>r(p=>{const m=d._3&&!_._3?Q(_._1,_._2,!0):_;return r(y=>en(m,r,i,o,(x,N)=>r(v=>{const k=eo(Ga(u1)),L=m._3&&!x._3?Q(x._1,x._2,!0):x;return r(E=>k(L,r,i,o,(B,q)=>r(j=>{const G=L._3&&!B._3?Q(B._1,B._2,!0):B;return r(P=>en(G,r,i,o,(V,U)=>r(M=>u(G._3&&!V._3?Q(V._1,V._2,!0):V,{name:w("Just",h),ops:q,kind:e}))))})))})))})))}))),ev=(t,e,n,r,i)=>{const o=t._1,u=t._2;return e(s=>Pa("keyframe")(OT)(Q(o,u,!1),e,n,(a,c)=>{const f=a._3;return e(d=>{if(f)return r(a,c);const l=t._1,_=t._2;return e(h=>Pa("still")(YT)(Q(l,_,!1),e,n,(p,m)=>{const y=p._3;return e(x=>y?r(p,m):Pa("title")($T)(t,e,n,r,i))},i))})},i))},nv=(t,e,n,r,i)=>e(o=>to("inside")(t,e,n,r,(u,s)=>e(a=>{const c=Gt(Le)("node identifier"),f=t._3&&!u._3?Q(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>{const p=f._3&&!l._3?Q(l._1,l._2,!0):l;return e(m=>en(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?Q(y._1,y._2,!0):y;return e(k=>eo(T1)(v,e,n,r,(L,E)=>e(B=>{const q=v._3&&!L._3?Q(L._1,L._2,!0):L;return e(j=>en(q,e,n,r,(G,P)=>e(V=>i(q._3&&!G._3?Q(G._1,G._2,!0):G,{node:_,doc:E}))))})))})))})))}))),T1=(t,e,n,r,i)=>e(o=>{const u=(c,f)=>e(d=>{const l=sn(rv()),_=t._3&&!c._3?Q(c._1,c._2,!0):c;return e(h=>l(_,e,n,r,(p,m)=>e(y=>{const x=Ct(Vt.foldr,m);return i(_._3&&!p._3?Q(p._1,p._2,!0):p,{seed:(()=>{if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1;g()})(),frames:xt(N=>{if(N.tag==="TopFrame")return w("Just",N._1);if(N.tag==="TopInside")return J;g()})(x),interiors:xt(N=>{if(N.tag==="TopInside")return w("Just",N._1);if(N.tag==="TopFrame")return J;g()})(x)})})))}),s=t._1,a=t._2;return e(c=>e(f=>Xw(Q(s,a,!1),e,n,(d,l)=>{const _=d._3;return e(h=>_?r(d,l):u(t,J))},(d,l)=>e(_=>u(d,w("Just",l))))))}),rv=Qa(()=>yw.defer(t=>(e,n,r,i,o)=>{const u=e._1,s=e._2;return n(a=>n(c=>nv(Q(u,s,!1),n,r,(f,d)=>n(l=>n(_=>ev(e,n,r,i,(h,p)=>n(m=>o(h,p1("TopFrame",p)))))),(f,d)=>n(l=>o(f,p1("TopInside",d))))))})),iv=(()=>{const t=Gt((e,n,r,i,o)=>n(u=>n(s=>en(e,n,r,i,(a,c)=>n(f=>n(d=>{const l=e._3&&!a._3?Q(a._1,a._2,!0):a;return Ea(l,n,r,i,(_,h)=>n(p=>o(l._3&&!_._3?Q(_._1,_._2,!0):_,h)))}))))))("'keyframe', 'still', 'title', 'inside', or end of input");return(e,n,r,i,o)=>n(u=>n(s=>n(a=>n(c=>en(e,n,r,i,(f,d)=>n(l=>n(_=>{const h=e._3&&!f._3?Q(f._1,f._2,!0):f;return T1(h,n,r,i,(p,m)=>n(y=>{const x=h._3&&!p._3?Q(p._1,p._2,!0):p;return n(N=>n(v=>{const k=e._3&&!x._3?Q(x._1,x._2,!0):x;return t(k,n,r,i,(L,E)=>n(B=>o(k._3&&!L._3?Q(L._1,L._2,!0):L,m)))}))}))})))))))})(),ov=t=>{const e=Tw(t)(iv);if(e.tag==="Left")return Dt("Left",{msg:e._1._1,line:e._1._2.line,column:e._1._2.column});if(e.tag==="Right")return Dt("Right",e._1);g()},uv=t=>{const e=ov(t);if(e.tag==="Left")return Dt("Left",e._1.msg);if(e.tag==="Right")return Dt("Right",e._1);g()};function Da(t,e,n,r){if(typeof window<"u"){var i=window[n];if(i!=null&&r instanceof i)return e(r)}for(var o=r;o!=null;){var u=Object.getPrototypeOf(o),s=u.constructor.name;if(s===n)return e(r);if(s==="Object")return t;o=u}return t}function ni(t){return function(e){return function(n){return function(){n.setAttribute(t,e)}}}}function sv(t){return function(e){return function(){return e.getAttribute(t)}}}const w1=t=>{const e=sv(t);return n=>{const r=e(n);return()=>{const i=r();return ac(i,J,Ut)}}};function av(t){return function(e){return function(){e.textContent=t}}}function cv(t){return function(){return function(e){return t(e)()}}}function gv(t){return function(e){return function(n){return function(r){return function(){return r.addEventListener(t,e,n)}}}}}const fv=function(){return window};function _v(t){return function(e){return function(){e.value=t}}}function dv(t){return function(){return t.valueAsNumber}}function lv(t){return function(){return t.value}}function hv(t){return function(e){return function(){return e.requestAnimationFrame(t)}}}const pv=t=>t,mv=t=>()=>t.clientWidth||0,yv=t=>()=>t.clientHeight||0,xv=()=>window.devicePixelRatio||1,Ia=(t,e)=>{e.innerHTML=t},Lu=(t,e,n)=>{t.style.setProperty(e,n)},Nv=(t,e)=>t.querySelector(`[data-mg="${e}"]`),Jv=t=>e=>t===e,Tv=t=>t,wv=(t,e,n)=>({tag:t,_1:e,_2:n}),vv=zt.foldMap(Ed),v1=t=>e=>{const n=it.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},bv=t=>e=>{const n=it.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},kv=wv("AutoSize"),Lv=Tv("CanvasRenderer"),Ev=t=>e=>{const n=t-e*et(ce(mn(t/e)));return e<=0?0:n<0?n+e:n},Cv=t=>T(e=>n=>{const r=t(n);return()=>(e(),r())})(()=>{}),Sv=t=>{const e=w1("data-markgraf-titles")(t);return()=>{const n=e();return n.tag==="Nothing"||!(n.tag==="Just"&&n._1==="false")}},Gv=t=>{const e=w1("data-markgraf-theme")(t);return()=>{const n=e();if(n.tag==="Just")return n._1==="light"?Na:n._1==="dark"?yT:n._1==="blueprint"?xT:n._1==="whiteboard"?NT:n._1==="isometric"?JT:Na;if(n.tag==="Nothing")return Na;g()}},Pv=`
1
+ var jb=(function(Iu){"use strict";function Ua(t){let e=0,n;return()=>{if(e===2)return n;if(e===1)throw new Error("Binding demanded before initialized");return e=1,n=t(),e=2,n}}function g(){throw new Error("Failed pattern match")}function An(t,e){return e>0?Math.floor(t/e):e<0?-Math.floor(t/-e):0}const Se=t=>e=>t,H=function(t){return function(e){for(var n=e.length,r=new Array(n),i=0;i<n;i++)r[i]=t(e[i]);return r}},id={map:H},Ka=t=>t,Tt=typeof Array.prototype.flatMap=="function"?function(t){return function(e){return t.flatMap(e)}}:function(t){return function(e){for(var n=[],r=t.length,i=0;i<r;i++)for(var o=e(t[i]),u=o.length,s=0;s<u;s++)n.push(o[s]);return n}},ue=function(t){return t.toString()},dr=function(t){var e=t.toString();return isNaN(e+".0")?e:e+".0"},od=function(t){var e=t.length;return'"'+t.replace(/[\0-\x1F\x7F"\\]/g,function(n,r){switch(n){case'"':case"\\":return"\\"+n;case"\x07":return"\\a";case"\b":return"\\b";case"\f":return"\\f";case`
2
+ `:return"\\n";case"\r":return"\\r";case" ":return"\\t";case"\v":return"\\v"}var i=r+1,o=i<e&&t[i]>="0"&&t[i]<="9"?"\\&":"";return"\\"+n.charCodeAt(0).toString(10)+o})+'"'},Qu=t=>t,me=Qu("LT"),ye=Qu("GT"),Ie=Qu("EQ"),T=(t,e)=>({tag:t,_1:e}),J=T("Nothing"),Zt=t=>T("Just",t),ja=t=>{if(t.tag==="Nothing")return!0;if(t.tag==="Just")return!1;g()},Za=t=>{if(t.tag==="Nothing")return!1;if(t.tag==="Just")return!0;g()},Gt=(t,e)=>({tag:t,_1:e}),ud=t=>Gt("Right",t),sd={map:t=>e=>{if(e.tag==="Left")return Gt("Left",e._1);if(e.tag==="Right")return Gt("Right",t(e._1));g()}},tc={apply:t=>e=>{if(t.tag==="Left")return Gt("Left",t._1);if(t.tag==="Right"){if(e.tag==="Left")return Gt("Left",e._1);if(e.tag==="Right")return Gt("Right",t._1(e._1))}g()},Functor0:()=>sd},ad={bind:t=>{if(t.tag==="Left"){const e=t._1;return n=>Gt("Left",e)}if(t.tag==="Right"){const e=t._1;return n=>n(e)}g()},Apply0:()=>tc},cd={pure:ud,Apply0:()=>tc},ec={Applicative0:()=>cd,Bind1:()=>ad},gd=t=>t,fd={map:t=>e=>t(e)},nc={apply:t=>e=>t(e),Functor0:()=>fd},_d={bind:t=>e=>e(t),Apply0:()=>nc},dd={pure:gd,Apply0:()=>nc},Vn={Applicative0:()=>dd,Bind1:()=>_d},ld=function(t){return function(){return t}},hd={apply:t=>e=>()=>{const n=t(),r=e();return Du.pure(n(r))()},Functor0:()=>pd},Du={pure:ld,Apply0:()=>hd},pd={map:t=>e=>()=>{const n=e();return t(n)}},gi=(t,e)=>({tag:t,_1:e}),rc=t=>gi("Loop",t),md={tailRecM:t=>{const e=n=>{let r=n,i=!0,o;for(;i;){const u=r;if(u.tag==="Loop"){r=t(u._1);continue}if(u.tag==="Done"){i=!1,o=u._1;continue}g()}return o};return n=>e(t(n))},Monad0:()=>Vn},yd=function(t){return function(e){return function(){return t(e())}}},xd=function(t){return function(){return t}},Nd={map:yd},Jd={apply:t=>e=>()=>{const n=t(),r=e();return ic.pure(n(r))()},Functor0:()=>Nd},ic={pure:xd,Apply0:()=>Jd},wd=(function(t){return function(e){return function(n){return function(){return t(e,n)}}}})(function(t,e){return e.push(t)}),Td=(t,e)=>({tag:"Iterator",_1:t,_2:e}),vd=t=>e=>n=>()=>{let r=!1;const i=e._2;for(;!r;){const o=i.value,u=e._1(o);if(u.tag==="Just"&&t(u._1)){n.push(u._1),e._2.value;const s=e._2.value;e._2.value=s+1|0;continue}r=!0}},bd=t=>e=>()=>{let n=!1;const r=t._2;for(;!n;){const i=r.value,o=r.value;r.value=o+1|0;const u=t._1(i);if(u.tag==="Just"){e(u._1)();continue}if(u.tag==="Nothing"){n=!0;continue}g()}},Qr=function(t){return function(e){return function(n){for(var r=e,i=n.length,o=i-1;o>=0;o--)r=t(n[o])(r);return r}}},w=function(t){return function(e){return function(n){for(var r=e,i=n.length,o=0;o<i;o++)r=t(r)(n[o]);return r}}},Fu=t=>{const e=t.Apply0();return n=>r=>n.foldr(i=>{const o=r(i);return u=>e.apply(e.Functor0().map(s=>Ka)(o))(u)})(t.pure())},oc=t=>{const e=Fu(t);return n=>{const r=e(n);return i=>o=>r(o)(i)}},Bt={foldr:Qr,foldl:w,foldMap:t=>{const e=t.mempty;return n=>Bt.foldr(r=>i=>t.Semigroup0().append(n(r))(i))(e)}},L=(t,e)=>({tag:"Tuple",_1:t,_2:e}),ln=t=>e=>L(t,e),to=t=>t._2,eo=t=>t._1,Ft=function(t){return function(e){for(var n=e.length,r=Array(n),i=0;i<n;i++)r[i]=t(i)(e[i]);return r}};var zu=function(t){return function(e){return t===e}};const Ld=zu,kd=zu,fi=zu,Bu=function(t){return function(e){return function(n){if(e.length!==n.length)return!1;for(var r=0;r<e.length;r++)if(!t(e[r])(n[r]))return!1;return!0}}},hn={eq:fi},Ed={eq:kd},Dr={eq:Ld};var Mu=function(t){return function(e){return function(n){return function(r){return function(i){return r<i?t:r===i?e:n}}}}};const Sd=Mu,Cd=Mu,G={compare:Mu(me)(Ie)(ye),Eq0:()=>hn},rt={compare:Cd(me)(Ie)(ye),Eq0:()=>Ed},nt={compare:Sd(me)(Ie)(ye),Eq0:()=>Dr},Gd=function(t){return t},Pd=(function(){function t(i){return[i]}function e(i){return function(o){return[i,o]}}function n(i){return function(o){return function(u){return[i,o,u]}}}function r(i){return function(o){return i.concat(o)}}return function(i){return function(o){return function(u){return function(s){return function(a){function c(f,d){switch(d-f){case 0:return u([]);case 1:return o(t)(s(a[f]));case 2:return i(o(e)(s(a[f])))(s(a[f+1]));case 3:return i(i(o(n)(s(a[f])))(s(a[f+1])))(s(a[f+2]));default:var l=f+Math.floor((d-f)/4)*2;return i(o(r)(c(f,l)))(c(l,d))}}return c(0,a.length)}}}}}})(),Ad=t=>t,lr={traverse:t=>{const e=t.Apply0();return Pd(e.apply)(e.Functor0().map)(t.pure)},sequence:t=>lr.traverse(t)(Ad),Functor0:()=>id,Foldable1:()=>Bt},zt=function(t,e){for(var n=t>e?-1:1,r=new Array(n*(e-t)+1),i=t,o=0;i!==e;)r[o++]=i,i+=n;return r[o]=i,r};var Id=function(t,e){if(t<1)return[];var n=new Array(t);return n.fill(e)},Qd=function(t,e){for(var n=[],r=0,i=0;i<t;i++)n[r++]=e;return n};const Dd=typeof Array.prototype.fill=="function"?Id:Qd,At=(function(){function t(i,o){this.head=i,this.tail=o}var e={};function n(i){return function(o){return new t(i,o)}}function r(i){for(var o=[],u=0,s=i;s!==e;)o[u++]=s.head,s=s.tail;return o}return function(i,o){return r(i(n)(e)(o))}})(),Mt=function(t,e,n){return n.length===0?t({}):e(n[0])(n.slice(1))},uc=function(t,e,n,r){for(var i=0;i<r.length;i++){var o=n(r[i]);if(e(o))return o}return t},hr=function(t,e,n,r){for(var i=0,o=r.length;i<o;i++)if(n(r[i]))return t(i);return e},sc=function(t,e,n,r,i){if(n<0||n>i.length)return e;var o=i.slice();return o.splice(n,0,r),t(o)},ac=function(t,e,n,r){if(n<0||n>=r.length)return e;var i=r.slice();return i.splice(n,1),t(i)},Un=function(t,e,n,r,i){if(n<0||n>=i.length)return e;var o=i.slice();return o[n]=r,t(o)},ve=function(t){return t.slice().reverse()},Ye=function(t){if(t.length<=1e4)return Array.prototype.concat.apply([],t);for(var e=[],n=0,r=t.length;n<r;n++)for(var i=t[n],o=0,u=i.length;o<u;o++)e.push(i[o]);return e},ut=function(t,e){return e.filter(t)},Fd=function(t,e,n){for(var r=n.length,i=e,o=new Array(r),u=0;u<r;u++)i=t(i)(n[u]),o[u]=i;return o},zd=(function(){function t(e,n,r,i,o,u){var s,a,c,f,d,l,_;for(s=o+(u-o>>1),s-o>1&&t(e,n,i,r,o,s),u-s>1&&t(e,n,i,r,s,u),a=o,c=s,f=o;a<s&&c<u;)d=i[a],l=i[c],_=n(e(d)(l)),_>0?(r[f++]=l,++c):(r[f++]=d,++a);for(;a<s;)r[f++]=i[a++];for(;c<u;)r[f++]=i[c++]}return function(e,n,r){var i;return r.length<2?r:(i=r.slice(0),t(e,n,i,r.slice(0),0,r.length),i)}})(),kt=function(t,e,n){return n.slice(t,e)},be=function(t,e,n){for(var r=e.length<n.length?e.length:n.length,i=new Array(r),o=0;o<r;o++)i[o]=t(e[o])(n[o]);return i},qe=function(t,e){for(var n=e.length,r=0;r<n;r++)if(t(e[r]))return!0;return!1},cc=function(t,e){for(var n=e.length,r=0;r<n;r++)if(!t(e[r]))return!1;return!0},Et=t=>e=>zd(t,n=>{if(n==="GT")return 1;if(n==="EQ")return 0;if(n==="LT")return-1;g()},e),Bd=t=>e=>Et(n=>r=>t.compare(e(n))(e(r))),Dt=t=>e=>(()=>{const n=wd(e);return()=>{const r=[...t];return n(r)(),r}})()(),pr=t=>{if(t.length===0)return t.length-1|0,J;const e=t.length-1|0;return e>=0&&e<t.length?T("Just",{init:kt(0,t.length-1|0,t),last:t[e]}):J},Md=t=>e=>n=>t>=0&&t<n.length?Un(Zt,J,t,e(n[t]),n):J,mr=t=>e=>{const n=(r=>{let i=r,o=!0,u;for(;o;){const s=i;if(s>=0&&s<e.length){if(t(e[s])){i=s+1|0;continue}o=!1,u=T("Just",s);continue}o=!1,u=J}return u})(0);if(n.tag==="Just")return n._1===0?{init:[],rest:e}:{init:kt(0,n._1,e),rest:kt(n._1,e.length,e)};if(n.tag==="Nothing")return{init:e,rest:[]};g()},Fr=t=>e=>{const n=Et(r=>i=>t(r._2)(i._2))(Ft(ln)(e));return 0<n.length?H(to)(Bd(nt)(eo)((()=>{const r=[n[0]];for(const i of n){const o=t((()=>{const u=r.length-1|0;if(u>=0&&u<r.length)return r[u]._2;g()})())(i._2);(o==="LT"||o==="GT"||o!=="EQ")&&r.push(i)}return r})())):[]},Wd=t=>e=>{const n=[],r=Td(i=>i>=0&&i<e.length?T("Just",e[i]):J,{value:0});return bd(r)(i=>()=>{const o=[];o.push(i),vd(t(i))(r)(o)(),n.push(o)})(),n},Vt=t=>e=>{const n=hr(Zt,J,t,e);return n.tag==="Just"?T("Just",e[n._1]):J},gc=t=>e=>ut(t,e),He=t=>e=>n=>{const r=hr(Zt,J,i=>t.eq(i)(e),n);if(r.tag==="Nothing")return!1;if(r.tag==="Just")return!0;g()},fc=t=>e=>Tt(e)(t),xt=t=>fc(e=>{const n=t(e);if(n.tag==="Nothing")return[];if(n.tag==="Just")return[n._1];g()}),_c=isFinite;function Rd(t,e,n,r){var i=parseFloat(t);return e(i)?n(i):r}const yn=Math.abs,qd=Math.acos,yr=function(t){return function(e){return Math.atan2(t,e)}},no=Math.ceil,rn=Math.cos,zr=Math.exp,xn=Math.floor,ro=Math.log,Hd=function(t){return function(e){return Math.min(t,e)}},Wu=function(t){return function(e){return Math.pow(t,e)}},xr=Math.round,Ve=Math.sin,Ce=Math.sqrt,Od=Math.tan,$d=function(t){return function(e){return function(n){return(n|0)===n?t(n):e}}},et=function(t){return t},Xd=(function(t){return function(e){return function(n){var r;n<11?r="[0-"+(n-1).toString()+"]":n===11?r="[0-9a]":r="[0-9a-"+String.fromCharCode(86+n)+"]";var i=new RegExp("^[\\+\\-]?"+r+"+$","i");return function(o){if(i.test(o)){var u=parseInt(o,n);return(u|0)===u?t(u):e}else return e}}}})(Zt)(J)(10),dc=$d(Zt)(J),xe=t=>{if(!_c(t))return 0;if(t>=et(2147483647))return 2147483647;if(t<=et(-2147483648))return-2147483648;const e=dc(t);if(e.tag==="Nothing")return 0;if(e.tag==="Just")return e._1;g()},Xt=(t,e,n)=>({tag:t,_1:e,_2:n}),Ut=Xt("Nil"),Kt={foldr:t=>e=>{const n=Kt.foldl(i=>o=>t(o)(i))(e),r=(i=>o=>{let u=i,s=o,a=!0,c;for(;a;){const f=u,d=s;if(d.tag==="Nil"){a=!1,c=f;continue}if(d.tag==="Cons"){u=Xt("Cons",d._1,f),s=d._2;continue}g()}return c})(Ut);return i=>n(r(i))},foldl:t=>e=>n=>{let r=e,i=n,o=!0,u;for(;o;){const s=r,a=i;if(a.tag==="Nil"){o=!1,u=s;continue}if(a.tag==="Cons"){r=t(s)(a._1),i=a._2;continue}g()}return u},foldMap:t=>{const e=t.mempty;return n=>Kt.foldl(r=>{const i=t.Semigroup0().append(r);return o=>i(n(o))})(e)}},Yd=function(t){return function(e){return function(n){return function(r){return function(i){return function(o){for(var u=[],s=o;;){var a=i(s);u.push(n(a));var c=r(a);if(t(c))return u;s=e(c)}}}}}}},Vd=t=>{if(t.tag==="Just")return t._1;g()},Ud={unfoldr1:Yd(ja)(Vd)(eo)(to)},Kd=function(t){return function(e){return function(n){return function(r){return function(i){return function(o){for(var u=[],s=o;;){var a=i(s);if(t(a))return u;var c=e(a);u.push(n(c)),s=r(c)}}}}}}},jd=t=>{if(t.tag==="Just")return t._1;g()},Ue={unfoldr:Kd(ja)(jd)(eo)(to),Unfoldable10:()=>Ud},Ot=(t,e,n,r,i,o,u)=>({tag:t,_1:e,_2:n,_3:r,_4:i,_5:o,_6:u}),Ke=(t,e,n,r)=>({tag:t,_1:e,_2:n,_3:r}),io=(t,e,n)=>({tag:"Split",_1:t,_2:e,_3:n}),lc=(t,e,n)=>({tag:"SplitLast",_1:t,_2:e,_3:n}),D=Ot("Leaf"),Nn=Ke("IterLeaf"),ce=(t,e,n,r)=>{if(n.tag==="Leaf"){if(r.tag==="Leaf")return Ot("Node",1,1,t,e,n,r);if(r.tag==="Node")return Ot("Node",1+r._1|0,1+r._2|0,t,e,n,r);g()}if(n.tag==="Node"){if(r.tag==="Leaf")return Ot("Node",1+n._1|0,1+n._2|0,t,e,n,r);if(r.tag==="Node")return Ot("Node",n._1>r._1?1+n._1|0:1+r._1|0,(1+n._2|0)+r._2|0,t,e,n,r)}g()},Oe=(t,e,n,r)=>{if(n.tag==="Leaf")return r.tag==="Leaf"?Ot("Node",1,1,t,e,D,D):r.tag==="Node"&&r._1>1?r._5.tag==="Node"&&(()=>{if(r._6.tag==="Leaf")return r._5._1>0;if(r._6.tag==="Node")return r._5._1>r._6._1;g()})()?ce(r._5._3,r._5._4,ce(t,e,n,r._5._5),ce(r._3,r._4,r._5._6,r._6)):ce(r._3,r._4,ce(t,e,n,r._5),r._6):ce(t,e,n,r);if(n.tag==="Node")return r.tag==="Node"?r._1>(n._1+1|0)?r._5.tag==="Node"&&(()=>{if(r._6.tag==="Leaf")return r._5._1>0;if(r._6.tag==="Node")return r._5._1>r._6._1;g()})()?ce(r._5._3,r._5._4,ce(t,e,n,r._5._5),ce(r._3,r._4,r._5._6,r._6)):ce(r._3,r._4,ce(t,e,n,r._5),r._6):n._1>(r._1+1|0)?n._6.tag==="Node"&&(()=>{if(n._5.tag==="Leaf")return 0<=n._6._1;if(n._5.tag==="Node")return n._5._1<=n._6._1;g()})()?ce(n._6._3,n._6._4,ce(n._3,n._4,n._5,n._6._5),ce(t,e,n._6._6,r)):ce(n._3,n._4,n._5,ce(t,e,n._6,r)):ce(t,e,n,r):r.tag==="Leaf"&&n._1>1?n._6.tag==="Node"&&(()=>{if(n._5.tag==="Leaf")return 0<=n._6._1;if(n._5.tag==="Node")return n._5._1<=n._6._1;g()})()?ce(n._6._3,n._6._4,ce(n._3,n._4,n._5,n._6._5),ce(t,e,n._6._6,r)):ce(n._3,n._4,n._5,ce(t,e,n._6,r)):ce(t,e,n,r);g()},Br=(t,e,n)=>{if(n.tag==="Leaf")return io(J,D,D);if(n.tag==="Node"){const r=t(e)(n._3);if(r==="LT"){const i=Br(t,e,n._5);return io(i._1,i._2,Oe(n._3,n._4,i._3,n._6))}if(r==="GT"){const i=Br(t,e,n._6);return io(i._1,Oe(n._3,n._4,n._5,i._2),i._3)}if(r==="EQ")return io(T("Just",n._4),n._5,n._6)}g()},hc=(t,e,n,r)=>{if(r.tag==="Leaf")return lc(t,e,n);if(r.tag==="Node"){const i=hc(r._3,r._4,r._5,r._6);return lc(i._1,i._2,Oe(t,e,n,i._3))}g()},_i=(t,e)=>{if(t.tag==="Leaf")return e;if(t.tag==="Node"){const n=hc(t._3,t._4,t._5,t._6);return Oe(n._1,n._2,n._3,e)}g()},In=(t,e,n)=>{if(e.tag==="Leaf")return D;if(n.tag==="Leaf")return e;if(n.tag==="Node"){const r=Br(t,n._3,e);return _i(In(t,r._2,n._5),In(t,r._3,n._6))}g()},oo=(t,e,n,r)=>{if(n.tag==="Leaf"||r.tag==="Leaf")return D;if(r.tag==="Node"){const i=Br(t,r._3,n),o=oo(t,e,i._2,r._5),u=oo(t,e,i._3,r._6);if(i._1.tag==="Just")return Oe(r._3,e(i._1._1)(r._4),o,u);if(i._1.tag==="Nothing")return _i(o,u)}g()},Ge=(t,e,n,r)=>{if(n.tag==="Leaf")return r;if(r.tag==="Leaf")return n;if(r.tag==="Node"){const i=Br(t,r._3,n),o=Ge(t,e,i._2,r._5),u=Ge(t,e,i._3,r._6);if(i._1.tag==="Just")return Oe(r._3,e(i._1._1)(r._4),o,u);if(i._1.tag==="Nothing")return Oe(r._3,r._4,o,u)}g()},Zd=t=>e=>{const n=r=>{if(r.tag==="Leaf")return D;if(r.tag==="Node"){const i=e(r._3)(r._4);if(i.tag==="Just")return Oe(r._3,i._1,n(r._5),n(r._6));if(i.tag==="Nothing")return _i(n(r._5),n(r._6))}g()};return n},Jn=(t=>e=>n=>{let r=n,i=!0,o;for(;i;){const u=r;if(u.tag==="IterLeaf"){i=!1,o=e();continue}if(u.tag==="IterEmit"){i=!1,o=t(u._1,u._2,u._3);continue}if(u.tag==="IterNode"){r=(s=>a=>{let c=s,f=a,d=!0,l;for(;d;){const _=c,h=f;if(h.tag==="Leaf"){d=!1,l=_;continue}if(h.tag==="Node"){if(h._6.tag==="Leaf"){c=Ke("IterEmit",h._3,h._4,_),f=h._5;continue}c=Ke("IterEmit",h._3,h._4,Ke("IterNode",h._6,_)),f=h._5;continue}g()}return l})(u._2)(u._1);continue}g()}return o})((t,e,n)=>T("Just",L(L(t,e),n)))(t=>J),bt=t=>e=>n=>r=>{const i=o=>{if(o.tag==="Leaf")return Ot("Node",1,1,n,r,D,D);if(o.tag==="Node"){const u=t.compare(n)(o._3);if(u==="LT")return Oe(o._3,o._4,i(o._5),o._6);if(u==="GT")return Oe(o._3,o._4,o._5,i(o._6));if(u==="EQ")return Ot("Node",o._1,o._2,n,e(o._4)(r),o._5,o._6)}g()};return i},Z=t=>e=>n=>{const r=i=>{if(i.tag==="Leaf")return Ot("Node",1,1,e,n,D,D);if(i.tag==="Node"){const o=t.compare(e)(i._3);if(o==="LT")return Oe(i._3,i._4,r(i._5),i._6);if(o==="GT")return Oe(i._3,i._4,i._5,r(i._6));if(o==="EQ")return Ot("Node",i._1,i._2,e,n,i._5,i._6)}g()};return r},te=t=>e=>e.foldl(n=>r=>Z(t)(r._1)(r._2)(n))(D),di=t=>e=>{const n=r=>{if(r.tag==="Leaf")return D;if(r.tag==="Node"){const i=t.compare(e)(r._3);if(i==="LT")return Oe(r._3,r._4,n(r._5),r._6);if(i==="GT")return Oe(r._3,r._4,r._5,n(r._6));if(i==="EQ")return _i(r._5,r._6)}g()};return n},pc=t=>{const e=t.compare;return n=>r=>i=>{const o=Br(e,r,i),u=n(o._1);if(u.tag==="Nothing")return _i(o._2,o._3);if(u.tag==="Just")return Oe(r,u._1,o._2,o._3);g()}},se=function(t){return function(e){return t+e|0}},Mr=function(t){return function(e){return t+e}},Kn=function(t){return function(e){if(e===0)return 0;var n=Math.abs(e);return(t%n+n)%n}},tl=function(t){return function(e){return t+e}},ne=function(t){return function(e){return t.length===0?e:e.length===0?t:t.concat(e)}},el={append:tl},nl={append:ne},rl={mempty:"",Semigroup0:()=>el},il={mempty:[],Semigroup0:()=>nl},ol=null;function mc(t,e,n){return t==null?e:n(t)}function Kb(t){return t}function Ru(t){return function(e){return function(n){return t.apply(n,[e])}}}const ul=Ru(Number.prototype.toPrecision),sl=Ru(Number.prototype.toFixed),al=Ru(Number.prototype.toExponential),li=(t,e)=>({tag:t,_1:e}),hi=t=>e=>n=>{const r=nt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=nt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},pi=t=>{if(t.tag==="Precision")return ul(t._1);if(t.tag==="Fixed")return sl(t._1);if(t.tag==="Exponential")return al(t._1);g()},yc=function(t){return function(){console.log(t)}};function cl(){return Date.now()}function gl(t){return function(){return t.getContext("2d")}}function fl(t){return function(){return t.width}}function _l(t){return function(){return t.height}}function dl(t){return function(e){return function(){t.width=e}}}function ll(t){return function(e){return function(){t.height=e}}}function qu(t){return function(e){return function(){t.lineWidth=e}}}function hl(t){return function(e){return function(){t.fillStyle=e}}}function pl(t){return function(e){return function(){t.strokeStyle=e}}}function Hu(t){return function(e){return function(){t.lineCap=e}}}function Ou(t){return function(e){return function(){t.lineJoin=e}}}function ml(t){return function(e){return function(){t.globalCompositeOperation=e}}}function yl(t){return function(e){return function(){t.globalAlpha=e}}}function xc(t){return function(){t.beginPath()}}function $u(t){return function(){t.stroke()}}function Xu(t){return function(){t.fill()}}function xl(t){return function(){t.clip()}}function mi(t){return function(e){return function(n){return function(){t.lineTo(e,n)}}}}function Nc(t){return function(e){return function(n){return function(){t.moveTo(e,n)}}}}function Jc(t){return function(){t.closePath()}}function Nl(t){return function(e){return function(){t.fillRect(e.x,e.y,e.width,e.height)}}}function Jl(t){return function(e){return function(){t.clearRect(e.x,e.y,e.width,e.height)}}}function uo(t){return function(e){return function(){t.scale(e.scaleX,e.scaleY)}}}function Yu(t){return function(e){return function(){t.translate(e.translateX,e.translateY)}}}function wl(t){return function(e){return function(){t.transform(e.a,e.b,e.c,e.d,e.e,e.f)}}}function Tl(t){return function(e){return function(){t.textAlign=e}}}function vl(t){return function(e){return function(){t.textBaseline=e}}}function bl(t){return function(e){return function(){t.font=e}}}function Ll(t){return function(e){return function(n){return function(r){return function(){t.fillText(e,n,r)}}}}}function jn(t){return function(){t.save()}}function Zn(t){return function(){t.restore()}}function yi(t){return function(e){return function(){t.quadraticCurveTo(e.cpx,e.cpy,e.x,e.y)}}}function kl(t){return function(e){return function(){t.bezierCurveTo(e.cp1x,e.cp1y,e.cp2x,e.cp2y,e.x,e.y)}}}const wc=t=>t,Vu=t=>t,Uu=t=>t,Ku=t=>t,so=t=>t,El=so("BaselineTop"),Sl=so("BaselineMiddle"),Cl=so("BaselineAlphabetic"),Gl=so("BaselineBottom"),Pl=Ku("AlignLeft"),Al=Ku("AlignRight"),Il=Ku("AlignCenter"),ju=Uu("BevelJoin"),ao=Uu("RoundJoin"),Zu=Uu("MiterJoin"),ts=Vu("Round"),es=Vu("Square"),ns=Vu("Butt"),Ql=wc("SourceOver"),Dl=wc("Difference"),Fl=t=>e=>vl(t)((()=>{if(e==="BaselineTop")return"top";if(e==="BaselineHanging")return"hanging";if(e==="BaselineMiddle")return"middle";if(e==="BaselineAlphabetic")return"alphabetic";if(e==="BaselineIdeographic")return"ideographic";if(e==="BaselineBottom")return"bottom";g()})()),zl=t=>e=>Tl(t)((()=>{if(e==="AlignLeft")return"left";if(e==="AlignRight")return"right";if(e==="AlignCenter")return"center";if(e==="AlignStart")return"start";if(e==="AlignEnd")return"end";g()})()),co=t=>e=>{if(e==="BevelJoin")return Ou(t)("bevel");if(e==="RoundJoin")return Ou(t)("round");if(e==="MiterJoin")return Ou(t)("miter");g()},rs=t=>e=>{if(e==="Round")return Hu(t)("round");if(e==="Square")return Hu(t)("square");if(e==="Butt")return Hu(t)("butt");g()},Tc=t=>e=>ml(t)((()=>{if(e==="SourceOver")return"source-over";if(e==="SourceIn")return"source-in";if(e==="SourceOut")return"source-out";if(e==="SourceAtop")return"source-atop";if(e==="DestinationOver")return"destination-over";if(e==="DestinationIn")return"destination-in";if(e==="DestinationOut")return"destination-out";if(e==="DestinationAtop")return"destination-atop";if(e==="Lighter")return"lighter";if(e==="Copy")return"copy";if(e==="Xor")return"xor";if(e==="Multiply")return"multiply";if(e==="Screen")return"screen";if(e==="Overlay")return"overlay";if(e==="Darken")return"darken";if(e==="Lighten")return"lighten";if(e==="ColorDodge")return"color-dodge";if(e==="ColorBurn")return"color-burn";if(e==="HardLight")return"hard-light";if(e==="SoftLight")return"soft-light";if(e==="Difference")return"difference";if(e==="Exclusion")return"exclusion";if(e==="Hue")return"hue";if(e==="Saturation")return"saturation";if(e==="Color")return"color";if(e==="Luminosity")return"luminosity";g()})()),vc={foldrWithIndex:t=>e=>{const n=Qr(i=>{const o=i._1,u=i._2;return s=>t(o)(u)(s)})(e),r=Ft(ln);return i=>n(r(i))},foldlWithIndex:t=>e=>{const n=w(i=>o=>t(o._1)(i)(o._2))(e),r=Ft(ln);return i=>n(r(i))},foldMapWithIndex:t=>{const e=t.mempty;return n=>vc.foldrWithIndex(r=>i=>o=>t.Semigroup0().append(n(r)(i))(o))(e)},Foldable0:()=>Bt},$e={foldr:t=>e=>{const n=Kt.foldr(t)(e);return r=>n((()=>{const i=(o,u)=>{if(o.tag==="Leaf")return u;if(o.tag==="Node")return i(o._5,Xt("Cons",o._3,i(o._6,u)));g()};return i(r,Ut)})())}},Bl=t=>{const e={append:(()=>{const n=t.compare;return r=>i=>Ge(n,Se,r,i)})()};return{mempty:D,Semigroup0:()=>e}},xi=function(t){return function(e){if(t>=0&&t<e.length)return e.charAt(t);throw new Error("Data.String.Unsafe.charAt: Invalid index.")}},Nr=function(t){return t.join("")},Jr=function(t){return t.split("")},go=function(t){return t},tr=function(t){return t.length},bc=function(t){return function(e){return e.substr(0,t)}},Ni=function(t){return function(e){return e.substring(t)}},Ml=function(t){return function(e){return{before:e.substring(0,t),after:e.substring(t)}}},Wl=t=>e=>{const n=Ml(tr(t))(e);return n.before===t?T("Just",n.after):J},Rl=function(t){var e=null;return function(){return t===void 0||(e=t(),t=void 0),e}},ql=function(t){return t()},Hl=t=>e=>n=>{try{var r=BigInt(n);return t(r)}catch{return e}},Ol=t=>e=>n=>{try{var r=BigInt(n);return t(r)}catch{return e}},wr=t=>BigInt(t),$l=t=>Number(t),fo=t=>e=>t+e,_o=t=>e=>t*e,is=t=>e=>t-e,Lc=0n,lo=1n,kc=t=>e=>t^e,Ji=t=>e=>t&e,os=t=>e=>t<<e,us=t=>e=>t>>e,Xl=t=>e=>t==e,Yl=t=>e=>t===e?0:t>e?1:-1,Vl={eq:Xl},Ec={compare:t=>e=>{const n=Yl(t)(e);return n===1?ye:n===0?Ie:me},Eq0:()=>Vl},Ul=Hl(Zt)(J),Kl=Ol(Zt)(J),Sc=(()=>{const t={eq:e=>n=>e._1===n._1&&e._2===n._2};return{compare:e=>n=>{const r=rt.compare(e._1)(n._1);return r==="LT"?me:r==="GT"?ye:rt.compare(e._2)(n._2)},Eq0:()=>t}})(),jl=t=>e=>yn(t._1-e._1)+yn(t._2-e._2),Tr=t=>t,ho=t=>t,de=ho("North"),le=ho("South"),Qn=ho("East"),Dn=ho("West"),er=Tr("Rectangle"),Zl=Tr("Cylinder"),th=Tr("Parallelogram"),eh=Tr("Diamond"),nh=Tr("Ellipse"),rh=Tr("Document"),ih=Tr("Cloud"),Cc=t=>t,Gc=w(Mr)(0),oh=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},nr=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},po=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Pc=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},uh=t=>{const e={top:0,bottom:0,left:0,right:0},n=t.shape==="Cloud"?{...e,top:t.h*.38}:t.shape==="Cylinder"?{...e,bottom:5}:t.shape==="Document"?{...e,bottom:t.h*.05}:e;return[{x:t.x-n.left,y:t.y-n.top},{x:t.x+t.w+n.right,y:t.y+t.h+n.bottom}]},wi=t=>e=>{const n=be(u=>s=>({a:u,b:s,len:(()=>{const a=s.y-u.y,c=s.x-u.x;return Ce(c*c+a*a)})()}),t,kt(1,t.length,t)),r=Gc(H(u=>u.len)(n)),i=oh(0)(r)(e*r),o=u=>s=>a=>{let c=u,f=s,d=a,l=!0,_;for(;l;){const h=c,p=f,m=d,y=Mt(x=>J,x=>N=>T("Just",{head:x,tail:N}),h);if(y.tag==="Nothing"){const x=t.length-1|0;if(x>=0&&x<t.length){l=!1,_=t[x];continue}l=!1,_=m;continue}if(y.tag==="Just"){if(p<=y._1.head.len){const x=y._1.head.len<=0?0:p/y._1.head.len;l=!1,_={x:y._1.head.a.x+(y._1.head.b.x-y._1.head.a.x)*x,y:y._1.head.a.y+(y._1.head.b.y-y._1.head.a.y)*x};continue}c=y._1.tail,f=p-y._1.head.len,d=m;continue}g()}return _};return 0<t.length?T("Just",o(n)(i)(t[0])):J},sh=t=>e=>{const n=nr(1e-6)(t.scale);return{x:(e.x-t.tx)/n,y:(e.y-t.ty)/n,w:e.w/n,h:e.h/n}},mo=t=>Gc(be(e=>n=>{const r=n.y-e.y,i=n.x-e.x;return Ce(i*i+r*r)},t,kt(1,t.length,t))),ah=t=>e=>{const n=nr(4)(.15*po(e.w)(e.h)),r=nr(1)(t.w),i=nr(1)(t.h),o=nr(1)(e.w-2*n),u=nr(1)(e.h-2*n),s=po(o/r)(u/i);return{scale:s,tx:e.x+n+(o-r*s)/2-t.x*s,ty:e.y+n+(u-i*s)/2-t.y*s}},ss={scale:1,tx:0,ty:0},Ne=t=>{const e=Mt(n=>J,n=>r=>T("Just",{head:n,tail:r}),[...(()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._4,n(r._6,i)));g()};return Tt(At(Kt.foldr,n(t.nodes,Ut)))(uh)})(),...Ye((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._4,n(r._6,i)));g()};return At(Kt.foldr,n(t.edges,Ut))})())]);if(e.tag==="Nothing")return{x:0,y:0,w:0,h:0};if(e.tag==="Just"){const n=w(r=>i=>({minX:po(r.minX)(i.x),minY:po(r.minY)(i.y),maxX:nr(r.maxX)(i.x),maxY:nr(r.maxY)(i.y)}))({minX:e._1.head.x,minY:e._1.head.y,maxX:e._1.head.x,maxY:e._1.head.y})(e._1.tail);return{x:n.minX,y:n.minY,w:n.maxX-n.minX,h:n.maxY-n.minY}}g()},ch=t=>e=>(n=>r=>i=>{let o=n,u=r,s=i,a=!0,c;for(;a;){const f=o,d=u,l=s,_=Mt(h=>J,h=>p=>T("Just",{head:h,tail:p}),d);if(_.tag==="Nothing"){a=!1,c=l;continue}if(_.tag==="Just"){const h=Pc(_._1.head)(f.interiors);if(h.tag==="Nothing"){a=!1,c=l;continue}if(h.tag==="Just"){o=h._1,u=_._1.tail,s=(()=>{const p=ah(Ne(h._1.layout))((()=>{const m=Pc(_._1.head)(f.layout.nodes);if(m.tag==="Nothing")return{x:0,y:0,w:1,h:1,label:"",shape:er};if(m.tag==="Just")return m._1;g()})());return{scale:l.scale*p.scale,tx:l.scale*p.tx+l.tx,ty:l.scale*p.ty+l.ty}})();continue}}g()}return c})(t)(e)(ss),gh=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},fh=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},yo=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},_h=t=>e=>n=>r=>{const i=Ne(e);return n<=0||r<=0||i.w<=0||i.h<=0?1:t?gh(i.w/n)(i.h/r):fh(i.w/n)(i.h/r)},Ac=t=>e=>n=>{const r=t.widthPx/t.heightPx,i=n.w/n.h;if(t.widthPx<=0||t.heightPx<=0){const u=1/yo(.05)(1)(e);return{w:n.w*u,h:n.h*u}}if(r>i){const u=1/yo(.05)(1)(e);return{w:n.h*r*u,h:n.h*u}}const o=1/yo(.05)(1)(e);return{w:n.w*o,h:n.w/r*o}},Ic=t=>e=>n=>r=>i=>{const o=t+i/2,u=t+e-i/2,s=t+e/2,a=n+r/2;return i>=e?s:yo(o)(u)(a)},Qc=t=>e=>n=>r=>{const i=Ne(t);return{x:Ic(i.x)(i.w)(e.x)(e.w)(n),y:Ic(i.y)(i.h)(e.y)(e.h)(r)}},Dc=t=>e=>n=>({center:{x:n.x+n.w/2,y:n.y+n.h/2},zoom:_h(t)(e)(n.w)(n.h)}),dh=t=>e=>n=>r=>{const i={x:r.x-t.padding,y:r.y-t.padding,w:r.w+t.padding*2,h:r.h+t.padding*2},o=Ac(e)(.65)(i),u=Qc(n)(i)(o.w)(o.h),s={x:u.x-o.w/2,y:u.y-o.h/2,w:o.w,h:o.h};return{focus:r,paddedFocus:i,viewport:s,camera:Dc(e.widthPx>0&&e.heightPx>0)(n)(s)}},lh=t=>e=>n=>r=>i=>o=>{const u=Ne(r),s={x:u.x*i.scale+i.tx,y:u.y*i.scale+i.ty,w:u.w*i.scale,h:u.h*i.scale},a=t.padding*i.scale,c={x:s.x-a,y:s.y-a,w:s.w+a*2,h:s.h+a*2},f=Ac(e)(.7)(c),d=Qc(n)(c)(f.w)(f.h),l={x:d.x-f.w/2,y:d.y-f.h/2,w:f.w,h:f.h};return{footprint:s,viewport:l,camera:Dc(e.widthPx>0&&e.heightPx>0)(n)(l)}},Fc=t=>t,zc=(t,e)=>({tag:t,_1:e}),as=t=>t,Ti=(t,e)=>({tag:t,_1:e}),cs=(t,e)=>({tag:t,_1:e}),vi=as("Animated"),hh=as("StaticStill"),ph=as("TitleCard"),mh=cs("First"),yh=Fc("Forward"),xh=Fc("Backward"),Nh=Ti("ExitNode"),Bc=te(G)(Bt),Jh=t=>Qr(e=>n=>({nodes:Ge(G.compare,Se,e.nodes,n.nodes),edges:Ge(G.compare,Se,e.edges,n.edges)}))({nodes:D,edges:D})(t.keyframes),wh=t=>e=>({entering:{nodes:In(G.compare,e.nodes,t.nodes),edges:In(G.compare,e.edges,t.edges)},leaving:{nodes:In(G.compare,t.nodes,e.nodes),edges:In(G.compare,t.edges,e.edges)},surviving:{nodes:oo(G.compare,Se,t.nodes,e.nodes),edges:oo(G.compare,Se,t.edges,e.edges)}}),xo=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Wr=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},No=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},gs=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Th=w(t=>e=>Z(G)(e)()(t))(D),vh=w(t=>e=>Z(G)(e)()(t))(D),bh=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),Mc=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Wc=te(G)(Bt),Rc=t=>{const e=Mt(n=>J,n=>r=>T("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return{x:0,y:0,w:0,h:0};if(e.tag==="Just"){const n=w(r=>i=>({minX:xo(r.minX)(i.x),minY:xo(r.minY)(i.y),maxX:Wr(r.maxX)(i.x),maxY:Wr(r.maxY)(i.y)}))({minX:e._1.head.x,minY:e._1.head.y,maxX:e._1.head.x,maxY:e._1.head.y})(e._1.tail);return{x:n.minX,y:n.minY,w:n.maxX-n.minX,h:n.maxY-n.minY}}g()},Lh=t=>e=>n=>Th(Tt(At($e.foldr,n))(r=>{const i=No(r)(t);if(i.tag==="Just")return ut(o=>!gs(o)(e),[i._1.source,i._1.target]);if(i.tag==="Nothing")return[];g()})),kh=t=>t.kind.tag==="SendToken"?T("Just",L(t.kind._1.edge,{source:t.kind._1.from,target:t.kind._1.to})):J,Eh=t=>t.tag==="DataFlow"?xt(kh)(t._1.events):[],Sh=t=>e=>vh(xt(n=>gs(n._2.source)(e)||gs(n._2.target)(e)?T("Just",n._1):J)(bh(t))),vr=t=>{const e=Mt(n=>J,n=>r=>T("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return{x:0,y:0,w:0,h:0};if(e.tag==="Just"){const n=w(r=>i=>({minX:xo(r.minX)(i.x),minY:xo(r.minY)(i.y),maxX:Wr(r.maxX)(i.x+i.w),maxY:Wr(r.maxY)(i.y+i.h)}))({minX:e._1.head.x,minY:e._1.head.y,maxX:e._1.head.x+e._1.head.w,maxY:e._1.head.y+e._1.head.h})(e._1.tail);return{x:n.minX,y:n.minY,w:n.maxX-n.minX,h:n.maxY-n.minY}}g()},fs=t=>e=>n=>{if(n.tag==="Leaf")return Ne(t);const r=Sh(e)(n),i=[...xt(o=>{const u=Mc(o)(t.nodes);return u.tag==="Just"?T("Just",{x:u._1.x,y:u._1.y,w:u._1.w,h:u._1.h}):J})(At($e.foldr,Ge(G.compare,Se,n,Lh(e)(n)(r)))),...xt(o=>{const u=No(o)(t.edges);return u.tag==="Just"?T("Just",Rc(u._1)):J})(At($e.foldr,r))];return i.length===0?Ne(t):vr(i)},qc=t=>e=>n=>{const r=[...xt(i=>i)([(()=>{const i=No(n)(t.edges);return i.tag==="Just"?T("Just",Rc(i._1)):J})()]),...(()=>{const i=No(n)(e);if(i.tag==="Just")return xt(o=>{const u=Mc(o)(t.nodes);return u.tag==="Just"?T("Just",{x:u._1.x,y:u._1.y,w:u._1.w,h:u._1.h}):J})([i._1.source,i._1.target]);if(i.tag==="Nothing")return[];g()})()];return r.length===0?fs(t)(e)(D):vr(r)},Jo=t=>e=>{const n=Ne(t),r=n.w/Wr(1e-4)(e.zoom),i=n.h/Wr(1e-4)(e.zoom);return{x:e.center.x-r/2,y:e.center.y-i/2,w:r,h:i}},Ch=t=>Ge(G.compare,Se,Wc(H(e=>L(e.id,{source:e.from.node,target:e.to.node}))(t.graph.edges)),Wc(Tt(t.scenes)(Eh))),wo=t=>t,Gh=t=>t,_s=wo("Linear"),Ph=wo("EaseInOutQuad"),rr=wo("EaseInOutCubic"),Ah=wo("SpringBouncy"),bi=t=>e=>n=>{const r=Ce(1-e*e),i=t*r;return 1-zr(-e*t*n)*(rn(i*n)+e/r*Ve(i*n))},Ih=t=>{const e=rt.compare(0)(t),n=(()=>{if(e==="LT")return t;if(e==="EQ"||e==="GT")return 0;g()})(),r=rt.compare(1)(n);if(r==="LT"||r==="EQ")return 1;if(r==="GT")return n;g()},Fn=t=>e=>(()=>{if(t==="Linear")return Gh;if(t==="EaseInQuad")return n=>n*n;if(t==="EaseOutQuad")return n=>1-(1-n)*(1-n);if(t==="EaseInOutQuad")return n=>n<.5?2*n*n:1-2*(1-n)*(1-n);if(t==="EaseInCubic")return n=>n*n*n;if(t==="EaseOutCubic")return n=>1-(1-n)*(1-n)*(1-n);if(t==="EaseInOutCubic")return n=>n<.5?4*n*n*n:1-(-2*n+2)*(-2*n+2)*(-2*n+2)/2;if(t==="EaseOutExpo")return n=>n>=1?1:1-Wu(2)(-10*n);if(t==="Spring")return n=>1-(1+6*n)*zr(-6*n);if(t==="SpringBouncy")return bi(6)(.7);g()})()(Ih(e)),To=t=>t,Hc=t=>t,Oc=t=>t,wn=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Rr=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},$c=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Qh=t=>e=>{const n=nt.compare(t._1)(e._1);return n==="LT"?me:n==="GT"?ye:rt.compare(t._2)(e._2)},Dh=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Fh=Oc("Hold"),zh=Oc("Gap"),vo=Hc("LinearLerp"),Xc=Hc("StagedLogLerp"),ds=To("Overview"),Bh=To("DiveHome"),Yc=To("DiveTransition"),Mh=To("ActionFocus"),Wh=t=>e=>{const n=Ne(t),r=n.h/wn(1e-6)(e.zoom),i=n.w/wn(1e-6)(e.zoom);return{x:e.center.x-i/2,y:e.center.y-r/2,w:i,h:r}},Rh=t=>e=>n=>{const r=n.center.y-e.center.y,i=n.center.x-e.center.x,o=Ce(i*i+r*r),u=n.zoom-e.zoom,s=u<0?-u:u;return Rr(t.minTransition)(t.maxTransition)(wn(t.panSpeed<=0?t.minTransition:o/t.panSpeed)(t.zoomSpeed<=0?t.minTransition:s/t.zoomSpeed))},qh=t=>({startT:t.startT,endT:t.endT,fromCam:t.fromCam,toCam:t.toCam,easing:t.easing,interp:t.interp,intent:t.intent}),Hh=w(t=>e=>{const n=t.length-1|0;return n>=0&&n<t.length&&t[n]===e?t:Dt(t)(e)})([]),Oh=t=>e=>{const n=t.x-e.x;return(n<0?-n<.001:n<.001)&&(()=>{const r=t.y-e.y;return(r<0?-r<.001:r<.001)&&(()=>{const i=t.w-e.w;return(i<0?-i<.001:i<.001)&&(()=>{const o=t.h-e.h;return o<0?-o<.001:o<.001})()})()})()},$h=t=>e=>t.tag==="Just"?e.tag==="Just"&&Oh(t._1)(e._1):t.tag==="Nothing"&&e.tag==="Nothing",Vc=t=>e=>n=>r=>({center:{x:r.center.x*n.scale+n.tx,y:r.center.y*n.scale+n.ty},zoom:r.zoom*Ne(t).w/wn(1e-6)(n.scale*Ne(e).w)}),Xh=t=>e=>({center:{x:e.center.x*t.scale+t.tx,y:e.center.y*t.scale+t.ty},zoom:e.zoom/wn(1e-6)(t.scale)}),Uc=t=>e=>n=>r=>({center:{x:t.center.x+(e.center.x-t.center.x)*n,y:t.center.y+(e.center.y-t.center.y)*n},zoom:zr((()=>{const i=ro(wn(1e-6)(t.zoom));return i+(ro(wn(1e-6)(e.zoom))-i)*r})())}),Yh=t=>e=>n=>r=>{const i=zr(-t*e);return{center:{x:r.center.x+(n.center.x-r.center.x)*i,y:r.center.y+(n.center.y-r.center.y)*i},zoom:zr((()=>{const o=ro(wn(1e-6)(r.zoom));return o+(ro(wn(1e-6)(n.zoom))-o)*i})())}},Vh=t=>e=>n=>e.zoom>=t.zoom?Fn(rr)(Rr(0)(1)((n-.28)/.72)):Fn(rr)(Rr(0)(1)(n/.28)),Uh=t=>e=>n=>e.zoom>=t.zoom?Fn(rr)(Rr(0)(1)(n/.28)):Fn(rr)(Rr(0)(1)((n-.28)/.72)),Kh=t=>e=>n=>Uc(t)(e)(Uh(t)(e)(n))(Vh(t)(e)(n)),jh=t=>e=>n=>{const r=n.endT<=n.startT?1:(e-n.startT)/(n.endT-n.startT),i=Fn(n.easing)(Rr(0)(1)(r));if(n.interp==="LinearLerp")return{center:{x:n.fromCam.center.x+(n.toCam.center.x-n.fromCam.center.x)*i,y:n.fromCam.center.y+(n.toCam.center.y-n.fromCam.center.y)*i},zoom:n.fromCam.zoom+(n.toCam.zoom-n.fromCam.zoom)*i};if(n.interp==="LogLerp")return Uc(n.fromCam)(n.toCam)(i)(i);if(n.interp==="StagedLogLerp")return Kh(n.fromCam)(n.toCam)(r);g()},Zh={widthPx:0,heightPx:0},t0={padding:24,easing:_s,minimumReadableLabelPx:24,minimumVisibleLabelPx:5,labelBasePx:11,panSpeed:1500,zoomSpeed:4,minTransition:.15,maxTransition:.6,cameraDecay:6},Li=t=>e=>n=>r=>i=>{const o=Wh(n)(r),u=i.x-t.padding,s=i.y-t.padding;return u>=o.x&&s>=o.y&&u+i.w+t.padding*2<=o.x+o.w&&s+i.h+t.padding*2<=o.y+o.h},e0=t=>e=>n=>r=>i=>vc.foldlWithIndex(o=>u=>s=>{const a=(()=>{if(s.kind==="Hold"){const c=(()=>{if(s.focus.tag==="Just"){if(s.intent==="ActionFocus"&&Li(t)(e)(n)({center:u.prev.center,zoom:s.toCam.zoom})(s.focus._1))return{...s.toCam,center:u.prev.center};if(s.intent==="ActionFocus")return s.toCam;if(Li(t)(e)(n)(u.prev)(s.focus._1))return u.prev;if(Li(t)(e)(n)({center:u.prev.center,zoom:s.toCam.zoom})(s.focus._1))return{...s.toCam,center:u.prev.center}}return s.toCam})();return{startT:s.startT,endT:s.endT,fromCam:c,toCam:c,easing:s.easing,interp:vo,focus:s.focus,intent:s.intent}}if(s.kind==="Gap")return{startT:s.startT,endT:s.endT,fromCam:u.prev,toCam:(()=>{const c=o+1|0,f=hr(Zt,J,d=>d.kind==="Hold",c<1?i:kt(c,i.length,i));if(f.tag==="Just"){const d=(o+1|0)+f._1|0;return d>=0&&d<i.length?(()=>{if(i[d].focus.tag==="Just")return Li(t)(e)(n)(u.prev)(i[d].focus._1);if(i[d].focus.tag==="Nothing")return!1;g()})()?u.prev:i[d].fromCam:u.prev}if(f.tag==="Nothing")return u.prev;g()})(),easing:s.easing,interp:vo,focus:J,intent:s.intent};g()})();return{acc:Dt(u.acc)(a),prev:a.toCam}})({acc:[],prev:r})(i).acc,n0=t=>e=>n=>r=>i=>{const o=(s,a)=>$c(Rh(t)(s.toCam)(a.toCam))(s.endT-s.startT),u=w(s=>a=>{if(s.pending.tag==="Nothing")return{acc:s.acc,pending:T("Just",a)};if(s.pending.tag==="Just")return!(a.fromCam.zoom===a.toCam.zoom&&a.fromCam.center.x===a.toCam.center.x&&a.fromCam.center.y===a.toCam.center.y)||(()=>{if(a.focus.tag==="Just")return Li(t)(e)(n)(s.pending._1.toCam)(a.focus._1);if(a.focus.tag==="Nothing")return!1;g()})()||(()=>{const c=s.pending._1.toCam.center.x-a.toCam.center.x;return(c<0?-c<8:c<8)&&(()=>{const f=s.pending._1.toCam.center.y-a.toCam.center.y;return(f<0?-f<8:f<8)&&(()=>{const d=s.pending._1.toCam.zoom-a.toCam.zoom;return d<0?-d<.08:d<.08})()})()})()||o(s.pending._1,a)<=0?{acc:Dt(s.acc)(s.pending._1),pending:T("Just",a)}:{acc:Dt(Dt(s.acc)({...s.pending._1,endT:a.startT-o(s.pending._1,a)}))({startT:a.startT-o(s.pending._1,a),endT:a.startT,fromCam:s.pending._1.toCam,toCam:a.toCam,easing:a.easing,interp:vo,focus:a.focus,intent:a.intent}),pending:T("Just",a)};g()})({acc:[],pending:J})(i);if(u.pending.tag==="Nothing")return u.acc;if(u.pending.tag==="Just")return Dt(u.acc)(u.pending._1);g()},r0=t=>e=>n=>{const r=e.w+n*2,i=e.h+n*2,o=Ne(t);return r<=0||i<=0||o.w<=0||o.h<=0?1:$c(o.w/r)(o.h/i)},i0=t=>e=>{if(t.tag==="Just"){if(e.tag==="Just")return T("Just",vr([t._1,e._1]));if(e.tag==="Nothing")return T("Just",t._1);g()}if(t.tag==="Nothing"){if(e.tag==="Just")return T("Just",e._1);if(e.tag==="Nothing")return J}g()},o0=w(t=>e=>{const n=t.length-1|0,r=n>=0&&n<t.length?T("Just",t[n]):J;return r.tag==="Just"&&r._1.fromCam.zoom===r._1.toCam.zoom&&r._1.fromCam.center.x===r._1.toCam.center.x&&r._1.fromCam.center.y===r._1.toCam.center.y&&e.fromCam.zoom===e.toCam.zoom&&e.fromCam.center.x===e.toCam.center.x&&e.fromCam.center.y===e.toCam.center.y&&(!(r._1.intent==="ActionFocus"||e.intent==="ActionFocus")||(r._1.intent==="Overview"?e.intent==="Overview":r._1.intent==="DiveHome"?e.intent==="DiveHome":r._1.intent==="DiveTransition"?e.intent==="DiveTransition":r._1.intent==="ActionFocus"&&e.intent==="ActionFocus")&&$h(r._1.focus)(e.focus))&&(()=>{const i=r._1.toCam.center.x-e.toCam.center.x;return(i<0?-i<8:i<8)&&(()=>{const o=r._1.toCam.center.y-e.toCam.center.y;return(o<0?-o<8:o<8)&&(()=>{const u=r._1.toCam.zoom-e.toCam.zoom;return u<0?-u<.08:u<.08})()})()})()?Dt((()=>{const i=t.length-1|0;return i<1?[]:kt(0,i,t)})())({...r._1,endT:e.endT,focus:i0(r._1.focus)(e.focus)}):Dt(t)(e)})([]),u0=t=>{const e=Et(n=>r=>Qh(L((()=>{if(r.intent==="DiveTransition")return 3;if(r.intent==="ActionFocus")return 2;if(r.intent==="DiveHome")return 1;if(r.intent==="Overview")return 0;g()})(),r.startT))(L((()=>{if(n.intent==="DiveTransition")return 3;if(n.intent==="ActionFocus")return 2;if(n.intent==="DiveHome")return 1;if(n.intent==="Overview")return 0;g()})(),n.startT)))(t);return 0<e.length?T("Just",e[0]):J},bo=t=>e=>n=>r=>({center:{x:n.x+n.w/2,y:n.y+n.h/2},zoom:wn(r)(r0(e)(n)(t.padding))}),s0=t=>e=>n=>r=>i=>{const o=bo(t)(n)(Ne(n))(0),u=ut(a=>a>=0&&a<=r,Hh(Et(rt.compare)([0,r,...Tt(i)(a=>[a.startT,a.endT])]))),s=(a,c)=>qe(f=>f.priority>=1,ut(f=>f.startT<=c&&c<f.endT,i))?dh(t)(e)(n)(vr(a)).camera:bo(t)(n)(vr(a))(0);return H(qh)(n0(t)(e)(n)(o)(o0(e0(t)(e)(n)(o)(xt(a=>{const c=(a._1+a._2)/2;if(a._2<=a._1)return J;const f=H(d=>d.bbox)(ut(d=>d.priority===w(Dh)(0)(H(l=>l.priority)(ut(l=>l.startT<=c&&c<l.endT,i))),ut(d=>d.startT<=c&&c<d.endT,i)));return f.length===0?T("Just",{kind:zh,startT:a._1,endT:a._2,fromCam:o,toCam:o,easing:t.easing,focus:J,intent:ds}):T("Just",{kind:Fh,startT:a._1,endT:a._2,fromCam:s(f,c),toCam:s(f,c),easing:t.easing,focus:T("Just",vr(f)),intent:qe(d=>d.priority>=1,ut(d=>d.startT<=c&&c<d.endT,i))?Mh:ds})})(be(ln,u,kt(1,u.length,u)))))))},Kc=t=>e=>n=>r=>{const i=u0(ut(o=>r>=o.startT&&r<o.endT,n));if(i.tag==="Just")return{camera:jh()(r)(i._1),intent:i._1.intent};if(i.tag==="Nothing"){const o=n.length-1|0;return o>=0&&o<n.length&&r>=n[o].endT?{camera:n[o].toCam,intent:n[o].intent}:{camera:(()=>{const u=bo(t)(e)(Ne(e))(0);return 0<n.length?n[0].fromCam:u})(),intent:0<n.length?n[0].intent:ds}}g()};function ir(t){return t.charCodeAt(0)}function jc(t){return String.fromCharCode(t)}const or=function(t){return function(e){return function(n){return n.replace(new RegExp(t.replace(/[-\/\\^$*+?.()|[\]{}]/g,"\\$&"),"g"),e)}}},Lo=function(t){return function(e){return e.split(t)}},a0=function(t){return t.trim()},ko=function(t){return function(e){return e.join(t)}};var c0=typeof Array.from=="function",g0=typeof Symbol<"u"&&Symbol!=null&&typeof Symbol.iterator<"u"&&typeof String.prototype[Symbol.iterator]=="function",f0=typeof String.prototype.fromCodePoint=="function",_0=typeof String.prototype.codePointAt=="function";const d0=function(t){return _0?function(e){return e.codePointAt(0)}:t},l0=function(t){return f0?String.fromCodePoint:t},h0=function(t){return function(e){return g0?function(n){for(var r="",i=n[Symbol.iterator](),o=0;o<e;++o){var u=i.next();if(u.done)return r;r+=u.value}return r}:t(e)}},p0=function(t){return function(e){return c0?function(n){return Array.from(n,e)}:t}},Eo=t=>{const e=tr(t);if(e===0)return J;if(e===1)return T("Just",{head:ir(xi(0)(t)),tail:""});const n=ir(xi(1)(t)),r=ir(xi(0)(t));return 55296<=r&&r<=56319&&56320<=n&&n<=57343?T("Just",{head:(((r-55296|0)*1024|0)+(n-56320|0)|0)+65536|0,tail:Ni(2)(t)}):T("Just",{head:r,tail:Ni(1)(t)})},m0=t=>{const e=Eo(t);return e.tag==="Just"?T("Just",L(e._1.head,e._1.tail)):J},y0=t=>Ue.unfoldr(m0)(t),Zc=d0(t=>{const e=ir(xi(0)(t));if(55296<=e&&e<=56319&&tr(t)>1){const n=ir(xi(1)(t));if(56320<=n&&n<=57343)return(((e-55296|0)*1024|0)+(n-56320|0)|0)+65536|0}return e}),So=p0(y0)(Zc),ls=t=>go(t>=0&&t<=65535?jc(t):t<0?"\0":"\uFFFF"),x0=l0(t=>t<=65535?ls(t):ls(An(t-65536|0,1024)+55296|0)+ls(Kn(t-65536|0)(1024)+56320|0)),tg=t=>e=>{if(t<1)return"";const n=Eo(e);return n.tag==="Just"?x0(n._1.head)+tg(t-1|0)(n._1.tail):e},Je=h0(tg),N0=t=>e=>e===""?J:T("Just",Zc(e)),J0=t=>t,eg=t=>e=>{const n=e.vw/e.vh,r=e.vh*t,i={...e,vx:e.vx-(r-e.vw)/2,vw:r},o=e.vw/t,u={...e,vy:e.vy-(o-e.vh)/2,vh:o};return t<=0||e.vw<=0||e.vh<=0?e:t>n?i:t<n?u:e},ng=t=>e=>t.width<=0||t.height<=0?e:eg(t.width/t.height)(e),Co=(t,e,n)=>({tag:t,_1:e,_2:n}),w0=()=>({tag:"ExtendFromSource"}),Go=(t,e)=>({tag:t,_1:e}),hs=t=>t,Po=(t,e)=>({tag:t,_1:e}),ps=Po("NotYet"),rg=Po("Consumed"),T0=hs("FromSource"),ig=hs("FromTarget"),v0=hs("FromBoth"),og=Go("Hidden"),b0=Go("Visible"),ug=w0(),sg=Co("Retracted"),L0=Co("Extended"),ag=t=>t,ms=(t,e)=>({tag:t,_1:e}),br=(t,e,n)=>({tag:t,_1:e,_2:n}),cg=t=>t,ur=(t,e)=>({tag:t,_1:e}),qr=(t,e,n,r,i,o,u,s,a)=>({tag:t,_1:e,_2:n,_3:r,_4:i,_5:o,_6:u,_7:s,_8:a}),Ao=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},pn=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},gg=te(G)(Bt),ys=Bu(fi),Hr=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},ki=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},xs=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},fg=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},_g=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Or=(()=>{const t=Ue.unfoldr(e=>{if(e.tag==="Nil")return J;if(e.tag==="Cons")return T("Just",L(e._1,e._2));g()});return e=>t((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._3,n(r._6,i)));g()};return n(e,Ut)})())})(),k0=w(t=>e=>Z(G)(e)()(t))(D),Ns=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Io=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},E0=t=>t,S0=ur("NoKeyframes"),C0=t=>ur("DuplicateEventId",t),G0=t=>ur("UnknownEvent",t),dg=cg("PlopIn"),P0=cg("PlopOut"),A0=ag("DiveIn"),I0=ag("DiveOut"),Q0=t=>e=>n=>xt(r=>{if(r.target.tag==="NodeWindow"||r.target.tag==="EdgeWindow")return J;if(r.target.tag==="TokenWindow")return T("Just",{startT:r.startT,endT:r.endT,bbox:qc(e)(n)(r.target._2),priority:1});if(r.target.tag==="FillWindow")return T("Just",{startT:r.startT,endT:r.endT,bbox:fs(e)(n)(Ot("Node",1,1,r.target._2,void 0,D,D)),priority:1});g()}),D0=t=>e=>n=>r=>{const i=Ao(r.edge)(e.edges),o=(()=>{if(i.tag==="Nothing")return 0;if(i.tag==="Just")return mo(i._1);g()})(),u=pn(t.minTokenDuration)(pn(et(w(s=>a=>s+So(a).length|0)(0)(r.labels))*t.tokenReadSecPerChar)(t.tokenSpeed<=0?0:o/t.tokenSpeed))+n.pre+n.post;return{duration:u,holdPre:u<=0?0:n.pre/u,holdPost:u<=0?0:n.post/u}},F0=t=>e=>gg(xt(n=>{if(n.kind.tag==="SendToken")return T("Just",L(n.id,{pre:(()=>{const r=n.when;return(()=>{const i=n.kind._1.from;return qe(o=>{if(o.kind.tag==="SendToken")return(r.tag==="First"?!1:r.tag==="After"&&r._1===o.id)&&o.kind._1.to===i;if(o.kind.tag==="FillNodeWithoutTransition")return!1;g()},e)})()?0:t.tokenHold})(),post:(()=>{const r=n.id;return(()=>{const i=n.kind._1.to;return qe(o=>{if(o.kind.tag==="SendToken")return(o.when.tag==="First"?!1:o.when.tag==="After"&&o.when._1===r)&&o.kind._1.from===i;if(o.kind.tag==="FillNodeWithoutTransition")return!1;g()},e)})()?0:t.tokenHold})()}));if(n.kind.tag==="FillNodeWithoutTransition")return J;g()})(e)),z0=t=>{if(t.event.kind.tag==="SendToken")return T("Just",{startT:t.startT,endT:t.endT,target:qr("TokenWindow",t.event.id,t.event.kind._1.edge,t.event.kind._1.direction,t.event.kind._1.from,t.event.kind._1.to,t.event.kind._1.labels,t.holdPre,t.holdPost)});if(t.event.kind.tag==="FillNodeWithoutTransition")return T("Just",{startT:t.startT,endT:t.endT,target:qr("FillWindow",t.event.id,t.event.kind._1.node,t.event.kind._1.labels)});g()},B0=t=>e=>n=>r=>{const i=Vt(o=>ys(o.path)(e)&&(yn(o.endT-n)<1e-4||yn(o.startT-r)<1e-4))(t.segments);if(i.tag==="Just")return T("Just",i._1);if(i.tag==="Nothing")return Vt(o=>ys(o.path)(e))(t.segments);g()},M0=t=>e=>n=>xt(r=>{const i=xt(o=>xs(o)(t.nodes))(At($e.foldr,(()=>{if(r.scene.tag==="Structural")return Ge(G.compare,Se,(()=>{const o=Hr(r.scene._1.from)(n);if(o.tag==="Nothing")return D;if(o.tag==="Just")return o._1.nodes;g()})(),(()=>{const o=Hr(r.scene._1.to)(n);if(o.tag==="Nothing")return D;if(o.tag==="Just")return o._1.nodes;g()})());if(r.scene.tag==="DataFlow"){const o=Hr(r.scene._1.keyframe)(n);if(o.tag==="Nothing")return D;if(o.tag==="Just")return o._1.nodes;g()}if(r.scene.tag==="Hold"){const o=Hr(r.scene._1)(n);if(o.tag==="Nothing")return D;if(o.tag==="Just")return o._1.nodes;g()}if(r.scene.tag==="EnterNode"||r.scene.tag==="ExitNode")return D;g()})()));return i.length===0?J:T("Just",{startT:r.startT,endT:r.endT,bbox:(()=>{const o=w(u=>s=>({minX:ki(u.minX)(s.x),minY:ki(u.minY)(s.y),maxX:pn(u.maxX)(s.x+s.w),maxY:pn(u.maxY)(s.y+s.h)}))(0<i.length?{minX:i[0].x,minY:i[0].y,maxX:i[0].x+i[0].w,maxY:i[0].y+i[0].h}:{minX:0,minY:0,maxX:0,maxY:0})(kt(1,i.length,i));return{x:o.minX,y:o.minY,w:o.maxX-o.minX,h:o.maxY-o.minY}})(),priority:0})}),W0=t=>e=>n=>r=>i=>[...M0(i.layout)(n)(e)(ut(o=>o.startT>=i.startT&&o.endT<=i.endT,r.spans)),...Q0()(i.layout)(n)(i.windows)],R0=t=>e=>n=>r=>i=>o=>s0(t)(e)(o.layout)(i.endT)(W0()(n)(r)(i)(o)),lg=(()=>{const t=w(e=>n=>{const r=e.previous.tag==="Just"&&yn(e.previous._1.endT-n.startT)<1e-4&&!(n.fromCam.zoom===n.toCam.zoom&&n.fromCam.center.x===n.toCam.center.x&&n.fromCam.center.y===n.toCam.center.y)?{...n,fromCam:e.previous._1.toCam}:n;return{previous:T("Just",r),spans:Dt(e.spans)(r)}})({previous:J,spans:[]});return e=>t(e).spans})(),q0=t=>e=>n=>{const r=Ao(n)(t);if(r.tag==="Nothing")return ig;if(r.tag==="Just"){const i=fg(r._1.target)(e);return fg(r._1.source)(e)?i?v0:T0:ig}g()},H0=t=>e=>{const n=Ne(e),r=ng({width:t.widthPx,height:t.heightPx})({vx:n.x,vy:n.y,vw:n.w,vh:n.h});return{w:r.vw,h:r.vh}},O0=t=>e=>n=>r=>{const i=pn(n.center.x-r.x)(r.x+r.w-n.center.x),o=pn(n.center.y-r.y)(r.y+r.h-n.center.y),u=H0(t)(e);return ki(i<=0?n.zoom:u.w/(i*2))(o<=0?n.zoom:u.h/(o*2))},$0={pre:0,post:0},X0=t=>e=>n=>r=>i=>{const o=_g(i.event.id)(n),u=(()=>{if(o.tag==="Nothing")return $0;if(o.tag==="Just")return o._1;g()})(),s=(()=>{if(i.event.when.tag==="First")return 0;if(i.event.when.tag==="At")return i.event.when._1;if(i.event.when.tag==="After"){const c=i.event.when._1,f=Vt(d=>d.event.id===c)(r);if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1.endT;g()}if(i.event.when.tag==="With"){const c=i.event.when._1,f=Vt(d=>d.event.id===c)(r);if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1.startT}g()})(),a=(()=>{if(i.event.kind.tag==="SendToken")return D0(t)(e)(u)(i.event.kind._1);if(i.event.kind.tag==="FillNodeWithoutTransition")return{duration:t.plop,holdPre:0,holdPost:0};g()})();return Dt(r)({startT:s,endT:s+a.duration,event:i.event,holdPre:a.holdPre,holdPost:a.holdPost})},hg=t=>e=>n=>w(X0(t)(e)(F0(t)(n)))([])(Ft(r=>i=>({event:i}))(n)),Js=t=>e=>n=>r=>i=>{const o={width:e.widthPx,height:e.heightPx},u=ng(o)((()=>{const s=Jo(n)(i);return{vx:s.x,vy:s.y,vw:s.w,vh:s.h}})());return t.labelBasePx*r.placement.scale*(o.width<=0||u.vw<=0?0:o.width/u.vw)},Y0=t=>e=>n=>r=>i=>{const o=Js(t)(e)(n)(r)(i);return o<=t.minimumReadableLabelPx?i:{...i,zoom:i.zoom*t.minimumReadableLabelPx/o}},V0=t=>e=>{const n=xs(e)(t.interiors);if(n.tag==="Nothing")return t;if(n.tag==="Just")return n._1;g()},U0=t=>e=>n=>r=>({...r,fromCam:Vc(t)(e)(n)(r.fromCam),toCam:Vc(t)(e)(n)(r.toCam)}),K0=t=>e=>n=>r=>i=>o=>{if(i.tag==="Nothing")return o.zoom;if(i.tag==="Just")return pn(0)(O0(e)(n)(o)((()=>{const u=t.padding*r.placement.scale;return{x:i._1.x-u,y:i._1.y-u,w:i._1.w+u*2,h:i._1.h+u*2}})()));g()},j0=t=>e=>n=>r=>i=>o=>{const u=Js(t)(e)(n)(r)(o);return u<=0?o:{...o,zoom:ki(o.zoom*t.minimumReadableLabelPx/u)(K0(t)(e)(n)(r)(i)(o))}},Z0=t=>{if(t.when.tag==="First")return[];if(t.when.tag==="At")return[];if(t.when.tag==="After")return[t.when._1];if(t.when.tag==="With")return[t.when._1];g()},pg={id:"",nodes:D,edges:D,kind:vi},tp=t=>e=>wh((()=>{const n=Hr(e.from)(t);if(n.tag==="Nothing")return pg;if(n.tag==="Just")return n._1;g()})())((()=>{const n=Hr(e.to)(t);if(n.tag==="Nothing")return pg;if(n.tag==="Just")return n._1;g()})()),ep=t=>e=>{const n=xs(e)(t.interiors);if(n.tag==="Nothing")return{layout:t.layout,interiors:D};if(n.tag==="Just")return n._1;g()},ws=t=>e=>n=>r=>{const i=Ao(r)(n.edges);if(i.tag==="Just")return t<=0?e:pn(e)(mo(i._1)/t);if(i.tag==="Nothing")return e;g()},mg=t=>e=>n=>r=>i=>{const o=t.plop,u=tp(n)(i),s=H(_=>({startT:0,endT:0+ws(t.edgeSpeed)(t.minEdgeDuration)(e)(_),target:qr("EdgeWindow",_,ms("Extend",ug))}))(Or(u.entering.edges)),a=H(_=>({startT:0,endT:o,target:qr("NodeWindow",_,dg)}))(Or(u.entering.nodes)),c=w(pn)(0)(H(_=>ws(t.edgeSpeed)(t.minEdgeDuration)(e)(_))(Or(u.leaving.edges))),f=_=>qe(h=>{const p=Ao(h)(r);if(p.tag==="Just")return p._1.source===_||p._1.target===_;if(p.tag==="Nothing")return!1;g()},Or(u.leaving.edges))?c:0,d=H(_=>({startT:f(_),endT:f(_)+t.plop,target:qr("NodeWindow",_,P0)}))(Or(u.leaving.nodes)),l=H(_=>({startT:0,endT:ws(t.edgeSpeed)(t.minEdgeDuration)(e)(_),target:qr("EdgeWindow",_,ms("Retract",q0(r)(u.leaving.nodes)(_)))}))(Or(u.leaving.edges));return{duration:(()=>{const _=Et(rt.compare)([...H(p=>p.endT)(l),...H(p=>p.endT)(d),...H(p=>p.endT)(a),...H(p=>p.endT)(s)]),h=_.length-1|0;return h>=0&&h<_.length?_[h]+t.gap:t.gap})(),windows:[...l,...d,...a,...s]}},np=t=>e=>n=>r=>i=>o=>H((()=>{const u=i.startT;return s=>({...s,startT:s.startT+u,endT:s.endT+u})})())(mg(t)(e)(n)(r)(o).windows),rp=t=>xt(e=>At(Qr,e).length>1?T("Just",(()=>{const n=Mt(r=>J,r=>i=>T("Just",{head:r,tail:i}),At(Qr,e));if(n.tag==="Just")return n._1.head;if(n.tag==="Nothing")return"";g()})()):J)(Wd(fi)(Et(G.compare)(t))),ip=t=>{const e=H(r=>r.id)(t),n=k0(e);return[...H(C0)(rp(e)),...H(G0)(ut(r=>!Ns(r)(n),Tt(t)(Z0)))]},op=t=>{const e=gg(H(r=>L(r.id,(()=>{if(r.when.tag==="First")return[];if(r.when.tag==="At")return[];if(r.when.tag==="After")return[r.when._1];if(r.when.tag==="With")return[r.when._1];g()})()))(t)),n=r=>i=>o=>{if(Ns(o)(i))return[ur("ScheduleCycle",[...At($e.foldr,i),o])];if(Ns(o)(r))return[];const u=_g(o)(e);if(u.tag==="Nothing")return[];if(u.tag==="Just")return Tt(u._1)(n(Z(G)(o)()(r))(Z(G)(o)()(i)));g()};return Tt(t)(r=>n(D)(D)(r.id))},up={plop:.5,gap:.5,edgeSpeed:350,minEdgeDuration:.3,tokenSpeed:250,minTokenDuration:1.8,tokenHold:.5,stillHold:1.8,hatchHold:.4,tokenReadSecPerChar:.06,nodeEasing:Ah,edgeEasing:Ph,tokenEasing:_s,diveDur:1.2,retreatDur:1.2},sp=t=>e=>n=>r=>H((()=>{const i=n.startT;return o=>({...o,startT:o.startT+i,endT:o.endT+i})})())(xt(z0)(hg(t)(e)(r.events))),ap=t=>e=>n=>r=>i=>{if(i.scene.tag==="Structural")return np(t)(e)(n)(r)(i)(i.scene._1);if(i.scene.tag==="Hold")return[];if(i.scene.tag==="DataFlow")return sp(t)(e)(i)(i.scene._1);if(i.scene.tag==="EnterNode")return[];if(i.scene.tag==="ExitNode")return[];g()},cp=t=>e=>n=>{const r=hg(t)(e)(n.events);return r.length===0?t.gap:w(pn)(0)(H(i=>i.endT)(r))+t.gap},gp=t=>e=>n=>r=>i=>{if(i.tag==="Structural")return mg(t)(e)(n)(r)(i._1).duration;if(i.tag==="Hold")return t.stillHold;if(i.tag==="DataFlow")return cp(t)(e)(i._1);if(i.tag==="EnterNode"||i.tag==="ExitNode")return 0;g()},yg=t=>e=>n=>r=>i=>o=>{const u=ch(e)(r),s=n.layout,a=Bc(H(p=>L(p.id,p))(i.keyframes)),c=0<i.keyframes.length?T("Just",i.keyframes[0]):J,f=(()=>{if(c.tag==="Just")return c._1.id;if(c.tag==="Nothing")return"";g()})(),d=Ch(i),l=p=>({segments:p.runSpans.length===0?p.segments:Dt(p.segments)({startT:p.runStart,endT:p.t,path:r,layout:s,placement:u,windows:p.runWindows,spans:p.runSpans,keyframes:a,initialKeyframe:f,edgeEndpoints:d}),spans:p.spans,windows:p.windows,dives:p.dives}),_=w(p=>m=>{if(m.tag==="EnterNode"){const v=l(p),b=p.t+t.diveDur,k=Dt(r)(m._1),E=yg(t)(e)(ep(n)(m._1))(k)(V0(i)(m._1))(b),A=E.endT+t.retreatDur;return{...p,t:A,runStart:A,runSpans:[],runWindows:[],segments:[...v.segments,...E.segments],spans:[...v.spans,...E.spans],windows:[...v.windows,...E.windows],dives:[...v.dives,{startT:p.t,endT:b,node:m._1,parentPath:r,childPath:k,direction:A0},...E.dives,{startT:E.endT,endT:A,node:m._1,parentPath:r,childPath:k,direction:I0}]}}if(m.tag==="ExitNode")return p;const y=p.t+gp(t)(s)(a)(d)(m),x={startT:p.t,endT:y,scene:m},N=ap(t)(s)(a)(d)(x);return{...p,t:y,runSpans:Dt(p.runSpans)(x),runWindows:[...p.runWindows,...N],spans:Dt(p.spans)(x),windows:[...p.windows,...N]}})({t:o,runStart:o,runSpans:[],runWindows:[],segments:[],spans:[],windows:[],dives:[]})(i.scenes),h=l(_);return{endT:_.t,spans:h.spans,windows:Et(p=>m=>rt.compare(p.startT)(m.startT))(h.windows),segments:h.segments,dives:h.dives}},fp=t=>e=>n=>n.endT<=t||n.startT>=e?J:T("Just",{...n,startT:pn(t)(n.startT),endT:ki(e)(n.endT)}),Ts=t=>e=>n=>r=>i=>o=>xt(fp(o.startT)(o.endT))(H(U0(n)(o.layout)(o.placement))(R0(t)(e)(r)(o.edgeEndpoints)(i)(o))),vs=t=>e=>n=>r=>lh(t)(e)(n)(r.layout)(r.placement)((()=>{if(r.layout.nodes.tag==="Leaf")return 0;if(r.layout.nodes.tag==="Node")return r.layout.nodes._2;g()})()).camera,_p=t=>e=>n=>r=>r.placement.scale===1&&r.placement.tx===0&&r.placement.ty===0?Xh(r.placement)(bo(t)(r.layout)(Ne(r.layout))(0)):vs(t)(e)(n)(r),xg=t=>e=>n=>r=>i=>{const o=Jo(n)(i);return(()=>{const u=Ne(r.layout),s=u.x*r.placement.scale+r.placement.tx,a=u.y*r.placement.scale+r.placement.ty;return s>=o.x&&a>=o.y&&s+u.w*r.placement.scale<=o.x+o.w&&a+u.h*r.placement.scale<=o.y+o.h})()&&Js(t)(e)(n)(r)(i)>=t.minimumReadableLabelPx},bs=t=>e=>n=>r=>i=>o=>xg(t)(e)(n)(r)(o)?o:j0(t)(e)(n)(r)(i)(o),dp=t=>e=>{if(e.tag==="Structural")return xt(n=>n)([Io(e._1.from)(t)?J:T("Just",ur("UnknownKeyframe",e._1.from)),Io(e._1.to)(t)?J:T("Just",ur("UnknownKeyframe",e._1.to))]);if(e.tag==="Hold")return xt(n=>n)([Io(e._1)(t)?J:T("Just",ur("UnknownKeyframe",e._1))]);if(e.tag==="DataFlow")return[...xt(n=>n)([Io(e._1.keyframe)(t)?J:T("Just",ur("UnknownKeyframe",e._1.keyframe))]),...ip(e._1.events),...op(e._1.events)];if(e.tag==="EnterNode")return[];if(e.tag==="ExitNode")return[];g()},lp=t=>e=>{const n=Tt(e)(dp(t));return n.length===0?Gt("Right",void 0):Gt("Left",n)},Ls=t=>e=>n=>r=>i=>o=>xg(t)(e)(n)(r)(i)?i:Y0(t)(e)(n)(r)(o),hp=t=>e=>{const n=Mt(r=>J,r=>i=>T("Just",{head:r,tail:i}),e);if(n.tag==="Nothing")return[];if(n.tag==="Just")return[{...n._1.head,fromCam:t},...n._1.tail];g()},pp=t=>e=>{const n=e.fromCam.zoom===e.toCam.zoom&&e.fromCam.center.x===e.toCam.center.x&&e.fromCam.center.y===e.toCam.center.y?(e.startT+e.endT)/2:e.endT+1e-4,r=xt(i=>i.target.tag==="TokenWindow"?T("Just",qc(t.layout)(t.edgeEndpoints)(i.target._2)):i.target.tag==="FillWindow"?T("Just",fs(t.layout)(t.edgeEndpoints)(Ot("Node",1,1,i.target._2,void 0,D,D))):J)(ut(i=>i.startT<=n&&n<i.endT,t.windows));return r.length===0?J:T("Just",(()=>{const i=vr(r);return{x:i.x*t.placement.scale+t.placement.tx,y:i.y*t.placement.scale+t.placement.ty,w:i.w*t.placement.scale,h:i.h*t.placement.scale}})())},Ng=t=>e=>n=>r=>i=>o=>{const u=i(o.fromCam),s=i(o.toCam),a=pp(r)(o);return u.zoom===s.zoom&&u.center.x===s.center.x&&u.center.y===s.center.y?{...o,fromCam:bs(t)(e)(n)(r)(a)(u),toCam:bs(t)(e)(n)(r)(a)(s)}:{...o,fromCam:u,toCam:bs(t)(e)(n)(r)(a)(s)}},Jg=t=>e=>n=>r=>i=>o=>o.intent==="ActionFocus"?Ng(t)(e)(n)(r)(Ls(t)(e)(n)(r)(i))(o):{...o,fromCam:Ls(t)(e)(n)(r)(i)(o.fromCam),toCam:Ls(t)(e)(n)(r)(i)(o.toCam)},wg=t=>e=>n=>r=>i=>o=>{const u=Vt(s=>s.intent==="ActionFocus"&&yn(s.startT-r.startT)<1e-4)(o);if(u.tag==="Just"){const s=Jg(t)(e)(n)(r)(i)(u._1).toCam;return s.zoom<i.zoom?{...i,zoom:s.zoom}:i}if(u.tag==="Nothing")return i;g()},mp=t=>e=>n=>r=>i=>wg(t)(e)(n)(r)(vs(t)(e)(n)(r))(i),yp=t=>e=>n=>r=>i=>xt(o=>{const u=B0(i)(o.parentPath)(o.startT)(o.endT);if(u.tag==="Just"){const s=o.childPath,a=Vt(c=>ys(c.path)(s))(i.segments);if(a.tag==="Just"){const c=_p(t)(e)(n)(u._1),f=mp(t)(e)(n)(a._1)(Ts(t)(e)(n)(r)(i)(a._1));if(o.direction==="DiveIn")return T("Just",{startT:o.startT,endT:o.endT,fromCam:c,toCam:f,easing:rr,interp:Xc,intent:Yc});if(o.direction==="DiveOut")return T("Just",{startT:o.startT,endT:o.endT,fromCam:f,toCam:c,easing:rr,interp:Xc,intent:Yc});g()}if(a.tag==="Nothing")return J;g()}if(u.tag==="Nothing")return J;g()})(i.dives),xp=t=>e=>n=>r=>i=>i.intent==="ActionFocus"?Ng(t)(e)(n)(r)(E0)(i):i,Np=t=>e=>n=>r=>i=>Et(o=>u=>rt.compare(o.startT)(u.startT))(Tt(i.segments)(o=>{if(o.placement.scale===1&&o.placement.tx===0&&o.placement.ty===0)return lg(H(xp(t)(e)(n)(o))(Ts(t)(e)(n)(r)(i)(o)));const u=Ts(t)(e)(n)(r)(i)(o),s=vs(t)(e)(n)(o),a=wg(t)(e)(n)(o)(s)(u);return u.length===0?[{startT:o.startT,endT:o.endT,fromCam:a,toCam:a,easing:_s,interp:vo,intent:Bh}]:lg(hp(a)(H(Jg(t)(e)(n)(o)(s))(u)))})),Tg=t=>e=>n=>r=>i=>[...yp(t)(e)(n)(r)(i),...Np(t)(e)(n)(r)(i)],Jp=t=>e=>n=>r=>{if(0<n.keyframes.length){const i=n.keyframes[0],o=Bc(H(s=>L(s.id,s))(n.keyframes)),u=lp(o)(n.scenes);return(()=>{if(u.tag==="Left"){const s=u._1;return a=>Gt("Left",s)}if(u.tag==="Right"){const s=u._1;return a=>a(s)}g()})()(()=>{const s=yg(e)(r)(r)([])(n)(0);return Gt("Right",{totalDuration:s.endT,windows:s.windows,spans:s.spans,keyframes:o,initialKeyframe:i.id,timing:e,layout:r.layout,cameraSpans:Tg(t)(Zh)(r.layout)(o)(s),cameraConfig:t,levelTree:r,segments:s.segments,dives:s.dives,seed:n.seed})})}return Gt("Left",[S0])},wp=t=>e=>({...e,cameraSpans:Tg(e.cameraConfig)(t)(e.layout)(e.keyframes)({endT:e.totalDuration,spans:e.spans,windows:e.windows,segments:e.segments,dives:e.dives})}),ks=t=>t,vg=te(G)(Bt),Ei={eq:Bu(fi)},Es=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},zn=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},bg=Bt.foldMap(Bl(G)),Tp=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},vp=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),$r=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},bp=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Lp=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},kp=te(G)(Bt),Ep=te(G)(Bt),Sp=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},Lg=ks("Backdrop"),Cp=ks("FlyThrough"),Qo=ks("Active"),Gp=t=>e=>n=>({...n,state:{...n.state,edgeFadeAlpha:vg(H(r=>L(r,e))(t))}}),kg=t=>e=>n=>{const r=(t+e)/2,i=n-r,o=i<0?-1:1,u=(e-t)/2,s=u*.15,a=u-s,c=i<0?-i:i;return e<=t?(t+e)/2:c<=a?n:r+o*(u-s*zr(-(c-a)/s))},Do=t=>e=>n=>{const r=Vt(i=>Ei.eq(i.path)(e)&&n>=i.startT&&n<i.endT)(t.segments);if(r.tag==="Just")return T("Just",r._1);if(r.tag==="Nothing")return Vt(i=>Ei.eq(i.path)(e))(t.segments);g()},Pp=t=>({startT:0,endT:t.totalDuration,path:[],layout:t.layout,placement:ss,windows:t.windows,spans:t.spans,keyframes:t.keyframes,initialKeyframe:t.initialKeyframe,edgeEndpoints:D}),Ap=t=>H(e=>e<1?[]:kt(0,e,t))(zt(0,t.length-1|0)),Ss=t=>e=>{const n=Es(e)(t.keyframes);if(n.tag==="Nothing")return D;if(n.tag==="Just")return n._1.nodes;g()},Cs=t=>e=>{const n=Es(e)(t.keyframes);if(n.tag==="Nothing")return D;if(n.tag==="Just")return n._1.edges;g()},Fo=t=>e=>{if(e<t.startT)return br("AtKeyframe",t.initialKeyframe);const n=Vt(r=>e>=r.startT&&e<r.endT)(t.spans);if(n.tag==="Just"){if(n._1.scene.tag==="Structural")return br("InTransition",n._1.scene._1.from,n._1.scene._1.to);if(n._1.scene.tag==="DataFlow")return br("AtKeyframe",n._1.scene._1.keyframe);if(n._1.scene.tag==="Hold")return br("AtKeyframe",n._1.scene._1);if(n._1.scene.tag==="EnterNode"||n._1.scene.tag==="ExitNode")return br("AtKeyframe",t.initialKeyframe);g()}if(n.tag==="Nothing"){const r=t.spans.length-1|0;return r>=0&&r<t.spans.length?br("AtKeyframe",(()=>{if(t.spans[r].scene.tag==="Structural")return t.spans[r].scene._1.to;if(t.spans[r].scene.tag==="DataFlow")return t.spans[r].scene._1.keyframe;if(t.spans[r].scene.tag==="Hold")return t.spans[r].scene._1;if(t.spans[r].scene.tag==="EnterNode"||t.spans[r].scene.tag==="ExitNode")return t.initialKeyframe;g()})()):br("AtKeyframe",t.initialKeyframe)}g()},Ip=w(t=>e=>{const n=pr(t);return n.tag==="Just"&&e.startT<=n._1.last.endT+1e-6?Dt(n._1.init)({...n._1.last,endT:zn(n._1.last.endT)(e.endT),windows:Dt(n._1.last.windows)(e)}):Dt(t)({endT:e.endT,windows:[e]})})([]),Qp=t=>e=>n=>bg(r=>bg(i=>i.target.tag==="FillWindow"?i.startT<=n?Ot("Node",1,1,i.target._2,void 0,D,D):D:i.target.tag==="TokenWindow"&&i.startT+(i.endT-i.startT)*.25<=n?Ot("Node",1,1,i.target._4,void 0,D,D):D)(r.windows))(ut(r=>n<=r.endT+t,Ip(Et(r=>i=>rt.compare(r.startT)(i.startT))(ut(r=>r.target.tag==="FillWindow"||r.target.tag==="TokenWindow",e))))),Dp=t=>e=>n=>qe(r=>r.endT<=e&&r.target.tag==="EdgeWindow"&&r.target._2.tag==="Retract"&&r.target._1===n,t),Fp=t=>e=>n=>qe(r=>r.endT<=e&&r.target.tag==="NodeWindow"&&r.target._2==="PlopOut"&&r.target._1===n,t),zp=t=>e=>n=>qe(r=>r.startT>e&&r.target.tag==="NodeWindow"&&r.target._2==="PlopIn"&&r.target._1===n,t),Bp=t=>e=>n=>qe(r=>r.startT>e&&r.target.tag==="EdgeWindow"&&r.target._2.tag==="Extend"&&r.target._1===n,t),Mp=t=>e=>{const n=Fo(t)(e);if(n.tag==="AtKeyframe")return Je(3)(n._1)==="kf-"?"":n._1;if(n.tag==="InTransition")return Je(3)(n._2)==="kf-"?"":n._2;g()},Wp=t=>e=>{const n=Fo(t)(e),r=Es((()=>{if(n.tag==="AtKeyframe")return n._1;if(n.tag==="InTransition")return n._2;g()})())(t.keyframes);if(r.tag==="Just")return r._1.kind;if(r.tag==="Nothing")return vi;g()},Eg=t=>e=>n=>Vt(r=>n(r)&&e>=r.startT&&e<r.endT)(t),Rp={segment:{startT:0,endT:0,path:[],layout:{nodes:D,edges:D,chipExtras:D,edgeLabels:D},placement:ss,windows:[],spans:[],keyframes:D,initialKeyframe:"",edgeEndpoints:D},state:{nodes:D,edges:D,tokens:D,camera:{center:{x:0,y:0},zoom:1},frameTitle:"",staticKind:vi,visited:D,nodeFadeAlpha:D,nodeLabelFadeAlpha:D,edgeFadeAlpha:D,nodeInvert:D},bgAlpha:1,blur:0,minis:[],role:Qo},zo=t=>{const e=t.levels.length-1|0;return e>=0&&e<t.levels.length?t.levels[e]:Rp},qp=t=>e=>{const n=Tp(e)(t.nodes);if(n.tag==="Nothing")return[];if(n.tag==="Just"){const r=n._1,i=o=>o.x>=r.x-1&&o.x<=r.x+r.w+1&&o.y>=r.y-1&&o.y<=r.y+r.h+1;return xt(o=>(()=>{if(0<o._2.length){const s=o._2.length-1|0;return i(o._2[0])||s>=0&&s<o._2.length&&i(o._2[s])}const u=o._2.length-1|0;return u>=0&&u<o._2.length&&i(o._2[u])})()?T("Just",o._1):J)(vp(t.edges))}g()},Hp=t=>e=>{const n=Fo(t)(e);if(n.tag==="AtKeyframe")return Ss(t)(n._1);if(n.tag==="InTransition")return Ge(G.compare,Se,Ss(t)(n._1),Ss(t)(n._2));g()},Op=t=>e=>{const n=Fo(t)(e);if(n.tag==="AtKeyframe")return Cs(t)(n._1);if(n.tag==="InTransition")return Ge(G.compare,Se,Cs(t)(n._1),Cs(t)(n._2));g()},$p=t=>e=>n=>{const r=Ne(t),i=r.h/zn(1e-4)(n.zoom),o=r.w/zn(1e-4)(n.zoom);return{...n,center:{x:o>=e.w?e.x+e.w/2:kg(e.x+o/2)(e.x+e.w-o/2)(n.center.x),y:i>=e.h?e.y+e.h/2:kg(e.y+i/2)(e.y+e.h-i/2)(n.center.y)}}},Xp=t=>e=>n=>$p(t)((()=>{const r=e*n.placement.scale,i=Ne(n.layout),o=(()=>{const u=i.x*n.placement.scale+n.placement.tx,s=i.y*n.placement.scale+n.placement.ty;return{x:u,y:s,w:(i.x+i.w)*n.placement.scale+n.placement.tx-u,h:(i.y+i.h)*n.placement.scale+n.placement.ty-s}})();return{x:o.x-r,y:o.y-r,w:o.w+r*2,h:o.h+r*2}})()),Yp=t=>e=>{const n=t.endT-t.startT;return n<=0?1:zn(0)($r(1)((e-t.startT)/n))},Bo=t=>e=>{const n=t.endT-t.startT;return n<=0?1:zn(0)($r(1)((e-t.startT)/n))},Vp=t=>e=>n=>r=>i=>{const o=Eg(e)(n)(u=>u.target.tag==="EdgeWindow"&&u.target._1===i);if(o.tag==="Just"){const u=Fn(t.timing.edgeEasing)(Bo(o._1)(n)),s=o._1.target.tag==="EdgeWindow"?o._1.target._2:ms("Extend",ug);if(s.tag==="Retract")return Co("Retracting",s._1,u);if(s.tag==="Extend")return Co("Extending",s._1,u);g()}if(o.tag==="Nothing")return Bp(e)(n)(i)||Dp(e)(n)(i)?sg:bp(i)(r)?L0:sg;g()},Up=t=>e=>n=>{const r=Op(e)(n);return vg(H(i=>L(i,Vp(t)(e.windows)(n)(r)(i)))((()=>{const i=o=>{if(o.tag==="Leaf")return D;if(o.tag==="Node")return Ot("Node",o._1,o._2,o._3,void 0,i(o._5),i(o._6));g()};return At($e.foldr,i(e.layout.edges))})()))},Kp=t=>e=>n=>r=>{const i=Eg(t)(e)(o=>o.target.tag==="NodeWindow"&&o.target._1===r);if(i.tag==="Just"){const o=Bo(i._1)(e),u=i._1.target.tag==="NodeWindow"?i._1.target._2:dg;if(u==="PlopIn")return Go("PloppingIn",o);if(u==="PlopOut")return Go("PloppingOut",o);g()}if(i.tag==="Nothing")return zp(t)(e)(r)||Fp(t)(e)(r)?og:Lp(r)(n)?b0:og;g()},jp=t=>e=>n=>{const r=Hp(e)(n);return kp(H(i=>L(i,Kp(e.windows)(n)(r)(i)))((()=>{const i=o=>{if(o.tag==="Leaf")return D;if(o.tag==="Node")return Ot("Node",o._1,o._2,o._3,void 0,i(o._5),i(o._6));g()};return At($e.foldr,i(e.layout.nodes))})()))},Zp=t=>e=>n=>e.target.tag==="TokenWindow"?L(e.target._1,n<e.startT?ps:n>=e.endT?rg:Po("Travelling",{edge:e.target._2,direction:e.target._3,progress:Fn(t.timing.tokenEasing)(Bo(e)(n)),labels:e.target._6,source:e.target._4,target:e.target._5,holdPre:e.target._7,holdPost:e.target._8})):e.target.tag==="FillWindow"?L(e.target._1,n<e.startT?ps:n>=e.endT?rg:Po("Filling",{node:e.target._2,progress:Bo(e)(n),labels:e.target._3})):L("",ps),tm=t=>e=>n=>Ep(H(r=>Zp(t)(r)(n))(ut(r=>r.target.tag==="TokenWindow"||r.target.tag==="FillWindow",e))),em=t=>e=>n=>({nodes:jp()(e)(n),edges:Up(t)(e)(n),tokens:tm(t)(e.windows)(n),camera:Kc(t.cameraConfig)(e.layout)(t.cameraSpans)(n).camera,frameTitle:Mp(e)(n),staticKind:Wp(e)(n),visited:Qp(t.timing.hatchHold)(e.windows)(n),nodeFadeAlpha:D,nodeLabelFadeAlpha:D,edgeFadeAlpha:D,nodeInvert:D}),Xr=t=>e=>n=>r=>({segment:n,state:em(t)(n)(e),bgAlpha:1,blur:0,minis:nm(t)(e)(n),role:r}),nm=t=>e=>n=>xt(r=>{const i=Do(t)(Dt(n.path)(r))(e);if(i.tag==="Just")return T("Just",{...Xr(t)(Sp(i._1.startT)(i._1.endT-1e-4)(e))(i._1)(Lg),bgAlpha:0});if(i.tag==="Nothing")return J;g()})((()=>{const r=i=>{if(i.tag==="Leaf")return D;if(i.tag==="Node")return Ot("Node",i._1,i._2,i._3,void 0,r(i._5),r(i._6));g()};return At($e.foldr,r(n.layout.nodes))})()),rm=t=>e=>n=>uc(J,Za,r=>r.direction==="DiveIn"&&Ei.eq(r.parentPath)(e.path)&&n>=r.startT-.7&&n<r.startT?T("Just",{node:r.node,phase:(n-(r.startT-.7))/.7}):J,t.dives),im=t=>e=>n=>r=>{const i=rm(t)(e)(n);if(i.tag==="Just"){const o=Ve(3.141592653589793*i._1.phase*3);return{...r,state:{...r.state,nodeInvert:Ot("Node",1,1,i._1.node,1*o*o,D,D)}}}if(i.tag==="Nothing")return r;g()},Sg=t=>e=>xt(n=>{const r=Vt(i=>i.direction==="DiveIn"&&Ei.eq(i.childPath)((()=>{const o=n.length+1|0;return o<1?[]:kt(0,o,e)})()))(t.dives);if(r.tag==="Just"){const i=Do(t)(n)(r._1.startT-1e-4);if(i.tag==="Just")return T("Just",(()=>{const o=Xr(t)(r._1.startT-1e-4)(i._1)(Lg);return{...o,state:{...o.state,nodeFadeAlpha:Ot("Node",1,1,r._1.node,0,D,D)}}})());if(i.tag==="Nothing")return J;g()}if(r.tag==="Nothing")return J;g()})(Ap(e)),Cg=t=>e=>{const n=ut(i=>e>=i.startT&&e<i.endT,t.segments),r=n.length-1|0;return r>=0&&r<n.length?n[r]:Pp(t)},om=t=>e=>n=>{const r=Yp(n)(e),i=Do(t)(n.parentPath)((()=>{if(n.direction==="DiveIn")return n.startT-1e-4;if(n.direction==="DiveOut")return n.endT-1e-4;g()})()),o=Do(t)(n.childPath)((()=>{if(n.direction==="DiveIn")return n.endT;if(n.direction==="DiveOut")return n.startT-1e-4;g()})()),u=(()=>{if(n.direction==="DiveIn")return Fn(rr)(r);if(n.direction==="DiveOut")return 1-Fn(rr)(r);g()})(),s=1-zn(0)($r(1)((u-.1)/.25)),a=1-zn(0)($r(1)((u-.1)/.25)),c=1-zn(0)($r(1)((u-.8)/.2)),f=l=>{const _=Xr(t)((()=>{if(n.direction==="DiveIn")return n.startT-1e-4;if(n.direction==="DiveOut")return n.endT-1e-4;g()})())(l)(Cp);return{...Gp(qp(l.layout)(n.node))(a)({..._,state:{..._.state,nodeFadeAlpha:Ot("Node",1,1,n.node,s,D,D),nodeLabelFadeAlpha:Ot("Node",1,1,n.node,a,D,D)}}),minis:ut(h=>!Ei.eq(h.segment.path)(n.childPath),_.minis),bgAlpha:c}},d=0+1*zn(0)($r(1)((u-.1)/.5));return[...Sg(t)(n.parentPath),...(()=>{if(i.tag==="Just"){if(o.tag==="Just")return[f(i._1),{...Xr(t)((()=>{if(n.direction==="DiveIn")return n.endT;if(n.direction==="DiveOut")return n.startT-1e-4;g()})())(o._1)(Qo),bgAlpha:d}];if(o.tag==="Nothing")return[f(i._1)];g()}if(i.tag==="Nothing")return[Xr(t)(e)(Cg(t)(e))(Qo)];g()})()]},um=t=>e=>Vt(n=>e>=n.startT&&e<n.endT)(t.dives),sm=t=>e=>{const n=Cg(t)(e),r=Xr(t)(e)(n)(Qo),i=t.dives.length!==0,o=Kc(t.cameraConfig)(t.layout)(t.cameraSpans)(e).camera,u=Xp(t.layout)(t.cameraConfig.padding)(n)(o),s=im(t)(n)(e)({...r,state:{...r.state,camera:u}}),a=Sg(t)(n.path),c=um(t)(e);if(c.tag==="Just")return{levels:om(t)(e)(c._1),camera:o,rootLayout:t.layout,hasDives:i,diving:!0};if(c.tag==="Nothing")return{levels:Dt(a)(s),camera:u,rootLayout:t.layout,hasDives:i,diving:!1};g()},Gg=t=>t,Pg=Gg("RunText"),am=Gg("RunCode"),Ag=t=>e=>n=>e.length===0?n:Dt(n)({style:t,text:Nr(e)}),cm=t=>({style:(()=>{if(t.style==="RunText")return am;if(t.style==="RunCode")return Pg;g()})(),buf:[],runs:Ag(t.style)(t.buf)(t.runs)}),gm=t=>e=>0<e.length?{...t,buf:Dt(t.buf)(e[0])}:{...t,buf:Dt(t.buf)("\\")},fm=t=>e=>{let n=t,r=e,i=!0,o;for(;i;){const u=n,s=Mt(a=>J,a=>c=>T("Just",{head:a,tail:c}),r);if(s.tag==="Nothing"){i=!1,o=u;continue}if(s.tag==="Just"){if(s._1.head==="\\"){n=gm(u)(s._1.tail),r=kt(1,s._1.tail.length,s._1.tail);continue}if(s._1.head==="`"){n=cm(u),r=s._1.tail;continue}n={...u,buf:Dt(u.buf)(s._1.head)},r=s._1.tail;continue}g()}return o},Ig=t=>{const e=fm({style:Pg,buf:[],runs:[]})(Jr(t));return Ag(e.style)(e.buf)(e.runs)};let Gs=null;function _m(){return Gs||(typeof document>"u"?null:(Gs=document.createElement("canvas").getContext("2d"),Gs))}const Qg=new Map,dm=t=>e=>n=>r=>()=>{const i=`${n} ${e}px ${t}|${r}`,o=Qg.get(i);if(o!==void 0)return o;const u=_m();if(!u)return r.length*e*.62;u.font=`${n} ${e}px ${t}`;const s=u.measureText(r).width;return Qg.set(i,s),s},lm=lr.traverse(Du),hm=w(Mr)(0),Yr=(()=>{const t=or(`\r
3
+ `)(" "),e=or(`
4
+ `)(" "),n=(()=>{const r=or("\r")(" "),i=(()=>{const o=or(" ")(" ");return u=>o(r(u))})();return o=>i(e(o))})();return r=>n(t(r))})(),Dg=t=>e=>{const n=lm(r=>{const i=(()=>{if(r.style==="RunText")return t.text;if(r.style==="RunCode")return t.code;g()})();return dm(i.family)(i.size)(i.weight)(Yr(r.text))})(Ig(Yr(e)));return()=>{const r=n();return hm(r)}},Fg={text:{family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:11,weight:"500"},code:{family:"'CommitMono', ui-monospace, SFMono-Regular, Menlo, monospace",size:11,weight:"400"}},pm=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Vr=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},mm=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},ym=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},xm=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},zg=t=>Nr(ve(mr(e=>e===" ")(ve(mr(e=>e===" ")(Jr(t)).rest)).rest)),Nm=t=>w(e=>n=>n._1>0&&(n._2===" "||n._2==="-"||n._2==="_"||n._2===".")?T("Just",n._1):e)(J)(Ft(ln)(t)),Ps=t=>e=>{if(t<=0)return[e];if(tr(e)<=t)return[e];const n=Jr(e),r=t<1?[]:kt(0,t,n),i=Nm(r);if(i.tag==="Just"){const o=zg(bc(!(i._1>=0&&i._1<r.length)||r[i._1]===" "?i._1:i._1+1|0)(e)),u=zg(Ni(i._1+1|0)(e));return u===""?[o]:[o,...Ps(t)(u)]}if(i.tag==="Nothing"){const o=bc(t)(e),u=Ni(t)(e);return u===""?[o]:[o,...Ps(t)(u)]}g()},Jm={cellW:7,cellH:3,maxLineWidth:20},wm=t=>e=>{const n=H(o=>L((()=>{if(o.label.tag==="Just")return o.label._1;if(o.label.tag==="Nothing")return o.id;g()})(),o))(e.nodes),r=Vr(1)(An((mm(t.maxLineWidth)(w(o=>u=>Vr(o)(tr(u._1)))(0)(n))+2|0)+t.cellW|0,t.cellW)),i=(r*t.cellW|0)-1|0;return{...e,nodes:H(o=>{if(!(o._2.size._1===1&&o._2.size._2===1))return o._2;const u=Tt(Lo(`
5
+ `)(o._1))(Ps(i)),s=w(c=>f=>Vr(c)(tr(f)))(0)(u),a=o._2.shape==="Cylinder"?Vr(1)(An((s+2|0)+t.cellW|0,t.cellW)):r;return{...o._2,size:L(et(s>i?An((s+2|0)+t.cellW|0,t.cellW):a),et(Vr(1)(An(u.length+t.cellH|0,t.cellH))+(o._2.shape==="Cylinder"||o._2.shape==="Document"?1:0)|0))}})(n)}},Tm=t=>e=>n=>({...n,nodes:H(r=>{const i=xm(r.id)(e);if(i.tag==="Nothing")return r;if(i.tag==="Just")return{...r,size:L(ym(r.size._1)(et(Vr(1)(xe(no(r.shape==="Cylinder"?(i._1+0)/t:(i._1+32)/t))))),r.size._2)};g()})(n.nodes)}),vm=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},bm=t=>{const e=t.length;return(n=>r=>{let i=n,o=r,u=!0,s;for(;u;){const a=i,c=o;if(a>=e){u=!1,s=c;continue}const f=d=>l=>{let _=d,h=l,p=!0,m;for(;p;){const y=_,x=h;if(y>=e){p=!1,m=x;continue}if(a>=0&&a<t.length){if(y>=0&&y<t.length){_=y+1|0,h=(()=>{const N=t[a].position,v=t[a].size,b=t[y].position,k=t[y].size;return N._1<b._1+k._1&&b._1<N._1+v._1&&N._2<b._2+k._2&&b._2<N._2+v._2})()?x+1|0:x;continue}_=y+1|0,h=x;continue}p=!1,m=x}return m};i=a+1|0,o=f(a+1|0)(c)}return s})(0)(0)},Bg=t=>w(e=>n=>e+jl(n.start)(n.end))(0)(t.segments),Lm=t=>e=>n=>({crossingCount:w(r=>i=>r+i.jumps.length|0)(0)(e),bendCount:w(r=>i=>r+i.bends.length|0)(0)(e),totalEdgeLength:w(r=>i=>r+Bg(i))(0)(e),maxEdgeLength:w(r=>i=>vm(r)(Bg(i)))(0)(e),nodeOverlapCount:bm(t),constraintViolations:n,jumpCount:w(r=>i=>r+i.jumps.length|0)(0)(e)}),As=t=>t,jt=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Is=As("LEFT"),km=As("RIGHT"),Mg=As("UNDEFINED"),Em={eq:t=>e=>t==="LEFT"?e==="LEFT":t==="RIGHT"?e==="RIGHT":t==="UP"?e==="UP":t==="DOWN"?e==="DOWN":t==="UNDEFINED"&&e==="UNDEFINED"},Sm={compare:t=>e=>{if(t==="LEFT")return e==="LEFT"?Ie:me;if(e==="LEFT")return ye;if(t==="RIGHT")return e==="RIGHT"?Ie:me;if(e==="RIGHT")return ye;if(t==="UP")return e==="UP"?Ie:me;if(e==="UP")return ye;if(t==="DOWN")return e==="DOWN"?Ie:me;if(e==="DOWN")return ye;if(t==="UNDEFINED"&&e==="UNDEFINED")return Ie;g()},Eq0:()=>Em},Cm=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){if(t==="LEFT"){if(o._3==="LEFT"){r=!1,i=!0;continue}n=o._5;continue}if(o._3==="LEFT"){n=o._6;continue}if(t==="RIGHT"){if(o._3==="RIGHT"){r=!1,i=!0;continue}n=o._5;continue}if(o._3==="RIGHT"){n=o._6;continue}if(t==="UP"){if(o._3==="UP"){r=!1,i=!0;continue}n=o._5;continue}if(o._3==="UP"){n=o._6;continue}if(t==="DOWN"){if(o._3==="DOWN"){r=!1,i=!0;continue}n=o._5;continue}if(o._3==="DOWN"){n=o._6;continue}if(t==="UNDEFINED"&&o._3==="UNDEFINED"){r=!1,i=!0;continue}}g()}return i},Gm={x:0,y:0},je=t=>e=>n=>{const r=jt(t)(n.cNodes);if(r.tag==="Nothing")return n;if(r.tag==="Just")return{...n,cNodes:Z(nt)(t)(e(r._1))(n.cNodes)};g()},Si=t=>e=>n=>{const r=jt(t)(n.cGroups);if(r.tag==="Nothing")return n;if(r.tag==="Just")return{...n,cGroups:Z(nt)(t)(e(r._1))(n.cGroups)};g()},Pm=t=>w(e=>n=>je(n)(r=>({...r,hitboxPreCompaction:r.hitbox}))(e))(t)(t.cNodeOrder),Am=t=>{const e=w(n=>r=>{const i=jt(r)(t.cNodes);if(i.tag==="Nothing")return n;if(i.tag==="Just")return w(o=>u=>bt(nt)(ne)(u)([r])(o))(n)(i._1.constraints);g()})(D)(t.cNodeOrder);return w(n=>r=>je(r)(i=>({...i,constraints:(()=>{const o=jt(r)(e);if(o.tag==="Nothing")return[];if(o.tag==="Just")return o._1;g()})()}))(n))(t)(t.cNodeOrder)},Im=t=>e=>je(t)(n=>({...n,ignoreSpacing:{left:n.ignoreSpacing.left||e.left,right:n.ignoreSpacing.right||e.right,up:n.ignoreSpacing.up||e.up,down:n.ignoreSpacing.down||e.down}})),Qm=t=>{const e=w(n=>r=>Si(r)(i=>({...i,outDegree:i.outDegreeReal}))(n))(t)(t.cGroupOrder);return w(n=>r=>je(r)(i=>({...i,startPos:-1e308}))(n))(e)(e.cNodeOrder)},cn={left:!1,right:!1,up:!1,down:!1},Dm={horizontalSpacing:t=>e=>0,verticalSpacing:t=>e=>0},Qs=t=>w(e=>n=>{const r=jt(n)(e.cGroups);if(r.tag==="Nothing")return e;if(r.tag==="Just"){const i=w(u=>s=>{const a=jt(s)(e.cNodes);if(a.tag==="Nothing")return u;if(a.tag==="Just"){if(u.tag==="Nothing")return T("Just",s);if(u.tag==="Just"){const c=jt(u._1)(e.cNodes);if(c.tag==="Nothing")return T("Just",s);if(c.tag==="Just")return a._1.hitbox.x<c._1.hitbox.x?T("Just",s):T("Just",u._1)}}g()})(J)(r._1.cNodes),o=Si(n)(u=>({...u,reference:i}))(e);if(i.tag==="Nothing")return o;if(i.tag==="Just"){const u=jt(i._1)(o.cNodes);if(u.tag==="Nothing")return o;if(u.tag==="Just"){const s=u._1;return w(a=>c=>je(c)(f=>({...f,cGroupOffset:{x:f.hitbox.x-s.hitbox.x,y:f.hitbox.y-s.hitbox.y}}))(a))(o)(r._1.cNodes)}}}g()})(t)(t.cGroupOrder),Ze=t=>Qs({...t,cNodes:(()=>{const e=n=>{if(n.tag==="Leaf")return D;if(n.tag==="Node")return Ot("Node",n._1,n._2,n._3,{...n._4,hitbox:{...n._4.hitbox,x:-n._4.hitbox.x-n._4.hitbox.width}},e(n._5),e(n._6));g()};return e(t.cNodes)})()}),Tn=t=>Qs({...t,cNodes:(()=>{const e=n=>{if(n.tag==="Leaf")return D;if(n.tag==="Node")return Ot("Node",n._1,n._2,n._3,{...n._4,hitbox:{x:n._4.hitbox.y,y:n._4.hitbox.x,width:n._4.hitbox.height,height:n._4.hitbox.width},cGroupOffset:{x:n._4.cGroupOffset.y,y:n._4.cGroupOffset.x}},e(n._5),e(n._6));g()};return e(t.cNodes)})()}),Wg=t=>{const e=w(n=>r=>Si(r)(i=>({...i,outDegree:0,outDegreeReal:0,incomingConstraints:[]}))(n))(t)(t.cGroupOrder);return w(n=>r=>{const i=jt(r)(n.cNodes);if(i.tag==="Nothing")return n;if(i.tag==="Just"){if(i._1.cGroup.tag==="Nothing")return n;if(i._1.cGroup.tag==="Just"){const o=i._1.cGroup._1;return w(u=>s=>{const a=jt(s)(u.cNodes);if(a.tag==="Nothing")return u;if(a.tag==="Just")return a._1.cGroup.tag==="Just"&&a._1.cGroup._1!==o?Si(a._1.cGroup._1)(c=>({...c,outDegree:c.outDegree+1|0,outDegreeReal:c.outDegreeReal+1|0}))(Si(o)(c=>He(Dr)(s)(c.incomingConstraints)?c:{...c,incomingConstraints:[...c.incomingConstraints,s]})(u)):u;g()})(n)(i._1.constraints)}}g()})(e)(e.cNodeOrder)},Mo=t=>{const e=Am(t.cGraph);return{...t,cGraph:Wg(w(n=>r=>je(r)(i=>({...i,startPos:-1e308}))(n))(e)(e.cNodeOrder))}},Fm=t=>e=>w(n=>r=>{if(t==="LEFT"||t==="UP"){const o=r._2;return je(r._1)(u=>({...u,constraints:[...u.constraints,o]}))(n)}const i=r._1;return je(r._2)(o=>({...o,constraints:[...o.constraints,i]}))(n)})(e)(t==="LEFT"||t==="RIGHT"?e.predefinedHorizontalConstraints:e.predefinedVerticalConstraints),gn=t=>{const e={...t,cGraph:Fm(t.direction)({...t.cGraph,cNodes:(()=>{const n=r=>{if(r.tag==="Leaf")return D;if(r.tag==="Node")return Ot("Node",r._1,r._2,r._3,{...r._4,constraints:[]},n(r._5),n(r._6));g()};return n(t.cGraph.cNodes)})()})};return{...e,cGraph:Wg((()=>{if(e.constraintAlgorithm.tag==="Nothing")return e.cGraph;if(e.constraintAlgorithm.tag==="Just")return e.constraintAlgorithm._1(e);g()})())}},zm=t=>e=>n=>{const r={...n,direction:e};if(t==="UNDEFINED")return e==="LEFT"?gn(r):e==="RIGHT"?gn({...r,cGraph:Ze(r.cGraph)}):e==="UP"?gn({...r,cGraph:Tn(r.cGraph)}):e==="DOWN"?gn({...r,cGraph:Ze(Tn(r.cGraph))}):r;if(t==="LEFT")return e==="RIGHT"?Mo({...r,cGraph:Ze(r.cGraph)}):e==="UP"?gn({...r,cGraph:Tn(r.cGraph)}):e==="DOWN"?gn({...r,cGraph:Ze(Tn(r.cGraph))}):r;if(t==="RIGHT")return e==="LEFT"?Mo({...r,cGraph:Ze(r.cGraph)}):e==="UP"?gn({...r,cGraph:Tn(Ze(r.cGraph))}):e==="DOWN"?gn({...r,cGraph:Ze(Tn(Ze(r.cGraph)))}):r;if(t==="UP")return e==="LEFT"?gn({...r,cGraph:Tn(r.cGraph)}):e==="RIGHT"?gn({...r,cGraph:Ze(Tn(r.cGraph))}):e==="DOWN"?Mo({...r,cGraph:Ze(r.cGraph)}):r;if(t==="DOWN")return e==="LEFT"?gn({...r,cGraph:Tn(Ze(r.cGraph))}):e==="RIGHT"?gn({...r,cGraph:Ze(Tn(Ze(r.cGraph)))}):e==="UP"?Mo({...r,cGraph:Ze(r.cGraph)}):r;g()},Rg=t=>e=>e.finished||!Cm(t)(e.cGraph.supportedDirections)||(t==="LEFT"?e.direction==="LEFT":t==="RIGHT"?e.direction==="RIGHT":t==="UP"?e.direction==="UP":t==="DOWN"?e.direction==="DOWN":t==="UNDEFINED"&&e.direction==="UNDEFINED")?e:zm(e.direction)(t)(e),Bm=t=>{if(t.finished)return t;const e=t.direction==="UNDEFINED"?Rg(Is)(t):t,n={...e,cGraph:Qm(e.cGraph)};if(n.compactionAlgorithm.tag==="Nothing")return n;if(n.compactionAlgorithm.tag==="Just")return n.compactionAlgorithm._1(n);g()},qg=t=>e=>n=>{const r=jt(t)(n.cNodes),i=jt(e)(n.cGroups);return r.tag==="Just"&&i.tag==="Just"?(()=>{if(r._1.cGroup.tag==="Nothing")return!1;if(r._1.cGroup.tag==="Just")return!0;g()})()&&(r._1.cGroup.tag==="Nothing"||!(r._1.cGroup.tag==="Just"&&r._1.cGroup._1===e))?n:{...n,cNodes:Z(nt)(t)({...r._1,cGroup:T("Just",e)})(n.cNodes),cGroups:Z(nt)(e)({...i._1,cNodes:He(Dr)(t)(i._1.cNodes)?i._1.cNodes:[...i._1.cNodes,t],reference:(()=>{if(i._1.reference.tag==="Nothing")return T("Just",t);if(i._1.reference.tag==="Just")return T("Just",i._1.reference._1);g()})()})(n.cGroups)}:n},Hg=t=>e=>({id:e.nextCNodeId,graph:{...e,cNodes:Z(nt)(e.nextCNodeId)({id:e.nextCNodeId,origin:t.origin,kind:t.kind,cGroup:J,cGroupOffset:Gm,hitbox:t.hitbox,hitboxPreCompaction:t.hitbox,constraints:[],startPos:-1e308,ignoreSpacing:cn})(e.cNodes),cNodeOrder:[...e.cNodeOrder,e.nextCNodeId],nextCNodeId:e.nextCNodeId+1|0}}),Ds=t=>e=>{const n=e.nextCGroupId;return{id:n,graph:w(r=>i=>qg(i)(n)(r))({...e,cGroups:Z(nt)(n)({id:n,master:t.master,cNodes:[],startPos:-1e308,incomingConstraints:[],outDegree:0,outDegreeReal:0,reference:J,delta:0,deltaNormalized:0})(e.cGroups),cGroupOrder:[...e.cGroupOrder,n],nextCGroupId:n+1|0})(t.nodes)}},Mm=t=>w(e=>n=>{const r=jt(n)(e.cNodes);return r.tag==="Just"&&r._1.cGroup.tag==="Nothing"?Ds({master:J,nodes:[n]})(e).graph:e})(t)(t.cNodeOrder),Wm=t=>({cGraph:Pm(Mm(Qs(t))),direction:Mg,compactionAlgorithm:J,constraintAlgorithm:J,spacingsHandler:Dm,lockFun:J,finished:!1}),Rm=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},qm=t=>e=>{const n=rt.compare(t._1)(e._1);return n==="LT"?me:n==="GT"?ye:nt.compare(t._2)(e._2)},Hm=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),Og=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},$g=t=>t.kind.tag==="Nothing"?!1:t.kind.tag==="Just"&&t.kind._1==="vs",Xg=t=>t.kind.tag==="Nothing"||!(t.kind.tag==="Just"&&t.kind._1==="vs"),Wo=t=>e=>qm(L(t.hitbox.x+t.hitbox.width/2,t.id))(L(e.hitbox.x+e.hitbox.width/2,e.id)),Om=t=>e=>{const n=hr(Zt,J,r=>Wo(t)(r)==="LT",e);if(n.tag==="Just"){const r=sc(Zt,J,n._1,t,e);if(r.tag==="Nothing")return e;if(r.tag==="Just")return r._1;g()}if(n.tag==="Nothing")return Dt(e)(t);g()},Yg=t=>e=>{const n=ut(i=>Wo(i)(t)==="LT",e),r=n.length-1|0;return r>=0&&r<n.length?T("Just",n[r]):J},$m=t=>e=>{const n=Om(e)(t.intervals),r=Vt(o=>Wo(e)(o)==="LT")(n),i=Z(nt)(e.id)((()=>{const o=Yg(e)(n);return o.tag==="Just"?T("Just",o._1.id):J})())(t.cand);return{...t,intervals:n,cand:(()=>{if(r.tag==="Just")return Z(nt)(r._1.id)(T("Just",e.id))(i);if(r.tag==="Nothing")return i;g()})()}},Xm=t=>e=>{const n=rt.compare(t.low?t.node.hitbox.y:t.node.hitbox.y+t.node.hitbox.height)(e.low?e.node.hitbox.y:e.node.hitbox.y+e.node.hitbox.height);return n==="EQ"?t.low?t.low&&!e.low?ye:Ie:e.low?me:Ie:n},Ym=t=>w(e=>n=>je(n.id)(r=>({...r,constraints:[]}))(e))(t)(xt(e=>jt(e)(t.cNodes))(t.cNodeOrder)),Fs=t=>e=>w(n=>r=>{const i=jt(r._1)(n.cNodes);if(i.tag==="Just")return je(r._1)(o=>({...o,constraints:[...o.constraints,...r._2]}))(n);if(i.tag==="Nothing")return n;g()})(e)(Hm(t)),Vg=t=>e=>e.kind.tag!=="Nothing"&&e.kind.tag==="Just"&&e.kind._1==="vs"?e.ignoreSpacing.up?e.ignoreSpacing.down?e:{...e,hitbox:{...e.hitbox,height:e.hitbox.height+t+.01}}:{...e,hitbox:{...e.hitbox,y:e.hitbox.y-t-.01,height:e.hitbox.height+t+.01}}:{...e,hitbox:{...e.hitbox,y:e.hitbox.y-t,height:e.hitbox.height+2*t}},Ug=t=>e=>n=>w(r=>i=>n(i)?je(i.id)(Vg(t))(r):r)(e)(xt(r=>jt(r)(e.cNodes))(e.cNodeOrder)),Vm=t=>e=>{const n=(r,i,o)=>{const u=je(o)(Vg(t))(r);return i.length<=1?u:w(s=>a=>a===o?s:je(a)(c=>c.ignoreSpacing.up?{...c,hitbox:{...c.hitbox,y:c.hitbox.y+t+.01,height:c.hitbox.height-t-.01}}:c.ignoreSpacing.down?{...c,hitbox:{...c.hitbox,height:c.hitbox.height-t-.01}}:c)(s))(u)(i)};return w(r=>i=>{if(i.master.tag==="Nothing")return 0<i.cNodes.length?n(r,i.cNodes,i.cNodes[0]):r;if(i.master.tag==="Just")return n(r,i.cNodes,i.master._1);g()})(e)(xt(r=>jt(r)(e.cGroups))(e.cGroupOrder))},Um=t=>e=>{const n=Yg(e)(t.intervals),r=Vt(o=>Wo(e)(o)==="LT")(t.intervals),i=n.tag==="Just"&&(()=>{const o=Og(e.id)(t.cand);return(o.tag==="Nothing"?!1:o.tag==="Just"&&(o._1.tag==="Nothing"?!1:o._1.tag==="Just"&&o._1._1===n._1.id))&&n._1.cGroup.tag==="Just"&&e.cGroup.tag==="Just"&&n._1.cGroup._1!==e.cGroup._1})()?bt(nt)(ne)(n._1.id)([e.id])(t.constraints):t.constraints;return{...t,constraints:r.tag==="Just"&&(()=>{const o=Og(r._1.id)(t.cand);return(o.tag==="Nothing"?!1:o.tag==="Just"&&(o._1.tag==="Nothing"?!1:o._1.tag==="Just"&&o._1._1===e.id))&&e.cGroup.tag==="Just"&&r._1.cGroup.tag==="Just"&&e.cGroup._1!==r._1.cGroup._1})()?bt(nt)(ne)(e.id)([r._1.id])(i):i,intervals:ut(o=>o.id!==e.id,t.intervals)}},Km=t=>e=>e.low?$m(t)(e.node):Um(t)(e.node),zs=t=>e=>w(Km)({intervals:[],cand:D,constraints:D})(Et(Xm)(Tt(ut(t,xt(n=>jt(n)(e.cNodes))(e.cNodeOrder)))(n=>[{node:n,low:!0},{node:n,low:!1}]))).constraints,jm=t=>e=>{const n=Rm(0)(t/2-.5),r=Fs(zs($g)(Ug(n)(e)($g)))(e),i=Fs(zs(Xg)(Ug(n)(r)(Xg)))(r);return Fs(zs(o=>!0)(Vm(n)(i)))(i)},Zm=t=>e=>jm(t)(Ym(e.cGraph)),Ro=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Kg=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Bs=t=>e=>n=>r=>i=>({id:t,representedEdges:[i],affectedBends:[e,n],hitbox:{x:Ro(e._1)(n._1),y:Ro(e._2)(n._2),width:yn(e._1-n._1),height:yn(e._2-n._2)},ignoreSpacing:cn,potentialGroupParents:(()=>{if(r.tag==="Nothing")return[];if(r.tag==="Just")return[r._1];g()})(),aPort:J}),ty=t=>e=>{const n=Ro(t.hitbox.x)(e.hitbox.x),r=Ro(t.hitbox.y)(e.hitbox.y);return{...t,representedEdges:[...t.representedEdges,...e.representedEdges],affectedBends:[...t.affectedBends,...e.affectedBends],potentialGroupParents:[...t.potentialGroupParents,...e.potentialGroupParents],hitbox:{x:n,y:r,width:Kg(t.hitbox.x+t.hitbox.width)(e.hitbox.x+e.hitbox.width)-n,height:Kg(t.hitbox.y+t.hitbox.height)(e.hitbox.y+e.hitbox.height)-r},ignoreSpacing:{left:t.ignoreSpacing.left||e.ignoreSpacing.left,right:t.ignoreSpacing.right||e.ignoreSpacing.right,up:t.ignoreSpacing.up||e.ignoreSpacing.up,down:t.ignoreSpacing.down||e.ignoreSpacing.down},aPort:(()=>{if(t.aPort.tag==="Just")return t.aPort;if(t.aPort.tag==="Nothing")return e.aPort;g()})()}},ey=t=>e=>yn(t.hitbox.x-e.hitbox.x)<=1e-4&&e.hitbox.y-(t.hitbox.y+t.hitbox.height)<=1e-4&&t.hitbox.y-(e.hitbox.y+e.hitbox.height)<=1e-4,ny=t=>e=>yn(t.hitbox.x-e.hitbox.x)<=1e-4?rt.compare(t.hitbox.y)(e.hitbox.y):t.hitbox.x<e.hitbox.x?me:ye,jg=(t,e)=>({tag:t,_1:e}),Ms=te(G)(Bt),qo=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Zg=(()=>{const t={eq:n=>r=>n._1===r._1&&(n._2.tag==="Nothing"?r._2.tag==="Nothing":n._2.tag==="Just"&&r._2.tag==="Just"&&n._2._1===r._2._1)},e={compare:n=>r=>{const i=G.compare(n._1)(r._1);if(i==="LT")return me;if(i==="GT")return ye;if(n._2.tag==="Nothing")return r._2.tag==="Nothing"?Ie:me;if(r._2.tag==="Nothing")return ye;if(n._2.tag==="Just"&&r._2.tag==="Just")return G.compare(n._2._1)(r._2._1);g()},Eq0:()=>t};return w(n=>r=>Z(e)(r)()(n))(D)})(),Bn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},ry=w(t=>e=>Z(Sm)(e)()(t))(D),Ws=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=Sc.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},iy=t=>e=>{const n=Ms(H(o=>L(o.id,o))(t)),r=xt(o=>qo(o)(n))(e),i=nt.compare((()=>{const o=Zg(H(u=>L(u.from.node,u.from.port))(r));if(o.tag==="Leaf")return 0;if(o.tag==="Node")return o._2;g()})())((()=>{const o=Zg(H(u=>L(u.to.node,u.to.port))(r));if(o.tag==="Leaf")return 0;if(o.tag==="Node")return o._2;g()})());if(i==="LT")return{...cn,left:!0,right:!1};if(i==="GT")return{...cn,left:!1,right:!0};if(i==="EQ")return cn;g()},oy=t=>xt(e=>{if(e.direction==="V")return T("Just",{start:e.start,end:e.end});if(e.direction==="H")return J;g()})(t.segments),Ho=t=>e=>n=>r=>{if(r.tag==="Just"){const i=Bn(n)(e);if(i.tag==="Just"){const o=Vt(u=>u.id===r._1)(i._1);if(o.tag==="Just")return o._1.side;if(o.tag==="Nothing")return t;g()}if(i.tag==="Nothing")return t;g()}if(r.tag==="Nothing")return t;g()},uy=t=>e=>n=>{const r=Hg({origin:T("Just",jg("SegmentOrigin",n)),kind:T("Just","vs"),hitbox:n.hitbox})(e.cGraph),i=Im(r.id)(n.ignoreSpacing)(r.graph);return{...e,cGraph:(()=>{if(0<n.potentialGroupParents.length){const o=jt(n.potentialGroupParents[0])(i.cNodes);if(o.tag==="Just"){if(o._1.cGroup.tag==="Just")return qg(r.id)(o._1.cGroup._1)(i);if(o._1.cGroup.tag==="Nothing")return i;g()}if(o.tag==="Nothing")return i;g()}return Ds({master:T("Just",r.id),nodes:[r.id]})(i).graph})(),edgeToCs:w(o=>u=>bt(G)(ne)(u)([r.id])(o))(e.edgeToCs)(n.representedEdges),lockMap:Z(nt)(r.id)(iy(t)(n.representedEdges))(e.lockMap)}},sy=t=>e=>n=>{const r=Mt(i=>J,i=>o=>T("Just",{head:i,tail:o}),Et(ny)(e));if(r.tag==="Nothing")return n;if(r.tag==="Just"){const i=w(o=>u=>ey(o.survivor)(u)?{...o,survivor:ty(o.survivor)(u)}:{survivor:u,merged:[...o.merged,o.survivor]})({survivor:r._1.head,merged:[]})(r._1.tail);return w(uy(t))(n)([...i.merged,i.survivor])}g()},ay=t=>({cGraph:{cNodes:D,cNodeOrder:[],cGroups:D,cGroupOrder:[],supportedDirections:ry([Mg,Is,km]),predefinedHorizontalConstraints:[],predefinedVerticalConstraints:[],nextCNodeId:0,nextCGroupId:0},nodeToC:D,edgeToCs:D,lockMap:D}),cy=t=>{const e=et(4);return{x:t.position._1*e,y:t.position._2*e,width:t.size._1*e,height:t.size._2*e}},gy=t=>e=>n=>w(r=>i=>{const o=Hg({origin:T("Just",jg("NodeOrigin",i.node)),kind:J,hitbox:cy(i)})(r.cGraph),u=Bn(i.node)(t),s=(()=>{if(u.tag==="Nothing")return L(0,0);if(u.tag==="Just")return u._1;g()})();return{...r,cGraph:Ds({master:T("Just",o.id),nodes:[o.id]})(o.graph).graph,nodeToC:Z(G)(i.node)(o.id)(r.nodeToC),lockMap:Z(nt)(o.id)((()=>{const a=s._1-s._2|0;return a<0?{...cn,left:!0}:a>0?{...cn,right:!0}:cn})())(r.lockMap)}})(n)(e),fy=t=>w(e=>n=>bt(G)(r=>i=>L(r._1+i._1|0,r._2+i._2|0))(n.to.node)(L(1,0))(bt(G)(r=>i=>L(r._1+i._1|0,r._2+i._2|0))(n.from.node)(L(0,1))(e)))(D)(t),_y=t=>w(e=>n=>n.origin.tag==="Just"&&n.origin._1.tag==="NodeOrigin"?Z(G)(n.origin._1._1)(n.hitbox.x)(e):e)(D)(xt(e=>jt(e)(t.cNodes))(t.cNodeOrder)),dy=t=>w(e=>n=>n.origin.tag==="Just"&&n.origin._1.tag==="NodeOrigin"?Z(G)(n.origin._1._1)(n.hitbox.x-n.hitboxPreCompaction.x)(e):e)(D)(xt(e=>jt(e)(t.cNodes))(t.cNodeOrder)),ly=t=>w(e=>n=>{if(n.origin.tag==="Just"&&n.origin._1.tag==="SegmentOrigin"){const r=n.hitbox.x-n.hitboxPreCompaction.x;return w(i=>o=>Z(Sc)(o)(r)(i))(e)(n.origin._1._1.affectedBends)}return e})(D)(xt(e=>jt(e)(t.cNodes))(t.cNodeOrder)),tf=t=>{const e=Ms(H(n=>L(n.id,n))(t.edges));return xt(n=>{const r=qo(n.edge)(e);if(r.tag==="Just")return n.reversed?T("Just",{edgeId:n.edge,src:r._1.to.node,tgt:r._1.from.node,srcSide:Ho(Qn)(t.ports)(r._1.to.node)(r._1.to.port),tgtSide:Ho(Dn)(t.ports)(r._1.from.node)(r._1.from.port),path:n}):T("Just",{edgeId:n.edge,src:r._1.from.node,tgt:r._1.to.node,srcSide:Ho(Qn)(t.ports)(r._1.from.node)(r._1.from.port),tgtSide:Ho(Dn)(t.ports)(r._1.to.node)(r._1.to.port),path:n});if(r.tag==="Nothing")return J;g()})(t.paths)},hy=t=>e=>{const n=Tt(e)(r=>{if(r.src===r.tgt)return[];if((r.srcSide==="North"||r.srcSide==="South")&&(r.tgtSide==="North"||r.tgtSide==="South"))return[];const i=Bn(r.tgt)(t.nodeToC),o=(()=>{if(i.tag==="Just")return jt(i._1)(t.cGraph.cNodes);if(i.tag==="Nothing")return J;g()})(),u=Bn(r.src)(t.nodeToC),s=(()=>{if(u.tag==="Just")return jt(u._1)(t.cGraph.cNodes);if(u.tag==="Nothing")return J;g()})(),a=(()=>{if(s.tag==="Just"){if(o.tag==="Just"){if(s._1.cGroup.tag==="Just"){if(o._1.cGroup.tag==="Just")return T("Just",{srcGroup:s._1.cGroup._1,tgtGroup:o._1.cGroup._1,delta:0,weight:100});if(o._1.cGroup.tag==="Nothing")return J;g()}if(s._1.cGroup.tag==="Nothing")return J;g()}if(o.tag==="Nothing")return J;g()}if(s.tag==="Nothing")return J;g()})(),c=_=>h=>p=>{if(s.tag==="Just"){if(s._1.cGroup.tag==="Just"){if(p.cGroup.tag==="Just")return _(p.hitbox.x)&&p.cGroup._1!==s._1.cGroup._1?T("Just",h(p.cGroup._1)(s._1.cGroup._1)):J;if(p.cGroup.tag==="Nothing")return J;g()}if(s._1.cGroup.tag==="Nothing")return J;g()}if(s.tag==="Nothing")return J;g()},f=xt(_=>jt(_)(t.cGraph.cNodes))((()=>{const _=qo(r.edgeId)(t.edgeToCs);if(_.tag==="Nothing")return[];if(_.tag==="Just")return _._1;g()})()),d=(()=>{if(s.tag==="Just"&&r.srcSide==="West"){const _=s._1;return xt(c(h=>h<_.hitbox.x)(h=>p=>({srcGroup:h,tgtGroup:p,delta:1,weight:100})))(f)}return[]})(),l=(()=>{if(s.tag==="Just"&&r.tgtSide==="East"){const _=s._1;return xt(c(h=>h>_.hitbox.x)(h=>p=>({srcGroup:p,tgtGroup:h,delta:1,weight:100})))(f)}return[]})();if(a.tag==="Nothing")return[];if(a.tag==="Just")return[a._1,...d,...l];g()});return{sameEdgeVerticalSegments:r=>i=>r.origin.tag==="Just"&&r.origin._1.tag==="SegmentOrigin"&&i.origin.tag==="Just"&&i.origin._1.tag==="SegmentOrigin"&&(()=>{const o=i.origin._1._1;return qe(u=>He(hn)(u)(o.representedEdges),r.origin._1._1.representedEdges)})(),vsLNodePair:r=>i=>r.origin.tag==="Just"&&i.origin.tag==="Just"&&(r.origin._1.tag==="SegmentOrigin"?i.origin._1.tag==="NodeOrigin":r.origin._1.tag==="NodeOrigin"&&i.origin._1.tag==="SegmentOrigin"),edgeLengthEdges:r=>n}},py=t=>e=>{const n=et(4),r=_y(t),i=dy(t),o=Ms(H(s=>L(s.id,L(s.from.node,s.to.node)))(e.edges)),u=ly(t);return{nodes:H(s=>{const a=Bn(s.node)(r);if(a.tag==="Just")return{...s,position:L(a._1/n,s.position._2)};if(a.tag==="Nothing")return s;g()})(e.nodes),edges:H(s=>{const a=qo(s.edge)(o),c=(()=>{if(a.tag==="Nothing")return s.segments;if(a.tag==="Just"){const f=Bn(a._1._1)(i),d=(()=>{if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1;g()})(),l=Bn(a._1._2)(i),_=(()=>{if(l.tag==="Nothing")return 0;if(l.tag==="Just")return l._1;g()})();return Ft((()=>{const h=s.reversed?_:d,p=s.reversed?d:_,m=s.segments.length;return y=>x=>{if(x.direction==="V"){const N=(()=>{if(y===0)return h;if(y===(m-1|0))return p;const v=Ws(x.start)(u);if(v.tag==="Nothing")return 0;if(v.tag==="Just")return v._1;g()})();return{...x,start:L(x.start._1+N,x.start._2),end:L(x.end._1+N,x.end._2)}}if(x.direction==="H")return{...x,start:L((()=>{if(y===0)return x.start._1+h;const N=Ws(x.start)(u);if(N.tag==="Nothing")return x.start._1+0;if(N.tag==="Just")return x.start._1+N._1;g()})(),x.start._2),end:L((()=>{if(y===(m-1|0))return x.end._1+p;const N=Ws(x.end)(u);if(N.tag==="Nothing")return x.end._1+0;if(N.tag==="Just")return x.end._1+N._1;g()})(),x.end._2)};g()}})())(s.segments)}g()})();return{...s,segments:c,bends:be(f=>d=>f.end,c,kt(1,c.length,c))}})(e.paths)}},my=t=>e=>n=>r=>i=>o=>{const u=Bs(i.nextId)(o._2.start)(o._2.end)(J)(t.edgeId),s=(()=>{if(o._1===0){if(e.tag==="Nothing")return u;if(e.tag==="Just")return{...u,ignoreSpacing:o._2.end._2<e._1.y?{...u.ignoreSpacing,down:!0}:o._2.end._2>e._1.y+e._1.height?{...u.ignoreSpacing,up:!0}:{...u.ignoreSpacing,up:!0,down:!0}};g()}return u})();return{nextId:i.nextId+1|0,segments:[...i.segments,(()=>{if(o._1===r){if(n.tag==="Nothing")return s;if(n.tag==="Just")return{...s,ignoreSpacing:o._2.start._2<n._1.y?{...s.ignoreSpacing,down:!0}:o._2.start._2>n._1.y+n._1.height?{...s.ignoreSpacing,up:!0}:{...s.ignoreSpacing,up:!0,down:!0}};g()}return s})()]}},ef=t=>e=>n=>r=>i=>o=>({nextId:o.nextId+1|0,segments:[...o.segments,{...Bs(o.nextId)(r.start)(L(r.start._1,i.down?n.y:n.y+n.height))(T("Just",e))(t.edgeId),aPort:T("Just",{node:t.src,side:i.side}),ignoreSpacing:i.down?{...cn,down:!0}:{...cn,up:!0}}]}),Oo=t=>e=>n=>r=>i=>o=>({nextId:o.nextId+1|0,segments:[...o.segments,{...Bs(o.nextId)(r.end)(L(r.end._1,i.down?n.y:n.y+n.height))(T("Just",e))(t.edgeId),aPort:T("Just",{node:t.tgt,side:i.side}),ignoreSpacing:i.down?{...cn,down:!0}:{...cn,up:!0}}]}),yy=t=>e=>n=>{if(n.src===n.tgt)return e;const r=Bn(n.src)(t.nodeToC),i=Bn(n.tgt)(t.nodeToC),o=(()=>{if(r.tag==="Just"){const f=jt(r._1)(t.cGraph.cNodes);return f.tag==="Just"?T("Just",f._1.hitbox):J}if(r.tag==="Nothing")return J;g()})(),u=(()=>{if(i.tag==="Just"){const f=jt(i._1)(t.cGraph.cNodes);return f.tag==="Just"?T("Just",f._1.hitbox):J}if(i.tag==="Nothing")return J;g()})(),s=oy(n.path),a=w(my(n)(o)(u)(s.length-1|0))(e)(Ft(f=>d=>L(f,d))(s));if(0<s.length){const f=(()=>{if(r.tag==="Just"&&o.tag==="Just"){if(n.srcSide==="North")return ef(n)(r._1)(o._1)(s[0])({side:de,down:!0})(a);if(n.srcSide==="South")return ef(n)(r._1)(o._1)(s[0])({side:le,down:!1})(a)}return a})(),d=s.length-1|0;if(d>=0&&d<s.length&&i.tag==="Just"&&u.tag==="Just"){if(n.tgtSide==="North")return Oo(n)(i._1)(u._1)(s[d])({side:de,down:!0})(f);if(n.tgtSide==="South")return Oo(n)(i._1)(u._1)(s[d])({side:le,down:!1})(f)}return f}const c=s.length-1|0;if(c>=0&&c<s.length&&i.tag==="Just"&&u.tag==="Just"){if(n.tgtSide==="North")return Oo(n)(i._1)(u._1)(s[c])({side:de,down:!0})(a);if(n.tgtSide==="South")return Oo(n)(i._1)(u._1)(s[c])({side:le,down:!1})(a)}return a},xy=t=>e=>n=>sy(t)(w(yy(n))({nextId:0,segments:[]})(e).segments)(n),Ny=t=>xy(t.edges)(tf(t))(gy(fy(t.edges))(t.nodes)(ay())),Mn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Rs=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},qs=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Jy=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},wy=t=>{const e=t.Eq0();return n=>r=>{const i=s=>{let a=s,c=!0,f;for(;c;){const d=a,l=Mt(_=>J,_=>h=>T("Just",{head:_,tail:h}),d.queue);if(l.tag==="Nothing"){c=!1,f=d;continue}if(l.tag==="Just"){const _=l._1.head;if((p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=!1;continue}if(N.tag==="Node"){const v=t.compare(_)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=!0;continue}}g()}return x})(d.removedNodes)){a={...d,queue:l._1.tail};continue}const h=Vt(p=>!Mn(p.eid)(d.removedEdges)&&(e.eq(p.src)(_)||e.eq(p.tgt)(_)))(r);if(h.tag==="Nothing"){a={...d,queue:l._1.tail};continue}if(h.tag==="Just"){const p=e.eq(h._1.src)(_)?h._1.tgt:h._1.src,m={...d,degree:Z(t)(p)((()=>{const y=(x=>{let N=x,v=!0,b;for(;v;){const k=N;if(k.tag==="Leaf"){v=!1,b=J;continue}if(k.tag==="Node"){const E=t.compare(p)(k._3);if(E==="LT"){N=k._5;continue}if(E==="GT"){N=k._6;continue}if(E==="EQ"){v=!1,b=T("Just",k._4);continue}}g()}return b})(d.degree);if(y.tag==="Nothing")return-1;if(y.tag==="Just")return y._1-1|0;g()})())(d.degree),removedNodes:Z(t)(_)()(d.removedNodes),removedEdges:Z(nt)(h._1.eid)()(d.removedEdges),record:[...d.record,{node:_,neighbour:p,viaSrc:e.eq(h._1.src)(_)}],queue:l._1.tail};if((()=>{const y=(N=>{let v=N,b=!0,k;for(;b;){const E=v;if(E.tag==="Leaf"){b=!1,k=J;continue}if(E.tag==="Node"){const A=t.compare(p)(E._3);if(A==="LT"){v=E._5;continue}if(A==="GT"){v=E._6;continue}if(A==="EQ"){b=!1,k=T("Just",E._4);continue}}g()}return k})(m.degree),x=N=>{let v=N,b=!0,k;for(;b;){const E=v;if(E.tag==="Leaf"){b=!1,k=!1;continue}if(E.tag==="Node"){const A=t.compare(p)(E._3);if(A==="LT"){v=E._5;continue}if(A==="GT"){v=E._6;continue}if(A==="EQ"){b=!1,k=!0;continue}}g()}return k};return(()=>{if(y.tag==="Nothing")return!1;if(y.tag==="Just")return y._1===1;g()})()&&!x(m.removedNodes)})()){a={...m,queue:[...m.queue,p]};continue}a=m;continue}}g()}return f},o=w(s=>a=>bt(t)(se)(a.src)(1)(bt(t)(se)(a.tgt)(1)(s)))(D)(r),u=i({degree:o,removedNodes:D,removedEdges:D,record:[],queue:ut(s=>{const a=(c=>{let f=c,d=!0,l;for(;d;){const _=f;if(_.tag==="Leaf"){d=!1,l=J;continue}if(_.tag==="Node"){const h=t.compare(s)(_._3);if(h==="LT"){f=_._5;continue}if(h==="GT"){f=_._6;continue}if(h==="EQ"){d=!1,l=T("Just",_._4);continue}}g()}return l})(o);if(a.tag==="Nothing")return!1;if(a.tag==="Just")return a._1===1;g()},n)});return{coreNodes:ut(s=>!(a=>{let c=a,f=!0,d;for(;f;){const l=c;if(l.tag==="Leaf"){f=!1,d=!1;continue}if(l.tag==="Node"){const _=t.compare(s)(l._3);if(_==="LT"){c=l._5;continue}if(_==="GT"){c=l._6;continue}if(_==="EQ"){f=!1,d=!0;continue}}g()}return d})(u.removedNodes),n),coreEdges:ut(s=>!Mn(s.eid)(u.removedEdges),r),removed:u.record}}},Ty=t=>e=>n=>w(r=>i=>{const o=i.neighbour,u=(()=>{const s=(a=>{let c=a,f=!0,d;for(;f;){const l=c;if(l.tag==="Leaf"){f=!1,d=J;continue}if(l.tag==="Node"){const _=t.compare(o)(l._3);if(_==="LT"){c=l._5;continue}if(_==="GT"){c=l._6;continue}if(_==="EQ"){f=!1,d=T("Just",l._4);continue}}g()}return d})(r);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})();return Z(t)(i.node)(i.viaSrc?u-1|0:u+1|0)(r)})(n)(ve(e)),Hs=t=>{const e=t.Eq0();return n=>r=>i=>{const o={...i,treeNode:Z(t)(r)()(i.treeNode)};return w(u=>s=>{if(Mn(s.eid)(u.st.edgeVisited))return u;const a={...u.st,edgeVisited:Z(nt)(s.eid)()(u.st.edgeVisited)},c=e.eq(s.src)((()=>{const f=s.src,d=_=>{let h=_,p=!0,m;for(;p;){const y=h;if(y.tag==="Leaf"){p=!1,m=!1;continue}if(y.tag==="Node"){const x=t.compare(f)(y._3);if(x==="LT"){h=y._5;continue}if(x==="GT"){h=y._6;continue}if(x==="EQ"){p=!1,m=!0;continue}}g()}return m},l=s.tgt;return d(a.treeNode)&&!(_=>{let h=_,p=!0,m;for(;p;){const y=h;if(y.tag==="Leaf"){p=!1,m=!1;continue}if(y.tag==="Node"){const x=t.compare(l)(y._3);if(x==="LT"){h=y._5;continue}if(x==="GT"){h=y._6;continue}if(x==="EQ"){p=!1,m=!0;continue}}g()}return m})(a.treeNode)})()?s.src:(()=>{const f=s.tgt,d=_=>{let h=_,p=!0,m;for(;p;){const y=h;if(y.tag==="Leaf"){p=!1,m=!1;continue}if(y.tag==="Node"){const x=t.compare(f)(y._3);if(x==="LT"){h=y._5;continue}if(x==="GT"){h=y._6;continue}if(x==="EQ"){p=!1,m=!0;continue}}g()}return m},l=s.src;return d(a.treeNode)&&!(_=>{let h=_,p=!0,m;for(;p;){const y=h;if(y.tag==="Leaf"){p=!1,m=!1;continue}if(y.tag==="Node"){const x=t.compare(l)(y._3);if(x==="LT"){h=y._5;continue}if(x==="GT"){h=y._6;continue}if(x==="EQ"){p=!1,m=!0;continue}}g()}return m})(a.treeNode)})()?s.tgt:s.src)?s.tgt:s.src;if(Mn(s.eid)(a.treeEdge)){if((d=>{let l=d,_=!0,h;for(;_;){const p=l;if(p.tag==="Leaf"){_=!1,h=!1;continue}if(p.tag==="Node"){const m=t.compare(c)(p._3);if(m==="LT"){l=p._5;continue}if(m==="GT"){l=p._6;continue}if(m==="EQ"){_=!1,h=!0;continue}}g()}return h})(a.treeNode))return{...u,st:a};const f=Hs(t)(n)(c)(a);return{count:u.count+f.count|0,st:f.st}}if((()=>{const f=l=>{let _=l,h=!0,p;for(;h;){const m=_;if(m.tag==="Leaf"){h=!1,p=!1;continue}if(m.tag==="Node"){const y=t.compare(c)(m._3);if(y==="LT"){_=m._5;continue}if(y==="GT"){_=m._6;continue}if(y==="EQ"){h=!1,p=!0;continue}}g()}return p},d=s.tgt;return!f(a.treeNode)&&(()=>{const l=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(d)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=T("Just",N._4);continue}}g()}return x})(a.layer),_=s.src,h=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(_)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=T("Just",N._4);continue}}g()}return x})(a.layer);if(l.tag==="Nothing"){if(h.tag==="Nothing")return s.delta===0;if(h.tag==="Just")return s.delta===-h._1;g()}if(l.tag==="Just"){if(h.tag==="Nothing")return s.delta===(l._1-0|0);if(h.tag==="Just")return s.delta===(l._1-h._1|0)}g()})()})()){const f=Hs(t)(n)(c)({...a,treeEdge:Z(nt)(s.eid)()(a.treeEdge)});return{count:u.count+f.count|0,st:f.st}}return{...u,st:a}})({count:1,st:o})(ut(u=>(e.eq(u.src)(r)||e.eq(u.tgt)(r))&&!Mn(u.eid)(o.edgeVisited),n))}},$o=t=>e=>n=>r=>{const i=r.src,o=(l=>{let _=l,h=!0,p;for(;h;){const m=_;if(m.tag==="Leaf"){h=!1,p=J;continue}if(m.tag==="Node"){const y=t.compare(i)(m._3);if(y==="LT"){_=m._5;continue}if(y==="GT"){_=m._6;continue}if(y==="EQ"){h=!1,p=T("Just",m._4);continue}}g()}return p})(e.poID),u=(()=>{if(o.tag==="Nothing")return 0;if(o.tag==="Just")return o._1;g()})(),s=r.tgt,a=(l=>{let _=l,h=!0,p;for(;h;){const m=_;if(m.tag==="Leaf"){h=!1,p=J;continue}if(m.tag==="Node"){const y=t.compare(s)(m._3);if(y==="LT"){_=m._5;continue}if(y==="GT"){_=m._6;continue}if(y==="EQ"){h=!1,p=T("Just",m._4);continue}}g()}return p})(e.poID),c=(()=>{if(a.tag==="Nothing")return 0;if(a.tag==="Just")return a._1;g()})(),f=(l=>{let _=l,h=!0,p;for(;h;){const m=_;if(m.tag==="Leaf"){h=!1,p=J;continue}if(m.tag==="Node"){const y=t.compare(n)(m._3);if(y==="LT"){_=m._5;continue}if(y==="GT"){_=m._6;continue}if(y==="EQ"){h=!1,p=T("Just",m._4);continue}}g()}return p})(e.poID),d=(()=>{if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1;g()})();return(()=>{const l=r.src,_=(h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=J;continue}if(x.tag==="Node"){const N=t.compare(l)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=T("Just",x._4);continue}}g()}return y})(e.lowestPoID);return(()=>{if(_.tag==="Nothing")return 0<=d;if(_.tag==="Just")return _._1<=d;g()})()&&(()=>{const h=r.tgt;return d<=u&&(()=>{const p=(m=>{let y=m,x=!0,N;for(;x;){const v=y;if(v.tag==="Leaf"){x=!1,N=J;continue}if(v.tag==="Node"){const b=t.compare(h)(v._3);if(b==="LT"){y=v._5;continue}if(b==="GT"){y=v._6;continue}if(b==="EQ"){x=!1,N=T("Just",v._4);continue}}g()}return N})(e.lowestPoID);return(()=>{if(p.tag==="Nothing")return 0<=d;if(p.tag==="Just")return p._1<=d;g()})()&&d<=c})()})()})()?u>=c:u<c},vy=t=>{const e=te(t)(Bt);return n=>({layer:e(H(r=>L(r,0))(n)),treeNode:D,treeEdge:D,poID:D,lowestPoID:D,cutvalue:D,postOrder:1,edgeVisited:D})},by=t=>e=>n=>w(r=>i=>{if((()=>{const f=i.src,d=h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=!1;continue}if(x.tag==="Node"){const N=t.compare(f)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=!0;continue}}g()}return y},l=i.tgt,_=h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=!1;continue}if(x.tag==="Node"){const N=t.compare(l)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=!0;continue}}g()}return y};return d(n.treeNode)===_(n.treeNode)})())return r;const o=i.tgt,u=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(o)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=T("Just",h._4);continue}}g()}return _})(n.layer),s=i.src,a=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(s)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=T("Just",h._4);continue}}g()}return _})(n.layer),c=(()=>{if(u.tag==="Nothing"){if(a.tag==="Nothing")return-i.delta;if(a.tag==="Just")return-a._1-i.delta|0;g()}if(u.tag==="Just"){if(a.tag==="Nothing")return(u._1-0|0)-i.delta|0;if(a.tag==="Just")return(u._1-a._1|0)-i.delta|0}g()})();return c<r.slack?{edge:T("Just",i),slack:c}:r})({edge:J,slack:1e9})(e).edge,Ly=t=>{const e=te(t)(Bt);return n=>r=>{const i=w(o=>u=>Rs(o)((()=>{const s=(a=>{let c=a,f=!0,d;for(;f;){const l=c;if(l.tag==="Leaf"){f=!1,d=J;continue}if(l.tag==="Node"){const _=t.compare(u)(l._3);if(_==="LT"){c=l._5;continue}if(_==="GT"){c=l._6;continue}if(_==="EQ"){f=!1,d=T("Just",l._4);continue}}g()}return d})(r);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})()))(1e9)(n);return e(H(o=>L(o,(()=>{const u=(s=>{let a=s,c=!0,f;for(;c;){const d=a;if(d.tag==="Leaf"){c=!1,f=J;continue}if(d.tag==="Node"){const l=t.compare(o)(d._3);if(l==="LT"){a=d._5;continue}if(l==="GT"){a=d._6;continue}if(l==="EQ"){c=!1,f=T("Just",d._4);continue}}g()}return f})(r);if(u.tag==="Nothing")return-i;if(u.tag==="Just")return u._1-i|0;g()})()))(n))}},nf=t=>{const e=t.Eq0();return n=>r=>i=>{const o=w(s=>a=>{const c=nf(t)(n)(e.eq(a.src)(r)?a.tgt:a.src)({...s.st,edgeVisited:Z(nt)(a.eid)()(s.st.edgeVisited)});return{lowest:Rs(s.lowest)(c.lowest),st:c.st}})({lowest:1e9,st:i})(ut(s=>Mn(s.eid)(i.treeEdge)&&(e.eq(s.src)(r)||e.eq(s.tgt)(r))&&!Mn(s.eid)(i.edgeVisited),n)),u=Rs(o.lowest)(o.st.postOrder);return{lowest:u,st:{...o.st,poID:Z(t)(r)(o.st.postOrder)(o.st.poID),lowestPoID:Z(t)(r)(u)(o.st.lowestPoID),postOrder:o.st.postOrder+1|0}}}},rf=t=>{const e=nf(t);return n=>r=>i=>0<n.length?e(r)(n[0])({...i,edgeVisited:D,postOrder:1,poID:D,lowestPoID:D}).st:i},ky=t=>{const e=t.Eq0();return n=>r=>i=>ut(o=>Mn(o.eid)(r.treeEdge)&&(e.eq(o.src)(i)||e.eq(o.tgt)(i)),n)},Ey=t=>e=>Vt(n=>{const r=qs(n.eid)(e.cutvalue);return Mn(n.eid)(e.treeEdge)&&(()=>{if(r.tag==="Nothing")return!1;if(r.tag==="Just")return r._1<-1e-10;g()})()})(t),of=t=>{const e=Hs(t);return n=>r=>i=>{const o=0<n.length?T("Just",n[0]):J;if(o.tag==="Nothing")return i;if(o.tag==="Just"){const u=e(r)(o._1)({...i,edgeVisited:D,treeNode:D,treeEdge:D});if(u.count>=n.length)return u.st;const s=by(t)(r)(u.st);if(s.tag==="Nothing")return u.st;if(s.tag==="Just"){const a=s._1.tgt,c=(h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=J;continue}if(x.tag==="Node"){const N=t.compare(a)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=T("Just",x._4);continue}}g()}return y})(u.st.layer),f=s._1.src,d=(h=>{let p=h,m=!0,y;for(;m;){const x=p;if(x.tag==="Leaf"){m=!1,y=J;continue}if(x.tag==="Node"){const N=t.compare(f)(x._3);if(N==="LT"){p=x._5;continue}if(N==="GT"){p=x._6;continue}if(N==="EQ"){m=!1,y=T("Just",x._4);continue}}g()}return y})(u.st.layer),l=(()=>{if(c.tag==="Nothing"){if(d.tag==="Nothing")return-s._1.delta;if(d.tag==="Just")return-d._1-s._1.delta|0;g()}if(c.tag==="Just"){if(d.tag==="Nothing")return(c._1-0|0)-s._1.delta|0;if(d.tag==="Just")return(c._1-d._1|0)-s._1.delta|0}g()})(),_=(()=>{const h=s._1.tgt;return(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=!1;continue}if(N.tag==="Node"){const v=t.compare(h)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=!0;continue}}g()}return x})(u.st.treeNode)})()?-l:l;return of(t)(n)(r)({...u.st,layer:w(h=>p=>(m=>{let y=m,x=!0,N;for(;x;){const v=y;if(v.tag==="Leaf"){x=!1,N=!1;continue}if(v.tag==="Node"){const b=t.compare(p)(v._3);if(b==="LT"){y=v._5;continue}if(b==="GT"){y=v._6;continue}if(b==="EQ"){x=!1,N=!0;continue}}g()}return N})(u.st.treeNode)?Z(t)(p)((()=>{const m=(y=>{let x=y,N=!0,v;for(;N;){const b=x;if(b.tag==="Leaf"){N=!1,v=J;continue}if(b.tag==="Node"){const k=t.compare(p)(b._3);if(k==="LT"){x=b._5;continue}if(k==="GT"){x=b._6;continue}if(k==="EQ"){N=!1,v=T("Just",b._4);continue}}g()}return v})(u.st.layer);if(m.tag==="Nothing")return 0+_|0;if(m.tag==="Just")return m._1+_|0;g()})())(h):h)(u.st.layer)(n)})}}g()}},Sy=t=>e=>n=>r=>w(i=>o=>{if($o(t)(r)(o.src)(n)&&!$o(t)(r)(o.tgt)(n)){const u=o.tgt,s=(d=>{let l=d,_=!0,h;for(;_;){const p=l;if(p.tag==="Leaf"){_=!1,h=J;continue}if(p.tag==="Node"){const m=t.compare(u)(p._3);if(m==="LT"){l=p._5;continue}if(m==="GT"){l=p._6;continue}if(m==="EQ"){_=!1,h=T("Just",p._4);continue}}g()}return h})(r.layer),a=o.src,c=(d=>{let l=d,_=!0,h;for(;_;){const p=l;if(p.tag==="Leaf"){_=!1,h=J;continue}if(p.tag==="Node"){const m=t.compare(a)(p._3);if(m==="LT"){l=p._5;continue}if(m==="GT"){l=p._6;continue}if(m==="EQ"){_=!1,h=T("Just",p._4);continue}}g()}return h})(r.layer),f=(()=>{if(s.tag==="Nothing"){if(c.tag==="Nothing")return-o.delta;if(c.tag==="Just")return-c._1-o.delta|0;g()}if(s.tag==="Just"){if(c.tag==="Nothing")return(s._1-0|0)-o.delta|0;if(c.tag==="Just")return(s._1-c._1|0)-o.delta|0}g()})();if(f<i.slack)return{edge:T("Just",o),slack:f}}return i})({edge:J,slack:1e9})(e).edge,Cy=t=>{const e=t.Eq0();return n=>r=>i=>o=>{const u=o.tgt,s=o.src;return w(a=>c=>{if((()=>{const f=qs(c.eid)(r.cutvalue);if(f.tag==="Just")return!0;if(f.tag==="Nothing")return!1;g()})()){const f=qs(c.eid)(r.cutvalue),d=(()=>{if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1;g()})();return e.eq(s)(c.src)||e.eq(u)(c.tgt)?a-(d-c.weight):a+(d-c.weight)}return e.eq(i)(s)?e.eq(c.src)(i)?a+c.weight:a-c.weight:e.eq(c.src)(i)?a-c.weight:a+c.weight})(o.weight)(ut(a=>a.eid!==o.eid&&(e.eq(a.src)(i)||e.eq(a.tgt)(i)),n))}},Gy=t=>{const e=Cy(t);return n=>r=>i=>{const o=(u,s,a)=>{const c=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(u)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=T("Just",h._4);continue}}g()}return _})(a);if(c.tag==="Just")return Z(t)(u)(ut(f=>f.eid!==s.eid,c._1))(a);if(c.tag==="Nothing")return a;g()};return(u=>s=>{let a=u,c=s,f=!0,d;for(;f;){const l=a,_=c,h=(m=>{let y=m,x=!0,N;for(;x;){const v=y;if(v.tag==="Leaf"){x=!1,N=J;continue}if(v.tag==="Node"){const b=t.compare(_)(v._3);if(b==="LT"){y=v._5;continue}if(b==="GT"){y=v._6;continue}if(b==="EQ"){x=!1,N=T("Just",v._4);continue}}g()}return N})(l.unknown),p=(()=>{if(h.tag==="Nothing")return[];if(h.tag==="Just")return h._1;g()})();if(p.length===1){const m=t.Eq0().eq(p[0].src)(_)?p[0].tgt:p[0].src;a={unknown:o(_,p[0],o(m,p[0],l.unknown)),cutvalue:Z(nt)(p[0].eid)(e(n)(l)(_)(p[0]))(l.cutvalue)},c=m;continue}f=!1,d=l}return d})(r)(i)}},uf=t=>{const e=t.Eq0(),n=t.Eq0(),r={eq:c=>f=>c.delta===f.delta&&c.eid===f.eid&&n.eq(c.src)(f.src)&&e.eq(c.tgt)(f.tgt)&&c.weight===f.weight},i={compare:c=>f=>{const d=nt.compare(c.delta)(f.delta);if(d==="LT"||d==="GT"||d!=="EQ")return d;const l=nt.compare(c.eid)(f.eid);if(l==="LT"||l==="GT"||l!=="EQ")return l;const _=t.compare(c.src)(f.src);if(_==="LT"||_==="GT"||_!=="EQ")return _;const h=t.compare(c.tgt)(f.tgt);if(h==="LT"||h==="GT"||h!=="EQ")return h;const p=rt.compare(c.weight)(f.weight);return p==="LT"||p==="GT"||p!=="EQ"?p:Ie},Eq0:()=>r},o=w(c=>f=>Z(i)(f)()(c))(D),u=ky(t),s=te(t)(Bt),a=Gy(t);return c=>f=>d=>{const l={unknown:s(H(_=>L(_,At($e.foldr,o(u(f)(d)(_)))))(c)),cutvalue:D};return{...d,cutvalue:w(a(f))(l)(ut(_=>{const h=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(_)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=T("Just",N._4);continue}}g()}return x})(l.unknown);if(h.tag==="Nothing")return!1;if(h.tag==="Just")return h._1.length===1;g()},c)).cutvalue}}},Py=t=>{const e=rf(t),n=uf(t);return r=>i=>o=>u=>s=>{const a={...s,treeEdge:Z(nt)(u.eid)()(di(nt)(o.eid)(s.treeEdge))},c=u.tgt,f=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(c)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=T("Just",N._4);continue}}g()}return x})(a.layer),d=u.src,l=(p=>{let m=p,y=!0,x;for(;y;){const N=m;if(N.tag==="Leaf"){y=!1,x=J;continue}if(N.tag==="Node"){const v=t.compare(d)(N._3);if(v==="LT"){m=N._5;continue}if(v==="GT"){m=N._6;continue}if(v==="EQ"){y=!1,x=T("Just",N._4);continue}}g()}return x})(a.layer),_=(()=>{if(f.tag==="Nothing"){if(l.tag==="Nothing")return-u.delta;if(l.tag==="Just")return-l._1-u.delta|0;g()}if(f.tag==="Just"){if(l.tag==="Nothing")return(f._1-0|0)-u.delta|0;if(l.tag==="Just")return(f._1-l._1|0)-u.delta|0}g()})(),h=$o(t)(a)(u.tgt)(o)?_:-_;return n(r)(i)(e(r)(i)({...a,layer:w(p=>m=>$o(t)(a)(m)(o)?p:Z(t)(m)((()=>{const y=(x=>{let N=x,v=!0,b;for(;v;){const k=N;if(k.tag==="Leaf"){v=!1,b=J;continue}if(k.tag==="Node"){const E=t.compare(m)(k._3);if(E==="LT"){N=k._5;continue}if(E==="GT"){N=k._6;continue}if(E==="EQ"){v=!1,b=T("Just",k._4);continue}}g()}return b})(a.layer);if(y.tag==="Nothing")return 0+h|0;if(y.tag==="Just")return y._1+h|0;g()})())(p))(a.layer)(r)}))}},Ay=t=>{const e=Py(t);return n=>r=>i=>o=>(u=>s=>{let a=u,c=s,f=!0,d;for(;f;){const l=a,_=c;if(l===0){f=!1,d=_;continue}const h=Ey(i)(_);if(h.tag==="Nothing"){f=!1,d=_;continue}if(h.tag==="Just"){const p=Sy(t)(i)(h._1)(_);if(p.tag==="Nothing"){f=!1,d=_;continue}if(p.tag==="Just"){a=l-1|0,c=e(r)(i)(h._1)(p._1)(_);continue}}g()}return d})(n)(o)},Iy=t=>{const e=uf(t),n=rf(t),r=of(t);return i=>o=>u=>e(i)(o)(n(i)(o)(r(i)(o)(u)))},sf=t=>e=>w(n=>r=>bt(t)(ne)(e(r))([r])(n))(D),Qy=t=>{const e=te(t)(Bt);return n=>r=>i=>{const o=a=>c=>f=>d=>{let l=a,_=c,h=f,p=d,m=!0,y;for(;m;){const x=l,N=_,v=h,b=p,k=Mt(E=>J,E=>A=>T("Just",{head:E,tail:A}),v);if(k.tag==="Nothing"){m=!1,y=b;continue}if(k.tag==="Just"){const E=k._1.head,A=(S=>{let C=S,V=!0,U;for(;V;){const M=C;if(M.tag==="Leaf"){V=!1,U=J;continue}if(M.tag==="Node"){const W=t.compare(E)(M._3);if(W==="LT"){C=M._5;continue}if(W==="GT"){C=M._6;continue}if(W==="EQ"){V=!1,U=T("Just",M._4);continue}}g()}return U})(b.layer),$=(()=>{if(A.tag==="Nothing")return 0;if(A.tag==="Just")return A._1;g()})(),tt=w(S=>C=>{const V=C.tgt,U=(W=>{let B=W,P=!0,I;for(;P;){const F=B;if(F.tag==="Leaf"){P=!1,I=J;continue}if(F.tag==="Node"){const Q=t.compare(V)(F._3);if(Q==="LT"){B=F._5;continue}if(Q==="GT"){B=F._6;continue}if(Q==="EQ"){P=!1,I=T("Just",F._4);continue}}g()}return I})(S.incident),M=(()=>{if(U.tag==="Nothing")return-1;if(U.tag==="Just")return U._1-1|0;g()})();return{st:{...S.st,layer:Z(t)(C.tgt)(Jy((()=>{const W=C.tgt,B=(P=>{let I=P,F=!0,Q;for(;F;){const R=I;if(R.tag==="Leaf"){F=!1,Q=J;continue}if(R.tag==="Node"){const Y=t.compare(W)(R._3);if(Y==="LT"){I=R._5;continue}if(Y==="GT"){I=R._6;continue}if(Y==="EQ"){F=!1,Q=T("Just",R._4);continue}}g()}return Q})(S.st.layer);if(B.tag==="Nothing")return 0;if(B.tag==="Just")return B._1;g()})())($+C.delta|0))(S.st.layer)},incident:Z(t)(C.tgt)(M)(S.incident),queue:M===0?[...S.queue,C.tgt]:S.queue}})({st:b,incident:N,queue:k._1.tail})((()=>{const S=(C=>{let V=C,U=!0,M;for(;U;){const W=V;if(W.tag==="Leaf"){U=!1,M=J;continue}if(W.tag==="Node"){const B=t.compare(E)(W._3);if(B==="LT"){V=W._5;continue}if(B==="GT"){V=W._6;continue}if(B==="EQ"){U=!1,M=T("Just",W._4);continue}}g()}return M})(x);if(S.tag==="Nothing")return[];if(S.tag==="Just")return S._1;g()})());l=x,_=tt.incident,h=tt.queue,p=tt.st;continue}g()}return y},u=sf(t)(a=>a.tgt)(r),s=e(H(a=>L(a,(()=>{const c=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(a)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=T("Just",h._4);continue}}g()}return _})(u);if(c.tag==="Nothing")return 0;if(c.tag==="Just")return c._1.length;g()})()))(n));return o(sf(t)(a=>a.src)(r))(s)(ut(a=>{const c=(f=>{let d=f,l=!0,_;for(;l;){const h=d;if(h.tag==="Leaf"){l=!1,_=J;continue}if(h.tag==="Node"){const p=t.compare(a)(h._3);if(p==="LT"){d=h._5;continue}if(p==="GT"){d=h._6;continue}if(p==="EQ"){l=!1,_=T("Just",h._4);continue}}g()}return _})(s);if(c.tag==="Nothing")return!0;if(c.tag==="Just")return c._1===0;g()},n))(i)}},Dy=t=>{const e=vy(t),n=Qy(t),r=Iy(t),i=Ay(t);return o=>u=>{const s=n(o)(u)(e(o));return u.length===0?s.layer:i(4*o.length|0)(o)(u)(r(o)(u)(s)).layer}},af=t=>{const e=Ly(t),n=Dy(t),r=wy(t);return i=>o=>{if(i.length===0)return D;if(i.length<40)return e(i)(n(i)(o));const u=r(i)(o);return e(i)(Ty(t)(u.removed)(n(u.coreNodes)(u.coreEdges)))}},cf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Os=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Fy=af(nt),Ci=t=>e=>({...e,edges:[...e.edges,{src:t.src,tgt:t.tgt,delta:t.delta,weight:t.weight,eid:e.nextEid}],nextEid:e.nextEid+1|0}),zy=t=>e=>n=>{if(n.cGroup.tag==="Nothing")return e;if(n.cGroup.tag==="Just"){const r=et((()=>{const i=cf(n.cGroup._1)(t);if(i.tag==="Nothing")return 0;if(i.tag==="Just")return i._1;g()})());return je(n.id)(i=>({...i,hitbox:{...i.hitbox,x:r+i.cGroupOffset.x}}))(e)}g()},By=t=>e=>({...e,cGraph:w(zy(t))(e.cGraph)((()=>{const n=e.cGraph;return xt(r=>jt(r)(n.cNodes))(n.cNodeOrder)})())}),My=t=>e=>n=>r=>i=>{const o=xe(no(e.cGroupOffset.x-t.cGroupOffset.x));return Ci({src:i.nextNodeId,tgt:r,delta:Os(0)(-o),weight:1})(Ci({src:i.nextNodeId,tgt:n,delta:Os(0)(o),weight:1})({...i,nodes:[...i.nodes,i.nextNodeId],nextNodeId:i.nextNodeId+1|0}))},Wy=t=>e=>n=>r=>i=>o=>u=>{const s=Os(0)(xe(no(n.cGroupOffset.x+n.hitbox.width+(e.direction==="LEFT"||e.direction==="RIGHT"?e.spacingsHandler.horizontalSpacing(n)(r):e.spacingsHandler.verticalSpacing(n)(r))-r.cGroupOffset.x)));return t.sameEdgeVerticalSegments(n)(r)?My(n)(r)(i)(o)(u):Ci({src:i,tgt:o,delta:s,weight:t.vsLNodePair(n)(r)?2:1})(u)},Ry=t=>e=>n=>r=>i=>{const o=jt(i)(e.cGraph.cNodes);if(o.tag==="Nothing")return r;if(o.tag==="Just")return(n.cGroup.tag==="Nothing"?o._1.cGroup.tag==="Nothing":n.cGroup.tag==="Just"&&o._1.cGroup.tag==="Just"&&n.cGroup._1===o._1.cGroup._1)?r:n.cGroup.tag==="Just"&&o._1.cGroup.tag==="Just"?Wy(t)(e)(n)(o._1)(n.cGroup._1)(o._1.cGroup._1)(r):r;g()},qy=t=>e=>n=>r=>w(Ry(t)(e)(r))(n)(r.constraints),Hy=t=>e=>Ci({src:e.srcGroup,tgt:e.tgtGroup,delta:e.delta,weight:e.weight})(t),Oy=t=>{const e=w(i=>o=>bt(nt)(se)(o.tgt)(1)(i))(D)(t.edges),n=ut(i=>{const o=cf(i)(e);if(o.tag==="Nothing")return!0;if(o.tag==="Just")return o._1===0;g()},t.nodes);if(n.length<=1)return t;const r=t.nextNodeId;return w(i=>o=>Ci({src:r,tgt:o,delta:1,weight:0})(i))({...t,nodes:[...t.nodes,r],nextNodeId:r+1|0})(n)},$y=t=>e=>{const n=Oy(w(Hy)(w(qy(t)(e))({nodes:e.cGraph.cGroupOrder,edges:[],nextNodeId:e.cGraph.nextCGroupId,nextEid:0})((()=>{const r=e.cGraph;return xt(i=>jt(i)(r.cNodes))(r.cNodeOrder)})()))(t.edgeLengthEdges(e.cGraph)));return{nodes:n.nodes,edges:n.edges}},Xy=t=>e=>{const n=$y(t)(e);return By(Fy(n.nodes)(n.edges))(e)},gf=t=>t,re=gf("H"),ie=gf("V"),Yy=t=>L(t._2,t._1),ff=t=>({...t,position:L(t.position._2,t.position._1),size:L(t.size._2,t.size._1)}),Vy=t=>({start:L(t.start._2,t.start._1),end:L(t.end._2,t.end._1),direction:(()=>{if(t.direction==="H")return ie;if(t.direction==="V")return re;g()})()}),_f=t=>({...t,segments:H(Vy)(t.segments),bends:H(Yy)(t.bends)}),Uy=t=>({nodes:H(ff)(t.nodes),edges:t.edges,paths:H(_f)(t.paths),ports:t.ports}),Ky={nodeNode:8,edgeNode:4,edgeEdge:10},jy=t=>e=>({horizontalSpacing:n=>r=>{if(e.sameEdgeVerticalSegments(n)(r)||n.ignoreSpacing.right||r.ignoreSpacing.left)return 0;const i=r.kind.tag==="Nothing"?!1:r.kind.tag==="Just"&&r.kind._1==="vs";return n.kind.tag!=="Nothing"&&n.kind.tag==="Just"&&n.kind._1==="vs"?i?t.edgeEdge:t.edgeNode:i?t.edgeNode:t.nodeNode},verticalSpacing:n=>r=>{if(e.sameEdgeVerticalSegments(n)(r))return 1;if(n.hitbox.y<=r.hitbox.y?n.ignoreSpacing.down||r.ignoreSpacing.up:n.ignoreSpacing.up||r.ignoreSpacing.down)return 0;const i=r.kind.tag==="Nothing"?!1:r.kind.tag==="Just"&&r.kind._1==="vs";return n.kind.tag!=="Nothing"&&n.kind.tag==="Just"&&n.kind._1==="vs"?i?t.edgeEdge:t.edgeNode:i?t.edgeNode:t.nodeNode}}),Zy=t=>e=>Xy(e),tx=t=>e=>n=>{const r=Uy(n),i=Ny(r),o=hy(i)(tf(r)),u=py(Rg(Is)(Bm({...Wm(i.cGraph),compactionAlgorithm:T("Just",Zy()(o)),constraintAlgorithm:T("Just",Zm(e.edgeEdge)),spacingsHandler:jy(e)(o)})).cGraph)({nodes:r.nodes,edges:r.edges,paths:r.paths});return{nodes:H(ff)(u.nodes),edges:H(_f)(u.edges)}},df=t=>t,Ur=te(nt)(Bt),It=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},lf=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},lt=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},ht=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Kr=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},ex=t=>e=>{const n=nt.compare(t._1)(e._1);return n==="LT"?me:n==="GT"?ye:nt.compare(t._2)(e._2)},jr=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},nx=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),rx=t=>t,hf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},ix=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Xo=df("Regular"),Yo=df("Critical"),pf=t=>e=>{const n=w(u=>s=>Z(G)(s.node)(s)(u))(D)(e),r=1.25*et(4),i=(u,s,a)=>(c=>f=>d=>{let l=c,_=f,h=d,p=!0,m;for(;p;){const y=l,x=_,N=h;if(N.critical){p=!1,m=N;continue}const v=Mt(k=>J,k=>E=>T("Just",{head:k,tail:E}),y),b=Mt(k=>J,k=>E=>T("Just",{head:k,tail:E}),x);if(v.tag==="Just"&&b.tag==="Just"){const k=v._1.head>b._1.head-u&&v._1.head<b._1.head+u?{...N,critical:!0}:v._1.head>b._1.head-r&&v._1.head<b._1.head+r?{...N,conflicts:N.conflicts+1|0}:N;if(k.critical){p=!1,m=k;continue}if(v._1.head<=b._1.head){l=v._1.tail,_=x,h=k;continue}l=y,_=b._1.tail,h=k;continue}p=!1,m=N}return m})(s)(a)({conflicts:0,critical:!1}),o=(u,s,a)=>{if(ht(w(ht)(-1e18)(s.incoming))(w(ht)(-1e18)(s.outgoing))-lt(w(lt)(1e18)(s.incoming))(w(lt)(1e18)(s.outgoing))<.001||ht(w(ht)(-1e18)(a.incoming))(w(ht)(-1e18)(a.outgoing))-lt(w(lt)(1e18)(a.incoming))(w(lt)(1e18)(a.outgoing))<.001)return[];const c=i(u,s.outgoing,a.incoming),f=i(u,a.outgoing,s.incoming);if(c.critical||f.critical)return[...c.critical?[{src:a.id,tgt:s.id,weight:1,kind:Yo}]:[],...f.critical?[{src:s.id,tgt:a.id,weight:1,kind:Yo}]:[]];const d=lt(w(lt)(1e18)(s.incoming))(w(lt)(1e18)(s.outgoing)),l=ht(w(ht)(-1e18)(s.incoming))(w(ht)(-1e18)(s.outgoing)),_=lt(w(lt)(1e18)(a.incoming))(w(lt)(1e18)(a.outgoing)),h=ht(w(ht)(-1e18)(a.incoming))(w(ht)(-1e18)(a.outgoing)),p=(1*c.conflicts|0)+(16*(w(y=>x=>x>h?y:x>=_?y+1|0:y)(0)(s.outgoing)+w(y=>x=>x>l?y:x>=d?y+1|0:y)(0)(a.incoming)|0)|0)|0,m=(1*f.conflicts|0)+(16*(w(y=>x=>x>l?y:x>=d?y+1|0:y)(0)(a.outgoing)+w(y=>x=>x>h?y:x>=_?y+1|0:y)(0)(s.incoming)|0)|0)|0;return p<m?[{src:s.id,tgt:a.id,weight:m-p|0,kind:Xo}]:p>m?[{src:a.id,tgt:s.id,weight:p-m|0,kind:Xo}]:p>0?[{src:s.id,tgt:a.id,weight:0,kind:Xo},{src:a.id,tgt:s.id,weight:0,kind:Xo}]:[]};return w(u=>s=>w(a=>c=>Z(G)(c._1)(c._2)(a))(u)((()=>{const a=w(S=>C=>{const V=C.edge.from.node+"|"+(()=>{if(C.edge.from.port.tag==="Just")return C.edge.from.port._1;if(C.edge.from.port.tag==="Nothing")return"_auto_"+C.edge.id;g()})(),U=hf(V)(S.entries);if(U.tag==="Nothing")return{...S,entries:Z(G)(V)({id:0,members:[C.edge.id],incoming:[C.fromPos._1],outgoing:[C.toPos._1],slot:0,mark:0,splitBy:J,splitPartner:J})(S.entries),order:[...S.order,V]};if(U.tag==="Just")return{...S,entries:Z(G)(V)({...U._1,members:[...U._1.members,C.edge.id],incoming:[...mr(M=>M<C.fromPos._1)(U._1.incoming).init,C.fromPos._1,...mr(M=>M<=C.fromPos._1)(U._1.incoming).rest],outgoing:[...mr(M=>M<C.toPos._1)(U._1.outgoing).init,C.toPos._1,...mr(M=>M<=C.toPos._1)(U._1.outgoing).rest]})(S.entries)};g()})({entries:D,order:[]})(s._2),c=Ft(S=>C=>({...C,id:S}))(xt(S=>hf(S)(a.entries))(a.order));if(c.length===0)return[];const f=w(S=>C=>S.prev.tag==="Just"&&C-S.prev._1<1e-9?S:{prev:T("Just",C),out:[...S.out,C]})({prev:J,out:[]})(Et(rt.compare)([...Tt(c)(S=>S.incoming),...Tt(c)(S=>S.outgoing)])).out,d=f.length<2?.2*r:.2*w(S=>C=>{if(S.prev.tag==="Nothing")return{prev:T("Just",C),mn:S.mn};if(S.prev.tag==="Just")return{prev:T("Just",C),mn:lt(S.mn)(C-S.prev._1)};g()})({prev:J,mn:1e18})(f).mn,l={segments:c,deps:(()=>{const S=c.length;return Tt(Tt(zt(0,S-2|0))(C=>Tt(zt(C+1|0,S-1|0))(V=>[L(C,V)])))(C=>C._1>=0&&C._1<c.length?C._2>=0&&C._2<c.length?o(d,c[C._1],c[C._2]):[]:[])})()},_=ut(S=>{if(S.kind==="Critical")return!0;if(S.kind==="Regular")return!1;g()},l.deps),h=(()=>{if(_.length<2)return l;const S=Ur((()=>{const W=l.segments;return H(B=>L(B.id,B.mark))((()=>{const B=W.length,P=F=>{let Q=F,R=!0,Y;for(;R;){const O=Q,X=Vt(q=>{const K=It(q)(O.inWeight);if(K.tag==="Nothing")return!0;if(K.tag==="Just")return K._1===0;g()})(O.remaining);if(X.tag==="Nothing"){R=!1,Y=O;continue}if(X.tag==="Just"){const q=X._1;Q={...O,inWeight:w(K=>j=>bt(nt)(se)(j.tgt)(-j.weight)(K))(O.inWeight)((()=>{const K=It(q)(O.depsBySrc);if(K.tag==="Nothing")return[];if(K.tag==="Just")return K._1;g()})()),marks:Z(nt)(q)(O.nextSource)(O.marks),nextSource:O.nextSource+1|0,outWeight:w(K=>j=>bt(nt)(se)(j.src)(-j.weight)(K))(O.outWeight)((()=>{const K=It(q)(O.depsByTgt);if(K.tag==="Nothing")return[];if(K.tag==="Just")return K._1;g()})()),remaining:ut(K=>K!==q,O.remaining)};continue}g()}return Y},I=F=>{let Q=F,R=!0,Y;for(;R;){const O=Q,X=Vt(q=>{const K=It(q)(O.outWeight);if(K.tag==="Nothing")return!0;if(K.tag==="Just")return K._1===0;g()})(O.remaining);if(X.tag==="Nothing"){R=!1,Y=O;continue}if(X.tag==="Just"){const q=X._1;Q={...O,inWeight:w(K=>j=>bt(nt)(se)(j.tgt)(-j.weight)(K))(O.inWeight)((()=>{const K=It(q)(O.depsBySrc);if(K.tag==="Nothing")return[];if(K.tag==="Just")return K._1;g()})()),marks:Z(nt)(q)(O.nextSink)(O.marks),nextSink:O.nextSink-1|0,outWeight:w(K=>j=>bt(nt)(se)(j.src)(-j.weight)(K))(O.outWeight)((()=>{const K=It(q)(O.depsByTgt);if(K.tag==="Nothing")return[];if(K.tag==="Just")return K._1;g()})()),remaining:ut(K=>K!==q,O.remaining)};continue}g()}return Y};return(F=>{let Q=F,R=!0,Y;for(;R;){const O=P(I(Q));if(O.remaining.length===0){R=!1,Y=H(X=>{const q=It(X.id)(O.marks),K=(()=>{if(q.tag==="Nothing")return X.id;if(q.tag==="Just")return q._1;g()})();return{...X,mark:K<B?(K+B|0)+1|0:K}})(W);continue}Q=(()=>{const X=K=>{const j=It(K)(O.outWeight),ot=It(K)(O.inWeight);return(()=>{if(j.tag==="Nothing")return 0;if(j.tag==="Just")return j._1;g()})()-(()=>{if(ot.tag==="Nothing")return 0;if(ot.tag==="Just")return ot._1;g()})()|0},q=Et(K=>j=>nt.compare(X(j))(X(K)))(O.remaining);if(0<q.length){const K=q[0];return{...O,inWeight:w(j=>ot=>bt(nt)(se)(ot.tgt)(-ot.weight)(j))(O.inWeight)((()=>{const j=It(K)(O.depsBySrc);if(j.tag==="Nothing")return[];if(j.tag==="Just")return j._1;g()})()),marks:Z(nt)(K)(O.nextSource)(O.marks),nextSource:O.nextSource+1|0,outWeight:w(j=>ot=>bt(nt)(se)(ot.src)(-ot.weight)(j))(O.outWeight)((()=>{const j=It(K)(O.depsByTgt);if(j.tag==="Nothing")return[];if(j.tag==="Just")return j._1;g()})()),remaining:ut(j=>j!==K,O.remaining)}}return O})()}return Y})({remaining:H(F=>F.id)(W),marks:D,inWeight:w(F=>Q=>bt(nt)(se)(Q.tgt)(Q.weight)(F))(D)(_),outWeight:w(F=>Q=>bt(nt)(se)(Q.src)(Q.weight)(F))(D)(_),depsBySrc:w(F=>Q=>bt(nt)(ne)(Q.src)([Q])(F))(D)(_),depsByTgt:w(F=>Q=>bt(nt)(ne)(Q.tgt)([Q])(F))(D)(_),nextSink:B-1|0,nextSource:B+1|0})})())})()),C=ut(W=>{const B=It(W.src)(S),P=It(W.tgt)(S);return(()=>{if(B.tag==="Nothing")return 0;if(B.tag==="Just")return B._1;g()})()>(()=>{if(P.tag==="Nothing")return 0;if(P.tag==="Just")return P._1;g()})()},_);if(C.length===0)return l;const V=w(W=>B=>{if(He(Dr)(B.src)(W.decisions)||He(Dr)(B.tgt)(W.decisions))return W;const P=It(B.src)(W.segMap),I=It(B.tgt)(W.segMap);if(P.tag==="Just"&&I.tag==="Just"){const F=(P._1.incoming.length+P._1.outgoing.length|0)>2&&(I._1.incoming.length+I._1.outgoing.length|0)<=2,Q=F?I._1:P._1;return{decisions:[...W.decisions,Q.id],segMap:Z(nt)(Q.id)({...Q,splitBy:T("Just",F?P._1.id:I._1.id)})(W.segMap)}}return W})({decisions:[],segMap:Ur(H(W=>L(W.id,W))(l.segments))})(C),U=V.segMap,M=w(W=>B=>{const P=lt(w(lt)(1e18)(B.incoming))(w(lt)(1e18)(B.outgoing)),I=ht(w(ht)(-1e18)(B.incoming))(w(ht)(-1e18)(B.outgoing)),F=ut(X=>X.a.startPosition<=I&&X.a.endPosition>=P,Ft(X=>q=>({i:X,a:q}))(W.freeAreas));if(F.length===0){const X={...B,incoming:Et(rt.compare)(B.incoming),outgoing:Et(rt.compare)([(P+I)/2]),splitPartner:T("Just",W.nextId)},q={id:W.nextId,incoming:Et(rt.compare)([(P+I)/2]),mark:0,members:B.members,outgoing:Et(rt.compare)(B.outgoing),slot:0,splitBy:J,splitPartner:T("Just",B.id)};return{segMap:Z(nt)(q.id)(q)(Z(nt)(X.id)(X)(W.segMap)),freeAreas:W.freeAreas,nextId:W.nextId+1|0}}const Q=0<F.length?T("Just",F[0]):J,R=(()=>{if(Q.tag==="Nothing")return{i:0,a:{startPosition:0,endPosition:0,size:0}};if(Q.tag==="Just"){if(F.length===1)return Q._1;const X=H(q=>({c:q,rating:(()=>{const K=(q.a.startPosition+q.a.endPosition)/2,j=[K],ot=[K],_t=w((()=>{const yt=W.segMap;return Ct=>Rt=>{const pt=It(Rt.tgt)(yt);if(pt.tag==="Nothing")return Ct;if(pt.tag==="Just"){const qt=lt(w(lt)(1e18)(pt._1.incoming))(w(lt)(1e18)(pt._1.outgoing)),wt=ht(w(ht)(-1e18)(pt._1.incoming))(w(ht)(-1e18)(pt._1.outgoing)),mt=lt(w(lt)(1e18)(B.incoming))(w(lt)(1e18)(j)),ft=(()=>{const Pt=ht(w(ht)(-1e18)(B.incoming))(w(ht)(-1e18)(j)),Qt=w($t=>_e=>_e>wt?$t:_e>=qt?$t+1|0:$t)(0)(j)+w($t=>_e=>_e>Pt?$t:_e>=mt?$t+1|0:$t)(0)(pt._1.incoming)|0,ze=lt(w(lt)(1e18)(B.incoming))(w(lt)(1e18)(j)),an=ht(w(ht)(-1e18)(B.incoming))(w(ht)(-1e18)(j)),Xe=lt(w(lt)(1e18)(pt._1.incoming))(w(lt)(1e18)(pt._1.outgoing)),nn=ht(w(ht)(-1e18)(pt._1.incoming))(w(ht)(-1e18)(pt._1.outgoing)),Ae=w($t=>_e=>_e>an?$t:_e>=ze?$t+1|0:$t)(0)(pt._1.outgoing)+w($t=>_e=>_e>nn?$t:_e>=Xe?$t+1|0:$t)(0)(B.incoming)|0;return Qt===Ae?Qt>0?{...Ct,deps:Ct.deps+2|0,crossings:Ct.crossings+Qt|0}:Ct:{...Ct,deps:Ct.deps+1|0,crossings:Ct.crossings+jr(Qt)(Ae)|0}})(),st=lt(w(lt)(1e18)(pt._1.incoming))(w(lt)(1e18)(pt._1.outgoing)),dt=ht(w(ht)(-1e18)(pt._1.incoming))(w(ht)(-1e18)(pt._1.outgoing)),at=lt(w(lt)(1e18)(ot))(w(lt)(1e18)(B.outgoing)),ct=ht(w(ht)(-1e18)(ot))(w(ht)(-1e18)(B.outgoing)),Nt=w(Pt=>Qt=>Qt>dt?Pt:Qt>=st?Pt+1|0:Pt)(0)(B.outgoing)+w(Pt=>Qt=>Qt>ct?Pt:Qt>=at?Pt+1|0:Pt)(0)(pt._1.incoming)|0,Jt=lt(w(lt)(1e18)(ot))(w(lt)(1e18)(B.outgoing)),Lt=ht(w(ht)(-1e18)(ot))(w(ht)(-1e18)(B.outgoing)),Ht=lt(w(lt)(1e18)(pt._1.incoming))(w(lt)(1e18)(pt._1.outgoing)),dn=ht(w(ht)(-1e18)(pt._1.incoming))(w(ht)(-1e18)(pt._1.outgoing)),Fe=w(Pt=>Qt=>Qt>Lt?Pt:Qt>=Jt?Pt+1|0:Pt)(0)(pt._1.outgoing)+w(Pt=>Qt=>Qt>dn?Pt:Qt>=Ht?Pt+1|0:Pt)(0)(ot)|0;return Nt===Fe?Nt>0?{...ft,deps:ft.deps+2|0,crossings:ft.crossings+Nt|0}:ft:{...ft,deps:ft.deps+1|0,crossings:ft.crossings+jr(Nt)(Fe)|0}}g()}})())(w((()=>{const yt=W.segMap;return Ct=>Rt=>{const pt=It(Rt.src)(yt);if(pt.tag==="Nothing")return Ct;if(pt.tag==="Just"){const qt=lt(w(lt)(1e18)(pt._1.incoming))(w(lt)(1e18)(pt._1.outgoing)),wt=ht(w(ht)(-1e18)(pt._1.incoming))(w(ht)(-1e18)(pt._1.outgoing)),mt=lt(w(lt)(1e18)(B.incoming))(w(lt)(1e18)(j)),ft=(()=>{const Pt=ht(w(ht)(-1e18)(B.incoming))(w(ht)(-1e18)(j)),Qt=w($t=>_e=>_e>wt?$t:_e>=qt?$t+1|0:$t)(0)(j)+w($t=>_e=>_e>Pt?$t:_e>=mt?$t+1|0:$t)(0)(pt._1.incoming)|0,ze=lt(w(lt)(1e18)(B.incoming))(w(lt)(1e18)(j)),an=ht(w(ht)(-1e18)(B.incoming))(w(ht)(-1e18)(j)),Xe=lt(w(lt)(1e18)(pt._1.incoming))(w(lt)(1e18)(pt._1.outgoing)),nn=ht(w(ht)(-1e18)(pt._1.incoming))(w(ht)(-1e18)(pt._1.outgoing)),Ae=w($t=>_e=>_e>an?$t:_e>=ze?$t+1|0:$t)(0)(pt._1.outgoing)+w($t=>_e=>_e>nn?$t:_e>=Xe?$t+1|0:$t)(0)(B.incoming)|0;return Qt===Ae?Qt>0?{...Ct,deps:Ct.deps+2|0,crossings:Ct.crossings+Qt|0}:Ct:{...Ct,deps:Ct.deps+1|0,crossings:Ct.crossings+jr(Qt)(Ae)|0}})(),st=lt(w(lt)(1e18)(pt._1.incoming))(w(lt)(1e18)(pt._1.outgoing)),dt=ht(w(ht)(-1e18)(pt._1.incoming))(w(ht)(-1e18)(pt._1.outgoing)),at=lt(w(lt)(1e18)(ot))(w(lt)(1e18)(B.outgoing)),ct=ht(w(ht)(-1e18)(ot))(w(ht)(-1e18)(B.outgoing)),Nt=w(Pt=>Qt=>Qt>dt?Pt:Qt>=st?Pt+1|0:Pt)(0)(B.outgoing)+w(Pt=>Qt=>Qt>ct?Pt:Qt>=at?Pt+1|0:Pt)(0)(pt._1.incoming)|0,Jt=lt(w(lt)(1e18)(ot))(w(lt)(1e18)(B.outgoing)),Lt=ht(w(ht)(-1e18)(ot))(w(ht)(-1e18)(B.outgoing)),Ht=lt(w(lt)(1e18)(pt._1.incoming))(w(lt)(1e18)(pt._1.outgoing)),dn=ht(w(ht)(-1e18)(pt._1.incoming))(w(ht)(-1e18)(pt._1.outgoing)),Fe=w(Pt=>Qt=>Qt>Lt?Pt:Qt>=Jt?Pt+1|0:Pt)(0)(pt._1.outgoing)+w(Pt=>Qt=>Qt>dn?Pt:Qt>=Ht?Pt+1|0:Pt)(0)(ot)|0;return Nt===Fe?Nt>0?{...ft,deps:ft.deps+2|0,crossings:ft.crossings+Nt|0}:ft:{...ft,deps:ft.deps+1|0,crossings:ft.crossings+jr(Nt)(Fe)|0}}g()}})())({crossings:0,deps:0})(ut(yt=>yt.tgt===B.id,l.deps)))(ut(yt=>yt.src===B.id,l.deps)),gt=(()=>{if(B.splitBy.tag==="Just")return It(B.splitBy._1)(W.segMap);if(B.splitBy.tag==="Nothing")return J;g()})();if(gt.tag==="Just")return{..._t,deps:_t.deps+2|0,crossings:(()=>{const yt=lt(w(lt)(1e18)(gt._1.incoming))(w(lt)(1e18)(gt._1.outgoing)),Ct=lt(w(lt)(1e18)(ot))(w(lt)(1e18)(B.outgoing)),Rt=ht(w(ht)(-1e18)(gt._1.incoming))(w(ht)(-1e18)(gt._1.outgoing)),pt=ht(w(ht)(-1e18)(ot))(w(ht)(-1e18)(B.outgoing)),qt=lt(w(lt)(1e18)(B.incoming))(w(lt)(1e18)(j));return _t.crossings+(()=>{const wt=lt(w(lt)(1e18)(gt._1.incoming))(w(lt)(1e18)(gt._1.outgoing)),mt=ht(w(ht)(-1e18)(B.incoming))(w(ht)(-1e18)(j)),ft=ht(w(ht)(-1e18)(gt._1.incoming))(w(ht)(-1e18)(gt._1.outgoing));return((w(st=>dt=>dt>Rt?st:dt>=yt?st+1|0:st)(0)(j)+w(st=>dt=>dt>mt?st:dt>=qt?st+1|0:st)(0)(gt._1.incoming)|0)+w(st=>dt=>dt>pt?st:dt>=Ct?st+1|0:st)(0)(gt._1.outgoing)|0)+w(st=>dt=>dt>ft?st:dt>=wt?st+1|0:st)(0)(ot)|0})()|0})()};if(gt.tag==="Nothing")return _t;g()})()}))(F);return w(q=>K=>K.rating.crossings<q.rating.crossings||!(K.rating.crossings>q.rating.crossings)&&(K.rating.deps<q.rating.deps||!(K.rating.deps>q.rating.deps)&&K.c.a.size>q.c.a.size)?K:q)(0<X.length?X[0]:{c:Q._1,rating:{crossings:1e6,deps:1e6}})(X).c}g()})(),Y={...B,incoming:Et(rt.compare)(B.incoming),outgoing:Et(rt.compare)([(R.a.startPosition+R.a.endPosition)/2]),splitPartner:T("Just",W.nextId)},O={id:W.nextId,incoming:Et(rt.compare)([(R.a.startPosition+R.a.endPosition)/2]),mark:0,members:B.members,outgoing:Et(rt.compare)(B.outgoing),slot:0,splitBy:J,splitPartner:T("Just",B.id)};return{segMap:Z(nt)(O.id)(O)(Z(nt)(Y.id)(Y)(W.segMap)),freeAreas:(()=>{if(R.i>=0&&R.i<W.freeAreas.length){const X=ac(Zt,J,R.i,W.freeAreas),q=(()=>{if(X.tag==="Nothing")return W.freeAreas;if(X.tag==="Just")return X._1;g()})();if(W.freeAreas[R.i].size/2<d)return q;const K=(W.freeAreas[R.i].startPosition+W.freeAreas[R.i].endPosition)/2,j=K-d,ot=K+d;return[...R.i<1?[]:kt(0,R.i,q),...W.freeAreas[R.i].startPosition<=j?[{startPosition:W.freeAreas[R.i].startPosition,endPosition:j,size:j-W.freeAreas[R.i].startPosition}]:[],...ot<=W.freeAreas[R.i].endPosition?[{startPosition:ot,endPosition:W.freeAreas[R.i].endPosition,size:W.freeAreas[R.i].endPosition-ot}]:[],...R.i<1?q:kt(R.i,q.length,q)]}return W.freeAreas})(),nextId:W.nextId+1|0}})({segMap:U,freeAreas:(()=>{const W=Et(rt.compare)([...Tt(l.segments)(B=>B.incoming),...Tt(l.segments)(B=>B.outgoing)]);return xt(rx)(be(B=>P=>P-B>=2*d?T("Just",{startPosition:B+d,endPosition:P-d,size:P-B-2*d}):J,W,kt(1,W.length,W)))})(),nextId:l.segments.length})(Et(W=>B=>rt.compare(ht(w(ht)(-1e18)(W.incoming))(w(ht)(-1e18)(W.outgoing))-lt(w(lt)(1e18)(W.incoming))(w(lt)(1e18)(W.outgoing)))(ht(w(ht)(-1e18)(B.incoming))(w(ht)(-1e18)(B.outgoing))-lt(w(lt)(1e18)(B.incoming))(w(lt)(1e18)(B.outgoing))))(xt(W=>It(W)(U))(V.decisions)));return{segments:(()=>{const W=(B,P)=>{if(B.tag==="Leaf")return P;if(B.tag==="Node")return W(B._5,Xt("Cons",B._4,W(B._6,P)));g()};return At(Kt.foldr,W(M.segMap,Ut))})(),deps:(()=>{const W=M.segMap,B=(F,Q)=>{if(F.tag==="Leaf")return Q;if(F.tag==="Node")return B(F._5,Xt("Cons",F._4,B(F._6,Q)));g()},P=At(Kt.foldr,B(W,Ut)),I=P.length;return[...Tt(Tt(zt(0,I-2|0))(F=>Tt(zt(F+1|0,I-1|0))(Q=>[L(F,Q)])))(F=>F._1>=0&&F._1<P.length?F._2>=0&&F._2<P.length?P[F._1].splitPartner.tag!=="Nothing"&&P[F._1].splitPartner.tag==="Just"&&P[F._1].splitPartner._1===P[F._2].id||P[F._2].splitPartner.tag!=="Nothing"&&P[F._2].splitPartner.tag==="Just"&&P[F._2].splitPartner._1===P[F._1].id?[]:o(d,P[F._1],P[F._2]):[]:[]),...Tt(P)(F=>F.splitBy.tag==="Just"&&F.splitPartner.tag==="Just"&&(()=>{const Q=It(F.splitPartner._1)(W);if(Q.tag==="Nothing")return!1;if(Q.tag==="Just")return!0;g()})()&&(()=>{const Q=It(F.splitBy._1)(W);if(Q.tag==="Nothing")return!1;if(Q.tag==="Just")return!0;g()})()?[{src:F.id,tgt:F.splitBy._1,weight:1,kind:Yo},{src:F.splitBy._1,tgt:F.splitPartner._1,weight:1,kind:Yo}]:[])]})()}})(),p=h.segments,m=p.length,y=S=>{let C=S,V=!0,U;for(;V;){const M=C,W=Vt(B=>{const P=It(B)(M.inWeight);if(P.tag==="Nothing")return!0;if(P.tag==="Just")return P._1===0;g()})(M.remaining);if(W.tag==="Nothing"){V=!1,U=M;continue}if(W.tag==="Just"){const B=W._1;C={...M,inWeight:w(P=>I=>bt(nt)(se)(I.tgt)(-I.weight)(P))(M.inWeight)((()=>{const P=It(B)(M.depsBySrc);if(P.tag==="Nothing")return[];if(P.tag==="Just")return P._1;g()})()),marks:Z(nt)(B)(M.nextSource)(M.marks),nextSource:M.nextSource+1|0,outWeight:w(P=>I=>bt(nt)(se)(I.src)(-I.weight)(P))(M.outWeight)((()=>{const P=It(B)(M.depsByTgt);if(P.tag==="Nothing")return[];if(P.tag==="Just")return P._1;g()})()),remaining:ut(P=>P!==B,M.remaining)};continue}g()}return U},x=S=>{let C=S,V=!0,U;for(;V;){const M=C,W=Vt(B=>{const P=It(B)(M.outWeight);if(P.tag==="Nothing")return!0;if(P.tag==="Just")return P._1===0;g()})(M.remaining);if(W.tag==="Nothing"){V=!1,U=M;continue}if(W.tag==="Just"){const B=W._1;C={...M,inWeight:w(P=>I=>bt(nt)(se)(I.tgt)(-I.weight)(P))(M.inWeight)((()=>{const P=It(B)(M.depsBySrc);if(P.tag==="Nothing")return[];if(P.tag==="Just")return P._1;g()})()),marks:Z(nt)(B)(M.nextSink)(M.marks),nextSink:M.nextSink-1|0,outWeight:w(P=>I=>bt(nt)(se)(I.src)(-I.weight)(P))(M.outWeight)((()=>{const P=It(B)(M.depsByTgt);if(P.tag==="Nothing")return[];if(P.tag==="Just")return P._1;g()})()),remaining:ut(P=>P!==B,M.remaining)};continue}g()}return U},N=(S=>{let C=S,V=!0,U;for(;V;){const M=y(x(C));if(M.remaining.length===0){V=!1,U=H(W=>{const B=It(W.id)(M.marks),P=(()=>{if(B.tag==="Nothing")return W.id;if(B.tag==="Just")return B._1;g()})();return{...W,mark:P<m?(P+m|0)+1|0:P}})(p);continue}C=(()=>{const W=P=>{const I=It(P)(M.outWeight),F=It(P)(M.inWeight);return(()=>{if(I.tag==="Nothing")return 0;if(I.tag==="Just")return I._1;g()})()-(()=>{if(F.tag==="Nothing")return 0;if(F.tag==="Just")return F._1;g()})()|0},B=Et(P=>I=>nt.compare(W(I))(W(P)))(M.remaining);if(0<B.length){const P=B[0];return{...M,inWeight:w(I=>F=>bt(nt)(se)(F.tgt)(-F.weight)(I))(M.inWeight)((()=>{const I=It(P)(M.depsBySrc);if(I.tag==="Nothing")return[];if(I.tag==="Just")return I._1;g()})()),marks:Z(nt)(P)(M.nextSource)(M.marks),nextSource:M.nextSource+1|0,outWeight:w(I=>F=>bt(nt)(se)(F.src)(-F.weight)(I))(M.outWeight)((()=>{const I=It(P)(M.depsByTgt);if(I.tag==="Nothing")return[];if(I.tag==="Just")return I._1;g()})()),remaining:ut(I=>I!==P,M.remaining)}}return M})()}return U})({remaining:H(S=>S.id)(p),marks:D,inWeight:w(S=>C=>bt(nt)(se)(C.tgt)(C.weight)(S))(D)(h.deps),outWeight:w(S=>C=>bt(nt)(se)(C.src)(C.weight)(S))(D)(h.deps),depsBySrc:w(S=>C=>bt(nt)(ne)(C.src)([C])(S))(D)(h.deps),depsByTgt:w(S=>C=>bt(nt)(ne)(C.tgt)([C])(S))(D)(h.deps),nextSink:m-1|0,nextSource:m+1|0}),v=(()=>{const S=(()=>{const U=Ur(H(M=>L(M.id,M.mark))(N));return{segments:N,deps:xt(M=>(()=>{if(M.kind==="Critical")return!0;if(M.kind==="Regular")return!1;g()})()?T("Just",M):(()=>{const W=It(M.src)(U),B=It(M.tgt)(U);return(()=>{if(W.tag==="Nothing")return 0;if(W.tag==="Just")return W._1;g()})()>(()=>{if(B.tag==="Nothing")return 0;if(B.tag==="Just")return B._1;g()})()})()?M.weight===0?J:T("Just",{src:M.tgt,tgt:M.src,weight:M.weight,kind:M.kind}):T("Just",M))(h.deps)}})(),C=w(U=>M=>bt(nt)(se)(M.tgt)(1)(U))(D)(S.deps),V=(U=>{let M=U,W=!0,B;for(;W;){const P=M,I=Mt(F=>J,F=>Q=>T("Just",{head:F,tail:Q}),P.queue);if(I.tag==="Nothing"){W=!1,B=P;continue}if(I.tag==="Just"){M=w((()=>{const F=It(I._1.head)(P.slots),Q=(()=>{if(F.tag==="Nothing")return 0;if(F.tag==="Just")return F._1;g()})();return R=>Y=>{const O=It(Y)(R.inDegree),X=(()=>{if(O.tag==="Nothing")return-1;if(O.tag==="Just")return O._1-1|0;g()})();return{...R,slots:Z(nt)(Y)(lf((()=>{const q=It(Y)(R.slots);if(q.tag==="Nothing")return 0;if(q.tag==="Just")return q._1;g()})())(Q+1|0))(R.slots),inDegree:Z(nt)(Y)(X)(R.inDegree),queue:X===0?[...R.queue,Y]:R.queue}}})())({...P,queue:I._1.tail})((()=>{const F=It(I._1.head)(P.adj);if(F.tag==="Nothing")return[];if(F.tag==="Just")return F._1;g()})());continue}g()}return B})({slots:Ur(H(U=>L(U.id,0))(S.segments)),inDegree:C,adj:w(U=>M=>bt(nt)(ne)(M.src)([M.tgt])(U))(D)(S.deps),queue:H(U=>U.id)(ut(U=>{const M=It(U.id)(C);if(M.tag==="Nothing")return!0;if(M.tag==="Just")return M._1===0;g()},S.segments))});return Et(U=>M=>nt.compare(U.slot)(M.slot))(H(U=>({...U,slot:(()=>{const M=It(U.id)(V.slots);if(M.tag==="Nothing")return 0;if(M.tag==="Just")return M._1;g()})()}))(S.segments))})(),b=1+w(S=>C=>lf(S)(C.slot))(0)(v)|0,k=Tt(v)(S=>S.members),E=ut(S=>He(hn)(S.edge.id)(k),t),A=w(ht)(-1e18)(H(S=>S.fromPos._2)(E)),$=w(lt)(1e18)(H(S=>S.toPos._2)(E));if(A>$){const S=Ur(H(C=>L(C.id,C))(v));return Ye(H(C=>H(V=>L(V,{slot:C.slot,slotCount:b,gapTop:$,gapBottom:A,partner:(()=>{if(C.splitPartner.tag==="Just"){const U=It(C.splitPartner._1)(S);if(U.tag==="Just")return T("Just",{slot:U._1.slot,splitX:0<U._1.incoming.length?U._1.incoming[0]:0});if(U.tag==="Nothing")return J;g()}if(C.splitPartner.tag==="Nothing")return J;g()})()}))(C.members))(ut(C=>{if(C.splitPartner.tag==="Just"){const V=It(C.splitPartner._1)(S);return!(V.tag==="Just"&&(()=>{if(V._1.splitBy.tag==="Nothing")return!1;if(V._1.splitBy.tag==="Just")return!0;g()})())}if(C.splitPartner.tag==="Nothing")return!0;g()},v)))}const tt=Ur(H(S=>L(S.id,S))(v));return Ye(H(S=>H(C=>L(C,{slot:S.slot,slotCount:b,gapTop:A,gapBottom:$,partner:(()=>{if(S.splitPartner.tag==="Just"){const V=It(S.splitPartner._1)(tt);if(V.tag==="Just")return T("Just",{slot:V._1.slot,splitX:0<V._1.incoming.length?V._1.incoming[0]:0});if(V.tag==="Nothing")return J;g()}if(S.splitPartner.tag==="Nothing")return J;g()})()}))(S.members))(ut(S=>{if(S.splitPartner.tag==="Just"){const C=It(S.splitPartner._1)(tt);return!(C.tag==="Just"&&(()=>{if(C._1.splitBy.tag==="Nothing")return!1;if(C._1.splitBy.tag==="Just")return!0;g()})())}if(S.splitPartner.tag==="Nothing")return!0;g()},v)))})()))(D)(nx(w(u=>s=>{const a=Kr(s.edge.from.node)(n);if(a.tag==="Just"){const c=Kr(s.edge.to.node)(n);return c.tag==="Just"&&a._1.layer!==c._1.layer?bt(nt)(ne)(jr(a._1.layer)(c._1.layer))([s])(u):u}return u})(D)((()=>{const u=s=>L((()=>{const a=Kr(s.edge.from.node)(n);return a.tag==="Just"?a._1.layer:1e6})(),(()=>{const a=Kr(s.edge.from.node)(n);return a.tag==="Just"?a._1.order:1e6})());return Et(s=>a=>ex(u(s))(u(a)))(t)})())))},ox=t=>e=>{const n=pf(t)(e),r=w(i=>o=>Z(G)(o.node)(o)(i))(D)(e);return w(i=>o=>{const u=Kr(o.edge.from.node)(r);if(u.tag==="Just"){const s=Kr(o.edge.to.node)(r);if(s.tag==="Just"&&u._1.layer!==s._1.layer){const a=ix(o.edge.id)(n);if(a.tag==="Just")return Z(nt)(jr(u._1.layer)(s._1.layer))(a._1.slotCount)(i)}return i}return i})(D)(t)},mf=Bt.foldMap((()=>{const t={append:e=>n=>e||n};return{mempty:!1,Semigroup0:()=>t}})()),ge=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},fe=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Gi=t=>e=>n=>r=>mf(i=>n>=i.x&&n<i.x+i.w&&e>i.y&&t<i.y+i.h)(r),Vo=t=>e=>n=>r=>Gi(ge(e)(n))(fe(e)(n))(r)(t),Uo=et(4),ux=fc(t=>{if(t.direction==="H"){const e=ge(t.start._1)(t.end._1);return[{x:e,y:t.start._2-1,w:fe(t.start._1)(t.end._1)-e,h:2}]}if(t.direction==="V"){const e=ge(t.start._2)(t.end._2);return[{x:t.start._1-1,y:e,w:2,h:fe(t.start._2)(t.end._2)-e}]}g()}),Pi=gc(t=>{const e=t.start._1-t.end._1;return!((e<0?-e<1e-6:e<1e-6)&&(()=>{const n=t.start._2-t.end._2;return n<0?-n<1e-6:n<1e-6})())}),sx=t=>e=>n=>{const r=Mt(i=>J,i=>o=>T("Just",{head:i,tail:o}),e);if(r.tag==="Nothing")return[{start:t.start,end:n.end,direction:t.direction}];if(r.tag==="Just"){const i=(r._1.head.direction==="H"?t.direction==="H":r._1.head.direction==="V"&&t.direction==="V")?[{start:t.start,end:r._1.head.end,direction:t.direction}]:[t,r._1.head],o=pr(r._1.tail);if(o.tag==="Nothing"){const u=i.length-1|0;return u>=0&&u<i.length&&(i[u].direction==="H"?n.direction==="H":i[u].direction==="V"&&n.direction==="V")?[...(()=>{const s=i.length-1|0;return s<1?[]:kt(0,s,i)})(),{start:i[u].start,end:n.end,direction:n.direction}]:[...i,n]}if(o.tag==="Just")return(o._1.last.direction==="H"?n.direction==="H":o._1.last.direction==="V"&&n.direction==="V")?[...i,...o._1.init,{start:o._1.last.start,end:n.end,direction:n.direction}]:[...i,...r._1.tail,n]}g()},Ai=t=>{const e=r=>i=>{const o=Mt(u=>J,u=>s=>T("Just",{head:u,tail:s}),i);if(o.tag==="Nothing")return[r];if(o.tag==="Just")return(r.direction==="H"?o._1.head.direction==="H":r.direction==="V"&&o._1.head.direction==="V")&&(()=>{if(r.direction==="H")return r.end._1-r.start._1>=0==o._1.head.end._1-o._1.head.start._1>=0;if(r.direction==="V")return r.end._2-r.start._2>=0==o._1.head.end._2-o._1.head.start._2>=0;g()})()?e({start:r.start,end:o._1.head.end,direction:r.direction})(o._1.tail):[r,...e(o._1.head)(o._1.tail)];g()},n=Mt(r=>J,r=>i=>T("Just",{head:r,tail:i}),t);if(n.tag==="Nothing")return[];if(n.tag==="Just")return e(n._1.head)(n._1.tail);g()},Ii=t=>e=>n=>r=>mf(i=>n>=i.y&&n<i.y+i.h&&e>i.x&&t<i.x+i.w)(r),Qi=t=>e=>n=>r=>Ii(ge(e)(n))(fe(e)(n))(r)(t),ax=t=>e=>n=>r=>{const i=n+2|0,o=i<1?e:kt(i,e.length,e),u=n<1?[]:kt(0,n,e),s=(n+1|0)===(r-1|0),a=n===0,c=n>=0&&n<e.length?T("Just",e[n]):J;if(c.tag==="Just"){const f=n+1|0,d=f>=0&&f<e.length?T("Just",e[f]):J;if(d.tag==="Just"){const l=c._1.start._1===d._1.end._1&&(!a||c._1.direction==="V")&&(!s||d._1.direction==="V")&&!Vo(t)(ge(c._1.start._2)(d._1.end._2))(fe(c._1.start._2)(d._1.end._2))(c._1.start._1)?T("Just",[...u,{start:c._1.start,end:d._1.end,direction:ie},...o]):J,_=c._1.start._2===d._1.end._2&&(!a||c._1.direction==="H")&&(!s||d._1.direction==="H")&&!Qi(t)(ge(c._1.start._1)(d._1.end._1))(fe(c._1.start._1)(d._1.end._1))(c._1.start._2)?T("Just",[...u,{start:c._1.start,end:d._1.end,direction:re},...o]):J;return l.tag==="Nothing"?_:l}if(d.tag==="Nothing")return J;g()}if(c.tag==="Nothing")return J;g()},cx=t=>e=>{const n=e.length;return(r=>{let i=r,o=!0,u;for(;o;){const s=i;if((s+1|0)>=n){o=!1,u=e;continue}const a=ax(t)(e)(s)(n);if(a.tag==="Just"){o=!1,u=a._1;continue}if(a.tag==="Nothing"){i=s+1|0;continue}g()}return u})(0)},gx=t=>e=>n=>r=>{const i=(l,_,h)=>!Vo(t)(ge(_)(h))(fe(_)(h))(l),o=n+3|0,u=o<1?e:kt(o,e.length,e),s=n<1?[]:kt(0,n,e),a=(n+2|0)===(r-1|0),c=n===0,f=(l,_,h)=>!Qi(t)(ge(_)(h))(fe(_)(h))(l),d=n>=0&&n<e.length?T("Just",e[n]):J;if(d.tag==="Just"){const l=n+2|0,_=l>=0&&l<e.length?T("Just",e[l]):J;if(_.tag==="Just"){const h=d._1.start._1===_._1.end._1&&(!c||d._1.direction==="V")&&(!a||_._1.direction==="V")&&i(d._1.start._1,d._1.start._2,_._1.end._2)?T("Just",[...s,{start:d._1.start,end:_._1.end,direction:ie},...u]):d._1.start._2===_._1.end._2&&(!c||d._1.direction==="H")&&(!a||_._1.direction==="H")&&f(d._1.start._2,d._1.start._1,_._1.end._1)?T("Just",[...s,{start:d._1.start,end:_._1.end,direction:re},...u]):J,p=(!c||d._1.direction==="V")&&(!a||_._1.direction==="H")&&i(d._1.start._1,d._1.start._2,_._1.end._2)&&f(_._1.end._2,d._1.start._1,_._1.end._1)?T("Just",[...s,{start:d._1.start,end:L(d._1.start._1,_._1.end._2),direction:ie},{start:L(d._1.start._1,_._1.end._2),end:_._1.end,direction:re},...u]):J,m=(!c||d._1.direction==="H")&&(!a||_._1.direction==="V")&&f(d._1.start._2,d._1.start._1,_._1.end._1)&&i(_._1.end._1,d._1.start._2,_._1.end._2)?T("Just",[...s,{start:d._1.start,end:L(_._1.end._1,d._1.start._2),direction:re},{start:L(_._1.end._1,d._1.start._2),end:_._1.end,direction:ie},...u]):J,y=p.tag==="Nothing"?m:p;return h.tag==="Nothing"?y:h}if(_.tag==="Nothing")return J;g()}if(d.tag==="Nothing")return J;g()},fx=t=>e=>{const n=e.length;return(r=>{let i=r,o=!0,u;for(;o;){const s=i;if((s+2|0)>=n){o=!1,u=e;continue}const a=gx(t)(e)(s)(n);if(a.tag==="Just"){o=!1,u=a._1;continue}if(a.tag==="Nothing"){i=s+1|0;continue}g()}return u})(0)},_x=t=>{const e=n=>{let r=n,i=!0,o;for(;i;){const u=r,s=Ai(Pi(cx(t)(fx(t)(u))));if(s.length<u.length){r=s;continue}i=!1,o=s}return o};return n=>e(Ai(Pi(n)))},dx=t=>e=>n=>r=>{const i=ge(n)(r),o=fe(n)(r),u=ut(a=>e>=a.y&&e<a.y+a.h&&a.x+a.w>i&&a.x<o,t);if(r>n){const a=Et(c=>f=>rt.compare(c.x)(f.x))(u);return 0<a.length?a[0].x-1:(n+r)/2}const s=Et(a=>c=>rt.compare(c.x)(a.x))(H(a=>({...a,x:a.x+a.w}))(u));return 0<s.length?s[0].x+1:(n+r)/2},lx=t=>e=>n=>r=>{const i=ge(n)(r),o=fe(n)(r),u=ut(a=>e>=a.x&&e<a.x+a.w&&a.y+a.h>i&&a.y<o,t);if(r>n){const a=Et(c=>f=>rt.compare(c.y)(f.y))(u);return 0<a.length?a[0].y-1:(n+r)/2}const s=Et(a=>c=>rt.compare(c.y)(a.y))(H(a=>({...a,y:a.y+a.h}))(u));return 0<s.length?s[0].y+1:(n+r)/2},hx=t=>e=>n=>r=>{const i=ge(n)(r),o=fe(n)(r),u=ut(a=>e>=a.y&&e<a.y+a.h&&a.x+a.w>i&&a.x<o,t);if(r>n){const a=Et(c=>f=>rt.compare(f.x)(c.x))(H(c=>({...c,x:c.x+c.w}))(u));return 0<a.length?a[0].x:(n+r)/2}const s=Et(a=>c=>rt.compare(a.x)(c.x))(u);return 0<s.length?s[0].x-1:(n+r)/2},px=t=>e=>n=>r=>{const i=ge(n)(r),o=fe(n)(r),u=ut(a=>e>=a.x&&e<a.x+a.w&&a.y+a.h>i&&a.y<o,t);if(r>n){const a=Et(c=>f=>rt.compare(f.y)(c.y))(H(c=>({...c,y:c.y+c.h}))(u));return 0<a.length?a[0].y:(n+r)/2}const s=Et(a=>c=>rt.compare(a.y)(c.y))(u);return 0<s.length?s[0].y-1:(n+r)/2},yf=t=>e=>n=>{let r=t,i=e,o=n,u=!0,s;for(;u;){const a=r,c=i,f=o;if(f>100){u=!1,s=c;continue}if(!a(c+f)){u=!1,s=c+f;continue}if(!a(c-f)){u=!1,s=c-f;continue}r=a,i=c,o=f+1}return s},xf=t=>e=>n=>r=>i=>{const o=ge(e)(n),u=fe(e)(n);if(!Gi(o)(u)(r)(t))return r;if(!Gi(o)(u)(i)(t))return i;const s=(r+i)/2;return Gi(o)(u)(s)(t)?yf(a=>Gi(o)(u)(a)(t))(s)(1):s},mx=t=>e=>n=>r=>i=>{const o=ge(e)(n),u=fe(e)(n);if(!Ii(o)(u)(r)(t))return r;if(!Ii(o)(u)(i)(t))return i;const s=(r+i)/2;return Ii(o)(u)(s)(t)?yf(a=>Ii(o)(u)(a)(t))(s)(1):s},yx=t=>e=>n=>r=>{const i=ge(e)(n),o=fe(e)(n),u=ut(c=>r>=c.x&&r<c.x+c.w&&c.y+c.h>i&&c.y<o,t),s=w(c=>f=>fe(c)(f.x+f.w+4))(r+4)(u),a=w(c=>f=>ge(c)(f.x-4))(r-4)(u);return(()=>{const c=s-r,f=a-r;return(c<0?-c:c)<=(f<0?-f:f)})()?s:a},xx=t=>e=>n=>r=>{const i=ge(e)(n),o=fe(e)(n),u=ut(c=>r>=c.y&&r<c.y+c.h&&c.x+c.w>i&&c.x<o,t),s=w(c=>f=>fe(c)(f.y+f.h+4))(r+4)(u),a=w(c=>f=>ge(c)(f.y-4))(r-4)(u);return(()=>{const c=s-r,f=a-r;return(c<0?-c:c)<=(f<0?-f:f)})()?s:a},Nx=t=>e=>n=>r=>i=>o=>u=>{const s=(()=>{if(r==="South")return L(i._1,i._2+4);if(r==="North")return L(i._1,i._2-4);if(r==="East")return L(i._1+4,i._2);if(r==="West")return L(i._1-4,i._2);g()})(),a=(()=>{if(o==="South")return L(u._1,u._2+4);if(o==="North")return L(u._1,u._2-4);if(o==="East")return L(u._1+4,u._2);if(o==="West")return L(u._1-4,u._2);g()})(),c=(b,k,E)=>!Vo(e)(ge(k)(E))(fe(k)(E))(b),f=(b,k,E)=>!Vo(n)(ge(k)(E))(fe(k)(E))(b),d=(b,k,E,A)=>t.tag==="Just"&&!Qi(n)(ge(b)(k))(fe(b)(k))(t._1)?t._1:mx(e)(b)(k)(E)(A),l=(b,k,E,A)=>{if(b===E){const tt=yx(e)(k)(A)(b),S=lx(e)(b)(k)(A),C=px(e)(b)(k)(A);return[{start:L(b,k),end:L(b,S),direction:ie},{start:L(b,S),end:L(tt,S),direction:re},{start:L(tt,S),end:L(tt,C),direction:ie},{start:L(tt,C),end:L(E,C),direction:re},{start:L(E,C),end:L(E,A),direction:ie}]}const $=d(b,E,k,A);return[{start:L(b,k),end:L(b,$),direction:ie},{start:L(b,$),end:L(E,$),direction:re},{start:L(E,$),end:L(E,A),direction:ie}]},_=(b,k,E,A)=>{if(k===A){const tt=xx(e)(b)(E)(k),S=dx(e)(k)(b)(E),C=hx(e)(k)(b)(E);return[{start:L(b,k),end:L(S,k),direction:re},{start:L(S,k),end:L(S,tt),direction:ie},{start:L(S,tt),end:L(C,tt),direction:re},{start:L(C,tt),end:L(C,A),direction:ie},{start:L(C,A),end:L(E,A),direction:re}]}const $=xf(e)(k)(A)(b)(E);return[{start:L(b,k),end:L($,k),direction:re},{start:L($,k),end:L($,A),direction:ie},{start:L($,A),end:L(E,A),direction:re}]},h=(b,k,E)=>!Qi(e)(ge(k)(E))(fe(k)(E))(b),p=(b,k,E)=>!Qi(n)(ge(k)(E))(fe(k)(E))(b),m=(b,k,E,A)=>{if(p(k,b,E)&&f(E,k,A))return[{start:L(b,k),end:L(E,k),direction:re},{start:L(E,k),end:L(E,A),direction:ie}];const $=xf(e)(k)(A)(b)(E);return[{start:L(b,k),end:L($,k),direction:re},{start:L($,k),end:L($,A),direction:ie},{start:L($,A),end:L(E,A),direction:re}]},y=(b,k,E,A)=>{if(f(b,k,A)&&p(A,b,E))return[{start:L(b,k),end:L(b,A),direction:ie},{start:L(b,A),end:L(E,A),direction:re}];const $=d(b,E,k,A);return[{start:L(b,k),end:L(b,$),direction:ie},{start:L(b,$),end:L(E,$),direction:re},{start:L(E,$),end:L(E,A),direction:ie}]},x=(()=>{if(r==="South")return o==="North"?s._1===a._1&&c(s._1,s._2,a._2)?[{start:L(s._1,s._2),end:L(a._1,a._2),direction:ie}]:l(s._1,s._2,a._1,a._2):o==="East"||o==="West"?y(s._1,s._2,a._1,a._2):l(s._1,s._2,a._1,a._2);if(r==="North")return o==="South"?s._1===a._1&&c(s._1,s._2,a._2)?[{start:L(s._1,s._2),end:L(a._1,a._2),direction:ie}]:l(s._1,s._2,a._1,a._2):o==="East"||o==="West"?y(s._1,s._2,a._1,a._2):l(s._1,s._2,a._1,a._2);if(r==="East")return o==="West"?s._2===a._2&&h(s._2,s._1,a._1)?[{start:L(s._1,s._2),end:L(a._1,a._2),direction:re}]:_(s._1,s._2,a._1,a._2):o==="North"||o==="South"?m(s._1,s._2,a._1,a._2):l(s._1,s._2,a._1,a._2);if(r==="West"){if(o==="East")return s._2===a._2&&h(s._2,s._1,a._1)?[{start:L(s._1,s._2),end:L(a._1,a._2),direction:re}]:_(s._1,s._2,a._1,a._2);if(o==="North"||o==="South")return m(s._1,s._2,a._1,a._2)}return l(s._1,s._2,a._1,a._2)})(),N=(()=>{if(r==="South"||r==="North")return ie;if(r==="East"||r==="West")return re;g()})(),v={start:L(a._1,a._2),end:L(u._1,u._2),direction:(()=>{if(o==="South"||o==="North")return ie;if(o==="East"||o==="West")return re;g()})()};return s._1===a._1&&s._2===a._2?[{start:L(i._1,i._2),end:L(u._1,u._2),direction:N}]:sx({start:L(i._1,i._2),end:L(s._1,s._2),direction:N})(x)(v)},Jx=H(t=>({x:t.position._1*Uo-2,y:t.position._2*Uo-2,w:t.size._1*Uo+4,h:t.size._2*Uo+4})),$s=te(G)(Bt),Wn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Xs=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},wx=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t._1)(o._3._1);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(t._2==="North"){if(o._3._2==="North"){r=!1,i=T("Just",o._4);continue}n=o._5;continue}if(o._3._2==="North"){n=o._6;continue}if(t._2==="South"){if(o._3._2==="South"){r=!1,i=T("Just",o._4);continue}n=o._5;continue}if(o._3._2==="South"){n=o._6;continue}if(t._2==="East"){if(o._3._2==="East"){r=!1,i=T("Just",o._4);continue}n=o._5;continue}if(o._3._2==="East"){n=o._6;continue}if(t._2==="West"&&o._3._2==="West"){r=!1,i=T("Just",o._4);continue}}g()}return i},Nf=t=>e=>{const n=e.position._1+e.size._1,r=e.position._2*2+e.size._2,i=e.position._1*2+e.size._1,o=e.position._2+e.size._2;if(t==="South")return L(i,o*2);if(t==="North")return L(i,e.position._2*2);if(t==="East")return L(n*2,r);if(t==="West")return L(e.position._1*2,r);g()},Ys=t=>e=>{const n=et(4);if(t==="South")return{lo:e.position._1*n,hi:(e.position._1+e.size._1)*n};if(t==="North")return{lo:e.position._1*n,hi:(e.position._1+e.size._1)*n};if(t==="East")return{lo:e.position._2*n,hi:(e.position._2+e.size._2)*n};if(t==="West")return{lo:e.position._2*n,hi:(e.position._2+e.size._2)*n};g()},Jf=t=>e=>w(n=>r=>bt(t)(ne)(e(r))([r])(n))(D),wf=t=>e=>n=>r=>{const i=(t==="South"||t==="North")&&(e==="East"||e==="West")&&(()=>{if(t==="South")return r._2>n._2;if(t==="North")return r._2<n._2;if(t==="East")return r._2>n._2;if(t==="West")return r._2<n._2;g()})()&&(()=>{if(e==="East")return n._1>r._1;if(e==="West"||e==="North")return n._1<r._1;if(e==="South")return n._1>r._1;g()})(),o=(t==="East"||t==="West")&&(e==="North"||e==="South")&&(()=>{if(t==="South")return r._1>n._1;if(t==="North")return r._1<n._1;if(t==="East")return r._1>n._1;if(t==="West")return r._1<n._1;g()})()&&(()=>{if(e==="East")return n._2>r._2;if(e==="West"||e==="North")return n._2<r._2;if(e==="South")return n._2>r._2;g()})();return(t==="South"?e==="North"&&n._1===r._1&&r._2>n._2:t==="North"?e==="South"&&n._1===r._1&&r._2<n._2:t==="East"?e==="West"&&n._2===r._2&&r._1>n._1:t==="West"&&e==="East"&&n._2===r._2&&r._1<n._1)?0:i||o?1:2},Tf=t=>e=>{const n=t.hi-t.lo,r=(t.lo+t.hi)/2,i=e.length;return i===0?D:$s(i===1?H(o=>L(o,r))(e):Ft(o=>u=>L(u,t.lo+et(o+1|0)*n/et(i+1|0)))(e))},vf=t=>e=>n=>r=>i=>{const o=Jf(G)(_=>_.to.node)(t),u=Jf(G)(_=>_.from.node)(t),s=w(_=>h=>Z(G)(h.node)(h)(_))(D)(e),a=(_,h,p)=>{const m=Wn(_)(s);if(m.tag==="Nothing")return L(0,0);if(m.tag==="Just"){const y=Wn(_)(n);if(y.tag==="Nothing"){const x=et(4);if(p==="South")return L(m._1.position._1*x+m._1.size._1*x/2,(m._1.position._2+m._1.size._2)*x);if(p==="North")return L(m._1.position._1*x+m._1.size._1*x/2,m._1.position._2*x);if(p==="East")return L((m._1.position._1+m._1.size._1)*x,m._1.position._2*x+m._1.size._2*x/2);if(p==="West")return L(m._1.position._1*x,m._1.position._2*x+m._1.size._2*x/2);g()}if(y.tag==="Just"){const x=Vt(N=>N.id===h)(y._1);if(x.tag==="Nothing"){const N=et(4);if(p==="South")return L(m._1.position._1*N+m._1.size._1*N/2,(m._1.position._2+m._1.size._2)*N);if(p==="North")return L(m._1.position._1*N+m._1.size._1*N/2,m._1.position._2*N);if(p==="East")return L((m._1.position._1+m._1.size._1)*N,m._1.position._2*N+m._1.size._2*N/2);if(p==="West")return L(m._1.position._1*N,m._1.position._2*N+m._1.size._2*N/2);g()}if(x.tag==="Just"){const N=et(4);if(x._1.side==="North")return L(m._1.position._1*N+et(x._1.offset)*N,m._1.position._2*N);if(x._1.side==="South")return L(m._1.position._1*N+et(x._1.offset)*N,(m._1.position._2+m._1.size._2)*N);if(x._1.side==="East")return L((m._1.position._1+m._1.size._1)*N,m._1.position._2*N+et(x._1.offset)*N);if(x._1.side==="West")return L(m._1.position._1*N,m._1.position._2*N+et(x._1.offset)*N)}}}g()},c=$s(Tt(r)(_=>{if(_.nodes.length<=2)return[];const h=et(4);if(1<_.nodes.length){const p=Wn(_.nodes[1])(s);if(p.tag==="Nothing")return[];if(p.tag==="Just"){const m=p._1.position._1*h+p._1.size._1*h/2;return H(y=>L(y,m))(be(y=>x=>_.edgeId+":"+y+"->"+x,_.nodes,kt(1,_.nodes.length,_.nodes)))}g()}return[]})),f=_=>{const h=Wn(_.from.node)(s),p=Wn(_.to.node)(s);if(h.tag==="Just"&&p.tag==="Just"){const m=h._1,y=p._1,x=Et(N=>v=>nt.compare(N.score)(v.score))(H(N=>{const v=N._1,b=N._2;return{from:v,to:b,score:(()=>{const k=(tt,S,C,V,U)=>{const M=Ys(tt)(S),W=Ys(tt)(C);return M.lo<W.hi&&W.lo<M.hi&&(v==="South"?b==="North"&&U._2>V._2:v==="North"?b==="South"&&U._2<V._2:v==="East"?b==="West"&&U._1>V._1:v==="West"&&b==="East"&&U._1<V._1)?0:wf(v)(b)(V)(U)},E=Nf(v)(m),A=Nf(b)(y),$=wf(v)(b)(E)(A);return(()=>{if($>0){if(v==="South")return b==="North"?k(le,m,y,E,A)*10|0:$*10|0;if(v==="North")return b==="South"?k(de,m,y,E,A)*10|0:$*10|0;if(v==="East")return b==="West"?k(Qn,m,y,E,A)*10|0:$*10|0;if(v==="West"&&b==="East")return k(Dn,m,y,E,A)*10|0}return $*10|0})()+(v==="South"?b==="North"?0:15:v==="North"?b==="South"?0:15:v==="East"?b==="West"?5:15:v==="West"&&b==="East"?5:15)|0})()}})([L(le,de),L(Qn,de),L(Dn,de),L(le,Qn),L(le,Dn),L(de,le),L(de,Qn),L(de,Dn),L(Qn,le),L(Dn,le),L(Qn,Dn),L(Dn,Qn)]));if(0<x.length)return{from:x[0].from,to:x[0].to}}return{from:le,to:de}},d=$s(H(_=>L(_.id,f(_)))(t)),l=(_,h,p,m,y,x)=>{const N=et(4),v=Wn(h)(s);if(v.tag==="Nothing")return L(0,0);if(v.tag==="Just"){const b=wx(L(p,_))(i);if(b.tag==="Just"){const k=v._1.position._1*N+b._1,E=et(4);if(_==="South")return L(k,(v._1.position._2+v._1.size._2)*E);if(_==="North")return L(k,v._1.position._2*E);if(_==="East")return L((v._1.position._1+v._1.size._1)*E,k);if(_==="West")return L(v._1.position._1*E,k);g()}if(b.tag==="Nothing"){const k=Ys(_)(v._1),E=(k.lo+k.hi)/2,A=Xs(p)(Tf(k)(H(S=>S.id)(Et(S=>C=>rt.compare(y(_)(S))(y(_)(C)))(ut(S=>{const C=Xs(S.id)(d);if(C.tag==="Just"){const V=x(C._1);return V==="North"?_==="North":V==="South"?_==="South":V==="East"?_==="East":V==="West"&&_==="West"}if(C.tag==="Nothing")return!0;g()},(()=>{const S=Wn(h)(m);if(S.tag==="Nothing")return[];if(S.tag==="Just")return S._1;g()})()))))),$=(()=>{if(A.tag==="Nothing")return E;if(A.tag==="Just")return A._1;g()})(),tt=et(4);if(_==="South")return L($,(v._1.position._2+v._1.size._2)*tt);if(_==="North")return L($,v._1.position._2*tt);if(_==="East")return L((v._1.position._1+v._1.size._1)*tt,$);if(_==="West")return L(v._1.position._1*tt,$)}}g()};return H(_=>{const h=Xs(_.edge.id)(c);if(h.tag==="Nothing")return _;if(h.tag==="Just")return{..._,fromPos:Je(3)(_.edge.from.node)==="$d:"?L(h._1,_.fromPos._2):_.fromPos,toPos:Je(3)(_.edge.to.node)==="$d:"?L(h._1,_.toPos._2):_.toPos};g()})(H(_=>{if(_.from.port.tag==="Just"&&_.to.port.tag==="Just")return{edge:_,fromPos:a(_.from.node,_.from.port._1,le),toPos:a(_.to.node,_.to.port._1,de),fromSide:le,toSide:de};const h=f(_);return{edge:_,fromPos:l(h.from,_.from.node,_.id,u,p=>m=>{const y=Wn(m.to.node)(s);if(y.tag==="Nothing")return 0;if(y.tag==="Just"){const x=et(4);if(p==="South"||p==="North")return y._1.position._1*x+y._1.size._1*x/2;if(p==="East"||p==="West")return y._1.position._2*x+y._1.size._2*x/2}g()},p=>p.from),toPos:l(h.to,_.to.node,_.id,o,p=>m=>{const y=Wn(m.from.node)(s);if(y.tag==="Nothing")return 0;if(y.tag==="Just"){const x=et(4);if(p==="South"||p==="North")return y._1.position._1*x+y._1.size._1*x/2;if(p==="East"||p==="West")return y._1.position._2*x+y._1.size._2*x/2}g()},p=>p.to),fromSide:h.from,toSide:h.to}})(t))},bf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Zr=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Tx=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),Vs=t=>e=>t.gapTop+1*et(4)+et(e)*2.5*et(4),vx=t=>e=>{const n=bf(e.edge.id)(t);if(n.tag==="Just"){if(n._1.partner.tag==="Just")return T("Just",{slot1Y:Vs(n._1)(n._1.slot),splitX:n._1.partner._1.splitX,slot2Y:Vs(n._1)(n._1.partner._1.slot)});if(n._1.partner.tag==="Nothing")return J;g()}if(n.tag==="Nothing")return J;g()},bx=t=>e=>{const n=w(r=>i=>Z(G)(i.node)(i)(r))(D)(e);return Ye(Ft(r=>i=>{const o=Zr(i.node)(n);if(o.tag==="Nothing")return[];if(o.tag==="Just"){const u=o._1;return Ft(s=>a=>{const c=i.edges.length,f=et(4),d=u.position._1*f,l=u.position._2*f,_=u.size._2*f,h=et((2*c|0)+1|0),p=l+_*et(c-s|0)/h,m=l+_*et((c+1|0)+s|0)/h,y=d-f*2.5*et(s+1|0),x=[{start:L(d,p),end:L(y,p),direction:re},{start:L(y,p),end:L(y,m),direction:ie},{start:L(y,m),end:L(d,m),direction:re}];return{edge:a.id,segments:x,bends:be(N=>v=>N.end,x,kt(1,3,x)),bendType:[],jumps:[],reversed:!1}})(i.edges)}g()})(H(r=>({node:r._1,edges:r._2}))(Tx(w(r=>i=>bt(G)(ne)(i.from.node)([i])(r))(D)(t)))))},Lx=t=>e=>{const n=w(o=>u=>Z(G)(u.node)(u)(o))(D)(e),r=o=>{const u=Zr(o)(n);if(u.tag==="Nothing")return 0;if(u.tag==="Just")return u._1.position._1;g()},i=o=>{const u=Zr(o)(n);if(u.tag==="Nothing")return 0;if(u.tag==="Just")return u._1.layer;g()};return Et(o=>u=>{const s=nt.compare(i(o.edge.from.node))(i(u.edge.from.node));if(s==="EQ"){const a=rt.compare(r(o.edge.from.node))(r(u.edge.from.node));return a==="EQ"?rt.compare(r(o.edge.to.node))(r(u.edge.to.node)):a}return s})(t)},Be=t=>{const e=et(4);return{x:t.position._1*e-2,y:t.position._2*e-2,w:t.size._1*e+4,h:t.size._2*e+4}},kx=t=>t.from.node===t.to.node,Ex=t=>e=>n=>r=>{const i=_x(n)(Nx(t)(e)(n)(r.fromSide)(r.fromPos)(r.toSide)(r.toPos));return{edge:r.edge.id,segments:i,bends:be(o=>u=>o.end,i,kt(1,i.length,i)),bendType:[],jumps:[],reversed:!1}},Sx=t=>e=>n=>r=>{const i=[{start:L(r.fromPos._1,r.fromPos._2),end:L(r.fromPos._1,t.slot1Y),direction:ie},{start:L(r.fromPos._1,t.slot1Y),end:L(t.splitX,t.slot1Y),direction:re},{start:L(t.splitX,t.slot1Y),end:L(t.splitX,t.slot2Y),direction:ie},{start:L(t.splitX,t.slot2Y),end:L(r.toPos._1,t.slot2Y),direction:re},{start:L(r.toPos._1,t.slot2Y),end:L(r.toPos._1,r.toPos._2),direction:ie}];return{edge:r.edge.id,segments:i,bends:be(o=>u=>o.end,i,kt(1,5,i)),bendType:[],jumps:[],reversed:!1}},Cx=t=>e=>n=>{const r=Zr(t.edge.from.node)(n);if(r.tag==="Just"){const o=Zr(t.edge.to.node)(n);return o.tag==="Just"?ut(u=>!(u.h===Be(r._1).h&&u.w===Be(r._1).w&&u.x===Be(r._1).x&&u.y===Be(r._1).y)&&!(u.h===Be(o._1).h&&u.w===Be(o._1).w&&u.x===Be(o._1).x&&u.y===Be(o._1).y),e):ut(u=>!(u.h===Be(r._1).h&&u.w===Be(r._1).w&&u.x===Be(r._1).x&&u.y===Be(r._1).y),e)}const i=Zr(t.edge.to.node)(n);return i.tag==="Just"?ut(o=>!(o.h===Be(i._1).h&&o.w===Be(i._1).w&&o.x===Be(i._1).x&&o.y===Be(i._1).y),e):ut(o=>!0,e)},Gx=t=>e=>{const n=bf(e.edge.id)(t);if(n.tag==="Just")return T("Just",Vs(n._1)(n._1.slot));if(n.tag==="Nothing")return J;g()},Px=t=>e=>n=>r=>i=>{const o=w(c=>f=>Z(G)(f.node)(f)(c))(D)(e),u=Jx(e),s=vf(ut(c=>c.from.node!==c.to.node,t))(e)(n)(r)(i),a=pf(s)(e);return[...bx(ut(kx,t))(e),...w(c=>f=>{const d=Cx(f)(u)(o),l=[...d,...c.edgeObstacles],_=vx(a)(f),h=(()=>{if(_.tag==="Just")return Sx(_._1)(d)(l)(f);if(_.tag==="Nothing")return Ex(Gx(a)(f))(d)(l)(f);g()})();return{results:[...c.results,h],edgeObstacles:[...c.edgeObstacles,...ux(h.segments)]}})({results:[],edgeObstacles:[]})(Lx(s)(e)).results]},sr=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},ar=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Ax=t=>e=>n=>{if(t.start._1!==e.start._1)return J;const r=ar(sr(t.start._2)(t.end._2))(sr(e.start._2)(e.end._2)),i=sr(ar(t.start._2)(t.end._2))(ar(e.start._2)(e.end._2));return r<i?T("Just",{position:L(t.start._1,(r+i)/2),crossingEdge:n}):J},Ix=t=>e=>n=>{if(t.start._2!==e.start._2)return J;const r=ar(sr(t.start._1)(t.end._1))(sr(e.start._1)(e.end._1)),i=sr(ar(t.start._1)(t.end._1))(ar(e.start._1)(e.end._1));return r<i?T("Just",{position:L((r+i)/2,t.start._2),crossingEdge:n}):J},Qx=t=>e=>n=>{if(t.direction==="H")return Ix(t)(e)(n);if(t.direction==="V")return Ax(t)(e)(n);g()},Dx=t=>e=>n=>{const r=t+1|0,i=r<1?n:kt(r,n.length,n);return Tt(e.segments)(o=>Tt(i)(u=>xt(s=>Qx(o)(s)(u.edge))(ut(s=>s.direction==="H"?o.direction==="H":s.direction==="V"&&o.direction==="V",u.segments))))},Fx=t=>e=>n=>e.start._1>sr(t.start._1)(t.end._1)&&e.start._1<ar(t.start._1)(t.end._1)&&t.start._2>sr(e.start._2)(e.end._2)&&t.start._2<ar(e.start._2)(e.end._2)?T("Just",{position:L(e.start._1,t.start._2),crossingEdge:n}):J,zx=t=>e=>Tt(ut(n=>n.direction==="H",t.segments))(n=>Tt(e)(r=>xt(i=>Fx(n)(i)(r.edge))(ut(i=>i.direction==="V",r.segments)))),Bx=t=>e=>n=>[...zx(e)(ut(r=>r.edge!==e.edge,n)),...Dx(t)(e)(n)],Lf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},kf=t=>Je(3)(t)==="$d:",Mx=t=>e=>n=>w(r=>i=>{const o=Lf(i.from.node)(t),u=(()=>{if(o.tag==="Nothing")return 0;if(o.tag==="Just")return o._1;g()})(),s=Lf(i.to.node)(t),a=(()=>{if(s.tag==="Nothing")return-u;if(s.tag==="Just")return s._1-u|0;g()})();if(a<=1)return{...r,edges:[...r.edges,i],chains:[...r.chains,{edgeId:i.id,nodes:[i.from.node,i.to.node]}]};const c=i.id,f=H(l=>"$d:"+c+":"+ue(l))(zt(1,a-1|0)),d=[i.from.node,...f,i.to.node];return{...r,layers:w(l=>_=>{const h=_._2,p=Md(u+_._1|0)(m=>[...m,h])(l);if(p.tag==="Nothing")return l;if(p.tag==="Just")return p._1;g()})(r.layers)(be(ln,zt(1,a-1|0),f)),edges:[...r.edges,...be(l=>_=>({id:c+":"+l+"->"+_,from:{node:l,port:i.from.port},to:{node:_,port:i.to.port},label:J}),d,kt(1,d.length,d))],chains:[...r.chains,{edgeId:i.id,nodes:d}]}})({layers:n,edges:[],chains:[]})(e),Ko=(()=>{const t={eq:e=>n=>e._1===n._1&&(e._2==="North"?n._2==="North":e._2==="South"?n._2==="South":e._2==="East"?n._2==="East":e._2==="West"&&n._2==="West")};return{compare:e=>n=>{const r=G.compare(e._1)(n._1);if(r==="LT")return me;if(r==="GT")return ye;if(e._2==="North")return n._2==="North"?Ie:me;if(n._2==="North")return ye;if(e._2==="South")return n._2==="South"?Ie:me;if(n._2==="South")return ye;if(e._2==="East")return n._2==="East"?Ie:me;if(n._2==="East")return ye;if(e._2==="West"&&n._2==="West")return Ie;g()},Eq0:()=>t}})(),Wx=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=Ko.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Rx=te(G)(Bt),Us=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},qx=te(Ko)(Bt),Ef=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),ti=t=>e=>n=>r=>{const i=Wx(L(e,n))(t);if(i.tag==="Nothing")return r;if(i.tag==="Just")return i._1;g()},Sf=t=>e=>n=>{const r=Rx(Ye(H(u=>Ft(s=>a=>L(a,s))(u))(t))),i=(u,s)=>{if(u==="South"){const a=Us(s.to.node)(r);if(a.tag==="Nothing")return 0;if(a.tag==="Just")return a._1;g()}if(u==="North"){const a=Us(s.from.node)(r);if(a.tag==="Nothing")return 0;if(a.tag==="Just")return a._1;g()}return 0},o=u=>w(s=>a=>Ge(Ko.compare,Se,qx(H(c=>L(L(c._1,u),c._2))(Ef(Tf({lo:0,hi:(()=>{const c=Us(a._1)(n);if(c.tag==="Just")return c._1._1;if(c.tag==="Nothing")return Je(3)(a._1)==="$d:"?0:1;g()})()})(H(c=>c.id)(Et(c=>f=>nt.compare(i(u,c))(i(u,f)))(a._2)))))),s))(D)(Ef(w(s=>a=>a.from.node===a.to.node?s:u==="South"?bt(G)(ne)(a.from.node)([a])(s):u==="North"?bt(G)(ne)(a.to.node)([a])(s):s)(D)(e)));return Ge(Ko.compare,Se,o(de),o(le))},Cf=t=>t,Gf=t=>t,Pf=t=>t,Hx=w(t=>e=>Z(G)(e)()(t))(D),Ox=(()=>{const t=Ue.unfoldr(e=>{if(e.tag==="Nil")return J;if(e.tag==="Cons")return T("Just",L(e._1,e._2));g()});return e=>t((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._3,n(r._6,i)));g()};return n(e,Ut)})())})(),it=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},on=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},vn=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},bn=te(G)(Bt),Ks=pc(G),js=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),$x=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Xx=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Af=Pf("VDown"),If=Pf("VUp"),Yx=Gf("ForwardPhase"),Vx=Gf("StackPhase"),Qf=Cf("HRight"),Df=Cf("HLeft"),Ff=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Ux=t=>e=>n=>{const r=w(u=>s=>bt(G)(se)(s.tgt)(1)(u))(D)(t),i=Ox(Hx([...H(u=>u.src)(t),...H(u=>u.tgt)(t),...(()=>{const u=(s,a)=>{if(s.tag==="Leaf")return a;if(s.tag==="Node")return u(s._5,Xt("Cons",s._4,u(s._6,a)));g()};return At(Kt.foldr,u(e,Ut))})()])),o=w(u=>s=>bt(G)(ne)(s.src)([{target:s.tgt,sep:s.sep}])(u))(D)(t);return(u=>s=>a=>{let c=u,f=s,d=a,l=!0,_;for(;l;){const h=c,p=f,m=d,y=Mt(x=>J,x=>N=>T("Just",{head:x,tail:N}),h);if(y.tag==="Nothing"){l=!1,_=m;continue}if(y.tag==="Just"){const x=it(y._1.head)(m),N=(()=>{if(x.tag==="Nothing")return 0;if(x.tag==="Just")return x._1;g()})(),v=w(b=>k=>{const E=it(k.target)(b.result),A=N+k.sep,$=it(k.target)(b.indeg),tt=(()=>{if($.tag==="Nothing")return-1;if($.tag==="Just")return $._1-1|0;g()})();return{newQueue:tt===0?[...b.newQueue,k.target]:b.newQueue,result:Z(G)(k.target)((()=>{if(E.tag==="Nothing")return A;if(E.tag==="Just"){if(n==="VDown")return on(E._1)(A);if(n==="VUp")return vn(E._1)(A)}g()})())(b.result),indeg:Z(G)(k.target)(tt)(b.indeg)}})({newQueue:[],result:m,indeg:p})((()=>{const b=it(y._1.head)(o);if(b.tag==="Nothing")return[];if(b.tag==="Just")return b._1;g()})());c=[...y._1.tail,...v.newQueue],f=v.indeg,d=v.result;continue}g()}return _})(ut(u=>{const s=it(u)(r);if(s.tag==="Nothing")return!0;if(s.tag==="Just")return s._1===0;g()},i))(r)(w(u=>s=>Z(G)(s)(0)(u))(D)(i))},Kx=t=>{const e=(o,u)=>{if(o.tag==="Leaf")return u;if(o.tag==="Node")return e(o._5,Xt("Cons",o._4,e(o._6,u)));g()},n=At(Kt.foldr,e(t,Ut)),r=w(on)(999999)(n);if(r===0||n.length===0)return t;const i=o=>{if(o.tag==="Leaf")return D;if(o.tag==="Node")return Ot("Node",o._1,o._2,o._3,o._4-r,i(o._5),i(o._6));g()};return i(t)},zf=t=>{const e=(o,u)=>{if(o.tag==="Leaf")return u;if(o.tag==="Node")return e(o._5,Xt("Cons",o._4,e(o._6,u)));g()},n=e(t,Ut),r=o=>u=>{let s=o,a=u,c=!0,f;for(;c;){const d=s,l=a;if(l.tag==="Nil"){c=!1,f=d;continue}if(l.tag==="Cons"){s=vn(d)(l._1),a=l._2;continue}g()}return f},i=o=>u=>{let s=o,a=u,c=!0,f;for(;c;){const d=s,l=a;if(l.tag==="Nil"){c=!1,f=d;continue}if(l.tag==="Cons"){s=on(d)(l._1),a=l._2;continue}g()}return f};return r(-999999)(n)-i(999999)(n)},Di=t=>e=>(n=>r=>{let i=n,o=r,u=!0,s;for(;u;){const a=i,c=o;if(a===e){u=!1,s=c;continue}i=(()=>{const f=it(a)(t.align);if(f.tag==="Nothing")return e;if(f.tag==="Just")return f._1;g()})(),o=[...c,a]}return s})((()=>{const n=it(e)(t.align);if(n.tag==="Nothing")return e;if(n.tag==="Just")return n._1;g()})())([e]),jx=t=>e=>n=>r=>i=>o=>u=>s=>a=>c=>f=>{const d=(P,I,F)=>{const Q=P.from.node===I?P.from.port:P.to.node===I?P.to.port:J;if(Q.tag==="Just"){const R=it(I)(i);if(R.tag==="Just"){const Y=Vt(O=>O.id===Q._1)(R._1);if(Y.tag==="Just"){const O=et(Y._1.offset)*et(4);return F==="North"||F==="South"?O:0}if(Y.tag==="Nothing"){const O=it(I)(r),X=ti(u)(P.id)(F)((()=>{if(O.tag==="Nothing")return .5;if(O.tag==="Just")return O._1._1/2;g()})());return F==="North"||F==="South"?X:0}g()}if(R.tag==="Nothing"){const Y=it(I)(r),O=ti(u)(P.id)(F)((()=>{if(Y.tag==="Nothing")return .5;if(Y.tag==="Just")return Y._1._1/2;g()})());return F==="North"||F==="South"?O:0}g()}if(Q.tag==="Nothing"){const R=it(I)(r),Y=ti(u)(P.id)(F)((()=>{if(R.tag==="Nothing")return .5;if(R.tag==="Just")return R._1._1/2;g()})());return F==="North"||F==="South"?Y:0}g()},l=(P,I)=>{if(P.from.node===I){if(f==="HRight")return le;if(f==="HLeft")return de;g()}if(f==="HRight")return de;if(f==="HLeft")return le;g()},_=(P,I,F)=>w(Q=>R=>Z(G)(R)((()=>{const Y=it(R)(Q);if(Y.tag==="Nothing")return 0+I;if(Y.tag==="Just")return Y._1+I;g()})())(Q))(F)(Di(a)(P)),h=(()=>{if(f==="HRight")return n;if(f==="HLeft")return ve(n);g()})(),p=P=>{const I=it(P)(r);if(I.tag==="Nothing")return 1;if(I.tag==="Just")return I._1._1;g()},m=bn(Ye(Ft(P=>I=>H(F=>L(F,P))(I))(n))),y=(P,I)=>Je(3)(P)==="$d:"&&Je(3)(I)==="$d:"||Je(3)(P)==="$d:"||Je(3)(I)==="$d:"?10:et(t.nodeGap),x=w(P=>I=>Ks(F=>T("Just",[...(()=>{if(F.tag==="Nothing")return[];if(F.tag==="Just")return F._1;g()})(),I]))(I.to.node)(P))(D)(o),N=w(P=>I=>Ks(F=>T("Just",[...(()=>{if(F.tag==="Nothing")return[];if(F.tag==="Just")return F._1;g()})(),I]))(I.from.node)(P))(D)(o),v=Ye(n),b=w(P=>I=>{const F=it(I)(a.root),Q=(()=>{if(F.tag==="Nothing")return I;if(F.tag==="Just")return F._1;g()})();return I===Q?P:Ks(R=>T("Just",(()=>{if(R.tag==="Nothing")return!0;if(R.tag==="Just")return R._1;g()})()&&Je(3)(I)==="$d:"))(Q)(P)})(bn(H(P=>L(P,!0))(Fr(G.compare)((()=>{const P=(I,F)=>{if(I.tag==="Leaf")return F;if(I.tag==="Node")return P(I._5,Xt("Cons",I._4,P(I._6,F)));g()};return At(Kt.foldr,P(a.root,Ut))})()))))(v),k=(P,I)=>{const F=P.free,Q=it(F)(a.root),R=(()=>{if(Q.tag==="Nothing")return F;if(Q.tag==="Just")return Q._1;g()})(),Y=it(R)(b),O=(()=>{if(Y.tag==="Nothing")return!0;if(Y.tag==="Just")return Y._1;g()})();return w(X=>q=>{if(X.edge.tag==="Just")return X;if(X.edge.tag==="Nothing"){if((()=>{const gt=it(R)(I.su);return!O&&(()=>{const yt=it(q.from.node)(m);return q.from.node!==q.to.node&&(()=>{const Ct=it(q.to.node)(m);return(()=>{if(yt.tag==="Nothing")return-1;if(yt.tag==="Just")return yt._1;g()})()===(()=>{if(Ct.tag==="Nothing")return-1;if(Ct.tag==="Just")return Ct._1;g()})()})()})()||(()=>{if(gt.tag==="Nothing")return!1;if(gt.tag==="Just")return gt._1;g()})()})())return X;const K=q.from.node===F?q.to.node:q.from.node,j=it(K)(a.root),ot=(()=>{if(j.tag==="Nothing")return K;if(j.tag==="Just")return j._1;g()})(),_t=ot!==R;return _t&&(()=>{const gt=it(ot)(I.blockFinished);if(gt.tag==="Nothing")return!1;if(gt.tag==="Just")return gt._1;g()})()?{...X,edge:T("Just",q),hasEdges:!0}:{...X,hasEdges:X.hasEdges||_t}}g()})({edge:J,hasEdges:!1})((()=>{if(P.isRoot){if(f==="HRight"){const X=it(F)(x);if(X.tag==="Nothing")return[];if(X.tag==="Just")return X._1;g()}if(f==="HLeft"){const X=it(F)(N);if(X.tag==="Nothing")return[];if(X.tag==="Just")return X._1}g()}if(f==="HRight"){const X=it(F)(N);if(X.tag==="Nothing")return[];if(X.tag==="Just")return X._1;g()}if(f==="HLeft"){const X=it(F)(x);if(X.tag==="Nothing")return[];if(X.tag==="Just")return X._1}g()})())},E=(P,I,F,Q)=>{const R=(()=>{if(c==="VDown")return-1e18;if(c==="VUp")return 1e18;g()})(),Y={free:I,isRoot:F},O=k(Y,Q);if(O.edge.tag==="Nothing")return O.hasEdges?{thresh:R,state:{...Q,queue:[...Q.queue,Y]}}:{thresh:R,state:Q};if(O.edge.tag==="Just"){const X=O.edge._1.from.node===I?O.edge._1.to.node:O.edge._1.from.node;return{thresh:(()=>{const q=it((()=>{const _t=it(X)(a.root);if(_t.tag==="Nothing")return X;if(_t.tag==="Just")return _t._1;g()})())(Q.x),K=it(X)(s),j=it(I)(s),ot=(()=>{if(q.tag==="Just")return q._1;if(q.tag==="Nothing")return J;g()})();return(()=>{if(ot.tag==="Nothing")return 0;if(ot.tag==="Just")return ot._1;g()})()+(()=>{if(K.tag==="Nothing")return 0;if(K.tag==="Just")return K._1;g()})()+d(O.edge._1,X,(()=>{if(F){if(f==="HRight")return le;if(f==="HLeft")return de;g()}if(f==="HRight")return de;if(f==="HLeft")return le;g()})())-(()=>{if(j.tag==="Nothing")return 0;if(j.tag==="Just")return j._1;g()})()-d(O.edge._1,I,(()=>{if(F){if(f==="HRight")return de;if(f==="HLeft")return le;g()}if(f==="HRight")return le;if(f==="HLeft")return de;g()})())})(),state:{...Q,su:Z(G)((()=>{const q=it(O.edge._1.from.node)(a.root);if(q.tag==="Nothing")return O.edge._1.from.node;if(q.tag==="Just")return q._1;g()})())(!0)(Z(G)((()=>{const q=it(O.edge._1.to.node)(a.root);if(q.tag==="Nothing")return O.edge._1.to.node;if(q.tag==="Just")return q._1;g()})())(!0)(Q.su))}}}g()},A=(P,I,F,Q)=>{const R=I===P,Y=it(I)(a.align),O=(()=>{if(Y.tag==="Nothing")return I===P;if(Y.tag==="Just")return Y._1===P;g()})();if(!(R||O))return{thresh:F,state:Q};const X=(()=>{if(c==="VDown")return R&&F<=-1e18;if(c==="VUp")return R&&F>=1e18;g()})()?E(P,I,!0,Q):{thresh:F,state:Q};return(()=>{if(c==="VDown")return X.thresh<=-1e18&&O;if(c==="VUp")return X.thresh>=1e18&&O;g()})()?E(P,I,!1,X.state):X},$=P=>I=>F=>{const Q=it(F)(e.nodeIndex),R=(()=>{if(Q.tag==="Nothing")return 0;if(Q.tag==="Just")return Q._1;g()})(),Y=Vt(j=>He(hn)(F)(j))(h),O=(()=>{if(Y.tag==="Nothing")return[];if(Y.tag==="Just")return Y._1;g()})(),X=O.length;if((()=>{if(c==="VDown")return R<=0;if(c==="VUp")return R>=(X-1|0);g()})()){const j=A(P,F,I.thresh,I.st);return{...I,st:j.state,thresh:j.thresh}}const q=(()=>{if(c==="VDown")return R-1|0;if(c==="VUp")return R+1|0;g()})(),K=q>=0&&q<O.length?T("Just",O[q]):J;if(K.tag==="Nothing")return I;if(K.tag==="Just"){const j=it(K._1)(a.root),ot=(()=>{if(j.tag==="Nothing")return K._1;if(j.tag==="Just")return j._1;g()})(),_t=A(P,F,I.thresh,tt(ot)(I.st)),gt=(()=>{const Lt=it(P)(_t.state.sink);if(Lt.tag==="Nothing")return P===P;if(Lt.tag==="Just")return Lt._1===P;g()})()?{..._t.state,sink:Z(G)(P)((()=>{const Lt=it(ot)(_t.state.sink);if(Lt.tag==="Nothing")return ot;if(Lt.tag==="Just")return Lt._1;g()})())(_t.state.sink)}:_t.state,yt=it(ot)(gt.sink),Ct=(()=>{if(yt.tag==="Nothing")return ot;if(yt.tag==="Just")return yt._1;g()})(),Rt=it(P)(gt.sink),pt=(()=>{if(Rt.tag==="Nothing")return P;if(Rt.tag==="Just")return Rt._1;g()})();if(pt===Ct){const Lt=it(ot)(gt.x),Ht=(()=>{if(Lt.tag==="Just")return Lt._1;if(Lt.tag==="Nothing")return J;g()})(),dn=(()=>{if(Ht.tag==="Nothing")return 0;if(Ht.tag==="Just")return Ht._1;g()})(),Fe=it(P)(gt.x),Pt=(()=>{if(Fe.tag==="Just")return Fe._1;if(Fe.tag==="Nothing")return J;g()})(),Qt=(()=>{if(Pt.tag==="Nothing")return 0;if(Pt.tag==="Just")return Pt._1;g()})(),ze=y(F,K._1),an=it(K._1)(s),Xe=it(F)(s),nn=(()=>{if(an.tag==="Nothing")return 0;if(an.tag==="Just")return an._1;g()})()-(()=>{if(Xe.tag==="Nothing")return 0;if(Xe.tag==="Just")return Xe._1;g()})();if(c==="VDown"){const Ae=vn(dn+nn+p(K._1)+ze)(_t.thresh);return{st:{...gt,x:Z(G)(P)(T("Just",I.initial?Ae:vn(Qt)(Ae)))(gt.x)},initial:!1,thresh:_t.thresh}}if(c==="VUp"){const Ae=on(dn+nn-ze-p(F))(_t.thresh);return{st:{...gt,x:Z(G)(P)(T("Just",I.initial?Ae:on(Qt)(Ae)))(gt.x)},initial:!1,thresh:_t.thresh}}g()}const qt=it(ot)(gt.x),wt=(()=>{if(qt.tag==="Just")return qt._1;if(qt.tag==="Nothing")return J;g()})(),mt=(()=>{if(wt.tag==="Nothing")return 0;if(wt.tag==="Just")return wt._1;g()})(),ft=it(P)(gt.x),st=(()=>{if(ft.tag==="Just")return ft._1;if(ft.tag==="Nothing")return J;g()})(),dt=(()=>{if(st.tag==="Nothing")return 0;if(st.tag==="Just")return st._1;g()})(),at=et(t.nodeGap),ct=it(F)(s),Nt=it(K._1)(s),Jt=(()=>{if(ct.tag==="Nothing")return 0;if(ct.tag==="Just")return ct._1;g()})()-(()=>{if(Nt.tag==="Nothing")return 0;if(Nt.tag==="Just")return Nt._1;g()})();return{st:{...gt,classEdges:[...gt.classEdges,{src:pt,tgt:Ct,sep:(()=>{if(c==="VDown")return dt+Jt-mt-p(K._1)-at;if(c==="VUp")return dt+Jt+p(F)+at-mt;g()})()}]},initial:I.initial,thresh:_t.thresh}}g()},tt=P=>I=>{const F=it(P)(I.x),Q=(()=>{if(F.tag==="Just")return F._1;if(F.tag==="Nothing")return J;g()})();if(Q.tag==="Just")return I;if(Q.tag==="Nothing"){const R=w($(P))({st:{...I,x:Z(G)(P)(T("Just",0))(I.x)},initial:!0,thresh:(()=>{if(c==="VDown")return-1e18;if(c==="VUp")return 1e18;g()})()})(Di(a)(P));return{...R.st,blockFinished:Z(G)(P)(!0)(R.st.blockFinished)}}g()},S=w(P=>I=>w(F=>Q=>{const R=it(Q)(a.root),Y=(()=>{if(R.tag==="Nothing")return Q;if(R.tag==="Just")return R._1;g()})();return Y===Q?tt(Y)(F):F})(P)((()=>{if(c==="VDown")return I;if(c==="VUp")return ve(I);g()})()))({x:bn(H(P=>L(P,J))(v)),sink:bn(H(P=>L(P,P))(v)),classEdges:[],su:D,blockFinished:D,queue:[]})(h),C=Ux(S.classEdges)(S.sink)(c),V=(P,I,F,Q)=>{const R=it(I)(Q),Y=it(I)(s);return(()=>{if(R.tag==="Nothing")return 0;if(R.tag==="Just")return R._1;g()})()+(()=>{if(Y.tag==="Nothing")return 0;if(Y.tag==="Just")return Y._1;g()})()+d(P,I,F)},U=bn(H(P=>L(P,!0))(Fr(G.compare)((()=>{const P=(I,F)=>{if(I.tag==="Leaf")return F;if(I.tag==="Node")return P(I._5,Xt("Cons",I._4,P(I._6,F)));g()};return At(Kt.foldr,P(a.root,Ut))})()))),M=P=>I=>F=>{const Q=k(F,{su:I.su,blockFinished:U}),R={phase:P,ppFree:F.free,ppIsRoot:F.isRoot,edgeId:J,delta:0,avail:0,shift:0,freeSu:(()=>{const Y=it((()=>{const O=it(F.free)(a.root);if(O.tag==="Nothing")return F.free;if(O.tag==="Just")return O._1;g()})())(I.su);if(Y.tag==="Nothing")return!1;if(Y.tag==="Just")return Y._1;g()})(),hasEdges:Q.hasEdges,candCount:(()=>{if(F.isRoot){if(f==="HRight"){const Y=it(F.free)(x);if(Y.tag==="Nothing")return 0;if(Y.tag==="Just")return Y._1.length;g()}if(f==="HLeft"){const Y=it(F.free)(N);if(Y.tag==="Nothing")return 0;if(Y.tag==="Just")return Y._1.length}g()}if(f==="HRight"){const Y=it(F.free)(N);if(Y.tag==="Nothing")return 0;if(Y.tag==="Just")return Y._1.length;g()}if(f==="HLeft"){const Y=it(F.free)(x);if(Y.tag==="Nothing")return 0;if(Y.tag==="Just")return Y._1.length}g()})()};if(Q.edge.tag==="Nothing")return{...I,stack:[...I.stack,F],trace:[...I.trace,R],x:I.x};if(Q.edge.tag==="Just"){const Y=Q.edge._1.from.node===F.free?L(Q.edge._1.from.node,Q.edge._1.to.node):L(Q.edge._1.to.node,Q.edge._1.from.node),O=V(Q.edge._1,Y._1,l(Q.edge._1,Y._1),I.x)-V(Q.edge._1,Y._2,l(Q.edge._1,Y._2),I.x),X=it(Y._1)(a.root),q=(()=>{if(X.tag==="Nothing")return Y._1;if(X.tag==="Just")return X._1;g()})(),K={...R,edgeId:T("Just",Q.edge._1.id),delta:O};if(O>0&&O<1e300){const j=w(gt=>yt=>{const Ct=it(yt)(m),Rt=(()=>{if(Ct.tag==="Nothing")return-1;if(Ct.tag==="Just")return Ct._1;g()})();if(Rt>=0&&Rt<n.length){const wt=n[Rt],mt=it(yt)(e.nodeIndex),ft=(()=>{if(mt.tag==="Nothing")return-2;if(mt.tag==="Just")return mt._1-1|0;g()})();return ft>=0&&ft<wt.length?on(gt)((()=>{const st=it(yt)(I.x),dt=it(yt)(s),at=it(wt[ft])(I.x),ct=it(wt[ft])(s);return(()=>{if(st.tag==="Nothing")return 0;if(st.tag==="Just")return st._1;g()})()+(()=>{if(dt.tag==="Nothing")return 0;if(dt.tag==="Just")return dt._1;g()})()-((()=>{if(at.tag==="Nothing")return 0;if(at.tag==="Just")return at._1;g()})()+(()=>{if(ct.tag==="Nothing")return 0;if(ct.tag==="Just")return ct._1;g()})()+p(wt[ft])+y(yt,wt[ft]))})()):gt}const pt=it(yt)(e.nodeIndex),qt=(()=>{if(pt.tag==="Nothing")return-2;if(pt.tag==="Just")return pt._1-1|0;g()})();return qt>=0&&qt<0?on(gt)((()=>{const wt=it(yt)(I.x),mt=it(yt)(s),ft=it([][qt])(I.x),st=it([][qt])(s);return(()=>{if(wt.tag==="Nothing")return 0;if(wt.tag==="Just")return wt._1;g()})()+(()=>{if(mt.tag==="Nothing")return 0;if(mt.tag==="Just")return mt._1;g()})()-((()=>{if(ft.tag==="Nothing")return 0;if(ft.tag==="Just")return ft._1;g()})()+(()=>{if(st.tag==="Nothing")return 0;if(st.tag==="Just")return st._1;g()})()+p([][qt])+y(yt,[][qt]))})()):gt})(O)(Di(a)(q)),ot=j>0?-j:0,_t={...I,x:j>0?_(q,ot,I.x):I.x,trace:[...I.trace,{...K,avail:j,shift:ot}]};return j>0?_t:{..._t,stack:[..._t.stack,F]}}if(O<0&&-O<1e300){const j=w(gt=>yt=>{const Ct=it(yt)(m),Rt=(()=>{if(Ct.tag==="Nothing")return-1;if(Ct.tag==="Just")return Ct._1;g()})();if(Rt>=0&&Rt<n.length){const wt=n[Rt],mt=it(yt)(e.nodeIndex),ft=(()=>{if(mt.tag==="Nothing")return 0;if(mt.tag==="Just")return mt._1+1|0;g()})();return ft>=0&&ft<wt.length?on(gt)((()=>{const st=it(wt[ft])(I.x),dt=it(wt[ft])(s),at=it(yt)(I.x),ct=it(yt)(s);return(()=>{if(st.tag==="Nothing")return 0;if(st.tag==="Just")return st._1;g()})()+(()=>{if(dt.tag==="Nothing")return 0;if(dt.tag==="Just")return dt._1;g()})()-((()=>{if(at.tag==="Nothing")return 0;if(at.tag==="Just")return at._1;g()})()+(()=>{if(ct.tag==="Nothing")return 0;if(ct.tag==="Just")return ct._1;g()})()+p(yt)+y(yt,wt[ft]))})()):gt}const pt=it(yt)(e.nodeIndex),qt=(()=>{if(pt.tag==="Nothing")return 0;if(pt.tag==="Just")return pt._1+1|0;g()})();return qt>=0&&qt<0?on(gt)((()=>{const wt=it([][qt])(I.x),mt=it([][qt])(s),ft=it(yt)(I.x),st=it(yt)(s);return(()=>{if(wt.tag==="Nothing")return 0;if(wt.tag==="Just")return wt._1;g()})()+(()=>{if(mt.tag==="Nothing")return 0;if(mt.tag==="Just")return mt._1;g()})()-((()=>{if(ft.tag==="Nothing")return 0;if(ft.tag==="Just")return ft._1;g()})()+(()=>{if(st.tag==="Nothing")return 0;if(st.tag==="Just")return st._1;g()})()+p(yt)+y(yt,[][qt]))})()):gt})(-O)(Di(a)(q)),ot=j>0?j:0,_t={...I,x:j>0?_(q,ot,I.x):I.x,trace:[...I.trace,{...K,avail:j,shift:ot}]};return j>0?_t:{..._t,stack:[..._t.stack,F]}}return{...I,stack:[...I.stack,F],trace:[...I.trace,K],x:I.x}}g()},W=w(M(Yx))({x:bn(H(P=>L(P,(()=>{const I=it(P)(a.root),F=(()=>{if(I.tag==="Nothing")return P;if(I.tag==="Just")return I._1;g()})(),Q=it(F)(S.x),R=it((()=>{const O=it(F)(S.sink);if(O.tag==="Nothing")return F;if(O.tag==="Just")return O._1;g()})())(C),Y=(()=>{if(Q.tag==="Just")return Q._1;if(Q.tag==="Nothing")return J;g()})();return(()=>{if(Y.tag==="Nothing")return 0;if(Y.tag==="Just")return Y._1;g()})()+(()=>{if(R.tag==="Nothing")return 0;if(R.tag==="Just")return R._1;g()})()})()))(v)),su:S.su,stack:[],trace:[]})(S.queue),B=w(M(Vx))({...W,stack:[]})(ve(W.stack));return{x:B.x,queue:S.queue,trace:B.trace}},Zx=t=>e=>n=>r=>i=>o=>u=>s=>a=>c=>f=>jx(t)(e)(n)(r)(i)(o)(u)(s)(a)(c)(f).x,t2=t=>e=>n=>r=>i=>o=>{const u=(a,c,f)=>{const d=it(c)(n),l=(()=>{if(d.tag==="Nothing")return .5;if(d.tag==="Just")return d._1._1/2;g()})(),_=a.from.node===c?a.from.port:a.to.node===c?a.to.port:J;if(_.tag==="Just"){const h=it(c)(e);if(h.tag==="Just"){const p=Vt(m=>m.id===_._1)(h._1);if(p.tag==="Just"){const m=et(p._1.offset)*et(4);return f==="North"||f==="South"?m:0}if(p.tag==="Nothing"){const m=ti(i)(a.id)(f)(l);return f==="North"||f==="South"?m:0}g()}if(h.tag==="Nothing"){const p=ti(i)(a.id)(f)(l);return f==="North"||f==="South"?p:0}g()}if(_.tag==="Nothing"){const h=ti(i)(a.id)(f)(l);return f==="North"||f==="South"?h:0}g()},s=a=>c=>f=>d=>{let l=a,_=c,h=f,p=d,m=!0,y;for(;m;){const x=l,N=_,v=h,b=Mt(k=>J,k=>E=>T("Just",{head:k,tail:E}),p);if(b.tag==="Nothing"){m=!1,y=x;continue}if(b.tag==="Just"){const k=b._1.head,E=Vt($=>$.from.node===v&&$.to.node===k||$.from.node===k&&$.to.node===v)(r),A=(()=>{if(E.tag==="Nothing")return N+0;if(E.tag==="Just")return N+(u(E._1,v,E._1.from.node===v?le:de)-u(E._1,k,E._1.from.node===k?le:de));g()})();l=Z(G)(k)(A)(x),_=A,h=k,p=b._1.tail;continue}g()}return y};return w(a=>c=>{const f=Mt(_=>J,_=>h=>T("Just",{head:_,tail:h}),Di(t)(c)),d=(()=>{if(f.tag==="Nothing")return Z(G)(c)(0)(D);if(f.tag==="Just")return s(Z(G)(f._1.head)(0)(D))(0)(f._1.head)(f._1.tail);g()})(),l=w(_=>h=>vn(_)(-h._2))(0)(js(d));return w(_=>h=>Z(G)(h._1)(h._2+l)(_))(a)(js(d))})(D)(Fr(G.compare)((()=>{const a=(c,f)=>{if(c.tag==="Leaf")return f;if(c.tag==="Node")return a(c._5,Xt("Cons",c._4,a(c._6,f)));g()};return At(Kt.foldr,a(t.root,Ut))})()))},e2=t=>e=>{const n=(i,o,u)=>Je(3)(o)==="$d:"&&cc(kf,(()=>{const s=it(o)(t.preds);if(s.tag==="Nothing")return[];if(s.tag==="Just")return s._1;g()})()),r=i=>o=>u=>s=>a=>c=>f=>{let d=i,l=o,_=s,h=c,p=f,m=!0,y;for(;m;){const x=d,N=l,v=_,b=h,k=p,E=N.length;if(k>=E){m=!1,y=x;continue}const A=k>=0&&k<N.length?T("Just",N[k]):J,$=(()=>{if(A.tag==="Nothing")return"";if(A.tag==="Just")return A._1;g()})(),tt=n(t,$);if(k===(E-1|0)||tt){const S=(()=>{if(tt){const C=it($)(t.preds),V=(()=>{if(C.tag==="Nothing")return[];if(C.tag==="Just")return C._1;g()})();if(0<V.length){const U=v-1|0,M=it(V[0])(t.nodeIndex);if(M.tag==="Nothing")return U;if(M.tag==="Just")return M._1;g()}}return v-1|0})();d=w(C=>V=>{if(V>=0&&V<N.length){const U=N[V];return n(t,U)?C:w(M=>W=>{const B=it(W)(t.nodeIndex),P=(()=>{if(B.tag==="Nothing")return 0;if(B.tag==="Just")return B._1;g()})();return P<b||P>S?Z(G)(W+"\u2192"+U)()(M):M})(C)((()=>{const M=it(U)(t.preds);if(M.tag==="Nothing")return[];if(M.tag==="Just")return M._1;g()})())}return n(t,"")?C:w(U=>M=>{const W=it(M)(t.nodeIndex),B=(()=>{if(W.tag==="Nothing")return 0;if(W.tag==="Just")return W._1;g()})();return B<b||B>S?Z(G)(M+"\u2192")()(U):U})(C)((()=>{const U=it("")(t.preds);if(U.tag==="Nothing")return[];if(U.tag==="Just")return U._1;g()})())})(x)(zt(0,k)),l=N,_=v,h=S,p=k+1|0;continue}d=x,l=N,_=v,h=b,p=k+1|0}return y};return e.length<3?D:w(i=>o=>{if(o>=0&&o<e.length){const u=e[o];return r(i)((()=>{const s=o+1|0;return s>=0&&s<e.length?e[s]:[]})())(u)(u.length)(o)(0)(0)}return r(i)((()=>{const u=o+1|0;return u>=0&&u<e.length?e[u]:[]})())([])(0)(o)(0)(0)})(D)(zt(1,e.length-2|0))},n2=t=>e=>n=>r=>i=>{const o=Ye(e),u=w(s=>a=>{const c=w(f=>d=>{const l=(()=>{if(i==="HRight"){const m=it(d)(t.preds);if(m.tag==="Nothing")return[];if(m.tag==="Just")return m._1;g()}if(i==="HLeft"){const m=it(d)(t.succs);if(m.tag==="Nothing")return[];if(m.tag==="Just")return m._1}g()})(),_=l.length;if(_===0)return f;const h=An(_-1|0,2),p=An(_,2);return w(m=>y=>{if((()=>{const x=it(d)(m.align);if(x.tag==="Nothing")return d!==d;if(x.tag==="Just")return x._1!==d;g()})())return m;if(y>=0&&y<l.length){const x=it(l[y])(t.nodeIndex),N=(()=>{if(x.tag==="Nothing")return 0;if(x.tag==="Just")return x._1;g()})();if(!(Ff(l[y]+"\u2192"+d)(n)||Ff(d+"\u2192"+l[y])(n))&&(()=>{if(r==="VDown")return m.r<N;if(r==="VUp")return m.r>N;g()})()){const v=it(l[y])(m.root),b=(()=>{if(v.tag==="Nothing")return l[y];if(v.tag==="Just")return v._1;g()})();return{root:Z(G)(d)(b)(m.root),align:Z(G)(l[y])(d)(Z(G)(d)(b)(m.align)),r:N}}}return m})(f)((()=>{if(r==="VDown")return zt(h,p);if(r==="VUp")return ve(zt(h,p));g()})())})({root:s.root,align:s.align,r:(()=>{if(r==="VDown")return-1;if(r==="VUp")return 999999;g()})()})((()=>{if(r==="VDown")return a;if(r==="VUp")return ve(a);g()})());return{root:c.root,align:c.align}})({root:bn(H(s=>L(s,s))(o)),align:bn(H(s=>L(s,s))(o))})((()=>{if(i==="HRight")return e;if(i==="HLeft")return ve(e);g()})());return{root:u.root,align:u.align}},jo=t=>e=>n=>r=>i=>o=>u=>s=>a=>c=>{const f=n2(e)(n)(s)(a)(c),d=t2(f)(i)(r)(o)(u)(c);return Zd()(l=>_=>T("Just",(()=>{const h=it(l)(d);if(h.tag==="Nothing")return _+0;if(h.tag==="Just")return _+h._1;g()})()))(Zx(t)(e)(n)(r)(i)(o)(u)(d)(f)(a)(c))},Bf=t=>e=>Ft(n=>r=>w(i=>o=>o>=0&&o<e.length?o>=0&&o<t.length?i+e[o]+t[o]:i+e[o]+0:o>=0&&o<t.length?i+1+t[o]:i+1)(0)((()=>{const i=zt(0,e.length-1|0);return n<1?[]:kt(0,n,i)})()))(e),r2=t=>e=>n=>r=>i=>o=>u=>{const s=$x(0)(e.length-1|0),a=et(t.layerGap),c=u(Dd(s,a)),f=ox(vf(i)(c)(r)(o)(D))(c);return H(d=>{const l=Xx(d)(f);return l.tag==="Just"&&l._1>0?vn(a)(2+et(l._1-1|0)*2.5):a})(zt(0,s-1|0))},Mf=t=>e=>n=>r=>cc(i=>w(o=>u=>{if(!o.ok)return o;const s=it(u)(r),a=(()=>{if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})(),c=it(u)(n),f=(()=>{if(c.tag==="Nothing")return a+1;if(c.tag==="Just")return a+c._1._1;g()})();return a+1e-4>o.pos&&f+1e-4>o.pos?{ok:!0,pos:f}:{ok:!1,pos:o.pos}})({ok:!0,pos:-1e18})(i).ok,e),i2=t=>e=>n=>r=>{const i=Et(o=>u=>rt.compare(o.w)(u.w))(H(o=>({l:o,w:zf(o)}))(ut(Mf()(e)(n),r)));return 0<i.length?T("Just",i[0].l):J},o2=t=>e=>{const n=bn(Ye(H(Ft(i=>o=>L(o,i)))(t))),r=i=>Et(o=>u=>nt.compare((()=>{const s=it(o)(n);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})())((()=>{const s=it(u)(n);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})()))(i);return{preds:(()=>{const i=o=>{if(o.tag==="Leaf")return D;if(o.tag==="Node")return Ot("Node",o._1,o._2,o._3,r(o._4),i(o._5),i(o._6));g()};return i(w(o=>u=>bt(G)(ne)(u.to.node)([u.from.node])(o))(D)(e))})(),succs:(()=>{const i=o=>{if(o.tag==="Leaf")return D;if(o.tag==="Node")return Ot("Node",o._1,o._2,o._3,r(o._4),i(o._5),i(o._6));g()};return i(w(o=>u=>bt(G)(ne)(u.from.node)([u.to.node])(o))(D)(e))})(),nodeIndex:n}},u2=t=>e=>{const n=Et(d=>l=>rt.compare(d.w)(l.w))(Ft(d=>l=>({i:d,l,w:zf(l)}))(e)),r=0<n.length?T("Just",n[0]):J,i=(()=>{if(r.tag==="Just")return r._1.i;if(r.tag==="Nothing")return 0;g()})(),o=i>=0&&i<e.length?T("Just",e[i]):J,u=(()=>{if(o.tag==="Just")return(d=>l=>{let _=d,h=l,p=!0,m;for(;p;){const y=_,x=h;if(x.tag==="Nil"){p=!1,m=y;continue}if(x.tag==="Cons"){_=on(y)(x._1),h=x._2;continue}g()}return m})(999999)((()=>{const d=(l,_)=>{if(l.tag==="Leaf")return _;if(l.tag==="Node")return d(l._5,Xt("Cons",l._4,d(l._6,_)));g()};return d(o._1,Ut)})());if(o.tag==="Nothing")return 0;g()})(),s=d=>w(l=>_=>vn(l)((()=>{const h=it(_._1)(t);if(h.tag==="Nothing")return _._2+1;if(h.tag==="Just")return _._2+h._1._1;g()})()))(-999999)(js(d)),a=i>=0&&i<e.length?T("Just",e[i]):J,c=(()=>{if(a.tag==="Just")return s(a._1);if(a.tag==="Nothing")return 0;g()})(),f=be(d=>l=>{const _=h=>{if(h.tag==="Leaf")return D;if(h.tag==="Node")return Ot("Node",h._1,h._2,h._3,h._4+l,_(h._5),_(h._6));g()};return _(d)},e,Ft(d=>l=>Kn(d)(2)===0?u-(_=>h=>{let p=_,m=h,y=!0,x;for(;y;){const N=p,v=m;if(v.tag==="Nil"){y=!1,x=N;continue}if(v.tag==="Cons"){p=on(N)(v._1),m=v._2;continue}g()}return x})(999999)((()=>{const _=(h,p)=>{if(h.tag==="Leaf")return p;if(h.tag==="Node")return _(h._5,Xt("Cons",h._4,_(h._6,p)));g()};return _(l,Ut)})()):c-s(l))(e));return Kx(w(d=>l=>{const _=Et(rt.compare)(xt(it(l))(f));return Z(G)(l)(_.length===4?1<_.length&&2<_.length?(_[1]+_[2])/2:0:0<_.length?_[0]:0)(d)})(D)(Fr(G.compare)(Ye(H(d=>{const l=_=>{if(_.tag==="Leaf")return D;if(_.tag==="Node")return Ot("Node",_._1,_._2,_._3,void 0,l(_._5),l(_._6));g()};return At($e.foldr,l(d))})(f)))))},s2=t=>e=>n=>r=>i=>o=>{const u=o2(e)(i),s=e2(u)(e),a={nodeGap:t.nodeGap*4|0},c=Ge(G.compare,Se,bn(H(_=>L(_,L(1,1)))(ut(kf,Ye(e)))),(()=>{const _=h=>{if(h.tag==="Leaf")return D;if(h.tag==="Node")return Ot("Node",h._1,h._2,h._3,L(h._4._1*et(4),h._4._2),_(h._5),_(h._6));g()};return _(n)})()),f=[jo(a)(u)(e)(c)(r)(i)(o)(s)(Af)(Qf),jo(a)(u)(e)(c)(r)(i)(o)(s)(If)(Qf),jo(a)(u)(e)(c)(r)(i)(o)(s)(Af)(Df),jo(a)(u)(e)(c)(r)(i)(o)(s)(If)(Df)],d=u2(c)(f);if(Mf()(e)(c)(d))return d;const l=i2()(e)(c)(f);if(l.tag==="Just")return l._1;if(l.tag==="Nothing")return f[0];g()},a2=t=>e=>n=>r=>{const i=uc(J,Za,o=>o.node===e?T("Just",o.position):J,t);if(i.tag==="Nothing")return t;if(i.tag==="Just"){const o=i._1;return H(u=>u.node===n?{...u,position:L(o._1+r._1,o._2+r._2)}:u)(t)}g()},c2=t=>e=>n=>r=>{const i=ut(u=>He(hn)(u.node)(e),t),o=(()=>{if(n==="Vertical"){if(r==="Start")return w(u=>s=>on(u)(s.position._1))(99999)(i);if(r==="End")return w(u=>s=>vn(u)(s.position._1))(0)(i);if(r==="Center"){const u=w(s=>a=>s+a.position._1)(0)(i);return i.length===0?0:u/et(i.length)}g()}if(n==="Horizontal"){if(r==="Start")return w(u=>s=>on(u)(s.position._2))(99999)(i);if(r==="End")return w(u=>s=>vn(u)(s.position._2))(0)(i);if(r==="Center"){const u=w(s=>a=>s+a.position._2)(0)(i);return i.length===0?0:u/et(i.length)}}g()})();return H(u=>{if(He(hn)(u.node)(e)){if(n==="Vertical")return{...u,position:L(o,u.position._2)};if(n==="Horizontal")return{...u,position:L(u.position._1,o)};g()}return u})(t)},g2=t=>e=>w(n=>r=>r.tag==="AlignGroup"?c2(n)(r._1.nodes)(r._1.axis)(r._1.alignment):r.tag==="RelativePosition"?a2(n)(r._1.anchor)(r._1.target)(r._1.offset):n)(e)(t),f2=t=>e=>n=>r=>i=>o=>u=>s=>{const a=H(d=>w(l=>_=>vn(l)((()=>{const h=it(_)(r);if(h.tag==="Nothing")return 1;if(h.tag==="Just")return h._1._2;g()})()))(1)(d))(n),c=s2(t)(n)(r)(i)(o)(s),f=Bf(r2(t)(n)(r)(i)(o)(u)(d=>{const l=Bf(d)(a);return Ye(Ft(_=>h=>Ft(p=>m=>({node:m,position:L((()=>{const y=it(m)(c);return(()=>{if(y.tag==="Nothing")return 0;if(y.tag==="Just")return y._1;g()})()/et(4)})(),_>=0&&_<l.length?l[_]:0),size:(()=>{const y=Je(3)(m)==="$d:"?L(0,1):L(1,1),x=it(m)(r);if(x.tag==="Nothing")return y;if(x.tag==="Just")return x._1;g()})(),layer:_,order:p}))(h))(n))}))(a);return g2(e)(Ye(Ft(d=>l=>Ft(_=>h=>({node:h,position:L((()=>{const p=it(h)(c);return(()=>{if(p.tag==="Nothing")return 0;if(p.tag==="Just")return p._1;g()})()/et(4)})(),d>=0&&d<f.length?f[d]:0),size:(()=>{const p=Je(3)(h)==="$d:"?L(0,1):L(1,1),m=it(h)(r);if(m.tag==="Nothing")return p;if(m.tag==="Just")return m._1;g()})(),layer:d,order:_}))(l))(n)))},Zs=os(lo)(wr(32)),Wf=os(lo)(wr(31)),Fi=(()=>{const t=Ul("25214903917");if(t.tag==="Nothing")return Lc;if(t.tag==="Just")return t._1;g()})(),zi=is(os(lo)(wr(48)))(lo),_2=t=>{const e=Kl(t);return Ji(kc((()=>{if(e.tag==="Nothing")return Lc;if(e.tag==="Just")return e._1;g()})())(Fi))(zi)},ta=wr(11),Zo=t=>e=>{const n=Ji(fo(_o(e)(Fi))(ta))(zi);return L((()=>{const r=dc($l(us(n)(wr(48-t|0))));if(r.tag==="Nothing")return 0;if(r.tag==="Just")return r._1;g()})(),n)},d2=t=>{const e=Zo(26)(t),n=Zo(27)(e._2);return L((et(e._1)*Wu(2)(27)+et(n._1))/Wu(2)(53),n._2)},l2=t=>e=>{const n=w(r=>i=>{const o=d2(r.finalR);return{rs:[...r.rs,o._1],finalR:o._2}})({rs:[],finalR:t})(e);return L(H(r=>r.x)(Et(r=>i=>rt.compare(r.k)(i.k))(be(r=>i=>({x:r,k:i}),e,n.rs))),n.finalR)},h2=t=>{const e=Ji(fo(_o(t)(Fi))(ta))(zi),n=Ji(fo(_o(e)(Fi))(ta))(zi);return L(fo(_o((()=>{const r=us(e)(wr(16));return Ec.compare(r)(Wf)!=="LT"?is(r)(Zs):r})())(Zs))((()=>{const r=us(n)(wr(16));return Ec.compare(r)(Wf)!=="LT"?is(r)(Zs):r})()),n)},Bi=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},tu=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},ea=te(G)(Bt),ei=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},eu=te(G)(Bt),p2=Bu(fi),m2=w(Mr)(0),y2=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Rf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},x2=t=>e=>n=>{if(t>=0&&t<n.length){const r=n[t];if(e>=0&&e<n.length){const i=Un(Zt,J,t,n[e],n);if(i.tag==="Just")return Un(Zt,J,e,r,i._1);if(i.tag==="Nothing")return J;g()}}return J},N2=t=>e=>n=>r=>i=>ea(w(o=>u=>{const s=Et(a=>c=>nt.compare((()=>{const f=Bi(a.id)(i);if(f.tag==="Nothing")return 1e6;if(f.tag==="Just")return f._1;g()})())((()=>{const f=Bi(c.id)(i);if(f.tag==="Nothing")return 1e6;if(f.tag==="Just")return f._1;g()})()))(ut(a=>tu(a.to.node)(n),ut(a=>a.from.node===u,r)));return{ranks:[...o.ranks,...Ft(a=>c=>L(c.id,et((o.rankSum+a|0)+1|0)))(s)],rankSum:o.rankSum+s.length|0}})({ranks:[],rankSum:0})(t).ranks),J2=t=>e=>n=>r=>i=>ea(w(o=>u=>{const s=Et(c=>f=>{const d=nt.compare((()=>{const l=ei(f.from.node)(n);if(l.tag==="Nothing")return-1;if(l.tag==="Just")return l._1;g()})())((()=>{const l=ei(c.from.node)(n);if(l.tag==="Nothing")return-1;if(l.tag==="Just")return l._1;g()})());return d==="EQ"?nt.compare((()=>{const l=Bi(c.id)(i);if(l.tag==="Nothing")return 1e6;if(l.tag==="Just")return l._1;g()})())((()=>{const l=Bi(f.id)(i);if(l.tag==="Nothing")return 1e6;if(l.tag==="Just")return l._1;g()})()):d})(ut(c=>tu(c.from.node)(n),ut(c=>c.to.node===u,r))),a=s.length;return{ranks:[...o.ranks,...Ft(c=>f=>L(f.id,et((o.rankSum+a|0)-c|0)))(s)],rankSum:o.rankSum+a|0}})({ranks:[],rankSum:0})(t).ranks),na=t=>e=>n=>{const r=eu(Ft(s=>a=>L(a,s))(t)),i=eu(Ft(s=>a=>L(a,s))(e)),o=xt(s=>{const a=ei(s.from.node)(r),c=ei(s.to.node)(i);if(a.tag==="Just"&&c.tag==="Just")return T("Just",L(a._1,c._1));const f=ei(s.from.node)(i),d=ei(s.to.node)(r);return f.tag==="Just"&&d.tag==="Just"?T("Just",L(d._1,f._1)):J})(n),u=o.length;return w(s=>a=>w(c=>f=>a>=0&&a<o.length&&f>=0&&f<o.length&&((o[a]._1-o[f]._1|0)*(o[a]._2-o[f]._2|0)|0)<0?c+1|0:c)(s)(zt(a+1|0,u-1|0)))(0)(zt(0,u-2|0))},w2=t=>e=>n=>r=>{const i=o=>u=>{let s=o,a=u,c=!0,f;for(;c;){const d=s,l=a;if(l>=(d.length-1|0)){c=!1,f=d;continue}if(l>=0&&l<d.length){const _=l+1|0;if(_>=0&&_<d.length){const h=d[l],p=d[_];if(qe(N=>N.before===h&&N.after===p,r)){s=d,a=l+1|0;continue}const m=Un(Zt,J,l,p,d),y=(()=>{if(m.tag==="Just")return Un(Zt,J,l+1|0,h,m._1);if(m.tag==="Nothing")return J;g()})(),x=(()=>{if(y.tag==="Nothing")return d;if(y.tag==="Just")return y._1;g()})();if(na(e)(x)(n)<na(e)(d)(n)){s=x,a=l+1|0;continue}s=d,a=l+1|0;continue}c=!1,f=d;continue}c=!1,f=d}return f};return(o=>{let u=o,s=!0,a;for(;s;){const c=u,f=i(c)(0);if(p2(f)(c)){s=!1,a=c;continue}u=f}return a})(t)},nu=t=>e=>w(n=>r=>{if(r>=0&&r<t.length){const i=t[r],o=r+1|0;if(o>=0&&o<t.length)return n+na(i)(t[o])(e)|0}return n})(0)(zt(0,t.length-2|0)),T2=(()=>{const t=e=>{if(e.length<7){const o=u=>s=>{let a=u,c=s,f=!0,d;for(;f;){const l=a,_=c,h=_-1|0;if(h>=0&&h<l.length){if(_>=0&&_<l.length&&_>0&&l[h].key>l[_].key){const p=x2(_-1|0)(_)(l);if(p.tag==="Just"){a=p._1,c=_-1|0;continue}if(p.tag==="Nothing"){f=!1,d=l;continue}g()}f=!1,d=l;continue}f=!1,d=l}return d};return w(u=>s=>o(u)(s))(e)(zt(1,e.length-1|0))}const n=An(e.length,2),r=t(kt(0,n,e)),i=t(kt(n,e.length,e));return(o=>u=>s=>{let a=o,c=u,f=s,d=!0,l;for(;d;){const _=a,h=c,p=f;if(h>=0&&h<r.length){if(p>=0&&p<i.length){if(r[h].key>i[p].key){a=Dt(_)(i[p]),c=h,f=p+1|0;continue}a=Dt(_)(r[h]),c=h+1|0,f=p;continue}d=!1,l=[..._,...h<1?r:kt(h,r.length,r)];continue}d=!1,l=[..._,...p<1?i:kt(p,i.length,i)]}return l})([])(0)(0)};return t})(),v2=t=>e=>n=>{const r=xt(c=>c.tag==="OrderConstraint"?T("Just",{before:c._1.before,after:c._1.after}):J)(t.constraints),i=c=>w(f=>d=>{const l=d.after,_=d.before,h=hr(Zt,J,m=>m===_,f),p=hr(Zt,J,m=>m===l,f);if(h.tag==="Just"&&p.tag==="Just"&&h._1>p._1){const m=ac(Zt,J,h._1,f),y=(()=>{if(m.tag==="Nothing")return f;if(m.tag==="Just")return m._1;g()})(),x=sc(Zt,J,p._1,_,y);if(x.tag==="Nothing")return y;if(x.tag==="Just")return x._1;g()}return f})(c)(r),o=ea(Ft(c=>f=>L(f.id,c))(n)),u=(c,f,d)=>{const l=c.length;return w(_=>h=>{const p=f?h-1|0:h+1|0,m=p>=0&&p<_._1.length?T("Just",_._1[p]):J;if(m.tag==="Just"){const y=h>=0&&h<_._1.length?T("Just",_._1[h]):J;if(y.tag==="Just"){const x=eu(Ft(E=>A=>L(A,E))(m._1)),N=eu(Ft(E=>A=>L(A,E))(y._1)),v=f?N2(m._1)(x)(N)(n)(o):J2(m._1)(x)(N)(n)(o),b=w(E=>A=>{const $=xt(S=>Bi(S.id)(v))(ut(f?S=>S.to.node===A._2&&tu(S.from.node)(x):S=>S.from.node===A._2&&tu(S.to.node)(x),n));if($.length===0)return{...E,items:[...E.items,{n:A._2,key:J,origIdx:A._1}]};const tt=Zo(24)(E.r);return{items:[...E.items,{n:A._2,key:T("Just",(m2($)+(et(tt._1)*4172325152040912e-24-.03500000014901161))/et($.length)),origIdx:A._1}],r:tt._2}})({items:[],r:_._2})(Ft(ln)(y._1)),k=Un(Zt,J,h,w2(i(H(E=>E.n)(T2((()=>{const E=b.items,A=$=>tt=>{let S=$,C=tt,V=!0,U;for(;V;){const M=S,W=C;if(M>=0&&M<E.length){if(E[M].key.tag==="Just"){V=!1,U=E[M].key._1;continue}if(E[M].key.tag==="Nothing"){S=M+1|0,C=W;continue}g()}V=!1,U=W}return U};return($=>tt=>S=>{let C=$,V=tt,U=S,M=!0,W;for(;M;){const B=C,P=V,I=U;if(B>=0&&B<E.length){if(E[B].key.tag==="Just"){C=B+1|0,V=E[B].key._1,U=[...I,{n:E[B].n,key:E[B].key._1,origIdx:E[B].origIdx}];continue}if(E[B].key.tag==="Nothing"){const F=(P+A(B+1|0)(P+1))/2;C=B+1|0,V=F,U=[...I,{n:E[B].n,key:F,origIdx:E[B].origIdx}];continue}g()}M=!1,W=I}return W})(0)(-1)([])})()))))(m._1)(n)(r),_._1);if(k.tag==="Just")return L(k._1,b.r);if(k.tag==="Nothing")return L(_._1,_._2);g()}if(y.tag==="Nothing")return L(_._1,_._2);g()}if(m.tag==="Nothing")return L(_._1,_._2);g()})(L(c,d))(f?zt(1,l-1|0):ve(zt(0,l-2|0)))},s=w(c=>f=>Z(G)(f.from.node)()(Z(G)(f.to.node)()(c)))(D)(n),a=w(c=>f=>{if(c.result.crossings===0)return c;const d=x=>N=>v=>b=>{let k=x,E=N,A=v,$=b,tt=!0,S;for(;tt;){const C=k,V=E,U=A,M=$;if(U===0){tt=!1,S={layout:C,crossings:0,random:M};continue}const W=u(C,V,M),B=nu(W._1)(n);if(B<U){k=W._1,E=!V,A=B,$=W._2;continue}tt=!1,S={layout:C,crossings:U,random:W._2}}return S},l=Zo(1)(c.result.random),_=l._1!==0,h=t.modelOrder.tag==="Leaf",p=(c.firstTry||c.secondTry)&&!h?c.firstTry:_,m=(()=>{if(!h){const b=u(e,p,l._2);return d(b._1)(!p)(nu(b._1)(n))(b._2)}const x=p?0:y2(0)(e.length-1|0),N=x>=0&&x<e.length?T("Just",e[x]):J;if(N.tag==="Just"&&N._1.length>1){const b=ut(k=>Rf(k)(s),N._1);if(b.length>1){const k=l2(l._2)(b),E=k._1,A=Un(Zt,J,x,i(w($=>tt=>Rf(tt)(s)?$.idx>=0&&$.idx<E.length?{idx:$.idx+1|0,result:[...$.result,E[$.idx]]}:{idx:$.idx,result:[...$.result,tt]}:{idx:$.idx,result:[...$.result,tt]})({idx:0,result:[]})(N._1).result),e);if(A.tag==="Just"){const $=u(A._1,p,k._2);return d($._1)(!p)(nu($._1)(n))($._2)}}}const v=u(e,p,l._2);return d(v._1)(!p)(nu(v._1)(n))(v._2)})(),y=c.secondTry?!1:c.secondTry;return c.firstTry?{result:m.crossings<c.result.crossings?{layout:m.layout,crossings:m.crossings,random:m.random}:{...c.result,random:m.random},firstTry:!1,secondTry:!0}:{result:m.crossings<c.result.crossings?{layout:m.layout,crossings:m.crossings,random:m.random}:{...c.result,random:m.random},firstTry:c.firstTry,secondTry:y}})({result:{layout:e,crossings:1e9,random:Ji(kc(h2(_2(1))._1)(Fi))(zi)},firstTry:t.modelOrder.tag!=="Leaf",secondTry:!1})(zt(1,t.iterations)).result;return e.length<=0||t.iterations<=0?e:a.layout},b2=t=>t,qf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Me=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},ni=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Mi=(()=>{const t={eq:e=>n=>e._1===n._1&&e._2===n._2};return{compare:e=>n=>{const r=G.compare(e._1)(n._1);return r==="LT"?me:r==="GT"?ye:G.compare(e._2)(n._2)},Eq0:()=>t}})(),L2=te(G)(Bt),k2=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=Mi.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},E2=b2("Greedy"),ra=t=>e=>n=>w(r=>i=>{if(i.from.node===i.to.node)return r;if(i.from.node===e&&!qf(i.to.node)(r.marks)){const o=Me(i.to.node)(r.inDeg),u=(()=>{if(o.tag==="Nothing")return-1;if(o.tag==="Just")return o._1-1|0;g()})(),s=Z(G)(i.to.node)(u)(r.inDeg);return(()=>{const a=Me(i.to.node)(r.outDeg);return u<=0&&(()=>{if(a.tag==="Nothing")return!1;if(a.tag==="Just")return a._1>0;g()})()&&!He(hn)(i.to.node)(r.sources)})()?{...r,inDeg:s,sources:[...r.sources,i.to.node]}:{...r,inDeg:s}}if(i.to.node===e&&!qf(i.from.node)(r.marks)){const o=Me(i.from.node)(r.outDeg),u=(()=>{if(o.tag==="Nothing")return-1;if(o.tag==="Just")return o._1-1|0;g()})(),s=Z(G)(i.from.node)(u)(r.outDeg);return(()=>{const a=Me(i.from.node)(r.inDeg);return u<=0&&(()=>{if(a.tag==="Nothing")return!1;if(a.tag==="Just")return a._1>0;g()})()&&!He(hn)(i.from.node)(r.sinks)})()?{...r,outDeg:s,sinks:[...r.sinks,i.from.node]}:{...r,outDeg:s}}return r})({...n,remaining:ut(r=>r!==e,n.remaining)})(t),S2=w(t=>e=>{if(e.tag==="LayerConstraint"){if(e._1.pin.tag==="SpecificLayer")return Z(G)(e._1.node)(e._1.pin._1)(t);if(e._1.pin.tag==="FirstLayer")return Z(G)(e._1.node)(0)(t);if(e._1.pin.tag==="LastLayer")return Z(G)(e._1.node)(99999)(t)}return t})(D),Hf=t=>e=>n=>{const r=Me(e)(t),i=Me(n)(t);return r.tag==="Just"&&i.tag==="Just"&&r._1>i._1},Of=t=>e=>n=>r=>{if(ni(n)(r.visited)||ni(n)(r.visiting))return r;const i=w(C2(t)(e)(n))({...r,visiting:Z(G)(n)()(r.visiting)})((()=>{const o=Me(n)(e);if(o.tag==="Nothing")return[];if(o.tag==="Just")return o._1;g()})());return{...i,visiting:di(G)(n)(i.visiting),visited:Z(G)(n)()(i.visited)}},C2=t=>e=>n=>r=>i=>Hf(t)(n)(i)?{...r,backEdges:Z(Mi)(L(n,i))()(r.backEdges)}:ni(i)(r.visiting)?{...r,backEdges:Z(Mi)(L(n,i))()(r.backEdges)}:ni(i)(r.visited)?r:Of(t)(e)(i)(r),G2=t=>e=>n=>{const r=l=>{let _=l,h=!0,p;for(;h;){const m=_,y=Mt(x=>J,x=>N=>T("Just",{head:x,tail:N}),m.sinks);if(y.tag==="Just"){_=ra(n)(y._1.head)({...m,sinks:y._1.tail,marks:Z(G)(y._1.head)(m.nextRight)(m.marks),nextRight:m.nextRight-1|0});continue}if(y.tag==="Nothing"){const x=Mt(N=>J,N=>v=>T("Just",{head:N,tail:v}),m.sources);if(x.tag==="Just"){_=ra(n)(x._1.head)({...m,sources:x._1.tail,marks:Z(G)(x._1.head)(m.nextLeft)(m.marks),nextLeft:m.nextLeft+1|0});continue}if(x.tag==="Nothing"){const N=b=>{const k=Me(b)(m.outDeg),E=Me(b)(m.inDeg);return(()=>{if(k.tag==="Nothing")return 0;if(k.tag==="Just")return k._1;g()})()-(()=>{if(E.tag==="Nothing")return 0;if(E.tag==="Just")return E._1;g()})()|0},v=Et(b=>k=>{const E=nt.compare(N(k))(N(b));return E==="EQ"?nt.compare((()=>{const A=Me(b)(e);if(A.tag==="Nothing")return 1e6;if(A.tag==="Just")return A._1;g()})())((()=>{const A=Me(k)(e);if(A.tag==="Nothing")return 1e6;if(A.tag==="Just")return A._1;g()})()):E})(m.remaining);if(0<v.length){const b=v[0];_=ra(n)(b)({...m,remaining:ut(k=>k!==b,m.remaining),marks:Z(G)(b)(m.nextLeft)(m.marks),nextLeft:m.nextLeft+1|0});continue}h=!1,p=m;continue}}g()}return p},i=Fr(G.compare)([...H(l=>l.from.node)(n),...H(l=>l.to.node)(n)]),o=ut(l=>l.from.node!==l.to.node,n),u=w(l=>_=>bt(G)(se)(_.to.node)(1)(l))(D)(o),s=w(l=>_=>bt(G)(se)(_.from.node)(1)(l))(D)(o),a=ut(l=>{const _=Me(l)(u);if(_.tag==="Nothing")return!0;if(_.tag==="Just")return _._1===0;g()},i),c=ut(l=>{const _=Me(l)(s);if(_.tag==="Nothing")return!0;if(_.tag==="Just")return _._1===0;g()},i),f=i.length+1|0,d=w(l=>_=>{const h=Me(_)(l);return h.tag==="Just"&&h._1<0?Z(G)(_)(h._1+f|0)(l):l})(r({remaining:ut(l=>!He(hn)(l)(a)&&!He(hn)(l)(c),i),marks:D,inDeg:u,outDeg:s,sources:a,sinks:c,nextLeft:1,nextRight:-1}).marks)(i);return w(l=>_=>{if(_.from.node===_.to.node)return l;if(Hf(t)(_.from.node)(_.to.node))return Z(Mi)(L(_.from.node,_.to.node))()(l);const h=Me(_.from.node)(d),p=Me(_.to.node)(d);return h.tag==="Just"&&p.tag==="Just"&&h._1>p._1?Z(Mi)(L(_.from.node,_.to.node))()(l):l})(D)(n)},P2=w(t=>e=>bt(G)(ne)(e.from.node)([e.to.node])(t))(D),A2=t=>e=>{const n=P2(e),r=Fr(G.compare)([...H(o=>o.from.node)(e),...H(o=>o.to.node)(e)]),i=w(o=>u=>Z(G)(u.to.node)()(o))(D)(e);return w(o=>u=>Of(t)(n)(u)(o))({visiting:D,visited:D,backEdges:D})([...ut(o=>!ni(o)(i),r),...ut(o=>ni(o)(i),r)]).backEdges},I2=t=>e=>n=>r=>{const i=L2(Ft(s=>a=>L(a,s))(e)),o=S2(n),u=(()=>{if(t==="DepthFirst")return A2(o)(r);if(t==="Greedy")return G2(o)(i)(r);g()})();return{edges:H(s=>k2(L(s.from.node,s.to.node))(u)?{...s,from:s.to,to:s.from}:s)(r),reversedEdges:u}},$f=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Q2=w(t=>e=>Z(G)(e)()(t))(D),ru=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},D2=af(G),Ln=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Xf=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},ia=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=nt.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},F2=te(nt)(Bt),z2=t=>e=>Ge(G.compare,Se,t,e),Yf=Ft(t=>e=>({src:e.src,tgt:e.tgt,delta:1,weight:1,eid:t})),B2=t=>w(e=>n=>({base:(()=>{const r=i=>o=>{let u=i,s=o,a=!0,c;for(;a;){const f=u,d=s;if(d.tag==="Nil"){a=!1,c=f;continue}if(d.tag==="Cons"){u=$f(f)(d._1),s=d._2;continue}g()}return c};return(e.base+r(0)((()=>{const i=(o,u)=>{if(o.tag==="Leaf")return u;if(o.tag==="Node")return i(o._5,Xt("Cons",o._4,i(o._6,u)));g()};return i(n,Ut)})())|0)+1|0})(),result:[...e.result,(()=>{if(e.base===0)return n;const r=i=>{if(i.tag==="Leaf")return D;if(i.tag==="Node")return Ot("Node",i._1,i._2,i._3,i._4+e.base|0,r(i._5),r(i._6));g()};return r(n)})()]}))({base:0,result:[]})(t).result,M2=t=>e=>{const n=Q2(t);return D2(t)(Yf(ut(r=>ru(r.src)(n)&&ru(r.tgt)(n),e)))},W2=t=>e=>{const n=w(i=>o=>bt(G)(ne)(o.tgt)([o.src])(bt(G)(ne)(o.src)([o.tgt])(i)))(D)(e),r=i=>o=>u=>{let s=i,a=o,c=u,f=!0,d;for(;f;){const l=s,_=a,h=c,p=Mt(m=>J,m=>y=>T("Just",{head:m,tail:y}),l);if(p.tag==="Nothing"){f=!1,d={nodes:h};continue}if(p.tag==="Just"){if(ru(p._1.head)(_)){s=p._1.tail,a=_,c=h;continue}s=[...p._1.tail,...(()=>{const m=Ln(p._1.head)(n);if(m.tag==="Nothing")return[];if(m.tag==="Just")return m._1;g()})()],a=Z(G)(p._1.head)()(_),c=[...h,p._1.head];continue}g()}return d};return w(i=>o=>{if(ru(o)(i.visited))return i;const u=r([o])(i.visited)([]);return{...i,visited:w(s=>a=>Z(G)(a)()(s))(i.visited)(u.nodes),components:[...i.components,u.nodes]}})({visited:D,components:[]})(t).components},R2=t=>e=>n=>{const r=w(o=>u=>bt(G)(se)(u.tgt)(1)(o))(D)(e),i=w(o=>u=>bt(G)(se)(u.src)(1)(o))(D)(e);return w(o=>u=>{const s=Ln(u)(r),a=(()=>{if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})();if((()=>{const x=Ln(u)(i);return(()=>{if(x.tag==="Nothing")return a!==0;if(x.tag==="Just")return a!==x._1;g()})()||a===0})())return o;const c=Ln(u)(o.layers),f=(()=>{if(c.tag==="Nothing")return 0;if(c.tag==="Just")return c._1;g()})(),d=o.layers,l=w(x=>N=>N.tgt===u?{...x,mIn:Xf(x.mIn)((()=>{const v=Ln(u)(d),b=Ln(N.src)(d);return(()=>{if(v.tag==="Nothing")return 0;if(v.tag==="Just")return v._1;g()})()-(()=>{if(b.tag==="Nothing")return 0;if(b.tag==="Just")return b._1;g()})()|0})())}:N.src===u?{...x,mOut:Xf(x.mOut)((()=>{const v=Ln(N.tgt)(d),b=Ln(u)(d);return(()=>{if(v.tag==="Nothing")return 0;if(v.tag==="Just")return v._1;g()})()-(()=>{if(b.tag==="Nothing")return 0;if(b.tag==="Just")return b._1;g()})()|0})())}:x)({mIn:1e9,mOut:1e9})(e),_=l.mIn===1e9?-1:l.mIn,h=l.mOut===1e9?-1:l.mOut;if(_<0||h<0)return o;const p=(f-_|0)+1|0,m=(f+h|0)-1|0;if(m<p)return o;const y=w(x=>N=>{const v=ia(N)(o.filling),b=(()=>{if(v.tag==="Nothing")return 0;if(v.tag==="Just")return v._1;g()})();return b<x.bestFill?{best:N,bestFill:b}:x})({best:f,bestFill:(()=>{const x=ia(f)(o.filling);if(x.tag==="Nothing")return 0;if(x.tag==="Just")return x._1;g()})()})(zt(p,m));return y.best===f?o:{layers:Z(G)(u)(y.best)(o.layers),filling:Z(nt)(f)((()=>{const x=ia(f)(o.filling);if(x.tag==="Nothing")return-1;if(x.tag==="Just")return x._1-1|0;g()})())(Z(nt)(y.best)(y.bestFill+1|0)(o.filling))}})({layers:n,filling:F2(H(o=>L(o,w(u=>s=>(()=>{const a=Ln(s)(n);return a.tag==="Nothing"?!1:a.tag==="Just"&&a._1===o})()?u+1|0:u)(0)(t)))(zt(0,w(o=>u=>$f(o)((()=>{const s=Ln(u)(n);if(s.tag==="Nothing")return 0;if(s.tag==="Just")return s._1;g()})()))(0)(t))))})(t).layers},q2=t=>e=>R2(t)(Yf(e))(w(z2)(D)(B2(H(n=>M2(n)(e))(W2(t)(e))))),H2=t=>t,Lr=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},iu=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Vf=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),O2=H2("NetworkSimplex"),$2=t=>e=>w(n=>r=>{const i=w(iu)(0)(xt(o=>Lr(o)(n))(r));return w(o=>u=>Z(G)(u)(i)(o))(n)(r)})(e)(t),X2=t=>e=>({layers:H(n=>ut(r=>{const i=Lr(r)(e);return i.tag==="Nothing"?!1:i.tag==="Just"&&i._1===n},t))(zt(0,(n=>r=>{let i=n,o=r,u=!0,s;for(;u;){const a=i,c=o;if(c.tag==="Nil"){u=!1,s=a;continue}if(c.tag==="Cons"){i=iu(a)(c._1),o=c._2;continue}g()}return s})(0)((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._4,n(r._6,i)));g()};return n(e,Ut)})()))),nodeLayer:e}),Y2=t=>e=>n=>{const r=w(i=>o=>Z(G)(o)(!0)(i))(D)(e);return w(i=>o=>Z(G)(o._1)(o._2)(i))(q2(e)(xt(i=>i.from.node===i.to.node||(()=>{const o=Lr(i.from.node)(r);if(o.tag==="Nothing")return!0;if(o.tag==="Just")return!o._1;g()})()||(()=>{const o=Lr(i.to.node)(r);if(o.tag==="Nothing")return!0;if(o.tag==="Just")return!o._1;g()})()?J:T("Just",{src:i.from.node,tgt:i.to.node}))(t)))(Vf(n))},V2=t=>e=>n=>r=>{const i=s=>a=>{const c=Lr(a)(s);if(c.tag==="Just")return s;if(c.tag==="Nothing"){const f=ut(l=>l!==a,(()=>{const l=Lr(a)(t);if(l.tag==="Nothing")return[];if(l.tag==="Just")return l._1;g()})()),d=w(i)(s)(f);return Z(G)(a)(1+w(iu)(0)(xt(l=>Lr(l)(d))(f))|0)(d)}g()},o=w(i)(D)(n),u=(s=>a=>{let c=s,f=a,d=!0,l;for(;d;){const _=c,h=f;if(h.tag==="Nil"){d=!1,l=_;continue}if(h.tag==="Cons"){c=iu(_)(h._1),f=h._2;continue}g()}return l})(1)((()=>{const s=(a,c)=>{if(a.tag==="Leaf")return c;if(a.tag==="Node")return s(a._5,Xt("Cons",a._4,s(a._6,c)));g()};return s(o,Ut)})());return w(s=>a=>Z(G)(a._1)(a._2)(s))((()=>{const s=a=>{if(a.tag==="Leaf")return D;if(a.tag==="Node")return Ot("Node",a._1,a._2,a._3,u-a._4|0,s(a._5),s(a._6));g()};return s(o)})())(Vf(r))},U2=w(t=>e=>{if(e.tag==="LayerConstraint"){if(e._1.pin.tag==="SpecificLayer")return Z(G)(e._1.node)(e._1.pin._1)(t);if(e._1.pin.tag==="FirstLayer")return Z(G)(e._1.node)(0)(t)}return t})(D),K2=w(t=>e=>bt(G)(ne)(e.to.node)([e.from.node])(t))(D),j2=w(t=>e=>bt(G)(ne)(e.from.node)([e.to.node])(t))(D),Z2=t=>e=>n=>r=>{const i=j2(n),o=K2(n),u=U2(e);return X2(r)($2(xt(s=>s.tag==="SameLayer"?T("Just",s._1.nodes):J)(e))((()=>{if(t==="LongestPath")return V2(i)(o)(r)(u);if(t==="NetworkSimplex")return Y2(n)(r)(u);g()})()))},tN=te(G)(Bt),eN=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Uf=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Kf=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Wi=te(G)(Bt),nN=te(G)(Bt),jf=(()=>{const t=H(e=>({start:e.end,end:e.start,direction:e.direction}));return e=>ve(t(e))})(),rN=t=>e=>n=>r=>{const i=tN(H(u=>L(u.edge,u))(r)),o=u=>0<u.nodes.length&&(()=>{const s=eN(u.edgeId)(n);return s.tag==="Just"&&u.nodes[0]!==s._1._1})();return H(u=>{if(u.nodes.length<=2){const f=Uf(u.edgeId)(i);if(f.tag==="Just"){const d=o(u),l=Ai(Pi(d?jf(f._1.segments):f._1.segments));return{...f._1,edge:u.edgeId,segments:l,bends:be(_=>h=>_.end,l,kt(1,l.length,l)),reversed:d}}if(f.tag==="Nothing")return{edge:u.edgeId,segments:[],bends:[],bendType:[],jumps:[],reversed:!1};g()}const s=Tt(xt(f=>Uf(f)(i))(be(f=>d=>u.edgeId+":"+f+"->"+d,u.nodes,kt(1,u.nodes.length,u.nodes))))(f=>f.segments),a=o(u),c=Ai(Pi(a?jf(s):s));return{edge:u.edgeId,segments:c,bends:be(f=>d=>f.end,c,kt(1,c.length,c)),bendType:[],jumps:[],reversed:a}})(t)},iN={layers:[],edges:[],chains:[]},oN={nodeGap:3,layerGap:2,iterations:8,layerer:O2,cycleBreaker:E2,compactPostRouting:!0,compactionSpacings:Ky},uN=t=>({pos:L(0,0),size:L(w(e=>n=>Kf(e)(n.position._1+n.size._1))(0)(t),w(e=>n=>Kf(e)(n.position._2+n.size._2))(0)(t))}),sN=t=>e=>n=>{const r=Wi(H(c=>L(c.id,c.ports))(e.nodes)),i=ut(c=>Je(3)(c.node)!=="$d:",n.placements),o=rN(n.withDummies.chains)(n.acyclic.reversedEdges)(nN(H(c=>L(c.id,L(c.from.node,c.to.node)))(e.edges)))(Px(n.withDummies.edges)(n.placements)(r)(n.withDummies.chains)(Sf(n.ordered)(ut(c=>c.from.node!==c.to.node,n.withDummies.edges))((()=>{const c=f=>{if(f.tag==="Leaf")return D;if(f.tag==="Node")return Ot("Node",f._1,f._2,f._3,L(f._4._1*4,f._4._2),c(f._5),c(f._6));g()};return c(Wi(H(f=>L(f.id,f.size))(e.nodes)))})()))),u=t.compactPostRouting?tx()(t.compactionSpacings)({nodes:i,edges:e.edges,paths:o,ports:r}):{nodes:i,edges:o},s=H(c=>{const f=Ai(Pi(c.segments));return{...c,segments:f,bends:be(d=>l=>d.end,f,kt(1,f.length,f))}})(u.edges),a=Ft(c=>f=>({...f,jumps:Bx(c)(f)(s)}))(s);return{nodes:u.nodes,edges:a,boundingBox:uN(u.nodes),metrics:Lm(u.nodes)(a)(0)}},aN=t=>e=>n=>{const r=Wi(H(o=>L(o.id,o.size))(e.nodes)),i={...n,placements:f2({nodeGap:t.nodeGap,layerGap:t.layerGap})(e.constraints)(n.ordered)(r)(Wi(H(o=>L(o.id,o.ports))(e.nodes)))(n.withDummies.edges)(n.withDummies.chains)(Sf(n.ordered)(n.withDummies.edges)((()=>{const o=u=>{if(u.tag==="Leaf")return D;if(u.tag==="Node")return Ot("Node",u._1,u._2,u._3,L(u._4._1*4,u._4._2),o(u._5),o(u._6));g()};return o(r)})()))};return{pipeline:i,result:sN(t)(e)(i)}},cN=t=>e=>n=>aN(t)(e)({...n,ordered:v2({iterations:t.iterations,constraints:e.constraints,modelOrder:Wi(Ft(r=>i=>L(i.id,r))(e.nodes))})(n.withDummies.layers)(n.withDummies.edges)}),gN=t=>e=>n=>cN(t)(e)({...n,withDummies:Mx(n.layered.nodeLayer)(n.acyclic.edges)(n.layered.layers)}),fN=t=>e=>{const n=H(i=>i.id)(e.nodes),r=I2(t.cycleBreaker)(n)(e.constraints)(e.edges);return gN(t)(e)({acyclic:r,layered:Z2(t.layerer)(e.constraints)(r.edges)(n),withDummies:iN,ordered:[],placements:[]})},ou=t=>t,_N=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},kr=ou("TopSide"),Er=ou("BottomSide"),Sr=ou("LeftSide"),Cr=ou("RightSide"),dN=t=>{const e=rt.compare(0)(t),n=(()=>{if(e==="LT")return t;if(e==="EQ"||e==="GT")return 0;g()})(),r=rt.compare(1)(n);if(r==="LT"||r==="EQ")return 1;if(r==="GT")return n;g()},Zf=t=>e=>n=>{const r=_N(t.h*.12)(t.w*.2),i=t.w/2;return(e<0?t.y+r:t.y+t.h-r)+e*r*Ce(dN((()=>{const o=(n-(t.x+i))/i;return 1-o*o})()))},We=t=>e=>n=>r=>{let i=t,o=e,u=n,s=r,a=!0,c;for(;a;){const f=i,d=o,l=u,_=s;if(f==="Rectangle"){if(l==="TopSide"){a=!1,c=d.y;continue}if(l==="BottomSide"){a=!1,c=d.y+d.h;continue}if(l==="LeftSide"){a=!1,c=d.x;continue}if(l==="RightSide"){a=!1,c=d.x+d.w;continue}i=er,o=d,u=l,s=_;continue}if(f==="Cylinder"){if(l==="TopSide"){a=!1,c=Zf(d)(-1)(_);continue}if(l==="BottomSide"){a=!1,c=Zf(d)(1)(_);continue}if(l==="LeftSide"){a=!1,c=d.x;continue}if(l==="RightSide"){a=!1,c=d.x+d.w;continue}}i=er,o=d,u=l,s=_}return c},t_=t=>e=>{const n=e.y-t.y,r=n<0?-n:n,i=e.x-(t.x+t.w),o=i<0?-i:i,u=e.x-t.x,s=u<0?-u:u,a=e.y-(t.y+t.h),c=a<0?-a:a;return r<=c&&r<=s&&r<=o?kr:c<=s&&c<=o?Er:s<=o?Sr:Cr},lN=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),oa=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Ri=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},qi=te(G)(Bt),hN=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},pN=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},mN=w(t=>e=>Z(G)(e)()(t))(D),yN=w(t=>e=>Z(G)(e)()(t))(D),uu=lr.traverse(Du),su=te(G)(Bt),xN=t=>e=>Ge(G.compare,Se,t,e),NN=w(t=>e=>Z(G)(e)()(t))(D),JN=te(G)(Bt),wN=t=>e=>Ge(G.compare,Se,t,e),TN=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},e_=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},vN=t=>e=>({...e,edges:qi(H(n=>L(n._1,(()=>{const r=oa(n._1)(t);if(r.tag==="Nothing")return n._2;if(r.tag==="Just"){const i=Ri(r._1._2)(e.nodes),o=Ri(r._1._1)(e.nodes),u=(()=>{if(o.tag==="Nothing")return n._2;if(o.tag==="Just"){const s=Mt(a=>J,a=>c=>T("Just",{head:a,tail:c}),n._2);if(s.tag==="Nothing")return n._2;if(s.tag==="Just")return[(()=>{const a=Mt(l=>J,l=>_=>T("Just",{head:l,tail:_}),s._1.tail),c=a.tag==="Just"?T("Just",a._1.head):J,f={x:o._1.x,y:o._1.y,w:o._1.w,h:o._1.h},d=(()=>{if(c.tag==="Just"){if((c._1.x>s._1.head.x?c._1.x-s._1.head.x<.5:s._1.head.x-c._1.x<.5)&&s._1.head.x>=f.x-.5&&s._1.head.x<=f.x+f.w+.5)return c._1.y>=f.y+f.h?T("Just",Er):c._1.y<=f.y?T("Just",kr):J;if((c._1.y>s._1.head.y?c._1.y-s._1.head.y<.5:s._1.head.y-c._1.y<.5)&&s._1.head.y>=f.y-.5&&s._1.head.y<=f.y+f.h+.5){if(c._1.x>=f.x+f.w)return T("Just",Cr);if(c._1.x<=f.x)return T("Just",Sr)}return J}if(c.tag==="Nothing")return J;g()})();if(d.tag==="Just"){if(d._1==="TopSide")return{...s._1.head,y:We(o._1.shape)(f)(kr)(s._1.head.x)};if(d._1==="BottomSide")return{...s._1.head,y:We(o._1.shape)(f)(Er)(s._1.head.x)};if(d._1==="LeftSide")return{...s._1.head,x:We(o._1.shape)(f)(Sr)(s._1.head.y)};if(d._1==="RightSide")return{...s._1.head,x:We(o._1.shape)(f)(Cr)(s._1.head.y)};g()}if(d.tag==="Nothing"){const l={x:o._1.x,y:o._1.y,w:o._1.w,h:o._1.h},_=t_(l)(s._1.head);if(_==="TopSide")return{...s._1.head,y:We(o._1.shape)(l)(kr)(s._1.head.x)};if(_==="BottomSide")return{...s._1.head,y:We(o._1.shape)(l)(Er)(s._1.head.x)};if(_==="LeftSide")return{...s._1.head,x:We(o._1.shape)(l)(Sr)(s._1.head.y)};if(_==="RightSide")return{...s._1.head,x:We(o._1.shape)(l)(Cr)(s._1.head.y)}}g()})(),...s._1.tail]}g()})();if(i.tag==="Nothing")return u;if(i.tag==="Just"){const s=pr(u);if(s.tag==="Nothing")return u;if(s.tag==="Just")return Dt(s._1.init)((()=>{const a=pr(s._1.init),c=a.tag==="Just"?T("Just",a._1.last):J,f={x:i._1.x,y:i._1.y,w:i._1.w,h:i._1.h},d=(()=>{if(c.tag==="Just"){if((c._1.x>s._1.last.x?c._1.x-s._1.last.x<.5:s._1.last.x-c._1.x<.5)&&s._1.last.x>=f.x-.5&&s._1.last.x<=f.x+f.w+.5)return c._1.y>=f.y+f.h?T("Just",Er):c._1.y<=f.y?T("Just",kr):J;if((c._1.y>s._1.last.y?c._1.y-s._1.last.y<.5:s._1.last.y-c._1.y<.5)&&s._1.last.y>=f.y-.5&&s._1.last.y<=f.y+f.h+.5){if(c._1.x>=f.x+f.w)return T("Just",Cr);if(c._1.x<=f.x)return T("Just",Sr)}return J}if(c.tag==="Nothing")return J;g()})();if(d.tag==="Just"){if(d._1==="TopSide")return{...s._1.last,y:We(i._1.shape)(f)(kr)(s._1.last.x)};if(d._1==="BottomSide")return{...s._1.last,y:We(i._1.shape)(f)(Er)(s._1.last.x)};if(d._1==="LeftSide")return{...s._1.last,x:We(i._1.shape)(f)(Sr)(s._1.last.y)};if(d._1==="RightSide")return{...s._1.last,x:We(i._1.shape)(f)(Cr)(s._1.last.y)};g()}if(d.tag==="Nothing"){const l={x:i._1.x,y:i._1.y,w:i._1.w,h:i._1.h},_=t_(l)(s._1.last);if(_==="TopSide")return{...s._1.last,y:We(i._1.shape)(l)(kr)(s._1.last.x)};if(_==="BottomSide")return{...s._1.last,y:We(i._1.shape)(l)(Er)(s._1.last.x)};if(_==="LeftSide")return{...s._1.last,x:We(i._1.shape)(l)(Sr)(s._1.last.y)};if(_==="RightSide")return{...s._1.last,x:We(i._1.shape)(l)(Cr)(s._1.last.y)}}g()})())}}g()})()))(lN(e.edges)))}),bN=t=>e=>n=>{const r=Vt(i=>i.id===n)(t.graph.edges);if(r.tag==="Just")return T("Just",r._1);if(r.tag==="Nothing")return oa(n)(e);g()},LN=t=>e=>n=>r=>({x:r.position._1*t,y:r.position._2*t,w:r.size._1*t,h:r.size._2*t,label:(()=>{const i=Ri(r.node)(e);if(i.tag==="Just")return i._1;if(i.tag==="Nothing")return r.node;g()})(),shape:(()=>{const i=Ri(r.node)(n);if(i.tag==="Nothing")return er;if(i.tag==="Just")return i._1;g()})()}),kN=t=>({id:t,size:L(1,1),ports:[],label:T("Just",t),shape:er}),EN=t=>e=>n=>r=>L(r.node,LN(t)(e)(n)(r)),n_=t=>{const e=Lo(`
6
+ `)(t);return e.length===0?[""]:e},r_=t=>{const e=(n,r)=>{if(n.tag==="Leaf")return r;if(n.tag==="Node")return e(n._5,Xt("Cons",n._4,e(n._6,r)));g()};return At(Kt.foldr,e(t.interiors,Ut))},SN=t=>qi(xt(e=>T("Just",L(e.edge,{id:e.edge,from:{node:e.from,port:J},to:{node:e.to,port:J},label:J})))(Tt(t.scenes)(e=>e.tag==="DataFlow"?xt(n=>n.kind.tag==="SendToken"?T("Just",n.kind._1):J)(e._1.events):[]))),i_=t=>{const e=Jh(t),n=ut(i=>hN(i.id)(e.nodes),t.graph.nodes),r=ut(i=>pN(i.id)(e.edges),t.graph.edges);return{nodes:[...n,...H(kN)(At($e.foldr,In(G.compare,e.nodes,mN(H(i=>i.id)(n)))))],edges:[...r,...xt(bN(t)(SN(t)))(At($e.foldr,In(G.compare,e.edges,yN(H(i=>i.id)(r)))))],constraints:t.graph.constraints}},CN=t=>{const e=uu(n=>{const r=Dg(Fg)((()=>{if(n.label.tag==="Just")return n.label._1;if(n.label.tag==="Nothing")return n.id;g()})());return()=>{const i=r();return L(n.id,i)}})(i_(t).nodes);return()=>{const n=e();return su(n)}},o_=t=>{const e=CN(t);return()=>{const n=e(),r=uu(o_)(r_(t))();return w(xN)(n)(r)}},GN=t=>e=>{const n=Mt(r=>J,r=>i=>T("Just",{head:r,tail:i}),e.segments);if(n.tag==="Nothing")return[];if(n.tag==="Just")return[{x:n._1.head.start._1*t,y:n._1.head.start._2*t},...H(r=>({x:r.end._1*t,y:r.end._2*t}))([n._1.head,...n._1.tail])];g()},PN=t=>e=>L(e.edge,GN(t)(e)),AN=t=>e=>n=>r=>({nodes:su(H(EN(et(4)*t)(e)(n))(r.nodes)),edges:qi(H(PN(t))(r.edges)),chipExtras:D,edgeLabels:D}),IN=t=>e=>({...vN(qi(H(n=>L(n.id,L(n.from.node,n.to.node)))(e.edges)))(AN(8)(su(H(n=>L(n.id,(()=>{if(n.label.tag==="Just")return n.label._1;if(n.label.tag==="Nothing")return n.id;g()})()))(e.nodes)))(su(H(n=>L(n.id,n.shape))(e.nodes)))(fN(oN)(e).result)),edgeLabels:qi(xt(n=>n.label.tag==="Just"?T("Just",L(n.id,n.label._1)):J)(e.edges))}),QN=t=>w(e=>n=>{if(n.tag==="Structural")return e;if(n.tag==="DataFlow")return w(r=>i=>{if(i.kind.tag==="SendToken")return w(o=>u=>Z(G)(u)()(o))(r)(i.kind._1.labels);if(i.kind.tag==="FillNodeWithoutTransition")return w(o=>u=>Z(G)(u)()(o))(r)(i.kind._1.labels);g()})(e)(n._1.events);if(n.tag==="Hold"||n.tag==="EnterNode"||n.tag==="ExitNode")return e;g()})(D)(t.scenes),DN=t=>{const e=uu(n=>{const r=Dg(Fg)(n);return()=>{const i=r();return L(n,{labelW:i,charCount:tr(Yr(n)),lineCount:1})}})(At($e.foldr,NN(Tt(At($e.foldr,QN(t)))(n_))));return()=>{const n=e();return JN(n)}},u_=t=>{const e=DN(t);return()=>{const n=e(),r=uu(u_)(r_(t))();return w(wN)(n)(r)}},FN=et(4)*8,zN=t=>Tt(t.scenes)(e=>{if(e.tag==="Structural")return[];if(e.tag==="DataFlow")return e._1.events;if(e.tag==="Hold")return[];if(e.tag==="EnterNode")return[];if(e.tag==="ExitNode")return[];g()}),BN=t=>e=>n=>{const r=i=>{const o=xt(u=>{const s=TN(u)(t);return s.tag==="Just"?T("Just",{w:s._1.labelW+28,h:et(pm(1)(s._1.lineCount))*13.2+12}):J})(Tt(i)(n_));return o.length===0?J:T("Just",{w:w(e_)(0)(H(u=>u.w)(o)),h:w(e_)(0)(H(u=>u.h)(o))})};return w(i=>o=>{if(o.kind.tag==="SendToken"){const u=oa(o.kind._1.edge)(n.edges),s=r(o.kind._1.labels);if(s.tag==="Just"&&u.tag==="Just"){const a=s._1;return bt(G)(ne)(o.kind._1.edge)(H(c=>({x:c.x+14+a.w,y:c.y-6-8-a.h}))(u._1))(i)}return i}if(o.kind.tag==="FillNodeWithoutTransition"){const u=Ri(o.kind._1.node)(n.nodes),s=r(o.kind._1.labels);return s.tag==="Just"&&u.tag==="Just"?bt(G)(ne)("__fill__:"+o.kind._1.node)((()=>{const a=u._1.y-s._1.h-14,c=u._1.x+u._1.w/2,f=c-s._1.w/2,d=c+s._1.w/2,l=u._1.y-14;return[{x:f,y:a},{x:d,y:a},{x:f,y:l},{x:d,y:l}]})())(i):i}g()})(D)(zN(e))},s_=t=>e=>n=>({layout:(()=>{const r=IN()(Tm(FN)(t)(wm(Jm)(i_(n))));return{...r,chipExtras:BN(e)(n)(r)}})(),interiors:(()=>{const r=s_(t)(e),i=o=>{if(o.tag==="Leaf")return D;if(o.tag==="Node")return Ot("Node",o._1,o._2,o._3,r(o._4),i(o._5),i(o._6));g()};return i(n.interiors)})()}),a_=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},ua=t=>e=>n=>{const r=t<.05?t:.05,i=(u,s)=>{if(s.tag==="Leaf")return u;if(s.tag==="Node")return i((()=>{const a=a_(s._3)(n),c=(()=>{if(a.tag==="Just")return a._1;if(a.tag==="Nothing")return{x:s._4.x,y:s._4.y,vx:0,vy:0};g()})(),f=c.vx+(180*(s._4.x-c.x)-22*c.vx)*r,d=c.vy+(180*(s._4.y-c.y)-22*c.vy)*r;return Z(G)(s._3)({x:c.x+f*r,y:c.y+d*r,vx:f,vy:d})(i(u,s._5))})(),s._6);g()},o=i(D,e);return{springs:o,applied:(()=>{const u=(s,a)=>{if(a.tag==="Leaf")return s;if(a.tag==="Node")return u((()=>{const c=u(s,a._5),f=a_(a._3)(o);if(f.tag==="Just")return Z(G)(a._3)({...a._4,x:f._1.x,y:f._1.y})(c);if(f.tag==="Nothing")return Z(G)(a._3)(a._4)(c);g()})(),a._6);g()};return u(D,e)})()}};(function(){var t={},e="Pure",n="Throw",r="Catch",i="Sync",o="Async",u="Bind",s="Bracket",a="Fork",c="Sequential",f="Map",d="Apply",l="Alt",_="Cons",h="Resume",p="Release",m="Finalizer",y="Finalized",x="Forked";function N(Q,R,Y,O){this.tag=Q,this._1=R,this._2=Y,this._3=O}function v(Q){var R=function(Y,O,X){return new N(Q,Y,O,X)};return R.tag=Q,R}function b(Q){return new N(e,void 0)}function k(Q){try{Q()}catch(R){setTimeout(function(){throw R},0)}}function E(Q,R,Y){try{return R(Y())}catch(O){return Q(O)}}function A(Q,R,Y){try{return R(Y)()}catch(O){return Y(Q(O))(),b}}var $=(function(){var Q=1024,R=0,Y=0,O=new Array(Q),X=!1;function q(){var K;for(X=!0;R!==0;)R--,K=O[Y],O[Y]=void 0,Y=(Y+1)%Q,K();X=!1}return{isDraining:function(){return X},enqueue:function(K){var j;R===Q&&(j=X,q(),X=j),O[(Y+R)%Q]=K,R++,X||q()}}})();function tt(Q){var R={},Y=0,O=0;return{register:function(X){var q=Y++;X.onComplete({rethrow:!0,handler:function(K){return function(){O--,delete R[q]}}})(),R[q]=X,O++},isEmpty:function(){return O===0},killAll:function(X,q){return function(){if(O===0)return q();var K=0,j={};function ot(gt){j[gt]=R[gt].kill(X,function(yt){return function(){delete j[gt],K--,Q.isLeft(yt)&&Q.fromLeft(yt)&&setTimeout(function(){throw Q.fromLeft(yt)},0),K===0&&q()}})()}for(var _t in R)R.hasOwnProperty(_t)&&(K++,ot(_t));return R={},Y=0,O=0,function(gt){return new N(i,function(){for(var yt in j)j.hasOwnProperty(yt)&&j[yt]()})}}}}}var S=0,C=1,V=2,U=3,M=4,W=5,B=6;function P(Q,R,Y){var O=0,X=S,q=Y,K=null,j=null,ot=null,_t=null,gt=null,yt=0,Ct=0,Rt=null,pt=!0;function qt(st){for(var dt,at,ct;;)switch(dt=null,at=null,ct=null,X){case V:X=C;try{q=ot(q),_t===null?ot=null:(ot=_t._1,_t=_t._2)}catch(Jt){X=W,K=Q.left(Jt),q=null}break;case U:Q.isLeft(q)?(X=W,K=q,q=null):ot===null?X=W:(X=V,q=Q.fromRight(q));break;case C:switch(q.tag){case u:ot&&(_t=new N(_,ot,_t)),ot=q._2,X=C,q=q._1;break;case e:ot===null?(X=W,q=Q.right(q._1)):(X=V,q=q._1);break;case i:X=U,q=E(Q.left,Q.right,q._1);break;case o:X=M,q=A(Q.left,q._1,function(Jt){return function(){O===st&&(O++,$.enqueue(function(){O===st+1&&(X=U,q=Jt,qt(O))}))}});return;case n:X=W,K=Q.left(q._1),q=null;break;case r:ot===null?gt=new N(_,q,gt,j):gt=new N(_,q,new N(_,new N(h,ot,_t),gt,j),j),ot=null,_t=null,X=C,q=q._1;break;case s:yt++,ot===null?gt=new N(_,q,gt,j):gt=new N(_,q,new N(_,new N(h,ot,_t),gt,j),j),ot=null,_t=null,X=C,q=q._1;break;case a:X=U,dt=P(Q,R,q._2),R&&R.register(dt),q._1&&dt.run(),q=Q.right(dt);break;case c:X=C,q=F(Q,R,q._1);break}break;case W:if(ot=null,_t=null,gt===null)X=B,q=j||K||q;else switch(dt=gt._3,ct=gt._1,gt=gt._2,ct.tag){case r:j&&j!==dt&&yt===0?X=W:K&&(X=C,q=ct._2(Q.fromLeft(K)),K=null);break;case h:j&&j!==dt&&yt===0||K?X=W:(ot=ct._1,_t=ct._2,X=V,q=Q.fromRight(q));break;case s:yt--,K===null&&(at=Q.fromRight(q),gt=new N(_,new N(p,ct._2,at),gt,dt),(j===dt||yt>0)&&(X=C,q=ct._3(at)));break;case p:gt=new N(_,new N(y,q,K),gt,j),X=C,j&&j!==dt&&yt===0?q=ct._1.killed(Q.fromLeft(j))(ct._2):K?q=ct._1.failed(Q.fromLeft(K))(ct._2):q=ct._1.completed(Q.fromRight(q))(ct._2),K=null,yt++;break;case m:yt++,gt=new N(_,new N(y,q,K),gt,j),X=C,q=ct._1;break;case y:yt--,X=W,q=ct._1,K=ct._2;break}break;case B:for(var Nt in Rt)Rt.hasOwnProperty(Nt)&&(pt=pt&&Rt[Nt].rethrow,k(Rt[Nt].handler(q)));Rt=null,j&&K?setTimeout(function(){throw Q.fromLeft(K)},0):Q.isLeft(q)&&pt&&setTimeout(function(){if(pt)throw Q.fromLeft(q)},0);return;case S:X=C;break;case M:return}}function wt(st){return function(){if(X===B)return pt=pt&&st.rethrow,st.handler(q)(),function(){};var dt=Ct++;return Rt=Rt||{},Rt[dt]=st,function(){Rt!==null&&delete Rt[dt]}}}function mt(st,dt){return function(){if(X===B)return dt(Q.right(void 0))(),function(){};var at=wt({rethrow:!1,handler:function(){return dt(Q.right(void 0))}})();switch(X){case S:j=Q.left(st),X=B,q=j,qt(O);break;case M:j===null&&(j=Q.left(st)),yt===0&&(X===M&&(gt=new N(_,new N(m,q(st)),gt,j)),X=W,q=null,K=null,qt(++O));break;default:j===null&&(j=Q.left(st)),yt===0&&(X=W,q=null,K=null)}return at}}function ft(st){return function(){var dt=wt({rethrow:!1,handler:st})();return X===S&&qt(O),dt}}return{kill:mt,join:ft,onComplete:wt,isSuspended:function(){return X===S},run:function(){X===S&&($.isDraining()?qt(O):$.enqueue(function(){qt(O)}))}}}function I(Q,R,Y,O){var X=0,q={},K=0,j={},ot=new Error("[ParAff] Early exit"),_t=null,gt=t;function yt(wt,mt,ft){var st=mt,dt=null,at=null,ct=0,Nt={},Jt,Lt;t:for(;;)switch(Jt=null,st.tag){case x:if(st._3===t&&(Jt=q[st._1],Nt[ct++]=Jt.kill(wt,function(Ht){return function(){ct--,ct===0&&ft(Ht)()}})),dt===null)break t;st=dt._2,at===null?dt=null:(dt=at._1,at=at._2);break;case f:st=st._2;break;case d:case l:dt&&(at=new N(_,dt,at)),dt=st,st=st._1;break}if(ct===0)ft(Q.right(void 0))();else for(Lt=0,Jt=ct;Lt<Jt;Lt++)Nt[Lt]=Nt[Lt]();return Nt}function Ct(wt,mt,ft){var st,dt,at,ct,Nt,Jt;for(Q.isLeft(wt)?(st=wt,dt=null):(dt=wt,st=null);;){if(at=null,ct=null,Nt=null,Jt=null,_t!==null)return;if(mt===null){O(st||dt)();return}if(mt._3!==t)return;switch(mt.tag){case f:st===null?(mt._3=Q.right(mt._1(Q.fromRight(dt))),dt=mt._3):mt._3=st;break;case d:if(at=mt._1._3,ct=mt._2._3,st){if(mt._3=st,Nt=!0,Jt=K++,j[Jt]=yt(ot,st===at?mt._2:mt._1,function(){return function(){delete j[Jt],Nt?Nt=!1:ft===null?Ct(st,null,null):Ct(st,ft._1,ft._2)}}),Nt){Nt=!1;return}}else{if(at===t||ct===t)return;dt=Q.right(Q.fromRight(at)(Q.fromRight(ct))),mt._3=dt}break;case l:if(at=mt._1._3,ct=mt._2._3,at===t&&Q.isLeft(ct)||ct===t&&Q.isLeft(at))return;if(at!==t&&Q.isLeft(at)&&ct!==t&&Q.isLeft(ct))st=dt===at?ct:at,dt=null,mt._3=st;else if(mt._3=dt,Nt=!0,Jt=K++,j[Jt]=yt(ot,dt===at?mt._2:mt._1,function(){return function(){delete j[Jt],Nt?Nt=!1:ft===null?Ct(dt,null,null):Ct(dt,ft._1,ft._2)}}),Nt){Nt=!1;return}break}ft===null?mt=null:(mt=ft._1,ft=ft._2)}}function Rt(wt){return function(mt){return function(){delete q[wt._1],wt._3=mt,Ct(mt,wt._2._1,wt._2._2)}}}function pt(){var wt=C,mt=Y,ft=null,st=null,dt,at;t:for(;;)switch(dt=null,at=null,wt){case C:switch(mt.tag){case f:ft&&(st=new N(_,ft,st)),ft=new N(f,mt._1,t,t),mt=mt._2;break;case d:ft&&(st=new N(_,ft,st)),ft=new N(d,t,mt._2,t),mt=mt._1;break;case l:ft&&(st=new N(_,ft,st)),ft=new N(l,t,mt._2,t),mt=mt._1;break;default:at=X++,wt=W,dt=mt,mt=new N(x,at,new N(_,ft,st),t),dt=P(Q,R,dt),dt.onComplete({rethrow:!1,handler:Rt(mt)})(),q[at]=dt,R&&R.register(dt)}break;case W:if(ft===null)break t;ft._1===t?(ft._1=mt,wt=C,mt=ft._2,ft._2=t):(ft._2=mt,mt=ft,st===null?ft=null:(ft=st._1,st=st._2))}for(gt=mt,at=0;at<X;at++)q[at].run()}function qt(wt,mt){_t=Q.left(wt);var ft;for(var st in j)if(j.hasOwnProperty(st)){ft=j[st];for(st in ft)ft.hasOwnProperty(st)&&ft[st]()}j=null;var dt=yt(wt,gt,mt);return function(at){return new N(o,function(ct){return function(){for(var Nt in dt)dt.hasOwnProperty(Nt)&&dt[Nt]();return b}})}}return pt(),function(wt){return new N(o,function(mt){return function(){return qt(wt,mt)}})}}function F(Q,R,Y){return new N(o,function(O){return function(){return I(Q,R,Y,O)}})}return N.EMPTY=t,N.Pure=v(e),N.Throw=v(n),N.Catch=v(r),N.Sync=v(i),N.Async=v(o),N.Bind=v(u),N.Bracket=v(s),N.Fork=v(a),N.Seq=v(c),N.ParMap=v(f),N.ParApply=v(d),N.ParAlt=v(l),N.Fiber=P,N.Supervisor=tt,N.Scheduler=$,N.nonCanceler=b,N})();let c_=null;function MN(){return c_||(typeof document>"u"?null:c_=document.createElement("canvas").getContext("2d"))}const sa=new Map;function g_(t,e,n,r,i,o){const u=`${n} ${e}px ${t}`,s=u+"|"+r;if(sa.has(s))return sa.get(s);const a=MN();if(!a)return o;a.font=u;const c=i(a.measureText(r)),f=typeof document<"u"?document.fonts:null;if(!f||f.check(u))sa.set(s,c);else if(f&&f.load)try{f.load(u)}catch{}return c}const WN=(t,e,n,r)=>g_(t,e,n,r,i=>i.width,-1),RN=(t,e,n,r)=>g_(t,e,n,r,i=>({ascent:i.actualBoundingBoxAscent,descent:i.actualBoundingBoxDescent}),{ascent:-1,descent:-1}),f_=t=>e=>{const n=WN(t.family,t.size,t.weight,Yr(e));return n<0?et(So(e).length)*t.size*.62:n},__=t=>e=>{const n=RN(t.family,t.size,t.weight,Yr(e));return n.ascent<0?{ascent:t.size*.72,descent:t.size*.2}:n},d_=t=>t,l_=t=>t,au=t=>t,h_=t=>t,qN=t=>t,p_=t=>t,m_=t=>t,HN=m_("BaselineTop"),cr=m_("BaselineMiddle"),aa=p_("AlignLeft"),ri=p_("AlignCenter"),Le=qN("RoundJoin"),mn=h_("ButtCap"),kn=h_("RoundCap"),ON=au("LayerPolyOut"),$N=au("LayerPolyIn"),XN=au("LayerNodeMask"),YN=au("LayerOverlay"),cu=l_("NonZero"),VN=l_("EvenOdd"),y_=d_("Normal"),gu=d_("Difference"),oe={r:255,g:255,b:255,a:255},Rn={r:26,g:26,b:26,a:255},ca=t=>e=>Math.imul(t,e),ii=t=>{const e=t+1831565813|0,n=ca(e^e>>>15)(e|1),r=n^(n+ca(n^n>>>7)(n|61)|0),i=r^r>>>14;return{prng:i,value:i<0?(et(i)+4294967296)/4294967296:et(i)/4294967296}},he=t=>e=>n=>{const r=ii(n);return{prng:r.prng,value:t+r.value*(e-t)}},ga=t=>e=>w(n=>r=>ca(n^r)(-2048144789))(e)(H(ir)(Jr(t))),UN=t=>t,x_=t=>t,KN=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},un=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},N_=t=>e=>n=>{const r=nt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=nt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},fa=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},jN=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},ZN=x_("FlatLevel"),tJ=x_("NestedLevel"),J_=UN("GenieSilhouette"),eJ=t=>e=>n=>r=>{if(e)return{prng:t,yLift:0};const i=ii(t);return{prng:i.prng,yLift:i.value*n.yJitter*r}},nJ=t=>e=>n=>r=>{if(e)return{prng:t,dx:0};const i=ii(t);return{prng:i.prng,dx:(i.value*2-1)*n.xJitter*r}},w_=t=>e=>{const n=e.cy-t.cy,r=e.cx-t.cx,i=Ce(r*r+n*n),o=(t.r*t.r-e.r*e.r+i*i)/(2*i),u=Ce(KN(0)(t.r*t.r-o*o)),s=t.cx+o*r/i,a=t.cy+o*n/i,c={x:s-u*n/i,y:a+u*r/i},f={x:s+u*n/i,y:a-u*r/i};return i===0||i>t.r+e.r?{x:(t.cx+e.cx)/2,y:t.cy}:c.y<f.y?c:f},rJ=t=>e=>{const n=un(e)(un(t.w/2)(t.h/2));return[1,t.x+n,t.y,2,t.x+t.w-n,t.y,3,t.x+t.w,t.y,t.x+t.w,t.y+n,2,t.x+t.w,t.y+t.h-n,3,t.x+t.w,t.y+t.h,t.x+t.w-n,t.y+t.h,2,t.x+n,t.y+t.h,3,t.x,t.y+t.h,t.x,t.y+t.h-n,2,t.x,t.y+n,3,t.x,t.y,t.x+n,t.y,5]},iJ=t=>e=>n=>r=>i=>o=>{if(e)return{prng:t,r:i};if(n)return{prng:t,r:i*(1+o.rJitter)};if(r)return{prng:t,r:i*o.smallScale};const u=ii(t);return{prng:u.prng,r:i*(1+u.value*o.rJitter)}},T_=t=>{const e=un(t.w)(t.h)/2;return[1,t.x+e,t.y,2,t.x+t.w-e,t.y,4,t.x+t.w-e+.5522847498307936*e,t.y,t.x+t.w,t.y+e-.5522847498307936*e,t.x+t.w,t.y+e,4,t.x+t.w,t.y+e+.5522847498307936*e,t.x+t.w-e+.5522847498307936*e,t.y+t.h,t.x+t.w-e,t.y+t.h,2,t.x+e,t.y+t.h,4,t.x+e-.5522847498307936*e,t.y+t.h,t.x,t.y+e+.5522847498307936*e,t.x,t.y+e,4,t.x,t.y+e-.5522847498307936*e,t.x+e-.5522847498307936*e,t.y,t.x+e,t.y,5]},oJ=t=>e=>n=>{const r=ii(t),i=e.length;return i===0?{prng:t,idx:-1}:{prng:r.prng,idx:(()=>{const o=N_(0)(i-1|0)(xe(xn(r.value*et(n))));return o>=0&&o<e.length?e[o]:-1})()}},uJ=t=>e=>{const n=ii(t),r=e.length;return r===0?{prng:t,idx:-1}:{prng:n.prng,idx:(()=>{const i=N_(0)(r-1|0)(xe(xn(n.value*et(r))));return i>=0&&i<e.length?e[i]:-1})()}},v_=t=>{const e=un(t.w*.18)(t.h*.6);return[1,t.x+e,t.y,2,t.x+t.w,t.y,2,t.x+t.w-e,t.y+t.h,2,t.x,t.y+t.h,5]},b_=t=>[1,t.x,t.y,2,t.x+t.w,t.y,2,t.x+t.w,t.y+t.h*.85,4,t.x+t.w*.66,t.y+t.h*1.05,t.x+t.w*.34,t.y+t.h*.65,t.x,t.y+t.h*.85,5],L_={rBase:1.2,stepRatio:.7,rJitter:.35,yJitter:.2,xJitter:.2,heroShift:.2,smallScale:.85,smallShift:.15,seed:7,minN:3},sJ=t=>{const e=un(t.h*.075)(t.w*.075),n=t.w/2,r=t.y+e,i=t.x+n;return[1,t.x,r,4,t.x,r+.5522847498*e,i-.5522847498*n,r+e,i,r+e,4,i+.5522847498*n,r+e,t.x+t.w,r+.5522847498*e,t.x+t.w,r]},k_=t=>{const e=un(t.h*.075)(t.w*.075),n=t.w/2,r=t.y+t.h+5,i=t.y+e,o=r-e,u=t.x+n;return[1,t.x,i,4,t.x,i-.5522847498*e,u-.5522847498*n,t.y,u,t.y,4,u+.5522847498*n,t.y,t.x+t.w,i-.5522847498*e,t.x+t.w,i,2,t.x+t.w,o,4,t.x+t.w,o+.5522847498*e,u+.5522847498*n,r,u,r,4,u-.5522847498*n,r,t.x,o+.5522847498*e,t.x,o,5]},E_=t=>e=>{const n=e.y+e.h,r=Hd(t.rBase*e.h)(e.w/(2*(1+(et(t.minN)-1)*t.stepRatio))),i=e.w-2*r,o=2*r*t.stepRatio,u=fa(t.minN)(i<=0||o<=0?t.minN:xe(xr(i/o))+1|0),s=u>=3?zt(1,u-2|0):[],a=s.length,c=An(a+1|0,2),f=c<1?[]:kt(0,c,s),d=uJ(t.seed)((()=>{const m=a-c|0;return m<1?s:kt(m,s.length,s)})()),l=d.idx,_=oJ(d.prng)(ut(m=>m!==l,f))(fa(1)(f.length-(He(Dr)(l)(f)?1:0)|0)),h=_.idx,p=u>=2?i/(et(u)-1):0;return w(m=>y=>{const x=y===h,N=y===l,v=y===0||y===(u-1|0),b=iJ(m.prng)(v)(N)(x)(r)(t),k=eJ(b.prng)(v)(t)(e.h),E=nJ(k.prng)(v)(t)(p);return{prng:E.prng,circles:Dt(m.circles)({cx:e.x+jN(b.r)(e.w-b.r)((u>=2?r+et(y)/(et(u)-1)*i+E.dx:r+0*i+E.dx)+(N?t.heroShift*p:x?-1*t.smallShift*p:0)),cy:n-k.yLift,r:b.r})}})({prng:_.prng,circles:[]})(zt(0,u-1|0)).circles},S_=t=>e=>{const n=t.length;return Ft(r=>i=>({c:i,p1:(()=>{if(r===0)return{x:i.cx-i.r,y:e};const o=r-1|0;return o>=0&&o<t.length?w_(t[o])(i):{x:i.cx-i.r,y:e}})(),p2:(()=>{if(r===(n-1|0))return{x:i.cx+i.r,y:e};const o=r+1|0;return o>=0&&o<t.length?w_(i)(t[o]):{x:i.cx+i.r,y:e}})()}))(t)},C_=t=>{const e=un(t.h*.4)(t.w*.2);return[1,t.x+e,t.y,2,t.x+t.w-e,t.y,2,t.x+t.w,t.y+t.h/2,2,t.x+t.w-e,t.y+t.h,2,t.x+e,t.y+t.h,2,t.x,t.y+t.h/2,5]},aJ=t=>e=>n=>{const r=yr(e.y-t.cy)(e.x-t.cx),i=yr(n.y-t.cy)(n.x-t.cx),o=i>r?i-r:i+6.283185307179586-r,u=fa(1)(xe(no(o/1.5707963267948966))),s=o/et(u),a=1.3333333333333333*Od(s/4);return Tt(zt(0,u-1|0))(c=>{const f=r+et(c+1|0)*s,d=t.cx+t.r*rn(f),l=t.cy+t.r*Ve(f),_=r+et(c)*s;return[4,t.cx+t.r*rn(_)-a*t.r*Ve(_),t.cy+t.r*Ve(_)+a*t.r*rn(_),d+a*t.r*Ve(f),l-a*t.r*rn(f),d,l]})},G_=t=>e=>{const n=t.h*.38,r=S_(E_(L_)({x:t.x,y:t.y-n,w:t.w,h:n}))(t.y),i=un(e)(un(t.w/2)(t.h/2));return 0<r.length?[1,r[0].p1.x,r[0].p1.y,...Tt(r)(o=>aJ(o.c)(o.p1)(o.p2)),2,t.x+t.w,t.y+t.h-i,3,t.x+t.w,t.y+t.h,t.x+t.w-i,t.y+t.h,2,t.x+i,t.y+t.h,3,t.x,t.y+t.h,t.x,t.y+t.h-i,2,r[0].p1.x,r[0].p1.y,5]:rJ(t)(e)},_a=t=>e=>n=>r=>i=>o=>{if(e==="Rectangle")return t.drawRoundedRect(n)(r)(i)(o);if(e==="Cylinder"){const u=k_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Parallelogram"){const u=v_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Diamond"){const u=C_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Ellipse"){const u=T_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Document"){const u=b_(n);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}if(e==="Cloud"){const u=G_(n)(r);if(i.tag==="Just"){if(o.tag==="Just")return t.fillStrokePath(u)(i._1)(o._1);if(o.tag==="Nothing")return t.fillPath(u)(i._1);g()}if(i.tag==="Nothing"){if(o.tag==="Just")return t.strokePath(u)(o._1);if(o.tag==="Nothing")return t.Monad0().Applicative0().pure()}g()}return t.drawRoundedRect(n)(r)(i)(o)},cJ=t=>()=>t.clip("evenodd"),gJ=t=>e=>()=>{t.filter=`blur(${e}px)`},fJ=t=>e=>()=>{const n=Math.max(8,Math.ceil(8/Math.max(e.tile,.001))),r=Math.max(2,Math.round(e.tile*n)),i=document.createElement("canvas");i.width=r,i.height=r;const o=i.getContext("2d");o.scale(n,n),o.fillStyle=e.bgCss,o.fillRect(0,0,e.tile,e.tile),o.fillStyle=e.dotCss,o.beginPath(),o.arc(e.tile/2,e.tile/2,e.dotR,0,2*Math.PI),o.fill();const u=t.createPattern(i,"repeat");u&&typeof u.setTransform=="function"&&u.setTransform(new DOMMatrix().translateSelf(e.ox,e.oy).scaleSelf(1/n,1/n)),t.save(),t.fillStyle=u,t.fillRect(e.vx,e.vy,e.vw,e.vh),t.restore()},da=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},la=t=>e=>n=>{const r=e.stroke;return()=>{const i=r.value,o=pl(t)(n);if(i!==n)return o(),e.stroke.value=n}},_J=t=>e=>n=>{const r=e.font;return()=>{const i=r.value,o=bl(t)(n);if(i!==n)return o(),e.font.value=n}},Hi=t=>e=>n=>{const r=e.fill;return()=>{const i=r.value,o=hl(t)(n);if(i!==n)return o(),e.fill.value=n}},fu=t=>e=>{const n=e.length,r=o=>{if(o>=n)return()=>{};const u=o>=0&&o<e.length?e[o]:0;if(u===1){const s=Nc(t)((()=>{const c=o+1|0;return c>=0&&c<e.length?e[c]:0})())((()=>{const c=o+2|0;return c>=0&&c<e.length?e[c]:0})()),a=r(o+3|0);return()=>(s(),a())}if(u===2){const s=mi(t)((()=>{const c=o+1|0;return c>=0&&c<e.length?e[c]:0})())((()=>{const c=o+2|0;return c>=0&&c<e.length?e[c]:0})()),a=r(o+3|0);return()=>(s(),a())}if(u===3){const s=yi(t)({cpx:(()=>{const c=o+1|0;return c>=0&&c<e.length?e[c]:0})(),cpy:(()=>{const c=o+2|0;return c>=0&&c<e.length?e[c]:0})(),x:(()=>{const c=o+3|0;return c>=0&&c<e.length?e[c]:0})(),y:(()=>{const c=o+4|0;return c>=0&&c<e.length?e[c]:0})()}),a=r(o+5|0);return()=>(s(),a())}if(u===4){const s=kl(t)({cp1x:(()=>{const c=o+1|0;return c>=0&&c<e.length?e[c]:0})(),cp1y:(()=>{const c=o+2|0;return c>=0&&c<e.length?e[c]:0})(),cp2x:(()=>{const c=o+3|0;return c>=0&&c<e.length?e[c]:0})(),cp2y:(()=>{const c=o+4|0;return c>=0&&c<e.length?e[c]:0})(),x:(()=>{const c=o+5|0;return c>=0&&c<e.length?e[c]:0})(),y:(()=>{const c=o+6|0;return c>=0&&c<e.length?e[c]:0})()}),a=r(o+7|0);return()=>(s(),a())}if(u===5){const s=Jc(t),a=r(o+1|0);return()=>(s(),a())}return()=>{}},i=xc(t);return()=>(i(),r(0)())},dJ=t=>e=>n=>r=>i=>o=>{const u=da(o)(da(r/2)(i/2)),s=Nc(t)(e+u)(n);return()=>(s(),mi(t)(e+r-u)(n)(),yi(t)({cpx:e+r,cpy:n,x:e+r,y:n+u})(),mi(t)(e+r)(n+i-u)(),yi(t)({cpx:e+r,cpy:n+i,x:e+r-u,y:n+i})(),mi(t)(e+u)(n+i)(),yi(t)({cpx:e,cpy:n+i,x:e,y:n+i-u})(),mi(t)(e)(n+u)(),yi(t)({cpx:e,cpy:n,x:e+u,y:n})(),Jc(t)())},lJ=()=>({font:{value:""},fill:{value:""},stroke:{value:""}}),hJ=t=>e=>{const n=Jl(t)({x:0,y:0,width:e.width,height:e.height});return()=>{n();const r=lJ();return{ctx:t,surface:e,styleCache:r,maskDepth:{value:0},groupAlpha:{value:1},alphaSaves:{value:[]}}}},pJ={map:t=>e=>n=>{const r=e(n);return()=>{const i=r();return t(i)}}},mJ=t=>ue(t.weight)+" "+dr(t.size)+"px "+t.family,En=t=>{const e=dr(et(t.a)/255);return t.a>=255?"rgb("+ue(t.r)+","+ue(t.g)+","+ue(t.b)+")":"rgba("+ue(t.r)+","+ue(t.g)+","+ue(t.b)+","+e+")"},yJ=t=>e=>n=>r=>{const i=Hi(t)(n)(En(r));return()=>(i(),Nl(t)({x:0,y:0,width:e.width,height:e.height})())},xJ=t=>e=>n=>{const r=e.font;return()=>(r.value="",e.fill.value="",e.stroke.value="",fJ(t)({vx:n.viewport.vx,vy:n.viewport.vy,vw:n.viewport.vw,vh:n.viewport.vh,bgCss:En(n.bgColor),dotCss:En(n.dotColor),tile:n.tile,dotR:n.dotRadius,ox:n.origin.x,oy:n.origin.y})())},NJ=t=>e=>n=>r=>{const i=Hi(t)(e)(En(r));return()=>(i(),fu(t)(n)(),Xu(t)())},JJ=t=>e=>n=>r=>i=>{const o=Hi(t)(e)(En(r));return()=>(o(),la(t)(e)(En(i.color))(),qu(t)(i.width)(),co(t)((()=>{if(i.lineJoin==="RoundJoin")return ao;if(i.lineJoin==="BevelJoin")return ju;if(i.lineJoin==="MiterJoin")return Zu;g()})())(),rs(t)((()=>{if(i.lineCap==="ButtCap")return ns;if(i.lineCap==="RoundCap")return ts;if(i.lineCap==="SquareCap")return es;g()})())(),fu(t)(n)(),Xu(t)(),$u(t)())},wJ=t=>e=>n=>r=>i=>o=>{const u=xc(t);return()=>{if(u(),dJ(t)(n.x)(n.y)(n.w)(n.h)(r)(),i.tag==="Just"?(Hi(t)(e)(En(i._1.color))(),Xu(t)()):i.tag==="Nothing"||g(),o.tag==="Just")return la(t)(e)(En(o._1.color))(),qu(t)(o._1.width)(),co(t)((()=>{if(o._1.lineJoin==="RoundJoin")return ao;if(o._1.lineJoin==="BevelJoin")return ju;if(o._1.lineJoin==="MiterJoin")return Zu;g()})())(),rs(t)((()=>{if(o._1.lineCap==="ButtCap")return ns;if(o._1.lineCap==="RoundCap")return ts;if(o._1.lineCap==="SquareCap")return es;g()})())(),$u(t)();o.tag!=="Nothing"&&g()}},TJ=t=>e=>n=>r=>{const i=la(t)(e)(En(r.color));return()=>(i(),qu(t)(r.width)(),co(t)((()=>{if(r.lineJoin==="RoundJoin")return ao;if(r.lineJoin==="BevelJoin")return ju;if(r.lineJoin==="MiterJoin")return Zu;g()})())(),rs(t)((()=>{if(r.lineCap==="ButtCap")return ns;if(r.lineCap==="RoundCap")return ts;if(r.lineCap==="SquareCap")return es;g()})())(),fu(t)(n)(),$u(t)())},P_=t=>e=>n=>{const r=Hi(t)(e)(En(n.color));return()=>(r(),_J(t)(e)(mJ(n.font))(),zl(t)((()=>{if(n.align==="AlignLeft")return Pl;if(n.align==="AlignCenter")return Il;if(n.align==="AlignRight")return Al;g()})())(),Fl(t)((()=>{if(n.baseline==="BaselineTop")return El;if(n.baseline==="BaselineMiddle")return Sl;if(n.baseline==="BaselineAlphabetic")return Cl;if(n.baseline==="BaselineBottom")return Gl;g()})())(),Ll(t)(n.content)(n.x)(n.y)())},A_={apply:t=>e=>n=>{const r=t(n),i=e(n);return()=>{const o=r(),u=i();return o(u)}},Functor0:()=>pJ},vJ={bind:t=>e=>n=>{const r=t(n);return()=>{const i=r();return e(i)(n)()}},Apply0:()=>A_},bJ=t=>e=>n=>{const r=da(e.width/n.vw)(e.height/n.vh),i=Yu(t)({translateX:(e.width-n.vw*r)/2-n.vx*r,translateY:(e.height-n.vh*r)/2-n.vy*r});return()=>(i(),uo(t)({scaleX:r,scaleY:r})(),co(t)(ao)())},LJ={pure:t=>e=>()=>t,Apply0:()=>A_},kJ={Applicative0:()=>LJ,Bind1:()=>vJ},I_={fillPath:t=>e=>n=>{const r=NJ(n.ctx)(n.styleCache)(t)(e.color),i=n.maskDepth;return()=>{if(i.value===0)return r()}},strokePath:t=>e=>n=>{const r=TJ(n.ctx)(n.styleCache)(t)(e),i=n.maskDepth;return()=>{if(i.value===0)return r()}},fillStrokePath:t=>e=>n=>r=>{const i=JJ(r.ctx)(r.styleCache)(t)(e.color)(n),o=r.maskDepth;return()=>{if(o.value===0)return i()}},drawRoundedRect:t=>e=>n=>r=>i=>{const o=wJ(i.ctx)(i.styleCache)(t)(e)(n)(r),u=i.maskDepth;return()=>{if(u.value===0)return o()}},drawText:t=>e=>{const n=P_(e.ctx)(e.styleCache)(t),r=e.maskDepth;return()=>{if(r.value===0)return n()}},drawTextAffine:t=>e=>n=>{const r=jn(n.ctx),i=n.maskDepth;return()=>{if(i.value===0)return r(),n.styleCache.font.value="",n.styleCache.fill.value="",n.styleCache.stroke.value="",wl(n.ctx)(t)(),P_(n.ctx)(n.styleCache)(e)(),Zn(n.ctx)(),n.styleCache.font.value="",n.styleCache.fill.value="",n.styleCache.stroke.value=""}},pushTransform:t=>e=>{const n=jn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0)return n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="",Yu(e.ctx)({translateX:t.tx,translateY:t.ty})(),uo(e.ctx)({scaleX:t.sx,scaleY:t.sy})()}},popTransform:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushBakedTransform:t=>e=>{const n=jn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0)return n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="",Yu(e.ctx)({translateX:t.tx,translateY:t.ty})(),uo(e.ctx)({scaleX:t.sx,scaleY:t.sy})()}},popBakedTransform:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushClip:t=>e=>n=>{const r=jn(n.ctx),i=n.maskDepth;return()=>{if(i.value===0){if(r(),n.styleCache.font.value="",n.styleCache.fill.value="",n.styleCache.stroke.value="",fu(n.ctx)(t)(),e==="NonZero")return xl(n.ctx)();if(e==="EvenOdd")return cJ(n.ctx)();g()}}},popClip:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushBlend:t=>e=>{const n=jn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0){if(n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="",t==="Normal")return Tc(e.ctx)(Ql)();if(t==="Difference")return Tc(e.ctx)(Dl)();g()}}},popBlend:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushAlpha:t=>e=>{const n=jn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0){n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="";const i=e.groupAlpha.value,o=e.alphaSaves.value;e.alphaSaves.value=[...o,i];const u=i*t;return e.groupAlpha.value=u,yl(e.ctx)(u)()}}},popAlpha:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0){e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value="";const r=t.alphaSaves.value,i=pr(r);if(i.tag==="Just")return t.alphaSaves.value=i._1.init,t.groupAlpha.value=i._1.last;if(i.tag==="Nothing")return t.groupAlpha.value=1;g()}}},pushBlur:t=>e=>{const n=jn(e.ctx),r=e.maskDepth;return()=>{if(r.value===0){n(),e.styleCache.font.value="",e.styleCache.fill.value="",e.styleCache.stroke.value="";const i=gJ(e.ctx)(t);if(t>=.01)return i()}}},popBlur:t=>{const e=Zn(t.ctx),n=t.maskDepth;return()=>{if(n.value===0)return e(),t.styleCache.font.value="",t.styleCache.fill.value="",t.styleCache.stroke.value=""}},pushLayer:t=>e=>{if(t==="LayerNodeMask"){const n=e.maskDepth;return()=>{const r=n.value;n.value=r+1|0}}return()=>{}},popLayer:t=>{const e=t.maskDepth;return()=>{const n=e.value,r=n-1|0;if(n>0)return t.maskDepth.value=r}},setViewport:t=>e=>{const n=bJ(e.ctx)(e.surface)(t),r=e.maskDepth;return()=>{if(r.value===0)return n()}},clearBackground:t=>e=>{const n=yJ(e.ctx)(e.surface)(e.styleCache)(t),r=e.maskDepth;return()=>{if(r.value===0)return n()}},backgroundDots:t=>e=>{const n=xJ(e.ctx)(e.styleCache)(t),r=e.maskDepth;return()=>{if(r.value===0)return n()}},measureText:t=>e=>n=>{const r=f_(t)(e);return()=>r},measureInk:t=>e=>n=>{const r=__(t)(e);return()=>r},insideTokenStyle:t=>e=>()=>J_,Monad0:()=>kJ},EJ=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},oi=t=>e=>n=>{const r=EJ(.05)(1-t-e);return n<t?0:n>1-e?1:(n-t)/r},Q_=t=>{const e=rt.compare(0)(t),n=(()=>{if(e==="LT")return t;if(e==="EQ"||e==="GT")return 0;g()})(),r=rt.compare(1)(n);if(r==="LT"||r==="EQ")return 1;if(r==="GT")return n;g()},_u=t=>{if(t.tag==="Hidden")return{alpha:0,scale:0};if(t.tag==="Visible")return{alpha:1,scale:1};if(t.tag==="PloppingIn")return{alpha:t._1>0?1:0,scale:bi(8)(.6)(Q_(t._1))};if(t.tag==="PloppingOut")return{alpha:t._1<1?1:0,scale:bi(8)(.6)(Q_(1-t._1))};g()};function SJ(t,e){const n=e.x-t.x,r=e.y-t.y;return Math.sqrt(n*n+r*r)}function CJ(t){const e=t.length,n=new Array(e);for(let r=0;r<e;r++){const i=t[r],o=t[(r+1)%e];n[r]={a:i,b:o,len:SJ(i,o)}}return n}function GJ(t,e,n){let r=0;for(let i=0;i<t.length;i++){const o=t[i],u=r,s=u+o.len;if(n<=s){const a=o.len>1e-6?(n-u)/o.len:0;return{x:o.a.x+(o.b.x-o.a.x)*a,y:o.a.y+(o.b.y-o.a.y)*a}}r=s}return e.length>0?e[e.length-1]:{x:0,y:0}}function D_(t,e){if(e.length===0)return[];const n=CJ(e);let r=0;for(let o=0;o<n.length;o++)r+=n[o].len;const i=new Array(t);for(let o=0;o<t;o++)i[o]=GJ(n,e,o*r/t);return i}function PJ(t,e){const n=e.length;if(n===0)return e;const r=(t%n+n)%n|0,i=new Array(n);for(let o=0;o<n;o++)i[o]=e[(o+r)%n];return i}function AJ(t,e){const n=e.length;if(n===0)return e;let r=0,i=1/0;for(let o=0;o<n;o++){let u=0;for(let s=0;s<n;s++){const a=t[s]||{x:0,y:0},c=e[(s+o)%n]||{x:0,y:0},f=a.x-c.x,d=a.y-c.y;u+=f*f+d*d}u<i&&(i=u,r=o)}return PJ(r,e)}const F_=t=>e=>n=>{const r=D_(t,e),i=D_(t,n),o=AJ(r,i);return{from:r,to:o}};function z_(t){const e=t.length;if(e===0)return{x:0,y:0};let n=0,r=0;for(let i=0;i<e;i++)n+=t[i].x,r+=t[i].y;return{x:n/e,y:r/e}}function IJ(t,e){const n=e.x-t.x,r=e.y-t.y,i=Math.sqrt(n*n+r*r);return i<=1e-4?{x:1,y:0}:{x:n/i,y:r/i}}function QJ(t,e){const n=e.length;if(n===0)return e;const r=new Array(n);for(let i=0;i<n;i++){const o=e[((i-1)%n+n)%n],u=e[((i+1)%n+n)%n],s=e[i];r[i]={x:s.x+((o.x+u.x)/2-s.x)*t,y:s.y+((o.y+u.y)/2-s.y)*t}}return r}function DJ(t){return t<0?0:t>1?1:t}const B_=t=>e=>n=>r=>{const i=e.length;if(i===0)return[];const o=z_(e),u=z_(n),s=IJ(o,u),a=new Array(i);let c=1/0,f=-1/0;for(let _=0;_<i;_++){const h=e[_],p=(h.x-o.x)*s.x+(h.y-o.y)*s.y;a[_]=p,p<c&&(c=p),p>f&&(f=p)}const d=f-c;let l=new Array(i);for(let _=0;_<i;_++){const h=e[_],p=n[_];if(p===void 0){l[_]=h;continue}const m=d<=1e-4?0:r.maxDelay*(1-(a[_]-c)/d),y=Math.max(1e-4,1-m),x=DJ((t-m)/y),N=x*x*(3-2*x);l[_]={x:h.x+(p.x-h.x)*N,y:h.y+(p.y-h.y)*N}}for(let _=0;_<r.smoothPasses;_++)l=QJ(.5,l);return l},Sn=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},M_=w(Mr)(0),W_=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},FJ=w(t=>e=>t+e.len)(0),ha=t=>{const e=Mt(n=>J,n=>r=>T("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return[];if(e.tag==="Just")return[1,e._1.head.x,e._1.head.y,...Tt(kt(1,t.length,t))(n=>[2,n.x,n.y]),5];g()},zJ=t=>e=>{const n=Sn(e)(Sn(t.w/2)(t.h/2));return[1,t.x+n,t.y,2,t.x+t.w-n,t.y,3,t.x+t.w,t.y,t.x+t.w,t.y+n,2,t.x+t.w,t.y+t.h-n,3,t.x+t.w,t.y+t.h,t.x+t.w-n,t.y+t.h,2,t.x+n,t.y+t.h,3,t.x,t.y+t.h,t.x,t.y+t.h-n,2,t.x,t.y+n,3,t.x,t.y,t.x+n,t.y,5]},BJ=t=>{const e=Mt(n=>J,n=>r=>T("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return[];if(e.tag==="Just")return[1,e._1.head.x,e._1.head.y,...Tt(e._1.tail)(n=>[2,n.x,n.y])];g()},MJ=t=>{const e={x:t.x,y:t.y,w:t.w,h:t.h};if(t.shape==="Cylinder")return k_(e);if(t.shape==="Parallelogram")return v_(e);if(t.shape==="Diamond")return C_(e);if(t.shape==="Ellipse")return T_(e);if(t.shape==="Document")return b_(e);if(t.shape==="Cloud")return G_(e)(7);if(t.shape==="Rectangle")return zJ(e)(7);g()},pe=t=>e=>n=>H(r=>{const i=et(r)/et(n);return{x:t.x+(e.x-t.x)*i,y:t.y+(e.y-t.y)*i}})(zt(0,n-1|0)),WJ=t=>{const e=un(t.w*.18)(t.h*.6);return[...pe({x:t.x+e,y:t.y})({x:t.x+t.w,y:t.y})(16),...pe({x:t.x+t.w,y:t.y})({x:t.x+t.w-e,y:t.y+t.h})(16),...pe({x:t.x+t.w-e,y:t.y+t.h})({x:t.x,y:t.y+t.h})(16),...pe({x:t.x,y:t.y+t.h})({x:t.x+e,y:t.y})(16)]},ui=t=>e=>{const n=Sn(t)(Sn(e.w/2)(e.h/2));return{...e,x:e.x+n,y:e.y+n,w:e.w-2*n,h:e.h-2*n}},pa=t=>e=>{const n=e.y-t.y,r=e.x-t.x;return Ce(r*r+n*n)},RJ=t=>be(e=>n=>({a:e,b:n,len:pa(e)(n)}),t,kt(1,t.length,t)),qJ=t=>e=>{const n=e.length-1|0,r=n>=0&&n<e.length?T("Just",e[n]):J,i=(()=>{if(r.tag==="Just")return[r._1];if(r.tag==="Nothing")return[];g()})(),o=0<e.length?T("Just",e[0]):J,u=(()=>{if(o.tag==="Just")return o._1;if(o.tag==="Nothing")return{x:0,y:0};g()})(),s=e.length;return s<3?e:[u,...Tt(zt(1,s-2|0))(a=>{const c=a+1|0,f=c>=0&&c<e.length?T("Just",e[c]):J,d=a>=0&&a<e.length?T("Just",e[a]):J,l=a-1|0,_=l>=0&&l<e.length?T("Just",e[l]):J;if(_.tag==="Just"&&d.tag==="Just"&&f.tag==="Just"){const h=d._1,p=pa(h)(f._1),m=pa(_._1)(h),y=Sn(t)(p/2),x=Sn(t)(m/2),N=p>0?y/p:0,v=h.x+(f._1.x-h.x)*N,b=h.y+(f._1.y-h.y)*N,k=m>0?x/m:0,E=h.x+(_._1.x-h.x)*k,A=h.y+(_._1.y-h.y)*k;return H($=>{const tt=et($)/et(10),S=1-tt;return{x:S*S*E+2*S*tt*h.x+tt*tt*v,y:S*S*A+2*S*tt*h.y+tt*tt*b}})(zt(0,10))}return[]}),...i]},HJ=t=>e=>n=>r=>i=>H(o=>{const u=et(o)/et(i),s=1-u,a=u*u*u,c=3*s*u*u,f=3*s*s*u,d=s*s*s;return{x:d*t.x+f*e.x+c*n.x+a*r.x,y:d*t.y+f*e.y+c*n.y+a*r.y}})(zt(0,i-1|0)),OJ=t=>[...pe({x:t.x,y:t.y})({x:t.x+t.w,y:t.y})(12),...pe({x:t.x+t.w,y:t.y})({x:t.x+t.w,y:t.y+t.h*.85})(12),...HJ({x:t.x+t.w,y:t.y+t.h*.85})({x:t.x+t.w*.66,y:t.y+t.h*1.05})({x:t.x+t.w*.34,y:t.y+t.h*.65})({x:t.x,y:t.y+t.h*.85})(32),...pe({x:t.x,y:t.y+t.h*.85})({x:t.x,y:t.y})(12)],R_=t=>e=>H(n=>{const r=6.283185307179586*et(n)/et(64);return{x:t.x+e*rn(r),y:t.y+e*Ve(r)}})(zt(0,63)),du=t=>e=>{const n=.5522847498*e;return[1,t.x+e,t.y,4,t.x+e,t.y+n,t.x+n,t.y+e,t.x,t.y+e,4,t.x-n,t.y+e,t.x-e,t.y+n,t.x-e,t.y,4,t.x-e,t.y-n,t.x-n,t.y-e,t.x,t.y-e,4,t.x+n,t.y-e,t.x+e,t.y-n,t.x+e,t.y,5]},$J=t=>{const e=t.y+t.h/2,n=un(t.h*.4)(t.w*.2);return[...pe({x:t.x+n,y:t.y})({x:t.x+t.w-n,y:t.y})(10),...pe({x:t.x+t.w-n,y:t.y})({x:t.x+t.w,y:e})(8),...pe({x:t.x+t.w,y:e})({x:t.x+t.w-n,y:t.y+t.h})(8),...pe({x:t.x+t.w-n,y:t.y+t.h})({x:t.x+n,y:t.y+t.h})(10),...pe({x:t.x+n,y:t.y+t.h})({x:t.x,y:e})(8),...pe({x:t.x,y:e})({x:t.x+n,y:t.y})(8)]},q_=t=>{const e=t.length;return e===0?{x:0,y:0}:{x:M_(H(n=>n.x)(t))/et(e),y:M_(H(n=>n.y)(t))/et(e)}},lu=t=>e=>n=>r=>i=>H(o=>{const u=n+(r-n)*(et(o)/et(i));return{x:t.x+e*rn(u),y:t.y+e*Ve(u)}})(zt(0,i-1|0)),H_=t=>e=>{const n=Sn(t)(Sn(e.w/2)(e.h/2));return[...pe({x:e.x+n,y:e.y})({x:e.x+e.w-n,y:e.y})(6),...lu({x:e.x+e.w-n,y:e.y+n})(n)(4.71238898038469)(6.283185307179586)(12),...pe({x:e.x+e.w,y:e.y+n})({x:e.x+e.w,y:e.y+e.h-n})(6),...lu({x:e.x+e.w-n,y:e.y+e.h-n})(n)(0)(1.5707963267948966)(12),...pe({x:e.x+e.w-n,y:e.y+e.h})({x:e.x+n,y:e.y+e.h})(6),...lu({x:e.x+n,y:e.y+e.h-n})(n)(1.5707963267948966)(3.141592653589793)(12),...pe({x:e.x,y:e.y+e.h-n})({x:e.x,y:e.y+n})(6),...lu({x:e.x+n,y:e.y+n})(n)(3.141592653589793)(4.71238898038469)(12)]},hu=t=>e=>n=>r=>i=>o=>H(u=>{const s=r+(i-r)*(et(u)/et(o));return{x:t.x+e*rn(s),y:t.y+n*Ve(s)}})(zt(0,o-1|0)),XJ=t=>{const e=t.h*.38;return[...Tt(S_(E_(L_)({x:t.x,y:t.y-e,w:t.w,h:e}))(t.y))(n=>{const r=yr(n.p2.y-n.c.cy)(n.p2.x-n.c.cx),i=yr(n.p1.y-n.c.cy)(n.p1.x-n.c.cx);return hu({x:n.c.cx,y:n.c.cy})(n.c.r)(n.c.r)(i)(r>i?r:r+6.283185307179586)(16)}),...pe({x:t.x+t.w,y:t.y})({x:t.x+t.w,y:t.y+t.h})(8),...pe({x:t.x+t.w,y:t.y+t.h})({x:t.x,y:t.y+t.h})(12),...pe({x:t.x,y:t.y+t.h})({x:t.x,y:t.y})(8)]},YJ=t=>{const e=Sn(t.h*.075)(t.w*.075),n=t.w/2,r=t.y+e,i=t.y+t.h+5-e-2,o=t.x+n;return[...hu({x:o,y:r})(n)(e)(3.141592653589793)(6.283185307179586)(24),...pe({x:t.x+t.w,y:r})({x:t.x+t.w,y:i})(12),...hu({x:o,y:i})(n)(e)(0)(3.141592653589793)(24),...pe({x:t.x,y:i})({x:t.x,y:r})(12)]},Gr=t=>e=>e.shape==="Cylinder"?YJ(e):e.shape==="Parallelogram"?WJ(e):e.shape==="Diamond"?$J(e):e.shape==="Ellipse"?H_(un(e.w)(e.h)/2)(e):e.shape==="Document"?OJ(e):e.shape==="Cloud"?XJ(e):H_(t)(e),VJ=t=>{const e=Sn(t.h*.075)(t.w*.075),n=t.w/2;return hu({x:t.x+n,y:t.y+e})(n)(e)(0)(3.141592653589793)(24)},UJ=t=>e=>n=>w(r=>i=>{const o=r.pos+i.len,u=n<o?(n-r.pos)/i.len:1,s={x:i.a.x+(i.b.x-i.a.x)*u,y:i.a.y+(i.b.y-i.a.y)*u},a=e>r.pos?(e-r.pos)/i.len:0,c={x:i.a.x+(i.b.x-i.a.x)*a,y:i.a.y+(i.b.y-i.a.y)*a},f=r.points.length-1|0,d=f>=0&&f<r.points.length?(()=>{const l=r.points[f].x-c.x;return(l<0?-l<1e-4:l<1e-4)&&(()=>{const _=r.points[f].y-c.y;return _<0?-_<1e-4:_<1e-4})()})()?Dt(r.points)(s):[...r.points,c,s]:[c,s];return i.len<=0||o<=e||r.pos>=n?{...r,pos:o}:{pos:o,points:d}})({pos:0,points:[]})(t).points,KJ=t=>e=>n=>{const r=Mt(i=>J,i=>o=>T("Just",{head:i,tail:o}),t);if(r.tag==="Nothing")return[];if(r.tag==="Just"){const i=RJ(t),o=FJ(i),u=W_(0)(o)(e*o),s=W_(0)(o)(n*o);return s<=u?[]:UJ(i)(u)(s)}g()},jJ=t=>e=>n=>r=>{const i=r.x-n.x,o=r.y-n.y,u=e.x-t.x,s=e.y-t.y,a=n.x-t.x,c=n.y-t.y,f=u*o-s*i,d=(a*o-c*i)/f,l=(a*s-c*u)/f;return(f<0?-f<1e-9:f<1e-9)?J:d>=0&&d<=1&&l>=0&&l<=1?T("Just",d):J},ZJ=t=>e=>n=>{const r=Et(i=>o=>rt.compare(i.t)(o.t))(xt(i=>{const o=jJ(e)(n)(i._1)(i._2);return o.tag==="Just"?T("Just",{t:o._1,p:{x:e.x+(n.x-e.x)*o._1,y:e.y+(n.y-e.y)*o._1}}):J})(be(ln,t,[...kt(1,t.length,t),...kt(0,1,t)])));return 0<r.length?T("Just",r[0].p):J},O_=t=>e=>{const n=pr(e);if(n.tag==="Nothing")return e;if(n.tag==="Just"){const r=n._1.init.length-1|0;if(r>=0&&r<n._1.init.length){const i=ZJ(t)(n._1.init[r])(n._1.last);if(i.tag==="Just")return Dt(n._1.init)(i._1);if(i.tag==="Nothing")return e;g()}return e}g()},gr=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},ma=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},tw=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},ew=t=>e=>{const n=gr(0)(t.y+4-e.y)+gr(0)(e.y+e.h-(t.y+t.h-4)),r=gr(0)(t.x+4-e.x)+gr(0)(e.x+e.w-(t.x+t.w-4));return r*e.h+n*e.w+r*n},nw=t=>e=>{const n=t.y+t.h-6,r=t.y+6,i=t.x+14,o=t.x+t.w-14,u=w(gr)(0)(H(s=>i-10<s.x+s.w+12&&o+10>s.x-12&&r-10<s.y+s.h+12&&n+10>s.y-12?ma((s.x+s.w+12-(i-10))/.7071067811865476)((n+10-(s.y-12))/.7071067811865476):0)(e));return{...t,x:t.x+u*.7071067811865476,y:t.y-u*.7071067811865476}},rw=t=>e=>{const n=ma(t.x+t.w)(e.x+e.w)-gr(t.x)(e.x),r=ma(t.y+t.h)(e.y+e.h)-gr(t.y)(e.y);return t.x<e.x+e.w&&t.x+t.w>e.x&&t.y<e.y+e.h&&t.y+t.h>e.y?n*r:0},$_=t=>e=>n=>r=>{const i=t+4,o=gr(0)(e-8),u=i+o-n;return n<=o?tw(i)(u)(r):t+(e-n)/2},X_=t=>e=>({...e,x:$_(t.x)(t.w)(e.w)(e.x),y:$_(t.y)(t.h)(e.h)(e.y)}),iw=t=>{const e=2*t.token.x-t.rect.x-t.rect.w,n=t.token.y-t.rect.h/2,r=t.token.x-t.rect.w/2,i=2*t.token.y-t.rect.y-t.rect.h;return[{...t.rect,x:t.rect.x,y:t.rect.y},{...t.rect,x:e,y:t.rect.y},{...t.rect,x:t.rect.x,y:i},{...t.rect,x:e,y:i},{...t.rect,x:t.rect.x,y:n},{...t.rect,x:e,y:n},{...t.rect,x:r,y:t.rect.y},{...t.rect,x:r,y:i}]},ow=t=>e=>n=>r=>i=>{const o=i.y+i.h/2-n.token.y,u=i.y-r.y;return(()=>{const s=i.x+i.w/2-n.token.x,a=i.x-r.x;return 1e6*ew(t)(i)+1e4*w(c=>f=>c+rw(i)(f))(0)(e)+.05*(a*a+u*u)+.01*(s*s+o*o)})()+(i.y>n.token.y?100:0)},uw=t=>e=>n=>r=>{const i=u=>{const s=X_(t)(u);return{rect:s,score:ow(t)(e)(n)(r)(s)}},o=Mt(u=>J,u=>s=>T("Just",{head:u,tail:s}),[r,n.rect,...iw(n)]);if(o.tag==="Nothing")return X_(t)(r);if(o.tag==="Just")return w(u=>s=>{const a=i(s);return a.score<u.score?a:u})(i(o._1.head))(o._1.tail).rect;g()},sw=t=>e=>n=>w(r=>i=>{const o=nw(i.rect)(r.obstacles),u=o.x>=t.x+4&&o.y>=t.y+4&&o.x+o.w<=t.x+t.w-4&&o.y+o.h<=t.y+t.h-4?o:uw(t)(r.obstacles)(i)(o);return{acc:Z(G)(i.id)(u)(r.acc),obstacles:Dt(r.obstacles)(u)}})({acc:D,obstacles:e})(n).acc,ya=t=>t,qn=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Pr=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},aw=oc(ic)(Bt),cw=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},gw=t=>e=>{const n=nt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Y_=ya("SegMove"),fw=ya("SegLine"),_w=ya("SegQuad"),V_={offset:.4,passes:1,rMax:1.5},U_=t=>xe(xn(t.x*7919+t.y*3001+t.w*113+t.h*17+1))*-1640531535|0,pu=t=>e=>n=>()=>{t.push(3),t.push(e.x),t.push(e.y),t.push(n.x),t.push(n.y)},mu=t=>e=>()=>{t.push(1),t.push(e.x),t.push(e.y)},Hn=t=>e=>()=>{t.push(2),t.push(e.x),t.push(e.y)},Oi=(()=>{const t=w(e=>n=>((e*31|0)+xe(xn(n.x*100))|0)+xe(xn(n.y*100))|0)(1);return e=>t(e)*-1640531535|0})(),dw=t=>{const e=[];let n=0,r={x:0,y:0};for(;n<t.length;){const i=n,o=r,u=i>=0&&i<t.length?T("Just",t[i]):J;if(u.tag==="Nothing"){n=t.length;continue}if(u.tag==="Just"){if(u._1===1){const s={x:(()=>{const a=i+1|0;return a>=0&&a<t.length?t[a]:0})(),y:(()=>{const a=i+2|0;return a>=0&&a<t.length?t[a]:0})()};e.push({kind:Y_,m:o,c:o,p:s,len:0}),r=s,n=i+3|0;continue}if(u._1===2){const s={x:(()=>{const f=i+1|0;return f>=0&&f<t.length?t[f]:0})(),y:(()=>{const f=i+2|0;return f>=0&&f<t.length?t[f]:0})()},a=s.x-o.x,c=s.y-o.y;e.push({kind:fw,m:o,c:o,p:s,len:Ce(a*a+c*c)}),r=s,n=i+3|0;continue}if(u._1===3){const s={x:(()=>{const f=i+3|0;return f>=0&&f<t.length?t[f]:0})(),y:(()=>{const f=i+4|0;return f>=0&&f<t.length?t[f]:0})()},a=s.x-o.x,c=s.y-o.y;e.push({kind:_w,m:o,c:{x:(()=>{const f=i+1|0;return f>=0&&f<t.length?t[f]:0})(),y:(()=>{const f=i+2|0;return f>=0&&f<t.length?t[f]:0})()},p:s,len:Ce(a*a+c*c)*1.05}),r=s,n=i+5|0;continue}if(u._1===5){e.push({kind:Y_,m:o,c:o,p:o,len:0}),n=i+1|0;continue}n=t.length;continue}g()}return e},lw=t=>e=>{const n=e.length-1|0,r=n<1?[]:kt(0,n,e),i=(()=>{const u=r.length-1|0;return u>=0&&u<r.length?T("Just",r[u]):J})(),o=e.length-1|0;if(o>=0&&o<e.length&&i.tag==="Just"){const u=e[o].y-i._1.y,s=e[o].x-i._1.x,a=Ce(s*s+u*u);return a<=1e-4?e:Dt((()=>{const c=e.length-1|0;return c<1?[]:kt(0,c,e)})())({x:e[o].x+s/a*t,y:e[o].y+u/a*t})}return e},hw=t=>e=>n=>ve(w(r=>i=>{const o=he(0)(t)(r.prng),u=he(0)(6.283185307179586)(o.prng);return{prng:u.prng,out:[{x:i.x+o.value*rn(u.value),y:i.y+o.value*Ve(u.value)},...r.out]}})({prng:e,out:[]})(n).out),pw=t=>e=>n=>{if(e.kind==="SegMove")return mu(t)(e.p);if(e.kind==="SegLine")return Hn(t)({x:e.m.x+(e.p.x-e.m.x)*n,y:e.m.y+(e.p.y-e.m.y)*n});if(e.kind==="SegQuad")return Hn(t)({x:e.m.x+(e.p.x-e.m.x)*n,y:e.m.y+(e.p.y-e.m.y)*n});g()},mw=t=>e=>{if(e.kind==="SegMove")return mu(t)(e.p);if(e.kind==="SegLine")return Hn(t)(e.p);if(e.kind==="SegQuad")return pu(t)(e.c)(e.p);g()},K_=t=>e=>{const n=dw(e),r=w(s=>a=>s+a.len)(0)(n)*qn(0)(Pr(1)(t)),i=[];let o=0,u=0;for(;u<n.length;){const s=u,a=o;if(s>=0&&s<n.length){if(a+n[s].len<=r){const c=n[s];mw(i)(c)(),o=a+c.len,u=s+1|0;continue}if(a>=r){u=n.length;continue}pw(i)(n[s])((r-a)/qn(n[s].len)(1e-4))()}u=n.length}return i},j_={offset:1.5,passes:2,rMax:14,overshoot:2.5},Z_=t=>e=>n=>r=>{const i=r.y-n.y,o=n.y-e.y,u=r.x-n.x,s=Ce(u*u+i*i),a=n.x-e.x,c=Ce(a*a+o*o),f=Pr(t.rMax*(qd(c>0&&s>0?qn(-1)(Pr(1)((a*u+o*i)/(c*s))):1)/3.141592653589793))(.4*Pr(c)(s));return{inP:c>0?{x:n.x-a/c*f,y:n.y-o/c*f}:n,curr:n,outP:s>0?{x:n.x+u/s*f,y:n.y+i/s*f}:n}},t1=t=>e=>{const n=e.length,r=[],i=0<e.length?T("Just",e[0]):J;if(i.tag==="Just"?mu(r)(i._1)():i.tag==="Nothing"||g(),n>=3){let u=1;for(;u<=(n-2|0);){const s=u,a=s+1|0;if(a>=0&&a<e.length){if(s>=0&&s<e.length){const c=s-1|0;if(c>=0&&c<e.length){const f=Z_(t)(e[c])(e[s])(e[a]);Hn(r)(f.inP)(),pu(r)(f.curr)(f.outP)()}}u=s+1|0;continue}u=s+1|0}}const o=e.length-1|0;return o>=0&&o<e.length&&n>=2&&Hn(r)(e[o])(),r},yw=t=>e=>n=>r=>i=>{if(i.length<4)return t1(t)(i);const o=0<i.length?T("Just",i[0]):J,u=(()=>{if(o.tag==="Nothing")return{x:0,y:0};if(o.tag==="Just")return o._1;g()})(),s=i.length-1|0,a=Kn(Kn(e)(s)+s|0)(s),c=_=>{const h=Kn(_+s|0)(s);return h>=0&&h<i.length?i[h]:u},f=H(_=>Z_(t)(c((a+_|0)-1|0))(c(a+_|0))(c((a+_|0)+1|0)))(zt(0,s-1|0)),d=[],l=0<f.length?T("Just",f[0]):J;if(l.tag==="Just")if(mu(d)(l._1.outP)(),aw((()=>{const _=Mt(h=>J,h=>p=>T("Just",p),f);if(_.tag==="Nothing")return[];if(_.tag==="Just")return _._1;g()})())(_=>{const h=Hn(d)(_.inP);return()=>(h(),pu(d)(_.curr)(_.outP)())})(),n)Hn(d)(l._1.inP)(),pu(d)(l._1.curr)(l._1.outP)(),d.push(5);else{const _=f.length-1|0;_>=0&&_<f.length?Hn(d)((()=>{const h=1-r;return{x:f[_].outP.x+(l._1.inP.x-f[_].outP.x)*h,y:f[_].outP.y+(l._1.inP.y-f[_].outP.y)*h}})())():Hn(d)(l._1.inP)()}else l.tag==="Nothing"||g();return d},si=t=>e=>n=>r=>{const i=cw(1)(r.length-1|0),o=he(0)(et(i))(ga("shape")(e)),u=gw(i-1|0)(xe(xn(o.value))),s=o.prng;return H(a=>{const c=he(0)(1)(ga(ue(a))(s)),f=he(-.18)(.3)(c.prng),d=c.value<.7,l=he(.5)(.85)(f.prng),_=hw(t.offset)(l.prng)(r);return{path:n?yw(t)(u)(d)(f.value)(_):t1(t)(_),alpha:l.value}})(zt(0,t.passes-1|0))},xw=t=>e=>n=>si(t)(e)(!0)([{x:n.x,y:n.y},{x:n.x+n.w,y:n.y},{x:n.x+n.w,y:n.y+n.h},{x:n.x,y:n.y+n.h},{x:n.x,y:n.y}]),Nw=t=>e=>n=>{const r=qn(0)(Pr(1)(n)),i=e.h/et(4),o=qn(6)(i*1.4);return xt(u=>u)(H(u=>{if(r<qn(0)(et(u)/et(4)-.05))return J;const s=ga(ue(u))(t),a=qn(0)(et(u)/et(4)-.05),c=Kn(u)(2)===0,f=c?e.x-2:e.x+e.w+2,d=c?e.x+e.w+2:e.x-2,l=e.y+(et(u)+.5)*i;return T("Just",{path:K_(qn(0)(Pr(1)((r-a)/qn(1e-4)(Pr(1)(et(u+1|0)/et(4)+.05)-a))))((()=>{const _={rMax:2,offset:.6,passes:1},h=ve(w(m=>y=>{const x=he(-i*.08)(i*.08)(m.prng);return{prng:x.prng,out:[{x:f+(d-f)*(et(y)/et(4)),y:l+x.value},...m.out]}})({prng:s,out:[]})(zt(0,4)).out),p=h.length<2?[]:si(_)(s)(!1)(h);return 0<p.length?p[0].path:[]})()),width:o,alpha:1})})(zt(0,3)))},xa=(t,e,n)=>({tag:t,_1:e,_2:n}),e1=t=>t,Na=(t,e,n)=>({tag:t,_1:e,_2:n}),yu=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},ae=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Qe=(()=>{const t=Ue.unfoldr(Jn);return e=>t(Ke("IterNode",e,Nn))})(),Cn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Jw=Bt.foldMap(il),xu=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},ww=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Nu=t=>e=>{const n=nt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},n1=te(G)(Bt),r1=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Tw=pc(G),vw=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Ja=e1("LabelsShown"),bw=e1("LabelsHidden"),i1=t=>{const e=t.Monad0().Bind1(),n=t.popTransform,r=t.popAlpha;return i=>o=>u=>s=>a=>e.bind(t.pushAlpha(i.fadeAlpha))(()=>e.bind(t.pushTransform({tx:o*(1-i.popScale),ty:u*(1-i.popScale),sx:i.popScale,sy:i.popScale}))(()=>e.bind(t.pushTransform({tx:0,ty:s.y*(1-i.flipY),sx:1,sy:i.flipY}))(()=>e.bind(a)(()=>e.bind(n)(()=>e.bind(n)(()=>r))))))},tn=t=>{const e=t.Apply0();return n=>w(r=>i=>e.apply(e.Functor0().map(o=>Ka)(r))(n(i)))(t.pure())},o1=t=>e=>n=>r=>i=>o=>{const u={x:n.x+n.w/2,y:n.y+n.h/2},s={x:e.x+e.w/2,y:e.y+e.h/2},a=oi(i)(o)(r),c=0<t.length?T("Just",t[0]):J,f=(()=>{if(c.tag==="Just")return c._1;if(c.tag==="Nothing")return s;g()})(),d=t.length-1|0,l=d>=0&&d<t.length?T("Just",t[d]):J,_=(()=>{if(l.tag==="Just")return l._1;if(l.tag==="Nothing")return u;g()})(),h=F_(128)(Gr(4)(ui(2)(e)))(R_(f)(6)),p=f.x-s.x,m=2*(()=>{const V=f.y-s.y;return(p<0?-p:p)+(V<0?-V:V)})(),y=_.x-u.x,x=2*(()=>{const V=_.y-u.y;return(y<0?-y:y)+(V<0?-V:V)})(),N=m+mo(t)+x,v=N<=1e-4?1:1-x/N,b=N<=1e-4?0:m/N,k=v-b,E=F_(128)(R_(_)(6))(Gr(4)(ui(2)(n))),A={maxDelay:.4,smoothPasses:2},$=wi(t)(yu(0)(1)(k<=1e-4?0:(a-b)/k)),tt=(()=>{if($.tag==="Just")return $._1;if($.tag==="Nothing")return f;g()})(),S=(()=>{if(v>=1)return 0;const V=(a-v)/(1-v),U=V<0?0:V>1?1:V;return U*U*(3-2*U)})(),C=(()=>{if(b<=1e-4)return 1;const V=a/b,U=V<0?0:V>1?1:V;return U*U*(3-2*U)})();return a<b?Na("PolyShape",B_(C)(h.from)(h.to)(A)):a>=v?Na("PolyShape",B_(S)(E.from)(E.to)(A)):Na("CircleShape",tt,6)},wa=t=>e=>n=>r=>i=>o=>{const u=o1(t)(e)(n)(r)(i)(o);if(u.tag==="PolyShape")return q_(u._1);if(u.tag==="CircleShape")return u._1;g()},Ta=(()=>{const t={r:24,g:24,b:27,a:255},e={r:244,g:244,b:245,a:255},n={r:248,g:249,b:246,a:255},r={r:26,g:26,b:26,a:255},i={r:28,g:101,b:192,a:255},o={r:247,g:248,b:250,a:255},u={r:42,g:48,b:60,a:255},s={r:120,g:130,b:146,a:255};return a=>{if(a==="Light")return{bg:{r:255,g:255,b:255,a:255},bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:214,g:211,b:209,a:255},shadowFill:{r:255,g:255,b:255,a:255},shadowDot:{r:26,g:26,b:26,a:255},chip:{r:255,g:235,b:130,a:255},chipShadow:{r:214,g:211,b:209,a:255},chipText:Rn,nodeFill:oe,nodeStroke:Rn,text:Rn,edge:Rn,arrowFill:Rn,tokenOutsideFill:Rn,tokenOutsideStroke:oe,tokenInside:oe,tokenInsideStroke:oe,tokenInsideBlend:gu,tokenInsideAlpha:1,chipPillFill:Rn,chipPillText:oe,chipHairline:{r:26,g:26,b:26,a:90},trailDot:Rn,wobble:!1,fontFamily:"Ilisarniq, ui-sans-serif, system-ui, sans-serif"};if(a==="Dark")return{bg:t,bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:63,g:63,b:70,a:255},shadowFill:t,shadowDot:e,chip:{r:234,g:179,b:8,a:255},chipShadow:{r:0,g:0,b:0,a:120},chipText:t,nodeFill:Rn,nodeStroke:e,text:e,edge:e,arrowFill:e,tokenOutsideFill:oe,tokenOutsideStroke:oe,tokenInside:oe,tokenInsideStroke:oe,tokenInsideBlend:gu,tokenInsideAlpha:1,chipPillFill:e,chipPillText:t,chipHairline:{r:244,g:244,b:245,a:120},trailDot:e,wobble:!1,fontFamily:"Ilisarniq, ui-sans-serif, system-ui, sans-serif"};if(a==="Blueprint")return{bg:i,bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:90,g:160,b:230,a:255},shadowFill:i,shadowDot:oe,chip:oe,chipShadow:{r:0,g:0,b:0,a:120},chipText:i,nodeFill:i,nodeStroke:oe,text:oe,edge:oe,arrowFill:oe,tokenOutsideFill:oe,tokenOutsideStroke:oe,tokenInside:oe,tokenInsideStroke:oe,tokenInsideBlend:y_,tokenInsideAlpha:.35,chipPillFill:oe,chipPillText:i,chipHairline:{r:255,g:255,b:255,a:120},trailDot:oe,wobble:!1,fontFamily:"Ilisarniq, ui-sans-serif, system-ui, sans-serif"};if(a==="Whiteboard")return{bg:n,bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:0,g:0,b:0,a:0},shadowFill:n,shadowDot:r,chip:{r:217,g:74,b:56,a:255},chipShadow:{r:26,g:26,b:26,a:60},chipText:n,nodeFill:n,nodeStroke:r,text:r,edge:r,arrowFill:r,tokenOutsideFill:r,tokenOutsideStroke:n,tokenInside:n,tokenInsideStroke:n,tokenInsideBlend:y_,tokenInsideAlpha:1,chipPillFill:r,chipPillText:n,chipHairline:{r:26,g:26,b:26,a:90},trailDot:r,wobble:!0,fontFamily:"Supermarker, Ilisarniq, ui-sans-serif, system-ui, sans-serif"};if(a==="Isometric")return{bg:o,bgTransparent:{r:0,g:0,b:0,a:0},bgDot:{r:214,g:218,b:224,a:255},shadowFill:o,shadowDot:u,chip:{r:255,g:235,b:130,a:255},chipShadow:{r:100,g:110,b:125,a:90},chipText:u,nodeFill:{r:236,g:239,b:244,a:255},nodeStroke:u,text:u,edge:s,arrowFill:s,tokenOutsideFill:u,tokenOutsideStroke:oe,tokenInside:oe,tokenInsideStroke:oe,tokenInsideBlend:gu,tokenInsideAlpha:1,chipPillFill:u,chipPillText:oe,chipHairline:{r:60,g:66,b:78,a:90},trailDot:u,wobble:!1,fontFamily:"Ilisarniq, ui-sans-serif, system-ui, sans-serif"};g()}})(),va=t=>e=>Tt(Qe(t.nodes))(n=>{const r=ae(n._1)(e.nodes);return r.tag==="Just"&&_u(r._1).alpha>0?MJ(n._2):[]}),Lw=t=>e=>n=>[1,t.vx,t.vy,2,t.vx+t.vw,t.vy,2,t.vx+t.vw,t.vy+t.vh,2,t.vx,t.vy+t.vh,5,...va(e)(n)],kw=t=>{const e=t.Monad0(),n=e.Bind1(),r=e.Applicative0(),i=lr.traverse(r);return o=>u=>{const s=Jr(u),a=.32*o.size;return i(c=>n.bind(c===0?r.pure(0):t.measureText(o)(Je(c)(u)))(f=>n.bind(t.measureText(o)(Je(c+1|0)(u)))(d=>n.bind(t.measureInk(o)(c>=0&&c<s.length?go(s[c]):" "))(l=>r.pure({x:f,w:d-f,up:l.ascent-a,down:l.descent+a})))))(zt(0,s.length-1|0))}},Ew=t=>e=>{const n=i=>(i.x-e.x)*(i.x-e.x)+(i.y-e.y)*(i.y-e.y),r=w(i=>o=>n(o)<n(i)?o:i)({x:t.x,y:t.y})([{x:t.x,y:t.y},{x:t.x+t.w,y:t.y},{x:t.x,y:t.y+t.h},{x:t.x+t.w,y:t.y+t.h}]);return H(i=>{const o=et(i)/5;return{x:r.x+(e.x-r.x)*o,y:r.y+(e.y-r.y)*o}})([1,2,3,4])},ba=t=>{const e=Lo(`
7
+ `)(t);return e.length===0?[""]:e},Sw=t=>e=>n=>r=>i=>o=>{const u={x:n.x+n.w/2,y:n.y+n.h/2},s={x:e.x+e.w/2,y:e.y+e.h/2},a=oi(i)(o)(r),c=0<t.length?T("Just",t[0]):J,f=(()=>{if(c.tag==="Just")return c._1;if(c.tag==="Nothing")return s;g()})(),d=t.length-1|0,l=d>=0&&d<t.length?T("Just",t[d]):J,_=(()=>{if(l.tag==="Just")return l._1;if(l.tag==="Nothing")return u;g()})(),h=f.x-s.x,p=2*(()=>{const A=f.y-s.y;return(h<0?-h:h)+(A<0?-A:A)})(),m=_.x-u.x,y=2*(()=>{const A=_.y-u.y;return(m<0?-m:m)+(A<0?-A:A)})(),x=p+mo(t)+y,N=x<=1e-4?1:1-y/x,v=x<=1e-4?0:p/x,b=N-v,k=wi(t)(yu(0)(1)(b<=1e-4?0:(a-v)/b)),E=(()=>{if(k.tag==="Just")return k._1;if(k.tag==="Nothing")return f;g()})();return a<v?xa("InsideRect",ui(2)(e)):a>=N?xa("InsideRect",ui(2)(n)):xa("InsideBall",E,6)},Cw={offset:.8,passes:2,rMax:5},Gw=t=>{const e=t.Monad0().Applicative0(),n=tn(e);return r=>i=>o=>u=>{const s={color:u,width:1,lineJoin:Le,lineCap:mn},a={color:o,flat:!0},c=f=>t.drawRoundedRect({x:f.x,y:f.y,w:f.w,h:f.h})(4)(T("Just",a))(T("Just",s));return n(f=>{if(f._2.tag==="Travelling"){const d=Cn(f._2._1.edge)(r.edges),l=ae(f._2._1.target)(r.nodes),_=ae(f._2._1.source)(r.nodes);if(_.tag==="Just"&&l.tag==="Just"&&d.tag==="Just"){const h=Sw((()=>{if(f._2._1.direction==="Forward")return d._1;if(f._2._1.direction==="Backward")return ve(d._1);g()})())(_._1)(l._1)(f._2._1.progress)(f._2._1.holdPre)(f._2._1.holdPost);if(h.tag==="InsideRect")return c(h._1);if(h.tag==="InsideBall")return t.fillStrokePath(du(h._1)(h._2))(a)(s);g()}return e.pure()}if(f._2.tag==="Filling"){const d=ae(f._2._1.node)(r.nodes);if(d.tag==="Just")return c(ui(2)(d._1));if(d.tag==="Nothing")return e.pure();g()}return e.pure()})(Qe(i.tokens))}},u1=t=>e=>n=>r=>t.strokePath((()=>{const i=Mt(o=>J,o=>u=>T("Just",{head:o,tail:u}),H(o=>o.pt)(Fd(o=>u=>{const s=et(u)/et(72),a=he(-.18)(.18)(o.prng),c=he(-.1)(.1)(a.prng),f=he(-.07)(.07)(c.prng),d=n*(.05+.55*s)*(1+c.value),l=s*28.274333882308138+a.value;return{prng:f.prng,pt:{x:e.x+rn(l)*d+f.value*n,y:e.y+Ve(l)*d+f.value*n}}},{prng:137,pt:{x:e.x,y:e.y}},zt(0,72))));if(i.tag==="Just")return[1,i._1.head.x,i._1.head.y,...Jw(o=>[2,o.x,o.y])(i._1.tail)];if(i.tag==="Nothing")return[];g()})())({color:r,width:5.5,lineJoin:Le,lineCap:kn}),Pw=t=>{const e=t.Monad0(),n=e.Bind1(),r=t.popAlpha,i=tn(e.Applicative0());return o=>u=>s=>i(a=>n.bind(t.pushAlpha(a.alpha))(()=>n.bind(t.strokePath(a.path)({color:o.nodeFill,width:a.width,lineJoin:Le,lineCap:kn}))(()=>r)))(Nw(U_(u)+7777|0)(u)(s))},s1=t=>{const e=t.Monad0(),n=e.Bind1(),r=t.popAlpha,i=e.Applicative0(),o=tn(i),u=t.popClip,s=tn(i),a=lr.traverse(i),c=kw(t),f=Pw(t),d=t.popTransform;return l=>_=>h=>p=>m=>y=>x=>N=>v=>{const b=I=>n.bind(t.pushAlpha(I.alpha))(()=>n.bind(t.strokePath(I.path)({color:h.nodeStroke,width:2,lineJoin:Le,lineCap:kn}))(()=>r)),k={family:h.fontFamily,size:h.wobble?15:11,weight:h.wobble?800:500},E=Lo(`
8
+ `)(N.label===""?x:N.label),A=E.length===0?[""]:E,$=k.size*1.2,tt=N.shape==="Cylinder"?t.strokePath(sJ({x:N.x,y:N.y,w:N.w,h:N.h}))({color:h.nodeStroke,width:1.25,lineJoin:Le,lineCap:mn}):i.pure(),S=(N.shape==="Cylinder"?(N.y+(N.y+N.h+5-2*un(N.h*.075)(N.w*.075)))/2:(N.y+N.y+N.h)/2)-et(A.length)*$/2+$/2,C=v.tag==="PloppingOut"&&h.wobble?v._1:-1,V=C>=0,U=_u(v),M=V?{alpha:1,scale:1}:U,W=N.x+N.w/2,B=N.y+N.h/2,P=n.bind(t.pushAlpha(M.alpha*p))(()=>n.bind(t.pushTransform({tx:W*(1-M.scale),ty:B*(1-M.scale),sx:M.scale,sy:M.scale}))(()=>{const I={x:N.x,y:N.y,w:N.w,h:N.h},F={color:h.nodeStroke,width:h.wobble?2:1.25*_,lineJoin:Le,lineCap:h.wobble?kn:mn};return n.bind((()=>{if(h.wobble){if(N.shape==="Rectangle")return o(b)(xw(j_)(U_(I))(I));const Q=Gr(7)(N);return n.bind(o(b)((()=>{const R=Oi(Q);return Q.length<4?[]:si(V_)(R)(!0)(Q)})()))(()=>s(R=>o(b)((()=>{const Y=Oi(R);return R.length<2?[]:si(V_)(Y)(!1)(R)})()))(N.shape==="Cylinder"?[VJ(N)]:[]))}return n.bind(_a(t)(N.shape)(I)(7)(T("Just",{color:h.nodeFill,flat:!1}))(T("Just",F)))(()=>tt)})())(()=>n.bind((()=>{if(y.tag==="Just"&&h.wobble&&!V){const Q=y._1;return n.bind(a(c(k))(A))(R=>{const Y=Et(at=>ct=>rt.compare(at.x)(ct.x)),O=xe(xn(N.x*7919+N.y*3001))*-1640531535|0,X=he(5)(7.5)(O),q=he(0)(X.value)(X.prng),K=-(1+2*he(-1)(1)(q.prng).value*3.141592653589793/180),j=(at,ct,Nt,Jt,Lt)=>Y(xt(Ht=>Ht)([K*ct+at>=Jt&&K*ct+at<=Lt?T("Just",{x:ct,y:K*ct+at}):J,K*Nt+at>=Jt&&K*Nt+at<=Lt?T("Just",{x:Nt,y:K*Nt+at}):J,(()=>{const Ht=(Jt-at)/K;return Ht>=ct&&Ht<=Nt?T("Just",{x:Ht,y:Jt}):J})(),(()=>{const Ht=(Lt-at)/K;return Ht>=ct&&Ht<=Nt?T("Just",{x:Ht,y:Lt}):J})()])),ot=X.value,_t=Kn(Q.frameHash)(3),gt=_t===0?{r:200,g:35,b:30,a:220}:_t===1?{r:35,g:150,b:80,a:220}:{r:30,g:80,b:200,a:220},yt=N.x+N.w/2,Ct=Ye(Ft(at=>ct=>Ft((()=>{const Nt=S+et(at)*$,Jt=yt-w(Lt=>Ht=>Lt+Ht.w)(0)(ct)/2;return Lt=>Ht=>{const dn=k.size*.1,Fe=Lt-1|0,Pt=Fe>=0&&Fe<ct.length&&Lt>0?(ct[Fe].x+ct[Fe].w+Ht.x)/2:Ht.x-dn;return{x:Jt+Pt-1,y:Nt-Ht.up-1,w:xu(0)((()=>{const Qt=Lt+1|0;return Qt>=0&&Qt<ct.length&&Lt<(ct.length-1|0)?(Ht.x+Ht.w+ct[Qt].x)/2-Pt:Ht.x+Ht.w+dn-Pt})())+2,h:Ht.up+Ht.down+2}}})())(ct))(R)),Rt=N.y+4,pt=N.x+N.w-4,qt=N.x+4,wt=Rt-K*qt+q.value,mt=N.y+N.h-4,ft=Tt(Tt(Ft(at=>ct=>{const Nt=(ct.from.x+ct.to.x)/2,Jt=(ct.from.y+ct.to.y)/2,Lt=he(-1)(1)(O+(911*(at+1|0)|0)|0),Ht=he(-3)(5)(Lt.prng),dn=Lt.value*3.141592653589793/180,Fe=rn(dn),Pt=Ve(dn),Qt=ze=>({x:Nt+(ze.x-Nt)*Fe-(ze.y-Jt)*Pt,y:Jt+(ze.x-Nt)*Pt+(ze.y-Jt)*Fe});return{from:(()=>{const ze=Qt(ct.from),an=ze.y-Jt,Xe=ze.x-Nt,nn=Ce(Xe*Xe+an*an),Ae=nn<1e-4?1:(nn+Ht.value)/nn;return{x:Nt+Xe*Ae,y:Jt+an*Ae}})(),to:(()=>{const ze=Qt(ct.to),an=he(-3)(5)(Ht.prng).value,Xe=ze.y-Jt,nn=ze.x-Nt,Ae=Ce(nn*nn+Xe*Xe),$t=Ae<1e-4?1:(Ae+an)/Ae;return{x:Nt+nn*$t,y:Jt+Xe*$t}})()}})(xt(at=>{const ct=j(wt+et(at)*ot,qt,pt,Rt,mt);return ct.length===2?T("Just",{from:ct[0],to:ct[1]}):J})(zt(0,Nu(1)(xe(xn((mt-K*pt-wt)/ot)))))))(at=>ut(ct=>ct.to.x-ct.from.x>1,w(ct=>Nt=>Tt(ct)(Jt=>{const Lt=j(Jt.from.y-K*Jt.from.x,Nt.x,Nt.x+Nt.w,Nt.y,Nt.y+Nt.h);return Lt.length===2?Lt[0].x>Jt.from.x+.001&&Lt[1].x<Jt.to.x-.001?[{from:Jt.from,to:Lt[0]},{from:Lt[1],to:Jt.to}]:Lt[0].x<=Jt.from.x+.001&&Lt[1].x<Jt.to.x-.001?[{from:Lt[1],to:Jt.to}]:Lt[0].x>Jt.from.x+.001&&Lt[1].x>=Jt.to.x-.001?[{from:Jt.from,to:Lt[0]}]:[]:[Jt]}))([at])(Ct))))(at=>(()=>{const ct=at.to.x-at.from.x;return Ce(2)*(ct>=0?ct:-ct)<=28})()?[at]:[{from:at.from,to:{x:at.from.x+(at.to.x-at.from.x)*.495,y:at.from.y+(at.to.y-at.from.y)*.495}},{from:{x:at.from.x+(at.to.x-at.from.x)*.505,y:at.from.y+(at.to.y-at.from.y)*.505},to:at.to}]),st=ft.length,dt=at=>xu(0)(ww(1)(Q.t*et(st)-et(at)));return n.bind(t.pushClip(ha(Gr(7)(N)))(cu))(()=>n.bind(o(at=>{const ct=at._1,Nt=he(1.4)(1.9)(O+(1303*(ct+1|0)|0)|0),Jt=he(.35)(.8)(Nt.prng),Lt=o(Ht=>n.bind(t.pushAlpha(Ht.alpha*Jt.value))(()=>n.bind(t.strokePath(K_(dt(ct))(Ht.path))({color:gt,width:Nt.value,lineJoin:Le,lineCap:kn}))(()=>r)))(si({...j_,rMax:0,offset:.5})(O+(53*(ct+1|0)|0)|0)(!1)([at._2.from,at._2.to]));return dt(ct)>0?Lt:i.pure()})(Ft(ln)(ft)))(()=>u))})}return i.pure()})())(()=>n.bind((()=>{if(l==="LabelsShown"){const Q=n.bind(t.pushAlpha(m))(()=>n.bind(o(R=>t.drawText({x:N.x+N.w/2,y:S+et(R._1)*$,content:R._2,font:k,color:h.text,align:ri,baseline:cr}))(Ft(ln)(A)))(()=>r));return m>0?Q:i.pure()}if(l==="LabelsHidden")return i.pure();g()})())(()=>n.bind((()=>{const Q=f(h)(I)(C);return V?Q:i.pure()})())(()=>n.bind(d)(()=>r)))))}));return M.alpha*p>0?P:i.pure()}},a1=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=s1(t),o=t.popAlpha,u=tn(n);return s=>a=>c=>{const f={...s,nodeFill:s.text,text:s.nodeFill,nodeStroke:s.nodeFill};return u(d=>{const l=ae(d._1)(c.nodes),_=ae(d._1)(a.nodes),h=(()=>{if(_.tag==="Just"&&l.tag==="Just"){const p=l._1,m=_._1;return r.bind(t.pushAlpha(d._2))(()=>r.bind(i(Ja)(1)(f)(1)(1)(J)(d._1)(m)(p))(()=>o))}return n.pure()})();return d._2>0?h:n.pure()})(Qe(c.nodeInvert))}},Aw=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=tn(n);return o=>u=>s=>{const a={family:o.fontFamily,size:11,weight:500};return i(c=>{if(c._2===""||(()=>{const l=Cn(c._1)(s.edges);return l.tag==="Nothing"||!(l.tag==="Just"&&l._1.tag==="Extended")})())return n.pure();const f=Cn(c._1)(u.edges),d=(()=>{if(f.tag==="Just")return wi(f._1)(.5);if(f.tag==="Nothing")return J;g()})();if(d.tag==="Nothing")return n.pure();if(d.tag==="Just"){const l=d._1;return r.bind(t.measureText(a)(c._2))(_=>{const h=_+12;return r.bind(t.drawRoundedRect({x:l.x-h/2,y:l.y-8.5,w:h,h:17})(3)(T("Just",{color:o.chipPillFill,flat:!0}))(J))(()=>t.drawText({x:l.x,y:l.y,content:c._2,font:a,color:o.chipPillText,align:ri,baseline:cr}))})}g()})(Qe(u.edgeLabels))}},Iw=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=t.popAlpha;return o=>u=>s=>a=>c=>f=>d=>l=>_=>{const h=(()=>{if(_>1e-4&&d>1-_){const m=(1-d)/_;return m<0?0:m>1?1:m}if(l>1e-4&&d<l){const m=d/l;return m<0?0:m>1?1:m}return 1})(),p=o1(a)(c)(f)(d)(l)(_);if(p.tag==="CircleShape")return o?u1(t)(p._1)(p._2)({r:200,g:35,b:30,a:220}):t.fillStrokePath(du(p._1)(p._2))({color:u,flat:!0})({color:s,width:1,lineJoin:Le,lineCap:mn});if(p.tag==="PolyShape"&&o&&p._1.length>=3)return r.bind(t.pushAlpha(h))(()=>r.bind(u1(t)(q_(p._1))(6)({r:200,g:35,b:30,a:220}))(()=>i));if(p.tag==="PolyShape")return o?n.pure():p._1.length>=3?t.fillStrokePath(ha(p._1))({color:u,flat:!0})({color:s,width:1,lineJoin:Le,lineCap:mn}):n.pure();g()}},Qw=t=>{const e=t.Monad0().Bind1(),n=t.popAlpha;return r=>i=>o=>u=>s=>a=>c=>{const f=oi(a)(c)(s),d={x:o.x+o.w/2,y:o.y+o.h/2},l={x:u.x+u.w/2,y:u.y+u.h/2},_=(h,p)=>e.bind(t.pushAlpha(p))(()=>e.bind(t.fillStrokePath(du(h)(6))({color:r,flat:!0})({color:i,width:1,lineJoin:Le,lineCap:mn}))(()=>n));return f<.5?_(d,(()=>{const h=f*2;return 1-(h<0?0:h>1?1:h)*(h<0?0:h>1?1:h)*(h<0?3:h>1?1:3-2*h)})()):_(l,(()=>{const h=(f-.5)*2;return(h<0?0:h>1?1:h)*(h<0?0:h>1?1:h)*(h<0?3:h>1?1:3-2*h)})())}},Ju=t=>{const e=Iw(t),n=Qw(t),r=t.Monad0().Applicative0(),i=tn(r);return o=>u=>s=>a=>c=>i(f=>{if(f._2.tag==="Travelling"){const d=ae(f._2._1.target)(u.nodes),l=ae(f._2._1.source)(u.nodes);if(l.tag==="Just"&&d.tag==="Just"){const _=Cn(f._2._1.edge)(u.edges);if(_.tag==="Just")return e(o)(a)(c)((()=>{if(f._2._1.direction==="Forward")return _._1;if(f._2._1.direction==="Backward")return ve(_._1);g()})())(l._1)(d._1)(f._2._1.progress)(f._2._1.holdPre)(f._2._1.holdPost);if(_.tag==="Nothing")return n(a)(c)(l._1)(d._1)(f._2._1.progress)(f._2._1.holdPre)(f._2._1.holdPost);g()}return r.pure()}if(f._2.tag==="Filling"){if(o)return r.pure();const d=ae(f._2._1.node)(u.nodes);if(d.tag==="Just")return t.fillStrokePath(ha(Gr(4)(ui(2)(d._1))))({color:a,flat:!0})({color:c,width:1,lineJoin:Le,lineCap:mn});if(d.tag==="Nothing")return r.pure();g()}return r.pure()})(Qe(s.tokens))},c1=t=>{const e=Ju(t),n=t.Monad0(),r=n.Bind1(),i=Ju(t),o=Gw(t),u=t.popClip,s=t.popBlend,a=t.popLayer,c=n.Applicative0(),f=tn(c),d=t.popAlpha;return l=>_=>h=>p=>{const m=_.wobble?e(!0)(h)(p)(_.tokenInside)(_.tokenInsideStroke):r.bind(t.insideTokenStyle(l))(y=>{if(y==="GenieSilhouette")return i(!1)(h)(p)(_.tokenInside)(_.tokenInsideStroke);if(y==="ConvexAbsorb")return o(h)(p)(_.tokenInside)(_.tokenInsideStroke);g()});if(_.tokenInsideBlend==="Difference")return r.bind(t.pushLayer($N))(()=>r.bind(t.pushBlend(gu))(()=>r.bind(t.pushClip(va(h)(p))(cu))(()=>r.bind(m)(()=>r.bind(u)(()=>r.bind(s)(()=>r.bind(a)(()=>r.bind(t.pushLayer(XN))(()=>r.bind(f(y=>{const x=ae(y._1)(p.nodes);return x.tag==="Just"&&_u(x._1).alpha>0?_a(t)(y._2.shape)({x:y._2.x,y:y._2.y,w:y._2.w,h:y._2.h})(7)(T("Just",{color:oe,flat:!1}))(J):c.pure()})(Qe(h.nodes)))(()=>a)))))))));if(_.tokenInsideBlend==="Normal")return r.bind(t.pushClip(va(h)(p))(cu))(()=>r.bind(t.pushAlpha(_.tokenInsideAlpha))(()=>r.bind(m)(()=>r.bind(d)(()=>u))));g()}},g1=t=>{const e=t.Monad0().Bind1(),n=Ju(t),r=Ju(t),i=t.popClip,o=t.popLayer;return u=>s=>a=>c=>e.bind(t.pushLayer(ON))(()=>e.bind(t.pushClip(Lw(s)(a)(c))(VN))(()=>e.bind(u.wobble?n(!0)(a)(c)(u.tokenOutsideFill)(u.tokenOutsideStroke):r(!1)(a)(c)(u.tokenOutsideFill)(u.tokenOutsideStroke))(()=>e.bind(i)(()=>o))))},Dw=t=>{const e=t.Monad0(),n=e.Bind1(),r=e.Applicative0(),i=tn(r);return o=>u=>s=>a=>c=>f=>{const d=So(f).length,l=et(d+1|0),_=m=>{const y=(s*l-et(m))/1.5,x=y<0?0:y>1?1:y;return x*x*(3-2*x)},h=(m=>{let y=m,x=!0,N;for(;x;){const v=y;if(v>=d){x=!1,N=v;continue}if(_(v)>=1){y=v+1|0;continue}x=!1,N=v}return N})(0),p=h>=d?[]:mr(m=>_(m)>0)(zt(h,d-1|0)).init;return n.bind((()=>{const m=t.drawText({x:a,y:c,content:Je(h)(f),font:o,color:u,align:aa,baseline:cr});return h>0?m:r.pure()})())(()=>i(m=>n.bind(t.measureText(o)(Je(m)(f)))(y=>{const x=_(m);return t.drawText({x:a+y,y:c-(1-x)*10,content:Je(1)(Ni(tr(Je(m)(f)))(f)),font:o,color:{...u,a:xe(xn(x*et(u.a)))},align:aa,baseline:cr})}))(p))}},wu=t=>e=>n=>r=>{const i=H(_=>et(Nu(1)(So(_).length)))(r),o=xu(1)(w(Mr)(0)(i)),u=oi(e)(n)(t),s=u*o,a=Nu(1)(r.length),c=(_=>h=>p=>{let m=_,y=h,x=p,N=!0,v;for(;N;){const b=m,k=y,E=Mt(A=>J,A=>$=>T("Just",{head:A,tail:$}),x);if(E.tag==="Nothing"){N=!1,v=Nu(0)(a-1|0);continue}if(E.tag==="Just"){if(k+E._1.head>=s){N=!1,v=b;continue}m=b+1|0,y=k+E._1.head,x=E._1.tail;continue}g()}return v})(0)(0)(i),f=w(Mr)(0)(c<1?[]:kt(0,c,i)),d=f/o;if(c>=0&&c<i.length){const _=(f+i[c])/o;return{line:c>=0&&c<r.length?r[c]:"",phaseInLabel:(()=>{if(_<=d)return 1;const h=(u-d)/(_-d);return h<0?0:h>1?1:h})()}}const l=(f+1)/o;return{line:c>=0&&c<r.length?r[c]:"",phaseInLabel:(()=>{if(l<=d)return 1;const _=(u-d)/(l-d);return _<0?0:_>1?1:_})()}},f1=t=>{const e=t.Monad0();return n=>r=>i=>e.Bind1().bind(t.measureText({family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:11,weight:500})(wu(r)(0)(0)(H(Gd)(i)).line))(o=>{const u=o+28;return e.Applicative0().pure({x:n.x+n.w/2-u/2,y:n.y-25.2-14,w:u,h:25.2})})},Fw=t=>{const e=t.Monad0(),n=e.Bind1(),r=f1(t),i=e.Applicative0(),o=lr.traverse(i);return u=>s=>n.Apply0().Functor0().map(a=>n1(xt(c=>c)(a)))(o(a=>{if(a._2.tag==="Filling"&&a._2._1.labels.length!==0){const c=ae(a._2._1.node)(u.nodes);if(c.tag==="Just")return n.bind(r(c._1)(a._2._1.progress)(a._2._1.labels))(f=>i.pure(T("Just",L(a._1,f))));if(c.tag==="Nothing")return i.pure(J);g()}return i.pure(J)})(Qe(s.tokens)))},zw=t=>{const e=t.Monad0();return n=>r=>i=>o=>u=>s=>a=>{const c=wa(n)(r)(i)(o)(u)(s);return e.Bind1().bind(t.measureText({family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:11,weight:500})(wu(o)(u)(s)(Tt(a)(ba)).line))(f=>e.Applicative0().pure({x:c.x+14+f/2-f/2-14,y:c.y-6-8-6.6-6,w:f+28,h:25.2}))}},Bw=t=>{const e=t.Monad0(),n=e.Bind1(),r=zw(t),i=e.Applicative0(),o=lr.traverse(i);return u=>s=>n.Apply0().Functor0().map(a=>n1(xt(c=>c)(a)))(o(a=>{if(a._2.tag==="Travelling"&&a._2._1.labels.length!==0){const c=ae(a._2._1.target)(u.nodes),f=ae(a._2._1.source)(u.nodes),d=Cn(a._2._1.edge)(u.edges);if(d.tag==="Just"&&f.tag==="Just"&&c.tag==="Just"){const l=(()=>{if(a._2._1.direction==="Forward")return d._1;if(a._2._1.direction==="Backward")return ve(d._1);g()})(),_=wa(l)(f._1)(c._1)(a._2._1.progress)(a._2._1.holdPre)(a._2._1.holdPost);return n.bind(r(l)(f._1)(c._1)(a._2._1.progress)(a._2._1.holdPre)(a._2._1.holdPost)(a._2._1.labels))(h=>i.pure(T("Just",L(a._1,{id:a._1,rect:h,token:_}))))}}return i.pure(J)})(Qe(s.tokens)))},La=t=>{const e=t.Monad0(),n=e.Bind1(),r=Bw(t),i=Fw(t);return o=>u=>s=>n.bind(r(u)(s))(a=>n.bind(i(u)(s))(c=>e.Applicative0().pure(sw({x:o.vx,y:o.vy,w:o.vw,h:o.vh})([...xt(f=>{const d=ae(f._1)(s.nodes);return d.tag==="Just"&&_u(d._1).alpha>0?T("Just",{x:f._2.x,y:f._2.y,w:f._2.w,h:f._2.h}):J})(Qe(u.nodes)),...(()=>{const f=(d,l)=>{if(d.tag==="Leaf")return l;if(d.tag==="Node")return f(d._5,Xt("Cons",d._4,f(d._6,l)));g()};return At(Kt.foldr,f(c,Ut))})()])(xt(f=>r1(f)(a))((()=>{const f=d=>{if(d.tag==="Leaf")return D;if(d.tag==="Node")return Ot("Node",d._1,d._2,d._3,void 0,f(d._5),f(d._6));g()};return Et(G.compare)(At($e.foldr,f(a)))})())))))},_1=t=>e=>n=>{const r=bi(6)(.55)(yu(0)(1)((1-t)/.06)),i=t>.94,o=i&&n>1e-4,u=bi(6)(.55)(yu(0)(1)(t/.06)),s=t<.06,a=s&&e>1e-4,c=i&&n<=1e-4;return{popScale:a?u:o?r:1,flipY:s&&e<=1e-4?u:c?r:1,fadeAlpha:(()=>{if(a){const f=t/.06;return f<0?.55:f>1?1:.55+.44999999999999996*f}if(o){const f=(1-t)/.06;return f<0?.55:f>1?1:.55+.44999999999999996*f}return 1})()}},Mw=t=>{const e=i1(t),n=t.Monad0().Bind1();return r=>i=>o=>u=>s=>{const a=wu(o)(0)(0)(Tt(u)(ba)),c={x:s.x+s.w/2,y:s.y+s.h/2},f=[1,c.x,s.y+s.h,2,i.x+i.w/2,i.y];return e(_1(o)(0)(0))(s.x)(s.y+s.h)(c)(n.bind(t.drawRoundedRect({x:s.x,y:s.y+1.5,w:s.w,h:s.h})(6)(T("Just",{color:r.chipShadow,flat:!0}))(J))(()=>n.bind(t.drawRoundedRect({x:s.x,y:s.y,w:s.w,h:s.h})(6)(T("Just",{color:r.chip,flat:!0}))(T("Just",{color:r.chipHairline,width:1,lineJoin:Le,lineCap:mn})))(()=>n.bind(t.strokePath(f)({color:r.chipHairline,width:1,lineJoin:Le,lineCap:mn}))(()=>t.drawText({x:c.x,y:c.y,content:a.line,font:{family:r.fontFamily,size:11,weight:500},color:r.chipText,align:ri,baseline:cr})))))}},Ww=t=>{const e=f1(t),n=Mw(t);return r=>i=>o=>u=>s=>t.Monad0().Bind1().bind(e(o)(u)(s))(a=>n(r)(o)(u)(s)(a))},Rw=t=>{const e=i1(t),n=t.Monad0(),r=n.Bind1(),i=tn(n.Applicative0()),o=Dw(t);return u=>s=>a=>c=>f=>d=>l=>_=>h=>{const p=wu(f)(d)(l)(Tt(_)(ba)),m=p.line,y=p.phaseInLabel/.45,x=y<0?0:y>1?1:y,N=h.w,v=h.y,b=h.x,k=b+14,E=h.h,A=v+E/2;return e(_1(f)(d)(l))(b)(v+E)({x:b+N/2,y:A})(r.bind(i($=>t.fillPath(du($)(1.5))({color:u.trailDot,flat:!0}))(Ew(h)(wa(s)(a)(c)(f)(d)(l))))(()=>r.bind(t.drawRoundedRect({x:b,y:v,w:N,h:E})(3)(T("Just",{color:u.chipPillFill,flat:!0}))(J))(()=>o({family:u.fontFamily,size:11,weight:500})(u.chipPillText)(x)(k)(A)(m))))}},ka=t=>{const e=Rw(t),n=t.Monad0(),r=n.Applicative0(),i=Ww(t),o=n.Bind1(),u=tn(r),s=t.popLayer;return a=>c=>f=>d=>o.bind(t.pushLayer(YN))(()=>o.bind(u(l=>{if(l._2.tag==="Travelling"){if(l._2._1.labels.length!==0){const _=ae(l._2._1.target)(c.nodes),h=ae(l._2._1.source)(c.nodes),p=Cn(l._2._1.edge)(c.edges),m=r1(l._1)(d);if(m.tag==="Just"&&p.tag==="Just"&&h.tag==="Just"&&_.tag==="Just")return e(a)((()=>{if(l._2._1.direction==="Forward")return p._1;if(l._2._1.direction==="Backward")return ve(p._1);g()})())(h._1)(_._1)(l._2._1.progress)(l._2._1.holdPre)(l._2._1.holdPost)(l._2._1.labels)(m._1)}return r.pure()}if(l._2.tag==="Filling"&&l._2._1.labels.length!==0){const _=ae(l._2._1.node)(c.nodes);if(_.tag==="Just")return i(a)(c)(_._1)(l._2._1.progress)(l._2._1.labels);if(_.tag==="Nothing")return r.pure();g()}return r.pure()})(Qe(f.tokens)))(()=>s))},d1=t=>{const e=La(t),n=ka(t);return r=>i=>o=>u=>t.Monad0().Bind1().bind(e(i)(o)(u))(s=>n(r)(o)(u)(s))},qw=t=>{const e=t.Monad0(),n=e.Applicative0();return r=>i=>{const o=i.length-1|0,u=o<1?[]:kt(0,o,i),s=u.length-1|0,a=s>=0&&s<u.length?T("Just",u[s]):J,c=i.length-1|0,f=c>=0&&c<i.length?T("Just",i[c]):J;if(f.tag==="Just"&&a.tag==="Just"){const d=he(.78)(1.18)(Oi(i)+19|0),l=he(.4)(.62)(d.prng),_=r.wobble?8.75*l.value:4.375,h=he(.4)(.62)(l.prng),p=r.wobble?8.75*h.value:4.375,m=f._1.y-a._1.y,y=f._1.x-a._1.x,x=Ce(y*y+m*m),N=m/x,v=-N,b=y/x,k=f._1.x+b*.875,E=f._1.y+N*.875,A=r.wobble?8.75*d.value:8.75,$=k-b*A,tt=E-N*A,S=$+v*_,C=tt+b*_,V=[1,k,E,2,$+v*4.375,tt+b*4.375,2,$-v*4.375,tt-b*4.375,5],U=$-v*p,M=tt-b*p,W={color:r.arrowFill,width:2,lineJoin:Le,lineCap:kn};return x<=1e-4?n.pure():r.wobble?e.Bind1().bind(t.strokePath([1,S,C,2,k,E])(W))(()=>t.strokePath([1,U,M,2,k,E])(W)):t.fillPath(V)({color:r.arrowFill,flat:!0})}return n.pure()}},Hw=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=tn(n),o=t.popAlpha,u=qw(t);return s=>a=>c=>f=>{const d=qJ(8)(c);if(f.hi<=f.lo)return n.pure();const l=KJ(d)(f.lo)(f.hi);if(l.length===0)return n.pure();const _={color:s.edge,width:s.wobble?2:.9375,lineJoin:Le,lineCap:kn},h=s.wobble?he(-10)(4)(Oi(l)).value:0,p=s.wobble?lw(h)(l):l;return r.bind(s.wobble?i(m=>r.bind(t.pushAlpha(m.alpha))(()=>r.bind(t.strokePath(m.path)(_))(()=>o)))((()=>{const m=Oi(l);return p.length<2?[]:si(Cw)(m)(!1)(p)})()):t.strokePath(BJ(l))(_))(()=>{const m=u(s)(p);return f.hi>=.999?m:n.pure()})}},l1=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=Hw(t),o=t.popAlpha,u=tn(n);return s=>a=>c=>{const f=d=>{const l=Vt(_=>d.x>=_._2.x-1&&d.x<=_._2.x+_._2.w+1&&d.y>=_._2.y-1&&d.y<=_._2.y+_._2.h+1)(Qe(a.nodes));return l.tag==="Just"?T("Just",l._1._2):J};return u(d=>{const l=Cn(d._1)(c.edges);if(l.tag==="Just"){const _=l._1,h=Cn(d._1)(c.edgeFadeAlpha),p=(()=>{if(h.tag==="Nothing")return 1;if(h.tag==="Just")return h._1;g()})(),m=r.bind(t.pushAlpha(p))(()=>r.bind(i(s)(d._1)((()=>{const y=(()=>{if(0<d._2.length){const N=f(d._2[0]);if(N.tag==="Just")return ve(O_(Gr(7)(N._1))(ve(d._2)))}return d._2})(),x=y.length-1|0;if(x>=0&&x<y.length){const N=f(y[x]);if(N.tag==="Just")return O_(Gr(7)(N._1))(y)}return y})())((()=>{if(_.tag==="Retracted")return{lo:0,hi:0};if(_.tag==="Extended")return{lo:0,hi:1};if(_.tag==="Extending")return{lo:0,hi:_._2};if(_.tag==="Retracting"){if(_._1==="FromSource")return{lo:_._2,hi:1};if(_._1==="FromTarget")return{lo:0,hi:1-_._2};if(_._1==="FromBoth")return{lo:_._2/2,hi:1-_._2/2}}g()})()))(()=>o));return p>0?m:n.pure()}if(l.tag==="Nothing")return n.pure();g()})(Qe(a.edges))}},Ow=t=>e=>{const n=o=>{const u=ae(o)(t.nodes);if(u.tag==="Nothing")return!1;if(u.tag==="Just"){const s=u._1;return!qe(a=>0<a._2.length&&a._2[0].x>=s.x&&a._2[0].x<=s.x+s.w&&a._2[0].y>=s.y&&a._2[0].y<=s.y+s.h,Qe(t.edges))}g()},r=w(o=>u=>(o*31|0)+ir(u)|0)(5381)(Jr(e.frameTitle)),i=o=>{const u=ae(o)(t.nodes);if(u.tag==="Nothing")return!1;if(u.tag==="Just"){const s=u._1;return!qe(a=>{const c=a._2.length-1|0;return c>=0&&c<a._2.length&&a._2[c].x>=s.x&&a._2[c].x<=s.x+s.w&&a._2[c].y>=s.y&&a._2[c].y<=s.y+s.h},Qe(t.edges))}g()};return w(o=>u=>{const s=u._2;return Tw(a=>{if(a.tag==="Nothing")return T("Just",s);if(a.tag==="Just")return T("Just",{t:xu(a._1.t)(s.t),angle:s.t>=a._1.t?s.angle:a._1.angle,bigCircle:a._1.bigCircle||s.bigCircle,frameHash:a._1.frameHash});g()})(u._1)(o)})(D)(Tt(Qe(e.tokens))(o=>{if(o._2.tag==="Filling"){const u=o._2._1.node;return[L(u,{t:1,angle:(()=>{const s=xt(a=>(()=>{const c=ae(u)(t.nodes),f=a._2.length-1|0;return f>=0&&f<a._2.length&&c.tag==="Just"&&a._2[f].x>=c._1.x&&a._2[f].x<=c._1.x+c._1.w&&a._2[f].y>=c._1.y&&a._2[f].y<=c._1.y+c._1.h})()?T("Just",a._2):J)(Qe(t.edges));if(0<s.length){const a=s[0].length-1|0,c=a<1?[]:kt(0,a,s[0]),f=c.length-1|0;if(f>=0&&f<c.length){const d=s[0].length-1|0;return d>=0&&d<s[0].length?yr(s[0][d].y-c[f].y)(s[0][d].x-c[f].x):0}s[0].length-1|0}return 0})(),bigCircle:n(u)||i(u),frameHash:r})]}if(o._2.tag==="Travelling"){if(o._2._1.progress>=.75)return[L(o._2._1.target,{t:(o._2._1.progress-.75)/.25,angle:(()=>{const u=Cn(o._2._1.edge)(t.edges);if(u.tag==="Just"){const s=u._1.length-1|0,a=s<1?[]:kt(0,s,u._1),c=a.length-1|0;if(c>=0&&c<a.length){const f=u._1.length-1|0;return f>=0&&f<u._1.length?yr(u._1[f].y-a[c].y)(u._1[f].x-a[c].x):0}return u._1.length-1|0,0}if(u.tag==="Nothing")return 0;g()})(),bigCircle:n(o._2._1.target)||i(o._2._1.target),frameHash:r})];if(o._2._1.progress<.25)return[L(o._2._1.source,{t:o._2._1.progress/.25,angle:(()=>{const u=Cn(o._2._1.edge)(t.edges);if(u.tag==="Just")return 1<u._1.length&&0<u._1.length?yr(u._1[1].y-u._1[0].y)(u._1[1].x-u._1[0].x):0;if(u.tag==="Nothing")return 0;g()})(),bigCircle:n(o._2._1.source)||i(o._2._1.source),frameHash:r})]}return[]}))},$w=t=>w(e=>n=>(e*31|0)+ir(n)|0)(5381)(Jr(t.frameTitle)),h1=t=>{const e=s1(t),n=t.Monad0().Applicative0(),r=tn(n);return i=>o=>u=>s=>a=>{const c=$w(a),f=Ow(s)(a);return r(d=>{const l=ae(d._1)(a.nodes);if(l.tag==="Just")return e(i)(o)(u)((()=>{const _=ae(d._1)(a.nodeFadeAlpha);if(_.tag==="Nothing")return 1;if(_.tag==="Just")return _._1;g()})())((()=>{const _=ae(d._1)(a.nodeLabelFadeAlpha);if(_.tag==="Nothing")return 1;if(_.tag==="Just")return _._1;g()})())((()=>{const _=ae(d._1)(f);return _.tag==="Just"?T("Just",_._1):_.tag==="Nothing"&&vw(d._1)(a.visited)?T("Just",{t:1,angle:0,bigCircle:!1,frameHash:c}):J})())(d._1)(d._2)(l._1);if(l.tag==="Nothing")return n.pure();g()})(Qe(s.nodes))}},Xw=t=>e=>n=>{const r=nt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=nt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},p1=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},m1=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},Ea=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},Yw=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Vw=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},Uw=t=>e=>{const n=Ve(t.angle),r=rn(t.angle);return{a:r,b:n,c:0,d:1,e:-e*r,f:e*n-t.boxHeight/2}},Kw=t=>[t.box.ground.a,t.box.ground.b,t.box.ground.c,t.box.ground.d,t.box.top.a,t.box.top.b,t.box.top.c,t.box.top.d],ai=t=>e=>{const n=r=>Xw(0)(255)(xe(xr(et(r)*t)));return{r:n(e.r),g:n(e.g),b:n(e.b),a:e.a}},Pe=t=>e=>n=>r=>({x:(e-n)*rn(t.angle),y:(e+n)*Ve(t.angle)-r}),Ar=t=>{const e=Mt(n=>J,n=>r=>T("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return[];if(e.tag==="Just")return[1,e._1.head.x,e._1.head.y,...Tt(e._1.tail)(n=>[2,n.x,n.y]),5];g()},jw=t=>e=>n=>r=>i=>{const o=(()=>{if(t==="Forward")return i;if(t==="Backward")return ve(i);g()})();if(0<o.length){const s=wi(o)(p1(0)(1)(oi(n)(r)(e)));if(s.tag==="Nothing")return o[0];if(s.tag==="Just")return s._1;g()}const u=wi(o)(p1(0)(1)(oi(n)(r)(e)));if(u.tag==="Nothing")return{x:0,y:0};if(u.tag==="Just")return u._1;g()},Zw=t=>{const e=Mt(n=>J,n=>r=>T("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return[];if(e.tag==="Just")return[1,e._1.head.x,e._1.head.y,...Tt(e._1.tail)(n=>[2,n.x,n.y])];g()},tT=t=>{const e=Mt(n=>J,n=>r=>T("Just",{head:n,tail:r}),t);if(e.tag==="Nothing")return{vx:0,vy:0,vw:0,vh:0};if(e.tag==="Just"){const n=w(r=>i=>({minX:m1(r.minX)(i.x),minY:m1(r.minY)(i.y),maxX:Ea(r.maxX)(i.x),maxY:Ea(r.maxY)(i.y)}))({minX:e._1.head.x,minY:e._1.head.y,maxX:e._1.head.x,maxY:e._1.head.y})(e._1.tail);return{vx:n.minX-40,vy:n.minY-40,vw:n.maxX-n.minX+80,vh:n.maxY-n.minY+80}}g()},eT=t=>{const e=t.Monad0().Bind1();return n=>r=>i=>{const o=i.box,u=i.np,s={color:r.nodeStroke,width:1,lineJoin:Le,lineCap:mn};return e.bind(t.fillStrokePath(Ar([o.ground.d,o.ground.c,o.top.c,o.top.d]))({color:ai(.66)(r.nodeFill),flat:!0})(s))(()=>e.bind(t.fillStrokePath(Ar([o.ground.b,o.ground.c,o.top.c,o.top.b]))({color:ai(.82)(r.nodeFill),flat:!0})(s))(()=>e.bind(t.fillStrokePath(Ar([o.top.a,o.top.b,o.top.c,o.top.d]))({color:ai(1)(r.nodeFill),flat:!0})(s))(()=>t.drawTextAffine(Uw(n)(u.y+u.h))({x:u.x+u.w/2,y:0,content:u.label,font:{family:r.fontFamily,size:11,weight:600},color:r.text,align:ri,baseline:cr}))))}},nT=t=>{const e=t.Monad0().Bind1();return n=>r=>i=>o=>{const u={color:r.tokenOutsideStroke,width:1,lineJoin:Le,lineCap:mn},s=o.x-5.5,a=o.x+5.5,c=o.y-5.5,f=o.y+5.5,d=i+11,l=Pe(n)(s)(c)(d),_=Pe(n)(a)(c)(d),h=Pe(n)(a)(f)(d),p=Pe(n)(s)(f)(d),m=Pe(n)(a)(f)(i),y=Pe(n)(a)(c)(i);return e.bind(t.fillStrokePath(Ar([Pe(n)(s)(f)(i),m,h,p]))({color:ai(.66)(r.tokenOutsideFill),flat:!0})(u))(()=>e.bind(t.fillStrokePath(Ar([y,m,h,_]))({color:ai(.82)(r.tokenOutsideFill),flat:!0})(u))(()=>t.fillStrokePath(Ar([l,_,h,p]))({color:ai(1)(r.tokenOutsideFill),flat:!0})(u)))}},rT=t=>{const e=nT(t);return n=>r=>i=>o=>{if(o.tag==="Travelling"){const u=Yw(o._1.edge)(i.edges);return u.tag==="Just"?T("Just",(()=>{const s=jw(o._1.direction)(o._1.progress)(o._1.holdPre)(o._1.holdPost)(u._1);return{depth:s.x+s.y,draw:e(n)(r)(0)(s)}})()):J}if(o.tag==="Filling"){const u=Vw(o._1.node)(i.nodes);if(u.tag==="Just")return T("Just",(()=>{const s={x:u._1.x+u._1.w/2,y:u._1.y+u._1.h/2};return{depth:s.x+s.y,draw:e(n)(r)(n.boxHeight)(s)}})())}return J}},iT={angle:.5235987755982988,boxHeight:26,transparentBg:!0},oT=t=>e=>{const n=e.y+e.h,r=e.x+e.w;return{ground:{a:Pe(t)(e.x)(e.y)(0),b:Pe(t)(r)(e.y)(0),c:Pe(t)(r)(n)(0),d:Pe(t)(e.x)(n)(0)},top:{a:Pe(t)(e.x)(e.y)(t.boxHeight),b:Pe(t)(r)(e.y)(t.boxHeight),c:Pe(t)(r)(n)(t.boxHeight),d:Pe(t)(e.x)(n)(t.boxHeight)},depth:(e.x+r)/2+(e.y+n)/2}},y1=t=>e=>H(n=>({np:n,box:oT(t)(n)}))((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._4,n(r._6,i)));g()};return At(Kt.foldr,n(e.nodes,Ut))})()),uT=t=>e=>[...Tt(y1(t)(e))(Kw),...(()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._4,n(r._6,i)));g()};return Tt(At(Kt.foldr,n(e.edges,Ut)))(H(r=>Pe(t)(r.x)(r.y)(0)))})()],sT=t=>{const e=t.to.y-t.from.y,n=t.to.x-t.from.x,r=Ea(1e-4)(Ce(n*n+e*e)),i=e/r,o=n/r,u=t.to.y-i*7,s=t.to.x-o*7;return Ar([t.to,{x:s-i*3,y:u+o*3},{x:s+i*3,y:u-o*3}])},aT=t=>{const e=t.Monad0(),n=e.Applicative0();return r=>i=>o=>u=>s=>{const a=Pe(r)(s.x)(s.y)(0),c=Pe(r)(u.x)(u.y)(0);return e.Bind1().bind(t.strokePath(Zw([c,a]))({color:i.edge,width:1.5,lineJoin:Le,lineCap:kn}))(()=>{const f=t.fillPath(sT({from:c,to:a}))({color:i.arrowFill,flat:!0});return o?f:n.pure()})}},cT=t=>{const e=aT(t);return n=>r=>i=>{const o=be(ln,i,kt(1,i.length,i)),u=o.length-1|0;return Ft(s=>a=>({depth:(a._1.x+a._1.y+a._2.x+a._2.y)/2,draw:e(n)(r)(s===u)(a._1)(a._2)}))(o)}},gT=t=>{const e=eT(t),n=rT(t),r=cT(t),i=t.Monad0(),o=Fu(i.Applicative0())(Bt);return u=>s=>a=>c=>{const f=Ta(s),d=[...(()=>{const l=(_,h)=>{if(_.tag==="Leaf")return h;if(_.tag==="Node")return l(_._5,Xt("Cons",_._4,l(_._6,h)));g()};return Tt(At(Kt.foldr,l(a.edges,Ut)))(r(u)(f))})(),...H(l=>({depth:l.box.depth,draw:e(u)(f)(l)}))(y1(u)(a)),...xt(n(u)(f)(a))((()=>{const l=(_,h)=>{if(_.tag==="Leaf")return h;if(_.tag==="Node")return l(_._5,Xt("Cons",_._4,l(_._6,h)));g()};return At(Kt.foldr,l(c.tokens,Ut))})())];return i.Bind1().bind((()=>{const l=tT(uT(u)(a));return t.Monad0().Bind1().bind(t.clearBackground(u.transparentBg?f.bgTransparent:f.bg))(()=>t.setViewport(l))})())(()=>o(l=>l.draw)(Et(l=>_=>rt.compare(l.depth)(_.depth))(d)))}},x1=(t,e)=>({tag:t,_1:e}),Tu=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},fT=t=>e=>n=>{const r=rt.compare(t)(n),i=(()=>{if(r==="LT")return n;if(r==="EQ"||r==="GT")return t;g()})(),o=rt.compare(e)(i);if(o==="LT"||o==="EQ")return e;if(o==="GT")return i;g()},Sa=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},_T=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},dT=x1("ResolvedLabels"),lT=t=>{const e=Vt(n=>n.role==="FlyThrough")(t.levels);if(e.tag==="Just")return e._1;if(e.tag==="Nothing")return zo(t);g()},$i=t=>e=>{const n=Tu(1)(Ne(e.rootLayout).w),r=Jo(e.rootLayout)(e.camera),i=!e.diving&&e.levels.length===1?1:fT(0)(1)(r.w/n),o=zo(e).state.frameTitle===""?0*i:40*i,u=t.padding*i*i;return(()=>{if(t.outputAspect.tag==="Nothing")return J0;if(t.outputAspect.tag==="Just")return eg(t.outputAspect._1);g()})()({vx:r.x-u,vy:r.y-u-o,vw:r.w+2*u,vh:r.h+2*u+o})},hT=t=>e=>{if(e.tag==="Nothing")return[];if(e.tag==="Just"){const n=Sa(e._1)(t.segment.layout.nodes);if(n.tag==="Nothing")return[];if(n.tag==="Just"){const r=n._1.x*t.segment.placement.scale+t.segment.placement.tx,i=n._1.y*t.segment.placement.scale+t.segment.placement.ty,o=n._1.w*t.segment.placement.scale,u=n._1.h*t.segment.placement.scale;return[1,r,i,2,r+o,i,2,r+o,i+u,2,r,i+u,5]}}g()},Ca=t=>e=>{const n=sh(e.segment.placement)({x:t.vx,y:t.vy,w:t.vw,h:t.vh});return{vx:n.x,vy:n.y,vw:n.w,vh:n.h}},pT=t=>{const e=t.Monad0(),n=e.Bind1();return r=>i=>{if(r==="")return e.Applicative0().pure();const o=i.vh/720,u=56*o;return n.bind(t.measureText({family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:56,weight:700})(r))(s=>{const a=u+16*o*2,c=s*o+28*o*2,f=i.vy+i.vh/2,d=i.vx+i.vw/2;return n.bind(t.drawRoundedRect({x:d-c/2,y:f-a/2,w:c,h:a})(16*o)(T("Just",{color:{r:255,g:255,b:255,a:235},flat:!0}))(T("Just",{color:{r:0,g:0,b:0,a:255},width:1.5*o,lineJoin:Le,lineCap:kn})))(()=>t.drawText({x:d,y:f,content:r,font:{family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:u,weight:700},color:{r:28,g:30,b:36,a:255},align:ri,baseline:cr}))})}},mT=t=>{const e=t.Monad0(),n=e.Bind1();return r=>i=>{if(r==="")return e.Applicative0().pure();const o=i.vh/720,u=15*o;return n.bind(t.measureText({family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:15,weight:600})(r))(s=>{const a=i.vy+12*o,c=u+6*o*2,f=s*o+11*o*2,d=i.vx+i.vw/2;return n.bind(t.drawRoundedRect({x:d-f/2,y:a,w:f,h:c})(c/2)(T("Just",{color:{r:255,g:255,b:255,a:240},flat:!0}))(T("Just",{color:{r:0,g:0,b:0,a:255},width:1*o,lineJoin:Le,lineCap:kn})))(()=>t.drawText({x:d,y:a+c/2,content:r,font:{family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:u,weight:600},color:{r:28,g:30,b:36,a:255},align:ri,baseline:cr}))})}},yT=t=>{const e=d1(t),n=ka(t),r=t.Monad0(),i=r.Bind1(),o=r.Applicative0(),u=l1(t),s=h1(t)(Ja)(1),a=a1(t),c=g1(t),f=c1(t),d=Aw(t),l=t.popBlur,_=t.popAlpha,h=pT(t),p=mT(t);return m=>y=>x=>N=>v=>b=>k=>E=>{const A=Ta(m.theme),$=(()=>{if(E.tag==="ResolvedLabels")return e(A)(v)(b)(k);if(E.tag==="SpringLabels")return n(A)(b)(k)(E._1);g()})();return i.bind(t.Monad0().Bind1().bind(t.clearBackground(m.transparentBg?A.bgTransparent:A.bg))(()=>t.setViewport(v)))(()=>i.bind((()=>{const tt=i.bind((()=>{const S=t.pushAlpha(x);return x<1?S:o.pure()})())(()=>i.bind((()=>{const S=t.pushBlur(N);return N>0?S:o.pure()})())(()=>i.bind(u(A)(b)(k))(()=>i.bind(s(A)(b)(k))(()=>i.bind(a(A)(b)(k))(()=>i.bind(c(A)(v)(b)(k))(()=>i.bind(f(ZN)(A)(b)(k))(()=>i.bind($)(()=>i.bind((()=>{const S=d(A)(b)(k);return k.staticKind!=="Animated"?S:o.pure()})())(()=>i.bind(N>0?l:o.pure())(()=>x<1?_:o.pure()))))))))));return x>0?tt:o.pure()})())(()=>i.bind(m.watermark===""?t.Monad0().Applicative0().pure():t.drawText({x:v.vx+6,y:v.vy+6,content:m.watermark,font:{family:"Ilisarniq, ui-sans-serif, system-ui, sans-serif",size:9,weight:600},color:{r:180,g:180,b:180,a:255},align:aa,baseline:HN}))(()=>k.staticKind==="TitleCard"?h(k.frameTitle)(v):p(k.frameTitle)(v))))}},N1=t=>{const e=t.Monad0().Applicative0(),n=oc(e)(Bt);return r=>i=>o=>u=>n(u.minis)(s=>{const a=J1(t)(r)(i)(o)(D)(u)(s);return(()=>{const c=s.segment.path.length-1|0;return s.bgAlpha>0&&c>=0&&c<s.segment.path.length&&(()=>{const f=Sa(s.segment.path[c])(u.state.nodes);if(f.tag==="Just")return f._1.tag==="Hidden"?!1:f._1.tag!=="PloppingOut";if(f.tag==="Nothing")return!1;g()})()})()?a:e.pure()})},J1=t=>{const e=t.Monad0(),n=e.Applicative0(),r=e.Bind1(),i=t.popTransform,o=d1(t),u=ka(t),s=l1(t),a=h1(t),c=a1(t),f=g1(t),d=c1(t),l=t.popBakedTransform,_=t.popClip,h=t.popBlur,p=t.popAlpha;return m=>y=>x=>N=>v=>b=>{const k=b.blur>0,E=b.segment.placement,A=b.state,$={tx:E.tx,ty:E.ty,sx:E.scale,sy:E.scale},tt=Ta(m.theme),S=b.segment.layout,C=Ne(S),V={vx:C.x-1e3,vy:C.y-1e3,vw:C.w+2e3,vh:C.h+2e3},U=b.segment.path.length-1|0,M=U>=0&&U<b.segment.path.length?Sa(b.segment.path[U])(v.segment.layout.nodes):J,W=b.segment.placement.scale*x,B=_T(8)(Tu(1)(1/(1.25*Tu(1e-6)(W)))),P=11*W>=5?Ja:bw,I=(()=>{if(M.tag==="Nothing")return n.pure();if(M.tag==="Just"){const R=M._1;return r.bind(t.pushTransform({tx:v.segment.placement.tx,ty:v.segment.placement.ty,sx:v.segment.placement.scale,sy:v.segment.placement.scale}))(()=>r.bind(_a(t)(R.shape)({x:R.x+1,y:R.y+1,w:R.w-2,h:R.h-2})(7)(T("Just",{color:tt.bg,flat:!0}))(J))(()=>i))}g()})(),F=(()=>{if(P==="LabelsHidden")return n.pure();if(P==="LabelsShown")return N.tag==="Leaf"?o(tt)(Ca(y.viewport)(b))(S)(A):u(tt)(S)(A)(N);g()})(),Q=hT(v)((()=>{const R=b.segment.path.length-1|0;return R>=0&&R<b.segment.path.length?T("Just",b.segment.path[R]):J})());return r.bind(t.pushAlpha(b.bgAlpha))(()=>r.bind((()=>{const R=t.pushBlur(b.blur*E.scale);return k?R:n.pure()})())(()=>r.bind(t.pushClip(Q)(cu))(()=>r.bind(v.role==="Active"||v.role==="FlyThrough"?I:n.pure())(()=>r.bind(t.pushTransform($))(()=>r.bind(s(tt)(S)(A))(()=>r.bind(a(P)(B)(tt)(S)(A))(()=>r.bind(c(tt)(S)(A))(()=>r.bind(f(tt)(V)(S)(A))(()=>r.bind(i)(()=>r.bind(t.pushBakedTransform($))(()=>r.bind(d(tJ)(tt)(S)(A))(()=>r.bind(l)(()=>r.bind(_)(()=>r.bind(t.pushTransform($))(()=>r.bind(F)(()=>r.bind(i)(()=>r.bind(N1(t)(m)(y)(x)(b))(()=>r.bind(k?h:n.pure())(()=>p)))))))))))))))))))}},w1=t=>{const e=gT(t),n=t.Monad0(),r=n.Applicative0(),i=n.Bind1(),o=J1(t),u=yT(t),s=N1(t);return a=>c=>f=>{if(a.theme==="Isometric")return e({...iT,transparentBg:a.transparentBg})(a.theme)(zo(f).segment.layout)(zo(f).state);const d=$i(a)(f),l=m=>f.hasDives?d.vw/Tu(1)(Ne(f.rootLayout).w):1,_={tileScale:l(),viewport:d},h=m=>y=>{if(y.length===0)return r.pure();const x=Mt(N=>J,N=>v=>T("Just",{head:N,tail:v}),y);if(x.tag==="Nothing")return r.pure();if(x.tag==="Just"){const N=x._1.head,v=x._1.tail;return i.bind((()=>{const b=o(a)(_)(f.camera.zoom)(N.role==="Active"?c:D)(m)(N);return f.diving||N.role==="Active"?b:r.pure()})())(()=>h(N)(v))}g()},p=Mt(m=>J,m=>y=>T("Just",{head:m,tail:y}),f.levels);if(p.tag==="Nothing")return r.pure();if(p.tag==="Just"){const m=p._1.tail,y=p._1.head;return i.bind((()=>{const x=m.length===0;return u(a)(l())(y.role==="Active"||y.role==="FlyThrough"?y.bgAlpha:0)(y.blur)(d)(y.segment.layout)(lT(f).state)(x&&c.tag!=="Leaf"?x1("SpringLabels",c):dT)})())(()=>i.bind((()=>{const x=s(a)(_)(f.camera.zoom)(y);return y.role==="Active"||y.role==="FlyThrough"?x:r.pure()})())(()=>h(y)(m)))}g()}},xT=La(I_),T1=w1(I_),NT=t=>e=>n=>r=>i=>o=>u=>{const s={padding:24,transparentBg:(()=>{if(e==="TransparentBackground")return!0;if(e==="PaintBackground")return!1;g()})(),halftoneShadows:!0,watermark:"",theme:t,outputAspect:r.width<=0||r.height<=0?J:T("Just",r.width/r.height)},a=hJ(n)(r);return()=>{const c=a(),f=i.levels.length-1|0;if(f>=0&&f<i.levels.length){const l=xT(Ca($i(s)(i))(i.levels[f]))(i.levels[f].segment.layout)(i.levels[f].state)(c)(),_=ua(o)(l)(u);return T1(s)(_.applied)(i)(c)(),_.springs}const d=ua(o)(D)(u);return T1(s)(d.applied)(i)(c)(),d.springs}},JT=t=>t,Xi=t=>t,Ga=Xi("Light"),wT=Xi("Dark"),TT=Xi("Blueprint"),vT=Xi("Whiteboard"),bT=Xi("Isometric"),LT=JT("TransparentBackground"),fr=t=>"rgb("+ue(t.r)+","+ue(t.g)+","+ue(t.b)+")",Gn=pi(li("Fixed",hi(0)(20)(4))),kT=t=>"translate("+Gn(t.tx)+","+Gn(t.ty)+") scale("+Gn(t.sx)+","+Gn(t.sy)+")",vt=pi(li("Fixed",hi(0)(20)(2))),Pa=t=>{const e=[];let n=0;for(;n<t.length;){const r=n,i=r>=0&&r<t.length?T("Just",t[r]):J;if(i.tag==="Nothing"){n=t.length;continue}if(i.tag==="Just"){if(i._1===1){e.push("M"),e.push(vt((()=>{const o=r+1|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+2|0;return o>=0&&o<t.length?t[o]:0})())),n=r+3|0;continue}if(i._1===2){e.push("L"),e.push(vt((()=>{const o=r+1|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+2|0;return o>=0&&o<t.length?t[o]:0})())),n=r+3|0;continue}if(i._1===3){e.push("Q"),e.push(vt((()=>{const o=r+1|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+2|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+3|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+4|0;return o>=0&&o<t.length?t[o]:0})())),n=r+5|0;continue}if(i._1===4){e.push("C"),e.push(vt((()=>{const o=r+1|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+2|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+3|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+4|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+5|0;return o>=0&&o<t.length?t[o]:0})())),e.push(vt((()=>{const o=r+6|0;return o>=0&&o<t.length?t[o]:0})())),n=r+7|0;continue}if(i._1===5){e.push("Z"),n=r+1|0;continue}n=t.length;continue}g()}return ko(" ")(e)},ET={map:t=>e=>n=>{const r=e(n);return()=>{const i=r();return t(i)}}},Aa=(()=>{const t=or("&")("&amp;"),e=or("<")("&lt;"),n=(()=>{const r=or(">")("&gt;"),i=(()=>{const o=or('"')("&quot;");return u=>o(r(u))})();return o=>i(e(o))})();return r=>n(t(r))})(),ST=t=>{if(t.style==="RunText")return"<tspan>"+Aa(t.text)+"</tspan>";if(t.style==="RunCode")return`<tspan font-family="'CommitMono', ui-monospace, SFMono-Regular, Menlo, monospace" font-weight="400">`+Aa(t.text)+"</tspan>";g()},ke=t=>e=>{const n=e.maskDepth;return()=>{n.value===0&&e.out.push(t)}},CT=t=>e=>{const n=[];let r=0;const i=o=>{const u=o>=0&&o<e.length?t.sx*e[o]+t.tx:t.sx*0+t.tx;return()=>{n.push(u),n.push((()=>{const s=o+1|0;return s>=0&&s<e.length?t.sy*e[s]+t.ty:t.sy*0+t.ty})())}};for(;r<e.length;){const o=r,u=o>=0&&o<e.length?T("Just",e[o]):J;if(u.tag==="Nothing"){r=e.length;continue}if(u.tag==="Just"){if(u._1===1){n.push(u._1),i(o+1|0)(),r=o+3|0;continue}if(u._1===2){n.push(u._1),i(o+1|0)(),r=o+3|0;continue}if(u._1===3){n.push(u._1),i(o+1|0)(),i(o+3|0)(),r=o+5|0;continue}if(u._1===4){n.push(u._1),i(o+1|0)(),i(o+3|0)(),i(o+5|0)(),r=o+7|0;continue}if(u._1===5){n.push(u._1),r=o+1|0;continue}r=e.length;continue}g()}return n},vu=t=>e=>{const n=t.bake;return()=>{const r=n.value;if(r.tag==="Nothing")return e;if(r.tag==="Just")return CT(r._1)(e);g()}},v1={apply:t=>e=>n=>{const r=t(n),i=e(n);return()=>{const o=r(),u=i();return o(u)}},Functor0:()=>ET},GT={bind:t=>e=>n=>{const r=t(n);return()=>{const i=r();return e(i)(n)()}},Apply0:()=>v1},PT={pure:t=>e=>()=>t,Apply0:()=>v1},AT={Applicative0:()=>PT,Bind1:()=>GT},IT=t=>e=>'<defs><pattern id="'+t+'" x="'+vt(e.origin.x)+'" y="'+vt(e.origin.y)+'" width="'+vt(e.tile)+'" height="'+vt(e.tile)+'" patternUnits="userSpaceOnUse">'+(e.bgColor.a===0?"":'<rect width="'+vt(e.tile)+'" height="'+vt(e.tile)+'" fill="'+fr(e.bgColor)+'" fill-opacity="'+vt(et(e.bgColor.a)/255)+'"/>')+'<circle cx="'+vt(e.tile/2)+'" cy="'+vt(e.tile/2)+'" r="'+vt(e.dotRadius)+'" fill="'+fr(e.dotColor)+'"/></pattern></defs><rect x="'+vt(e.viewport.vx)+'" y="'+vt(e.viewport.vy)+'" width="'+vt(e.viewport.vw)+'" height="'+vt(e.viewport.vh)+'" fill="url(#'+t+')"/>',b1=t=>e=>'<path d="'+Pa(t)+'" fill="'+fr(e)+'" fill-opacity="'+vt(et(e.a)/255)+'"/>',QT=t=>e=>n=>r=>'<rect x="'+vt(t.x)+'" y="'+vt(t.y)+'" width="'+vt(t.w)+'" height="'+vt(t.h)+'" rx="'+vt(e)+'"'+(()=>{if(n.tag==="Just")return' fill="'+fr(n._1.color)+'" fill-opacity="'+vt(et(n._1.color.a)/255)+'"';if(n.tag==="Nothing")return' fill="none"';g()})()+(()=>{if(r.tag==="Just")return' stroke="'+fr(r._1.color)+'" stroke-opacity="'+vt(et(r._1.color.a)/255)+'" stroke-width="'+vt(r._1.width)+'" stroke-linejoin="'+(()=>{if(r._1.lineJoin==="RoundJoin")return"round";if(r._1.lineJoin==="BevelJoin")return"bevel";if(r._1.lineJoin==="MiterJoin")return"miter";g()})()+'" stroke-linecap="'+(()=>{if(r._1.lineCap==="ButtCap")return"butt";if(r._1.lineCap==="RoundCap")return"round";if(r._1.lineCap==="SquareCap")return"square";g()})()+'"';if(r.tag==="Nothing")return"";g()})()+"/>",L1=t=>e=>'<path d="'+Pa(t)+'" fill="none" stroke="'+fr(e.color)+'" stroke-opacity="'+vt(et(e.color.a)/255)+'" stroke-width="'+vt(e.width)+'" stroke-linejoin="'+(()=>{if(e.lineJoin==="RoundJoin")return"round";if(e.lineJoin==="BevelJoin")return"bevel";if(e.lineJoin==="MiterJoin")return"miter";g()})()+'" stroke-linecap="'+(()=>{if(e.lineCap==="ButtCap")return"butt";if(e.lineCap==="RoundCap")return"round";if(e.lineCap==="SquareCap")return"square";g()})()+'"/>',k1=t=>{const e=Ig(Yr(t.content));return'<text x="'+vt(t.x)+'" y="'+vt(t.y)+'"'+(()=>{if(t.baseline==="BaselineTop")return' dy="0.8em"';if(t.baseline==="BaselineMiddle")return' dy="0.32em"';if(t.baseline==="BaselineAlphabetic"||t.baseline==="BaselineBottom")return"";g()})()+' fill="'+fr(t.color)+'" fill-opacity="'+vt(et(t.color.a)/255)+'" font-size="'+vt(t.font.size)+'" font-family="Ilisarniq, ui-sans-serif, system-ui, sans-serif" font-weight="'+ue(t.font.weight)+'" text-anchor="'+(()=>{if(t.align==="AlignLeft")return"start";if(t.align==="AlignCenter")return"middle";if(t.align==="AlignRight")return"end";g()})()+'">'+(e.length===1&&e[0].style==="RunText"?Aa(e[0].text):ko("")(H(ST)(e)))+"</text>"},DT=t=>"matrix("+Gn(t.a)+" "+Gn(t.b)+" "+Gn(t.c)+" "+Gn(t.d)+" "+Gn(t.e)+" "+Gn(t.f)+")",E1={fillPath:t=>e=>n=>{const r=vu(n)(t);return()=>{const i=r();return ke(b1(i)(e.color))(n)()}},strokePath:t=>e=>n=>{const r=vu(n)(t);return()=>{const i=r(),o=n.bake.value;return ke(L1(i)((()=>{if(o.tag==="Nothing")return e;if(o.tag==="Just")return{...e,width:o._1.sx*e.width};g()})()))(n)()}},fillStrokePath:t=>e=>n=>r=>{const i=vu(r)(t);return()=>{const o=i(),u=r.bake.value;return ke(b1(o)(e.color)+L1(o)((()=>{if(u.tag==="Nothing")return n;if(u.tag==="Just")return{...n,width:u._1.sx*n.width};g()})()))(r)()}},drawRoundedRect:t=>e=>n=>r=>i=>{const o=i.bake;return()=>{const u=o.value;return ke(QT((()=>{if(u.tag==="Nothing")return t;if(u.tag==="Just")return{x:u._1.sx*t.x+u._1.tx,y:u._1.sy*t.y+u._1.ty,w:u._1.sx*t.w,h:u._1.sy*t.h};g()})())((()=>{if(u.tag==="Nothing")return e;if(u.tag==="Just")return u._1.sx*e;g()})())(n)(r.tag==="Just"?T("Just",(()=>{if(u.tag==="Nothing")return r._1;if(u.tag==="Just")return{...r._1,width:u._1.sx*r._1.width};g()})()):J))(i)()}},drawText:t=>e=>{const n=e.bake;return()=>{const r=n.value;return ke(k1((()=>{if(r.tag==="Nothing")return t;if(r.tag==="Just")return{...t,x:r._1.sx*t.x+r._1.tx,y:r._1.sy*t.y+r._1.ty,font:{...t.font,size:r._1.sx*t.font.size}};g()})()))(e)()}},drawTextAffine:t=>e=>ke((()=>{const n='transform="'+DT(t)+'"';return(n===""?"<g>":"<g "+n+">")+k1(e)+"</g>"})()),pushTransform:t=>ke((()=>{const e='transform="'+kT(t)+'"';return e===""?"<g>":"<g "+e+">"})()),popTransform:ke("</g>"),pushBakedTransform:t=>e=>{const n=e.bake;return()=>{n.value=T("Just",t)}},popBakedTransform:t=>{const e=t.bake;return()=>{e.value=J}},pushClip:t=>e=>n=>{const r=n.clipCounter;return()=>{const i=r.value;n.clipCounter.value=i+1|0;const o=vu(n)(t)(),u="clip"+ue(i);return ke((()=>{const s='clip-path="url(#'+u+')"';return'<defs><clipPath id="'+u+'"><path d="'+Pa(o)+'"'+(()=>{if(e==="EvenOdd")return' clip-rule="evenodd"';if(e==="NonZero")return"";g()})()+"/></clipPath></defs>"+(s===""?"<g>":"<g "+s+">")})())(n)()}},popClip:ke("</g>"),pushBlend:t=>ke((()=>{const e=(()=>{if(t==="Normal")return'style="mix-blend-mode: normal"';if(t==="Difference")return'style="mix-blend-mode: difference"';g()})();return e===""?"<g>":"<g "+e+">"})()),popBlend:ke("</g>"),pushAlpha:t=>ke((()=>{const e='opacity="'+vt(t)+'"';return e===""?"<g>":"<g "+e+">"})()),popAlpha:ke("</g>"),pushBlur:t=>e=>{if(t<.01)return ke("<g>")(e);const n=e.patternCounter;return()=>{const r=n.value;e.patternCounter.value=r+1|0;const i="lvl-blur-"+ue(r);return ke((()=>{const o='filter="url(#'+i+')"';return'<defs><filter id="'+i+'" x="-20%" y="-20%" width="140%" height="140%"><feGaussianBlur stdDeviation="'+vt(t)+'"/></filter></defs>'+(o===""?"<g>":"<g "+o+">")})())(e)()}},popBlur:ke("</g>"),pushLayer:t=>e=>{const n=(()=>{if(t==="LayerNodeMask"){const r=e.maskDepth;return()=>{const i=r.value;e.maskDepth.value=i+1|0}}return()=>{}})();return()=>{n(),e.out.push("<g>")}},popLayer:t=>{const e=t.maskDepth;return()=>{const n=e.value,r=n-1|0;n>0&&(t.maskDepth.value=r),t.out.push("</g>")}},setViewport:t=>e=>()=>{},clearBackground:t=>e=>ke('<rect x="'+vt(e.viewport.vx)+'" y="'+vt(e.viewport.vy)+'" width="'+vt(e.viewport.vw)+'" height="'+vt(e.viewport.vh)+'" fill="'+fr(t)+'" opacity="'+vt(et(t.a)/255)+'"/>')(e),backgroundDots:t=>e=>{const n=e.patternCounter;return()=>{const r=n.value;return e.patternCounter.value=r+1|0,ke(IT("bg-dots-"+ue(r))(t))(e)()}},measureText:t=>e=>n=>{const r=f_(t)(e);return()=>r},measureInk:t=>e=>n=>{const r=__(t)(e);return()=>r},insideTokenStyle:t=>e=>()=>J_,Monad0:()=>AT},FT=w1(E1),zT=La(E1),BT=t=>e=>n=>r=>i=>{const o={padding:24,transparentBg:(()=>{if(r==="TransparentBackground")return!0;if(r==="PaintBackground")return!1;g()})(),halftoneShadows:!0,watermark:"",theme:n,outputAspect:t},u=$i(o)(i);return{viewBox:vt(u.vx)+" "+vt(u.vy)+" "+vt(u.vw)+" "+vt(u.vh),body:(()=>{const s=[],a={value:0},c={value:0},f={value:0},d={value:J};return FT(o)(e)(i)({out:s,maskDepth:a,clipCounter:c,patternCounter:f,viewport:u,bake:d})(),ko("")(s)})(),vx:u.vx,vy:u.vy,vw:u.vw,vh:u.vh}},MT=t=>e=>n=>r=>i=>o=>{const u={padding:24,transparentBg:(()=>{if(n==="TransparentBackground")return!0;if(n==="PaintBackground")return!1;g()})(),outputAspect:t},s=ua(i)((()=>{const a=[],c={value:0},f={value:0},d={value:0},l={value:J},_=r.levels.length-1|0;if(_>=0&&_<r.levels.length){const h=Ca($i(u)(r))(r.levels[_]);return zT(h)(r.levels[_].segment.layout)(r.levels[_].state)({out:a,maskDepth:c,clipCounter:f,patternCounter:d,viewport:h,bake:l})()}return D})())(o);return{parts:BT(t)(s.applied)(e)(n)(r),springs:s.springs}},Yi=t=>({bind:e=>n=>r=>t.Bind1().bind(e(r))(i=>n(i._1)(i._2)),Apply0:()=>S1(t)}),S1=t=>{const e=t.Bind1().Apply0().Functor0(),n={map:r=>i=>o=>e.map(u=>L(r(u._1),u._2))(i(o))};return{apply:(()=>{const r=Yi(t);return i=>o=>r.bind(i)(u=>r.bind(o)(s=>Vi(t).pure(u(s))))})(),Functor0:()=>n}},Vi=t=>({pure:e=>n=>t.Applicative0().pure(L(e,n)),Apply0:()=>S1(t)}),WT=t=>{const e={Applicative0:()=>Vi(t),Bind1:()=>Yi(t)};return{state:n=>r=>t.Applicative0().pure(n(r)),Monad0:()=>e}},Ia=(t,e)=>({tag:t,_1:e}),Qa=t=>t,On=(t,e)=>({tag:t,_1:e}),Da=t=>t,we=WT(Vn),Wt=Yi(Vn),De=we.state(t=>L(t,t)),ee=Vi(Vn),$n=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},C1=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},bu=Fu(ee)(Bt),Xn=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},RT=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},qT=(()=>{const t=Ue.unfoldr(e=>{if(e.tag==="Nil")return J;if(e.tag==="Cons")return T("Just",L(e._1,e._2));g()});return e=>t((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._3,n(r._6,i)));g()};return n(e,Ut)})())})(),HT=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=!1;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=!0;continue}}g()}return i},Lu=t=>e=>n=>w(r=>i=>t.Bind1().bind(r)(o=>e(o)(i)))(t.Applicative0().pure(n)),OT=w(t=>e=>Z(G)(e)()(t))(D),$T=(()=>{const t=(e=>n=>{let r=e,i=n,o=!0,u;for(;o;){const s=r,a=i;if(a.tag==="Nil"){o=!1,u=s;continue}if(a.tag==="Cons"){r=Z(G)(a._1)()(s),i=a._2;continue}g()}return u})(D);return e=>t((()=>{const n=(r,i)=>{if(r.tag==="Leaf")return i;if(r.tag==="Node")return n(r._5,Xt("Cons",r._3,n(r._6,i)));g()};return n(e,Ut)})())})(),XT=Da("RightArrow"),YT=Da("LeftArrow"),VT=Da("UndirectedArrow"),UT=On("Exit"),KT=Qa("AnimatedKeyframe"),jT=Qa("Still"),ZT=Qa("Title"),tv=t=>Ia("Par",t),G1=t=>Ia("Seq",t),ev=t=>e=>n=>{const r=hr(Zt,J,i=>i._1===t,n);if(r.tag==="Just"){const i=Un(Zt,J,r._1,L(t,e),n);if(i.tag==="Nothing")return n;if(i.tag==="Just")return i._1;g()}if(r.tag==="Nothing")return Dt(n)(L(t,e));g()},nv=t=>e=>H(n=>n._1===t?L(n._1,{...n._2,label:T("Just",e)}):L(n._1,n._2)),Te=t=>we.state(e=>L(void 0,(()=>{if(e.error.tag==="Just")return e;if(e.error.tag==="Nothing")return{...e,error:T("Just",{msg:t,line:e.currentLine,column:e.currentColumn})};g()})())),rv=t=>Wt.bind(we.state(e=>L(void 0,{...e,currentLine:t.line,currentColumn:t.column})))(()=>Wt.bind(De)(e=>{if(e.error.tag==="Just")return ee.pure();if(e.error.tag==="Nothing"){if(t.op.tag==="Enter"){if(!$n(t.op._1.id)(e.currNodes))return Te("cannot enter node "+t.op._1.id+": does not exist");if(!C1(t.op._1.id)(e.interiorOf))return Te("cannot enter node "+t.op._1.id+": it has no `inside` block");if(He(hn)(t.op._1.id)(e.enterStack))return Te("cannot enter node "+t.op._1.id+": already entered");const n=t.op._1;return we.state(r=>L(void 0,{...r,enterStack:Dt(r.enterStack)(n.id),scenes:Dt(r.scenes)(Ti("EnterNode",n.id))}))}if(t.op.tag==="Exit"){const n=pr(e.enterStack);if(n.tag==="Nothing")return Te("`exit` without a matching `enter`");if(n.tag==="Just"){const r=n._1.init;return we.state(i=>L(void 0,{...i,enterStack:r,scenes:Dt(i.scenes)(Nh)}))}g()}return ee.pure()}g()})),iv=t=>Wt.bind(De)(e=>{const n=t.tag==="Just"&&t._1!==""?t._1:"kf-"+ue(e.kfCounter);if(qe(i=>i.id===n,e.keyframes))return Te("duplicate frame name "+n);const r={...e,keyframes:Dt(e.keyframes)({id:n,nodes:e.currNodes,edges:e.currEdges,kind:vi}),kfCounter:e.kfCounter+1|0,currentKf:T("Just",n)};return we.state(i=>L(void 0,r))}),ov=bu(t=>Wt.bind(De)(e=>{if(e.error.tag==="Just")return ee.pure();if(e.error.tag==="Nothing")return C1(t.node)(e.interiorOf)?Te("node "+t.node+" has more than one `inside` block"):we.state(n=>L(void 0,{...n,interiorOf:Z(G)(t.node)(t.doc)(n.interiorOf)}));g()})),uv=t=>e=>{const n=e.from+"->"+e.to,r=e.newFrom+"->"+e.newTo,i=Gt("Left","cannot repoint "+e.from+"\u2192"+e.to+": edge does not exist"),o=Xn(n)(t.currEdges)?Gt("Right",void 0):i;return(()=>{if(o.tag==="Left"){const u=o._1;return s=>Gt("Left",u)}if(o.tag==="Right"){const u=o._1;return s=>s(u)}g()})()(()=>{const u="cannot repoint "+e.from+"\u2192"+e.to+" to "+e.newFrom+"\u2192"+e.newTo+": unknown node "+e.newFrom;if(!$n(e.newFrom)(t.currNodes))return Gt("Left",u);const s="cannot repoint "+e.from+"\u2192"+e.to+" to "+e.newFrom+"\u2192"+e.newTo+": unknown node "+e.newTo;if(!$n(e.newTo)(t.currNodes))return Gt("Left",s);const a="cannot repoint "+e.from+"\u2192"+e.to+" to "+e.newFrom+"\u2192"+e.newTo+": target edge already exists";return n!==r&&Xn(r)(t.currEdges)?Gt("Left",a):Gt("Right",{nextCurrEdges:Z(G)(r)()(di(G)(n)(t.currEdges)),newId:r,newEdge:{id:r,from:{node:e.newFrom,port:J},to:{node:e.newTo,port:J},label:J}})})},P1={graphNodes:[],graphEdges:D,currNodes:D,currEdges:D,keyframes:[],scenes:[],kfCounter:0,eventCounter:0,currentKf:J,currentLine:0,currentColumn:0,error:J,enterStack:[],interiorOf:D},sv=Wt.bind(De)(t=>{if(t.error.tag==="Just")return ee.pure();if(t.error.tag==="Nothing"){if(t.currentKf.tag==="Just"){const e=t.currentKf._1;return we.state(n=>L(void 0,{...n,scenes:Dt(n.scenes)(Ti("Hold",e))}))}if(t.currentKf.tag==="Nothing")return ee.pure()}g()}),A1=t=>e=>Wt.bind(De)(n=>{const r="ev-"+ue(n.eventCounter);return Wt.bind((()=>{const i={...n,eventCounter:n.eventCounter+1|0};return we.state(o=>L(void 0,i))})())(()=>ee.pure({events:[{id:r,kind:e,when:t}],firstId:T("Just",r),lastId:T("Just",r)}))}),av=t=>e=>{if(e.tag==="Token"){const n=e._1;return Wt.bind(De)(r=>{const i=!$n(n.from)(r.currNodes),o=!$n(n.to)(r.currNodes);if(i||o)return Wt.bind(Te(i?o?"token references unknown node: "+n.from+", "+n.to:"token references unknown node: "+n.from:o?"token references unknown node: "+n.to:"token references unknown node: "))(()=>ee.pure({events:[],firstId:J,lastId:J}));const u=n.to+"->"+n.from,s=n.from+"->"+n.to;return Xn(s)(r.currEdges)?A1(t)(zc("SendToken",{from:n.from,to:n.to,edge:s,direction:yh,labels:n.labels})):Xn(u)(r.currEdges)?A1(t)(zc("SendToken",{from:n.from,to:n.to,edge:u,direction:xh,labels:n.labels})):Wt.bind(Te("token "+n.from+"\u2192"+n.to+": no edge between "+n.from+" and "+n.to))(()=>ee.pure({events:[],firstId:J,lastId:J}))})}return ee.pure({events:[],firstId:J,lastId:J})},cv=t=>e=>{if(0<t.length){const n=t[0];return Wt.bind(we.state(r=>L(void 0,{...r,currentLine:n.line,currentColumn:n.column})))(()=>Te(e))}return Te(e)},gv=t=>xt(e=>RT(e)(t.graphEdges))(At(Qr,qT(t.currEdges))),fv=t=>e=>{const n=ut(i=>i.from.node===e.id||i.to.node===e.id,gv(t)),r=Lu(ec)(i=>o=>{const u=o.from+"->"+e.id,s=e.id+"->"+o.to,a=o.from+"->"+o.to,c="via "+o.from+" "+o.to+": no edge "+o.from+"\u2192"+e.id;if(!Xn(u)(t.currEdges))return Gt("Left",c);const f="via "+o.from+" "+o.to+": no edge "+e.id+"\u2192"+o.to;if(!Xn(s)(t.currEdges))return Gt("Left",f);const d="via "+o.from+" "+o.to+": would create "+o.from+"\u2192"+o.to+" but it already exists";return Xn(a)(t.currEdges)||HT(a)(i.synthesized)?Gt("Left",d):Gt("Right",{consumed:Z(G)(u)()(Z(G)(s)()(i.consumed)),synthesized:Z(G)(a)({id:a,from:{node:o.from,port:J},to:{node:o.to,port:J},label:J})(i.synthesized)})})({consumed:D,synthesized:D})(e.via);return(()=>{if(r.tag==="Left"){const i=r._1;return o=>Gt("Left",i)}if(r.tag==="Right"){const i=r._1;return o=>o(i)}g()})()(i=>{const o=i.consumed,u=ut(s=>!Xn(s.id)(o),n);return u.length===0?Gt("Right",{nextCurrEdges:Ge(G.compare,Se,In(G.compare,t.currEdges,OT(H(s=>s.id)(n))),$T((()=>{const s=a=>{if(a.tag==="Leaf")return D;if(a.tag==="Node")return Ot("Node",a._1,a._2,a._3,void 0,s(a._5),s(a._6));g()};return s(i.synthesized)})())),synthesized:i.synthesized}):Gt("Left","cannot delete node "+e.id+": still connected ("+ko(", ")(H(s=>s.from.node+"\u2192"+s.to.node)(u))+"). Use -edge to drop them or `via a b` to merge "+e.id+"'s endpoints.")})},Fa=t=>{if(t.tag==="Leaf")return[t._1];if(t.tag==="Par"||t.tag==="Seq")return Tt(t._1)(Fa);g()},_v=Wt.bind(De)(t=>{if(t.error.tag==="Just")return ee.pure();if(t.error.tag==="Nothing"){const e=t.enterStack.length-1|0;return e>=0&&e<t.enterStack.length?Te("entered node "+t.enterStack[e]+" was never exited"):ee.pure()}g()}),dv=t=>({nodes:H(to)(t.graphNodes),edges:(()=>{const e=(n,r)=>{if(n.tag==="Leaf")return r;if(n.tag==="Node")return e(n._5,Xt("Cons",n._4,e(n._6,r)));g()};return At(Kt.foldr,e(t.graphEdges,Ut))})(),constraints:[]}),lv=t=>{if(t.tag==="AddNode"){const e=t._1;return we.state(n=>L(void 0,{...n,graphNodes:ev(e.id)({id:e.id,size:L(1,1),ports:[],label:T("Just",e.label),shape:e.shape})(n.graphNodes),currNodes:Z(G)(e.id)()(n.currNodes)}))}if(t.tag==="DelNode"){const e=t._1;return Wt.bind(De)(n=>{if(!$n(e.id)(n.currNodes))return Te("cannot delete node "+e.id+": does not exist");const r=fv(n)(e);if(r.tag==="Left")return Te(r._1);if(r.tag==="Right"){const i=r._1;return we.state(o=>L(void 0,{...o,currNodes:di(G)(e.id)(o.currNodes),currEdges:i.nextCurrEdges,graphEdges:Ge(G.compare,Se,i.synthesized,o.graphEdges)}))}g()})}if(t.tag==="ModNode"){const e=t._1;return Wt.bind(De)(n=>{if(!$n(e.id)(n.currNodes))return Te("cannot modify node "+e.id+": does not exist");if(e.label.tag==="Just"){const r=e.label._1;return we.state(i=>L(void 0,{...i,graphNodes:nv(e.id)(r)(i.graphNodes)}))}if(e.label.tag==="Nothing")return ee.pure();g()})}if(t.tag==="AddEdge"){const e=t._1;return Wt.bind(De)(n=>{const r=!$n(e.from)(n.currNodes),i=!$n(e.to)(n.currNodes);if(r||i)return Te("cannot add edge "+e.from+"\u2192"+e.to+": unknown node "+(r?i?e.from+", "+e.to:e.from:i?e.to:""));const o=e.from+"->"+e.to;return we.state(u=>L(void 0,{...u,graphEdges:Z(G)(o)({id:o,from:{node:e.from,port:J},to:{node:e.to,port:J},label:e.label})(u.graphEdges),currEdges:Z(G)(o)()(u.currEdges)}))})}if(t.tag==="DelEdge"){const e=t._1;return Wt.bind(De)(n=>{const r=e.from+"->"+e.to;return Xn(r)(n.currEdges)?we.state(i=>L(void 0,{...i,currEdges:di(G)(r)(i.currEdges)})):Te("cannot delete edge "+e.from+"\u2192"+e.to+": does not exist")})}if(t.tag==="RepointEdge"){const e=t._1;return Wt.bind(De)(n=>{const r=uv(n)(e);if(r.tag==="Left")return Te(r._1);if(r.tag==="Right"){const i=r._1;return we.state(o=>L(void 0,{...o,currEdges:i.nextCurrEdges,graphEdges:Z(G)(i.newId)(i.newEdge)(o.graphEdges)}))}g()})}return ee.pure()},hv=t=>Wt.bind(we.state(e=>L(void 0,{...e,currentLine:t.line,currentColumn:t.column})))(()=>lv(t.op)),I1=t=>e=>n=>Wt.bind(bu(hv)(n))(()=>Wt.bind(De)(r=>{const i=e.tag==="Just"&&e._1!==""?e._1:"kf-"+ue(r.kfCounter);if(qe(u=>u.id===i,r.keyframes))return Te("duplicate frame name "+i);const o={...r,keyframes:Dt(r.keyframes)({id:i,nodes:r.currNodes,edges:r.currEdges,kind:t}),kfCounter:r.kfCounter+1|0,currentKf:T("Just",i),scenes:(()=>{if(r.currentKf.tag==="Nothing")return r.scenes;if(r.currentKf.tag==="Just")return Dt(r.scenes)(Ti("Structural",{from:r.currentKf._1,to:i,focus:J}));g()})()};return we.state(u=>L(void 0,o))})),Q1=t=>e=>{const n=Fa(e.ops),r=ut(o=>o.op.tag==="AddNode"||o.op.tag==="DelNode"||o.op.tag==="ModNode"||o.op.tag==="AddEdge"||o.op.tag==="DelEdge"||o.op.tag==="RepointEdge",n),i=ut(o=>!(o.op.tag==="AddNode"||o.op.tag==="DelNode"||o.op.tag==="ModNode"||o.op.tag==="AddEdge"||o.op.tag==="DelEdge"||o.op.tag==="RepointEdge"),n);if(0<i.length){const o=i[0];return Wt.bind(we.state(u=>L(void 0,{...u,currentLine:o.line,currentColumn:o.column})))(()=>Te("still/title blocks hold a static snapshot; they cannot contain tokens (a -> b, a <- b, or a -- b) or enter/exit"))}return t==="TitleCard"&&r.length===0?Te(e.name.tag==="Just"&&e.name._1!==""?'title "'+e.name._1+'" has an empty body; give it nodes/edges to title, or use a still':"title has an empty body; give it nodes/edges to title, or use a still"):Wt.bind(I1(t)(e.name)(r))(()=>sv)},pv=t=>e=>{const n=Mt(r=>J,r=>i=>T("Just",{head:r,tail:i}),e);if(n.tag==="Nothing")return ee.pure({events:[],firstId:J,lastId:J});if(n.tag==="Just"){const r=n._1.tail;return Wt.bind(Ui(t)(n._1.head))(i=>Wt.bind(Lu({Applicative0:()=>Vi(Vn),Bind1:()=>Yi(Vn)})(o=>u=>Wt.bind(Ui((()=>{if(o.lastId.tag==="Just")return cs("After",o.lastId._1);if(o.lastId.tag==="Nothing")return t;g()})())(u))(s=>ee.pure({events:[...o.events,...s.events],firstId:(()=>{if(o.firstId.tag==="Just")return T("Just",o.firstId._1);if(o.firstId.tag==="Nothing")return s.firstId;g()})(),lastId:(()=>{if(s.lastId.tag==="Just")return T("Just",s.lastId._1);if(s.lastId.tag==="Nothing")return o.lastId;g()})()})))(i)(r))(o=>ee.pure(o)))}g()},mv=t=>e=>{const n=Mt(r=>J,r=>i=>T("Just",{head:r,tail:i}),e);if(n.tag==="Nothing")return ee.pure({events:[],firstId:J,lastId:J});if(n.tag==="Just"){const r=n._1.tail;return Wt.bind(Ui(t)(n._1.head))(i=>Wt.bind(yv((()=>{if(i.firstId.tag==="Just")return cs("With",i.firstId._1);if(i.firstId.tag==="Nothing")return t;g()})())(r))(o=>ee.pure({events:[...i.events,...o.events],firstId:i.firstId,lastId:(()=>{if(i.lastId.tag==="Just")return T("Just",i.lastId._1);if(i.lastId.tag==="Nothing")return o.lastId;g()})()})))}g()},Ui=t=>e=>{if(e.tag==="Leaf"){const n=e._1;return Wt.bind(we.state(r=>L(void 0,{...r,currentLine:n.line,currentColumn:n.column})))(()=>av(t)(n.op))}if(e.tag==="Seq")return pv(t)(e._1);if(e.tag==="Par")return mv(t)(e._1);g()},yv=t=>Lu({Applicative0:()=>Vi(Vn),Bind1:()=>Yi(Vn)})(e=>n=>Wt.bind(Ui(t)(n))(r=>ee.pure({events:[...e.events,...r.events],firstId:(()=>{if(e.firstId.tag==="Just")return T("Just",e.firstId._1);if(e.firstId.tag==="Nothing")return r.firstId;g()})(),lastId:(()=>{if(r.lastId.tag==="Just")return T("Just",r.lastId._1);if(r.lastId.tag==="Nothing")return e.lastId;g()})()})))({events:[],firstId:J,lastId:J}),xv=t=>Wt.bind(De)(e=>{if(e.currentKf.tag==="Nothing")return Te("flow ops before any structural frame");if(e.currentKf.tag==="Just"){const n=e.currentKf._1;return Wt.bind(Ui(mh)(t))(r=>Wt.bind(De)(i=>{const o={...i,scenes:Dt(i.scenes)(Ti("DataFlow",{keyframe:n,events:r.events,focus:J}))};return we.state(u=>L(void 0,o))}))}g()}),Nv=t=>{const e=Fa(t.ops),n=ut(o=>o.op.tag==="AddNode"||o.op.tag==="DelNode"||o.op.tag==="ModNode"||o.op.tag==="AddEdge"||o.op.tag==="DelEdge"||o.op.tag==="RepointEdge",e),r=ut(o=>o.op.tag==="Enter"||o.op.tag==="Exit",e),i=ut(o=>!(o.op.tag==="AddNode"||o.op.tag==="DelNode"||o.op.tag==="ModNode"||o.op.tag==="AddEdge"||o.op.tag==="DelEdge"||o.op.tag==="RepointEdge")&&!(o.op.tag==="Enter"||o.op.tag==="Exit"),e);return r.length!==0&&i.length!==0?cv(r)("`enter`/`exit` cannot be mixed with flow tokens in the same frame"):Wt.bind((()=>{const o=I1(vi)(t.name)(n);return n.length!==0?o:ee.pure()})())(()=>Wt.bind((()=>{const o=iv(t.name);return n.length===0&&i.length!==0?o:ee.pure()})())(()=>Wt.bind((()=>{const o=xv(t.ops);return i.length!==0?o:ee.pure()})())(()=>bu(rv)(r))))},Jv=t=>Wt.bind(De)(e=>{if(e.error.tag==="Just")return ee.pure();if(e.error.tag==="Nothing"){if(t.kind==="AnimatedKeyframe")return Nv(t);if(t.kind==="Still")return Q1(hh)(t);if(t.kind==="Title")return Q1(ph)(t)}g()}),D1=t=>Wt.bind(ov(t.interiors))(()=>Wt.bind(bu(Jv)(t.frames))(()=>Wt.bind(_v)(()=>Wt.bind(De)(e=>{if(e.error.tag==="Just")return ee.pure(Gt("Left",e.error._1));if(e.error.tag==="Nothing"){const n=wv(t.interiors);if(n.tag==="Left")return ee.pure(Gt("Left",n._1));if(n.tag==="Right")return ee.pure(Gt("Right",{seed:t.seed,graph:dv(e),keyframes:e.keyframes,scenes:e.scenes,interiors:n._1}))}g()})))),wv=t=>{const e=Lu(ec)(n=>r=>{const i=D1(r.doc)(P1)._1;return(()=>{if(i.tag==="Left"){const o=i._1;return u=>Gt("Left",o)}if(i.tag==="Right"){const o=i._1;return u=>u(o)}g()})()(o=>Gt("Right",Z(G)(r.node)(o)(n)))})(D)(t);if(e.tag==="Left")return Gt("Left",e._1);if(e.tag==="Right")return Gt("Right",e._1);g()},ci=(t,e)=>({tag:"ParseError",_1:t,_2:e}),z=(t,e,n)=>({tag:"ParseState",_1:t,_2:e,_3:n}),ku=(t,e,n)=>({tag:t,_1:e,_2:n}),Tv=t=>ku("More",t),vv=t=>ku("Lift",t),bv={defer:t=>{const e=Rl(t);return(n,r,i,o,u)=>ql(e)(n,r,i,o,u)}},F1={map:t=>e=>(n,r,i,o,u)=>r(s=>e(n,r,i,o,(a,c)=>r(f=>u(a,t(c)))))},Lv={alt:t=>e=>(n,r,i,o,u)=>{const s=n._1,a=n._2;return r(c=>t(z(s,a,!1),r,i,(f,d)=>{const l=f._3;return r(_=>l?o(f,d):e(n,r,i,o,u))},u))},Functor0:()=>F1},kv=t=>{const e=t.Monad0();return n=>r=>{const i=o=>{let u=o,s=!0,a;for(;s;){const c=u();if(c.tag==="More"){u=c._1;continue}if(c.tag==="Lift"){s=!1,a=e.Bind1().Apply0().Functor0().map(rc)(c._1);continue}if(c.tag==="Stop"){s=!1,a=e.Applicative0().pure(gi("Done",L(c._2,c._1)));continue}g()}return a};return t.tailRecM(i)(o=>r(n,Tv,vv,(u,s)=>ku("Stop",u,Gt("Left",s)),(u,s)=>ku("Stop",u,Gt("Right",s))))}},z1=(t,e,n,r,i)=>i(t,t._2),Ev={index:0,line:1,column:1},Sv=(t=>{const e=kv(t);return n=>r=>t.Monad0().Bind1().Apply0().Functor0().map(eo)(e(z(n,Ev,!1))(r))})(md),B1={apply:t=>e=>(n,r,i,o,u)=>r(s=>t(n,r,i,o,(a,c)=>r(f=>{const d=n._3&&!a._3?z(a._1,a._2,!0):a;return e(d,r,i,o,(l,_)=>r(h=>u(d._3&&!l._3?z(l._1,l._2,!0):l,c(_))))}))),Functor0:()=>F1},M1={pure:t=>(e,n,r,i,o)=>o(e,t),Apply0:()=>B1},Cv={bind:t=>e=>(n,r,i,o,u)=>r(s=>t(n,r,i,o,(a,c)=>r(f=>e(c)(n._3&&!a._3?z(a._1,a._2,!0):a,r,i,o,u)))),Apply0:()=>B1},Gv={Applicative0:()=>M1,Bind1:()=>Cv},Eu=t=>(e,n,r,i,o)=>n(u=>z1(e,n,r,i,(s,a)=>n(c=>i(e._3&&!s._3?z(s._1,s._2,!0):s,ci(t,a))))),Pv={empty:Eu("No alternative"),Alt0:()=>Lv},Av={Applicative0:()=>M1,Plus1:()=>Pv},sn=(t=>e=>{const n=e.Plus1().Alt0(),r=e.Applicative0();return i=>t.tailRecM(o=>t.Monad0().Bind1().bind(n.alt(n.Functor0().map(rc)(i))(r.pure(gi("Done",void 0))))(u=>r.pure((()=>{if(u.tag==="Loop")return gi("Loop",Xt("Cons",u._1,o));if(u.tag==="Done")return gi("Done",(s=>a=>{let c=s,f=a,d=!0,l;for(;d;){const _=c,h=f;if(h.tag==="Nil"){d=!1,l=_;continue}if(h.tag==="Cons"){c=Xt("Cons",h._1,_),f=h._2;continue}g()}return l})(Ut)(o));g()})())))(Ut)})({tailRecM:t=>e=>(n,r,i,o,u)=>{const s=(a,c,f)=>t(c)(a,r,i,o,(d,l)=>{const _=a._3&&!d._3?z(d._1,d._2,!0):d;if(l.tag==="Loop")return f===0?r(h=>s(_,l._1,30)):s(_,l._1,f-1|0);if(l.tag==="Done")return u(_,l._1);g()});return s(n,e,30)},Monad0:()=>Gv})(Av),St=t=>e=>{const n=Eu("Expected "+e);return(r,i,o,u,s)=>{const a=r._1,c=r._2;return i(f=>t(z(a,c,!1),i,o,(d,l)=>{const _=d._3;return i(h=>_?u(d,l):n(r,i,o,u,s))},s))}},Su=t=>(e,n,r,i,o)=>{const u=e._3,s=e._1,a=e._2;return n(c=>{const f=(d,l)=>{const _=d._3;return n(h=>_?i(z(d._1,d._2,u),l):o(e,void 0))};return n(d=>n(l=>t(z(s,a,!1),n,r,(_,h)=>f(z(_._1,_._2,!1),h),(_,h)=>n(p=>n(m=>Eu("Negated parser succeeded")(_,n,r,f,(y,x)=>n(N=>o(_._3&&!y._3?z(y._1,y._2,!0):y,x))))))))})},Iv=t=>{const e=t.foldr(n=>r=>{if(r.tag==="Nothing")return T("Just",n);if(r.tag==="Just")return T("Just",(i,o,u,s,a)=>{const c=i._1,f=i._2;return o(d=>n(z(c,f,!1),o,u,(l,_)=>{const h=l._3;return o(p=>h?s(l,_):r._1(i,o,u,s,a))},a))});g()})(J);return n=>{const r=e(n);if(r.tag==="Nothing")return Eu("No alternative");if(r.tag==="Just")return r._1;g()}},Qv=t=>e=>n=>(r,i,o,u,s)=>i(a=>i(c=>i(f=>i(d=>t(r,i,o,u,(l,_)=>i(h=>i(p=>{const m=r._3&&!l._3?z(l._1,l._2,!0):l;return n(m,i,o,u,(y,x)=>i(N=>{const v=m._3&&!y._3?z(y._1,y._2,!0):y;return i(b=>i(k=>{const E=r._3&&!v._3?z(v._1,v._2,!0):v;return e(E,i,o,u,(A,$)=>i(tt=>s(E._3&&!A._3?z(A._1,A._2,!0):A,x)))}))}))}))))))),za=t=>e=>n=>{if(e===10)return{index:t.index+1|0,line:t.line+1|0,column:1};if(e===13){const r=N0()(n);return r.tag==="Just"&&r._1===10?{index:t.index+1|0,line:t.line,column:t.column}:{index:t.index+1|0,line:t.line+1|0,column:1}}return e===9?{index:t.index+1|0,line:t.line,column:(t.column+8|0)-Kn(t.column-1|0)(8)|0}:{index:t.index+1|0,line:t.line,column:t.column+1|0}},Dv=t=>e=>n=>{let r=t,i=e,o=n,u=!0,s;for(;u;){const a=r,c=i,f=o,d=Eo(c);if(d.tag==="Nothing"){u=!1,s=a;continue}if(d.tag==="Just"){r=d._1.tail===""?za(a)(d._1.head)(f):za(a)(d._1.head)(d._1.tail),i=d._1.tail,o=f;continue}g()}return s},Yt=t=>(e,n,r,i,o)=>{const u=Eo(e._1);if(u.tag==="Nothing")return i(e,ci("Unexpected EOF",e._2));if(u.tag==="Just"){if(u._1.head<0||u._1.head>65535)return i(e,ci("Expected Char",e._2));if(u._1.head>=0&&u._1.head<=65535){const s=jc(u._1.head);return t(s)?o(z(u._1.tail,za(e._2)(u._1.head)(u._1.tail),!0),s):i(e,ci("Predicate unsatisfied",e._2))}}g()},Ba=(t,e,n,r,i)=>t._1===""?i(z(t._1,t._2,!0),void 0):r(t,ci("Expected EOF",t._2)),Fv=t=>(e,n,r,i,o)=>{const u=t(e._1);if(u.tag==="Left")return i(e,ci(u._1,e._2));if(u.tag==="Right")return o(z(u._1.remainder,Dv(e._2)(u._1.consumed)(u._1.remainder),u._1.consumed!==""),u._1.value);g()},Ir=t=>Fv(e=>{const n=Wl(t)(e);return n.tag==="Just"?Gt("Right",{value:t,consumed:t,remainder:n._1}):Gt("Left","Expected "+od(t))}),zv=Yt(t=>!0),W1=(t,e)=>({tag:t,_1:e}),Ma=Iv(Bt),Bv=te(G)(Bt),Mv=t=>e=>{let n=e,r=!0,i;for(;r;){const o=n;if(o.tag==="Leaf"){r=!1,i=J;continue}if(o.tag==="Node"){const u=G.compare(t)(o._3);if(u==="LT"){n=o._5;continue}if(u==="GT"){n=o._6;continue}if(u==="EQ"){r=!1,i=T("Just",o._4);continue}}g()}return i},R1=(()=>{const t=Yt(e=>e===" "||e===" "||e===`
9
+ `||e==="\r");return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>o(e._3&&!s._3?z(s._1,s._2,!0):s,void 0))))})(),Wa=(t,e,n,r,i)=>e(o=>Ir("#")(t,e,n,r,(u,s)=>e(a=>{const c=sn(Yt(d=>d!==`
10
+ `)),f=t._3&&!u._3?z(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>i(f._3&&!l._3?z(l._1,l._2,!0):l,void 0))))}))),Wv=St((()=>{const t=St(Yt(n=>n==="}"))("'}'"),e=Yt(n=>n===`
11
+ `||n==="\r");return(n,r,i,o,u)=>{const s=n._1,a=n._2;return r(c=>r(f=>t(z(s,a,!1),r,i,(d,l)=>r(_=>{const h=n._1,p=n._2;return r(m=>r(y=>Wa(z(h,p,!1),r,i,(x,N)=>{const v=x._3;return r(b=>{if(v)return o(x,N);const k=n._1,E=n._2;return r(A=>r($=>e(z(k,E,!1),r,i,(tt,S)=>{const C=tt._3;return r(V=>C?o(tt,S):Ba(n,r,i,o,u))},(tt,S)=>r(C=>u(tt,void 0)))))})},(x,N)=>r(v=>u(x,void 0)))))}),(d,l)=>r(_=>u(z(s,a,!1),void 0)))))}})())("newline or '}' (statements end at the end of the line)"),en=(()=>{const t=sn((e,n,r,i,o)=>{const u=e._1,s=e._2;return n(a=>R1(z(u,s,!1),n,r,(c,f)=>{const d=c._3;return n(l=>d?i(c,f):Wa(e,n,r,i,o))},o))});return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>o(e._3&&!s._3?z(s._1,s._2,!0):s,void 0))))})(),fn=(t,e,n,r,i)=>e(o=>{const u=(c,f)=>e(d=>en(t._3&&!c._3?z(c._1,c._2,!0):c,e,n,r,i)),s=t._1,a=t._2;return e(c=>R1(z(s,a,!1),e,n,(f,d)=>{const l=f._3;return e(_=>l?r(f,d):Wa(t,e,n,r,u))},u))}),q1=(()=>{const t=St(Yt(e=>e==="|"))("'|'");return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>{const f=sn(Yt(l=>l!=="|")),d=e._3&&!s._3?z(s._1,s._2,!0):s;return n(l=>f(d,n,r,i,(_,h)=>n(p=>{const m=St(St(Yt(x=>x==="|"))("'|'"))("closing '|'"),y=d._3&&!_._3?z(_._1,_._2,!0):_;return n(x=>m(y,n,r,i,(N,v)=>n(b=>o(y._3&&!N._3?z(N._1,N._2,!0):N,Nr(At(Kt.foldr,h))))))})))})))})(),Rv=St(Ma([(t,e,n,r,i)=>e(o=>{const u=t._3;return Ir("->")(t,e,n,(s,a)=>r(z(s._1,s._2,u),a),(s,a)=>e(c=>i(s,XT)))}),(t,e,n,r,i)=>e(o=>{const u=t._3;return Ir("<-")(t,e,n,(s,a)=>r(z(s._1,s._2,u),a),(s,a)=>e(c=>i(s,YT)))}),(()=>{const t=Su(St(Yt(e=>e===">"))("'>'"));return(e,n,r,i,o)=>n(u=>{const s=e._3;return n(a=>n(c=>Ir("--")(e,n,r,(f,d)=>i(z(f._1,f._2,s),d),(f,d)=>n(l=>n(_=>{const h=e._3&&!f._3?z(f._1,f._2,!0):f;return t(h,n,r,(p,m)=>i(z(p._1,p._2,s),m),(p,m)=>n(y=>{const x=h._3&&!p._3?z(p._1,p._2,!0):p;return n(N=>o(x,VT))}))})))))})})()]))("'->', '<-', or '--'"),Cu=Yt(t=>t>="a"&&t<="z"||t>="A"&&t<="Z"),Re=(()=>{const t=sn(Yt(e=>e===" "||e===" "));return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>o(e._3&&!s._3?z(s._1,s._2,!0):s,void 0))))})(),qv=(()=>{const t=St(Yt(e=>e==="\\"))("'\\\\'");return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>{const f=e._3&&!s._3?z(s._1,s._2,!0):s;return n(d=>zv(f,n,r,i,(l,_)=>n(h=>o(f._3&&!l._3?z(l._1,l._2,!0):l,_==="n"?`
12
+ `:_==="t"?" ":_==="r"?"\r":_))))})))})(),Hv=(()=>{const t=Yt(e=>e!=='"'&&e!=="\\"&&e!==`
13
+ `);return(e,n,r,i,o)=>{const u=e._1,s=e._2;return n(a=>qv(z(u,s,!1),n,r,(c,f)=>n(d=>t(e,n,r,i,o)),o))}})(),Ra=(()=>{const t=St(Yt(e=>e==='"'))(`'"'`);return(e,n,r,i,o)=>n(u=>t(e,n,r,i,(s,a)=>n(c=>{const f=sn(Hv),d=e._3&&!s._3?z(s._1,s._2,!0):s;return n(l=>f(d,n,r,i,(_,h)=>n(p=>{const m=St(St(Yt(x=>x==='"'))(`'"'`))(`closing '"' (unterminated string)`),y=d._3&&!_._3?z(_._1,_._2,!0):_;return n(x=>m(y,n,r,i,(N,v)=>n(b=>o(y._3&&!N._3?z(N._1,N._2,!0):N,Nr(At(Kt.foldr,h))))))})))})))})(),Ov=(()=>{const t=St(Yt(e=>e===":"))("':'");return(e,n,r,i,o)=>n(u=>Re(e,n,r,i,(s,a)=>n(c=>St((f,d,l,_,h)=>{const p=f._1,m=f._2;return d(y=>{const x=(N,v)=>{const b=N._3;return d(k=>{if(b)return _(N,v);const E=f._1,A=f._2;return d($=>q1(z(E,A,!1),d,l,(tt,S)=>{const C=tt._3;return d(V=>C?_(tt,S):Ra(f,d,l,_,h))},h))})};return d(N=>t(z(p,m,!1),d,l,x,(v,b)=>d(k=>d(E=>Re(v,d,l,x,(A,$)=>d(tt=>{const S=sn(Yt(V=>V!==`
14
+ `&&V!=="\r"&&V!=="#"&&V!=="}")),C=v._3&&!A._3?z(A._1,A._2,!0):A;return d(V=>S(C,d,l,x,(U,M)=>d(W=>h(C._3&&!U._3?z(U._1,U._2,!0):U,a0(Nr(At(Kt.foldr,M)))))))}))))))})})('label ("\u2026", : rest-of-line, or |\u2026|)')(e._3&&!s._3?z(s._1,s._2,!0):s,n,r,i,o))))})(),H1=(t,e,n,r,i)=>{const o=t._1,u=t._2;return e(s=>q1(z(o,u,!1),e,n,(a,c)=>{const f=a._3;return e(d=>f?r(a,c):Ra(t,e,n,r,i))},i))},Ki=Yt(t=>t>="0"&&t<="9"),Ee=(()=>{const t=St(Yt(e=>e==="_"))("'_'");return(e,n,r,i,o)=>n(u=>{const s=(f,d)=>n(l=>{const _=sn((()=>{const p=St(Yt(y=>y==="_"))("'_'"),m=St(Yt(y=>y==="-"))("'-'");return(y,x,N,v,b)=>{const k=y._1,E=y._2;return x(A=>Cu(z(k,E,!1),x,N,($,tt)=>{const S=$._3;return x(C=>{if(S)return v($,tt);const V=y._1,U=y._2;return x(M=>Ki(z(V,U,!1),x,N,(W,B)=>{const P=W._3;return x(I=>{if(P)return v(W,B);const F=y._1,Q=y._2;return x(R=>p(z(F,Q,!1),x,N,(Y,O)=>{const X=Y._3;return x(q=>X?v(Y,O):m(y,x,N,v,b))},b))})},b))})},b))}})()),h=e._3&&!f._3?z(f._1,f._2,!0):f;return n(p=>_(h,n,r,i,(m,y)=>n(x=>o(h._3&&!m._3?z(m._1,m._2,!0):m,go(d)+Nr(At(Kt.foldr,y))))))}),a=e._1,c=e._2;return n(f=>Cu(z(a,c,!1),n,r,(d,l)=>{const _=d._3;return n(h=>_?i(d,l):t(e,n,r,i,s))},s))})})(),$v=St((t,e,n,r,i)=>{const o=t._1,u=t._2;return e(s=>Ra(z(o,u,!1),e,n,(a,c)=>{const f=a._3;return e(d=>f?r(a,c):Ee(t,e,n,r,i))},i))})("frame name (identifier or quoted string)"),O1=(t,e,n,r,i)=>e(o=>Re(t,e,n,r,(u,s)=>e(a=>{const c=St(Ee)("attribute key"),f=t._3&&!u._3?z(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>{const p=f._3&&!l._3?z(l._1,l._2,!0):l;return e(m=>Re(p,e,n,r,(y,x)=>e(N=>{const v=St(St(Yt(k=>k===":"))("':'"))("':'"),b=p._3&&!y._3?z(y._1,y._2,!0):y;return e(k=>v(b,e,n,r,(E,A)=>e($=>{const tt=b._3&&!E._3?z(E._1,E._2,!0):E;return e(S=>Re(tt,e,n,r,(C,V)=>e(U=>{const M=St(Ee)("attribute value"),W=tt._3&&!C._3?z(C._1,C._2,!0):C;return e(B=>M(W,e,n,r,(P,I)=>e(F=>{const Q=W._3&&!P._3?z(P._1,P._2,!0):P;return e(R=>Re(Q,e,n,r,(Y,O)=>e(X=>i(Q._3&&!Y._3?z(Y._1,Y._2,!0):Y,L(_,I)))))})))})))})))})))})))}))),Xv=(t,e,n,r,i)=>e(o=>Ee(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>Re(c,e,n,r,(d,l)=>e(_=>{const h=c._3&&!d._3?z(d._1,d._2,!0):d;return e(p=>Rv(h,e,n,r,(m,y)=>e(x=>{const N=h._3&&!m._3?z(m._1,m._2,!0):m;return e(v=>Re(N,e,n,r,(b,k)=>e(E=>{const A=St(Ee)("target node identifier"),$=N._3&&!b._3?z(b._1,b._2,!0):b;return e(tt=>A($,e,n,r,(S,C)=>e(V=>{const U=sn((W,B,P,I,F)=>{const Q=W._3;return B(R=>B(Y=>Re(W,B,P,(O,X)=>I(z(O._1,O._2,Q),X),(O,X)=>B(q=>B(K=>{const j=W._3&&!O._3?z(O._1,O._2,!0):O;return H1(j,B,P,(ot,_t)=>I(z(ot._1,ot._2,Q),_t),(ot,_t)=>B(gt=>F(j._3&&!ot._3?z(ot._1,ot._2,!0):ot,_t)))})))))}),M=$._3&&!S._3?z(S._1,S._2,!0):S;return e(W=>U(M,e,n,r,(B,P)=>e(I=>(()=>{if(y==="LeftArrow"){const Q=On("Token",{from:C,to:s,labels:H(Cc)(At(Kt.foldr,P)),arrow:y});return(R,Y,O,X,q)=>q(R,Q)}const F=On("Token",{from:s,to:C,labels:H(Cc)(At(Kt.foldr,P)),arrow:y});return(Q,R,Y,O,X)=>X(Q,F)})()(M._3&&!B._3?z(B._1,B._2,!0):B,e,n,r,i))))})))})))})))})))}))),Yv=(t,e,n,r,i)=>e(o=>Ki(t,e,n,r,(u,s)=>e(a=>{const c=sn(Ki),f=t._3&&!u._3?z(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>{const p=Xd(go(s)+Nr(At(Kt.foldr,_)));return(()=>{if(p.tag==="Just"){const m=p._1;return(y,x,N,v,b)=>b(y,m)}if(p.tag==="Nothing")return(m,y,x,N,v)=>v(m,0);g()})()(f._3&&!l._3?z(l._1,l._2,!0):l,e,n,r,i)})))}))),ji=t=>(e,n,r,i,o)=>{const u=e._3;return n(s=>Ir(t)(e,n,r,(a,c)=>i(z(a._1,a._2,u),c),(a,c)=>n(f=>{const d=Su((()=>{const _=St(Yt(p=>p==="_"))("'_'"),h=St(Yt(p=>p==="-"))("'-'");return(p,m,y,x,N)=>{const v=p._1,b=p._2;return m(k=>Cu(z(v,b,!1),m,y,(E,A)=>{const $=E._3;return m(tt=>{if($)return x(E,A);const S=p._1,C=p._2;return m(V=>Ki(z(S,C,!1),m,y,(U,M)=>{const W=U._3;return m(B=>{if(W)return x(U,M);const P=p._1,I=p._2;return m(F=>_(z(P,I,!1),m,y,(Q,R)=>{const Y=Q._3;return m(O=>Y?x(Q,R):h(p,m,y,x,N))},N))})},N))})},N))}})()),l=e._3&&!a._3?z(a._1,a._2,!0):a;return n(_=>d(l,n,r,(h,p)=>i(z(h._1,h._2,u),p),(h,p)=>n(m=>{const y=l._3&&!h._3?z(h._1,h._2,!0):h;return n(x=>en(y,n,r,(N,v)=>i(z(N._1,N._2,u),v),(N,v)=>n(b=>o(y._3&&!N._3?z(N._1,N._2,!0):N,t))))})))})))},Vv=(t,e,n,r,i)=>e(o=>fn(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>ji("via")(c,e,n,r,(d,l)=>e(_=>{const h=c._3&&!d._3?z(d._1,d._2,!0):d;return e(p=>Ee(h,e,n,r,(m,y)=>e(x=>{const N=h._3&&!m._3?z(m._1,m._2,!0):m;return e(v=>fn(N,e,n,r,(b,k)=>e(E=>{const A=N._3&&!b._3?z(b._1,b._2,!0):b;return e($=>Ee(A,e,n,r,(tt,S)=>e(C=>i(A._3&&!tt._3?z(tt._1,tt._2,!0):tt,{from:y,to:S}))))})))})))})))}))),_r=t=>(e,n,r,i,o)=>{const u=e._3;return n(s=>Ir(t)(e,n,r,(a,c)=>i(z(a._1,a._2,u),c),(a,c)=>n(f=>{const d=Su((()=>{const _=St(Yt(p=>p==="_"))("'_'"),h=St(Yt(p=>p==="-"))("'-'");return(p,m,y,x,N)=>{const v=p._1,b=p._2;return m(k=>Cu(z(v,b,!1),m,y,(E,A)=>{const $=E._3;return m(tt=>{if($)return x(E,A);const S=p._1,C=p._2;return m(V=>Ki(z(S,C,!1),m,y,(U,M)=>{const W=U._3;return m(B=>{if(W)return x(U,M);const P=p._1,I=p._2;return m(F=>_(z(P,I,!1),m,y,(Q,R)=>{const Y=Q._3;return m(O=>Y?x(Q,R):h(p,m,y,x,N))},N))})},N))})},N))}})()),l=e._3&&!a._3?z(a._1,a._2,!0):a;return n(_=>d(l,n,r,(h,p)=>i(z(h._1,h._2,u),p),(h,p)=>n(m=>o(l._3&&!h._3?z(h._1,h._2,!0):h,void 0))))})))},Uv=(t,e,n,r,i)=>e(o=>_r("+edge")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=St(Ee)("source node identifier"),p=c._3&&!d._3?z(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?z(y._1,y._2,!0):y;return e(b=>fn(v,e,n,r,(k,E)=>e(A=>{const $=St(Ee)("target node identifier"),tt=v._3&&!k._3?z(k._1,k._2,!0):k;return e(S=>$(tt,e,n,r,(C,V)=>e(U=>{const M=tt._3&&!C._3?z(C._1,C._2,!0):C;return e(W=>{const B=(F,Q)=>e(R=>i(M._3&&!F._3?z(F._1,F._2,!0):F,On("AddEdge",{from:x,to:V,label:Q.tag==="Just"?T("Just",Q._1):J}))),P=M._1,I=M._2;return e(F=>e(Q=>{const R=(Y,O)=>{const X=Y._3;return e(q=>X?r(Y,O):B(M,J))};return e(Y=>e(O=>Re(z(P,I,!1),e,n,(X,q)=>R(z(X._1,X._2,!1),q),(X,q)=>e(K=>e(j=>H1(X,e,n,(ot,_t)=>R(z(ot._1,ot._2,!1),_t),(ot,_t)=>e(gt=>{const yt=X._3&&!ot._3?z(ot._1,ot._2,!0):ot;return e(Ct=>B(yt,T("Just",_t)))})))))))}))})})))})))})))})))}))),Kv=(t,e,n,r,i)=>e(o=>_r("-edge")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=St(Ee)("source node identifier"),p=c._3&&!d._3?z(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?z(y._1,y._2,!0):y;return e(b=>fn(v,e,n,r,(k,E)=>e(A=>{const $=St(Ee)("target node identifier"),tt=v._3&&!k._3?z(k._1,k._2,!0):k;return e(S=>$(tt,e,n,r,(C,V)=>e(U=>i(tt._3&&!C._3?z(C._1,C._2,!0):C,On("DelEdge",{from:x,to:V})))))})))})))})))}))),jv=(t,e,n,r,i)=>e(o=>_r("-node")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=St(Ee)("node identifier"),p=c._3&&!d._3?z(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=sn((k,E,A,$,tt)=>{const S=k._3;return Vv(k,E,A,(C,V)=>$(z(C._1,C._2,S),V),tt)}),b=p._3&&!y._3?z(y._1,y._2,!0):y;return e(k=>v(b,e,n,r,(E,A)=>e($=>i(b._3&&!E._3?z(E._1,E._2,!0):E,On("DelNode",{id:x,via:At(Kt.foldr,A)})))))})))})))}))),Zv=(t,e,n,r,i)=>e(o=>_r("enter")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=St(Ee)("node identifier"),p=c._3&&!d._3?z(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>i(p._3&&!y._3?z(y._1,y._2,!0):y,On("Enter",{id:x})))))})))}))),tb=(t,e,n,r,i)=>e(o=>_r("exit")(t,e,n,r,(u,s)=>e(a=>i(t._3&&!u._3?z(u._1,u._2,!0):u,UT)))),eb=(t,e,n,r,i)=>e(o=>_r("~edge")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=St(Ee)("source node identifier"),p=c._3&&!d._3?z(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?z(y._1,y._2,!0):y;return e(b=>fn(v,e,n,r,(k,E)=>e(A=>{const $=St(Ee)("target node identifier"),tt=v._3&&!k._3?z(k._1,k._2,!0):k;return e(S=>$(tt,e,n,r,(C,V)=>e(U=>{const M=tt._3&&!C._3?z(C._1,C._2,!0):C;return e(W=>en(M,e,n,r,(B,P)=>e(I=>{const F=St(Ir("->"))("'->'"),Q=M._3&&!B._3?z(B._1,B._2,!0):B;return e(R=>F(Q,e,n,r,(Y,O)=>e(X=>{const q=Q._3&&!Y._3?z(Y._1,Y._2,!0):Y;return e(K=>en(q,e,n,r,(j,ot)=>e(_t=>{const gt=St(Ee)("new source node identifier"),yt=q._3&&!j._3?z(j._1,j._2,!0):j;return e(Ct=>gt(yt,e,n,r,(Rt,pt)=>e(qt=>{const wt=yt._3&&!Rt._3?z(Rt._1,Rt._2,!0):Rt;return e(mt=>fn(wt,e,n,r,(ft,st)=>e(dt=>{const at=St(Ee)("new target node identifier"),ct=wt._3&&!ft._3?z(ft._1,ft._2,!0):ft;return e(Nt=>at(ct,e,n,r,(Jt,Lt)=>e(Ht=>i(ct._3&&!Jt._3?z(Jt._1,Jt._2,!0):Jt,On("RepointEdge",{from:x,to:V,newFrom:pt,newTo:Lt})))))})))})))})))})))})))})))})))})))})))}))),nb=(t,e,n,r,i)=>e(o=>_r("seed")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>Re(c,e,n,r,(d,l)=>e(_=>{const h=St(Yv)("integer (seed value)"),p=c._3&&!d._3?z(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?z(y._1,y._2,!0):y;return e(b=>en(v,e,n,r,(k,E)=>e(A=>i(v._3&&!k._3?z(k._1,k._2,!0):k,x))))})))})))}))),Zi=Qv((()=>{const t=St(Yt(e=>e==="{"))("'{'");return(e,n,r,i,o)=>n(u=>n(s=>t(e,n,r,i,(a,c)=>n(f=>n(d=>{const l=e._3&&!a._3?z(a._1,a._2,!0):a;return en(l,n,r,i,(_,h)=>n(p=>o(l._3&&!_._3?z(_._1,_._2,!0):_,h)))})))))})())(St((()=>{const t=St(Yt(e=>e==="}"))("'}'");return(e,n,r,i,o)=>n(u=>n(s=>en(e,n,r,i,(a,c)=>n(f=>n(d=>{const l=e._3&&!a._3?z(a._1,a._2,!0):a;return t(l,n,r,i,(_,h)=>n(p=>o(l._3&&!_._3?z(_._1,_._2,!0):_,h)))})))))})())("closing '}'")),rb=Zi((t,e,n,r,i)=>e(o=>{const u=(c,f)=>e(d=>(()=>{if(f.tag==="Nothing")return(l,_,h,p,m)=>m(l,D);if(f.tag==="Just"){const l=f._1,_=sn((()=>{const h=St(Yt(p=>p===","))("','");return(p,m,y,x,N)=>{const v=p._3;return m(b=>m(k=>m(E=>m(A=>m($=>m(tt=>Re(p,m,y,(S,C)=>x(z(S._1,S._2,v),C),(S,C)=>m(V=>m(U=>{const M=p._3&&!S._3?z(S._1,S._2,!0):S;return h(M,m,y,(W,B)=>x(z(W._1,W._2,v),B),(W,B)=>m(P=>{const I=M._3&&!W._3?z(W._1,W._2,!0):W;return m(F=>m(Q=>{const R=p._3&&!I._3?z(I._1,I._2,!0):I;return Re(R,m,y,(Y,O)=>x(z(Y._1,Y._2,v),O),(Y,O)=>m(X=>{const q=R._3&&!Y._3?z(Y._1,Y._2,!0):Y;return m(K=>m(j=>{const ot=p._3&&!q._3?z(q._1,q._2,!0):q;return O1(ot,m,y,(_t,gt)=>x(z(_t._1,_t._2,v),gt),(_t,gt)=>m(yt=>N(ot._3&&!_t._3?z(_t._1,_t._2,!0):_t,gt)))}))}))}))}))})))))))))}})());return(h,p,m,y,x)=>p(N=>_(h,p,m,y,(v,b)=>p(k=>x(h._3&&!v._3?z(v._1,v._2,!0):v,Bv([l,...At(Kt.foldr,b)])))))}g()})()(t._3&&!c._3?z(c._1,c._2,!0):c,e,n,r,i)),s=t._1,a=t._2;return e(c=>e(f=>O1(z(s,a,!1),e,n,(d,l)=>e(_=>u(t,J)),(d,l)=>e(_=>u(d,T("Just",l))))))})),ib=(t,e,n,r,i)=>e(o=>_r("+node")(t,e,n,r,(u,s)=>e(a=>{const c=t._3&&!u._3?z(u._1,u._2,!0):u;return e(f=>fn(c,e,n,r,(d,l)=>e(_=>{const h=St(Ee)("node identifier"),p=c._3&&!d._3?z(d._1,d._2,!0):d;return e(m=>h(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?z(y._1,y._2,!0):y;return e(b=>e(k=>Re(v,e,n,r,(E,A)=>e($=>{const tt=Yt(C=>C===`
15
+ `||C==="\r"||C==="#"||C==="}"||C==="{"),S=v._3&&!E._3?z(E._1,E._2,!0):E;return e(C=>{const V=(W,B)=>e(P=>(B?((I,F,Q,R,Y)=>Y(I,"")):Ov)(S._3&&!W._3?z(W._1,W._2,!0):W,e,n,r,(I,F)=>e(Q=>{const R=v._3&&!I._3?z(I._1,I._2,!0):I;return e(Y=>{const O=(K,j)=>e(ot=>i(R._3&&!K._3?z(K._1,K._2,!0):K,On("AddNode",{id:x,label:F,shape:(()=>{const _t=Mv("shape")(j);if(_t.tag==="Just")return _t._1==="rectangle"||_t._1==="rect"?er:_t._1==="cylinder"||_t._1==="cyl"?Zl:_t._1==="parallelogram"?th:_t._1==="diamond"?eh:_t._1==="ellipse"?nh:_t._1==="document"||_t._1==="doc"?rh:_t._1==="cloud"?ih:er;if(_t.tag==="Nothing")return er;g()})()}))),X=R._1,q=R._2;return e(K=>{const j=(ot,_t)=>{const gt=ot._3;return e(yt=>gt?r(ot,_t):O(R,D))};return e(ot=>e(_t=>Re(z(X,q,!1),e,n,(gt,yt)=>j(z(gt._1,gt._2,!1),yt),(gt,yt)=>e(Ct=>e(Rt=>rb(gt,e,n,(pt,qt)=>j(z(pt._1,pt._2,!1),qt),(pt,qt)=>e(wt=>O(gt._3&&!pt._3?z(pt._1,pt._2,!0):pt,qt))))))))})})}))),U=S._1,M=S._2;return e(W=>{const B=(P,I)=>{const F=P._3;return e(Q=>F?r(P,I):V(S,!1))};return e(P=>e(I=>e(F=>Ba(z(U,M,!1),e,n,(Q,R)=>{const Y=Q._3;return e(O=>Y?B(z(U,M,!1),R):e(X=>tt(z(U,M,!1),e,n,(q,K)=>B(z(U,M,!1),K),(q,K)=>e(j=>e(ot=>V(z(U,M,!1),!0))))))},(Q,R)=>e(Y=>e(O=>V(z(U,M,!1),!0)))))))})})}))))})))})))}))),ob=(t,e,n,r,i)=>e(o=>z1(t,e,n,r,(u,s)=>e(a=>{const c=St(Ma([ib,jv,eb,Uv,Kv,Zv,tb,Xv]))("statement (+node, -node, +edge, -edge, ~edge, enter, exit, or 'a -> b'/'a <- b'/'a -- b')"),f=t._3&&!u._3?z(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>i(f._3&&!l._3?z(l._1,l._2,!0):l,Ia("Leaf",{op:_,line:s.line,column:s.column})))))}))),ub=(t,e,n,r,i)=>e(o=>ji("seq")(t,e,n,r,(u,s)=>e(a=>Zi(qa(G1))(t._3&&!u._3?z(u._1,u._2,!0):u,e,n,r,i)))),sb=(t,e,n,r,i)=>e(o=>ji("par")(t,e,n,r,(u,s)=>e(a=>Zi(qa(tv))(t._3&&!u._3?z(u._1,u._2,!0):u,e,n,r,i)))),qa=t=>{const e=sn(ab());return(n,r,i,o,u)=>r(s=>e(n,r,i,o,(a,c)=>r(f=>u(n._3&&!a._3?z(a._1,a._2,!0):a,t(At(Kt.foldr,c))))))},ab=Ua(()=>{const t=Su(St(Yt(e=>e==="}"))("'}'"));return(e,n,r,i,o)=>n(u=>{const s=e._3;return n(a=>n(c=>en(e,n,r,(f,d)=>i(z(f._1,f._2,s),d),(f,d)=>n(l=>n(_=>{const h=e._3&&!f._3?z(f._1,f._2,!0):f;return t(h,n,r,(p,m)=>i(z(p._1,p._2,s),m),(p,m)=>n(y=>{const x=h._3&&!p._3?z(p._1,p._2,!0):p;return n(N=>{const v=Ma([(k,E,A,$,tt)=>{const S=k._3;return sb(k,E,A,(C,V)=>$(z(C._1,C._2,S),V),tt)},(k,E,A,$,tt)=>{const S=k._3;return ub(k,E,A,(C,V)=>$(z(C._1,C._2,S),V),tt)},ob]),b=e._3&&!x._3?z(x._1,x._2,!0):x;return n(k=>v(b,n,r,i,(E,A)=>n($=>{const tt=b._3&&!E._3?z(E._1,E._2,!0):E;return n(S=>Re(tt,n,r,i,(C,V)=>n(U=>{const M=tt._3&&!C._3?z(C._1,C._2,!0):C;return n(W=>Wv(M,n,r,i,(B,P)=>n(I=>o(M._3&&!B._3?z(B._1,B._2,!0):B,A))))})))})))})}))})))))})}),Ha=t=>e=>(n,r,i,o,u)=>r(s=>ji(t)(n,r,i,o,(a,c)=>r(f=>{const d=n._3&&!a._3?z(a._1,a._2,!0):a;return r(l=>$v(d,r,i,o,(_,h)=>r(p=>{const m=d._3&&!_._3?z(_._1,_._2,!0):_;return r(y=>en(m,r,i,o,(x,N)=>r(v=>{const b=Zi(qa(G1)),k=m._3&&!x._3?z(x._1,x._2,!0):x;return r(E=>b(k,r,i,o,(A,$)=>r(tt=>{const S=k._3&&!A._3?z(A._1,A._2,!0):A;return r(C=>en(S,r,i,o,(V,U)=>r(M=>u(S._3&&!V._3?z(V._1,V._2,!0):V,{name:T("Just",h),ops:$,kind:e}))))})))})))})))}))),cb=(t,e,n,r,i)=>{const o=t._1,u=t._2;return e(s=>Ha("keyframe")(KT)(z(o,u,!1),e,n,(a,c)=>{const f=a._3;return e(d=>{if(f)return r(a,c);const l=t._1,_=t._2;return e(h=>Ha("still")(jT)(z(l,_,!1),e,n,(p,m)=>{const y=p._3;return e(x=>y?r(p,m):Ha("title")(ZT)(t,e,n,r,i))},i))})},i))},gb=(t,e,n,r,i)=>e(o=>ji("inside")(t,e,n,r,(u,s)=>e(a=>{const c=St(Ee)("node identifier"),f=t._3&&!u._3?z(u._1,u._2,!0):u;return e(d=>c(f,e,n,r,(l,_)=>e(h=>{const p=f._3&&!l._3?z(l._1,l._2,!0):l;return e(m=>en(p,e,n,r,(y,x)=>e(N=>{const v=p._3&&!y._3?z(y._1,y._2,!0):y;return e(b=>Zi($1)(v,e,n,r,(k,E)=>e(A=>{const $=v._3&&!k._3?z(k._1,k._2,!0):k;return e(tt=>en($,e,n,r,(S,C)=>e(V=>i($._3&&!S._3?z(S._1,S._2,!0):S,{node:_,doc:E}))))})))})))})))}))),$1=(t,e,n,r,i)=>e(o=>{const u=(c,f)=>e(d=>{const l=sn(fb()),_=t._3&&!c._3?z(c._1,c._2,!0):c;return e(h=>l(_,e,n,r,(p,m)=>e(y=>{const x=At(Kt.foldr,m);return i(_._3&&!p._3?z(p._1,p._2,!0):p,{seed:(()=>{if(f.tag==="Nothing")return 0;if(f.tag==="Just")return f._1;g()})(),frames:xt(N=>{if(N.tag==="TopFrame")return T("Just",N._1);if(N.tag==="TopInside")return J;g()})(x),interiors:xt(N=>{if(N.tag==="TopInside")return T("Just",N._1);if(N.tag==="TopFrame")return J;g()})(x)})})))}),s=t._1,a=t._2;return e(c=>e(f=>nb(z(s,a,!1),e,n,(d,l)=>{const _=d._3;return e(h=>_?r(d,l):u(t,J))},(d,l)=>e(_=>u(d,T("Just",l))))))}),fb=Ua(()=>bv.defer(t=>(e,n,r,i,o)=>{const u=e._1,s=e._2;return n(a=>n(c=>gb(z(u,s,!1),n,r,(f,d)=>n(l=>n(_=>cb(e,n,r,i,(h,p)=>n(m=>o(h,W1("TopFrame",p)))))),(f,d)=>n(l=>o(f,W1("TopInside",d))))))})),_b=(()=>{const t=St((e,n,r,i,o)=>n(u=>n(s=>en(e,n,r,i,(a,c)=>n(f=>n(d=>{const l=e._3&&!a._3?z(a._1,a._2,!0):a;return Ba(l,n,r,i,(_,h)=>n(p=>o(l._3&&!_._3?z(_._1,_._2,!0):_,h)))}))))))("'keyframe', 'still', 'title', 'inside', or end of input");return(e,n,r,i,o)=>n(u=>n(s=>n(a=>n(c=>en(e,n,r,i,(f,d)=>n(l=>n(_=>{const h=e._3&&!f._3?z(f._1,f._2,!0):f;return $1(h,n,r,i,(p,m)=>n(y=>{const x=h._3&&!p._3?z(p._1,p._2,!0):p;return n(N=>n(v=>{const b=e._3&&!x._3?z(x._1,x._2,!0):x;return t(b,n,r,i,(k,E)=>n(A=>o(b._3&&!k._3?z(k._1,k._2,!0):k,m)))}))}))})))))))})(),db=t=>{const e=Sv(t)(_b);if(e.tag==="Left")return Gt("Left",{msg:e._1._1,line:e._1._2.line,column:e._1._2.column});if(e.tag==="Right")return Gt("Right",e._1);g()},lb=t=>{const e=db(t);if(e.tag==="Left")return Gt("Left",e._1.msg);if(e.tag==="Right")return Gt("Right",e._1);g()};function Oa(t,e,n,r){if(typeof window<"u"){var i=window[n];if(i!=null&&r instanceof i)return e(r)}for(var o=r;o!=null;){var u=Object.getPrototypeOf(o),s=u.constructor.name;if(s===n)return e(r);if(s==="Object")return t;o=u}return t}function _n(t){return function(e){return function(n){return function(){n.setAttribute(t,e)}}}}function hb(t){return function(e){return function(){return e.getAttribute(t)}}}const X1=t=>{const e=hb(t);return n=>{const r=e(n);return()=>{const i=r();return mc(i,J,Zt)}}};function pb(t){return function(e){return function(){e.textContent=t}}}function mb(t){return function(){return function(e){return t(e)()}}}function yb(t){return function(e){return function(n){return function(r){return function(){return r.addEventListener(t,e,n)}}}}}const Y1=function(){return window};function xb(t){return function(e){return function(){e.value=t}}}function Nb(t){return function(){return t.valueAsNumber}}function Jb(t){return function(){return t.value}}function V1(t){return function(e){return function(){return e.requestAnimationFrame(t)}}}const wb=t=>t,$a=t=>()=>{const e=t.getBoundingClientRect?.(),n=e?.width||t.clientWidth||0,r=e?.height||t.clientHeight||0;return{width:n,height:r}},Tb=t=>e=>()=>{let n=0;const r=()=>{n||(n=requestAnimationFrame(()=>{n=0,e()}))},i=typeof ResizeObserver>"u"?null:new ResizeObserver(r);return i?.observe(t),window.addEventListener("resize",r),()=>{n&&cancelAnimationFrame(n),i?.disconnect(),window.removeEventListener("resize",r)}},vb=()=>window.devicePixelRatio||1,bb=t=>e=>n=>r=>i=>()=>{const o=Math.max(1,e||t.clientWidth||r),u=Math.max(1,n||t.clientHeight||i),s="Markgraf needs more room",a=`Resize to at least ${Math.round(r)} \xD7 ${Math.round(i)} px`;if(t.setAttribute("data-mg-too-small","1"),t.setAttribute("data-mg-viewport-css-width",String(e||0)),t.setAttribute("data-mg-viewport-css-height",String(n||0)),t.setAttribute("data-mg-camera-vw","0"),t.setAttribute("data-mg-camera-vh","0"),t.setAttribute("data-mg-camera-zoom","0"),t instanceof SVGElement){t.setAttribute("viewBox",`0 0 ${o} ${u}`),t.setAttribute("preserveAspectRatio","xMidYMid meet"),t.innerHTML=`
16
+ <rect x="0" y="0" width="${o}" height="${u}" rx="16" fill="#111827"/>
17
+ <text x="${o/2}" y="${u/2-10}" text-anchor="middle" dominant-baseline="middle" fill="#f9fafb" font-family="system-ui, sans-serif" font-size="18" font-weight="700">${s}</text>
18
+ <text x="${o/2}" y="${u/2+18}" text-anchor="middle" dominant-baseline="middle" fill="#cbd5e1" font-family="system-ui, sans-serif" font-size="13">${a}</text>
19
+ `;return}if(t instanceof HTMLCanvasElement){const c=window.devicePixelRatio||1;t.width=Math.max(1,Math.round(o*c)),t.height=Math.max(1,Math.round(u*c));const f=t.getContext("2d");if(!f)return;f.save(),f.scale(c,c),f.clearRect(0,0,o,u),f.fillStyle="#111827",f.fillRect(0,0,o,u),f.textAlign="center",f.textBaseline="middle",f.fillStyle="#f9fafb",f.font="700 18px system-ui, sans-serif",f.fillText(s,o/2,u/2-10),f.fillStyle="#cbd5e1",f.font="13px system-ui, sans-serif",f.fillText(a,o/2,u/2+18),f.restore();return}t.textContent=`${s}. ${a}.`},Xa=(t,e)=>{e.innerHTML=t},U1=(t,e,n)=>{t.style.setProperty(e,n)},Lb=(t,e)=>t.querySelector(`[data-mg="${e}"]`),kb=t=>e=>t===e,Eb=t=>t,Sb=(t,e,n)=>({tag:t,_1:e,_2:n}),Cb=Bt.foldMap(rl),Gb=t=>e=>{const n=rt.compare(t)(e);if(n==="LT")return e;if(n==="EQ"||n==="GT")return t;g()},K1=t=>e=>{const n=rt.compare(t)(e);if(n==="LT"||n==="EQ")return t;if(n==="GT")return e;g()},j1=Sb("AutoSize"),Pb=Eb("CanvasRenderer"),Ab=t=>e=>{const n=t-e*et(xe(xn(t/e)));return e<=0?0:n<0?n+e:n},Ib=t=>w(e=>n=>{const r=t(n);return()=>(e(),r())})(()=>{}),Qb=t=>{const e=X1("data-markgraf-titles")(t);return()=>{const n=e();return n.tag==="Nothing"||!(n.tag==="Just"&&n._1==="false")}},Db=t=>{const e=X1("data-markgraf-theme")(t);return()=>{const n=e();if(n.tag==="Just")return n._1==="light"?Ga:n._1==="dark"?wT:n._1==="blueprint"?TT:n._1==="whiteboard"?vT:n._1==="isometric"?bT:Ga;if(n.tag==="Nothing")return Ga;g()}},Fb=`
16
20
  <canvas data-mg="stage" tabindex="0"></canvas>
17
21
  <div data-mg="play-overlay" aria-hidden="true"></div>
18
22
  <div data-mg="bar">
@@ -29,4 +33,4 @@ var $v=(function(Su){"use strict";function Qa(t){let e=0,n;return()=>{if(e===2)r
29
33
  <option value="2">2\xD7</option>
30
34
  </select>
31
35
  </div>
32
- `,$n=t=>e=>n=>()=>{const r=Nv(t,e),i=ac(r,J,Ut);if(i.tag==="Just")return n(i._1)();i.tag!=="Nothing"&&g()},Dv=t=>e=>{const n=e.totalDuration<=0?1:e.totalDuration,r=vv(i=>'<span class="mg-tick" style="left:'+gi(ai("Fixed",ci(0)(20)(2)))(100*i.startT/n)+'%" data-label="'+(()=>{if(i.scene.tag==="Structural")return i.scene._1.to;if(i.scene.tag==="DataFlow")return i.scene._1.keyframe;if(i.scene.tag==="Hold")return i.scene._1;if(i.scene.tag==="EnterNode"||i.scene.tag==="ExitNode")return"";g()})()+'"></span>')(e.spans);return $n(t)("ticks")(i=>()=>Ia(r,i))},Iv=t=>e=>n=>$n(t)("scrub")(r=>{const i=Da(J,Ut,"HTMLInputElement",r);if(i.tag==="Nothing")return()=>{};if(i.tag==="Just")return n<=0?()=>{}:_v(ee(ce(Dn(e/n*1e3))))(i._1);g()}),Aa=t=>e=>n=>{const r=cv(i=>n);return()=>{const i=r();return gv(t)(i)(!1)(e)()}},b1=()=>Id()/1e3,Fa=t=>e=>n=>r=>i=>o=>u=>s=>a=>c=>{const f=qe(u.layout),d=Pl(u.layout),l={center:{x:d.x+d.w/2,y:f.y+f.h/2},zoom:cs(u.layout)(f)(0)},_=Sc(u.layout)(l),h=()=>{const N=b1(),v=a.value;return a.value=N,v===0?0:N-v},p=ap(u)(v1(c)(u.totalDuration)),m=o?p:{...p,levels:O(N=>({...N,state:{...N.state,frameTitle:""}}))(p.levels)},y=u.dives.length===0&&(_.w+48)*1.0909090909090908<=1100&&(_.h+48)*1.0909090909090908<=1400,x=y?{...m,camera:l,levels:O(N=>({...N,state:{...N.state,camera:l}}))(m.levels)}:m;if(e==="CanvasRenderer")return()=>{const N=h(),v=pv(t),k=Nu({padding:8,outputAspect:J})(x),L=(()=>{if(n.tag==="FixedSize")return{w:n._1,h:n._2};if(n.tag==="AutoSize"){if(y)return{w:k.vw*1.0909090909090908,h:k.vh*1.0909090909090908};const R=mv(t)(),C=yv(t)();return{w:R,h:C<=0?k.vw<=0?R:R*k.vh/k.vw:C}}g()})(),E=xv(),B=L.w*E,q=L.h*E,j=Fd(v)(),G=Bd(v)(),P=Qd(v)(B);j!==B&&P();const V=Rd(v)(q);if(G!==q&&V(),n.tag==="FixedSize")Lu(t,"width",ee(ce(Dn(L.w)))+"px"),Lu(t,"height",ee(ce(Dn(L.h)))+"px");else if(n.tag==="AutoSize"){const R=ee(ce(Dn(L.w)))+"px";y&&(Lu(t,"width",R),Lu(t,"height",ee(ce(Dn(L.h)))+"px"))}else g();const U=Ad(v)();Kn(U)(),ao(U)({scaleX:E,scaleY:E})();const M=s.value,H=pT(r)(i)(U)({width:L.w,height:L.h})(x)(N)(M)();return s.value=H,Zn(U)()};if(e==="SvgRenderer")return()=>{const N=h(),v=s.value,k=FT((()=>{if(n.tag==="AutoSize")return J;if(n.tag==="FixedSize")return n._1<=0||n._2<=0?J:w("Just",n._1/n._2);g()})())(r)(i)(x)(N)(v);return s.value=k.springs,ni("viewBox")(k.parts.viewBox)(t)(),ni("preserveAspectRatio")("xMidYMid meet")(t)(),n.tag==="FixedSize"?(ni("width")(ee(ce(Dn(n._1))))(t)(),ni("height")(ee(ce(Dn(n._2))))(t)()):n.tag==="AutoSize"||g(),Ia(k.parts.body,t)};g()},k1=t=>{const e=uv(t);if(e.tag==="Left")return Dt("Left",e._1);if(e.tag==="Right"){const n=f1(e._1)(s1)._1;if(n.tag==="Left")return Dt("Left",n._1.msg);if(n.tag==="Right")return Dt("Right",n._1)}g()},Av=t=>{const e=k1(t);if(e.tag==="Left")return e._1;if(e.tag==="Right")return Sd;g()},Ba=t=>e=>{const n=Kt(r=>r.startT<=e&&e<r.endT)(t.spans);if(n.tag==="Just"){if(n._1.scene.tag==="Structural")return n._1.scene._1.to;if(n._1.scene.tag==="DataFlow")return n._1.scene._1.keyframe;if(n._1.scene.tag==="Hold")return n._1.scene._1;if(n._1.scene.tag==="EnterNode"||n._1.scene.tag==="ExitNode")return"";g()}if(n.tag==="Nothing"){const r=t.spans.length-1|0;if(r>=0&&r<t.spans.length){if(t.spans[r].scene.tag==="Structural")return t.spans[r].scene._1.to;if(t.spans[r].scene.tag==="DataFlow")return t.spans[r].scene._1.keyframe;if(t.spans[r].scene.tag==="Hold")return t.spans[r].scene._1;if(t.spans[r].scene.tag==="EnterNode"||t.spans[r].scene.tag==="ExitNode")return"";g()}return""}g()},Fv=t=>e=>$n(t)("speed")(n=>{const r=Da(J,Ut,"HTMLSelectElement",n);if(r.tag==="Nothing")return()=>{};if(r.tag==="Just")return Aa("change")(n)((()=>{const i=lv(r._1);return()=>{const o=i(),u=dd(o,nc,Ut,J);if(u.tag==="Just")return e(u._1)();u.tag!=="Nothing"&&g()}})());g()}),Bv=t=>e=>n=>$n(t)("scrub")(r=>{const i=Da(J,Ut,"HTMLInputElement",r);if(i.tag==="Nothing")return()=>{};if(i.tag==="Just")return Aa("input")(r)((()=>{const o=dv(i._1);return()=>{const u=o();return n.pause(),n.seek(u/1e3*e.totalDuration)()}})());g()}),Qv=t=>e=>n=>{const r=Dv(t)(e);return()=>{r(),$n(t)("play")(i=>ni("data-mg-playing")("1")(i))(),Fv(t)(n.setSpeed)(),$n(t)("play")(i=>Aa("click")(i)(n.toggle))(),Bv(t)(e)(n)(),n.subscribe(i=>{const o=Iv(t)(i.time)(e.totalDuration);return()=>(o(),$n(t)("time")(u=>av(gi(ai("Fixed",ci(0)(20)(2)))(i.time)+" / "+gi(ai("Fixed",ci(0)(20)(2)))(e.totalDuration))(u))(),$n(t)("play")(u=>ni("data-mg-playing")(i.playing?"1":"0")(u))())})()}},Rv={...dh,tokenZoomFloor:1,minZoom:1.6,maxZoom:3.2},Mv=t=>e=>{const n=Af(t);return()=>{const r=n(),i=Ff(t)(),o=m0(Rv)(u0)(t)(Bf(r)(i)(t));if(o.tag==="Left")return cc("[markgraf] precompute failed")();if(o.tag==="Right")return e(o._1)();g()}},zv=t=>e=>n=>r=>i=>o=>u=>()=>{let s=1,a=!0,c=!1,f=0,d=0;const l={value:A},_={value:0};let h=!1,p=[];Fa(t)(n)(r)(i)(o)(u)(e)(l)(_)(0)();const m=L=>()=>{const E=p,B=a,q={time:L,keyframe:Ba(e)(L),playing:B};return Cv(j=>j(q))(E)()},y=()=>(a=!1,m(f)()),x=()=>{if(!h&&(c=!1,a)){const L=b1(),E=d;d=L;const B=s,q=f,j=Ev(E===0?q+0*B:q+(L-E)*B)(e.totalDuration+.8);return f=j,Fa(t)(n)(r)(i)(o)(u)(e)(l)(_)(j)(),m(j)(),N()}},N=()=>{if(!h&&!c){c=!0;const L=fv();hv(x)(L)()}},v=()=>(d=0,a=!0,N()),k=()=>(a||v(),m(f)());return v(),{play:k,pause:y,toggle:()=>a?y():k(),seek:L=>{const E=bv(0)(v1(e.totalDuration)(L));return()=>(f=E,d=0,Fa(t)(n)(r)(i)(o)(u)(e)(l)(_)(E)(),m(E)())},setSpeed:L=>()=>s=L,currentTime:()=>f,currentKeyframe:()=>{const L=f;return Ba(e)(L)},isPlaying:()=>a,duration:e.totalDuration,subscribe:L=>()=>{p=Rt(p)(L);const E=f,B=a;L({time:E,keyframe:Ba(e)(E),playing:B})();const q=tc(j=>!Jv(j)(L));return()=>{p=q(p)}},destroy:()=>h=!0}},L1=t=>e=>{const n=k1(e);if(n.tag==="Left")return cc("[markgraf] parse failed: "+n._1);if(n.tag==="Right")return Mv(n._1)(r=>{const i=Sv(t);return()=>{const o=i(),u=Gv(t)();return Ia(Pv,t),$n(t)("stage")(s=>{const a=zv(s)(r)(Lv)(kv)(u)(TT)(o);return()=>{const c=a();return Qv(t)(r)(c)()}})()}});g()},Hv=t=>{const e=t.getAttribute("data-markgraf-src-b64");if(e)try{return decodeURIComponent(escape(atob(e)))}catch{return atob(e)}return t.getAttribute("data-markgraf-src")||t.textContent||""};let Sn=null;const Eu=t=>t.querySelector('[data-mg="play"]')?.dataset.mgPlaying==="1",Wv=t=>{const e=t.querySelector('[data-mg="play"]');if(!e)return;e.addEventListener("click",()=>{queueMicrotask(()=>{Eu(t)?(Sn&&Sn!==t&&Eu(Sn)&&Sn.querySelector('[data-mg="play"]').click(),Sn=t):Sn===t&&(Sn=null)})});const n=r=>{r.preventDefault(),e.click()};t.querySelector('[data-mg="stage"]')?.addEventListener("click",n)},Ov=t=>{if(t.dataset.markgrafMounted==="1")return;t.dataset.markgrafMounted="1";const e=Hv(t),n=t.dataset.markgrafPaused==="true";t.textContent="",L1(t)(e)(),n?Eu(t)&&t.querySelector('[data-mg="play"]').click():Sn===null?Sn=t:Eu(t)&&t.querySelector('[data-mg="play"]').click(),Wv(t)},Cu=(t=document)=>{t.querySelectorAll("[data-markgraf]").forEach(Ov)},E1=()=>{document.addEventListener("keydown",t=>{if(t.code!=="Space"&&t.key!==" ")return;const e=t.target,n=e&&e.closest?.("[data-markgraf]");if(!n){const i=e?.tagName,o=(e?.type||"").toLowerCase();if(e?.isContentEditable||i==="TEXTAREA"||i==="SELECT"||i==="INPUT"&&!["range","checkbox","radio","button","submit","reset"].includes(o))return}const r=n||Sn||document.querySelector("[data-markgraf]");r&&(t.preventDefault(),r.querySelector('[data-mg="play"]')?.click())})};if(typeof window<"u"){const t=e=>{const n=Av(e);return n==null?{ok:!0}:{ok:!1,error:n}};window.markgraf={mount:(e,n)=>L1(e)(n)(),mountAll:Cu,tryParse:t},document.readyState==="loading"?document.addEventListener("DOMContentLoaded",()=>{Cu(),E1()}):(Cu(),E1())}return Su.mountAll=Cu,Object.defineProperty(Su,Symbol.toStringTag,{value:"Module"}),Su})({});
36
+ `,Z1=t=>e=>({...e,state:{...e.state,camera:t},minis:H(n=>Z1(t)(n))(e.minis)}),zb=t=>e=>n=>{const r=Jo(n.rootLayout)(n.camera),i=_n("data-mg-too-small")("0")(t);return()=>(i(),_n("data-mg-camera-vw")(dr(r.w))(t)(),_n("data-mg-camera-vh")(dr(r.h))(t)(),_n("data-mg-camera-zoom")(dr(n.camera.zoom))(t)(),_n("data-mg-viewport-css-width")(dr(e.w))(t)(),_n("data-mg-viewport-css-height")(dr(e.h))(t)())},Yn=t=>e=>n=>()=>{const r=Lb(t,e),i=mc(r,J,Zt);if(i.tag==="Just")return n(i._1)();i.tag!=="Nothing"&&g()},Bb=t=>e=>{const n=e.totalDuration<=0?1:e.totalDuration,r=Cb(i=>'<span class="mg-tick" style="left:'+pi(li("Fixed",hi(0)(20)(2)))(100*i.startT/n)+'%" data-label="'+(()=>{if(i.scene.tag==="Structural")return i.scene._1.to;if(i.scene.tag==="DataFlow")return i.scene._1.keyframe;if(i.scene.tag==="Hold")return i.scene._1;if(i.scene.tag==="EnterNode"||i.scene.tag==="ExitNode")return"";g()})()+'"></span>')(e.spans);return Yn(t)("ticks")(i=>()=>Xa(r,i))},Mb=t=>e=>n=>Yn(t)("scrub")(r=>{const i=Oa(J,Zt,"HTMLInputElement",r);if(i.tag==="Nothing")return()=>{};if(i.tag==="Just")return n<=0?()=>{}:xb(ue(xe(xr(e/n*1e3))))(i._1);g()}),Ya=t=>e=>n=>{const r=mb(i=>n);return()=>{const i=r();return yb(t)(i)(!1)(e)()}},td=()=>cl()/1e3,ed=t=>{const e=lb(t);if(e.tag==="Left")return Gt("Left",e._1);if(e.tag==="Right"){const n=D1(e._1)(P1)._1;if(n.tag==="Left")return Gt("Left",n._1.msg);if(n.tag==="Right")return Gt("Right",n._1)}g()},Wb=t=>{const e=ed(t);if(e.tag==="Left")return e._1;if(e.tag==="Right")return ol;g()},Va=t=>e=>{const n=Vt(r=>r.startT<=e&&e<r.endT)(t.spans);if(n.tag==="Just"){if(n._1.scene.tag==="Structural")return n._1.scene._1.to;if(n._1.scene.tag==="DataFlow")return n._1.scene._1.keyframe;if(n._1.scene.tag==="Hold")return n._1.scene._1;if(n._1.scene.tag==="EnterNode"||n._1.scene.tag==="ExitNode")return"";g()}if(n.tag==="Nothing"){const r=t.spans.length-1|0;if(r>=0&&r<t.spans.length){if(t.spans[r].scene.tag==="Structural")return t.spans[r].scene._1.to;if(t.spans[r].scene.tag==="DataFlow")return t.spans[r].scene._1.keyframe;if(t.spans[r].scene.tag==="Hold")return t.spans[r].scene._1;if(t.spans[r].scene.tag==="EnterNode"||t.spans[r].scene.tag==="ExitNode")return"";g()}return""}g()},Rb=t=>e=>Yn(t)("speed")(n=>{const r=Oa(J,Zt,"HTMLSelectElement",n);if(r.tag==="Nothing")return()=>{};if(r.tag==="Just")return Ya("change")(n)((()=>{const i=Jb(r._1);return()=>{const o=i(),u=Rd(o,_c,Zt,J);if(u.tag==="Just")return e(u._1)();u.tag!=="Nothing"&&g()}})());g()}),qb=t=>e=>n=>Yn(t)("scrub")(r=>{const i=Oa(J,Zt,"HTMLInputElement",r);if(i.tag==="Nothing")return()=>{};if(i.tag==="Just")return Ya("input")(r)((()=>{const o=Nb(i._1);return()=>{const u=o();return n.pause(),n.seek(u/1e3*e.totalDuration)()}})());g()}),Hb=t=>e=>n=>{const r=Bb(t)(e);return()=>{r(),Yn(t)("play")(i=>_n("data-mg-playing")("1")(i))(),Rb(t)(n.setSpeed)(),Yn(t)("play")(i=>Ya("click")(i)(n.toggle))(),qb(t)(e)(n)(),n.subscribe(i=>{const o=Mb(t)(i.time)(e.totalDuration);return()=>(o(),Yn(t)("time")(u=>pb(pi(li("Fixed",hi(0)(20)(2)))(i.time)+" / "+pi(li("Fixed",hi(0)(20)(2)))(e.totalDuration))(u))(),Yn(t)("play")(u=>_n("data-mg-playing")(i.playing?"1":"0")(u))())})()}},Ob=t=>e=>n=>{const r=o_(n);return()=>{const i=r(),o=u_(n)(),u=Jp(t0)(up)(n)(s_(i)(o)(n));if(u.tag==="Left")return Gt("Left","precompute failed");if(u.tag==="Right")return Gt("Right",{schedule:u._1});g()}},$b=t=>e=>{if(e.tag==="FixedSize"){const n=e._1<=0||e._2<=0?J:T("Just",e._1/e._2);return()=>n}if(e.tag==="AutoSize"){const n=$a(t);return()=>{const r=n();return r.width<=0||r.height<=0?J:T("Just",r.width/r.height)}}g()},Gu=t=>e=>n=>r=>i=>o=>u=>s=>a=>c=>f=>()=>{const d=td(),l=c.value;c.value=d;const _=l===0?0:d-l,h=(()=>{if(n.tag==="FixedSize")return{w:n._1,h:n._2};if(n.tag==="AutoSize"){const b=$a(t)();return{w:b.width<=0?480:b.width,h:b.height<=0?320:b.height}}g()})();if(h.w<480||h.h<320)return bb(t)(h.w)(h.h)(480)(320)();const p=wp({widthPx:h.w,heightPx:h.h})(u),m=sm(p)(K1(f)(p.totalDuration)),y=o?m:{...m,levels:H(b=>({...b,state:{...b.state,frameTitle:""}}))(m.levels)},x=a.value,N=(()=>{if(x.tag==="Nothing")return y.camera;if(x.tag==="Just")return Yh(u.cameraConfig.cameraDecay)(_)(x._1)(y.camera);g()})();a.value=T("Just",N);const v={...y,camera:N,levels:H(Z1(N))(y.levels)};if(zb(t)(h)(v)(),e==="CanvasRenderer"){const b=wb(t),k=$i({padding:8,outputAspect:J})(v),E=(()=>{if(n.tag==="FixedSize")return{w:n._1,h:n._2};if(n.tag==="AutoSize"){const P=$a(t)();return{w:P.width,h:P.height<=0?k.vw<=0?P.width:P.width*k.vh/k.vw:P.height}}g()})(),A=vb(),$=E.w*A,tt=E.h*A,S=fl(b)(),C=_l(b)(),V=dl(b)($);S!==$&&V();const U=ll(b)(tt);C!==tt&&U(),n.tag==="FixedSize"?(U1(t,"width",ue(xe(xr(E.w)))+"px"),U1(t,"height",ue(xe(xr(E.h)))+"px")):n.tag==="AutoSize"||g();const M=gl(b)();jn(M)(),uo(M)({scaleX:A,scaleY:A})();const W=s.value,B=NT(r)(i)(M)({width:E.w,height:E.h})(v)(_)(W)();return s.value=B,Zn(M)()}if(e==="SvgRenderer"){const b=s.value,k=$b(t)(n)(),E=MT(k)(r)(i)(v)(_)(b);return s.value=E.springs,_n("viewBox")(E.parts.viewBox)(t)(),_n("preserveAspectRatio")("xMidYMid meet")(t)(),n.tag==="FixedSize"?(_n("width")(ue(xe(xr(n._1))))(t)(),_n("height")(ue(xe(xr(n._2))))(t)()):n.tag==="AutoSize"||g(),Xa(E.parts.body,t)}g()},Xb=t=>e=>n=>r=>i=>o=>u=>()=>{let s=1,a=!0,c=!1,f=0,d=0;const l={value:D},_={value:J},h={value:0};let p=!1,m=()=>{},y=[];Gu(t)(n)(r)(i)(o)(u)(e)(l)(_)(h)(0)();const x=A=>()=>{const $=y,tt=a,S={time:A,keyframe:Va(e)(A),playing:tt};return Ib(C=>C(S))($)()},N=()=>(a=!1,x(f)()),v=()=>{if(!p&&(c=!1,a)){const A=td(),$=d;d=A;const tt=s,S=f,C=Ab($===0?S+0*tt:S+(A-$)*tt)(e.totalDuration+.8);return C<S&&(_.value=J),f=C,Gu(t)(n)(r)(i)(o)(u)(e)(l)(_)(h)(C)(),x(C)(),b()}},b=()=>{if(!p&&!c){c=!0;const A=Y1();V1(v)(A)()}},k=()=>(d=0,a=!0,b()),E=()=>(a||k(),x(f)());return m=Tb(t)(()=>{if(!p){const A=f;return Gu(t)(n)(r)(i)(o)(u)(e)(l)(_)(h)(A)(),x(A)()}})(),k(),{play:E,pause:N,toggle:()=>a?N():E(),seek:A=>{const $=Gb(0)(K1(e.totalDuration)(A));return()=>(f=$,d=0,_.value=J,Gu(t)(n)(r)(i)(o)(u)(e)(l)(_)(h)($)(),x($)())},setSpeed:A=>()=>s=A,currentTime:()=>f,currentKeyframe:()=>{const A=f;return Va(e)(A)},isPlaying:()=>a,duration:e.totalDuration,subscribe:A=>()=>{y=Dt(y)(A);const $=f,tt=a;A({time:$,keyframe:Va(e)($),playing:tt})();const S=gc(C=>!kb(C)(A));return()=>{y=S(y)}},destroy:()=>(p=!0,m())}},nd=t=>e=>{const n=ed(e);if(n.tag==="Left")return yc("[markgraf] parse failed: "+n._1);if(n.tag==="Right"){const r=n._1,i=Qb(t);return()=>{const o=i(),u=Db(t)();return Xa(Fb,t),Yn(t)("stage")(s=>{const a=Ob()(j1)(r);return()=>{const c=Y1();V1(()=>{const f=a();if(f.tag==="Left")return yc("[markgraf] precompute failed")();if(f.tag==="Right"){const d=Xb(s)(f._1.schedule)(Pb)(j1)(u)(LT)(o)();return Hb(t)(f._1.schedule)(d)()}g()})(c)()}})()}}g()},Yb=t=>{const e=t.getAttribute("data-markgraf-src-b64");if(e)try{return decodeURIComponent(escape(atob(e)))}catch{return atob(e)}return t.getAttribute("data-markgraf-src")||t.textContent||""};let Pn=null;const Pu=t=>t.querySelector('[data-mg="play"]')?.dataset.mgPlaying==="1",Vb=t=>{const e=t.querySelector('[data-mg="play"]');if(!e)return;e.addEventListener("click",()=>{queueMicrotask(()=>{Pu(t)?(Pn&&Pn!==t&&Pu(Pn)&&Pn.querySelector('[data-mg="play"]').click(),Pn=t):Pn===t&&(Pn=null)})});const n=r=>{r.preventDefault(),e.click()};t.querySelector('[data-mg="stage"]')?.addEventListener("click",n)},Ub=t=>{if(t.dataset.markgrafMounted==="1")return;t.dataset.markgrafMounted="1";const e=Yb(t),n=t.dataset.markgrafPaused==="true";t.textContent="",nd(t)(e)(),n?Pu(t)&&t.querySelector('[data-mg="play"]').click():Pn===null?Pn=t:Pu(t)&&t.querySelector('[data-mg="play"]').click(),Vb(t)},Au=(t=document)=>{t.querySelectorAll("[data-markgraf]").forEach(Ub)},rd=()=>{document.addEventListener("keydown",t=>{if(t.code!=="Space"&&t.key!==" ")return;const e=t.target,n=e&&e.closest?.("[data-markgraf]");if(!n){const i=e?.tagName,o=(e?.type||"").toLowerCase();if(e?.isContentEditable||i==="TEXTAREA"||i==="SELECT"||i==="INPUT"&&!["range","checkbox","radio","button","submit","reset"].includes(o))return}const r=n||Pn||document.querySelector("[data-markgraf]");r&&(t.preventDefault(),r.querySelector('[data-mg="play"]')?.click())})};if(typeof window<"u"){const t=e=>{const n=Wb(e);return n==null?{ok:!0}:{ok:!1,error:n}};window.markgraf={mount:(e,n)=>nd(e)(n)(),mountAll:Au,tryParse:t},document.readyState==="loading"?document.addEventListener("DOMContentLoaded",()=>{Au(),rd()}):(Au(),rd())}return Iu.mountAll=Au,Object.defineProperty(Iu,Symbol.toStringTag,{value:"Module"}),Iu})({});