@tscircuit/runframe 0.0.1637 → 0.0.1639
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.
|
@@ -5133,7 +5133,7 @@ ${a.join(`
|
|
|
5133
5133
|
${Q}polygon: ${C.polygon.vertices}
|
|
5134
5134
|
`:a+=`
|
|
5135
5135
|
`,C.children.length>0&&c.push(C.children)}return a}};A.exports=s}}),jue=ot({"node_modules/@jscad/modeling/src/operations/booleans/trees/Tree.js"(e,A){var t=Oue(),i=Vue(),n=class{constructor(o){this.polygonTree=new i,this.rootnode=new t(null),o&&this.addPolygons(o)}invert(){this.polygonTree.invert(),this.rootnode.invert()}clipTo(o,s=!1){this.rootnode.clipTo(o,s)}allPolygons(){const o=[];return this.polygonTree.getPolygons(o),o}addPolygons(o){const s=new Array(o.length);for(let r=0;r<o.length;r++)s[r]=this.polygonTree.addChild(o[r]);this.rootnode.addPolygonTreeNodes(s)}clear(){this.polygonTree.clear()}toString(){return"Tree: "+this.polygonTree.toString("")}};A.exports=n}}),$QA=ot({"node_modules/@jscad/modeling/src/operations/booleans/trees/index.js"(e,A){A.exports={Tree:jue()}}}),zue=ot({"node_modules/@jscad/modeling/src/operations/booleans/intersectGeom3Sub.js"(e,A){var t=Vo(),i=XQA(),{Tree:n}=$QA(),o=(s,r)=>{if(!i(s,r))return t.create();const a=new n(t.toPolygons(s)),g=new n(t.toPolygons(r));a.invert(),g.clipTo(a),g.invert(),a.clipTo(g),g.clipTo(a),a.addPolygons(g.allPolygons()),a.invert();const c=a.allPolygons();return t.create(c)};A.exports=o}}),dzA=ot({"node_modules/@jscad/modeling/src/operations/booleans/intersectGeom3.js"(e,A){var t=Ro(),i=iH(),n=zue(),o=(...s)=>{s=t(s);let r=s.shift();return s.forEach(a=>{r=n(r,a)}),r=i(r),r};A.exports=o}}),Xue=ot({"node_modules/@jscad/modeling/src/operations/booleans/intersectGeom2.js"(e,A){var t=Ro(),i=Vo(),n=u_(),o=jQA(),s=zQA(),r=dzA(),a=(...g)=>{g=t(g);const c=g.map(B=>s({z0:-1,z1:1},B)),I=r(c),l=n(I);return o(l,i.toPolygons(I))};A.exports=a}}),$ue=ot({"node_modules/@jscad/modeling/src/operations/booleans/intersect.js"(e,A){var t=Ro(),i=eH(),n=Zo(),o=Vo(),s=Xue(),r=dzA(),a=(...g)=>{if(g=t(g),g.length===0)throw new Error("wrong number of arguments");if(!i(g))throw new Error("only intersect of the types are supported");const c=g[0];return n.isA(c)?s(g):o.isA(c)?r(g):c};A.exports=a}}),Ade=ot({"node_modules/@jscad/modeling/src/operations/booleans/scissionGeom3.js"(e,A){var t=mn(),i=u_(),n=Vo(),o=g=>g.sort((c,I)=>c-I).filter((c,I,l)=>!I||c!==l[I-1]),s=(g,c,I)=>{const l=`${c}`,B=g.get(l);B===void 0?g.set(l,[I]):B.push(I)},r=(g,c)=>{const I=`${c}`;return g.get(I)},a=g=>{const c=i(g),I=n.toPolygons(g),l=I.length,B=new Map,C=t.create();I.forEach((d,f)=>{d.vertices.forEach(m=>{s(B,t.snap(C,m,c),f)})});const Q=I.map(d=>{let f=[];return d.vertices.forEach(m=>{f=f.concat(r(B,t.snap(C,m,c)))}),{e:1,d:o(f)}});B.clear();let E=0;const h=Q.length;for(let d=0;d<h;d++){const f=Q[d];if(f.e>0){const m=new Array(l);m[d]=!0;do E=0,m.forEach((w,D)=>{const b=Q[D];if(b.e>0){b.e=-1;for(let k=0;k<b.d.length;k++)m[b.d[k]]=!0;E++}});while(E>0);f.indexes=m}}const u=[];for(let d=0;d<h;d++)if(Q[d].indexes){const f=[];Q[d].indexes.forEach((m,w)=>f.push(I[w])),u.push(n.create(f))}return u};A.exports=a}}),tde=ot({"node_modules/@jscad/modeling/src/operations/booleans/scission.js"(e,A){var t=Ro(),i=Vo(),n=Ade(),o=(...s)=>{if(s=t(s),s.length===0)throw new Error("wrong number of arguments");const r=s.map(a=>i.isA(a)?n(a):a);return r.length===1?r[0]:r};A.exports=o}}),ede=ot({"node_modules/@jscad/modeling/src/operations/booleans/subtractGeom3Sub.js"(e,A){var t=Vo(),i=XQA(),{Tree:n}=$QA(),o=(s,r)=>{if(!i(s,r))return t.clone(s);const a=new n(t.toPolygons(s)),g=new n(t.toPolygons(r));a.invert(),a.clipTo(g),g.clipTo(a,!0),a.addPolygons(g.allPolygons()),a.invert();const c=a.allPolygons();return t.create(c)};A.exports=o}}),pzA=ot({"node_modules/@jscad/modeling/src/operations/booleans/subtractGeom3.js"(e,A){var t=Ro(),i=iH(),n=ede(),o=(...s)=>{s=t(s);let r=s.shift();return s.forEach(a=>{r=n(r,a)}),r=i(r),r};A.exports=o}}),ide=ot({"node_modules/@jscad/modeling/src/operations/booleans/subtractGeom2.js"(e,A){var t=Ro(),i=Vo(),n=u_(),o=jQA(),s=zQA(),r=pzA(),a=(...g)=>{g=t(g);const c=g.map(B=>s({z0:-1,z1:1},B)),I=r(c),l=n(I);return o(l,i.toPolygons(I))};A.exports=a}}),nde=ot({"node_modules/@jscad/modeling/src/operations/booleans/subtract.js"(e,A){var t=Ro(),i=eH(),n=Zo(),o=Vo(),s=ide(),r=pzA(),a=(...g)=>{if(g=t(g),g.length===0)throw new Error("wrong number of arguments");if(!i(g))throw new Error("only subtract of the types are supported");const c=g[0];return n.isA(c)?s(g):o.isA(c)?r(g):c};A.exports=a}}),fzA=ot({"node_modules/@jscad/modeling/src/operations/booleans/unionGeom3Sub.js"(e,A){var t=Vo(),i=XQA(),{Tree:n}=$QA(),o=(r,a)=>{if(!i(r,a))return s(r,a);const g=new n(t.toPolygons(r)),c=new n(t.toPolygons(a));g.clipTo(c,!1),c.clipTo(g),c.invert(),c.clipTo(g),c.invert();const I=g.allPolygons().concat(c.allPolygons());return t.create(I)},s=(r,a)=>{let g=t.toPolygons(r);return g=g.concat(t.toPolygons(a)),t.create(g)};A.exports=o}}),yzA=ot({"node_modules/@jscad/modeling/src/operations/booleans/unionGeom3.js"(e,A){var t=Ro(),i=iH(),n=fzA(),o=(...s)=>{s=t(s);let r;for(r=1;r<s.length;r+=2)s.push(n(s[r-1],s[r]));let a=s[r-1];return a=i(a),a};A.exports=o}}),mzA=ot({"node_modules/@jscad/modeling/src/operations/booleans/unionGeom2.js"(e,A){var t=Ro(),i=Vo(),n=u_(),o=jQA(),s=zQA(),r=yzA(),a=(...g)=>{g=t(g);const c=g.map(B=>s({z0:-1,z1:1},B)),I=r(c),l=n(I);return o(l,i.toPolygons(I))};A.exports=a}}),AEA=ot({"node_modules/@jscad/modeling/src/operations/booleans/union.js"(e,A){var t=Ro(),i=eH(),n=Zo(),o=Vo(),s=mzA(),r=yzA(),a=(...g)=>{if(g=t(g),g.length===0)throw new Error("wrong number of arguments");if(!i(g))throw new Error("only unions of the same type are supported");const c=g[0];return n.isA(c)?s(g):o.isA(c)?r(g):c};A.exports=a}}),VN=ot({"node_modules/@jscad/modeling/src/operations/booleans/index.js"(e,A){A.exports={intersect:$ue(),scission:tde(),subtract:nde(),union:AEA()}}}),$8=ot({"node_modules/@jscad/modeling/src/operations/expansions/offsetFromPoints.js"(e,A){var{EPS:t,TAU:i}=dr(),n=XjA(),o=PQA(),s=ds(),r=j8(),a=(g,c)=>{const I={delta:1,corners:"edge",closed:!1,segments:16};let{delta:l,corners:B,closed:C,segments:Q}=Object.assign({},I,g);if(Math.abs(l)<t)return c;let E=g.closed?r(c):1;E===0&&(E=1);const h=E>0&&l>=0||E<0&&l<0;l=Math.abs(l);let u=null,d=[];const f=[],m=s.create(),w=c.length;for(let D=0;D<w;D++){const b=(D+1)%w,k=c[D],x=c[b];h?s.subtract(m,k,x):s.subtract(m,x,k),s.normal(m,m),s.normalize(m,m),s.scale(m,m,l);const N=s.add(s.create(),k,m),R=s.add(s.create(),x,m),U=[N,R];if(u!=null&&(C||!C&&b!==0)){const T=n(u[0],u[1],U[0],U[1]);T?(d.pop(),U[0]=T):f.push({c:k,s0:u,s1:U})}u=[N,R],!(b===0&&!C)&&(d.push(U[0]),d.push(U[1]))}if(C&&u!=null){const D=d[0],b=d[1],k=n(u[0],u[1],D,b);if(k)d[0]=k,d.pop();else{const x=c[0],N=[D,b];f.push({c:x,s0:u,s1:N})}}if(B==="edge"){const D=new Map;d.forEach((x,N)=>D.set(x,N));const b=o.create(),k=o.create();f.forEach(x=>{o.fromPoints(b,x.s0[0],x.s0[1]),o.fromPoints(k,x.s1[0],x.s1[1]);const N=o.intersectPointOfLines(b,k);if(Number.isFinite(N[0])&&Number.isFinite(N[1])){const R=x.s0[1],U=D.get(R);d[U]=N,d[(U+1)%d.length]=void 0}else{const R=x.s1[0],U=D.get(R);d[U]=void 0}}),d=d.filter(x=>x!==void 0)}if(B==="round"){let D=Math.floor(Q/4);const b=s.create();f.forEach(k=>{let x=s.angle(s.subtract(b,k.s1[0],k.c));if(x-=s.angle(s.subtract(b,k.s0[1],k.c)),h&&x<0&&(x=x+Math.PI,x<0&&(x=x+Math.PI)),!h&&x>0&&(x=x-Math.PI,x>0&&(x=x-Math.PI)),x!==0){D=Math.floor(Q*(Math.abs(x)/i));const N=x/D,R=s.angle(s.subtract(b,k.s0[1],k.c)),U=[];for(let T=1;T<D;T++){const Y=R+N*T,O=s.fromAngleRadians(s.create(),Y);s.scale(O,O,l),s.add(O,O,k.c),U.push(O)}if(U.length>0){const T=k.s0[1];let Y=d.findIndex(O=>s.equals(T,O));Y=(Y+1)%d.length,d.splice(Y,0,...U)}}else{const N=k.s1[0],R=d.findIndex(U=>s.equals(N,U));d.splice(R,1)}})}return d};A.exports=a}}),ode=ot({"node_modules/@jscad/modeling/src/operations/expansions/expandGeom2.js"(e,A){var t=Zo(),i=$8(),n=(o,s)=>{const r={delta:1,corners:"edge",segments:16},{delta:a,corners:g,segments:c}=Object.assign({},r,o);if(!(g==="edge"||g==="chamfer"||g==="round"))throw new Error('corners must be "edge", "chamfer", or "round"');const B=t.toOutlines(s).map(C=>(o={delta:a,corners:g,closed:!0,segments:c},i(o,C))).reduce((C,Q)=>C.concat(t.toSides(t.fromPoints(Q))),[]);return t.create(B)};A.exports=n}}),sde=ot({"node_modules/@jscad/modeling/src/operations/expansions/extrudePolygon.js"(e,A){var t=Kg(),i=mn(),n=Vo(),o=or(),s=(r,a)=>{i.dot(o.plane(a),r)>0&&(a=o.invert(a));const c=[a],I=o.transform(t.fromTranslation(t.create(),r),a),l=a.vertices.length;for(let B=0;B<l;B++){const C=B<l-1?B+1:0,Q=o.create([a.vertices[B],I.vertices[B],I.vertices[C],a.vertices[C]]);c.push(Q)}return c.push(o.invert(I)),n.create(c)};A.exports=s}}),rde=ot({"node_modules/@jscad/modeling/src/operations/expansions/expandShell.js"(e,A){var{EPS:t,TAU:i}=dr(),n=Kg(),o=mn(),s=hzA(),r=Vo(),a=or(),g=czA(),c=iH(),I=fzA(),l=sde(),B=(h,u,d)=>{const f=u.toString();if(h.has(f))h.get(f)[1].push(d);else{const m=[u,[d]];h.set(f,m)}},C=(h,u,d)=>{const f=u[0].toString(),m=u[1].toString(),w=f<m?`${f},${m}`:`${m},${f}`;if(h.has(w))h.get(w)[1].push(d);else{const D=[u,[d]];h.set(w,D)}},Q=(h,u)=>{h.findIndex(f=>f===u)<0&&h.push(u)},E=(h,u)=>{const d={delta:1,segments:12},{delta:f,segments:m}=Object.assign({},d,h);let w=r.create();const D=new Map,b=new Map,k=o.create(),x=o.create();return r.toPolygons(u).forEach((R,U)=>{const T=o.scale(o.create(),a.plane(R),2*f),Y=a.transform(n.fromTranslation(n.create(),o.scale(o.create(),T,-.5)),R),O=l(T,Y);w=I(w,O);const W=R.vertices;for(let X=0;X<W.length;X++){B(D,W[X],a.plane(R));const iA=(X+1)%W.length,aA=[W[X],W[iA]];C(b,aA,a.plane(R))}}),b.forEach(R=>{const U=R[0],T=R[1],Y=U[0],O=U[1],W=o.subtract(o.create(),O,Y);o.normalize(W,W);const X=T[0],iA=o.cross(o.create(),X,W);let aA=[];for(let TA=0;TA<m;TA++)Q(aA,TA*i/m);for(let TA=0,hA=T.length;TA<hA;TA++){const kA=T[TA],dA=o.dot(iA,kA),qA=o.dot(X,kA);let ZA=Math.atan2(dA,qA);ZA<0&&(ZA+=i),Q(aA,ZA),ZA=Math.atan2(-dA,-qA),ZA<0&&(ZA+=i),Q(aA,ZA)}aA=aA.sort(s);const tA=aA.length;let oA,rA;const CA=[],SA=[],MA=[];for(let TA=-1;TA<tA;TA++){const hA=aA[TA<0?TA+tA:TA],kA=Math.sin(hA),dA=Math.cos(hA);o.scale(k,X,dA*f),o.scale(x,iA,kA*f),o.add(k,k,x);const qA=o.add(o.create(),Y,k),ZA=o.add(o.create(),O,k);let rt=!1;if(TA>=0&&o.distance(qA,oA)<t&&(rt=!0),!rt){if(TA>=0){CA.push(qA),SA.push(ZA);const yA=[rA,ZA,qA,oA],$A=a.create(yA);MA.push($A)}oA=qA,rA=ZA}}SA.reverse(),MA.push(a.create(CA)),MA.push(a.create(SA));const GA=r.create(MA);w=I(w,GA)}),D.forEach(R=>{const U=R[0],T=R[1],Y=T[0];let O=null,W=0;for(let tA=1;tA<T.length;tA++){const oA=T[tA],rA=o.cross(k,Y,oA),CA=o.length(rA);CA>.05&&CA>W&&(W=CA,O=oA)}O||(O=o.orthogonal(k,Y));const X=o.cross(k,Y,O);o.normalize(X,X);const iA=o.cross(x,X,Y),aA=g({center:[U[0],U[1],U[2]],radius:f,segments:m,axes:[Y,X,iA]});w=I(w,aA)}),c(w)};A.exports=E}}),ade=ot({"node_modules/@jscad/modeling/src/operations/expansions/expandGeom3.js"(e,A){var t=Vo(),i=AEA(),n=rde(),o=(s,r)=>{const a={delta:1,corners:"round",segments:12},{delta:g,corners:c,segments:I}=Object.assign({},a,s);if(c!=="round")throw new Error('corners must be "round" for 3D geometries');if(t.toPolygons(r).length===0)throw new Error("the given geometry cannot be empty");s={delta:g,corners:c,segments:I};const B=n(s,r);return i(r,B)};A.exports=o}}),gde=ot({"node_modules/@jscad/modeling/src/operations/expansions/expandPath2.js"(e,A){var t=j8(),i=ds(),n=Zo(),o=wg(),s=$8(),r=c=>{let{external:I,internal:l}=c;t(I)<0?I=I.reverse():l=l.reverse();const B=o.fromPoints({closed:!0},I),C=o.fromPoints({closed:!0},l),Q=n.toSides(n.fromPoints(o.toPoints(B))),E=n.toSides(n.fromPoints(o.toPoints(C)));return Q.push(...E),n.create(Q)},a=(c,I,l,B)=>{const{points:C,external:Q,internal:E}=c,h=Math.floor(I/2),u=[],d=[];if(l==="round"&&h>0){const m=Math.PI/h,w=C[C.length-1],D=i.angle(i.subtract(i.create(),Q[Q.length-1],w)),b=C[0],k=i.angle(i.subtract(i.create(),E[0],b));for(let x=1;x<h;x++){let N=D+m*x,R=i.fromAngleRadians(i.create(),N);i.scale(R,R,B),i.add(R,R,w),u.push(R),N=k+m*x,R=i.fromAngleRadians(i.create(),N),i.scale(R,R,B),i.add(R,R,b),d.push(R)}}const f=[];return f.push(...Q,...u,...E.reverse(),...d),n.fromPoints(f)},g=(c,I)=>{c=Object.assign({},{delta:1,corners:"edge",segments:16},c);const{delta:B,corners:C,segments:Q}=c;if(B<=0)throw new Error("the given delta must be positive for paths");if(!(C==="edge"||C==="chamfer"||C==="round"))throw new Error('corners must be "edge", "chamfer", or "round"');const E=I.isClosed,h=o.toPoints(I);if(h.length===0)throw new Error("the given geometry cannot be empty");const u={points:h,external:s({delta:B,corners:C,segments:Q,closed:E},h),internal:s({delta:-B,corners:C,segments:Q,closed:E},h)};return I.isClosed?r(u):a(u,Q,C,B)};A.exports=g}}),tEA=ot({"node_modules/@jscad/modeling/src/operations/expansions/expand.js"(e,A){var t=Ro(),i=Zo(),n=Vo(),o=wg(),s=ode(),r=ade(),a=gde(),g=(c,...I)=>{if(I=t(I),I.length===0)throw new Error("wrong number of arguments");const l=I.map(B=>o.isA(B)?a(c,B):i.isA(B)?s(c,B):n.isA(B)?r(c,B):B);return l.length===1?l[0]:l};A.exports=g}}),cde=ot({"node_modules/@jscad/modeling/src/operations/expansions/offsetGeom2.js"(e,A){var t=Zo(),i=HQA(),n=$8(),o=(s,r)=>{const a={delta:1,corners:"edge",segments:0},{delta:g,corners:c,segments:I}=Object.assign({},a,s);if(!(c==="edge"||c==="chamfer"||c==="round"))throw new Error('corners must be "edge", "chamfer", or "round"');const l=t.toOutlines(r),C=l.map(Q=>(s={delta:l.reduce((u,d)=>u+i.arePointsInside(Q,i.create(d)),0)%2===0?g:-g,corners:c,closed:!0,segments:I},n(s,Q))).reduce((Q,E)=>Q.concat(t.toSides(t.fromPoints(E))),[]);return t.create(C)};A.exports=o}}),Ide=ot({"node_modules/@jscad/modeling/src/operations/expansions/offsetPath2.js"(e,A){var t=wg(),i=$8(),n=(o,s)=>{const r={delta:1,corners:"edge",closed:s.isClosed,segments:16},{delta:a,corners:g,closed:c,segments:I}=Object.assign({},r,o);if(!(g==="edge"||g==="chamfer"||g==="round"))throw new Error('corners must be "edge", "chamfer", or "round"');o={delta:a,corners:g,closed:c,segments:I};const l=i(o,t.toPoints(s));return t.fromPoints({closed:c},l)};A.exports=n}}),lde=ot({"node_modules/@jscad/modeling/src/operations/expansions/offset.js"(e,A){var t=Ro(),i=Zo(),n=wg(),o=cde(),s=Ide(),r=(a,...g)=>{if(g=t(g),g.length===0)throw new Error("wrong number of arguments");const c=g.map(I=>n.isA(I)?s(a,I):i.isA(I)?o(a,I):I);return c.length===1?c[0]:c};A.exports=r}}),wzA=ot({"node_modules/@jscad/modeling/src/operations/expansions/index.js"(e,A){A.exports={expand:tEA(),offset:lde()}}}),AW=ot({"node_modules/@jscad/modeling/src/operations/extrusions/extrudeLinearGeom2.js"(e,A){var t=Kg(),i=mn(),n=Zo(),o=ZN(),s=X8(),r=(a,g)=>{const c={offset:[0,0,1],twistAngle:0,twistSteps:12,repair:!0};let{offset:I,twistAngle:l,twistSteps:B,repair:C}=Object.assign({},c,a);if(B<1)throw new Error("twistSteps must be 1 or more");l===0&&(B=1);const Q=i.clone(I),E=n.toSides(g);if(E.length===0)throw new Error("the given geometry cannot be empty");const h=o.fromSides(E);Q[2]<0&&o.reverse(h,h);const u=t.create(),d=(f,m,w)=>{const D=m/B*l,b=i.scale(i.create(),Q,m/B);return t.multiply(u,t.fromZRotation(u,D),t.fromTranslation(t.create(),b)),o.transform(u,w)};return a={numberOfSlices:B+1,capStart:!0,capEnd:!0,repair:C,callback:d},s(a,h)};A.exports=r}}),Bde=ot({"node_modules/@jscad/modeling/src/operations/extrusions/extrudeLinearPath2.js"(e,A){var t=Zo(),i=wg(),n=AW(),o=(s,r)=>{if(!r.isClosed)throw new Error("extruded path must be closed");const a=i.toPoints(r),g=t.fromPoints(a);return n(s,g)};A.exports=o}}),Cde=ot({"node_modules/@jscad/modeling/src/operations/extrusions/extrudeLinear.js"(e,A){var t=Ro(),i=Zo(),n=wg(),o=AW(),s=Bde(),r=(a,...g)=>{const c={height:1,twistAngle:0,twistSteps:1,repair:!0},{height:I,twistAngle:l,twistSteps:B,repair:C}=Object.assign({},c,a);if(g=t(g),g.length===0)throw new Error("wrong number of arguments");a={offset:[0,0,I],twistAngle:l,twistSteps:B,repair:C};const Q=g.map(E=>n.isA(E)?s(a,E):i.isA(E)?o(a,E):E);return Q.length===1?Q[0]:Q};A.exports=r}}),Qde=ot({"node_modules/@jscad/modeling/src/operations/extrusions/extrudeRectangularPath2.js"(e,A){var t=wg(),i=tEA(),n=AW(),o=(s,r)=>{const a={size:1,height:1},{size:g,height:c}=Object.assign({},a,s);if(s.delta=g,s.offset=[0,0,c],t.toPoints(r).length===0)throw new Error("the given geometry cannot be empty");const l=i(s,r);return n(s,l)};A.exports=o}}),Ede=ot({"node_modules/@jscad/modeling/src/operations/extrusions/extrudeRectangularGeom2.js"(e,A){var{area:t}=XU(),i=Zo(),n=wg(),o=tEA(),s=AW(),r=(a,g)=>{const c={size:1,height:1},{size:I,height:l}=Object.assign({},c,a);a.delta=I,a.offset=[0,0,l];const B=i.toOutlines(g);if(B.length===0)throw new Error("the given geometry cannot be empty");const Q=B.map(h=>(t(h)<0&&h.reverse(),o(a,n.fromPoints({closed:!0},h)))).reduce((h,u)=>h.concat(i.toSides(u)),[]),E=i.create(Q);return s(a,E)};A.exports=r}}),hde=ot({"node_modules/@jscad/modeling/src/operations/extrusions/extrudeRectangular.js"(e,A){var t=Ro(),i=Zo(),n=wg(),o=Qde(),s=Ede(),r=(a,...g)=>{const c={size:1,height:1},{size:I,height:l}=Object.assign({},c,a);if(g=t(g),g.length===0)throw new Error("wrong number of arguments");if(I<=0)throw new Error("size must be positive");if(l<=0)throw new Error("height must be positive");const B=g.map(C=>n.isA(C)?o(a,C):i.isA(C)?s(a,C):C);return B.length===1?B[0]:B};A.exports=r}}),ude=ot({"node_modules/@jscad/modeling/src/operations/extrusions/extrudeHelical.js"(e,A){var{TAU:t}=dr(),i=Kg(),n=Zo(),o=X8(),s=ZN(),r=(a,g)=>{const c={angle:t,startAngle:0,pitch:10,height:0,endOffset:0,segmentsPerRotation:32};let{angle:I,startAngle:l,pitch:B,height:C,endOffset:Q,segmentsPerRotation:E}=Object.assign({},c,a);if(C!=0&&(B=C/(I/t)),E<3)throw new Error("The number of segments per rotation needs to be at least 3.");const u=n.toSides(g);if(u.length===0)throw new Error("The given geometry cannot be empty");const d=u.filter(x=>x[0][0]>=0);let f=s.fromSides(u);d.length===0&&(f=s.reverse(f));const m=Math.round(E/t*Math.abs(I)),w=m>=2?m:2,D=i.create(),b=i.create(),k=(x,N,R)=>{const U=l+I/w*N,T=Q/w*N,Y=(U-l)/t*B;return i.multiply(D,i.fromTranslation(i.create(),[T,0,Y*Math.sign(I)]),i.fromXRotation(i.create(),-t/4*Math.sign(I))),i.multiply(b,i.fromZRotation(i.create(),U),D),s.transform(b,R)};return o({numberOfSlices:w+1,callback:k},f)};A.exports=r}}),dde=ot({"node_modules/@jscad/modeling/src/operations/extrusions/project.js"(e,A){var t=Ro(),i=KQA(),n=sD(),o=Kg(),s=Zo(),r=Vo(),a=or(),g=u_(),c=mzA(),I=(B,C)=>{const Q=n.fromNormalAndPoint(n.create(),B.axis,B.origin);if(Number.isNaN(Q[0])||Number.isNaN(Q[1])||Number.isNaN(Q[2])||Number.isNaN(Q[3]))throw new Error("project: invalid axis or origin");const E=g(C),h=E*E*Math.sqrt(3)/4;if(E===0)return s.create();const u=r.toPolygons(C);let d=[];for(let m=0;m<u.length;m++){const w=u[m].vertices.map(k=>n.projectionOfPoint(Q,k)),D=a.create(w),b=a.plane(D);i(Q,b)&&(a.measureArea(D)<h||d.push(D))}if(!i(Q,[0,0,1])){const m=o.fromVectorRotation(o.create(),Q,[0,0,1]);d=d.map(w=>a.transform(m,w))}d=d.sort((m,w)=>a.measureArea(w)-a.measureArea(m));const f=d.map(m=>s.fromPoints(m.vertices));return c(f)},l=(B,...C)=>{const Q={axis:[0,0,1],origin:[0,0,0]},{axis:E,origin:h}=Object.assign({},Q,B);if(C=t(C),C.length===0)throw new Error("wrong number of arguments");B={axis:E,origin:h};const u=C.map(d=>r.isA(d)?I(B,d):d);return u.length===1?u[0]:u};A.exports=l}}),nH=ot({"node_modules/@jscad/modeling/src/operations/extrusions/index.js"(e,A){A.exports={extrudeFromSlices:X8(),extrudeLinear:Cde(),extrudeRectangular:hde(),extrudeRotate:CzA(),extrudeHelical:ude(),project:dde(),slice:ZN()}}}),eEA=ot({"node_modules/@jscad/modeling/src/operations/hulls/hullPoints2.js"(e,A){var t=ds(),i=s=>{let r=t.fromValues(1/0,1/0);s.forEach(c=>{(c[1]<r[1]||c[1]===r[1]&&c[0]<r[0])&&(r=c)});const a=[];s.forEach(c=>{const I=o(c[1]-r[1],c[0]-r[0]),l=t.squaredDistance(c,r);a.push({point:c,angle:I,distSq:l})}),a.sort((c,I)=>c.angle!==I.angle?c.angle-I.angle:c.distSq-I.distSq);const g=[];return a.forEach(c=>{let I=g.length;for(;I>1&&n(g[I-2],g[I-1],c.point)<=Number.EPSILON;)g.pop(),I=g.length;g.push(c.point)}),g},n=(s,r,a)=>(r[0]-s[0])*(a[1]-s[1])-(r[1]-s[1])*(a[0]-s[0]),o=(s,r)=>s===0&&r===0?-1/0:-r/s;A.exports=i}}),iEA=ot({"node_modules/@jscad/modeling/src/operations/hulls/toUniquePoints.js"(e,A){var t=Zo(),i=Vo(),n=wg(),o=s=>{const r=new Set,a=[],g=c=>{const I=c.toString();r.has(I)||(a.push(c),r.add(I))};return s.forEach(c=>{t.isA(c)?t.toPoints(c).forEach(g):i.isA(c)?i.toPoints(c).forEach(I=>I.forEach(g)):n.isA(c)&&n.toPoints(c).forEach(g)}),a};A.exports=o}}),pde=ot({"node_modules/@jscad/modeling/src/operations/hulls/hullPath2.js"(e,A){var t=Ro(),i=wg(),n=eEA(),o=iEA(),s=(...r)=>{r=t(r);const a=o(r),g=n(a);return i.fromPoints({closed:!0},g)};A.exports=s}}),fde=ot({"node_modules/@jscad/modeling/src/operations/hulls/hullGeom2.js"(e,A){var t=Ro(),i=Zo(),n=eEA(),o=iEA(),s=(...r)=>{r=t(r);const a=o(r),g=n(a);return g.length<3?i.create():i.fromPoints(g)};A.exports=s}}),DzA=ot({"node_modules/@jscad/modeling/src/operations/hulls/hullPoints3.js"(e,A){var t=or(),i=mjA(),n=o=>i(o,{skipTriangulation:!0}).map(a=>{const g=a.map(c=>o[c]);return t.create(g)});A.exports=n}}),yde=ot({"node_modules/@jscad/modeling/src/operations/hulls/hullGeom3.js"(e,A){var t=Ro(),i=Vo(),n=iEA(),o=DzA(),s=(...r)=>{r=t(r);const a=n(r);return a.length===0?i.create():i.create(o(a))};A.exports=s}}),SzA=ot({"node_modules/@jscad/modeling/src/operations/hulls/hull.js"(e,A){var t=Ro(),i=eH(),n=Zo(),o=Vo(),s=wg(),r=pde(),a=fde(),g=yde(),c=(...I)=>{if(I=t(I),I.length===0)throw new Error("wrong number of arguments");if(!i(I))throw new Error("only hulls of the same type are supported");const l=I[0];return s.isA(l)?r(I):n.isA(l)?a(I):o.isA(l)?g(I):l};A.exports=c}}),mde=ot({"node_modules/@jscad/modeling/src/operations/hulls/hullChain.js"(e,A){var t=Ro(),i=AEA(),n=SzA(),o=(...s)=>{if(s=t(s),s.length<2)throw new Error("wrong number of arguments");const r=[];for(let a=1;a<s.length;a++)r.push(n(s[a-1],s[a]));return i(r)};A.exports=o}}),wde=ot({"node_modules/@jscad/modeling/src/operations/hulls/index.js"(e,A){A.exports={hull:SzA(),hullChain:mde(),hullPoints2:eEA(),hullPoints3:DzA()}}}),bzA=ot({"node_modules/@jscad/modeling/src/operations/modifiers/snapPolygons.js"(e,A){var t=mn(),i=or(),n=(s,r)=>{const a=Math.abs(i.measureArea(r));return Number.isFinite(a)&&a>s},o=(s,r)=>{let a=r.map(c=>{const I=c.vertices.map(C=>t.snap(t.create(),C,s)),l=[];for(let C=0;C<I.length;C++){const Q=(C+1)%I.length;t.equals(I[C],I[Q])||l.push(I[C])}const B=i.create(l);return c.color&&(B.color=c.color),B});const g=s*s*Math.sqrt(3)/4;return a=a.filter(c=>n(g,c)),a};A.exports=o}}),Dde=ot({"node_modules/@jscad/modeling/src/operations/modifiers/mergePolygons.js"(e,A){var t=KQA(),i=mn(),n=or(),o=h=>{const u=n.toPoints(h),d=[];for(let f=0;f<u.length;f++){const m=(f+1)%u.length,w={v1:u[f],v2:u[m]};d.push(w)}for(let f=0;f<d.length;f++){const m=(f+1)%u.length;d[f].next=d[m],d[m].prev=d[f]}return d},s=(h,u)=>{const d=`${u.v1}:${u.v2}`;h.set(d,u)},r=(h,u)=>{const d=`${u.v1}:${u.v2}`;h.delete(d)},a=(h,u)=>{const d=`${u.v2}:${u.v1}`;return h.get(d)},g=(h,u,d)=>{let f=h.prev.v1,m=h.prev.v2,w=u.next.v2;const D=l(f,m,w,d);f=u.prev.v1,m=u.prev.v2,w=h.next.v2;const b=l(f,m,w,d);return[D,b]},c=i.create(),I=i.create(),l=(h,u,d,f)=>{const m=i.subtract(c,u,h),w=i.subtract(I,d,u);return i.cross(m,m,w),i.dot(m,f)},B=h=>{let u;const d=[];for(;h.next;){const f=h.next;d.push(h.v1),h.v1=null,h.v2=null,h.next=null,h.prev=null,h=f}return d.length>0&&(u=n.create(d)),u},C=h=>{if(h.length<2)return h;const u=h[0].plane,d=h.slice(),f=new Map;for(;d.length>0;){const w=d.shift(),D=o(w);for(let b=0;b<D.length;b++){const k=D[b],x=a(f,k);if(x){const N=g(k,x,u);if(N[0]>=0&&N[1]>=0){const R=x.next,U=k.next;k.prev.next=x.next,k.next.prev=x.prev,x.prev.next=k.next,x.next.prev=k.prev,k.v1=null,k.v2=null,k.next=null,k.prev=null,r(f,x),x.v1=null,x.v2=null,x.next=null,x.prev=null;const T=(Y,O,W)=>{const X={v1:W.v1,v2:O.v2,next:O.next,prev:W.prev};W.prev.next=X,O.next.prev=X,r(Y,O),O.v1=null,O.v2=null,O.next=null,O.prev=null,r(Y,W),W.v1=null,W.v2=null,W.next=null,W.prev=null};N[0]===0&&T(f,R,R.prev),N[1]===0&&T(f,U,U.prev)}}else k.next&&s(f,k)}}const m=[];return f.forEach(w=>{const D=B(w);D&&m.push(D)}),f.clear(),m},Q=(h,u)=>Math.abs(h[3]-u[3])<15e-8?t(h,u):!1,E=(h,u)=>{const d=[];u.forEach(m=>{const w=d.find(D=>Q(D[0],n.plane(m)));w?w[1].push(m):d.push([n.plane(m),[m]])});let f=[];return d.forEach(m=>{const w=m[1],D=C(w);f=f.concat(D)}),f};A.exports=E}}),Sde=ot({"node_modules/@jscad/modeling/src/operations/modifiers/insertTjunctions.js"(e,A){var t=dr(),i=mn(),n=or(),o=g=>`${g}`,s=(g,c,I,l,B,C)=>{const Q=o(l),E=o(B),h=`${Q}/${E}`,u=`${E}/${Q}`;if(g.has(u))return r(g,c,I,B,l,null),null;const d={vertex0:l,vertex1:B,polygonindex:C};return g.has(h)?g.get(h).push(d):g.set(h,[d]),c.has(Q)?c.get(Q).push(h):c.set(Q,[h]),I.has(E)?I.get(E).push(h):I.set(E,[h]),h},r=(g,c,I,l,B,C)=>{const Q=o(l),E=o(B),h=`${Q}/${E}`;let u=-1;const d=g.get(h);for(let f=0;f<d.length;f++){const m=d[f];let w=o(m.vertex0);if(w===Q&&(w=o(m.vertex1),w===E&&!(C!==null&&m.polygonindex!==C))){u=f;break}}d.splice(u,1),d.length===0&&g.delete(h),u=c.get(Q).indexOf(h),c.get(Q).splice(u,1),c.get(Q).length===0&&c.delete(Q),u=I.get(E).indexOf(h),I.get(E).splice(u,1),I.get(E).length===0&&I.delete(E)},a=g=>{const c=new Map;for(let I=0;I<g.length;I++){const l=g[I],B=l.vertices.length;if(B>=3){let C=l.vertices[0],Q=o(C);for(let E=0;E<B;E++){let h=E+1;h===B&&(h=0);const u=l.vertices[h],d=o(u),f=`${Q}/${d}`,m=`${d}/${Q}`;if(c.has(m)){const w=c.get(m);w.splice(-1,1),w.length===0&&c.delete(m)}else{const w={vertex0:C,vertex1:u,polygonindex:I};c.has(f)?c.get(f).push(w):c.set(f,[w])}C=u,Q=d}}else console.warn("warning: invalid polygon found during insertTjunctions")}if(c.size>0){const I=new Map,l=new Map,B=new Map;for(const[Q,E]of c)B.set(Q,!0),E.forEach(h=>{const u=o(h.vertex0),d=o(h.vertex1);I.has(u)?I.get(u).push(Q):I.set(u,[Q]),l.has(d)?l.get(d).push(Q):l.set(d,[Q])});const C=g.slice(0);for(;c.size!==0;){for(const E of c.keys())B.set(E,!0);let Q=!1;for(;;){const E=Array.from(B.keys());if(E.length===0)break;const h=E[0];let u=!0;if(c.has(h)){const f=c.get(h)[0];for(let m=0;m<2;m++){const w=m===0?f.vertex0:f.vertex1,D=m===0?f.vertex1:f.vertex0,b=o(w),k=o(D);let x=[];m===0?l.has(b)&&(x=l.get(b)):I.has(b)&&(x=I.get(b));for(let N=0;N<x.length;N++){const R=x[N],U=c.get(R)[0],T=m===0?U.vertex0:U.vertex1;if(m===0?U.vertex1:U.vertex0,o(T)===k){r(c,I,l,w,D,null),r(c,I,l,D,w,null),u=!1,m=2,Q=!0;break}else{const O=w,W=D,X=T,iA=i.subtract(i.create(),X,O),aA=i.dot(i.subtract(i.create(),W,O),iA)/i.dot(iA,iA);if(aA>0&&aA<1){const tA=i.scale(i.create(),iA,aA);if(i.add(tA,tA,O),i.squaredDistance(tA,W)<t.EPS*t.EPS){const rA=U.polygonindex,CA=C[rA],SA=o(U.vertex1);let MA=-1;for(let dA=0;dA<CA.vertices.length;dA++)if(o(CA.vertices[dA])===SA){MA=dA;break}const GA=CA.vertices.slice(0);GA.splice(MA,0,D);const TA=n.create(GA);C[rA]=TA,r(c,I,l,U.vertex0,U.vertex1,rA);const hA=s(c,I,l,U.vertex0,D,rA),kA=s(c,I,l,D,U.vertex1,rA);hA!==null&&B.set(hA,!0),kA!==null&&B.set(kA,!0),u=!1,m=2,Q=!0;break}}}}}}u&&B.delete(h)}if(!Q)break}g=C}return c.clear(),g};A.exports=a}}),bde=ot({"node_modules/@jscad/modeling/src/operations/modifiers/triangulatePolygons.js"(e,A){var t=mn(),i=or(),n=(s,r,a)=>{const g=r.vertices.length;if(g>3){if(g>4){const l=[0,0,0];r.vertices.forEach(B=>t.add(l,l,B)),t.snap(l,t.divide(l,l,[g,g,g]),s);for(let B=0;B<g;B++){const C=i.create([l,r.vertices[B],r.vertices[(B+1)%g]]);r.color&&(C.color=r.color),a.push(C)}return}const c=i.create([r.vertices[0],r.vertices[1],r.vertices[2]]),I=i.create([r.vertices[0],r.vertices[2],r.vertices[3]]);r.color&&(c.color=r.color,I.color=r.color),a.push(c,I);return}a.push(r)},o=(s,r)=>{const a=[];return r.forEach(g=>{n(s,g,a)}),a};A.exports=o}}),xde=ot({"node_modules/@jscad/modeling/src/operations/modifiers/generalize.js"(e,A){var t=Ro(),i=u_(),n=Zo(),o=Vo(),s=wg(),r=bzA(),a=Dde(),g=Sde(),c=bde(),I=(Q,E)=>E,l=(Q,E)=>E,B=(Q,E)=>{const h={snap:!1,simplify:!1,triangulate:!1},{snap:u,simplify:d,triangulate:f}=Object.assign({},h,Q),m=i(E);let w=o.toPolygons(E);u&&(w=r(m,w)),d&&(w=a(m,w)),f&&(w=g(w),w=c(m,w));const D=Object.assign({},E);return D.polygons=w,D},C=(Q,...E)=>{if(E=t(E),E.length===0)throw new Error("wrong number of arguments");const h=E.map(u=>{if(s.isA(u))return I(Q,u);if(n.isA(u))return l(Q,u);if(o.isA(u))return B(Q,u);throw new Error("invalid geometry")});return h.length===1?h[0]:h};A.exports=C}}),_de=ot({"node_modules/@jscad/modeling/src/operations/modifiers/snap.js"(e,A){var t=Ro(),i=ds(),n=Zo(),o=Vo(),s=wg(),r=u_(),a=bzA(),g=B=>{const C=r(B),E=s.toPoints(B).map(h=>i.snap(i.create(),h,C));return s.create(E)},c=B=>{const C=r(B);let E=n.toSides(B).map(h=>[i.snap(i.create(),h[0],C),i.snap(i.create(),h[1],C)]);return E=E.filter(h=>!i.equals(h[0],h[1])),n.create(E)},I=B=>{const C=r(B),Q=o.toPolygons(B),E=a(C,Q);return o.create(E)},l=(...B)=>{if(B=t(B),B.length===0)throw new Error("wrong number of arguments");const C=B.map(Q=>s.isA(Q)?g(Q):n.isA(Q)?c(Q):o.isA(Q)?I(Q):Q);return C.length===1?C[0]:C};A.exports=l}}),kde=ot({"node_modules/@jscad/modeling/src/operations/modifiers/index.js"(e,A){A.exports={generalize:xde(),snap:_de(),retessellate:iH()}}}),Fde=ot({"node_modules/@jscad/modeling/src/utils/padArrayToLength.js"(e,A){var t=(i,n,o)=>{for(i=i.slice();i.length<o;)i.push(n);return i};A.exports=t}}),Gde=ot({"node_modules/@jscad/modeling/src/operations/transforms/align.js"(e,A){var t=Ro(),i=Fde(),n=qQA(),{translate:o}=ZF(),s=c=>{if(!Array.isArray(c.modes)||c.modes.length>3)throw new Error("align(): modes must be an array of length <= 3");if(c.modes=i(c.modes,"none",3),c.modes.filter(I=>["center","max","min","none"].includes(I)).length!==3)throw new Error('align(): all modes must be one of "center", "max" or "min"');if(!Array.isArray(c.relativeTo)||c.relativeTo.length>3)throw new Error("align(): relativeTo must be an array of length <= 3");if(c.relativeTo=i(c.relativeTo,0,3),c.relativeTo.filter(I=>Number.isFinite(I)||I==null).length!==3)throw new Error("align(): all relativeTo values must be a number, or null.");if(typeof c.grouped!="boolean")throw new Error("align(): grouped must be a boolean value.");return c},r=(c,I,l)=>{for(let B=0;B<3;B++)c[B]==null&&(I[B]==="center"?c[B]=(l[0][B]+l[1][B])/2:I[B]==="max"?c[B]=l[1][B]:I[B]==="min"&&(c[B]=l[0][B]));return c},a=(c,I,l)=>{const B=n(c),C=[0,0,0];for(let Q=0;Q<3;Q++)I[Q]==="center"?C[Q]=l[Q]-(B[0][Q]+B[1][Q])/2:I[Q]==="max"?C[Q]=l[Q]-B[1][Q]:I[Q]==="min"&&(C[Q]=l[Q]-B[0][Q]);return o(C,c)},g=(c,...I)=>{c=Object.assign({},{modes:["center","center","min"],relativeTo:[0,0,0],grouped:!1},c),c=s(c);let{modes:B,relativeTo:C,grouped:Q}=c;if(I=t(I),I.length===0)throw new Error("align(): No geometries were provided to act upon");if(C.filter(E=>E==null).length){const E=n(I);C=r(C,B,E)}return Q?I=a(I,B,C):I=I.map(E=>a(E,B,C)),I.length===1?I[0]:I};A.exports=g}}),tW=ot({"node_modules/@jscad/modeling/src/operations/transforms/center.js"(e,A){var t=Ro(),i=Zo(),n=Vo(),o=wg(),s=OF(),{translate:r}=ZF(),a=(B,C)=>{const Q={axes:[!0,!0,!0],relativeTo:[0,0,0]},{axes:E,relativeTo:h}=Object.assign({},Q,B),u=s(C),d=[0,0,0];return E[0]&&(d[0]=h[0]-(u[0][0]+(u[1][0]-u[0][0])/2)),E[1]&&(d[1]=h[1]-(u[0][1]+(u[1][1]-u[0][1])/2)),E[2]&&(d[2]=h[2]-(u[0][2]+(u[1][2]-u[0][2])/2)),r(d,C)},g=(B,...C)=>{const Q={axes:[!0,!0,!0],relativeTo:[0,0,0]},{axes:E,relativeTo:h}=Object.assign({},Q,B);if(C=t(C),C.length===0)throw new Error("wrong number of arguments");if(h.length!==3)throw new Error("relativeTo must be an array of length 3");B={axes:E,relativeTo:h};const u=C.map(d=>o.isA(d)||i.isA(d)||n.isA(d)?a(B,d):d);return u.length===1?u[0]:u},c=(...B)=>g({axes:[!0,!1,!1]},B),I=(...B)=>g({axes:[!1,!0,!1]},B),l=(...B)=>g({axes:[!1,!1,!0]},B);A.exports={center:g,centerX:c,centerY:I,centerZ:l}}}),eW=ot({"node_modules/@jscad/modeling/src/operations/transforms/scale.js"(e,A){var t=Ro(),i=Kg(),n=Zo(),o=Vo(),s=wg(),r=(I,...l)=>{if(!Array.isArray(I))throw new Error("factors must be an array");if(l=t(l),l.length===0)throw new Error("wrong number of arguments");for(I=I.slice();I.length<3;)I.push(1);if(I[0]<=0||I[1]<=0||I[2]<=0)throw new Error("factors must be positive");const B=i.fromScaling(i.create(),I),C=l.map(Q=>s.isA(Q)?s.transform(B,Q):n.isA(Q)?n.transform(B,Q):o.isA(Q)?o.transform(B,Q):Q);return C.length===1?C[0]:C},a=(I,...l)=>r([I,1,1],l),g=(I,...l)=>r([1,I,1],l),c=(I,...l)=>r([1,1,I],l);A.exports={scale:r,scaleX:a,scaleY:g,scaleZ:c}}}),Mde=ot({"node_modules/@jscad/modeling/src/operations/transforms/transform.js"(e,A){var t=Ro(),i=Zo(),n=Vo(),o=wg(),s=(r,...a)=>{if(a=t(a),a.length===0)throw new Error("wrong number of arguments");const g=a.map(c=>o.isA(c)?o.transform(r,c):i.isA(c)?i.transform(r,c):n.isA(c)?n.transform(r,c):c);return g.length===1?g[0]:g};A.exports=s}}),VF=ot({"node_modules/@jscad/modeling/src/operations/transforms/index.js"(e,A){A.exports={align:Gde(),center:tW().center,centerX:tW().centerX,centerY:tW().centerY,centerZ:tW().centerZ,mirror:AH().mirror,mirrorX:AH().mirrorX,mirrorY:AH().mirrorY,mirrorZ:AH().mirrorZ,rotate:tH().rotate,rotateX:tH().rotateX,rotateY:tH().rotateY,rotateZ:tH().rotateZ,scale:eW().scale,scaleX:eW().scaleX,scaleY:eW().scaleY,scaleZ:eW().scaleZ,transform:Mde(),translate:ZF().translate,translateX:ZF().translateX,translateY:ZF().translateY,translateZ:ZF().translateZ}}}),iW=ot({"node_modules/@jscad/modeling/src/index.js"(e,A){A.exports={colors:V8(),curves:_he(),geometries:YQA(),maths:Aue(),measurements:aue(),primitives:d_(),text:VQA(),utils:uzA(),booleans:VN(),expansions:wzA(),extrusions:nH(),hulls:wde(),modifiers:kde(),transforms:VF()}}}),xzA=ot({"node_modules/jscad-planner/dist/index.cjs"(e,A){var t=Object.defineProperty,i=Object.getOwnPropertyDescriptor,n=Object.getOwnPropertyNames,o=Object.prototype.hasOwnProperty,s=(l,B)=>{for(var C in B)t(l,C,{get:B[C],enumerable:!0})},r=(l,B,C,Q)=>{if(B&&typeof B=="object"||typeof B=="function")for(let E of n(B))!o.call(l,E)&&E!==C&&t(l,E,{get:()=>B[E],enumerable:!(Q=i(B,E))||Q.enumerable});return l},a=l=>r(t({},"__esModule",{value:!0}),l),g={};s(g,{executeJscadOperations:()=>I,jscadPlanner:()=>c}),A.exports=a(g);var c={booleans:{intersect:(...l)=>({type:"intersect",shapes:l}),subtract:(...l)=>({type:"subtract",shapes:l}),union:(...l)=>({type:"union",shapes:l})},hulls:{hull:(...l)=>({type:"hull",shapes:l.flat()}),hullChain:(...l)=>({type:"hullChain",shapes:l.flat()})},colors:{colorize:(l,B)=>({type:"colorize",color:l,shape:B})},primitives:{cube:l=>({type:"cube",...l}),sphere:l=>({type:"sphere",...l}),cylinder:l=>({type:"cylinder",...l}),polygon:l=>({type:"polygon",...l}),cuboid:l=>({type:"cuboid",...l}),roundedCuboid:l=>({type:"roundedCuboid",...l})},transforms:{rotate:(l,B)=>({type:"rotate",angles:l,shape:B}),scale:(l,B)=>({type:"scale",factors:l,shape:B}),translate:(l,B)=>({type:"translate",vector:l,shape:B})},extrusions:{extrudeLinear:(l,B)=>({type:"extrudeLinear",options:l,shape:B}),extrudeRotate:(l,B)=>({type:"extrudeRotate",options:l,shape:B})},maths:{vec2:{create:(l,B)=>[l,B],fromValues:(l,B)=>[l,B]},vec3:{create:(l,B,C)=>[l,B,C],fromValues:(l,B,C)=>[l,B,C]}},geometries:{geom2:{create:l=>({type:"createGeom2",points:l})},geom3:{create:l=>({type:"createGeom3",polygons:l})},path2:{create:l=>({type:"createPath2",points:l})}},measurements:{measureBoundingBox:l=>({type:"measureBoundingBox",shape:l}),measureArea:l=>({type:"measureArea",shape:l}),measureVolume:l=>({type:"measureVolume",shape:l})},utils:{degToRad:l=>l*Math.PI/180,radToDeg:l=>l*180/Math.PI}},I=(l,B)=>{if(Array.isArray(B)&&B.length===1)return I(l,B[0]);if(Array.isArray(B))throw new Error("executeJscadOperations currently doesn't support Array<JscadOperation>, try adding a root union or or executing each element individually");const C=h=>I(l,h),{type:Q,...E}=B;switch(Q){case"intersect":return l.booleans.intersect(...B.shapes.map(C));case"subtract":return l.booleans.subtract(...B.shapes.map(C));case"union":return l.booleans.union(...B.shapes.map(C));case"hull":return l.hulls.hull(...B.shapes.map(C));case"hullChain":return l.hulls.hullChain(...B.shapes.map(C));case"colorize":return l.colors.colorize(B.color,C(B.shape));case"cube":return l.primitives.cube(E);case"sphere":return l.primitives.sphere(E);case"cylinder":return l.primitives.cylinder(E);case"polygon":return l.primitives.polygon(E);case"cuboid":return l.primitives.cuboid(E);case"roundedCuboid":return l.primitives.roundedCuboid(E);case"rotate":return l.transforms.rotate(B.angles,C(B.shape));case"scale":return l.transforms.scale(B.factors,C(B.shape));case"translate":return l.transforms.translate(B.vector,C(B.shape));case"extrudeLinear":return l.extrusions.extrudeLinear(B.options,C(B.shape));case"extrudeRotate":return l.extrusions.extrudeRotate(B.options,C(B.shape));case"createGeom2":return l.geometries.geom2.create(B.points);case"createGeom3":return l.geometries.geom3.create(B.polygons);case"createPath2":return l.geometries.path2.create(B.points);case"measureBoundingBox":return l.measurements.measureBoundingBox(C(B.shape));case"measureArea":return l.measurements.measureArea(C(B.shape));case"measureVolume":return l.measurements.measureVolume(C(B.shape));case"degToRad":return l.utils.degToRad(B.degrees);case"radToDeg":return l.utils.radToDeg(B.radians);default:throw B.type===void 0?new Error(`Operation type is undefined. This usually means the operation object is malformed or not properly initialized. Operation: ${JSON.stringify(B,null,2).slice(0,200)}...`):new Error(`Unsupported operation type: ${B.type}. Operation: ${JSON.stringify(B,null,2)}`)}}}}),Rde=ot({"node_modules/ms/index.js"(e,A){var t=1e3,i=t*60,n=i*60,o=n*24,s=o*7,r=o*365.25;A.exports=function(l,B){B=B||{};var C=typeof l;if(C==="string"&&l.length>0)return a(l);if(C==="number"&&isFinite(l))return B.long?c(l):g(l);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(l))};function a(l){if(l=String(l),!(l.length>100)){var B=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(l);if(B){var C=parseFloat(B[1]),Q=(B[2]||"ms").toLowerCase();switch(Q){case"years":case"year":case"yrs":case"yr":case"y":return C*r;case"weeks":case"week":case"w":return C*s;case"days":case"day":case"d":return C*o;case"hours":case"hour":case"hrs":case"hr":case"h":return C*n;case"minutes":case"minute":case"mins":case"min":case"m":return C*i;case"seconds":case"second":case"secs":case"sec":case"s":return C*t;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return C;default:return}}}}function g(l){var B=Math.abs(l);return B>=o?Math.round(l/o)+"d":B>=n?Math.round(l/n)+"h":B>=i?Math.round(l/i)+"m":B>=t?Math.round(l/t)+"s":l+"ms"}function c(l){var B=Math.abs(l);return B>=o?I(l,B,o,"day"):B>=n?I(l,B,n,"hour"):B>=i?I(l,B,i,"minute"):B>=t?I(l,B,t,"second"):l+" ms"}function I(l,B,C,Q){var E=B>=C*1.5;return Math.round(l/C)+" "+Q+(E?"s":"")}}}),Nde=ot({"node_modules/debug/src/common.js"(e,A){function t(i){o.debug=o,o.default=o,o.coerce=I,o.disable=g,o.enable=r,o.enabled=c,o.humanize=Rde(),o.destroy=l,Object.keys(i).forEach(B=>{o[B]=i[B]}),o.names=[],o.skips=[],o.formatters={};function n(B){let C=0;for(let Q=0;Q<B.length;Q++)C=(C<<5)-C+B.charCodeAt(Q),C|=0;return o.colors[Math.abs(C)%o.colors.length]}o.selectColor=n;function o(B){let C,Q=null,E,h;function u(...d){if(!u.enabled)return;const f=u,m=Number(new Date),w=m-(C||m);f.diff=w,f.prev=C,f.curr=m,C=m,d[0]=o.coerce(d[0]),typeof d[0]!="string"&&d.unshift("%O");let D=0;d[0]=d[0].replace(/%([a-zA-Z%])/g,(k,x)=>{if(k==="%%")return"%";D++;const N=o.formatters[x];if(typeof N=="function"){const R=d[D];k=N.call(f,R),d.splice(D,1),D--}return k}),o.formatArgs.call(f,d),(f.log||o.log).apply(f,d)}return u.namespace=B,u.useColors=o.useColors(),u.color=o.selectColor(B),u.extend=s,u.destroy=o.destroy,Object.defineProperty(u,"enabled",{enumerable:!0,configurable:!1,get:()=>Q!==null?Q:(E!==o.namespaces&&(E=o.namespaces,h=o.enabled(B)),h),set:d=>{Q=d}}),typeof o.init=="function"&&o.init(u),u}function s(B,C){const Q=o(this.namespace+(typeof C>"u"?":":C)+B);return Q.log=this.log,Q}function r(B){o.save(B),o.namespaces=B,o.names=[],o.skips=[];const C=(typeof B=="string"?B:"").trim().replace(/\s+/g,",").split(",").filter(Boolean);for(const Q of C)Q[0]==="-"?o.skips.push(Q.slice(1)):o.names.push(Q)}function a(B,C){let Q=0,E=0,h=-1,u=0;for(;Q<B.length;)if(E<C.length&&(C[E]===B[Q]||C[E]==="*"))C[E]==="*"?(h=E,u=Q,E++):(Q++,E++);else if(h!==-1)E=h+1,u++,Q=u;else return!1;for(;E<C.length&&C[E]==="*";)E++;return E===C.length}function g(){const B=[...o.names,...o.skips.map(C=>"-"+C)].join(",");return o.enable(""),B}function c(B){for(const C of o.skips)if(a(B,C))return!1;for(const C of o.names)if(a(B,C))return!0;return!1}function I(B){return B instanceof Error?B.stack||B.message:B}function l(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return o.enable(o.load()),o}A.exports=t}}),vde=ot({"node_modules/debug/src/browser.js"(e,A){e.formatArgs=i,e.save=n,e.load=o,e.useColors=t,e.storage=s(),e.destroy=(()=>{let a=!1;return()=>{a||(a=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),e.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function t(){if(typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs))return!0;if(typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))return!1;let a;return typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&(a=navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/))&&parseInt(a[1],10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function i(a){if(a[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+a[0]+(this.useColors?"%c ":" ")+"+"+A.exports.humanize(this.diff),!this.useColors)return;const g="color: "+this.color;a.splice(1,0,g,"color: inherit");let c=0,I=0;a[0].replace(/%[a-zA-Z%]/g,l=>{l!=="%%"&&(c++,l==="%c"&&(I=c))}),a.splice(I,0,g)}e.log=console.debug||console.log||(()=>{});function n(a){try{a?e.storage.setItem("debug",a):e.storage.removeItem("debug")}catch{}}function o(){let a;try{a=e.storage.getItem("debug")||e.storage.getItem("DEBUG")}catch{}return!a&&typeof FQA<"u"&&"env"in FQA&&(a=FQA.env.DEBUG),a}function s(){try{return localStorage}catch{}}A.exports=Nde()(e);var{formatters:r}=A.exports;r.j=function(a){try{return JSON.stringify(a)}catch(g){return"[UnexpectedJSONParseError]: "+g.message}}}}),_zA={boardBody:!0,topCopper:!0,bottomCopper:!0,adhesive:!1,solderPaste:!1,topSilkscreen:!0,bottomSilkscreen:!0,topMask:!0,bottomMask:!0,throughHoleModels:!0,smtModels:!0,translucentModels:!0,modelsNotInPosFile:!1,modelsMarkedDNP:!1,modelBoundingBoxes:!1,threedAxis:!1,backgroundStart:!0,backgroundEnd:!0},kzA=AA.createContext(void 0),Lde=({children:e})=>{const[A,t]=AA.useState(_zA),i=AA.useCallback((s,r)=>{t(a=>({...a,[s]:r}))},[]),n=AA.useCallback(()=>{t(_zA)},[]),o=AA.useMemo(()=>({visibility:A,setLayerVisibility:i,resetToDefaults:n}),[A,i,n]);return Z.jsx(kzA.Provider,{value:o,children:e})},jF=()=>{const e=AA.useContext(kzA);if(!e)throw new Error("useLayerVisibility must be used within a LayerVisibilityProvider");return e},nEA=1.2;function FzA(e){return AA.useMemo(()=>{if(!e)return nEA;try{return Ji(e).pcb_board.list()[0]?.thickness??nEA}catch{return nEA}},[e])}var GzA=AA.createContext(null),Lu=()=>{const e=AA.useContext(GzA);if(!e)throw new Error("useThree must be used within a ThreeProvider");return e},oH=(e,A=[])=>{const{addFrameListener:t,removeFrameListener:i}=Lu();nn.useEffect(()=>(t(e),()=>i(e)),[t,i,...A])},sH={clickToInteractOverlay:100,htmlElements:95,orientationCube:95,contextMenu:90,appearanceMenu:91},MzA=({children:e,position:A,style:t})=>{const{camera:i,renderer:n}=Lu(),o=AA.useRef(document.createElement("div")),[s,r]=AA.useState(null);return AA.useEffect(()=>{const a=n?.domElement.parentNode;if(a)return a.style.position!=="relative"&&a.style.position!=="absolute"&&(a.style.position="relative"),a.appendChild(o.current),r(cK.createPortal(e,o.current)),()=>{a.contains(o.current)&&a.removeChild(o.current)}},[n,e]),oH(()=>{if(!i||!o.current||!n)return;const a=new Mt(...A);a.project(i);const g=n.domElement.getBoundingClientRect(),c=Math.round((a.x+1)/2*g.width),I=Math.round((-a.y+1)/2*g.height);o.current.style.position="absolute",o.current.style.left=`${c}px`,o.current.style.top=`${I}px`,o.current.style.pointerEvents="none",o.current.style.zIndex=sH.htmlElements.toString(),t&&Object.assign(o.current.style,t)},[i,n,A,t]),s},RzA={in:25.4,inch:25.4,mil:.0254,mm:1,m:1e3,cm:10,ft:304.8,feet:304.8},Fr=e=>{let A=typeof e=="number"?"mm":e.replace(/^[^a-zA-Z]+/g,"").toLowerCase();A||(A="mm");const t=typeof e=="number"?e:Number.parseFloat(e.split(A)[0]);if(A in RzA)return t*RzA[A];throw new Error(`Unsupported unit: ${A}`)},_l=Fr,Ude=Object.defineProperty,Hde=(e,A)=>{for(var t in A)Ude(e,t,{get:A[t],enumerable:!0})},ob={};Hde(ob,{axial:()=>afe,bga:()=>hpe,breakoutheaders:()=>ffe,cap:()=>Ode,dfn:()=>Kpe,diode:()=>qde,dip:()=>Tde,electrolytic:()=>nme,hc49:()=>mfe,jst:()=>Sye,led:()=>Wde,lqfp:()=>dfe,m2host:()=>Dme,melf:()=>N0e,micromelf:()=>H0e,minimelf:()=>b0e,mlp:()=>Spe,ms012:()=>jpe,ms013:()=>Xpe,msop:()=>vye,pad:()=>wfe,pinrow:()=>Ope,platedhole:()=>Eme,potentiometer:()=>tme,pushbutton:()=>Bfe,qfn:()=>mpe,qfp:()=>Dpe,quad:()=>zN,radial:()=>Ife,res:()=>Cpe,sma:()=>K0e,smb:()=>z0e,smbf:()=>sme,smc:()=>tye,smf:()=>W0e,smtpad:()=>Cme,sod110:()=>xye,sod123:()=>nfe,sod123f:()=>o0e,sod123fl:()=>g0e,sod123w:()=>Hfe,sod128:()=>h0e,sod323:()=>Kfe,sod323f:()=>t0e,sod323fl:()=>Tye,sod323w:()=>Uye,sod523:()=>_fe,sod723:()=>B0e,sod80:()=>Nfe,sod882:()=>zfe,sod882d:()=>F0e,sod923:()=>Wfe,soic:()=>dpe,solderjumper:()=>Wye,son:()=>Oye,sop8:()=>Mfe,sot:()=>ume,sot223:()=>oye,sot23:()=>vpe,sot23w:()=>Cye,sot25:()=>Ype,sot323:()=>cme,sot343:()=>fme,sot363:()=>Gpe,sot457:()=>jye,sot563:()=>Zpe,sot723:()=>Afe,sot886:()=>Rpe,sot89:()=>m0e,sot963:()=>Xye,ssop:()=>xpe,stampboard:()=>Qfe,stampreceiver:()=>ufe,to220:()=>D0e,to92:()=>bfe,to92l:()=>bme,to92s:()=>pye,tqfp:()=>wpe,tssop:()=>kpe,vssop:()=>Mye});var Wi=(e,A,t)=>({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:"silkscreen_text_1",font:"tscircuit2024",font_size:t,pcb_component_id:"pcb_component_1",text:"{REF}",layer:"top",anchor_position:{x:e,y:A},anchor_alignment:"center"}),Zi=jA({norefdes:gt().optional().describe("disable reference designator label"),invert:gt().optional().describe("hint to invert the orientation of the 3D model"),faceup:gt().optional().describe("The male pin header should face upwards, out of the top layer"),nosilkscreen:gt().optional().describe("omit all silkscreen elements from the footprint")}),jo=(e,A,t,i,n)=>({pcb_plated_hole_id:"",type:"pcb_plated_hole",shape:"circle",x:A,y:t,hole_diameter:Fr(i),outer_diameter:Fr(n),pcb_port_id:"",layers:["top","bottom"],port_hints:[e.toString()]}),sb=(e,A,t,i,n,o,s,r)=>({pcb_plated_hole_id:"",type:"pcb_plated_hole",shape:"circular_hole_with_rect_pad",x:A,y:t,hole_diameter:Fr(i),hole_shape:"circle",pad_shape:"rect",rect_pad_width:Fr(n),rect_pad_height:Fr(o),pcb_port_id:"",layers:["top","bottom"],port_hints:[e.toString()],hole_offset_x:s,hole_offset_y:r}),NzA=Array.from({length:9},(e,A)=>Math.cos(A/8*Math.PI-Math.PI)).map(e=>({x:e,y:-Math.sqrt(1-e**2)}));function p_(e){return typeof e=="string"?e.trim().toLowerCase().endsWith("mil")?parseFloat(e)*.0254:parseFloat(e):Number(e)}var nW=Ze([H(),WA()]).transform(e=>p_(e)),Yde=e=>Zi.extend({fn:H(),num_pins:WA().optional().default(6),wide:gt().optional(),narrow:gt().optional(),w:nW.optional(),p:nW.default(e.p??"2.54mm"),id:nW.optional(),od:nW.optional(),nosquareplating:gt().optional().default(!1).describe("do not use rectangular pad for pin 1")}).transform(A=>(!A.id&&!A.od?Math.abs(A.p-1.27)<.01?(A.id=p_("0.55mm"),A.od=p_("0.95mm")):(A.id=p_("0.8mm"),A.od=p_("1.6mm")):A.id?A.od||(A.od=A.id*(1.5/1)):A.id=A.od*(1/1.5),A.w||(A.wide?A.w=p_("600mil"):A.narrow?A.w=p_("300mil"):A.w=p_(e.w??"300mil")),A)),Jde=Yde({}),vzA=(e,A,t,i,n)=>{const o=e/2,s=A<=o,r=o-1,a=i,g=a*r;return s?{x:-t/2,y:g/2-(A-1)*a}:{x:t/2,y:-g/2+(A-o-1)*a}},Tde=e=>{const A=Jde.parse(e),t=[];for(let g=0;g<A.num_pins;g++){const{x:c,y:I}=vzA(A.num_pins,g+1,A.w,A.p??2.54,A.nosquareplating);if(g===0&&!A.nosquareplating){t.push(sb(g+1,c,I,A.id??"0.8mm",A.od??"1mm",A.od??"1mm"));continue}t.push(jo(g+1,c,I,A.id??"0.8mm",A.od??"1mm"))}(A.num_pins/2-1)*A.p+A.od;const n=A.w-A.od-1,o=(A.num_pins/2-1)*A.p+A.od+.4,s={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-n/2,y:-o/2},{x:-n/2,y:o/2},...NzA.map(({x:g,y:c})=>({x:g*n/6,y:c*n/6+o/2})),{x:n/2,y:o/2},{x:n/2,y:-o/2},{x:-n/2,y:-o/2}],type:"pcb_silkscreen_path",stroke_width:.1},r=[];for(let g=0;g<A.num_pins;g++){const c=g<A.num_pins/2,I=.6,{y:l}=vzA(A.num_pins,g+1,A.w,A.p??2.54,A.nosquareplating),B=c?-A.w/2-A.od/2-I:A.w/2+A.od/2+I,C=l;r.push({type:"pcb_fabrication_note_text",pcb_fabrication_note_text_id:`pin_${g+1}`,layer:"top",pcb_component_id:`pin_${g+1}`,text:`{pin${g+1}}`,anchor_position:{x:B,y:C},font_size:.3,font:"tscircuit2024",anchor_alignment:"top_left"})}const a=Wi(0,o/2+.5,.4);return{circuitJson:[...t,s,a,...r],parameters:A}},di=(e,A,t,i,n)=>({type:"pcb_smtpad",x:A,y:t,width:i,height:n,layer:"top",shape:"rect",pcb_smtpad_id:"",port_hints:Array.isArray(e)?e.map(o=>o.toString()):[e.toString()]}),LzA=[{imperial:"01005",metric:"0402",p_mm_min:.5,pw_mm_min:.4,ph_mm_min:.3,w_mm_min:.58,h_mm_min:.21},{imperial:"0504",metric:"1310",p_mm_min:1.1,pw_mm_min:.65,ph_mm_min:1.3,w_mm_min:.58,h_mm_min:.21},{imperial:"1812",metric:"4532",p_mm_min:4.275,pw_mm_min:1.125,ph_mm_min:3.4,w_mm_min:5.4,h_mm_min:3.4},{imperial:"0201",metric:"0603",p_mm_min:.66,pw_mm_min:.46,ph_mm_min:.4,w_mm_min:.9,h_mm_min:.3},{imperial:"0402",metric:"1005",p_mm_min:1.02,pw_mm_min:.54,ph_mm_min:.64,w_mm_min:1.56,h_mm_min:.64},{imperial:"0603",metric:"1608",p_mm_min:1.65,pw_mm_min:.8,ph_mm_min:.95,w_mm_min:2.45,h_mm_min:.95},{imperial:"0805",metric:"2012",p_mm_min:1.825,pw_mm_min:1.025,ph_mm_min:1.4,w_mm_min:2.8499999999999996,h_mm_min:1.4},{imperial:"1206",metric:"3216",p_mm_min:2.925,pw_mm_min:1.125,ph_mm_min:1.75,w_mm_min:4.05,h_mm_min:1.75},{imperial:"1210",metric:"3225",p_mm_min:2.925,pw_mm_min:1.125,ph_mm_min:2.65,w_mm_min:4.05,h_mm_min:2.65},{imperial:"2010",metric:"5025",p_mm_min:4.625,pw_mm_min:1.225,ph_mm_min:2.65,w_mm_min:5.85,h_mm_min:2.65},{imperial:"2512",metric:"6332",p_mm_min:5.925,pw_mm_min:1.225,ph_mm_min:3.35,w_mm_min:7.15,h_mm_min:3.35}],Kde=Object.fromEntries(LzA.map(e=>[e.metric,e])),Pde=Object.fromEntries(LzA.map(e=>[e.imperial,e]));Zi.extend({tht:gt(),p:QA.optional(),pw:QA.optional(),ph:QA.optional(),metric:at.optional(),imperial:at.optional(),w:QA.optional(),h:QA.optional(),textbottom:gt().optional()});var oW=e=>{let{tht:A,p:t,pw:i,ph:n,metric:o,imperial:s,w:r,h:a,textbottom:g}=e;if(typeof r=="string"&&(r=_l(r)),typeof a=="string"&&(a=_l(a)),typeof t=="string"&&(t=_l(t)),typeof i=="string"&&(i=_l(i)),typeof n=="string"&&(n=_l(n)),a!==void 0&&r!==void 0&&a>r)throw new Error("height cannot be greater than width (rotated footprint not yet implemented)");let c;if(o&&(c=Kde[o]),s&&(c=Pde[s]),c&&(r=c.w_mm_min,a=c.h_mm_min,t=c.p_mm_min,i=c.pw_mm_min,n=c.ph_mm_min),t===void 0||i===void 0||n===void 0)throw new Error("Could not determine required pad dimensions (p, pw, ph)");const I={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:t/2,y:n/2+.4},{x:-t/2-i/2-.2,y:n/2+.4},{x:-t/2-i/2-.2,y:-n/2-.4},{x:t/2,y:-n/2-.4}],stroke_width:.1,pcb_silkscreen_path_id:""},l=g?-n/2-.9:n/2+.9,B=Wi(0,l,.2);return A?[jo(1,-t/2,0,i,i*1/.8),jo(2,t/2,0,i,i*1/.8),I,B]:[di(["1","left"],-t/2,0,i,n),di(["2","right"],t/2,0,i,n),I,B]},qde=e=>({circuitJson:oW(e),parameters:e}),Ode=e=>({circuitJson:oW(e),parameters:e}),Wde=e=>({circuitJson:oW(e),parameters:e}),jN=e=>{const{padSpacing:A,padWidth:t,padHeight:i,padPitch:n,numRows:o,textbottom:s}=e,r=[],a=(o-1)*(n/2);for(let b=0;b<o;b++)r.push(a-b*n);const g=[];r.forEach((b,k)=>{g.push(di(k+1,-A/2,b,t,i))}),r.slice().reverse().forEach((b,k)=>{g.push(di(k+o+1,A/2,b,t,i))});const c=Math.max(...r)+i/2+.4,I=Math.min(...r)-i/2-.4,l=-A/2-t/2-.4,B=A/2+t/2+.4,C={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:B*.5,y:c},{x:l*.5,y:c}],stroke_width:.12,pcb_silkscreen_path_id:"silkscreen_top"},Q={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:B*.5,y:I},{x:l*.5,y:I}],stroke_width:.12,pcb_silkscreen_path_id:"silkscreen_bottom"},E=-A/2,h=Math.max(...r),u=.2,d=E-t/2-.1,f=h+i/2+.1,m={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"pin1_marker",route:[{x:d,y:f},{x:d-u,y:f},{x:d,y:f+u},{x:d,y:f}],stroke_width:.1},w=s?I-.9:c+.9,D=Wi(0,w,.2);return[...g,C,Q,m,D]},Zde=Zi.extend({pw:H().default("0.5mm"),ph:H().default("0.4mm"),p:H().default("0.7mm"),textbottom:gt().optional()}),Vde=1,jde=e=>{const A=Zde.parse(e),t=_l(A.pw),i=_l(A.ph),n=_l(A.p);return jN({padSpacing:Vde,padWidth:t,padHeight:i,padPitch:n,numRows:2,textbottom:A.textbottom})},zde=Zi.extend({pw:H().default("0.5mm"),ph:H().default("0.32mm"),p:H().default("0.5mm"),textbottom:gt().optional()}),Xde=1,$de=e=>{const A=zde.parse(e),t=_l(A.pw),i=_l(A.ph),n=_l(A.p);return jN({padSpacing:Xde,padWidth:t,padHeight:i,padPitch:n,numRows:4,textbottom:A.textbottom})},Ape=Zi.extend({pw:H().default("0.9mm"),ph:H().default("0.4mm"),p:H().default("0.8mm"),textbottom:gt().optional()}),tpe=1.7,epe=e=>{const A=Ape.parse(e),t=_l(A.pw),i=_l(A.ph),n=_l(A.p);return jN({padSpacing:tpe,padWidth:t,padHeight:i,padPitch:n,numRows:2,textbottom:A.textbottom})},ipe=Zi.extend({pw:H().default("0.9mm"),ph:H().default("0.4mm"),p:H().default("0.8mm"),textbottom:gt().optional()}),npe=1.7,ope=e=>{const A=ipe.parse(e),t=_l(A.pw),i=_l(A.ph),n=_l(A.p);return jN({padSpacing:npe,padWidth:t,padHeight:i,padPitch:n,numRows:4,textbottom:A.textbottom})},spe=Zi.extend({pw:H().default("0.7mm"),ph:H().default("0.64mm"),p:H().default("0.94mm"),textbottom:gt().optional()}),rpe=1.4,ape=e=>{const A=spe.parse(e),t=_l(A.pw),i=_l(A.ph),n=_l(A.p);return jN({padSpacing:rpe,padWidth:t,padHeight:i,padPitch:n,numRows:2,textbottom:A.textbottom})},gpe=Zi.extend({pw:H().default("0.9mm"),ph:H().default("0.9mm"),p:H().default("1.34mm"),textbottom:gt().optional()}),cpe=3,Ipe=e=>{const A=gpe.parse(e),t=_l(A.pw),i=_l(A.ph),n=_l(A.p);return jN({padSpacing:cpe,padWidth:t,padHeight:i,padPitch:n,numRows:4,textbottom:A.textbottom})},lpe=e=>{const A=e.array??e.x;if(typeof A=="number")return Number.isNaN(A)?void 0:A;if(typeof A=="string"){const t=Number.parseInt(A,10);return Number.isNaN(t)?void 0:t}if(typeof e.imperial=="string"){const i=e.imperial.match(/(?:array|x)(2|4)$/)?.[1];if(i)return Number.parseInt(i,10)}},Bpe=e=>e?(typeof e=="number"?`${e}`:e).split("_")[0]:void 0,Cpe=e=>{const A=lpe(e),t=Bpe(e.imperial);return A===2&&t==="0402"?{circuitJson:jde(e),parameters:e}:A===4&&t==="0402"?{circuitJson:$de(e),parameters:e}:A===2&&t==="0603"?{circuitJson:epe(e),parameters:e}:A===4&&t==="0603"?{circuitJson:ope(e),parameters:e}:A===2&&t==="0606"?{circuitJson:ape(e),parameters:e}:A===4&&t==="1206"?{circuitJson:Ipe(e),parameters:e}:{circuitJson:oW(e),parameters:e}},UzA=(e,{x:A,y:t,radius:i})=>({type:"pcb_smtpad",x:A,y:t,radius:i,layer:"top",shape:"circle",pcb_smtpad_id:"",port_hints:Array.isArray(e)?e.map(n=>n.toString()):[e.toString()]}),HzA="ABCDEFGHIJKLMNOPQRSTUVWXYZ",YzA=H().transform(e=>{const[A,t]=e.split(/[x ]/);return{x:parseFloat(A),y:parseFloat(t)}}).pipe(jA({x:WA(),y:WA()})),Qpe=H().or(St(Yc())).transform(e=>Array.isArray(e)?e:(e.startsWith("(")&&e.endsWith(")")&&(e=e.slice(1,-1)),e.split(",").map(A=>{const t=Number(A);return isNaN(t)?A:t}))).pipe(St(H().or(WA()))),Epe=Zi.extend({fn:H(),num_pins:WA().optional().default(64),grid:YzA.optional(),p:at.default("0.8mm"),w:QA.optional(),h:QA.optional(),ball:QA.optional().describe("ball diameter"),pad:QA.optional().describe("pad width/height"),circularpads:gt().optional().describe("use circular pads"),tlorigin:gt().optional(),blorigin:gt().optional(),trorigin:gt().optional(),brorigin:gt().optional(),missing:Qpe.default([])}).transform(e=>{let A="tl";if(e.blorigin&&(A="bl"),e.trorigin&&(A="tr"),e.brorigin&&(A="br"),!e.grid){const i=Math.ceil(Math.sqrt(e.num_pins));e.grid={x:i,y:i}}return e.missing&&(e.missing=e.missing.map(i=>{if(typeof i=="number")return i;if(i==="center")return"center";if(i==="topleft")return"topleft";const n=i.match(/([A-Z]+)(\d+)/);if(!n)return i;const o=HzA.indexOf(n[1]),s=Number.parseInt(n[2])-1;return o*e.grid.x+s+1})),{...e,origin:A}}),hpe=e=>{const A=Epe.parse(e);let{num_pins:t,grid:i,p:n,w:o,h:s,ball:r,pad:a,missing:g}=A;r??=.75/1.27*n,a??=r*.8;const c=[],I=(g??[]).filter(m=>typeof m=="number"),l=i.x*i.y-t;if(g.length===0&&l>0&&(Math.sqrt(l)%1===0?g.push("center"):l===1&&g.push("topleft")),g?.includes("center")){const m=Math.floor(Math.sqrt(l)),w=Math.floor((i.x-m)/2),D=Math.floor((i.y-m)/2);for(let b=D;b<D+m;b++)for(let k=w;k<w+m;k++)I.push(b*i.x+k+1)}g?.includes("topleft")&&I.push(1);const B=new Set(I);let C=0;for(let m=0;m<i.y;m++)for(let w=0;w<i.x;w++){const D=(w-(i.x-1)/2)*n,b=(m-(i.y-1)/2)*n;let k=w,x=m;switch(A.origin){case"bl":k=w,x=i.y-1-m;break;case"br":k=i.x-1-w,x=i.y-1-m;break;case"tr":k=i.x-1-w,x=m;break}let N=x*i.x+k+1;if(B.has(N)){C++;continue}N-=C;const R=[N,`${HzA[x]}${k+1}`];c.push(A.circularpads?UzA(R,{x:D,y:b,radius:a/2}):di(R,D,b,a,a))}const Q=Wi(0,i.y*n/2,.2),E=n/6;let h;const u=i.x*n/2,d=i.y*n/2;switch(A.origin){case"bl":h=[{x:-u,y:-d},{x:-u,y:-d-E},{x:-u-E,y:-d},{x:-u,y:-d}];break;case"br":h=[{x:u,y:-d},{x:u,y:-d-E},{x:u+E,y:-d},{x:u,y:-d}];break;case"tr":h=[{x:u,y:d},{x:u,y:d+E},{x:u+E,y:d},{x:u,y:d}];break;default:h=[{x:-u,y:d},{x:-u,y:d+E},{x:-u-E,y:d},{x:-u,y:d}];break}const f={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"pin1_marker",route:h,stroke_width:.05};return{circuitJson:[...c,Q,f],parameters:A}},sW=(e,A,t,i,n)=>({type:"pcb_smtpad",x:A,y:t,width:i,height:n,radius:n/2,layer:"top",shape:"pill",pcb_smtpad_id:"",port_hints:Array.isArray(e)?e.map(o=>o.toString()):[e.toString()]}),rD=e=>Zi.extend({fn:H(),num_pins:WA().optional().default(8),w:QA.default(QA.parse(e.w??"5.3mm")),p:QA.default(QA.parse(e.p??"1.27mm")),pw:QA.default(QA.parse(e.pw??"0.6mm")),pl:QA.default(QA.parse(e.pl??"1.0mm")),legsoutside:gt().optional().default(e.legsoutside??!1),pillpads:gt().optional().default(e.pillpads??!1),silkscreen_stroke_width:WA().optional().default(.1)}).transform(A=>(!A.pw&&!A.pl?(A.pw=QA.parse("0.6mm"),A.pl=QA.parse("1.0mm")):A.pw?A.pl||(A.pl=A.pw*(1/.6)):A.pw=A.pl*(.6/1),A)),upe=rD({}),oEA=e=>{e.widthincludeslegs!==void 0&&(e.legsoutside=!e.widthincludeslegs);const{num_pins:A,pn:t,w:i,p:n,pl:o,legsoutside:s}=e,r=A/2,a=t<=r,g=r-1,c=n,I=c*g,l=s?o/2:-o/2;return a?{x:-i/2-l,y:I/2-(t-1)*c}:{x:i/2+l,y:-I/2+(t-r-1)*c}},dpe=e=>{const A=upe.parse(e);return{circuitJson:f_(A),parameters:A}},f_=e=>{const A=[];for(let r=0;r<e.num_pins;r++){const{x:a,y:g}=oEA({num_pins:e.num_pins,pn:r+1,w:e.w,p:e.p,pl:e.pl,legsoutside:e.legsoutside});e.pillpads?A.push(sW(r+1,a,g,e.pl,e.pw)):A.push(di(r+1,a,g,e.pl,e.pw))}const t=Math.min(1,e.p/2),i=e.w-(e.legsoutside?0:e.pl*2)-.2,n=(e.num_pins/2-1)*e.p+e.pw+t,o=Wi(0,n/2+.4,n/12),s={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",stroke_width:e.silkscreen_stroke_width??.1,route:[{x:-i/2,y:-n/2},{x:-i/2,y:n/2},...NzA.map(({x:r,y:a})=>({x:r*i/6,y:a*i/6+n/2})),{x:i/2,y:n/2},{x:i/2,y:-n/2},{x:-i/2,y:-n/2}]};return[...A,s,o]},JzA=se(["leftside","topside","rightside","bottomside","toppin","bottompin","leftpin","rightpin"]),ppe=({num_pins:e,cw:A,ccw:t,startingpin:i})=>{const n=[],o=e/4;let s=1;const r={};for(const a of i??[])r[a]=!0;!r.leftside&&!r.topside&&!r.rightside&&!r.bottomside&&(r.leftside=!0),!r.bottompin&&!r.leftpin&&!r.rightpin&&!r.toppin&&(r.leftside?r.toppin=!0:r.topside?r.rightpin=!0:r.rightside?r.bottompin=!0:r.bottomside&&(r.leftpin=!0)),r.leftside&&r.toppin?s=1:r.leftside&&r.bottompin?s=o:r.bottomside&&r.leftpin?s=o+1:r.bottomside&&r.rightpin?s=o*2:r.rightside&&r.bottompin?s=o*2+1:r.rightside&&r.toppin?s=o*3:r.topside&&r.rightpin?s=o*3+1:r.topside&&r.leftpin&&(s=o*4),n.push(-1);for(let a=0;a<e;a++)n[s]=a+1,t||!A?(s++,s>e&&(s=1)):(s--,s<1&&(s=e));return n},sEA=Zi.extend({fn:H(),cc:gt().default(!0).optional(),ccw:gt().default(!0).optional(),startingpin:H().or(St(JzA)).transform(e=>typeof e=="string"?e.slice(1,-1).split(","):e).pipe(St(JzA)).optional(),num_pins:WA().optional().default(64),w:QA.optional(),h:QA.optional(),p:QA.default(QA.parse("0.5mm")),pw:QA.optional(),pl:QA.optional(),thermalpad:Ze([xA(!0),YzA]).optional(),legsoutside:gt().default(!1)}),rEA=e=>{e.w&&!e.h?e.h=e.w:!e.w&&e.h&&(e.w=e.h);const A=e.num_pins/4;if(!e.p&&!e.pw&&!e.pl&&e.w){const t=A+4;e.p=e.w/t}return!e.p&&e.w&&e.h&&e.pw&&e.pl&&(e.p=(e.w-e.pl*2)/(A-1)),!e.w&&!e.h&&e.p&&(e.w=e.p*(A+4),e.h=e.w),e.p&&!e.pw&&!e.pl?(e.pw=e.p/2,e.pl=e.p/2):e.pw?e.pl||(e.pl=e.pw*(1/.6)):e.pw=e.pl*(.6/1),e},TzA=sEA.transform(rEA),fpe=["left","bottom","right","top"],ype=e=>{const{pin_count:A,pn:t,w:i,h:n,p:o,pl:s,legsoutside:r}=e,a=A/4,g=fpe[Math.floor((t-1)/a)],c=(t-1)%a,I=o*(a-1),l=o*(a-1),B=r?s/2:-s/2;switch(g){case"left":return{x:-i/2-B+.1,y:l/2-c*o,o:"vert"};case"bottom":return{x:-I/2+c*o,y:-n/2-B+.1,o:"horz"};case"right":return{x:i/2+B-.1,y:-l/2+c*o,o:"vert"};case"top":return{x:I/2-c*o,y:n/2+B-.1,o:"horz"};default:throw new Error("Invalid pin number")}},zN=e=>{const A=TzA.parse(e),t=[],i=ppe(A),n=A.num_pins/4;for(let r=0;r<A.num_pins;r++){const{x:a,y:g,o:c}=ype({pin_count:A.num_pins,pn:r+1,w:A.w,h:A.h,p:A.p??.5,pl:A.pl,legsoutside:A.legsoutside});let I=A.pw,l=A.pl;c==="vert"&&([I,l]=[l,I]);const B=i[r+1];t.push(di(B,a,g,I,l))}if(A.thermalpad)if(typeof A.thermalpad=="boolean"){const r=A.p*(n-1)+A.pw,a=A.p*(n-1)+A.pw;t.push(di(["thermalpad"],0,0,r,a))}else t.push(di(["thermalpad"],0,0,A.thermalpad.x,A.thermalpad.y));const o=[];for(const[r,a,g]of[["top-left",-1,1],["bottom-left",-1,-1],["bottom-right",1,-1],["top-right",1,1]]){const c=A.w/2*a,I=A.h/2*g;let l="none",B=c,C=I;const Q=A.pw*2;i[1]===1&&r==="top-left"?l="in1":i[n*4]===1&&r==="top-left"||i[n*3+1]===1&&r==="top-right"?l="in2":i[n*3]===1&&r==="top-right"||i[n]===1&&r==="bottom-left"?l="in1":i[n+1]===1&&r==="bottom-left"?l="in2":i[n*2]===1&&r==="bottom-right"?l="in1":i[n*2+1]===1&&r==="bottom-right"&&(l="in2");const E=l==="in1"?1:-1;if(A.legsoutside){const h=l==="in1"?A.pl/2:A.pw/2,u=l==="in1"?A.pw/2:A.pl/2;B+=h*a*E,C-=u*g*E}(l==="none"||A.legsoutside)&&o.push({layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:`pcb_silkscreen_path_${r}`,route:[{x:c-Q*a,y:I},{x:c,y:I},{x:c,y:I-Q*g}],type:"pcb_silkscreen_path",stroke_width:.1}),(l==="in1"||l==="in2")&&!A.legsoutside&&o.push({layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:`pcb_silkscreen_path_${r}_1`,route:[{x:c-Q*a,y:I},{x:c-Q*a/2,y:I}],type:"pcb_silkscreen_path",stroke_width:0},{layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:`pcb_silkscreen_path_${r}_2`,route:[{x:c,y:I-Q*g/2},{x:c,y:I-Q*g}],type:"pcb_silkscreen_path",stroke_width:.1}),(l==="in1"||l==="in2")&&o.push({layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:`pcb_silkscreen_path_${r}_3`,route:[{x:B-.2*-a,y:C+.2*E},{x:B,y:C},{x:B+.2*E*-a,y:C+.2},{x:B-.2*-a,y:C+.2*E}],type:"pcb_silkscreen_path",stroke_width:.1})}const s=Wi(0,A.h/2+(A.legsoutside?A.pl*1.2:.5),.3);return{circuitJson:[...t,...o,s],parameters:A}};sEA.extend({}).transform(rEA);var mpe=e=>(e.legsoutside=!1,e.pl||(e.pl=.875),e.pw||(e.pw=.25),zN(e)),wpe=e=>{if(e.legsoutside=!0,!e.p)switch(e.num_pins){case 32:e.p=.8;break;case 44:case 48:e.p=.5;break;case 64:case 80:case 100:e.p=.5;break;case 144:e.p=.5;break}if(!e.pl)switch(e.num_pins){case 32:case 44:case 48:case 64:case 80:case 100:e.pl=1.475;break;case 144:e.pl=1.6;break}if(!e.pw)switch(e.num_pins){case 32:e.pw=.55;break;case 44:case 48:case 64:case 80:case 100:e.pw=.3;break;case 144:e.pw=.25;break}return zN(e)},Dpe=e=>{e.legsoutside=!0;const A=TzA.parse(e);if(!e.p)switch(e.num_pins){case 44:case 64:e.p=.8;break;case 52:e.w===14?e.p=1:e.p=.65;break;case 208:e.p=.5;break}if(!e.pl)switch(e.num_pins){case 44:case 52:case 64:e.pl=2.25;break;case 208:e.pl=1.65;break;default:e.pl=A.pl*4;break}if(!e.pw)switch(e.num_pins){case 44:case 64:e.pw=.5;break;case 52:e.w===14?e.pw=.45:e.pw=.55;break;case 208:e.pw=.3;break;default:e.pw=A.pw;break}return zN(e)};sEA.extend({}).transform(rEA);var Spe=e=>(e.legsoutside=!1,e.thermalpad===void 0&&(e.thermalpad=!0),zN(e)),bpe=rD({w:"3.9mm",p:"1.27mm"}),xpe=e=>{const A=bpe.parse(e);return{circuitJson:f_(A),parameters:A}},_pe=rD({w:"7.1mm",p:"0.65mm",pl:"1.35mm",pw:"0.40mm",legsoutside:!0}),kpe=e=>{const A=_pe.parse(e);return{circuitJson:f_(A),parameters:A}},Fpe=rD({}),Gpe=e=>{const A=Fpe.parse({fn:"sot363",num_pins:6,w:2.56,p:.65,pw:.4,pl:.65,legoutside:!0});return{circuitJson:f_(A),parameters:A}},Mpe=Zi.extend({fn:H(),num_pins:xA(6).default(6),w:H().default("1.01mm"),h:H().default("1.45mm"),p:H().default("0.5mm"),pl:H().default("0.33mm"),pw:H().default("0.27mm"),string:H().optional()}),Rpe=e=>{const A=Mpe.parse({fn:"sot886",...e}),t=QA.parse(A.w),i=QA.parse(A.h),n=QA.parse(A.p),o=QA.parse(A.pl),s=QA.parse(A.pw),r=[];for(let B=0;B<6;B++){const{x:C,y:Q}=KzA(B+1,t,n,o);r.push(di(B+1,C,Q,o,s))}const a={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-t/2,y:i/2},{x:t/2,y:i/2}],stroke_width:.05,pcb_silkscreen_path_id:""},g={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-t/2,y:-i/2},{x:t/2,y:-i/2}],stroke_width:.05,pcb_silkscreen_path_id:""},c=KzA(1,t,n,o),I={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"pin_marker_1",route:[{x:c.x-o/2-.3,y:c.y},{x:c.x-o/2-.45,y:c.y+.15},{x:c.x-o/2-.45,y:c.y-.15},{x:c.x-o/2-.3,y:c.y}],stroke_width:.05,pcb_silkscreen_path_id:"pin_marker_1"},l=Wi(0,i/2+.4,.25);return{circuitJson:[...r,a,g,l,I],parameters:A}},KzA=(e,A,t,i)=>{const n=A/2-i/2;return e<=3?{x:-n,y:t-(e-1)*t}:{x:n,y:-t+(e-4)*t}},PzA=Zi.extend({fn:H(),num_pins:WA().default(3),w:H().default("1.92mm"),h:H().default("2.74mm"),pl:H().default("1.32mm"),pw:H().default("0.6mm"),p:H().default("0.95mm"),string:H().optional()}),Npe=rD({p:"0.95mm",w:"1.6mm",legsoutside:!0}),vpe=e=>{const A=e.string?.match(/^sot23_(\d+)/),t=A?Number.parseInt(A[1],10):3;if(t===6||t===8){const n=Npe.parse({...e,num_pins:t});return{circuitJson:f_(n),parameters:n}}const i=PzA.parse({...e,num_pins:t});if(i.num_pins===3)return{circuitJson:Upe(i),parameters:i};if(i.num_pins===5)return{circuitJson:OzA(i),parameters:i};throw new Error("Invalid number of pins")},Lpe=e=>{const{pn:A,p:t}=e;return A===1?{x:-1.155,y:t}:A===2?{x:-1.155,y:-t}:{x:1.15,y:0}},Upe=e=>{const A=[];for(let i=0;i<e.num_pins;i++){const{x:n,y:o}=Lpe({num_pins:e.num_pins,pn:i+1,w:Number.parseFloat(e.w),h:Number.parseFloat(e.h),pl:Number.parseFloat(e.pl),p:Number.parseFloat(e.p)});A.push(di(i+1,n,o,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}const t=Wi(0,Number.parseInt(e.h),.3);return[...A,t]},qzA=e=>{const{p:A,h:t,pn:i}=e;if(i===1)return{x:-t/2-.5,y:A};if(i===2)return{x:-t/2-.5,y:0};if(i===3)return{x:-t/2-.5,y:-A};if(i===4)return{x:t/2+.5,y:-A};if(i===5)return{x:t/2+.5,y:A};throw new Error("Invalid pin number")},OzA=e=>{const A=[];for(let I=1;I<=e.num_pins;I++){const{x:l,y:B}=qzA({h:Number.parseFloat(e.h),p:Number.parseFloat(e.p),pn:I});A.push(di(I,l,B,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}const t=(e.num_pins+1)/2*Number.parseFloat(e.p),i=Number.parseFloat(e.h),n={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-t/3,y:i/2+Number.parseFloat(e.p)/1.3},{x:t/3,y:i/2+Number.parseFloat(e.p)/1.3}],type:"pcb_silkscreen_path",stroke_width:.05},o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-t/3,y:-i/2-Number.parseFloat(e.p)/1.3},{x:t/3,y:-i/2-Number.parseFloat(e.p)/1.3}],type:"pcb_silkscreen_path",stroke_width:.05},s=Wi(0,i+.3,.3),r=qzA({h:Number.parseFloat(e.h),p:Number.parseFloat(e.p),pn:1});r.x=r.x-Number.parseFloat(e.pw)*1.5;const a=.3,g=.4,c={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"pin1_indicator",route:[{x:r.x+a/2,y:r.y},{x:r.x-a/2,y:r.y+g/2},{x:r.x-a/2,y:r.y-g/2},{x:r.x+a/2,y:r.y}],stroke_width:.05};return[...A,s,n,o,c]},Hpe=PzA.extend({}),Ype=e=>{const A=Hpe.parse({...e,num_pins:5});return{circuitJson:OzA(A),parameters:A}},Jpe=[{name:"top-left",dx:-1,dy:1},{name:"top-right",dx:1,dy:1},{name:"bottom-left",dx:-1,dy:-1},{name:"bottom-right",dx:1,dy:-1}],Tpe=rD({}),Kpe=e=>{const A=Tpe.parse(e),t=[];for(let I=0;I<A.num_pins;I++){const{x:l,y:B}=oEA({num_pins:A.num_pins,pn:I+1,w:A.w,p:A.p??1.27,pl:A.pl,widthincludeslegs:!0});t.push(di(I+1,l,B,A.pl??"1mm",A.pw??"0.6mm"))}const i=Math.min(1,A.p/2),n=A.w+i,o=(A.num_pins/2-1)*A.p+A.pw+i,s=[];for(const I of Jpe){const{dx:l,dy:B}=I;s.push({layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"",route:[{x:l*n/2-l*A.p,y:B*o/2},{x:l*n/2,y:B*o/2},{x:l*n/2,y:B*o/2-B*A.p}],type:"pcb_silkscreen_path",stroke_width:.1})}const r=A.p/4,a=-n/2-r/2,g=o/2-A.p/2;s.push({layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"",type:"pcb_silkscreen_path",route:[{x:a,y:g},{x:a-r,y:g+r},{x:a-r,y:g-r},{x:a,y:g}],stroke_width:.1});const c=Wi(0,o/2+.4,o/12);return{circuitJson:[...t,c,...s],parameters:A}},aEA=({fs:e,pn:A,anchor_x:t,anchor_y:i,textalign:n="center",orthogonal:o=!1,verticallyinverted:s=!1,layer:r="top"})=>{let a=0;o&&s?a=270:s?a=180:o?a=90:a=0;let g="center";return n==="left"&&(s?g="center_right":g="center_left"),n==="right"&&(s?g="center_left":g="center_right"),r==="bottom"&&(g==="center_left"?g="center_right":g==="center_right"&&(g="center_left")),{type:"pcb_silkscreen_text",pcb_silkscreen_text_id:"silkscreen_text_1",font:"tscircuit2024",font_size:e,pcb_component_id:"pcb_component_1",text:`{PIN${A}}`,layer:r,anchor_position:{x:t,y:i},anchor_alignment:g,ccw_rotation:a}};function Ppe({pinlabeltextalignleft:e,pinlabeltextalignright:A,pinlabelorthogonal:t}){let i="top";return t?i="left":i="top",e&&(t?i="bottom":i="right"),A&&(t?i="top":i="left"),i}var qpe=Zi.extend({fn:H(),num_pins:WA().optional().default(6),rows:Ze([H(),WA()]).transform(e=>Number(e)).optional().default(1).describe("number of rows"),p:QA.default("0.1in").describe("pitch"),id:QA.default("1.0mm").describe("inner diameter"),od:QA.default("1.5mm").describe("outer diameter"),male:gt().optional().describe("for male pin headers"),female:gt().optional().describe("for female pin headers"),smd:gt().optional().describe("surface mount device"),surfacemount:gt().optional().describe("surface mount device (verbose)"),rightangle:gt().optional().describe("right angle"),pw:QA.optional().default("1.0mm").describe("pad width for SMD"),pl:QA.optional().default("2.0mm").describe("pad length for SMD"),pinlabeltextalignleft:gt().optional().default(!1),pinlabeltextaligncenter:gt().optional().default(!1),pinlabeltextalignright:gt().optional().default(!1),pinlabelverticallyinverted:gt().optional().default(!1),pinlabelorthogonal:gt().optional().default(!1),nosquareplating:gt().optional().default(!1).describe("do not use rectangular pad for pin 1"),nopinlabels:gt().optional().default(!1).describe("omit silkscreen pin labels"),doublesidedpinlabel:gt().optional().default(!1).describe("add silkscreen pins in top and bottom layers"),bottomsidepinlabel:gt().optional().default(!1).describe("place the silkscreen reference text on the bottom layer instead of top")}).transform(e=>{const A=Ppe(e);return{...e,pinlabelAnchorSide:A,male:e.male??!e.female,female:e.female??!1,smd:e.smd??e.surfacemount??!1,rightangle:e.rightangle??!1}}).superRefine((e,A)=>{e.male&&e.female&&A.addIssue({code:Oe.custom,message:"'male' and 'female' cannot both be true; it should be male or female.",path:["male","female"]})}),Ope=e=>{const A=qpe.parse(e),{p:t,id:i,od:n,rows:o,num_pins:s,pinlabelAnchorSide:r,pinlabelverticallyinverted:a,pinlabelorthogonal:g,pinlabeltextalignleft:c,pinlabeltextalignright:I,nopinlabels:l,doublesidedpinlabel:B,bottomsidepinlabel:C}=A;let Q="center";c?Q="left":I&&(Q="right");const E=[],h=Math.ceil(s/o),u=-t,d=({xoff:b,yoff:k,od:x,anchorSide:N,smd:R,pw:U,pl:T})=>{let Y=0,O=0;if(R){const W=x/5;switch(N){case"right":Y=U/2+W;break;case"top":O=T/2+W;break;case"bottom":O=-(T/2+W);break;case"left":Y=-(U/2+W);break}}else{const W=x*.75;switch(N){case"right":Y=W;break;case"top":O=W;break;case"bottom":O=-W;break;case"left":Y=-W;break}}return{anchor_x:b+Y,anchor_y:k+O}},f=(b,k,x)=>{A.smd?E.push(di(b,k,x,A.pw,A.pl)):b===1&&!A.nosquareplating?E.push(sb(b,k,x,i,n,n,0,0)):E.push(jo(b,k,x,i,n));const{anchor_x:N,anchor_y:R}=d({xoff:k,yoff:x,od:n,anchorSide:r,smd:A.smd,pw:A.pw,pl:A.pl});l||(C?E.push(aEA({fs:n/5,pn:b,anchor_x:N,anchor_y:R,textalign:Q,orthogonal:g,verticallyinverted:a,layer:"bottom"})):E.push(aEA({fs:n/5,pn:b,anchor_x:N,anchor_y:R,textalign:Q,orthogonal:g,verticallyinverted:a,layer:"top"})),B&&E.push(aEA({fs:n/5,pn:b,anchor_x:N,anchor_y:R,textalign:Q,orthogonal:g,verticallyinverted:a,layer:"bottom"})))},m=new Set,w=o>2&&h>2;if(o===1){const b=-((s-1)/2)*t;for(let k=0;k<s;k++){const x=k+1,N=b+k*t,R=`${N},0`;if(m.has(R))throw new Error(`Overlap at ${R}`);m.add(R),f(x,N,0)}}else if(w){const b=-((h-1)/2)*t;let k=1;for(let x=0;x<o&&k<=s;x++)for(let N=0;N<h&&k<=s;N++){const R=b+N*t,U=x*u,T=`${R},${U}`;if(m.has(T))throw new Error(`Overlap at ${T}`);m.add(T),f(k++,R,U)}}else{const b=-((h-1)/2)*t;let k=1,x=0,N=o-1,R=0,U=h-1;for(;k<=s&&x<=N&&R<=U;){for(let T=x;T<=N&&k<=s;T++){const Y=b+R*t,O=T*u,W=`${Y},${O}`;if(m.has(W))throw new Error(`Overlap at ${W}`);m.add(W),f(k++,Y,O)}R++;for(let T=R;T<=U&&k<=s;T++){const Y=b+T*t,O=N*u,W=`${Y},${O}`;if(m.has(W))throw new Error(`Overlap at ${W}`);m.add(W),f(k++,Y,O)}if(N--,R<=U){for(let T=N;T>=x&&k<=s;T--){const Y=b+U*t,O=T*u,W=`${Y},${O}`;if(m.has(W))throw new Error(`Overlap at ${W}`);m.add(W),f(k++,Y,O)}U--}if(x<=N){for(let T=U;T>=R&&k<=s;T--){const Y=b+T*t,O=x*u,W=`${Y},${O}`;if(m.has(W))throw new Error(`Overlap at ${W}`);m.add(W),f(k++,Y,O)}x++}}if(k-1<s)throw new Error(`Missing pins: assigned ${k-1}, expected ${s}`)}const D=Wi(0,t,.5);return{circuitJson:[...E,D],parameters:A}},Wpe=Zi.extend({fn:H(),num_pins:xA(6).default(6),w:H().default("2.1mm"),h:H().default("2.45mm"),p:H().default("0.5mm"),pl:H().default("0.675mm"),pw:H().default("0.35mm"),string:H().optional()}),Zpe=e=>{const A=Wpe.parse({...e,fn:"sot563"}),t=QA.parse(A.w),i=QA.parse(A.h),n=QA.parse(A.p),o=QA.parse(A.pl),s=QA.parse(A.pw),r=[];for(let B=0;B<6;B++){const{x:C,y:Q}=WzA(B+1,t,n,o);r.push(di(B+1,C,Q,o,s))}const a={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-t/2,y:i/2},{x:t/2,y:i/2}],stroke_width:.05,pcb_silkscreen_path_id:""},g={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-t/2,y:-i/2},{x:t/2,y:-i/2}],stroke_width:.05,pcb_silkscreen_path_id:""},c=WzA(1,t,n,o),I={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"pin_marker_1",route:[{x:c.x-o/2-.3,y:c.y},{x:c.x-o/2-.45,y:c.y+.15},{x:c.x-o/2-.45,y:c.y-.15},{x:c.x-o/2-.3,y:c.y}],stroke_width:.05,pcb_silkscreen_path_id:"pin_marker_1"},l=Wi(0,i/2+.4,.25);return{circuitJson:[...r,a,g,l,I],parameters:A}},WzA=(e,A,t,i)=>{const n=A/2-i/2;return e<=3?{x:-n,y:t-(e-1)*t}:{x:n,y:-t+(e-4)*t}},Vpe=rD({p:"1.27mm",w:"3.9mm",legsoutside:!0}),jpe=e=>{const A=Vpe.parse({...e,num_pins:8});return{circuitJson:f_(A),parameters:A}},zpe=rD({p:"1.27mm",w:"7.5mm",legsoutside:!0}),Xpe=e=>{const A=zpe.parse({...e,num_pins:16});return{circuitJson:f_(A),parameters:A}},$pe=Zi.extend({fn:H(),num_pins:xA(3).default(3),w:H().default("1.2mm"),h:H().default("1.2mm"),pw:H().default("0.40mm"),pl:H().default("0.45mm"),p:H().default("0.575mm")}),Afe=e=>{const A=$pe.parse(e),t=efe(A),i=Wi(0,QA.parse(A.h),.2);return{circuitJson:[...t,i],parameters:A}},tfe=e=>{const{pn:A,p:t}=e;return A===1?{x:t,y:0}:A===2?{x:-t,y:-.4}:{x:-t,y:.4}},efe=e=>{const A=[];for(let t=0;t<3;t++){const{x:i,y:n}=tfe({num_pins:e.num_pins,pn:t+1,w:Number.parseFloat(e.w),h:Number.parseFloat(e.h),pl:Number.parseFloat(e.pl),p:Number.parseFloat(e.p)});A.push(di(t+1,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},ife=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("2.36mm"),h:H().default("1.22mm"),pl:H().default("0.9mm"),pw:H().default("1.2mm"),p:H().default("3.30mm")}),nfe=e=>{const A=ife.parse(e),t=Wi(0,QA.parse(A.h)/4+.4,.3);return{circuitJson:sfe(A).concat(t),parameters:A}},ofe=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},sfe=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=ofe({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},rfe=Zi.extend({fn:H(),p:QA.optional().default("2.54mm"),id:QA.optional().default("0.7mm"),od:QA.optional().default("1.4mm")}),afe=e=>{const A=rfe.parse(e),{p:t,id:i,od:n}=A,o=[jo(1,-t/2,0,i,n),jo(2,t/2,0,i,n)],s={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-t/2+n+i/2,y:0},{x:t/2-n-i/2,y:0}],stroke_width:.1,pcb_silkscreen_path_id:""},r=Wi(0,1.5,.5);return{circuitJson:[...o,s,r],parameters:A}},gfe=(e,A,t,i,n,o=.1)=>{const s=[],r=[],a=Math.max(1,Math.ceil(Math.PI*t/o)),g=Math.PI/a;for(let c=0;c<=a;c++){const I=c*g,l=e+Math.cos(I)*t,B=A+Math.sin(I)*t;l<e-i&&B>=A-n/2&&B<=A+n/2||s.push({x:l,y:B})}for(let c=0;c<=a;c++){const I=Math.PI+c*g,l=e+Math.cos(I)*t,B=A+Math.sin(I)*t;l<e-i&&B>=A-n/2&&B<=A+n/2||r.push({x:l,y:B})}return{topArc:s,bottomArc:r}},cfe=Zi.extend({fn:H(),p:QA.optional().default("5mm"),id:QA.optional().default("0.8mm"),od:QA.optional().default("1.6mm"),ceramic:gt().optional(),electrolytic:gt().optional(),polarized:gt().optional()}),Ife=e=>{const A=cfe.parse(e),{p:t,id:i,od:n}=A;i===.8&&n===1.6&&(A.id=t===5?.8:t*.25,A.od=t===5?1.6:t*.5);const o=[jo(1,-t/2,0,A.id,A.od),jo(2,t/2,0,A.id,A.od)],s=t+.1,{topArc:r,bottomArc:a}=gfe(0,0,s,A.od/2,A.od),g=.02*t,c={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:r,stroke_width:g,pcb_silkscreen_path_id:""},I={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:a,stroke_width:g,pcb_silkscreen_path_id:""},l={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:0,y:s},{x:0,y:-s}],stroke_width:g,pcb_silkscreen_path_id:""},B=.1*t,C=-(t+B+.04*t),Q=s-B-.08*t,E={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:C-B,y:Q},{x:C+B,y:Q}],stroke_width:g,pcb_silkscreen_path_id:""},h={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:C,y:Q-B},{x:C,y:Q+B}],stroke_width:g,pcb_silkscreen_path_id:""},u=Wi(0,s+.12*t,.1*t),d=[...o,c,I,l,u];return(A.electrolytic===!0||A.polarized===!0)&&d.push(E,h),{circuitJson:d,parameters:A}},rW=(e,A={})=>({type:"pcb_silkscreen_path",layer:A.layer||"top",pcb_component_id:A.pcb_component_id||"",pcb_silkscreen_path_id:A.pcb_silkscreen_path_id||"",route:e,stroke_width:A.stroke_width||.1}),lfe=Zi.extend({fn:xA("pushbutton"),w:QA.default(4.5),h:QA.default(6.5),id:QA.default(1),od:QA.default(1.2)}),Bfe=e=>{const A=lfe.parse(e),t=A.w,i=A.h,n=A.id,o=[jo(1,-t/2,i/2,n,n*1.5),jo(2,-t/2,-i/2,n,n*1.5),jo(3,t/2,-i/2,n,n*1.5),jo(4,t/2,i/2,n,n*1.5)],s=[rW([{x:-t/2,y:-i/2},{x:-t/2,y:i/2}]),rW([{x:t/2,y:-i/2},{x:t/2,y:i/2}]),rW([{x:-t/2,y:0},{x:-t/5,y:0},{x:t/5*1/Math.sqrt(2),y:i/8}]),rW([{x:t/2,y:0},{x:t/5,y:0}])],r=Wi(0,i/2+.4,.5);return{circuitJson:[...o,...s,r],parameters:A}},ZzA=Zi.extend({fn:H(),w:QA.default("22.58mm"),h:QA.optional(),left:QA.optional().default(20),right:QA.optional().default(20),top:QA.optional().default(2),bottom:QA.optional().default(2),p:QA.default(QA.parse("2.54mm")),pw:QA.default(QA.parse("1.6mm")),pl:QA.default(QA.parse("2.4mm")),innerhole:gt().default(!1),innerholeedgedistance:QA.default(QA.parse("1.61mm")),silkscreenlabels:gt().default(!1),silkscreenlabelmargin:QA.default(QA.parse("0.1mm"))}),Cfe=e=>{const A=ZzA.parse(e);return A.left&&A.right?Math.max(A.left,A.right)*A.p:A.left?A.left*A.p:A.right?A.right*A.p:51},aW=(e,A,t)=>{let i=[];return t==="right"&&(i=[{x:e+1/2,y:A},{x:e-1/2,y:A+.6/2},{x:e-1/2,y:A-.6/2},{x:e+1/2,y:A}]),t==="left"&&(i=[{x:e-1/2,y:A},{x:e+1/2,y:A+.6/2},{x:e+1/2,y:A-.6/2},{x:e-1/2,y:A}]),t==="top"&&(i=[{x:e,y:A+1/2},{x:e-.6/2,y:A-1/2},{x:e+.6/2,y:A-1/2},{x:e,y:A+1/2}]),t==="bottom"&&(i=[{x:e,y:A-1/2},{x:e-.6/2,y:A+1/2},{x:e+.6/2,y:A+1/2},{x:e,y:A-1/2}]),i},Qfe=e=>{const A=ZzA.parse(e),t=A.h??Cfe(A),i=[],n=[],o=[];let s=[];const r=1,a=r,g=A.left+A.right+(A.bottom??0)+(A.top??0),I=`pin${g}`.length*.7/2;if(A.right){const Q=-((A.right-1)/2)*A.p;for(let E=0;E<A.right;E++){if(E===0&&!A.left&&!A.bottom&&!A.silkscreenlabels&&(s=aW(A.w/2-A.pl*1.4,Q+E*A.p,"right")),i.push(di(E+1+A.left+(A.bottom??0),A.w/2-A.pl/2,Q+E*A.p,A.pl,A.pw)),A.silkscreenlabels){const h=E+1+A.left+(A.bottom??0),u=`pin${h}`;o.push({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:`pin_${h}`,pcb_component_id:"1",layer:"top",anchor_position:{x:A.w/2-A.pl-(I+A.silkscreenlabelmargin),y:Q+E*A.p},text:u,font_size:.7,font:"tscircuit2024",anchor_alignment:"center"})}A.innerhole&&(n.push(jo(E+1+A.left+(A.bottom??0)+g,A.w/2,Q+E*A.p,r,a)),n.push(jo(E+1+A.left+(A.bottom??0)+g*2,A.w/2-A.innerholeedgedistance,Q+E*A.p,r,a)))}}if(A.left){const Q=(A.left-1)/2*A.p;for(let E=0;E<A.left;E++){if(E===0&&!A.silkscreenlabels&&(s=aW(-A.w/2+A.pl*1.4,Q-E*A.p,"left")),i.push(di(E+1,-A.w/2+A.pl/2,Q-E*A.p,A.pl,A.pw)),A.silkscreenlabels){const h=E+1,u=`pin${h}`;o.push({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:`pin_${h}`,pcb_component_id:"1",layer:"top",anchor_position:{x:-A.w/2+A.pl+(I+A.silkscreenlabelmargin),y:Q-E*A.p},text:u,font_size:.7,font:"tscircuit2024",anchor_alignment:"center"})}A.innerhole&&(n.push(jo(E+1+g,-A.w/2,Q-E*A.p,r,a)),n.push(jo(E+1+g*2,-A.w/2+A.innerholeedgedistance,Q-E*A.p,r,a)))}}if(A.top){const Q=(A.top-1)/2*A.p;for(let E=0;E<A.top;E++){if(E===0&&!A.left&&!A.bottom&&!A.right&&!A.silkscreenlabels&&(s=aW(Q-E*A.p,t/2-A.pl*1.4,"top")),i.push(di(E+1+A.left+A.right+(A.bottom??0),Q-E*A.p,t/2-A.pl/2,A.pw,A.pl)),A.silkscreenlabels){const h=E+1+A.left+A.right+(A.bottom??0),u=`pin${h}`;o.push({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:`pin_${h}`,pcb_component_id:"1",layer:"top",anchor_position:{x:Q-E*A.p,y:t/2-A.pl-(I+A.silkscreenlabelmargin)},text:u,font_size:.7,font:"tscircuit2024",anchor_alignment:"center",ccw_rotation:270})}A.innerhole&&(n.push(jo(E+1+A.left+A.right+(A.bottom??0)+g,Q-E*A.p,t/2,r,a)),n.push(jo(E+1+A.left+A.right+(A.bottom??0)+g*2,Q-E*A.p,t/2-A.innerholeedgedistance,r,a)))}}if(A.bottom){const Q=-((A.bottom-1)/2)*A.p;for(let E=0;E<A.bottom;E++){if(E===0&&!A.left&&!A.silkscreenlabels&&(s=aW(Q+E*A.p,-t/2+A.pl*1.4,"bottom")),i.push(di(E+1+A.left,Q+E*A.p,-t/2+A.pl/2,A.pw,A.pl)),A.silkscreenlabels){const h=E+1+A.left,u=`pin${h}`;o.push({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:`pin_${h}`,pcb_component_id:"1",layer:"top",anchor_position:{x:Q+E*A.p,y:-t/2+A.pl+(I+A.silkscreenlabelmargin)},text:u,font_size:.7,font:"tscircuit2024",anchor_alignment:"center",ccw_rotation:90})}A.innerhole&&(n.push(jo(E+1+A.left+g,Q+E*A.p,-t/2,r,a)),n.push(jo(E+1+A.left+g*2,Q+E*A.p,-t/2+A.innerholeedgedistance,r,a)))}}const l={type:"pcb_silkscreen_path",pcb_silkscreen_path_id:"pcb_silkscreen_triangle_1",pcb_component_id:"2",route:s,stroke_width:.1,layer:"top"},B={type:"pcb_silkscreen_path",pcb_silkscreen_path_id:"pcb_silkscreen_path_1",pcb_component_id:"1",route:[{x:-A.w/2,y:t/2},{x:A.w/2,y:t/2},{x:A.w/2,y:-t/2},{x:-A.w/2,y:-t/2},{x:-A.w/2,y:t/2}],stroke_width:.1,layer:"top"},C=Wi(0,t/1.8,t/25);return{circuitJson:[...i,...n,...o,B,...A.silkscreenlabels?[]:[l],C],parameters:A}},VzA=Zi.extend({fn:H(),w:QA.default("22.58mm"),h:QA.optional(),left:QA.optional().default(20),right:QA.optional().default(20),top:QA.optional().default(2),bottom:QA.optional().default(2),p:QA.default(QA.parse("2.54mm")),pw:QA.default(QA.parse("1.6mm")),pl:QA.default(QA.parse("3.2mm")),innerhole:gt().default(!1),innerholeedgedistance:QA.default(QA.parse("1.61mm"))}),Efe=e=>{const A=VzA.parse(e);return A.left&&A.right?Math.max(A.left,A.right)*A.p:A.left?A.left*A.p:A.right?A.right*A.p:51},hfe=(e,A,t,i=1,n=.6)=>{const o=i/2,s=n/2;return{left:[{x:e+o,y:A},{x:e-o,y:A+s},{x:e-o,y:A-s},{x:e+o,y:A}],right:[{x:e-o,y:A},{x:e+o,y:A+s},{x:e+o,y:A-s},{x:e-o,y:A}],top:[{x:e,y:A-o},{x:e-s,y:A+o},{x:e+s,y:A+o},{x:e,y:A-o}],bottom:[{x:e,y:A+o},{x:e-s,y:A-o},{x:e+s,y:A-o},{x:e,y:A+o}]}[t]},ufe=e=>{const A=VzA.parse(e),t=A.h??Efe(A),i=[],n=[],o=[],s=1,r=1.2,a=A.left+A.right+(A.bottom??0)+(A.top??0);let g=[],c=1;if(A.left){const C=(A.left-1)/2*A.p;for(let Q=0;Q<A.left;Q++)Q===0&&(g=hfe(-A.w/2-A.pl/2,C-Q*A.p,"left")),i.push(di(c,-A.w/2+A.pl/2,C-Q*A.p,A.pl,A.pw)),n.push({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:`pin_${c}`,pcb_component_id:"1",layer:"top",anchor_position:{x:-A.w/2+A.pl/2-4.5,y:C-Q*A.p},text:`pin${c}`,font_size:.7,font:"tscircuit2024",anchor_alignment:"center"}),c++,A.innerhole&&o.push(jo(c+a,-A.w/2+A.innerholeedgedistance,C-Q*A.p,s,r))}if(A.bottom){const C=(A.bottom-1)/2*A.p;for(let Q=A.bottom-1;Q>=0;Q--)i.push(di(c,C-Q*A.p,-t/2+A.pl/2,A.pw,A.pl)),n.push({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:`pin_${c}`,pcb_component_id:"1",layer:"top",anchor_position:{x:C-Q*A.p,y:-t/2+A.pl/2-3.2},text:`pin${c}`,font_size:.7,font:"tscircuit2024",anchor_alignment:"center"}),c++,A.innerhole&&o.push(jo(c+a,C-Q*A.p,-t/2+A.innerholeedgedistance,s,r))}if(A.right){const C=-((A.right-1)/2)*A.p;for(let Q=0;Q<A.right;Q++)i.push(di(c,A.w/2-A.pl/2,C+Q*A.p,A.pl,A.pw)),n.push({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:`pin_${c}`,pcb_component_id:"1",layer:"top",anchor_position:{x:A.w/2-A.pl/2+3.7,y:C+Q*A.p},text:`pin${c}`,font_size:.7,font:"tscircuit2024",anchor_alignment:"center"}),c++,A.innerhole&&o.push(jo(c+a,A.w/2-A.innerholeedgedistance,C+Q*A.p,s,r))}if(A.top){const C=-((A.top-1)/2)*A.p;for(let Q=A.top-1;Q>=0;Q--)i.push(di(c,C+Q*A.p,t/2-A.pl/2,A.pw,A.pl)),n.push({type:"pcb_silkscreen_text",pcb_silkscreen_text_id:`pin_${c}`,pcb_component_id:"1",layer:"top",anchor_position:{x:C+Q*A.p,y:t/2-A.pl/2+3.2},text:`pin${c}`,font_size:.7,font:"tscircuit2024",anchor_alignment:"center"}),c++,A.innerhole&&o.push(jo(c+a,C+Q*A.p,t/2-A.innerholeedgedistance,s,r))}const I={type:"pcb_silkscreen_path",pcb_silkscreen_path_id:"1",pcb_component_id:"1",layer:"top",route:g,stroke_width:.1},l={type:"pcb_silkscreen_path",pcb_silkscreen_path_id:"pcb_silkscreen_path_1",pcb_component_id:"1",route:[{x:-A.w/2-A.pl/3,y:t/2+A.pl/3},{x:A.w/2+A.pl/3,y:t/2+A.pl/3},{x:A.w/2+A.pl/3,y:-t/2-A.pl/3},{x:-A.w/2-A.pl/3,y:-t/2-A.pl/3},{x:-A.w/2-A.pl/3,y:t/2+A.pl/3}],stroke_width:.1,layer:"top"},B=Wi(0,t/1.8,t/25);return{circuitJson:[...o,...i,...n,l,I,B],parameters:A}},dfe=e=>(e.legsoutside=!0,e.pl||(e.pl=1.5),e.pw||(e.pw=.3),zN(e)),jzA=Zi.extend({fn:H(),w:QA.default("10mm"),h:QA.optional(),left:QA.optional().default(20),right:QA.optional().default(20),top:QA.optional().default(0),bottom:QA.optional().default(0),p:QA.default(QA.parse("2.54mm")),id:QA.optional().default(QA.parse("1mm")),od:QA.optional().default(QA.parse("1.5mm"))}),pfe=e=>{const A=jzA.parse(e);return A.left&&A.right?Math.max(A.left,A.right)*A.p:A.left?A.left*A.p:A.right?A.right*A.p:51},gW=(e,A,t,i=1,n=.6)=>{const o=i/2,s=n/2;return{left:[{x:e+o,y:A},{x:e-o,y:A+s},{x:e-o,y:A-s},{x:e+o,y:A}],right:[{x:e-o,y:A},{x:e+o,y:A+s},{x:e+o,y:A-s},{x:e-o,y:A}],top:[{x:e,y:A-o},{x:e-s,y:A+o},{x:e+s,y:A+o},{x:e,y:A-o}],bottom:[{x:e,y:A+o},{x:e-s,y:A-o},{x:e+s,y:A-o},{x:e,y:A+o}]}[t]},ffe=e=>{const A=jzA.parse(e),t=A.h??pfe(A),i=[],n=A.id,o=A.od;let s=[];if(A.right){const c=-((A.right-1)/2)*A.p;for(let I=0;I<A.right;I++)I===0&&!A.left&&!A.bottom&&(s=gW(A.w/2+o*1.4,c+I*A.p,"right")),i.push(jo(I+1+A.left+(A.bottom??0),A.w/2,c+I*A.p,n,o))}if(A.left){const c=-((A.left-1)/2)*A.p;for(let I=0;I<A.left;I++)I===A.left-1&&(s=gW(-A.w/2-o*1.4,c+I*A.p,"left")),i.push(jo(I+1,-A.w/2,c+I*A.p,n,o))}if(A.top){const c=-((A.top-1)/2)*A.p;for(let I=0;I<A.top;I++)I===A.top-1&&!A.left&&!A.bottom&&!A.right&&(s=gW(c+I*A.p,t/2+o*1.4,"top")),i.push(jo(I+1+A.right+(A.bottom??0)+A.left,c+I*A.p,t/2,n,o))}if(A.bottom){const c=-((A.bottom-1)/2)*A.p;for(let I=0;I<A.bottom;I++)I===0&&!A.left&&(s=gW(c+I*A.p,-t/2-o*1.4,"bottom")),i.push(jo(I+1+A.left,c+I*A.p,-t/2,n,o))}const r={type:"pcb_silkscreen_path",pcb_silkscreen_path_id:"1",pcb_component_id:"1",layer:"top",route:s,stroke_width:.1},a={type:"pcb_silkscreen_path",pcb_silkscreen_path_id:"pcb_silkscreen_path_1",pcb_component_id:"1",route:[{x:-A.w/2-o,y:t/2+o},{x:A.w/2+o,y:t/2+o},{x:A.w/2+o,y:-t/2-o},{x:-A.w/2-o,y:-t/2-o},{x:-A.w/2-o,y:t/2+o}],stroke_width:.1,layer:"top"},g=Wi(0,t/1.7,t/25);return{circuitJson:[...i,a,g,r],parameters:A}},zzA=(e,A,t,i)=>Array.from({length:25},(n,o)=>{const s=o/24*Math.PI-Math.PI/2;return{x:e+(i==="right"?1:-1)*Math.cos(s)*t,y:A+Math.sin(s)*t}}),yfe=Zi.extend({fn:H(),p:QA.optional().default("4.88mm"),id:QA.optional().default("0.8mm"),od:QA.optional().default("1.5mm"),w:QA.optional().default("5.6mm"),h:QA.optional().default("3.5mm")}),mfe=e=>{const A=yfe.parse(e),{p:t,id:i,od:n,w:o,h:s}=A,r=s/2,a=[jo(1,-t/2,0,i,n),jo(2,t/2,0,i,n)],g=zzA(-o/2,0,r,"left"),c=zzA(o/2,0,r,"right"),I={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[...g,...g.slice(1).reverse(),{x:-o/2,y:-s/2},{x:o/2,y:-s/2},...c,{x:o/2,y:s/2},{x:-o/2,y:s/2}],stroke_width:.1,pcb_silkscreen_path_id:""},l=Wi(0,t/4,.5);return{circuitJson:[...a,I,l],parameters:A}};Zi.extend({w:QA,h:QA});var wfe=e=>{const{w:A,h:t}=e,i=Fr(A),n=Fr(t);return{circuitJson:[di(1,0,0,i,n),Wi(0,n/2+.5,.2)],parameters:e}},rH=(e,A,t,i,n,o)=>({pcb_plated_hole_id:"",type:"pcb_plated_hole",shape:"pill",x:A,y:t,outer_width:Fr(n),outer_height:Fr(o),hole_width:Fr(i),hole_height:Fr(i),pcb_port_id:"",layers:["top","bottom"],port_hints:[e.toString()],ccw_rotation:0}),Dfe=Zi.extend({fn:H(),num_pins:Ze([xA(3),xA(2)]).default(3),p:H().default("1.27mm"),id:H().default("0.72mm"),od:H().default("0.95mm"),w:H().default("4.5mm"),h:H().default("4.5mm"),inline:gt().default(!1),string:H().optional()}),Sfe=(e,A,t)=>Array.from({length:25},(i,n)=>{const o=n/24*Math.PI;return{x:e+Math.cos(o)*t,y:A+Math.sin(o)*t}}),bfe=e=>{const A=e.string?.match(/^to92_(\d+)/),t=A?Number.parseInt(A[1],10):3,i=Dfe.parse({...e,num_pins:t}),{p:n,id:o,od:s,w:r,h:a,inline:g}=i,c=Number.parseFloat(a)/2,I=Number.parseFloat(n),l=Number.parseFloat(o),B=Number.parseFloat(s),C=B,Q=B*(1.5/1.05);let E=[];if(i.num_pins===3)g?E=[sb(1,-I,c-I,l,B,Q,0,0),rH(2,0,c-I,l,C,Q),rH(3,I,c-I,l,C,Q)]:E=[sb(1,-I,c-I,l,B,B,0,0),jo(2,0,c,l,B),jo(3,I,c-I,l,B)];else if(i.num_pins===2)E=[sb(1,-I,c-I,l,C,Q,0,0),rH(2,I,c-I,l,C,Q)];else throw new Error("Invalid number of pins for TO-92");const h=Number.parseFloat(r)/2,u=Sfe(0,c,h),d={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[...u,{x:-h,y:0},{x:h,y:0},u[0]],stroke_width:.1,pcb_silkscreen_path_id:""},f=Wi(0,c+1,.5);return{circuitJson:[...E,d,f],parameters:i}},xfe=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("2.15mm"),h:H().default("1.20mm"),pl:H().default("0.5mm"),pw:H().default("0.6mm"),p:H().default("1.4mm")}),_fe=e=>{const A=xfe.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:Ffe(A).concat(i,t),parameters:A}},kfe=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},Ffe=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=kfe({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},Gfe=rD({}),Mfe=e=>{const A=Gfe.parse(e),t=[];for(let s=0;s<A.num_pins;s++){const{x:r,y:a}=oEA({num_pins:A.num_pins,pn:s+1,w:A.w,p:A.p??1.27,pl:A.pl,widthincludeslegs:!0});t.push(di(s+1,r,a,A.pl??"1.5mm",A.pw??"0.6mm"))}const i=(A.num_pins/2-1)*A.p+A.pw,n=Wi(0,i/2-.5,i/12),o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"",type:"pcb_silkscreen_path",route:[{x:-A.w/3,y:i/2+.2},{x:A.w/3,y:i/2+.2}],stroke_width:.1};return{circuitJson:[...t,n,o],parameters:A}},Rfe=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("5.0mm"),h:H().default("2.30mm"),pl:H().default("1.25mm"),pw:H().default("2mm"),p:H().default("3.75mm")}),Nfe=e=>{const A=Rfe.parse(e),t=Wi(0,QA.parse(A.h)/2+1,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2+.5,y:QA.parse(A.h)/2+.5},{x:-QA.parse(A.w)/2-.5,y:QA.parse(A.h)/2+.5},{x:-QA.parse(A.w)/2-.5,y:-QA.parse(A.h)/2-.5},{x:QA.parse(A.p)/2+.5,y:-QA.parse(A.h)/2-.5}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:Lfe(A).concat(i,t),parameters:A}},vfe=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},Lfe=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=vfe({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},Ufe=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("4.4mm"),h:H().default("2.1mm"),pl:H().default("1.2mm"),pw:H().default("1.2mm"),p:H().default("2.9mm")}),Hfe=e=>{const A=Ufe.parse(e),t=Wi(0,QA.parse(A.h)-.5,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:Jfe(A).concat(i,t),parameters:A}},Yfe=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},Jfe=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=Yfe({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},Tfe=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("3.30mm"),h:H().default("1.80mm"),pl:H().default("0.60mm"),pw:H().default("0.45mm"),p:H().default("2.1mm")}),Kfe=e=>{const A=Tfe.parse(e),t=Wi(0,QA.parse(A.h)-.5,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:qfe(A).concat(i,t),parameters:A}},Pfe=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},qfe=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=Pfe({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},Ofe=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("1.4mm"),h:H().default("0.9mm"),pl:H().default("0.36mm"),pw:H().default("0.25mm"),p:H().default("0.85mm")}),Wfe=e=>{const A=Ofe.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2+.15,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.15,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.15,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2+.15,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:Vfe(A).concat(i,t),parameters:A}},Zfe=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},Vfe=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=Zfe({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},jfe=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("1.3mm"),h:H().default("0.9mm"),pl:H().default("0.4mm"),pw:H().default("0.7mm"),p:H().default("0.7mm")}),zfe=e=>{const A=jfe.parse(e),t=Wi(0,QA.parse(A.h)+.1,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2+.2,y:QA.parse(A.h)/2+.2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2+.2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2-.2},{x:QA.parse(A.p)/2+.2,y:-QA.parse(A.h)/2-.2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:$fe(A).concat(i,t),parameters:A}},Xfe=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},$fe=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=Xfe({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},A0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("3,05mm"),h:H().default("1.65mm"),pl:H().default("0.6mm"),pw:H().default("0.6mm"),pad_spacing:H().default("2.2mm")}),t0e=e=>{const A=A0e.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.pad_spacing)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2},{x:QA.parse(A.pad_spacing)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:i0e(A).concat(i,t),parameters:A}},e0e=e=>{const{pn:A,pad_spacing:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},i0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=e0e({pn:t,pad_spacing:Number.parseFloat(e.pad_spacing)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},n0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("4.4mm"),h:H().default("2.1mm"),pl:H().default("1.2mm"),pw:H().default("1.2mm"),p:H().default("2.9mm")}),o0e=e=>{const A=n0e.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:r0e(A).concat(i,t),parameters:A}},s0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},r0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=s0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},a0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("4.4mm"),h:H().default("2.1mm"),pl:H().default("0.91mm"),pw:H().default("1.22mm"),p:H().default("3.146mm")}),g0e=e=>{const A=a0e.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:I0e(A).concat(i,t),parameters:A}},c0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},I0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=c0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},l0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("1.80mm"),h:H().default("1.00mm"),pl:H().default("0.66mm"),pw:H().default("0.5mm"),p:H().default("0.8mm")}),B0e=e=>{const A=l0e.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.1,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.1,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:Q0e(A).concat(i,t),parameters:A}},C0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},Q0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=C0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},E0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("6.2mm"),h:H().default("3.4mm"),pl:H().default("1.4mm"),pw:H().default("2.1mm"),p:H().default("4.4mm")}),h0e=e=>{const A=E0e.parse(e),t=Wi(0,QA.parse(A.h)/2+.4,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:d0e(A).concat(i,t),parameters:A}},u0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},d0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=u0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},p0e=Zi.extend({fn:H(),num_pins:Ze([xA(3),xA(5)]).default(3),w:H().default("4.20mm"),h:H().default("4.80mm"),pl:H().default("1.3mm"),pw:H().default("0.9mm"),p:H().default("1.5mm"),string:H().optional()}),f0e=e=>{const A=[],t=Number.parseFloat(e.p),i=Number.parseFloat(e.pw),n=Number.parseFloat(e.w),o=Number.parseFloat(e.pl),s=.175,r=(o-(o+s))/2;A.push(di(1,-n/2+r,t,o,i),di(2,-n/2,0,o+s,i),di(3,-n/2+r,-t,o,i));const a=Wi(0,0,.3),g=Number.parseFloat(e.w)/2-1,c=Number.parseFloat(e.h)/2,I={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-g,y:c},{x:g,y:c},{x:g,y:c/2+.5}],type:"pcb_silkscreen_path",stroke_width:.1},l={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-g,y:-c},{x:g,y:-c},{x:g,y:-c/2-.5}],type:"pcb_silkscreen_path",stroke_width:.1};return[...A,I,l,a]},y0e=e=>{const A=[];Number.parseFloat(e.p),Number.parseFloat(e.pw),Number.parseFloat(e.w),A.push(di(1,-1.85,-1.5,1.5,.7),di(2,-1.85,1.5,1.5,.7),di(3,0,0,.8,2),di(4,1.85,-1.5,1.5,.7),di(5,1.85,1.5,1.5,.7));const t=Wi(0,Number.parseFloat(e.h)/2+.5,.3),i=Number.parseFloat(e.w)/2-1,n=Number.parseFloat(e.h)/2,o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-i,y:n},{x:i,y:n}],type:"pcb_silkscreen_path",stroke_width:.1},s={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-i,y:-n},{x:i,y:-n}],type:"pcb_silkscreen_path",stroke_width:.1};return[...A,o,s,t]},m0e=e=>{const A=e.string?.match(/^sot89_(\d+)/),t=A?Number.parseInt(A[1],10):3,i=p0e.parse({...e,num_pins:t});if(i.num_pins===3)return{circuitJson:f0e(i),parameters:i};if(i.num_pins===5)return{circuitJson:y0e(i),parameters:i};throw new Error("Invalid number of pins for SOT89")},w0e=Zi.extend({fn:H(),p:QA.optional().default("5.0mm"),id:QA.optional().default("1.0mm"),od:QA.optional().default("1.9mm"),w:QA.optional().default("13mm"),h:QA.optional().default("7mm"),num_pins:WA().optional(),string:H().optional()}),D0e=e=>{const A=w0e.parse(e),{fn:t,id:i,od:n,w:o,h:s,string:r}=A,a=Number.parseInt(r?.split("_")[1]??"3"),g=-1,c=o/2,I=s/2,l=2.5,B=o*.4,C=Math.max(l,B/(a-1)),Q=Array.from({length:a},(m,w)=>{const D=a%2===0?(w-a/2+.5)*C:(w-Math.floor(a/2))*C;return jo(w+1,D,g,i,n)}),E={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-c,y:-I},{x:c,y:-I},{x:c,y:I},{x:-c,y:I},{x:-c,y:-I}],stroke_width:.1,pcb_silkscreen_path_id:""},h=-I+2*s/3,u={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-c,y:h},{x:c,y:h}],stroke_width:.1,pcb_silkscreen_path_id:""},d=[{type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-o/6,y:h},{x:-o/6,y:I}],stroke_width:.1,pcb_silkscreen_path_id:""},{type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:o/6,y:h},{x:o/6,y:I}],stroke_width:.1,pcb_silkscreen_path_id:""}],f=Wi(0,s/2+.6,.5);return{circuitJson:[...Q,E,u,...d,f],parameters:{...A,p:C}}},S0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("5.40mm"),h:H().default("2.30mm"),pl:H().default("1.30mm"),pw:H().default("1.70mm"),p:H().default("3.5mm")}),b0e=e=>{const A=S0e.parse(e),t=Wi(0,QA.parse(A.h)/2+.4,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:_0e(A).concat(i,t),parameters:A}},x0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},_0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=x0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},k0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("1.90mm"),h:H().default("1.33mm"),pl:H().default("0.5mm"),pw:H().default("0.7mm"),p:H().default("0.8mm")}),F0e=e=>{const A=k0e.parse(e),t=Wi(0,QA.parse(A.h)+.1,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2+.1,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2+.1,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:M0e(A).concat(i,t),parameters:A}},G0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},M0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=G0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},R0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("7.0mm"),h:H().default("3.35mm"),pl:H().default("1.50mm"),pw:H().default("2.70mm"),p:H().default("4.8mm")}),N0e=e=>{const A=R0e.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:L0e(A).concat(i,t),parameters:A}},v0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},L0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=v0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},U0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("3.0mm"),h:H().default("1.80mm"),pl:H().default("0.80mm"),pw:H().default("1.20mm"),p:H().default("1.6mm")}),H0e=e=>{const A=U0e.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.1,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.1,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:J0e(A).concat(i,t),parameters:A}},Y0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},J0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=Y0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},T0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("7.10mm"),h:H().default("3.40mm"),pl:H().default("2.45mm"),pw:H().default("1.80mm"),p:H().default("4.05mm")}),K0e=e=>{const A=T0e.parse(e),t=Wi(0,QA.parse(A.h)/2+.5,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.5,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.5,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:q0e(A).concat(i,t),parameters:A}},P0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},q0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=P0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},O0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("4.80mm"),h:H().default("2.10mm"),pl:H().default("1.30mm"),pw:H().default("1.40mm"),p:H().default("2.9mm")}),W0e=e=>{const A=O0e.parse(e),t=Wi(0,QA.parse(A.h)-.5,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:V0e(A).concat(i,t),parameters:A}},Z0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},V0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=Z0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},j0e=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("7.30mm"),h:H().default("4.40mm"),pl:H().default("2.50mm"),pw:H().default("2.30mm"),p:H().default("4.30mm")}),z0e=e=>{const A=j0e.parse(e),t=Wi(0,QA.parse(A.h)/2+.5,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.1,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.1,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:$0e(A).concat(i,t),parameters:A}},X0e=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},$0e=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=X0e({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},Aye=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("10.70mm"),h:H().default("6.60mm"),pl:H().default("3.30mm"),pw:H().default("2.50mm"),p:H().default("6.80mm")}),tye=e=>{const A=Aye.parse(e),t=Wi(0,3,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2-.8},{x:-QA.parse(A.w)/2-.8,y:QA.parse(A.h)/2-.8},{x:-QA.parse(A.w)/2-.8,y:-QA.parse(A.h)/2+.8},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2+.8}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:iye(A).concat(i,t),parameters:A}},eye=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},iye=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=eye({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},nye=Zi.extend({fn:H(),num_pins:WA().default(4),w:H().default("8.50mm"),h:H().default("6.90mm"),pl:H().default("2mm"),pw:H().default("1.5mm"),p:H().default("2.30mm"),string:H().optional()}),oye=e=>{const A=e.string?.match(/^sot223_(\d+)/),t=A?Number.parseInt(A[1],10):4;if(t===8){const n=aye.parse({...e,num_pins:t});return{circuitJson:f_(n),parameters:n}}const i=nye.parse({...e,num_pins:t});if(i.num_pins===4)return{circuitJson:rye(i),parameters:i};if(i.num_pins===5)return{circuitJson:cye(i),parameters:i};if(i.num_pins===6)return{circuitJson:lye(i),parameters:i};throw new Error("Invalid number of pins")},sye=e=>{const{pn:A,w:t,p:i}=e;return A===1?{x:-t/2+1.1,y:i}:A===2?{x:-t/2+1.1,y:0}:A===3?{x:-t/2+1.1,y:-i}:{x:t/2-1.1,y:0}},rye=e=>{const A=[];for(let r=0;r<e.num_pins;r++){const{x:a,y:g}=sye({num_pins:e.num_pins,pn:r+1,w:Number.parseFloat(e.w),h:Number.parseFloat(e.h),pl:Number.parseFloat(e.pl),p:Number.parseFloat(e.p)}),c=r===3?3.8:Number.parseFloat(e.pw);A.push(di(r+1,a,g,Number.parseFloat(e.pl),c))}const t=Wi(0,0,.3),i=Number.parseFloat(e.w)/2-2.4,n=Number.parseFloat(e.h)/2,o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-i,y:n},{x:i,y:n},{x:i,y:n/2+.5}],type:"pcb_silkscreen_path",stroke_width:.1},s={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-i,y:-n},{x:i,y:-n},{x:i,y:-n/2-.5}],type:"pcb_silkscreen_path",stroke_width:.1};return[...A,o,s,t]},aye=rD({p:"0.90mm",w:"2.8mm",legsoutside:!0}),gye=e=>{const{p:A,pn:t,w:i}=e;if(t===1)return{x:-i/2+1.2,y:A/2+A};if(t===2)return{x:-i/2+1.2,y:A/2};if(t===3)return{x:-i/2+1.2,y:-A/2};if(t===4)return{x:-i/2+1.2,y:-A/2-A};if(t===5)return{x:i/2-1,y:0};throw new Error("Invalid pin number")},cye=e=>{const A=[];for(let r=1;r<=e.num_pins;r++){const{x:a,y:g}=gye({h:Number.parseFloat(e.h),p:1.5,pn:r,w:Number.parseFloat(e.w)});let c=Number.parseFloat(e.pw),I=Number.parseFloat(e.pl);r===5?(c=3.4,I=1.8):(c=1,I=2.2),A.push(di(r,a,g,I,c))}const t=Number.parseFloat(e.w)/2-2.4,i=Number.parseFloat(e.h)/2,n={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-t,y:i},{x:t,y:i},{x:t,y:i/2+.5}],type:"pcb_silkscreen_path",stroke_width:.1},o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-t,y:-i},{x:t,y:-i},{x:t,y:-i/2-.5}],type:"pcb_silkscreen_path",stroke_width:.1},s=Wi(0,0,.3);return[...A,n,o,s]},Iye=e=>{const{p:A,pn:t,w:i}=e;if(t===1)return{x:-i/2+1.2,y:2*A};if(t===2)return{x:-i/2+1.2,y:A};if(t===3)return{x:-i/2+1.2,y:0};if(t===4)return{x:-i/2+1.2,y:-A};if(t===5)return{x:-i/2+1.2,y:-2*A};if(t===6)return{x:i/2-1.175,y:0};throw new Error("Invalid pin number")},lye=e=>{const A=[];for(let r=1;r<=e.num_pins;r++){const{x:a,y:g}=Iye({h:Number.parseFloat(e.h),p:1.3,pn:r,w:8.7});let c=Number.parseFloat(e.pw),I=Number.parseFloat(e.pl);r===6?(c=3.4,I=2.15):(c=.6,I=2.2),A.push(di(r,a,g,I,c))}const t=Number.parseFloat(e.w)/2-2.4,i=Number.parseFloat(e.h)/2,n={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-t,y:i},{x:t,y:i},{x:t,y:i/2+.5}],type:"pcb_silkscreen_path",stroke_width:.1},o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-t,y:-i},{x:t,y:-i},{x:t,y:-i/2-.5}],type:"pcb_silkscreen_path",stroke_width:.1},s=Wi(0,0,.3);return[...A,n,o,s]},Bye=Zi.extend({fn:H(),num_pins:WA().default(3),w:H().default("3.40mm"),h:H().default("3.30mm"),pl:H().default("1mm"),pw:H().default("0.7mm"),p:H().default("1.2mm"),string:H().optional()}),Cye=e=>{const A=e.string?.match(/^sot23w_(\d+)/),t=A?Number.parseInt(A[1],3):3,i=Bye.parse({...e,num_pins:t});if(i.num_pins===3)return{circuitJson:Eye(i),parameters:i};throw new Error("Invalid number of pins")},Qye=e=>{const{pn:A,p:t}=e;return A===1?{x:-t,y:.95}:A===2?{x:-t,y:-.95}:{x:t,y:0}},Eye=e=>{const A=[];for(let r=0;r<e.num_pins;r++){const{x:a,y:g}=Qye({num_pins:e.num_pins,pn:r+1,w:Number.parseFloat(e.w),h:Number.parseFloat(e.h),pl:Number.parseFloat(e.pl),p:Number.parseFloat(e.p)});A.push(di(r+1,a,g,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}const t=Wi(0,Number.parseInt(e.h)/2+1,.3),i=Number.parseFloat(e.w)/2-1,n=Number.parseFloat(e.h)/2,o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-i,y:n},{x:i+.3,y:n},{x:i+.3,y:n/2}],type:"pcb_silkscreen_path",stroke_width:.1},s={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-i,y:-n},{x:i+.3,y:-n},{x:i+.3,y:-n/2}],type:"pcb_silkscreen_path",stroke_width:.1};return[...A,o,s,t]},hye=Zi.extend({fn:H(),num_pins:Ze([xA(3),xA(2)]).default(3),p:H().default("1.27mm"),id:H().default("0.72mm"),od:H().default("0.95mm"),w:H().default("2.5mm"),h:H().default("4.2mm"),string:H().optional()}),uye=e=>{const{p:A,id:t,od:i,w:n,h:o}=e,s=Number.parseFloat(o)/2,r=Number.parseFloat(A);return[jo(1,-r,s-r,t,i),jo(2,0,s-r,t,i),jo(3,r,s-r,t,i)]},dye=e=>{const{p:A,id:t,od:i,h:n}=e,o=Number.parseFloat(n)/2,s=Number.parseFloat(A);return[jo(1,-s,o-s,t,i),jo(2,s,o-s,t,i)]},pye=e=>{const A=e.string?.match(/^to92s_(\d+)/),t=A?Number.parseInt(A[1],10):3,i=hye.parse({...e,num_pins:t});let n=[];if(i.num_pins===3)n=uye(i);else if(i.num_pins===2)n=dye(i);else throw new Error("Invalid number of pins for TO-92");const o=Number.parseFloat(i.h)/2,s=Number.parseFloat(i.p),r={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-o,y:o-s},{x:-1.9,y:0},{x:1.9,y:0},{x:o,y:o-s},{x:1.5,y:Number.parseFloat(i.h)/2+.5},{x:-1.5,y:Number.parseFloat(i.h)/2+.5},{x:-o,y:o-s}],stroke_width:.1,pcb_silkscreen_path_id:""},a=Wi(0,o+1,.5);return{circuitJson:[...n,r,a],parameters:i}},fye=Zi.extend({fn:H(),p:QA.optional(),id:QA.optional(),pw:QA.optional(),pl:QA.optional(),w:QA.optional(),h:QA.optional(),sh:Ze([gt(),H(),WA()]).optional().transform(e=>{if(typeof e=="string"){const A=Number(e);return Number.isNaN(A)?!0:A}return e}).describe('JST SH (Surface-mount) connector family. SH stands for "Super High-density".'),ph:gt().optional().describe('JST PH (Through-hole) connector family. PH stands for "Pin Header".'),string:H().optional()}),yye={ph:{p:QA.parse("2.2mm"),id:QA.parse("0.70mm"),pw:QA.parse("1.20mm"),pl:QA.parse("1.20mm"),w:QA.parse("6mm"),h:QA.parse("5mm")},sh:{p:QA.parse("1mm"),pw:QA.parse("0.6mm"),pl:QA.parse("1.55mm"),w:QA.parse("5.8mm"),h:QA.parse("7.8mm")}};function mye(e){return e.sh?"sh":(e.ph,"ph")}function wye(e,A,t,i,n,o){const s=[];if(e==="ph"){const r=t/2;s.push(sb(1,-r,2,i,n,o)),s.push(sb(2,r,2,i,n,o))}else{const r=-((A-1)/2)*t;for(let g=0;g<A;g++){const c=r+g*t;console.log("x si",c),s.push(di(g+1,c,-1.325,n,o))}const a=(A-1)/2*t+1.3;console.log("offset",a),s.push(di(A+1,-a,1.22,1.2,1.8)),s.push(di(A+2,a,1.22,1.2,1.8))}return s}function Dye(e,A,t){return e==="ph"?{type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-3,y:3},{x:3,y:3},{x:3,y:-2},{x:-3,y:-2},{x:-3,y:3}],stroke_width:.1,pcb_silkscreen_path_id:""}:{type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[],stroke_width:.1,pcb_silkscreen_path_id:""}}var Sye=e=>{const A=fye.parse(e),t=mye(A),i=yye[t],n=A.p??i.p,o=A.id??i.id,s=A.pw??i.pw,r=A.pl??i.pl,a=A.w??i.w,g=A.h??i.h;let c=t==="sh"?4:2;if(t==="sh"){const Q=(typeof e.string=="string"?e.string:"").match(/sh(\d+)/);if(Q&&Q[1]){const E=parseInt(Q[1],10);Number.isNaN(E)||(c=E)}else typeof A.sh=="number"&&(c=A.sh)}const I=wye(t,c,n,o,s,r),l=Dye(t),B=Wi(0,g/2+1,.5);return{circuitJson:[...I,l,B],parameters:{...A,p:n,id:o,pw:s,pl:r,w:a,h:g,num_pins:c,sh:t==="sh",ph:t==="ph"}}},bye=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("3.30mm"),h:H().default("1.70mm"),pl:H().default("0.80mm"),pw:H().default("1mm"),p:H().default("1.90mm")}),xye=e=>{const A=bye.parse(e),t=Wi(0,QA.parse(A.h)/2+.5,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:kye(A).concat(i,t),parameters:A}},_ye=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},kye=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=_ye({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},Fye=e=>{switch(e){case 8:return{w:"3.06mm",h:"3.14mm",p:"0.65mm",pl:"1.6mm",pw:"0.5mm"};case 10:return{w:"3.10mm",h:"3.33mm",p:"0.5mm",pl:"1.45mm",pw:"0.3mm"};default:return{w:"3.06mm",h:"3.14mm",p:"0.65mm",pl:"1.6mm",pw:"0.5mm"}}},Gye=Zi.extend({fn:H(),num_pins:Ze([xA(8),xA(10)]).default(8),w:H().optional(),h:H().optional(),p:H().optional(),pl:H().optional(),pw:H().optional(),string:H().optional()}),Mye=e=>{const A=Gye.parse(e),t=Fye(A.num_pins),i=QA.parse(A.w||t.w),n=QA.parse(A.h||t.h),o=QA.parse(A.p||t.p),s=QA.parse(A.pl||t.pl),r=QA.parse(A.pw||t.pw),a=[],g=A.num_pins/2;for(let u=0;u<A.num_pins;u++){const{x:d,y:f}=XzA(A.num_pins,u+1,i,o),m=u<g?u+1:A.num_pins-(u-g);a.push(di(m,d,f,s,r))}const c=i,I=n,l={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-c/2,y:I/2},{x:c/2,y:I/2}],stroke_width:.05,pcb_silkscreen_path_id:""},B={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-c/2,y:-I/2},{x:c/2,y:-I/2}],stroke_width:.05,pcb_silkscreen_path_id:""},C=XzA(A.num_pins,1,c,o),Q={x:C.x-.8,y:C.y},E={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"pin_marker_1",route:[{x:Q.x-.4,y:Q.y},{x:Q.x-.7,y:Q.y+.3},{x:Q.x-.7,y:Q.y-.3},{x:Q.x-.4,y:Q.y}],stroke_width:.05,pcb_silkscreen_path_id:"pin_marker_1"},h=Wi(0,I/2+.5,.3);return{circuitJson:[...a,l,B,h,E],parameters:A}},XzA=(e,A,t,i)=>{const n=e/2,o=(A-1)%n,s=A<=n?-1:1,r=(n-1)/2-o;return{x:s*QA.parse(e===8?"1.8mm":"2.2mm"),y:r*i}},Rye=e=>{switch(e){case 10:return{w:"3.10mm",h:"3.32mm",p:"0.5mm",pl:"1.63mm",pw:"0.33mm"};case 12:return{w:"3mm",h:"4mm",p:"0.65mm",pl:"0.88mm",pw:"0.4mm"};case 16:return{w:"3.10mm",h:"4mm",p:"0.5mm",pl:"0.88mm",pw:"0.3mm"};default:return{w:"3.10mm",h:"3.32mm",p:"0.65mm",pl:"1.63mm",pw:"0.4mm"}}},Nye=Zi.extend({fn:H(),num_pins:Ze([xA(8),xA(10),xA(12),xA(16)]).default(8),w:H().optional(),h:H().optional(),p:H().optional(),pl:H().optional(),pw:H().optional(),string:H().optional()}),$zA=(e,A,t,i)=>{const n=e/2,o=(A-1)%n,s=A<=n?-1:1,r=(n-1)/2-o;return{x:s*QA.parse("2mm"),y:r*i}},vye=e=>{const A=Nye.parse(e),t=Rye(A.num_pins),i=QA.parse(A.w||t.w),n=QA.parse(A.h||t.h),o=QA.parse(A.p||t.p),s=QA.parse(A.pl||t.pl),r=QA.parse(A.pw||t.pw),a=[];for(let h=0;h<A.num_pins;h++){const{x:u,y:d}=$zA(A.num_pins,h+1,i,o);a.push(di(h+1,u,d,s,r))}const g=i,c=n,I={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-g/2,y:c/2},{x:g/2,y:c/2}],stroke_width:.05,pcb_silkscreen_path_id:""},l={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-g/2,y:-c/2},{x:g/2,y:-c/2}],stroke_width:.05,pcb_silkscreen_path_id:""},B=$zA(A.num_pins,1,g,o),C={x:B.x-.8,y:B.y},Q={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"pin_marker_1",route:[{x:C.x-.4,y:C.y},{x:C.x-.7,y:C.y+.3},{x:C.x-.7,y:C.y-.3},{x:C.x-.4,y:C.y}],stroke_width:.05,pcb_silkscreen_path_id:"pin_marker_1"},E=Wi(0,c/2+.5,.3);return{circuitJson:[...a,I,l,E,Q],parameters:A}},Lye=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("3.8mm"),h:H().default("1.65mm"),pl:H().default("1.2mm"),pw:H().default("1.2mm"),pad_spacing:H().default("2.6mm")}),Uye=e=>{const A=Lye.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.pad_spacing)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2},{x:QA.parse(A.pad_spacing)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:Yye(A).concat(i,t),parameters:A}},Hye=e=>{const{pn:A,pad_spacing:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},Yye=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=Hye({pn:t,pad_spacing:Number.parseFloat(e.pad_spacing)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},Jye=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("3.20mm"),h:H().default("1.65mm"),pl:H().default("0.8mm"),pw:H().default("0.9mm"),pad_spacing:H().default("2.1mm")}),Tye=e=>{const A=Jye.parse(e),t=Wi(0,QA.parse(A.h),.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.pad_spacing)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.2,y:-QA.parse(A.h)/2},{x:QA.parse(A.pad_spacing)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:Pye(A).concat(i,t),parameters:A}},Kye=e=>{const{pn:A,pad_spacing:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},Pye=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=Kye({pn:t,pad_spacing:Number.parseFloat(e.pad_spacing)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},qye=Zi.extend({fn:H(),num_pins:Ze([xA(6),xA(8)]).default(8),w:H().default("3mm"),h:H().default("3mm"),p:H().default("0.5mm"),pl:H().default("0.52mm"),pw:H().default("0.35mm"),epw:H().default("1.40mm"),eph:H().default("1.60mm"),string:H().optional(),ep:gt().default(!1)}),Oye=e=>{e.string&&e.string.includes("_ep")&&(e.ep=!0);const A=e.string?.match(/^son_(\d+)/),t=A?Number.parseInt(A[1],10):e.num_pins||8,i=qye.parse({...e,num_pins:t}),n=QA.parse(i.w),o=QA.parse(i.h),s=QA.parse(i.p),r=QA.parse(i.pl),a=QA.parse(i.pw),g=QA.parse(i.epw),c=QA.parse(i.eph),I=[];for(let f=0;f<i.num_pins;f++){const{x:m,y:w}=AXA(i.num_pins,f+1,n,s);I.push(di(f+1,m,w,r,a))}i.ep&&I.push(di(i.num_pins+1,0,0,g,c));const l=n,B=o,C={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-l/2,y:B/2},{x:l/2,y:B/2}],stroke_width:.05,pcb_silkscreen_path_id:""},Q={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-l/2,y:-B/2},{x:l/2,y:-B/2}],stroke_width:.05,pcb_silkscreen_path_id:""},E=AXA(i.num_pins,1,l,s),h={x:E.x-.4,y:E.y},u={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"pin_marker_1",route:[{x:h.x-.4,y:h.y},{x:h.x-.7,y:h.y+.3},{x:h.x-.7,y:h.y-.3},{x:h.x-.4,y:h.y}],stroke_width:.05,pcb_silkscreen_path_id:"pin_marker_1"},d=Wi(0,B/2+.5,.3);return{circuitJson:[...I,C,Q,d,u],parameters:i}},AXA=(e,A,t,i)=>{const n=e/2,o=(A-1)%n,s=A<=n?-1:1,r=(n-1)/2-o;return{x:s*QA.parse("1.4mm"),y:r*i}},Wye=e=>{const{num_pins:A,bridged:t,p:i=2.54,pw:n=1.5,ph:o=1.5}=e,s=QA.parse(i),r=QA.parse(n),a=QA.parse(o),g=Math.min(a/4,.5),c=[];for(let f=0;f<A;f++)c.push(di(f+1,f*s,0,r,a));let I=[];if(t){const f=t.split("").map(Number);if(f.length>1)for(let m=0;m<f.length-1;m++){const w=f[m],D=f[m+1];if(typeof w=="number"&&typeof D=="number"&&!isNaN(w)&&!isNaN(D)){const b=(w-1)*s,k=(D-1)*s,x=Math.sign(k-b),N=b+x*(r/2),R=k-x*(r/2);I.push({type:"pcb_trace",pcb_trace_id:"",route:[{start_pcb_port_id:`{PIN${w}}`,x:N,y:0,width:g,layer:"top",route_type:"wire"},{end_pcb_port_id:`{PIN${D}}`,x:R,y:0,width:g,layer:"top",route_type:"wire"}]})}}}const l=(A-1)*s+r+.7,B=a+1,C=(A-1)*s/2,Q=0,E={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"outline",route:[{x:C-l/2,y:Q-B/2},{x:C+l/2,y:Q-B/2},{x:C+l/2,y:Q+B/2},{x:C-l/2,y:Q+B/2},{x:C-l/2,y:Q-B/2}],stroke_width:.15},u=Q+B/2+.6,d=Wi(C,u,.4);return{circuitJson:[...c,...I,E,d],parameters:e}},tXA={fn:xA("sot457"),num_pins:xA(6).default(6),pillh:H().default("0.45mm"),pillw:H().default("1.45mm"),pl:H(),pw:H(),p:H(),wave:gt().optional(),reflow:gt().optional()},Zye=Zi.extend({...tXA,h:H().default("2.5mm"),w:H().default("2.7mm"),pl:H().default("0.8mm"),pw:H().default("0.55mm"),p:H().default("0.95mm")}),Vye=Zi.extend({...tXA,h:H().default("3mm"),w:H().default("4mm"),pillr:H().default("0.225mm"),pl:H().default("1.45mm"),pw:H().default("1.5mm"),p:H().default("1.475mm")}).transform(e=>({...e,wave:e.wave??(e.reflow===void 0?!0:!e.reflow),reflow:e.reflow??(e.wave===void 0?!1:!e.wave)})),rb=e=>Number.parseFloat(e.replace("mm","")),eXA=({pitch:e,width:A,pinNumber:t})=>{const o={1:{x:-A/2-.1,y:e},2:{x:-A/2-.1,y:0},3:{x:-A/2-.1,y:-e},4:{x:A/2+.1,y:-e},5:{x:A/2+.1,y:0},6:{x:A/2+.1,y:e}}[t];if(!o)throw new Error(`Invalid pin number: ${t}`);return o},iXA=e=>{const A=[],t=rb(e.p),i=rb(e.pl),n=rb(e.pw),o=rb(e.w),s=rb(e.h);if(e.wave){const C={1:({padWidth:Q,padHeight:E})=>di(1,-t,t,E,Q),2:({padWidth:Q,padHeight:E})=>di(2,-t,-t,E,Q),3:({padWidth:Q,padHeight:E})=>sW(3,-t,0,rb(e.pillw),rb(e.pillh)),4:({padWidth:Q,padHeight:E})=>sW(4,t,0,rb(e.pillw),rb(e.pillh)),5:({padWidth:Q,padHeight:E})=>di(5,t,t,E,Q),6:({padWidth:Q,padHeight:E})=>di(6,t,-t,E,Q)};for(let Q=1;Q<=e.num_pins;Q++){const E=C[Q];E&&A.push(E({padWidth:i,padHeight:n}))}}else for(let C=1;C<=e.num_pins;C++){const{x:Q,y:E}=eXA({pitch:t,width:o,pinNumber:C});A.push(di(C,Q,E,i,n))}const r={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-o/3,y:s/2+t/1.3},{x:o/3,y:s/2+t/1.3}],stroke_width:.05},a={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-o/3,y:-s/2-t/1.3},{x:o/3,y:-s/2-t/1.3}],stroke_width:.05},g=Wi(0,s+.5,.3),c=eXA({pitch:t,width:o,pinNumber:1}),I=e.wave?1:.5,l=e.wave?.7:.3;c.x-=e.wave?n:n*1.7;const B={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"pin1_indicator",route:[{x:c.x+I/2,y:c.y},{x:c.x-I/2,y:c.y+l/2},{x:c.x-I/2,y:c.y-l/2},{x:c.x+I/2,y:c.y}],stroke_width:.05};return[g,r,a,B,...A]},jye=e=>{if(e.wave){const t=Vye.parse({...e,fn:"sot457"});return{circuitJson:iXA(t),parameters:t}}const A=Zye.parse(e);return{circuitJson:iXA(A),parameters:A}},zye=Zi.extend({fn:H(),num_pins:xA(6).default(6),w:H().default("1.1mm"),h:H().default("1.45mm"),p:H().default("0.35mm"),pl:H().default("0.2mm"),pw:H().default("0.2mm"),string:H().optional()}),Xye=e=>{const A=zye.parse({...e,fn:"sot963"}),t=QA.parse(A.w),i=QA.parse(A.h),n=QA.parse(A.p),o=QA.parse(A.pl),s=QA.parse(A.pw),r=[];for(let B=0;B<6;B++){const{x:C,y:Q}=nXA(B+1,t,n,o);r.push(di(B+1,C,Q,o,s))}const a={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-t/2,y:i/2},{x:t/2,y:i/2}],stroke_width:.05,pcb_silkscreen_path_id:""},g={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:-t/2,y:-i/2},{x:t/2,y:-i/2}],stroke_width:.05,pcb_silkscreen_path_id:""},c=nXA(1,t,n,o),I={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"pin_marker_1",route:[{x:c.x-o/2-.3,y:c.y},{x:c.x-o/2-.45,y:c.y+.15},{x:c.x-o/2-.45,y:c.y-.15},{x:c.x-o/2-.3,y:c.y}],stroke_width:.05,pcb_silkscreen_path_id:"pin_marker_1"},l=Wi(0,i/2+.4,.25);return{circuitJson:[...r,a,g,l,I],parameters:A}},nXA=(e,A,t,i)=>{const n=A/2-i/2;return e<=3?{x:-n,y:t-(e-1)*t}:{x:n,y:-t+(e-4)*t}},$ye=Zi.extend({fn:H(),num_pins:Ze([xA(3),xA(2)]).default(3),p:H().default("3.8mm"),id:H().default("1.25mm"),od:H().default("2.35mm"),ca:H().default("14mm").describe("Caliper axis (width or diameter of the potentiometer body or adjustment knob)"),w:H().default("5.35mm"),h:H().default("4mm"),string:H().optional()}),Ame=e=>{const{p:A,id:t,od:i,h:n,ca:o}=e,s=Number.parseFloat(n),r=Number.parseFloat(o);return[jo(1,0,r/4+.3,t,i),jo(2,s,0,t,i),jo(3,0,-r/4-.3,t,i)]},tme=e=>{const A=e.string?.match(/^potentiometer_(\d+)/),t=A?Number.parseInt(A[1],10):3,i=$ye.parse({...e,num_pins:t});let n=[];i.num_pins===3&&(n=Ame(i));const o=Number.parseFloat(i.ca)/2+.15,s=Number.parseFloat(i.w),r=Number.parseFloat(i.od)/2+.35,a={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:0,y:o-1.75},{x:0,y:o},{x:s,y:o},{x:s,y:r}],stroke_width:.1,pcb_silkscreen_path_id:""},g={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:s,y:-r},{x:s,y:-o},{x:0,y:-o},{x:0,y:-o+1.75}],stroke_width:.1,pcb_silkscreen_path_id:""},c=Number.parseFloat(i.w)/2,I=Wi(c,o+1,.5);return{circuitJson:[...n,a,g,I],parameters:i}},eme=Zi.extend({fn:H(),p:QA.optional().default("7.5mm"),id:QA.optional().default("1mm"),od:QA.optional().default("2mm"),d:QA.optional().default("10.5mm")}),ime=(e,A,t,i,n)=>{const o=[],s=[];for(let r=0;r<=50;r++){const a=r/50*Math.PI,g=e+Math.cos(a)*t,c=A+Math.sin(a)*t;g<e-i&&c>=A-n/2&&c<=A+n/2||o.push({x:g,y:c})}for(let r=0;r<=50;r++){const a=Math.PI+r/50*Math.PI,g=e+Math.cos(a)*t,c=A+Math.sin(a)*t;g<e-i&&c>=A-n/2&&c<=A+n/2||s.push({x:g,y:c})}return{topArc:o,bottomArc:s}},nme=e=>{const A=eme.parse(e),{p:t,id:i,od:n,d:o}=A,s=[jo(1,-t/2,0,i,n),jo(2,t/2,0,i,n)],{topArc:r,bottomArc:a}=ime(0,0,o/2+.1,n/2,n),g={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:r,stroke_width:.1,pcb_silkscreen_path_id:""},c={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:a,stroke_width:.1,pcb_silkscreen_path_id:""},I={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:0,y:o/2+.1},{x:0,y:-(o/2+.1)}],stroke_width:.1,pcb_silkscreen_path_id:""},l=-(o/2+.5),B=n/2+1.5,C=.5,Q={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:l-C,y:B},{x:l+C,y:B}],stroke_width:.1,pcb_silkscreen_path_id:""},E={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:l,y:B-C},{x:l,y:B+C}],stroke_width:.1,pcb_silkscreen_path_id:""},h=Wi(0,o/2+1,.5);return{circuitJson:[...s,g,c,I,Q,E,h],parameters:A}},ome=Zi.extend({fn:H(),num_pins:xA(2).default(2),w:H().default("6.5mm"),h:H().default("3mm"),pl:H().default("1.75mm"),pw:H().default("2.40mm"),p:H().default("4.75mm")}),sme=e=>{const A=ome.parse(e),t=Wi(0,QA.parse(A.h)-.5,.3),i={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",route:[{x:QA.parse(A.p)/2,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.3,y:QA.parse(A.h)/2},{x:-QA.parse(A.w)/2-.3,y:-QA.parse(A.h)/2},{x:QA.parse(A.p)/2,y:-QA.parse(A.h)/2}],stroke_width:.1,pcb_silkscreen_path_id:""};return{circuitJson:ame(A).concat(i,t),parameters:A}},rme=e=>{const{pn:A,p:t}=e;return A===1?{x:-t/2,y:0}:{x:t/2,y:0}},ame=e=>{const A=[];for(let t=1;t<=e.num_pins;t++){const{x:i,y:n}=rme({pn:t,p:Number.parseFloat(e.p)});A.push(di(t,i,n,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}return A},gme=Zi.extend({fn:H(),num_pins:WA().default(3),w:H().default("2.45mm"),h:H().default("2.40mm"),pl:H().default("1.225mm"),pw:H().default("0.5mm"),p:H().default("0.95mm"),string:H().optional()}),cme=e=>{const A=e.string?.match(/^sot323_(\d+)/),t=A?Number.parseInt(A[1],3):3,i=gme.parse({...e,num_pins:t});if(i.num_pins===3)return{circuitJson:lme(i),parameters:i};throw new Error("Invalid number of pins")},Ime=e=>{const{pn:A,p:t}=e;return A===1?{x:-t,y:.65}:A===2?{x:-t,y:-.65}:{x:t,y:0}},lme=e=>{const A=[];for(let r=0;r<e.num_pins;r++){const{x:a,y:g}=Ime({num_pins:e.num_pins,pn:r+1,w:Number.parseFloat(e.w),h:Number.parseFloat(e.h),pl:Number.parseFloat(e.pl),p:Number.parseFloat(e.p)});A.push(di(r+1,a,g,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}const t=Wi(0,Number.parseInt(e.h)/2+1,.3),i=Number.parseFloat(e.w)/2-Number.parseFloat(e.pl),n=Number.parseFloat(e.h)/2,o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-i,y:n+.3},{x:i,y:n+.3},{x:i,y:n/2}],type:"pcb_silkscreen_path",stroke_width:.1},s={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-i,y:-n-.3},{x:i,y:-n-.3},{x:i,y:-n/2}],type:"pcb_silkscreen_path",stroke_width:.1};return[...A,o,s,t]},Bme=Zi.extend({fn:H(),circle:gt().optional(),rect:gt().optional(),square:gt().optional(),pill:gt().optional(),d:QA.optional(),pd:QA.optional(),diameter:QA.optional(),r:QA.optional(),pr:QA.optional(),radius:QA.optional(),w:QA.optional(),pw:QA.optional(),width:QA.optional(),h:QA.optional(),ph:QA.optional(),height:QA.optional(),s:QA.optional(),size:QA.optional(),string:H().optional()}).transform(e=>{let A="rect";e.circle&&(A="circle"),e.square&&(A="square"),e.rect&&(A="rect"),e.pill&&(A="pill");let t,i,n;return A==="circle"?e.r!==void 0?t=Fr(e.r):e.pr!==void 0?t=Fr(e.pr):e.radius!==void 0?t=Fr(e.radius):e.d!==void 0?t=Fr(e.d)/2:e.pd!==void 0?t=Fr(e.pd)/2:e.diameter!==void 0?t=Fr(e.diameter)/2:t=Fr("1mm")/2:(e.w!==void 0?i=Fr(e.w):e.pw!==void 0?i=Fr(e.pw):e.width!==void 0?i=Fr(e.width):e.s!==void 0?i=Fr(e.s):e.size!==void 0?i=Fr(e.size):i=Fr("1mm"),e.h!==void 0?n=Fr(e.h):e.ph!==void 0?n=Fr(e.ph):e.height!==void 0?n=Fr(e.height):A==="square"||A==="rect"?n=i:n=Fr("1mm")),{fn:e.fn,shape:A,radius:t,width:i,height:n}}),Cme=e=>{const A=Bme.parse(e),{shape:t,radius:i,width:n,height:o}=A;let s,r;return t==="circle"?(s=UzA(1,{x:0,y:0,radius:i}),r=i+.5):t==="pill"?(s=sW(1,0,0,n,o),r=Math.max(n,o)/2+.5):(s=di(1,0,0,n,o),r=o/2+.5),{circuitJson:[s,Wi(0,r,.2)],parameters:A}},Qme=Zi.extend({fn:H(),d:QA.optional(),hd:QA.optional(),r:QA.optional(),hr:QA.optional(),pd:QA.optional(),pr:QA.optional(),squarepad:gt().optional().default(!1)}).transform(e=>{let A;e.d!==void 0?A=Fr(e.d):e.hd!==void 0?A=Fr(e.hd):e.r!==void 0?A=Fr(e.r)*2:e.hr!==void 0?A=Fr(e.hr)*2:A=Fr("1mm");let t;return e.pd!==void 0?t=Fr(e.pd):e.pr!==void 0?t=Fr(e.pr)*2:t=A*(1.5/1),{fn:e.fn,d:A,pd:t,squarepad:e.squarepad??!1}}),Eme=e=>{const A=Qme.parse(e),{d:t,pd:i,squarepad:n}=A;return{circuitJson:[n?sb(1,0,0,t,i,i):jo(1,0,0,t,i),Wi(0,i/2+.5,.2)],parameters:A}},hme=Zi.extend({fn:H(),num_pins:xA(6).default(6),h:H().default("1.6mm"),pl:H().default("1mm"),pw:H().default("0.7mm"),p:H().default("0.95mm")}),ume=e=>{const A=hme.parse(e);return{circuitJson:dme(A),parameters:A}},oXA=e=>{const{p:A,h:t,pn:i}=e;if(i===1)return{x:-t/2-.5,y:A};if(i===2)return{x:-t/2-.5,y:0};if(i===3)return{x:-t/2-.5,y:-A};if(i===4)return{x:t/2+.5,y:-A};if(i===5)return{x:t/2+.5,y:0};if(i===6)return{x:t/2+.5,y:A};throw new Error("Invalid pin number")},dme=e=>{const A=[];for(let I=1;I<=e.num_pins;I++){const{x:l,y:B}=oXA({h:Number.parseFloat(e.h),p:Number.parseFloat(e.p),pn:I});A.push(di(I,l,B,Number.parseFloat(e.pl),Number.parseFloat(e.pw)))}const t=e.num_pins/2*Number.parseFloat(e.p),i=Number.parseFloat(e.h),n={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_1",route:[{x:-t/3,y:i/2+Number.parseFloat(e.p)/1.3},{x:t/3,y:i/2+Number.parseFloat(e.p)/1.3}],type:"pcb_silkscreen_path",stroke_width:.05},o={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_2",route:[{x:-t/3,y:-i/2-Number.parseFloat(e.p)/1.3},{x:t/3,y:-i/2-Number.parseFloat(e.p)/1.3}],type:"pcb_silkscreen_path",stroke_width:.05},s=Wi(0,i+.3,.3),r=oXA({h:Number.parseFloat(e.h),p:Number.parseFloat(e.p),pn:1});r.x=r.x-Number.parseFloat(e.pw)*1.5;const a=.7,g=.3,c={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"pin1_indicator",route:[{x:r.x+a/2,y:r.y},{x:r.x-a/2,y:r.y+g/2},{x:r.x-a/2,y:r.y-g/2},{x:r.x+a/2,y:r.y}],stroke_width:.05};return[...A,s,n,o,c]},pme=Zi.extend({fn:H(),num_pins:WA().default(4),w:H().default("3.2mm"),h:H().default("2.6mm"),pl:H().default("1.35mm"),pw:H().default("0.50mm"),p:H().default("0.6mm"),string:H().optional()}),fme=e=>{const A=e.string?.match(/^sot343_(\d+)/),t=A?Number.parseInt(A[1],4):4,i=pme.parse({...e,num_pins:t});if(i.num_pins===4)return{circuitJson:mme(i),parameters:i};throw new Error("Invalid number of pins")},yme=e=>{const{pn:A,p:t}=e;return A===1?{x:-t*1.92,y:-.65}:A===2?{x:-t*1.92,y:.65}:A===3?{x:t,y:.65}:A===4?{x:t,y:-.65}:{x:0,y:0}},mme=e=>{const A=[],t=Number.parseFloat(e.w),i=Number.parseFloat(e.h),n=Number.parseFloat(e.pl),o=Number.parseFloat(e.pw),s=Number.parseFloat(e.p);let r=1/0,a=-1/0,g=1/0,c=-1/0;for(let d=0;d<e.num_pins;d++){const{x:f,y:m}=yme({num_pins:e.num_pins,pn:d+1,p:s});A.push(di(d+1,f,m,n,o)),f<r&&(r=f),f>a&&(a=f),m<g&&(g=m),m>c&&(c=m)}const I=(r+a)/2,l=c-g,B=i*.3,C=l/2+B;let Q=t*.8;i<=2.6&&(Q/=2);const E=Wi(I,C+.5,.3),h={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_top",route:[{x:I-Q/2,y:C},{x:I+Q/2,y:C}],type:"pcb_silkscreen_path",stroke_width:.1},u={layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"silkscreen_path_bottom",route:[{x:I-Q/2,y:-C},{x:I+Q/2,y:-C}],type:"pcb_silkscreen_path",stroke_width:.1};return[...A,h,u,E]},wme=Zi.extend({fn:H()}),Dme=e=>{const A=wme.parse(e),t=[],i=.5-.15,n=1.5,s=.5/2,r=75,a=-37/2;for(let D=0;D<r;D++){const b=D+1;if(b>=24&&b<=31)continue;const k=a-D*s,x=b%2===0,N=n+(x?.25:0),U=.5-N/2,T=di(b,U,k,N,i);T.layer=x?"bottom":"top",t.push(T)}const g=46*.0254,c=137*.0254,I=261*.0254,l={type:"pcb_cutout",pcb_cutout_id:"",shape:"rect",center:{x:-c/2+n/2,y:a-I},width:c,height:g},B={x:-.5,y:a},C={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"pin_marker_1",route:[{x:B.x-.4,y:B.y},{x:B.x-.7,y:B.y+.3},{x:B.x-.7,y:B.y-.3},{x:B.x-.4,y:B.y}],stroke_width:.05,pcb_silkscreen_path_id:"pin_marker_1"};let Q=1/0,E=-1/0,h=1/0,u=-1/0;const d=(D,b,k=0,x=0)=>{Q=Math.min(Q,D-k/2),E=Math.max(E,D+k/2),h=Math.min(h,b-x/2),u=Math.max(u,b+x/2)};for(const D of t)d(D.x,D.y,D.width,D.height);d(l.center.x,l.center.y,l.width,l.height);for(const D of C.route)d(D.x,D.y);const f=(Q+E)/2,m=(h+u)/2,w=D=>{typeof D.x=="number"&&(D.x-=f),typeof D.y=="number"&&(D.y-=m),D.center&&(D.center.x-=f,D.center.y-=m),Array.isArray(D.route)&&(D.route=D.route.map(b=>({x:b.x-f,y:b.y-m})))};for(const D of t)w(D);return w(l),w(C),{circuitJson:[...t,l,C],parameters:A}},Sme=Zi.extend({fn:H(),num_pins:WA().default(3),inline:gt().default(!1),p:H().default("1.27mm"),id:H().default("0.75mm"),od:H().default("1.3mm"),w:H().default("4.8mm"),h:H().default("4.0mm")}),bme=e=>{const A=Sme.parse(e),t=Number.parseFloat(A.p),i=Number.parseFloat(A.w),n=Number.parseFloat(A.h),o=A.inline?1.05:Number.parseFloat(A.od),s=A.inline?1.5:o,r=[sb(1,0,0,A.id,o,s,0,0),A.inline?rH(2,t,0,A.id,o,s):jo(2,t,t,A.id,o),A.inline?rH(3,t*2,0,A.id,o,s):jo(3,t*2,0,A.id,o)],a=i/2,g=A.inline?t-.09:t,c=.2,I=c+a-n,l=Array.from({length:32},(Q,E)=>{const h=Math.PI*E/31;return{x:g+a*Math.cos(h),y:c+a*Math.sin(h)}}),B={type:"pcb_silkscreen_path",layer:"top",pcb_component_id:"",pcb_silkscreen_path_id:"",stroke_width:.12,route:[...l,{x:g-a,y:I},{x:g+a,y:I},l[0]]},C=Wi(g,c+a+1,.5);return{circuitJson:[...r,B,C],parameters:A}};function xme(e){return e!=null}var _me=(e,A)=>{if(!A)return e;const t=e.filter(c=>c.type==="pcb_smtpad"||c.type==="pcb_plated_hole"||c.type==="pcb_thtpad");if(t.length===0)return e;let i=1/0,n=-1/0,o=1/0,s=-1/0;const r=(c,I,l=0,B=0)=>{const C=c-l/2,Q=c+l/2,E=I-B/2,h=I+B/2;i=Math.min(i,C),n=Math.max(n,Q),o=Math.min(o,E),s=Math.max(s,h)};for(const c of t)if(c.type==="pcb_smtpad"){const I=c.shape==="circle"?c.radius*2:c.width,l=c.shape==="circle"?c.radius*2:c.height;r(c.x,c.y,I,l)}else if(c.type==="pcb_plated_hole"){const I=c.outer_diameter??c.hole_diameter;r(c.x,c.y,I,I)}else if(c.type==="pcb_thtpad"){const I=c.diameter;r(c.x,c.y,I,I)}let a=0,g=0;switch(A){case"center":a=(i+n)/2,g=(o+s)/2;break;case"bottomleft":a=i,g=o;break;case"bottomcenter":case"centerbottom":a=(i+n)/2,g=o;break;case"topcenter":case"centertop":a=(i+n)/2,g=s;break;case"leftcenter":case"centerleft":a=i,g=(o+s)/2;break;case"rightcenter":case"centerright":a=n,g=(o+s)/2;break;case"pin1":const c=t.find(I=>I.port_hints?.[0]==="1")||t[0];a=c.x,g=c.y;break}if(a===0&&g===0)return e;for(const c of e){if(typeof c.x=="number"&&(c.x-=a),typeof c.y=="number"&&(c.y-=g),c.center&&typeof c.center.x=="number"&&(c.center.x-=a,c.center.y-=g),c.type==="pcb_silkscreen_path")for(const I of c.route)I.x-=a,I.y-=g;c.type==="pcb_silkscreen_text"&&c.anchor_position&&(c.anchor_position.x-=a,c.anchor_position.y-=g)}return e},kme=(e,A)=>{const t=e.filter(i=>i.type==="pcb_silkscreen_text");if(t.length===0)return e;for(const i of t)A.norefdes&&(i.text="");return e},Fme=(e,A)=>A.nosilkscreen?e.filter(t=>t.type!=="pcb_silkscreen_path"&&t.type!=="pcb_silkscreen_text"):e,Gme=e=>{let A=cW();const i=e.replace(/^((?:\d{4}|\d{5}))(?=$|_)/,"res$1").split(/_(?!metric)/).map(n=>{const o=n.match(/([a-zA-Z]+)([\(\d\.\+\?].*)?/);if(!o)return null;const[,s,r]=o;if(!s)return null;const a=s.toLowerCase();return r?.includes("?")?null:{fn:a,v:r}}).filter(xme);for(const{fn:n,v:o}of i)A=A[n](o);return A.setString(e),A},Mme=()=>Object.keys(ob),cW=()=>{const e=new Proxy({},{get:(A,t)=>{if(t==="soup"||t==="circuitJson"){if("fn"in A&&ob[A.fn])return()=>{const{circuitJson:i}=ob[A.fn](A),n=Fme(i,A),o=kme(n,A);return _me(o,A.origin)};if(!ob[A.fn])throw new Error(`Invalid footprint function, got "${A.fn}"${A.string?`, from string "${A.string}"`:""}`);return()=>{throw new Error(`No function found for footprinter, make sure to specify .dip, .lr, .p, etc. Got "${t}"`)}}if(t==="json"){if(!ob[A.fn])throw new Error(`Invalid footprint function, got "${A.fn}"${A.string?`, from string "${A.string}"`:""}`);return()=>ob[A.fn](A).parameters}return t==="getFootprintNames"?()=>Object.keys(ob):t==="params"?()=>A:t==="setString"?i=>(A.string=i,e):i=>(Object.keys(A).length===0?`${t}${i}`in ob?(A[`${t}${i}`]=!0,A.fn=`${t}${i}`):(A[t]=!0,A.fn=t,t==="res"||t==="cap"?i&&(typeof i=="string"&&i.includes("_metric")?A.metric=i.split("_metric")[0]:A.imperial=i):A.num_pins=Number.isNaN(Number.parseFloat(i))?void 0:Number.parseFloat(i)):!i&&["w","h","p"].includes(t)||(A[t]=i??!0),e)}});return e};cW.string=Gme,cW.getFootprintNames=Mme;var Rme=cW,sXA=Symbol("Fragment");function gEA(e,A,...t){const i=t.length?t:A?.children!==void 0?[A.children]:[],n=[],o=(Array.isArray(i)?i:[i]).flat(1/0);for(const s of o)s==null||s===!1||(Array.isArray(s)?n.push(...s):n.push(s));return{type:e,props:(A&&A.children!==void 0?{...A,children:void 0}:A)||{},children:n}}var Qe=Symbol("Cuboid"),rXA=Symbol("Cube"),kl=Symbol("Cylinder"),IW=Symbol("Sphere"),aH=Symbol("RoundedCuboid"),Pi=Symbol("Translate"),ZB=Symbol("Rotate"),kQ=Symbol("Union"),Zm=Symbol("Subtract"),Cc=Symbol("Hull"),To=Symbol("Colorize"),gH=Symbol("Polygon"),cH=Symbol("ExtrudeLinear"),sf=Symbol("RoundedCylinder"),Mn=sXA,zA=(e,A,t)=>gEA(e,A),Te=(e,A,t)=>gEA(e,A),sB=({center:e,width:A,length:t,height:i,heightAboveSurface:n=.15,color:o="#555",taperRatio:s=.12,faceRatio:r=.75,straightHeightRatio:a=.5,includeNotch:g=!0,notchRadius:c,notchPosition:I,notchRotation:l=[0,0,0],notchLength:B=.5,notchWidth:C=.25,chamferSize:Q=0})=>{const E=i*a,h=i-E,u=Math.min(A,t)*s,d=Math.max(A-u,A*r),f=Math.max(t-u,t*r),m=Math.min(A,t)*.12,w=c??m,D={x:0,y:t/2-w*.25,z:i},b=I??D,k=Te(kQ,{children:[Te(Cc,{children:[zA(Pi,{z:.005,children:zA(Qe,{size:[d,f,.01]})}),zA(Pi,{z:E,children:zA(Qe,{size:[A,t,.01]})})]}),Te(Cc,{children:[zA(Pi,{z:E,children:zA(Qe,{size:[A,t,.01]})}),zA(Pi,{z:E+h,children:zA(Qe,{size:[d,f,.01]})})]})]}),x=(R,U)=>zA(Pi,{offset:{x:R,y:U,z:0},children:zA(ZB,{rotation:[0,0,Math.PI/4],children:zA(Qe,{size:[Q*Math.SQRT2,Q*Math.SQRT2,i*3]})})});let N=k;if(Q>0){const R=A/2,U=t/2;N=Te(Zm,{children:[k,x(R,U),x(-R,U),x(R,-U),x(-R,-U)]})}return zA(To,{color:o,children:zA(Pi,{offset:e,children:zA(Pi,{offset:{x:0,y:0,z:n},children:g?Te(Zm,{children:[N,zA(Pi,{offset:b,children:zA(ZB,{rotation:l,children:zA(kl,{radius:w,height:C})})})]}):N})})})},Nme=e=>Array.from({length:e},(A,t)=>t);function cEA(e,A){if(e.length<2)throw new Error("Stroke must have at least two points");const t=Array.isArray(e[0])?e.map(([c,I])=>({x:c,y:I})):e,i=A/2,n=[],o=[];function s(c,I){const l=I.x-c.x,B=I.y-c.y,C=Math.sqrt(l*l+B*B);return{x:-B/C,y:l/C}}function r(c,I,l){const B={x:c.x+I.x*i*l,y:c.y+I.y*i*l};l>0?n.push(B):o.unshift(B)}const a=s(t[0],t[1]);r(t[0],a,1),r(t[0],a,-1);for(let c=1;c<t.length-1;c++){const I=t[c-1],l=t[c],B=t[c+1],C=s(I,l),Q=s(l,B),E=C.x+Q.x,h=C.y+Q.y,u=Math.sqrt(E*E+h*h);if(u/2>2*i)r(l,C,1),r(l,Q,1),r(l,C,-1),r(l,Q,-1);else{const f=1/u;r(l,{x:E*f,y:h*f},1),r(l,{x:E*f,y:h*f},-1)}}const g=s(t[t.length-2],t[t.length-1]);return r(t[t.length-1],g,1),r(t[t.length-1],g,-1),[...n,...o]}var vme=e=>{const A=Math.min(...e.map(r=>r.x)),t=Math.max(...e.map(r=>r.x)),i=Math.min(...e.map(r=>r.y)),s=5.47/(Math.max(...e.map(r=>r.y))-i);return e.map(r=>({x:(r.x-A-(t-A)/2)*s,y:(r.y-i)*s}))},Lme=vme([{x:20,y:105},{x:20,y:109},{x:20,y:102},{x:26,y:102},{x:26,y:109},{x:24,y:111},{x:24,y:118},{x:22,y:118},{x:22,y:111},{x:20,y:109}]),aXA=5.47,lW=.5,Ume=({x:e,y:A,z:t})=>{const i=e>0;return Te(Mn,{children:[zA(Pi,{offset:{x:e+.25/2,y:A,z:t},children:zA(ZB,{rotation:["-90deg",0,"90deg"],children:zA(cH,{height:.25,children:zA(gH,{points:Lme.slice().reverse().map(n=>[n.x,n.y])})})})}),zA(Pi,{offset:{x:e,y:A+(i?1:-1),z:t},children:zA(ZB,{rotation:["-90deg","90deg",i?"180deg":"0deg"],children:zA(cH,{height:2,children:zA(gH,{points:cEA([[0,0],[-1,0],[-1,-1]],.25).map(n=>[n.x,n.y])})})})})]})},Hme=({numPins:e=8,pitch:A=2.54,bodyWidth:t=6.4,rowSpacing:i})=>{const n=Math.floor(e/2),o=i??(t>=7?t:t+1.22),s=t>=7?o-1.22:t;return Te(Mn,{children:[Nme(e).map(r=>{const a=r%n,g=(Math.floor(r/n)-.5)*2;return zA(Ume,{x:g*o/2,y:a*A-(n-1)/2*A,z:aXA/2+lW})}),zA(sB,{width:s,length:n*A+.5,height:aXA-lW,heightAboveSurface:lW,center:{x:0,y:0,z:lW}})]})};function Yme(e,{height:A,padContactLength:t,curveLength:i,bodyDistance:n,steepness:o=10}){i||(i=n*.3);let s=n-t-i;s<0&&(i+=s,s=0);const r=t*.75,a=t+i+(n-t-i)*.25;if(e<=r)return 0;if(e>=a)return A;const g=(e-r)/(a-r);return A/(1+Math.exp(-o*(g-.5)))}var Vn=e=>{const{thickness:A,width:t,padContactLength:i,bodyDistance:n,height:o,rotation:s}=e,r=15,a=Array.from({length:r}).map((c,I)=>I/(r-1)*n).map(c=>[c,Yme(c,e)]),g=cEA(a,A);return zA(To,{color:"#fff",children:zA(Pi,{offset:{z:0,y:0,x:0,...e.position},children:zA(ZB,{rotation:["90deg",0,s??0],children:zA(Pi,{offset:{x:0,y:0,z:-t/2},children:zA(cH,{height:t,children:zA(gH,{points:g.map(c=>[c.x,c.y])})})})})})})},Jme=({pinCount:e,leadLength:A,leadWidth:t,pitch:i,bodyWidth:n})=>{const o=Math.ceil(e/2),s=i*e/2+t/2,r=(o-1)*i/2,a=.25;return Te(Mn,{children:[Array.from({length:o}).map((g,c)=>zA(Vn,{position:{x:-n/2-A,y:c*i-r,z:a/2},width:t,thickness:a,padContactLength:A,bodyDistance:A+1,height:.8})),Array.from({length:o}).map((g,c)=>zA(Vn,{rotation:Math.PI,position:{x:n/2+A,y:c*i-r,z:a/2},width:t,thickness:a,padContactLength:A,bodyDistance:A+1,height:.8})),zA(sB,{center:{x:0,y:0,z:a/2},width:n-t-1,length:s,height:1.5})]})},Tme=({pinCount:e,padContactLength:A=.4,leadWidth:t=.2,pitch:i=.65,bodyWidth:n=3})=>{const o=Math.ceil(e/2),s=(o-1)*i/2,r=.2;return Te(Mn,{children:[Array.from({length:o}).map((a,g)=>zA(Vn,{position:{x:-n/2-A-.3,y:g*i-s,z:r/2},width:t,thickness:r,padContactLength:A,bodyDistance:A+.4,height:.6})),Array.from({length:o}).map((a,g)=>zA(Vn,{rotation:Math.PI,position:{x:n/2+A+.3,y:g*i-s,z:r/2},width:t,thickness:r,padContactLength:A,bodyDistance:A+.4,height:.6})),zA(sB,{center:{x:0,y:0,z:r/2},width:n,length:n,height:1.1,notchRadius:.35,heightAboveSurface:.1,taperRatio:.09})]})},IEA=1,lEA=.5,XN=.5,IH=.2,Kme=IEA-IH*2,gXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[Kme,lEA,XN],offset:[0,0,XN/2],color:e}),zA(Qe,{size:[IH,XN,lEA],offset:[IEA/2-IH/2,0,XN/2],color:"#ccc"}),zA(Qe,{size:[IH,XN,lEA],offset:[-IEA/2+IH/2,0,XN/2],color:"#ccc"})]}),BEA=1.6,Pme=BEA-.3*2,BW=.3,CEA=.85,$N=.6,cXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[Pme,CEA,$N],offset:[0,0,$N/2],color:e}),zA(Qe,{size:[BW,CEA,$N],offset:[BEA/2-BW/2,0,$N/2],color:"#ccc"}),zA(Qe,{size:[BW,CEA,$N],offset:[-BEA/2+BW/2,0,$N/2],color:"#ccc"})]}),QEA=2,EEA=1.25,Av=.55,lH=.5,qme=QEA-lH*2,IXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[qme,EEA,Av],offset:[0,0,Av/2],color:e}),zA(Qe,{size:[lH,EEA,Av],offset:[QEA/2-lH/2,0,Av/2],color:"#ccc"}),zA(Qe,{size:[lH,EEA,Av],offset:[-QEA/2+lH/2,0,Av/2],color:"#ccc"})]}),Ome=({pinCount:e,pitch:A,leadWidth:t,padContactLength:i,bodyWidth:n})=>{const o=e/4;A||(A=Wme(e,n)),i||(i=Zme(e)),t||(t=Vme(e,n)),n||(n=A*(o+4));const s=n,r=(o-1)*A/2,a=s+2*i,g=a,c=.8,I=.15,l=(g-n)/2+.5;return Te(Mn,{children:[Array.from({length:o}).map((B,C)=>zA(Vn,{position:{x:-g/2-.4,y:C*A-r,z:I/2},width:t,thickness:I,padContactLength:i,bodyDistance:l,height:c})),Array.from({length:o}).map((B,C)=>zA(Vn,{rotation:Math.PI,position:{x:g/2+.4,y:C*A-r,z:I/2},width:t,thickness:I,padContactLength:i,bodyDistance:l,height:c})),Array.from({length:o}).map((B,C)=>zA(Vn,{rotation:Math.PI/2,position:{x:C*A-r,y:-a/2-.4,z:I/2},width:t,thickness:I,padContactLength:i,bodyDistance:l,height:c})),Array.from({length:o}).map((B,C)=>zA(Vn,{rotation:-Math.PI/2,position:{x:C*A-r,y:a/2+.4,z:I/2},width:t,thickness:I,padContactLength:i,bodyDistance:l,height:c})),zA(sB,{center:{x:0,y:0,z:0},width:n,length:s,height:1.5,taperRatio:.03,chamferSize:.7,notchPosition:{x:-(s/2-1.5),y:n/2-1.5,z:1.5},notchRadius:1.5/2})]})},Wme=(e,A)=>{switch(e){case 44:case 64:return .8;case 52:return A===14?1:.65;case 208:return .5;default:return .5}},Zme=e=>{switch(e){case 32:return .6;case 40:return .6;case 52:case 64:return .65;case 208:return 1.65;default:return .6}},Vme=(e,A)=>{switch(e){case 44:case 64:return .5;case 52:return A===14?.45:.55;case 208:return .3;default:return .25}},lXA=({x:e,y:A,pinThickness:t,shortSidePinLength:i,longSidePinLength:n,bodyHeight:o,bodyLength:s=2.54,bodyWidth:r=2.54,flipZ:a,faceup:g,smd:c,rightangle:I})=>Te(Mn,{children:[zA(Pi,{y:I?-3:0,children:zA(Qe,{color:"#222",size:[s,r,o],center:[e,A,a(o/2)]})}),!g&&zA(To,{color:"gold",children:c?zA(Vn,{rotation:-Math.PI/2,position:{x:e,y:A+1,z:t/2},thickness:t,width:t,height:t,padContactLength:2,bodyDistance:3}):Te(Cc,{children:[zA(Qe,{color:"gold",size:[t,t,i*.9],center:[e,A,a(o*.9+o/2)]}),zA(Qe,{color:"gold",size:[t/1.8,t/1.8,i],center:[e,A,a(o+o/2)]})]})}),zA(To,{color:"gold",children:zA(Pi,{y:I?-3.9:0,z:I?1:0,children:zA(ZB,{rotation:I?[-Math.PI/2,0,0]:[0,0,0],children:Te(Cc,{children:[zA(Qe,{color:"gold",size:[t,t,n*.9],center:[e,A,a(-n/2*.9)]}),zA(Qe,{color:"gold",size:[t/1.8,t/1.8,n],center:[e,A,a(-n/2)]})]})})})})]}),jme=({numberOfPins:e,pitch:A=2.54,longSidePinLength:t=6,invert:i,faceup:n,rows:o=1,smd:s,rightangle:r})=>{const c=Math.ceil(e/o),I=2.54,l=3,B=-((c-1)/2)*A,C=!s&&!r?-2-1.6:0,Q=E=>(i||n?-E+2:E)+C;return zA(Mn,{children:Array.from({length:e},(E,h)=>{const u=Math.floor(h/c),d=h%c,f=B+d*A,m=-u*I;return zA(lXA,{x:f,y:m,pinThickness:.63,shortSidePinLength:l,longSidePinLength:t,bodyHeight:2,flipZ:Q,faceup:n,smd:s,rightangle:r},h)})})},zme=e=>{const A=["left","bottom","right","top"],{pin_count:t,pn:i,w:n,h:o,p:s,pl:r}=e,a=t/4,g=A[Math.floor((i-1)/a)],c=(i-1)%a,I=s*(a-1),l=s*(a-1),B=-r/2;switch(g){case"left":return{x:-n/2-B,y:l/2-c*s,o:"vert"};case"bottom":return{x:-I/2+c*s,y:-o/2-B,o:"horz"};case"right":return{x:n/2+B,y:-l/2+c*s,o:"vert"};case"top":return{x:I/2-c*s,y:o/2+B,o:"horz"};default:throw new Error("Invalid pin number")}},Xme=({num_pins:e,cw:A,ccw:t,startingpin:i})=>{const n=[],o=e/4;let s=1;const r={};for(const a of i??[])r[a]=!0;!r.leftside&&!r.topside&&!r.rightside&&!r.bottomside&&(r.leftside=!0),!r.bottompin&&!r.leftpin&&!r.rightpin&&!r.toppin&&(r.leftside?r.toppin=!0:r.topside?r.rightpin=!0:r.rightside?r.bottompin=!0:r.bottomside&&(r.leftpin=!0)),r.leftside&&r.toppin?s=1:r.leftside&&r.bottompin?s=o:r.bottomside&&r.leftpin?s=o+1:r.bottomside&&r.rightpin?s=o*2:r.rightside&&r.bottompin?s=o*2+1:r.rightside&&r.toppin?s=o*3:r.topside&&r.rightpin?s=o*3+1:r.topside&&r.leftpin&&(s=o*4),n.push(-1);for(let a=0;a<e;a++)n[s]=a+1,s++,s>e&&(s=1);return n},$me=({num_pins:e=16,bodyWidth:A=9,bodyLength:t=9,bodyThickness:i=.8,thermalPadSize:n,padWidth:o=.25,padLength:s=.25,pitch:r=.5,thermalPadThickness:a=.05})=>{const g=Xme({num_pins:e,cw:!0,ccw:!0}),c=[];for(let I=0;I<e;I++){const{x:l,y:B,o:C}=zme({pin_count:e,pn:I+1,w:A,h:t,p:r,pl:s});let Q=o,E=s;C==="vert"&&([Q,E]=[E,Q]);const h=g[I+1];c.push({pn:h,x:l,y:B,pw:Q,pl:E})}return Te(Mn,{children:[zA(To,{color:"grey",children:zA(Qe,{center:{x:0,y:0,z:i/2},size:[A,t,i]})}),c.map((I,l)=>zA(Qe,{center:{x:I.x,y:I.y,z:a/2},size:[I.pw,I.pl,a]})),n?.length!==void 0&&n?.width!==void 0&&zA(Qe,{center:{x:0,y:0,z:a/2},size:[n.width,n.length,a]})]})},Awe=$me,twe=()=>{const a=1.1999999999999997;return Te(Mn,{children:[zA(Vn,{rotation:Math.PI,position:{x:2.8/2+a/4,y:-1,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:a,height:.95}),zA(Vn,{rotation:Math.PI,position:{x:2.8/2+a/4,y:1,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:a,height:.95}),zA(Vn,{position:{x:-2.8/2-a/4,y:0,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:a,height:.95}),zA(Vn,{position:{x:-2.8/2-a/4,y:-1,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:a,height:.95}),zA(Vn,{position:{x:-2.8/2-a/4,y:1,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:a,height:.95}),zA(sB,{center:{x:0,y:0,z:0},width:1.6,length:2.9,height:1.2})]})},ewe=twe,iwe=({fullWidth:e=2.9,fullLength:A=2.8})=>{const c=(e-1.92)/2+.3;return Te(Mn,{children:[zA(Vn,{rotation:Math.PI,position:{x:e/2,y:0,z:.075},width:.4,thickness:.15,padContactLength:.25,bodyDistance:c,height:.45}),zA(Vn,{position:{x:-e/2,y:-.95,z:.075},width:.4,thickness:.15,padContactLength:.25,bodyDistance:c,height:.45}),zA(Vn,{position:{x:-e/2,y:.95,z:.075},width:.4,thickness:.15,padContactLength:.25,bodyDistance:c,height:.45}),zA(sB,{center:{x:0,y:0,z:0},width:1.92,length:2.9,height:1.1,straightHeightRatio:.45,heightAboveSurface:.05})]})},hEA=.6,uEA=.3,tv=.33,BH=.1,nwe=hEA-BH*2,BXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[nwe,uEA,tv],offset:[0,0,tv/2],color:e}),zA(Qe,{size:[BH,uEA,tv],offset:[hEA/2-BH/2,0,tv/2],color:"#ccc"}),zA(Qe,{size:[BH,uEA,tv],offset:[-hEA/2+BH/2,0,tv/2],color:"#ccc"})]}),dEA=.4,pEA=.2,ev=.13,CH=.07,owe=dEA-CH*2,CXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[owe,pEA,ev],offset:[0,0,ev/2],color:e}),zA(Qe,{size:[CH,pEA,ev],offset:[dEA/2-CH/2,0,ev/2],color:"#ccc"}),zA(Qe,{size:[CH,pEA,ev],offset:[-dEA/2+CH/2,0,ev/2],color:"#ccc"})]}),fEA=3.2,yEA=1.6,iv=.9,QH=.5,swe=fEA-QH*2,QXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[swe,yEA,iv],offset:[0,0,iv/2],color:e}),zA(Qe,{size:[QH,yEA,iv],offset:[fEA/2-QH/2,0,iv/2],color:"#ccc"}),zA(Qe,{size:[QH,yEA,iv],offset:[-fEA/2+QH/2,0,iv/2],color:"#ccc"})]}),mEA=3.2,wEA=2.5,nv=1,EH=.6,rwe=mEA-EH*2,EXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[rwe,wEA,nv],offset:[0,0,nv/2],color:e}),zA(Qe,{size:[EH,wEA,nv],offset:[mEA/2-EH/2,0,nv/2],color:"#ccc"}),zA(Qe,{size:[EH,wEA,nv],offset:[-mEA/2+EH/2,0,nv/2],color:"#ccc"})]}),DEA=5,SEA=2.5,ov=1.4,hH=.6,awe=DEA-hH*2,hXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[awe,SEA,ov],offset:[0,0,ov/2],color:e}),zA(Qe,{size:[hH,SEA,ov],offset:[DEA/2-hH/2,0,ov/2],color:"#ccc"}),zA(Qe,{size:[hH,SEA,ov],offset:[-DEA/2+hH/2,0,ov/2],color:"#ccc"})]}),bEA=6.3,xEA=3.2,sv=1.8,uH=.8,gwe=bEA-uH*2,uXA=({color:e="#333"})=>Te(Mn,{children:[zA(Qe,{size:[gwe,xEA,sv],offset:[0,0,sv/2],color:e}),zA(Qe,{size:[uH,xEA,sv],offset:[bEA/2-uH/2,0,sv/2],color:"#ccc"}),zA(Qe,{size:[uH,xEA,sv],offset:[-bEA/2+uH/2,0,sv/2],color:"#ccc"})]}),cwe=({x:e,y:A,pitch:t=2.54,legsLength:i=3,innerDiameter:n=.945,bodyHeight:o=5,bodyLength:s=t,bodyWidth:r=t,flipZ:a})=>{const g=n/1.5,c=g*1.6;return Te(Mn,{children:[zA(To,{color:"#1a1a1a",children:Te(Zm,{children:[zA(Qe,{color:"#000",size:[s,r,o],center:[e,A,a(o/2)]}),n?zA(kl,{height:o+.1,radius:n/2,center:[e,A,a(o/2)],color:"#222"}):zA(Qe,{size:[c,c,o],center:[e,A,a(o/2)]})]})}),Te(To,{color:"silver",children:[Te(Cc,{children:[zA(Qe,{color:"silver",size:[g,g,i*.9],center:[e,A,a(-i/2*.9)]}),zA(Qe,{color:"silver",size:[g/1.8,g/1.8,i],center:[e,A,a(-i/2)]})]}),zA(Qe,{color:"silver",size:[c,c,c*.5],center:[e,A,a(c/2*.5)]})]})]})},Iwe=({numberOfPins:e,pitch:A=2.54,legsLength:t=3,innerDiameter:i=.945,rows:n=1,invert:o})=>{const r=Math.ceil(e/n),a=2.54,g=-((r-1)/2)*A,c=I=>o?-I+5:I;return zA(Mn,{children:Array.from({length:e},(I,l)=>{const B=Math.floor(l/r),C=l%r,Q=g+C*A,E=-B*a;return zA(cwe,{x:Q,y:E,pitch:A,legsLength:t,innerDiameter:i,flipZ:c},l)})})},lwe=({width:e,length:A,innerDiameter:t=1})=>{const i=e,n=A,o=e*.7,s=t/2.5;return Te(Mn,{children:[zA(aH,{color:"#1a1a1f",center:[0,0,o/2],size:[n,n,o],roundRadius:.3}),zA(aH,{color:"#f2f2f2",center:[0,0,o+o*.1/2.5],size:[n,n,o*.1],roundRadius:.14}),zA(kl,{color:"#1a1a1f",height:o*.8,radius:i/3,center:[0,0,o+o*.8/2]}),zA(kl,{color:"#1a1a1f",height:o*.2,radius:t/2,center:[n/3,n/3,o+o*.1/2]}),zA(kl,{color:"#1a1a1f",height:o*.2,radius:t/2,center:[-n/3,-n/3,o+o*.1/2]}),zA(kl,{color:"#1a1a1f",height:o*.2,radius:t/2,center:[-n/3,n/3,o+o*.1/2]}),zA(kl,{color:"#1a1a1f",height:o*.2,radius:t/2,center:[n/3,-n/3,o+o*.1/2]}),zA(CW,{thickness:t/3,width:s,horizontalLength:n*.8,verticalLength:o/2,position:{x:-i/2,y:-n/2,z:-o*1.2}}),zA(CW,{thickness:t/3,width:s,horizontalLength:n*.8,verticalLength:o/2,position:{x:-i/2,y:n/2,z:-o*1.2},rotation:Math.PI}),zA(CW,{thickness:t/3,width:s,horizontalLength:n*.8,verticalLength:o/2,position:{x:i/2,y:n/2,z:-o*1.2},rotation:Math.PI}),zA(CW,{thickness:t/3,width:s,horizontalLength:n*.8,verticalLength:o/2,position:{x:i/2+t/3.6,y:-n/2,z:-o*1.2}})]})},CW=e=>{const{thickness:A,width:t,horizontalLength:i,verticalLength:n,rotation:o=0,position:s}=e,r=[[0,i],[-n/3,i/3],[-n/5,i/4],[0,0]],a=cEA(r,A);return zA(To,{color:"#f2f2f2",children:zA(Pi,{offset:{x:s?.x||0,y:s?.y||0,z:s?.z||0},children:zA(ZB,{rotation:[0,55,o],children:zA(cH,{height:t,children:zA(gH,{points:a.map(g=>[g.y,g.x])})})})})})},Bwe=({pinCount:e,leadLength:A,leadWidth:t,pitch:i,bodyWidth:n})=>{const o=Math.ceil(e/2),s=(o-1)*i/2,r=.25,a=1,g=.8,c=A*0,I=i*(o-1)+t+.2,l=n*.55;return Te(Mn,{children:[Array.from({length:o}).map((B,C)=>zA(Vn,{position:{x:-n/2-c,y:C*i-s,z:r/2},width:t,thickness:r,padContactLength:A/2,bodyDistance:A+.3,height:g})),Array.from({length:o}).map((B,C)=>zA(Vn,{rotation:Math.PI,position:{x:n/2+c,y:C*i-s,z:r/2},width:t,thickness:r,padContactLength:A/2,bodyDistance:A+.3,height:g})),zA(sB,{center:{x:0,y:0,z:r/2},width:l,length:I,height:a})]})},Cwe=({pinCount:e,pitch:A,leadWidth:t,leadLength:i,bodyWidth:n,bodyLength:o})=>{const s=e===8?{pitch:.65,leadWidth:.3}:{pitch:.5,leadWidth:.225},r=isNaN(parseFloat(A))?s.pitch:parseFloat(A),a=isNaN(parseFloat(t))?s.leadWidth:parseFloat(t)*.8,g=isNaN(parseFloat(n))?2.6:parseFloat(n)*.8,c=isNaN(parseFloat(o))?2+Number(r)*1.4:parseFloat(o),I=e/2,l=(I-1)*r/2,B=.15,C=.8,Q=4.5,E=(Q-g)/2,h=E*.5;return Te(Mn,{children:[Array.from({length:I}).map((u,d)=>zA(Vn,{position:{x:-Q/2,y:l-d*r,z:B/2},width:a,thickness:B,padContactLength:h+.05,bodyDistance:E+.1,height:C})),Array.from({length:I}).map((u,d)=>zA(Vn,{rotation:Math.PI,position:{x:Q/2,y:l-d*r,z:B/2},width:a,thickness:B,padContactLength:h+.05,bodyDistance:E+.1,height:C})),zA(sB,{center:{x:0,y:0,z:B/2},width:g,length:c,height:1})]})},Qwe=()=>Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[.5,.6,.12],center:[-.725,0,.12/2]}),zA(Qe,{color:"#ccc",size:[.5,.6,.12],center:[.725,0,.12/2]}),zA(To,{color:"#222",children:Te(kQ,{children:[zA(Pi,{z:.3/2,children:zA(Qe,{size:[1.65,.8,.3]})}),Te(Cc,{children:[zA(Pi,{z:.3,children:zA(Qe,{size:[1.65,.8,.01]})}),zA(Pi,{z:.6,children:zA(Qe,{size:[1.65-.2,.8-.2,.01]})})]})]})})]}),Ewe=()=>Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[.26,.51,.12],center:[-.325,0,.12/2]}),zA(Qe,{color:"#ccc",size:[.26,.51,.12],center:[.325,0,.12/2]}),zA(To,{color:"#222",children:zA(Pi,{z:.47/2+.02,children:zA(Qe,{size:[.98,.58,.47]})})}),zA(Qe,{color:"#ccc",size:[.98+.001,.26/2,.26/4],center:[0,.26/2,.47/4]}),zA(Qe,{color:"#ccc",size:[.98+.001,.26/2,.26/4],center:[0,-.26/2,.47/4]}),zA(Qe,{color:"#ccc",size:[.26/1.5,.58+.001,.26/4],center:[.65/2,0,.47/4]}),zA(Qe,{color:"#ccc",size:[.26/1.5,.58+.001,.26/4],center:[-.65/2,0,.47/4]})]}),hwe=()=>{const g=zA(To,{color:"#1a1a1a",children:Te(kQ,{children:[Te(Cc,{children:[zA(Pi,{z:.13,children:zA(Qe,{size:[4,3,.03]})}),zA(Pi,{z:1.15,children:zA(Qe,{size:[4.4,3.4,.01]})})]}),Te(Cc,{children:[zA(Pi,{z:1.15,children:zA(Qe,{size:[4.4,3.4,.01]})}),zA(Pi,{z:2.3,children:zA(Qe,{size:[4,3,.01]})})]})]})}),c=({xDir:I})=>{const C=I*1.78,Q=I*(3.4/2-.2/2+1),E=I*(3.4/2-.2/2),h=Math.abs(E-Q),u=(Q+E)/2;return zA(To,{color:"#c0c0c0",children:Te(kQ,{children:[zA(Qe,{size:[2.3*.8,1.45,.2],center:[C,0,.2/2]}),zA(Qe,{size:[.2,1.45,1.14],center:[Q,0,1.14/2+.2]}),zA(Qe,{size:[h,1.45,.2],center:[u,0,.2/2+1.14]})]})})};return Te(Mn,{children:[zA(c,{xDir:1}),zA(c,{xDir:-1}),g]})},uwe=()=>{const g=zA(To,{color:"#1a1a1a",children:Te(kQ,{children:[Te(Cc,{children:[zA(Pi,{z:.13,children:zA(Qe,{size:[4,3,.03]})}),zA(Pi,{z:1.15,children:zA(Qe,{size:[4.4,3.4,.01]})})]}),Te(Cc,{children:[zA(Pi,{z:1.15,children:zA(Qe,{size:[4.4,3.4,.01]})}),zA(Pi,{z:2.3,children:zA(Qe,{size:[4,3,.01]})})]})]})}),c=({xDir:I})=>{const C=I*1.78,Q=I*(3.4/2-.2/2+1),E=I*(3.4/2-.2/2),h=Math.abs(E-Q),u=(Q+E)/2;return zA(To,{color:"#c0c0c0",children:Te(kQ,{children:[zA(Qe,{size:[2.3*.8,1.45,.2],center:[C,0,.2/2]}),zA(Qe,{size:[.2,1.45,1.14],center:[Q,0,1.14/2+.2]}),zA(Qe,{size:[h,1.45,.2],center:[u,0,.2/2+1.14]})]})})};return Te(Mn,{children:[zA(c,{xDir:1}),zA(c,{xDir:-1}),g]})},dwe=()=>{const g=zA(To,{color:"#1a1a1a",children:Te(kQ,{children:[Te(Cc,{children:[zA(Pi,{z:.21000000000000002,children:zA(Qe,{size:[6.3999999999999995,5.6,.03]})}),zA(Pi,{z:1.15,children:zA(Qe,{size:[6.8,6,.01]})})]}),Te(Cc,{children:[zA(Pi,{z:1.15,children:zA(Qe,{size:[6.8,6,.01]})}),zA(Pi,{z:2.3,children:zA(Qe,{size:[6.3999999999999995,5.6,.01]})})]})]})}),c=({xDir:I})=>{const C=I*3.08,Q=I*(6/2-.2/2+1),E=I*(6/2-.2/2),h=Math.abs(E-Q),u=(Q+E)/2;return zA(To,{color:"#c0c0c0",children:Te(kQ,{children:[zA(Qe,{size:[2.3*.8,2.95,.2],center:[C,0,.2/2]}),zA(Qe,{size:[.2,2.95,1.14],center:[Q,0,1.14/2+.2]}),zA(Qe,{size:[h,2.95,.2],center:[u,0,.2/2+1.14]})]})})};return Te(Mn,{children:[zA(c,{xDir:1}),zA(c,{xDir:-1}),g]})},pwe=()=>{const I=zA(To,{color:"#222",children:Te(kQ,{children:[zA(Pi,{z:.27,children:zA(Qe,{size:[2.9,1.9,.54]})}),Te(Cc,{children:[zA(Pi,{z:.54,children:zA(Qe,{size:[2.9,1.9,.01]})}),zA(Pi,{z:1.08,children:zA(Qe,{size:[2.6999999999999997,1.7,.01]})})]})]})});return Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[1,1.2,.25],center:[-1.3,0,.25/2]}),zA(Qe,{color:"#ccc",size:[1,1.2,.25],center:[1.3,0,.25/2]}),I]})},fwe=()=>Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[1,.6,.12],center:[-1.3,0,.12/2]}),zA(Qe,{color:"#ccc",size:[1,.6,.12],center:[1.3,0,.12/2]}),zA(To,{color:"#222",children:Te(kQ,{children:[zA(Pi,{z:.55/2,children:zA(Qe,{size:[2.7,1.6,.55]})}),Te(Cc,{children:[zA(Pi,{z:.55,children:zA(Qe,{size:[2.7,1.6,.01]})}),zA(Pi,{z:1.1,children:zA(Qe,{size:[2.7-.2,1.6-.2,.01]})})]})]})})]}),ywe=()=>Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[1,.9,.2],center:[-1.3,0,.2/2]}),zA(Qe,{color:"#ccc",size:[1,.9,.2],center:[1.3,0,.2/2]}),zA(To,{color:"#222",children:Te(kQ,{children:[zA(Pi,{z:.2/2,children:zA(Qe,{size:[2.75,1.8,.2]})}),Te(Cc,{children:[zA(Pi,{z:.2,children:zA(Qe,{size:[2.75,1.8,.01]})}),zA(Pi,{z:1,children:zA(Qe,{size:[2.75-.4,1.8-.4,.01]})})]})]})}),zA(Qe,{color:"#777",size:[.2,1.8-.4,.01],center:[-1.3+.4,0,1]})]}),mwe=()=>Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[.9,.9,.2],center:[-1.225,0,.2/2]}),zA(Qe,{color:"#ccc",size:[.9,.9,.2],center:[1.225,0,.2/2]}),zA(To,{color:"#222",children:Te(kQ,{children:[Te(Cc,{children:[zA(Pi,{z:.2,children:zA(Qe,{size:[2.6-.1/2,1.7-.1/2,.01]})}),zA(Pi,{z:.01,children:zA(Qe,{size:[2.6-.1,1.7-.1,.01]})})]}),Te(Cc,{children:[zA(Pi,{z:.2,children:zA(Qe,{size:[2.6,1.7,.01]})}),zA(Pi,{z:1,children:zA(Qe,{size:[2.6-.4,1.7-.4,.01]})})]})]})}),zA(Qe,{color:"#777",size:[.2*2.7,1.7-.4,.02],center:[-1.225+.4,0,1]})]}),wwe=()=>Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[.9,1.75,.2],center:[-1.825,0,.2/2]}),zA(Qe,{color:"#ccc",size:[.9,1.75,.2],center:[1.825,0,.2/2]}),zA(To,{color:"#222",children:Te(kQ,{children:[Te(Cc,{children:[zA(Pi,{z:.2,children:zA(Qe,{size:[3.8-.05/2,2.5-.05/2,.01]})}),zA(Pi,{z:.01,children:zA(Qe,{size:[3.8-.05,2.5-.05,.01]})})]}),Te(Cc,{children:[zA(Pi,{z:.2,children:zA(Qe,{size:[3.8,2.5,.01]})}),zA(Pi,{z:1,children:zA(Qe,{size:[3.8-.4,2.5-.4,.01]})})]})]})}),zA(Qe,{color:"#777",size:[.2*2.7,2.5-.4,.02],center:[-1.825+.4,0,1]})]}),Dwe=()=>Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[.4,.25,.14],center:[-.4,0,.14/2]}),zA(Qe,{color:"#ccc",size:[.4,.25,.14],center:[.4,0,.14/2]}),zA(To,{color:"#222",children:Te(kQ,{children:[zA(Pi,{z:.14/2,children:zA(Qe,{size:[.8,.6,.14]})}),Te(Cc,{children:[zA(Pi,{z:.14,children:zA(Qe,{size:[.8,.6,.01]})}),zA(Pi,{z:.37,children:zA(Qe,{size:[.8-.1,.6-.1,.01]})})]})]})})]}),Swe=()=>{const c=3.0999999999999996;return Te(Mn,{children:[zA(Vn,{rotation:Math.PI,position:{x:6.6/2+c/4,y:0,z:.25/2},width:3,thickness:.25,padContactLength:.5,bodyDistance:c,height:.75}),zA(Vn,{position:{x:-6.6/2-c/4,y:0,z:.25/2},width:.7,thickness:.25,padContactLength:.5,bodyDistance:c,height:.75}),zA(Vn,{position:{x:-6.6/2-c/4,y:-2.3,z:.25/2},width:.7,thickness:.25,padContactLength:.5,bodyDistance:c,height:.75}),zA(Vn,{position:{x:-6.6/2-c/4,y:2.3,z:.25/2},width:.7,thickness:.25,padContactLength:.5,bodyDistance:c,height:.75}),zA(sB,{center:{x:0,y:0,z:0},width:3.5,length:6.5,height:1.7,includeNotch:!1,taperRatio:.06,straightHeightRatio:.45})]})},bwe=()=>Te(Mn,{children:[Array.from({length:16}).map((B,C)=>zA(Vn,{position:{x:-10.5/2,y:C*.5-3.75,z:.25/2},width:.2,thickness:.25,padContactLength:.45,bodyDistance:.95,height:.65})),Array.from({length:16}).map((B,C)=>zA(Vn,{rotation:Math.PI,position:{x:10.5/2,y:C*.5-3.75,z:.25/2},width:.2,thickness:.25,padContactLength:.45,bodyDistance:.95,height:.65})),Array.from({length:16}).map((B,C)=>zA(Vn,{rotation:Math.PI/2,position:{x:C*.5-3.75,y:-10.5/2,z:.25/2},width:.2,thickness:.25,padContactLength:.45,bodyDistance:.95,height:.65})),Array.from({length:16}).map((B,C)=>zA(Vn,{rotation:-Math.PI/2,position:{x:C*.5-3.75,y:10.5/2,z:.25/2},width:.2,thickness:.25,padContactLength:.45,bodyDistance:.95,height:.65})),zA(sB,{center:{x:0,y:0,z:0},width:9,length:9,height:1.2,chamferSize:.7,taperRatio:.05,notchPosition:{x:-3.5,y:3.5,z:1.2},notchRadius:1.2/2})]}),xwe=bwe,_we=()=>{const g=.7999999999999998;return Te(Mn,{children:[zA(Vn,{rotation:Math.PI,position:{x:2.05/2+g/4,y:0,z:.18/2},width:.3,thickness:.18,padContactLength:.2,bodyDistance:g,height:.65}),zA(Vn,{position:{x:-2.05/2-g/4,y:-.65,z:.18/2},width:.3,thickness:.18,padContactLength:.2,bodyDistance:g,height:.65}),zA(Vn,{position:{x:-2.05/2-g/4,y:.65,z:.18/2},width:.3,thickness:.18,padContactLength:.2,bodyDistance:g,height:.65}),zA(sB,{center:{x:0,y:0,z:0},width:1.25,length:2,height:.9,includeNotch:!1,taperRatio:.06,straightHeightRatio:.7,heightAboveSurface:.05})]})},kwe=({pinCount:e,pitch:A,leadWidth:t,padContactLength:i,bodyWidth:n})=>{const o=e/4;if(o!==Math.floor(o))throw new Error(`LQFP pinCount must be divisible by 4, got ${e}`);A||(A=.5),i||(i=.6),t||(t=.22),n||(n=A*(o+4));const s=n,r=(o-1)*A/2,a=s+3.3*i,g=a,c=.8,I=.2,l=(g-n)/2+.4;return Te(Mn,{children:[Array.from({length:o}).map((B,C)=>zA(Vn,{position:{x:-g/2-.36,y:C*A-r,z:I/2},width:t,thickness:I,padContactLength:i,bodyDistance:l,height:c})),Array.from({length:o}).map((B,C)=>zA(Vn,{rotation:Math.PI,position:{x:g/2+.36,y:C*A-r,z:I/2},width:t,thickness:I,padContactLength:i,bodyDistance:l,height:c})),Array.from({length:o}).map((B,C)=>zA(Vn,{rotation:Math.PI/2,position:{x:C*A-r,y:-a/2-.36,z:I/2},width:t,thickness:I,padContactLength:i,bodyDistance:l,height:c})),Array.from({length:o}).map((B,C)=>zA(Vn,{rotation:-Math.PI/2,position:{x:C*A-r,y:a/2+.36,z:I/2},width:t,thickness:I,padContactLength:i,bodyDistance:l,height:c})),zA(sB,{center:{x:0,y:0,z:0},width:n,length:s,height:1.5,heightAboveSurface:.1,taperRatio:.04,chamferSize:.7,notchPosition:{x:-(s/2-1.5),y:s/2-1.5,z:1.5},notchRadius:1.5/2})]})},Fwe=()=>{const i=.20900000000000002,n=.1,o=.3,s=.1,r=.2;return Te(Mn,{children:[zA(To,{color:"#222",children:Te(kQ,{children:[zA(Qe,{size:[.85,1.2,i],center:[0,0,i/2]}),Te(Cc,{children:[zA(Pi,{z:i,children:zA(Qe,{size:[.85,1.2,.01]})}),zA(Pi,{z:.38,children:zA(Qe,{size:[.85-n,1.2-n,.01]})})]})]})}),zA(Qe,{color:"#ccc",size:[o,.25,s],center:[.55,0,s/2]}),zA(Qe,{color:"#ccc",size:[o,r,s],center:[-.55,.4,s/2]}),zA(Qe,{color:"#ccc",size:[o,r,s],center:[-.55,-.4,s/2]})]})},Gwe=({num_pins:e,bodyWidth:A=5.3,bodyLength:t=5.3,bodyThickness:i=1,thermalPadSize:n,padWidth:o=t/5.3*.6,padLength:s=t/5.3*1,pitch:r=.5,thermalPadThickness:a=.2})=>{const g=[],c=Math.floor(e/2),I=r*(c-1);for(let l=0;l<e;l++){const B=l<c?"left":"right",C=l%c,Q=I/2-C*r,E=s,h=o,u=B==="left"?-A/2+E/2:A/2-E/2,d=l+1;g.push({pinNumber:d,x:u,y:Q,padSizeX:E,padSizeY:h})}return Te(Mn,{children:[zA(sB,{center:{x:0,y:0,z:0},width:A,length:t,height:i,heightAboveSurface:0,color:"grey",chamferSize:.2,taperRatio:0,notchPosition:{x:-(A/2-s),y:t/2-s,z:i}}),g.map((l,B)=>zA(Qe,{center:[l.x,l.y,a/2],size:[l.padSizeX,l.padSizeY,a]})),n?.length!==void 0&&n?.width!==void 0&&zA(Qe,{center:[0,0,a/2],size:[n.width,n.length,a]})]})},Mwe=({bodyLength:e=10.2,bodyWidth:A=4.65,bodyHeight:t=13.46,leadSpacing:i=5,leadDiameter:n=.8,leadLength:o=12.7,color:s="#ddd",leadColor:r="#b87333"})=>{const a=e/2,g=A/2,c=a-g,I=i/2,l=.85;return Te(Mn,{children:[Te(To,{color:s,children:[Te(Cc,{children:[zA(sf,{height:t,roundRadius:.5,radius:g,center:[-c,0,t]}),zA(sf,{height:t,roundRadius:.5,radius:g,center:[c,0,t]})]}),Te(Cc,{children:[zA(sf,{height:l,roundRadius:.1,radius:g+.85,center:[-c,0,t/2+l/2]}),zA(sf,{height:l,roundRadius:.1,radius:g+.85,center:[c,0,t/2+l/2]})]})]}),Te(To,{color:r,children:[zA(kl,{height:o+t/2,radius:n/2,center:[-I+.06,0,-(o/2)+t/2]}),zA(kl,{height:o+t/2,radius:n/2,center:[I-.06,0,-(o/2)+t/2]})]})]})},Rwe=({bodyLength:e=1.4,bodyDiameter:A=1.1,color:t="#3a3a3aff",contactColor:i="#c6c6c6",cathodeIdentification:n="#111"})=>Te(Mn,{children:[zA(To,{color:t,children:Te(ZB,{rotation:[0,"90deg",0],children:[zA(aH,{size:[A,A,e-.2],roundRadius:.2,center:[-A/2,0,.05]}),zA(kl,{height:.2/2,radius:A/2-.2,center:[-A/2,0,-e/2+.2/2]})]})}),zA(To,{color:n,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(aH,{size:[A*1.01,A*1.01,e/3],roundRadius:.2,center:[-A/2,0,-e/4+.1]})})}),zA(To,{color:i,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(sf,{height:.2,radius:A/2,roundRadius:.2/3,center:[-A/2,0,-e/2]})})}),zA(To,{color:i,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(sf,{height:.2,radius:A/2,roundRadius:.2/3,center:[-A/2,0,e/2]})})})]}),Nwe=({bodyLength:e=3.5,bodyDiameter:A=1.5,color:t="#3a3a3aff",contactColor:i="#c6c6c6"})=>Te(Mn,{children:[zA(To,{color:t,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(sf,{height:e,radius:A/2,roundRadius:.3,center:[-A/2,0,0]})})}),zA(To,{color:i,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(sf,{height:.5,radius:A/2,roundRadius:.2,center:[-A/2,0,-e/2]})})}),zA(To,{color:i,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(sf,{height:.5,radius:A/2,roundRadius:.2,center:[-A/2,0,e/2]})})})]}),vwe=({bodyLength:e=3.9,bodyDiameter:A=2.5,color:t="#3a3a3aff",contactColor:i="#c6c6c6"})=>Te(Mn,{children:[zA(To,{color:t,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(sf,{height:e,radius:A/2,roundRadius:.3,center:[-A/2,0,0]})})}),zA(To,{color:i,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(sf,{height:.55,radius:A/2,roundRadius:.2,center:[-A/2,0,-e/2]})})}),zA(To,{color:i,children:zA(ZB,{rotation:[0,"90deg",0],children:zA(sf,{height:.55,radius:A/2,roundRadius:.2,center:[-A/2,0,e/2]})})})]}),Lwe=({pinCount:e,padContactLength:A=.6,leadWidth:t=.41,pitch:i=1.27})=>{if(e%2!==0)throw new Error("MS012 pinCount must be even");const n=e/2,o=4.9,s=3.9,r=(n-1)*i/2,a=.2;return Te(Mn,{children:[Array.from({length:n}).map((g,c)=>zA(Vn,{position:{x:-s/2-A-.3,y:c*i-r,z:a/2},width:t,thickness:a,padContactLength:A,bodyDistance:A+.4,height:.85})),Array.from({length:n}).map((g,c)=>zA(Vn,{rotation:Math.PI,position:{x:s/2+A+.3,y:c*i-r,z:a/2},width:t,thickness:a,padContactLength:A,bodyDistance:A+.4,height:.85})),zA(sB,{center:{x:0,y:0,z:a/2},width:s,length:o,height:1.55,notchPosition:{x:-.95,y:o/2-1,z:1.55},heightAboveSurface:.17,taperRatio:.09})]})},Uwe=({pinCount:e=16,padContactLength:A=.6,leadWidth:t=.41,pitch:i=1.27})=>{if(e!==16)throw new Error("MS013 only supports 16 pins");const n=e/2,o=7.5,s=10.3,r=(n-1)*i/2,a=.2;return Te(Mn,{children:[Array.from({length:n}).map((g,c)=>zA(Vn,{position:{x:-o/2-A-.3,y:c*i-r,z:a/2},width:t,thickness:a,padContactLength:A,bodyDistance:A+.4,height:.85})),Array.from({length:n}).map((g,c)=>zA(Vn,{rotation:Math.PI,position:{x:o/2+A+.3,y:c*i-r,z:a/2},width:t,thickness:a,padContactLength:A,bodyDistance:A+.4,height:.85})),zA(sB,{center:{x:0,y:0,z:a/2},width:o,length:s,height:1.1,notchPosition:{x:-2.25,y:s/2-1.5,z:1.1},heightAboveSurface:.17,taperRatio:.05})]})},Hwe=()=>{const Q=7.050000000000001,E=24.95+6.5/2;return zA(Pi,{center:[0,0,1],children:Te(Mn,{children:[Te(ZB,{rotation:[0,55,-55],children:[Te(Zm,{children:[zA(Qe,{color:"#ccc",size:[6.5+.1,9.9,1.3],center:[E,0,1.3-2]}),zA(kl,{color:"black",center:[E,0,1.3-2],radius:3/2,height:1.3*1.2})]}),zA(To,{color:"#222",children:zA(sB,{width:9.9,length:9.9,height:4.5,center:{x:20,y:0,z:-2.4},includeNotch:!1,straightHeightRatio:.3,taperRatio:.04,heightAboveSurface:1})})]}),zA(ZB,{rotation:[0,55,55],children:Array.from({length:3}).map((h,u)=>{const d=Q,f=(u-1)*2.7,m=-.5-.6;return Te(To,{color:"gold",children:[Te(Cc,{children:[zA(Pi,{center:[15.05-4.5/2+.1,f,m],children:zA(Qe,{size:[4.5,.81+1,.5]})}),zA(Pi,{center:[15.05-4.5/2-1+.1,f,m],children:zA(Qe,{size:[4.5,.81,.5]})})]}),zA(Pi,{center:[d,f,m],children:zA(Qe,{size:[16+.1,.81,.5]})})]},`prong-${u}`)})})]})})},Ywe=()=>{const g=1.1999999999999997;return Te(Mn,{children:[zA(Vn,{rotation:Math.PI,position:{x:2.8/2+g/4,y:-.95,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:g,height:.95}),zA(Vn,{rotation:Math.PI,position:{x:2.8/2+g/4,y:0,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:g,height:.95}),zA(Vn,{rotation:Math.PI,position:{x:2.8/2+g/4,y:.95,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:g,height:.95}),zA(Vn,{position:{x:-2.8/2-g/4,y:0,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:g,height:.95}),zA(Vn,{position:{x:-2.8/2-g/4,y:-.95,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:g,height:.95}),zA(Vn,{position:{x:-2.8/2-g/4,y:.95,z:.15/2},width:.4,thickness:.15,padContactLength:.5,bodyDistance:g,height:.95}),zA(sB,{center:{x:0,y:0,z:0},width:1.6,length:2.9,height:1.2,straightHeightRatio:.6,notchPosition:{x:-.4,y:1.2/2+.4,z:1.2+.05},notchRadius:.1})]})},Jwe=()=>Te(Mn,{children:[zA(sB,{center:{x:0,y:0,z:0},width:.8,length:1,height:.37,heightAboveSurface:0,color:"#1a1a1a",taperRatio:.15,straightHeightRatio:0,notchPosition:{x:-.8/4,y:.7/2.2,z:.37+.1}}),[0,1,2].map(g=>{const c=-.35+g*.35;return zA(Qe,{center:[-.8/2+.19/2-.1,c,.12/2],size:[.19,.15,.12]})}),[0,1,2].map(g=>{const c=-.35+g*.35;return zA(Qe,{center:[.8/2-.19/2+.1,c,.12/2],size:[.19,.15,.12]})})]}),Twe=()=>{const s="#222",a=[.43,.4,1.32],g=[.43,.4,.25],c=[0,0,-.66],I=[0,0,-1.32],l=[0,1.28,-2.72],B=[0,1.28,-8.9],C=-7.5;return Te(Pi,{center:[0,1,10.5],children:[zA(To,{color:s,children:Te(Zm,{children:[zA(Pi,{center:[0,0,2.25],children:zA(kl,{radius:2.4,height:4.5})}),zA(Pi,{center:[0,-1.8499999999999999,2.25],children:zA(Qe,{size:[2.4*2,1.1,4.5+.2]})})]})}),zA(Pi,{center:c,children:zA(Qe,{size:a})}),Te(Cc,{children:[zA(Pi,{center:I,children:zA(Qe,{size:g})}),zA(Pi,{center:l,children:zA(Qe,{size:g})})]}),zA(Pi,{center:B,children:zA(Qe,{size:[.43,.4,12.2]})}),zA(Pi,{center:[1.3,0,C],children:zA(Qe,{size:[.43,.4,15]})}),zA(Pi,{center:[-1.3,0,C],children:zA(Qe,{size:[.43,.4,15]})})]})},Kwe=()=>Te(Mn,{children:[zA(Vn,{rotation:Math.PI,position:{x:2/2+.75/4,y:-.65,z:.15/2},width:.25,thickness:.15,padContactLength:.3,bodyDistance:.75,height:.85}),zA(Vn,{rotation:Math.PI,position:{x:2/2+.75/4,y:0,z:.15/2},width:.25,thickness:.15,padContactLength:.3,bodyDistance:.75,height:.85}),zA(Vn,{rotation:Math.PI,position:{x:2/2+.75/4,y:.65,z:.15/2},width:.25,thickness:.15,padContactLength:.3,bodyDistance:.75,height:.85}),zA(Vn,{position:{x:-2/2-.75/4,y:0,z:.15/2},width:.25,thickness:.15,padContactLength:.3,bodyDistance:.75,height:.85}),zA(Vn,{position:{x:-2/2-.75/4,y:-.65,z:.15/2},width:.25,thickness:.15,padContactLength:.3,bodyDistance:.75,height:.85}),zA(Vn,{position:{x:-2/2-.75/4,y:.65,z:.15/2},width:.25,thickness:.15,padContactLength:.3,bodyDistance:.75,height:.85}),zA(sB,{center:{x:0,y:0,z:0},width:1.25,length:2,height:1.1,straightHeightRatio:.6,notchPosition:{x:-.375,y:1.1/2+.2,z:1.1},heightAboveSurface:.1})]}),Pwe=Kwe,qwe=()=>Te(Mn,{children:[zA(sB,{center:{x:0,y:0,z:.05},width:1,length:1.45,height:.5,heightAboveSurface:0,color:"#1a1a1a",taperRatio:0,includeNotch:!1}),[0,1,2].map(r=>{const a=-.5+r*.5;return zA(Qe,{center:[-1/2+.3/2,a,.05/2],size:[.3,.2,.05]})}),[0,1,2].map(r=>{const a=-.5+r*.5;return zA(Qe,{center:[1/2-.3/2,a,.05/2],size:[.3,.2,.05]})})]}),Owe=()=>Te(Mn,{children:[zA(Vn,{position:{x:-2.5/2,y:0,z:.175/2},width:.3,thickness:.175,padContactLength:.3,bodyDistance:.45,height:.7}),zA(Vn,{rotation:Math.PI,position:{x:2.5/2,y:0,z:.175/2},width:.3,thickness:.175,padContactLength:.3,bodyDistance:.45,height:.7}),zA(To,{color:"#222",children:zA(sB,{center:{x:0,y:0,z:0},width:1.7,length:1.25,height:.95,includeNotch:!1,taperRatio:.06,straightHeightRatio:.7,heightAboveSurface:.05})}),zA(Qe,{color:"#777",size:[1.7/3,1.25-.075,.02],center:[-.85*2/3+.035,0,.95+.05]})]}),Wwe=()=>Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[.4,.325,.175],center:[-1.05,0,.175/2]}),zA(Qe,{color:"#ccc",size:[.4,.325,.175],center:[1.05,0,.175/2]}),zA(To,{color:"#222",children:Te(kQ,{children:[zA(Pi,{z:.175/2,children:zA(Qe,{size:[1.7,1.25,.175]})}),Te(Cc,{children:[zA(Pi,{z:.175,children:zA(Qe,{size:[1.7,1.25,.01]})}),zA(Pi,{z:.725,children:zA(Qe,{size:[1.7-.2,1.25-.2,.01]})})]})]})}),zA(Qe,{color:"#777",size:[1.7/3,1.25-.2,.02],center:[-1.05+1.7/4.4+.2,0,.725]})]}),Zwe=()=>{const s=-1.0474999999999999,r=1.775/2+.4/2-.04;return Te(Mn,{children:[zA(Qe,{color:"#ccc",size:[.4,.325,.13],center:[s,0,.13/2]}),zA(Qe,{color:"#ccc",size:[.4,.325,.13],center:[r,0,.13/2]}),zA(To,{color:"#222",children:zA(sB,{width:1.775,length:1.25,height:.725,center:{x:0,y:0,z:0},heightAboveSurface:0,straightHeightRatio:.7,taperRatio:.06,includeNotch:!1})}),zA(Qe,{color:"#777",size:[1.775/3,1.25-.05,.02],center:[s+1.775/4.4+.2,0,.725]})]})},Vwe=({pitch:e=10})=>Te(Mn,{children:[zA(kl,{height:4,radius:.5,center:[-e/2,0,.5]}),zA(IW,{radius:.5,center:[-e/2,0,2.5]}),zA(Pi,{x:-2.5,y:0,z:2.5,children:Te(ZB,{rotation:[0,Math.PI/2,0],children:[zA(kl,{height:e,radius:.5,center:[0,0,2.5]}),zA(To,{color:"#d2b48c",children:zA(kl,{height:5,radius:1.3,center:[0,0,2.5]})})]})}),zA(kl,{height:4,radius:.5,center:[e/2,0,.5]}),zA(IW,{radius:.5,center:[e/2,0,2.5]})]}),jwe=({bodyWidth:e=21,boardThickness:A=.5,leadWidth:t=1.6,leadLength:i=2.4,leadsPitch:n=2.54,leadsLeft:o,leadsRight:s,leadsTop:r,leadsBottom:a,innerHoles:g=!0,innerHoleEdgeDistance:c=1.61,innerHoleDiameter:I=1})=>{const l=e/2,B=A/2,C=A*1.05,Q=I/2,E=Math.max(o||0,s||0,r||0,a||0)*n||51,h=[],u=[];if(s){const w=-((s-1)/2)*n;for(let D=0;D<s;D++){const b=w+D*n;h.push({x:-l+i/2,y:-b,pl:i,pw:t}),g&&u.push({x:-l,y:-b},{x:-l+c,y:-b})}}if(o){const w=-((o-1)/2)*n;for(let D=0;D<o;D++){const b=w+D*n;h.push({x:l-i/2,y:-b,pl:i,pw:t}),g&&u.push({x:l,y:-b},{x:l-c,y:-b})}}if(r){const w=-((r-1)/2)*n;for(let D=0;D<r;D++){const b=w+D*n;h.push({x:-b,y:-E/2+i/2,pl:t,pw:i}),g&&u.push({x:-b,y:-E/2},{x:-b,y:-E/2+c})}}if(a){const w=-((a-1)/2)*n;for(let D=0;D<a;D++){const b=w+D*n;h.push({x:-b,y:E/2-i/2,pl:t,pw:i}),g&&u.push({x:-b,y:E/2},{x:-b,y:E/2-c})}}const d=zA(To,{color:"#008080",children:Te(Zm,{children:[zA(Qe,{center:[0,0,B],size:[e,E,A]}),h.map((w,D)=>zA(Qe,{center:[w.x,w.y,B],size:[w.pl+.01,w.pw+.01,C]},D))]})}),f=g&&u.map((w,D)=>zA(kl,{color:"black",center:[w.x,w.y,B],radius:Q,height:A*1.07})),m=h.map((w,D)=>zA(Qe,{center:[w.x,w.y,B],size:[w.pl+.01,w.pw+.01,C]}));return Te(Mn,{children:[d,zA(To,{color:"#FFD700",children:g?Te(Zm,{children:[zA(kQ,{children:h.map((w,D)=>zA(Qe,{center:[w.x,w.y,B],size:[w.pl+.01,w.pw+.01,C]},D))}),f]}):m})]})},zwe=({numPins:e=5,rows:A=1,p:t=2.54,id:i=1,od:n=1.5,boardThickness:o=1.6,width:s,height:r,pinRowSide:a="left",holes:g=[],holeInset:c=1,pinRowHoleEdgeToEdgeDist:I=2,nopin:l})=>{const B=o/2,C=Math.ceil(e/A);let Q,E;a==="left"||a==="right"?(Q=(A-1)*t+2*I,E=(C-1)*t+2*I):(E=(A-1)*t+2*I,Q=(C-1)*t+2*I),e===0&&(Q=10,E=10);const h=Number(s??Q),u=Number(r??E),d=[];let f=0,m=0,w=0,D=0,b=0,k=0;a==="left"||a==="right"?(f=a==="left"?-h/2+I:h/2-I,m=-((C-1)/2)*t,w=0,D=t,b=a==="left"?t:-t,k=0):(f=-((C-1)/2)*t,m=a==="top"?u/2-I:-u/2+I,w=t,D=0,b=0,k=a==="top"?-t:t);let x=0;for(let aA=0;aA<A&&x<e;aA++)for(let tA=0;tA<C&&x<e;tA++){const oA=f+tA*w+aA*b,rA=m+tA*D+aA*k;d.push({x:oA,y:rA}),x++}const N=[];if(g)for(const aA of g){let tA=0,oA=0;aA==="topleft"?(tA=-h/2+c,oA=u/2-c):aA==="topright"?(tA=h/2-c,oA=u/2-c):aA==="bottomleft"?(tA=-h/2+c,oA=-u/2+c):aA==="bottomright"?(tA=h/2-c,oA=-u/2+c):aA==="center"&&(tA=0,oA=0),N.push({x:tA,y:oA})}const R=.63,U=2,T=6,Y=3,O=l?0:U,W=zA(To,{color:"#008080",children:Te(Zm,{children:[zA(Qe,{center:[0,0,B+O],size:[h,u,o]}),N.map((aA,tA)=>zA(kl,{center:[aA.x,aA.y,B+O],radius:n/2,height:o},`hole-${tA}`)),d.map((aA,tA)=>zA(kl,{center:[aA.x,aA.y,B+O],radius:n/2,height:o},`pin-hole-${tA}`))]})}),X=d.map((aA,tA)=>zA(To,{color:"#FFD700",children:Te(Zm,{children:[zA(kl,{center:[aA.x,aA.y,o/2+O],radius:n/2,height:o}),zA(kl,{center:[aA.x,aA.y,o/2+O],radius:i/2,height:o})]})})),iA=d.map((aA,tA)=>zA(lXA,{x:aA.x,y:aA.y,pinThickness:R,shortSidePinLength:Y,longSidePinLength:T,bodyHeight:U,flipZ:oA=>oA}));return Te(Mn,{children:[W,X,!l&&iA]})},Xwe=({footprint:e})=>{const A=Rme.string(e).json();switch(A.fn){case"dip":return zA(Hme,{numPins:A.num_pins,pitch:A.p,bodyWidth:A.w});case"axial":return zA(Vwe,{pitch:A.p});case"tssop":return zA(Jme,{pinCount:A.num_pins,leadLength:A.pl,leadWidth:A.pw,pitch:A.p,bodyWidth:A.w});case"msop":return zA(Tme,{pinCount:A.num_pins,padContactLength:A.pl,leadWidth:A.pw,pitch:A.p,bodyWidth:A.w});case"vssop":return zA(Cwe,{pinCount:A.num_pins,leadLength:A.pl,leadWidth:A.pw,pitch:A.p,bodyWidth:A.w,bodyLength:A.h});case"qfp":return zA(Ome,{pinCount:A.num_pins,pitch:A.p,leadWidth:A.pw,padContactLength:A.pl,bodyWidth:A.w});case"tqfp":return zA(xwe,{});case"lqfp":return zA(kwe,{pinCount:A.num_pins});case"qfn":{const n=typeof A.thermalpad?.x=="number"&&typeof A.thermalpad?.y=="number";return zA(Awe,{num_pins:A.num_pins,bodyWidth:A.w,bodyLength:A.h,pitch:A.p,padLength:A.pl,padWidth:A.pw,thermalPadSize:n?{width:A.thermalpad.x,length:A.thermalpad.y}:void 0})}case"dfn":{const n=typeof A.thermalpad?.x=="number"&&typeof A.thermalpad?.y=="number";return zA(Gwe,{num_pins:A.num_pins,bodyWidth:A.w,bodyLength:A.h,pitch:A.p,padLength:A.pl,padWidth:A.pw,thermalPadSize:n?{width:A.thermalpad.x,length:A.thermalpad.y}:void 0})}case"pinrow":{const n=e.match(/_rows(\d+)/),o=n&&n[1]?parseInt(n[1],10):1;if(A.male)return zA(jme,{numberOfPins:A.num_pins,pitch:A.p,invert:A.invert,faceup:A.faceup,rows:o,smd:A.smd||A.surface_mount,rightangle:A.rightangle});if(A.female)return zA(Iwe,{numberOfPins:A.num_pins,pitch:A.p,rows:o})}case"cap":switch(A.imperial){case"0402":return zA(gXA,{color:"#856c4d"});case"0603":return zA(cXA,{color:"#856c4d"});case"0805":return zA(IXA,{color:"#856c4d"});case"0201":return zA(BXA,{color:"#856c4d"});case"01005":return zA(CXA,{color:"#856c4d"});case"1206":return zA(QXA,{color:"#856c4d"});case"1210":return zA(EXA,{color:"#856c4d"});case"2010":return zA(hXA,{color:"#856c4d"});case"2512":return zA(uXA,{color:"#856c4d"})}case"sot235":return zA(ewe,{});case"sot457":return zA(Ywe,{});case"sot223":return zA(Swe,{});case"sot23w":return zA(iwe,{});case"sot323":return zA(_we,{});case"sod323f":return zA(Wwe,{});case"sod323fl":return zA(Zwe,{});case"sot363":return zA(Pwe,{});case"sot886":return zA(qwe,{});case"sot963":return zA(Jwe,{});case"pushbutton":return zA(lwe,{width:A.w,length:A.h,innerDiameter:A.id});case"soic":return zA(Bwe,{pinCount:A.num_pins,leadLength:A.pl,leadWidth:A.pw,pitch:A.p,bodyWidth:A.w});case"sod523":return zA(Qwe,{});case"sod882":return zA(Ewe,{});case"sma":return zA(hwe,{});case"smb":return zA(uwe,{});case"smc":return zA(dwe,{});case"smf":return zA(pwe,{});case"sod123f":return zA(fwe,{});case"sod123fl":return zA(ywe,{});case"sod123w":return zA(mwe,{});case"sod128":return zA(wwe,{});case"sod323":return zA(Owe,{});case"sod923":return zA(Dwe,{});case"hc49":return zA(Mwe,{});case"micromelf":return zA(Rwe,{});case"minimelf":return zA(Nwe,{});case"melf":return zA(vwe,{});case"ms012":return zA(Lwe,{pinCount:A.num_pins,padContactLength:A.pl,leadWidth:A.pw,pitch:A.p});case"ms013":return zA(Uwe,{pinCount:A.num_pins,padContactLength:A.pl,leadWidth:A.pw,pitch:A.p});case"sot723":return zA(Fwe,{});case"to220":return zA(Hwe,{});case"to92":return zA(Twe,{});case"stampboard":case"stampreceiver":return zA(jwe,{bodyWidth:A.w,leadsLeft:A.left,leadsRight:A.right,leadsTop:A.top,leadsBottom:A.bottom,leadsPitch:A.p,leadWidth:A.pw,leadLength:A.pl,innerHoles:A.innerhole,innerHoleEdgeDistance:A.innerholeedgedistance});case"mountedpcbmodule":{const n=A.rows??1,o=A.pinRowSide??"left",s=A.holeInset,r=A.width,a=A.height,g=A.pinrow,c=A.pinRowHoleEdgeToEdgeDist,I=Array.isArray(A.holes)?A.holes:[];return zA(zwe,{numPins:g,rows:n,p:A.p,id:A.id,od:A.od,width:r,height:a,pinRowSide:o,holes:I,holeInset:s,pinRowHoleEdgeToEdgeDist:c,nopin:A.nopin})}}const t=e.match(/_color\(([^)]+)\)/),i=t?t[1]:void 0;switch(A.imperial){case"0402":return zA(gXA,{color:i});case"0603":return zA(cXA,{color:i});case"0805":return zA(IXA,{color:i});case"0201":return zA(BXA,{color:i});case"01005":return zA(CXA,{color:i});case"1206":return zA(QXA,{color:i});case"1210":return zA(EXA,{color:i});case"2010":return zA(hXA,{color:i});case"2512":return zA(uXA,{color:i})}return null},$we=e=>e&&typeof e=="object"&&"type"in e,rv=e=>{if(typeof e=="number")return e;if(typeof e=="string"){const A=/^(-?\d+(?:\.\d+)?)\s*deg$/i.exec(e);if(A)return parseFloat(A[1])*Math.PI/180;const t=Number(e);if(!Number.isNaN(t))return t}return 0},ADe=e=>Array.isArray(e)?[Number(e[0])||0,Number(e[1])||0,Number(e[2])||0]:typeof e=="object"&&e?[Number(e.x)||0,Number(e.y)||0,Number(e.z)||0]:[0,0,0];function aD(e,A,t){const{jscad:{primitives:i,booleans:n,hulls:o,geometries:s,extrusions:r,transforms:a}}=t;if(e==null||e===!1)return[];if(Array.isArray(e))return e.flatMap(l=>aD(l,A,t));if(!$we(e))return[];const{type:g,props:c,children:I}=e;if(g===sXA)return(I??[]).flatMap(l=>aD(l,A,t));if(g===To){const l=c?.color;return(I??[]).flatMap(B=>aD(B,l??A,t))}if(g===Pi){const l=ADe(c?.offset??c?.center??{x:c?.x,y:c?.y,z:c?.z});return(I??[]).flatMap(C=>aD(C,A,t)).map(({geom:C,color:Q})=>({geom:a.translate(l,C),color:Q??A}))}if(g===ZB){const l=Array.isArray(c?.rotation)?[rv(c.rotation[0]),rv(c.rotation[1]),rv(c.rotation[2])]:[rv(c?.x??0),rv(c?.y??0),rv(c?.z??0)];return(I??[]).flatMap(C=>aD(C,A,t)).map(({geom:C,color:Q})=>({geom:a.rotateZ(l[2],a.rotateY(l[1],a.rotateX(l[0],C))),color:Q}))}if(g===kQ||g===Zm||g===Cc){const l=(I??[]).flatMap(C=>aD(C,A,t)).map(C=>C.geom);if(l.length===0)return[];let B;return g===kQ?B=n.union(l):g===Zm?B=n.subtract(l[0],l.slice(1)):B=o.hull(l),[{geom:B,color:A}]}if(g===gH){const l=c?.points??[];return[{geom:s.geom2.fromPoints(l),color:A??c?.color}]}if(g===cH){const l=(I??[]).flatMap(E=>aD(E,A,t)).map(E=>E.geom);if(l.length===0)return[];const B=l.length>1?n.union(l):l[0],C=c?.height??c?.h??1;let Q=r.extrudeLinear({height:C},B);if(Q.polygons)for(const E of Q.polygons)!E.plane||!E.vertices||E.vertices.length<3||E.vertices.reverse();return[{geom:Q,color:A??c?.color}]}if(g===Qe||g===rXA||g===kl||g===IW||g===aH||g===sf){let l;if(g===Qe){const B=c?.size??[1,1,1],C=c?.offset,Q=c?.center??(C?[C[0],C[1],C[2]]:[0,0,0]);l=i.cuboid({size:B,center:Q})}else if(g===rXA){const B=c?.size??1,C=c?.offset,Q=c?.center??(C?[C[0],C[1],C[2]]:[0,0,0]);l=i.cube({size:B,center:Q})}else if(g===kl){const B=c?.height??1,C=c?.radius??1,Q=c?.center??[0,0,0];l=i.cylinder({height:B,radius:C,center:Q})}else if(g===IW){const B=c?.radius??1,C=c?.center??[0,0,0];l=i.sphere({radius:B,center:C})}else if(g===sf){const B=c?.height??1,C=c?.radius??1,Q=c?.roundRadius??.1,E=c?.center??[0,0,0];l=i.roundedCylinder({height:B,radius:C,roundRadius:Q,center:E})}else{const B=c?.size??[1,1,1],C=c?.roundRadius??.1,Q=c?.center??[0,0,0];l=i.roundedCuboid({size:B,roundRadius:C,center:Q})}return[{geom:l,color:A??c?.color}]}if(typeof g=="function"){const l=g(c??{});return aD(l,A,t)}return(I??[]).flatMap(l=>aD(l,A,t))}function tDe(e,A){return{geometries:aD(e,void 0,{jscad:A})}}function dXA(e){if(e.polygons){const A=[],t=[],i=[];let n=0;for(const s of e.polygons){for(const a of s.vertices)a.index=n,A.push(a[0],a[1],a[2]),e.color&&e.color.length>=3?i.push(e.color[0],e.color[1],e.color[2]):i.push(1,1,1),n++;const r=s.vertices[0].index;for(let a=2;a<s.vertices.length;a++){const g=s.vertices[a-1].index,c=s.vertices[a].index;t.push(r,g,c)}}const o=new fg;if(o.setAttribute("position",new lc(new Float32Array(A),3)),o.setIndex(t),i.length>0&&o.setAttribute("color",new lc(new Float32Array(i),3)),e.transforms){const s=new ss;s.fromArray(e.transforms),o.applyMatrix4(s)}return o.computeVertexNormals(),o}if(e.sides){const A=[],t=[];for(const n of e.sides)A.push(n[0][0],n[0][1],0),e.color&&e.color.length>=3?t.push(e.color[0],e.color[1],e.color[2]):t.push(1,1,1);const i=new fg;if(i.setAttribute("position",new lc(new Float32Array(A),3)),t.length>0&&i.setAttribute("color",new lc(new Float32Array(t),3)),e.transforms){const n=new ss;n.fromArray(e.transforms),i.applyMatrix4(n)}return i}return console.error("Invalid CSG object: neither polygons nor sides found"),new fg}function eDe(e,A){const t=gEA(Xwe,{footprint:e});return tDe(t,A)}var iDe=Kr(iW()),pXA=AA.createContext(null),nDe=()=>{const e=AA.useContext(pXA);if(!e)throw new Error("useHover must be used within a HoverProvider");return e},oDe=({children:e})=>{const{camera:A,renderer:t}=Lu(),[i,n]=AA.useState([]),o=AA.useMemo(()=>new MMt,[]),s=AA.useMemo(()=>new En,[]),r=AA.useRef(i);r.current=i;const a=AA.useRef(null),g=AA.useCallback(C=>{n(Q=>[...Q,C])},[]),c=AA.useCallback(C=>{if(a.current){let Q=!1,E=a.current.object;for(;E;){if(E===C){Q=!0;break}E=E.parent}Q&&(a.current.onUnhover(),a.current=null)}n(Q=>Q.filter(E=>E.object!==C))},[]),I=AA.useCallback(C=>{let Q=C;for(;Q;){const E=r.current.find(h=>h.object===Q);if(E)return E;Q=Q.parent}},[]),l=AA.useCallback(C=>{if(!t.domElement)return;const Q=t.domElement.getBoundingClientRect();s.x=(C.clientX-Q.left)/Q.width*2-1,s.y=-((C.clientY-Q.top)/Q.height)*2+1,o.setFromCamera(s,A);const E=r.current.map(u=>u.object);if(E.length===0){a.current&&(a.current.onUnhover(),a.current=null);return}const h=o.intersectObjects(E,!0);if(h.length>0){const u=h[0],d=I(u.object);if(d){const f={mousePosition:[u.point.x,u.point.y,u.point.z]};a.current!==d?(a.current?.onUnhover(),d.onHover(f),a.current=d):d.onHover(f)}else a.current&&(a.current.onUnhover(),a.current=null)}else a.current&&(a.current.onUnhover(),a.current=null)},[A,t,o,s,I]);AA.useEffect(()=>{const C=t.domElement;return C.addEventListener("mousemove",l),()=>{C.removeEventListener("mousemove",l)}},[t,l]);const B=AA.useMemo(()=>({addHoverable:g,removeHoverable:c}),[g,c]);return Z.jsx(pXA.Provider,{value:B,children:e})},sDe=({children:e,object:A,onHover:t,onUnhover:i,isHovered:n})=>{const{addHoverable:o,removeHoverable:s}=nDe();return AA.useEffect(()=>A?(o({object:A,onHover:t,onUnhover:i}),()=>{s(A)}):void 0,[A,t,i,o,s]),Z.jsx(Z.Fragment,{children:e})},dH=sDe,rDe=({positionOffset:e,footprint:A,rotationOffset:t,onHover:i,onUnhover:n,isHovered:o,scale:s,isTranslucent:r=!1})=>{const{rootObject:a}=Lu(),g=AA.useMemo(()=>{if(!A)return null;const{geometries:c}=eDe(A,iDe),I=new Vp;for(const l of c.flat(1/0)){const B=l.geom;if(!B||!B.polygons&&!B.sides)continue;const C=new Oi(l.color);C.convertLinearToSRGB();const Q={...B,color:[C.r,C.g,C.b]},E=dXA(Q),h=new dh({vertexColors:!0,side:WB,transparent:r,opacity:r?.5:1,depthWrite:!r}),u=new Ao(E,h);I.add(u)}return I},[A,r]);return AA.useEffect(()=>{if(!(!g||!a))return a.add(g),()=>{a.remove(g)}},[a,g]),AA.useEffect(()=>{g&&(e&&g.position.fromArray(e),t&&g.rotation.fromArray(t),s!==void 0&&g.scale.setScalar(s))},[g,e?.[0],e?.[1],e?.[2],t?.[0],t?.[1],t?.[2],s]),AA.useEffect(()=>{g&&g.traverse(c=>{c instanceof Ao&&c.material instanceof dh&&(o?(c.material.emissive.setHex(255),c.material.emissiveIntensity=.2):c.material.emissiveIntensity=0)})},[o,g]),g?Z.jsx(dH,{isHovered:o,onHover:i,onUnhover:n,object:g}):null},fXA=new WeakMap,aDe=()=>{const e=new Hc;return e.name="fallback-environment-map",e.mapping=KK,e},gDe=e=>{if(!e)return null;const A=e,t=fXA.get(A);if(t)return t;let i;if(e instanceof fP){const n=new i7(e);i=n.fromScene(UNt(),.04).texture,n.dispose()}else i=aDe();return fXA.set(A,i),i},yXA=1.25;function mXA({gltfUrl:e,position:A,rotation:t,onHover:i,onUnhover:n,isHovered:o,scale:s,isTranslucent:r=!1}){const{renderer:a,rootObject:g}=Lu(),[c,I]=AA.useState(null),[l,B]=AA.useState(null);if(AA.useEffect(()=>{if(!e)return;const C=new YNt;let Q=!0;return C.load(e,E=>{if(!Q)return;const h=E.scene;h.traverse(u=>{if(u instanceof Ao&&u.material){const d=f=>{f.transparent=r,f.opacity=r?.5:1,f.depthWrite=!r,f.needsUpdate=!0};Array.isArray(u.material)?u.material.forEach(d):d(u.material)}}),I(h)},void 0,E=>{if(!Q)return;console.error(`An error happened loading ${e}`,E);const h=E instanceof Error?E:new Error(`Failed to load glTF model from ${e}`);B(h)}),()=>{Q=!1}},[e,r]),AA.useEffect(()=>{c&&(A&&c.position.fromArray(A),t&&c.rotation.fromArray(t),s!==void 0&&c.scale.setScalar(s))},[c,A?.[0],A?.[1],A?.[2],t?.[0],t?.[1],t?.[2],s]),AA.useEffect(()=>{if(!(!g||!c))return g.add(c),()=>{g.remove(c)}},[g,c]),AA.useEffect(()=>{if(!c||!a)return;const C=gDe(a);if(!C)return;const Q=[],E=h=>{h instanceof dh&&(Q.push({material:h,envMap:h.envMap??null,envMapIntensity:h.envMapIntensity??1}),h.envMap=C,(typeof h.envMapIntensity!="number"||h.envMapIntensity<yXA)&&(h.envMapIntensity=yXA),h.needsUpdate=!0)};return c.traverse(h=>{if(!(h instanceof Ao))return;const u=h.material;Array.isArray(u)?u.forEach(E):u&&E(u)}),()=>{Q.forEach(({material:h,envMap:u,envMapIntensity:d})=>{h.envMap=u,h.envMapIntensity=d,h.needsUpdate=!0})}},[c,a]),AA.useEffect(()=>{c&&c.traverse(C=>{C instanceof Ao&&C.material instanceof dh&&(o?(C.material.emissive.setHex(255),C.material.emissiveIntensity=.2):C.material.emissiveIntensity=0)})},[o,c]),l)throw l;return c?Z.jsx(dH,{isHovered:o,onHover:i,onUnhover:n,object:c}):null}var cDe=Kr(xzA()),IDe=Kr(iW()),lDe=({jscadPlan:e,positionOffset:A,rotationOffset:t,onHover:i,onUnhover:n,isHovered:o,scale:s,isTranslucent:r=!1})=>{const{rootObject:a}=Lu(),{threeGeom:g,material:c}=AA.useMemo(()=>{const l=(0,cDe.executeJscadOperations)(IDe.default,e);if(!l||!l.polygons&&!l.sides)return{threeGeom:null,material:null};const B=dXA(l),C=new dh({vertexColors:!0,side:WB,transparent:r,opacity:r?.5:1,depthWrite:!r});return{threeGeom:B,material:C}},[e,r]),I=AA.useMemo(()=>g?new Ao(g,c):null,[g,c]);return AA.useEffect(()=>{if(!(!I||!a))return a.add(I),()=>{a.remove(I)}},[a,I]),AA.useEffect(()=>{I&&(A&&I.position.fromArray(A),t&&I.rotation.fromArray(t),s!==void 0&&I.scale.setScalar(s))},[I,A?.[0],A?.[1],A?.[2],t?.[0],t?.[1],t?.[2],s]),AA.useMemo(()=>{if(c)if(o){const l=new Oi(c.color.getHex());c.emissive.copy(l),c.emissive.setRGB(0,0,1),c.emissiveIntensity=.2}else c.emissiveIntensity=0},[o,c]),g?Z.jsx(dH,{isHovered:o,onHover:i,onUnhover:n,object:I}):null};function BDe(e){return e.replace(/(DEF|USE)\s+([^\s]+)/g,(A,t,i)=>`${t} ${i.replace(/-/g,"_")}`)}async function CDe(e){const A=await fetch(e);if(!A.ok)throw new Error(`Failed to fetch "${e}": ${A.status} ${A.statusText}`);const t=await A.text();return new Dvt().parse(BDe(t),e)}typeof window<"u"&&!window.TSCIRCUIT_OBJ_LOADER_CACHE&&(window.TSCIRCUIT_OBJ_LOADER_CACHE=new Map);function QDe(e){const[A,t]=AA.useState(null);return AA.useEffect(()=>{if(!e)return;const i=e.replace(/&cachebust_origin=$/,""),n=window.TSCIRCUIT_OBJ_LOADER_CACHE;let o=!1;async function s(){try{if(i.endsWith(".wrl"))return await CDe(i);const a=await fetch(i);if(!a.ok)throw new Error(`Failed to fetch "${i}": ${a.status} ${a.statusText}`);const g=await a.text(),c=g.match(/newmtl[\s\S]*?endmtl/g),I=new Rvt;if(c?.length){const l=c.join(`
|
|
5136
|
-
`).replace(/d 0\./g,"d 1."),B=g.replace(/newmtl[\s\S]*?endmtl/g,"").replace(/^mtllib.*/gm,""),C=new yvt;C.setMaterialOptions({invertTrProperty:!0});const Q=C.parse(l.replace(/Kd\s+([\d.]+)\s+([\d.]+)\s+([\d.]+)/g,"Kd $2 $2 $2"),"embedded.mtl");return I.setMaterials(Q),I.parse(B)}return I.parse(g.replace(/^mtllib.*/gm,""))}catch(a){return a}}function r(){if(n.has(i)){const g=n.get(i);return g.result?Promise.resolve(g.result.clone()):g.promise.then(c=>c instanceof Error?c:c.clone())}const a=s().then(g=>(g instanceof Error||n.set(i,{...n.get(i),result:g}),g));return n.set(i,{promise:a,result:null}),a}return r().then(a=>{o||t(a)}).catch(a=>{console.error(a)}),()=>{o=!0}},[e]),A}function EDe({url:e,position:A,rotation:t,onHover:i,onUnhover:n,isHovered:o,scale:s,isTranslucent:r=!1}){const a=QDe(e),{rootObject:g}=Lu(),c=AA.useMemo(()=>a&&!(a instanceof Error)?(a.traverse(I=>{if(I instanceof Ao&&I.material){const l=B=>{B.transparent=r,B.opacity=r?.5:1,B.depthWrite=!r,B.needsUpdate=!0};Array.isArray(I.material)?I.material.forEach(l):l(I.material)}}),a):new Ao(new _m(.5,.5,.5),new dh({transparent:!0,color:"red",opacity:.25})),[a,r]);if(AA.useEffect(()=>{if(!(!g||!c))return g.add(c),()=>{g.remove(c)}},[g,c]),AA.useEffect(()=>{c&&(A&&(Array.isArray(A)?c.position.fromArray(A):c.position.copy(A)),t&&(Array.isArray(t)?c.rotation.fromArray(t):c.rotation.copy(t)),s!==void 0&&c.scale.setScalar(s))},[c,Array.isArray(A)?A[0]:A?.x,Array.isArray(A)?A[1]:A?.y,Array.isArray(A)?A[2]:A?.z,Array.isArray(t)?t[0]:t?.x,Array.isArray(t)?t[1]:t?.y,Array.isArray(t)?t[2]:t?.z,s]),a instanceof Error)throw a;return Z.jsx(dH,{isHovered:o,onHover:i,onUnhover:n,object:c})}var _EA,hDe="https://cdn.jsdelivr.net/npm/occt-import-js@0.0.23/dist";function uDe(e){if(typeof e=="function")return e;if(e&&typeof e=="object"&&"default"in e&&typeof e.default=="function")return e.default;throw new Error("Unable to resolve occt-import-js factory export")}async function dDe(){if(!_EA){const e=await import("https://cdn.jsdelivr.net/npm/occt-import-js@0.0.23/+esm");_EA=uDe(e)({locateFile:t=>`${hDe}/${t}`})}return _EA}function pDe(e){const A=new Vp;for(const t of e){const i=t.attributes.position?.array??[],n=t.index?.array??[];if(!i.length||!n.length)continue;const o=new fg;o.setAttribute("position",new Jo(i,3));const s=t.attributes.normal?.array??[];s.length?o.setAttribute("normal",new Jo(s,3)):o.computeVertexNormals(),o.setIndex(n);const r=new dh({color:t.color?new Oi(t.color[0],t.color[1],t.color[2]):new Oi(.82,.82,.82)}),a=new Ao(o,r);a.name=t.name,A.add(a)}return A}async function fDe(e){const A=await fetch(e);if(!A.ok)throw new Error(`Failed to fetch STEP file: ${A.statusText}`);const t=await A.arrayBuffer(),n=(await dDe()).ReadStepFile(new Uint8Array(t),null);if(!n.success||!n.meshes.length)throw new Error("occt-import-js failed to convert STEP file");const o=pDe(n.meshes),s=new b$;return await new Promise((a,g)=>{s.parse(o,c=>{c instanceof ArrayBuffer?a(c):g(new Error("GLTFExporter did not return binary output"))},c=>{g(c)},{binary:!0})})}var wXA="step-glb-cache:";function yDe(e){const A=new Uint8Array(e),t=32768;let i="";for(let n=0;n<A.length;n+=t){const o=A.subarray(n,n+t);i+=String.fromCharCode(...o)}return btoa(i)}function mDe(e){const A=atob(e),t=new Uint8Array(A.length);for(let i=0;i<A.length;i+=1)t[i]=A.charCodeAt(i);return t.buffer}function wDe(e){try{const A=localStorage.getItem(`${wXA}${e}`);return A?mDe(A):null}catch(A){return console.warn("Failed to read STEP GLB cache",A),null}}function DXA(e,A){try{const t=yDe(A);localStorage.setItem(`${wXA}${e}`,t)}catch(t){console.warn("Failed to write STEP GLB cache",t)}}function DDe(){const e=globalThis;return e.stepUrlToGltfModelConversions||(e.stepUrlToGltfModelConversions={inProgress:new Map,completed:new Map}),e.stepUrlToGltfModelConversions}var SDe=({stepUrl:e,position:A,rotation:t,scale:i,onHover:n,onUnhover:o,isHovered:s,isTranslucent:r})=>{const[a,g]=AA.useState(null);return AA.useEffect(()=>{let c=!0,I=null,l=!0;const B=DDe(),C=wDe(e);if(C){const h={arrayBuffer:C,blobUrl:URL.createObjectURL(new Blob([C],{type:"model/gltf-binary"}))};return B.completed.set(e,h),I=h.blobUrl,l=!1,g(h.blobUrl),()=>{c=!1,I&&l&&URL.revokeObjectURL(I)}}const Q=B.completed.get(e);if(Q)return I=Q.blobUrl,l=!1,g(Q.blobUrl),DXA(e,Q.arrayBuffer),()=>{c=!1,I&&l&&URL.revokeObjectURL(I)};let E=B.inProgress.get(e);return E||(E=fDe(e).then(h=>{const u={arrayBuffer:h,blobUrl:URL.createObjectURL(new Blob([h],{type:"model/gltf-binary"}))};return B.completed.set(e,u),B.inProgress.delete(e),u}).catch(h=>{throw B.inProgress.delete(e),h}),B.inProgress.set(e,E)),E.then(h=>{c&&(I=h.blobUrl,l=!1,g(h.blobUrl),DXA(e,h.arrayBuffer))}).catch(h=>{console.error("Failed to convert STEP file to GLB",h),c&&g(null)}),()=>{c=!1,I&&l&&URL.revokeObjectURL(I)}},[e]),a?Z.jsx(mXA,{gltfUrl:a,position:A,rotation:t,scale:i,onHover:n,onUnhover:o,isHovered:s,isTranslucent:r}):null},bDe=(e,A)=>{if(e)return A?A(e):e},SXA=(...e)=>e,bXA=({cad_component:e,circuitJson:A,resolveStaticAsset:t})=>{const i=FzA(A),[n,o]=AA.useState(!1),{visibility:s}=jF(),[r,a]=AA.useState(null),g=AA.useCallback(w=>{w?.mousePosition?(o(!0),a(w.mousePosition)):(o(!1),a(null))},[]),c=AA.useCallback(()=>{o(!1),a(null)},[]),I=AA.useMemo(()=>Ji(A).source_component.getUsing({source_component_id:e.source_component_id})?.name,[A,e.source_component_id]),l=AA.useMemo(()=>A.filter(D=>D.type==="pcb_plated_hole"&&D.pcb_component_id===e.pcb_component_id).length>0,[A,e.pcb_component_id]),B=AA.useCallback(w=>bDe(w,t),[t]),C=B(e.model_obj_url??e.model_wrl_url??e.model_stl_url),Q=B(e.model_glb_url??e.model_gltf_url),E=B(e.model_step_url),u=A.find(w=>w.type==="pcb_component"&&w.source_component_id===e.source_component_id)?.layer??"top",d=AA.useMemo(()=>e.rotation?SXA(e.rotation.x*Math.PI/180,e.rotation.y*Math.PI/180,e.rotation.z*Math.PI/180):SXA(0,0,0),[e.rotation,u]),f=AA.useMemo(()=>{if(!e.position)return;let w;return u==="top"?w=e.position.z:u==="bottom"?w=-(e.position.z+i):w=e.position.z,[e.position.x,e.position.y,w]},[e.position,u,i]);let m=null;if(C?m=Z.jsx(EDe,{url:C,position:f,rotation:d,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model},e.cad_component_id):Q?m=Z.jsx(mXA,{gltfUrl:Q,position:f,rotation:d,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model},e.cad_component_id):E&&!e.model_jscad&&!e.footprinter_string?m=Z.jsx(SDe,{stepUrl:E,position:f,rotation:d,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model}):e.model_jscad?m=Z.jsx(lDe,{jscadPlan:e.model_jscad,positionOffset:f,rotationOffset:d,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model},e.cad_component_id):e.footprinter_string&&(m=Z.jsx(rDe,{positionOffset:f,rotationOffset:d,footprint:e.footprinter_string,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model})),e.show_as_translucent_model){if(!s.translucentModels)return null}else if(l&&!s.throughHoleModels||!l&&!s.smtModels)return null;return Z.jsxs(Z.Fragment,{children:[m,n&&r?Z.jsx(MzA,{position:r,style:{fontFamily:"sans-serif",transform:"translate3d(1rem, 1rem, 0)",backgroundColor:"white",padding:"5px",borderRadius:"3px",pointerEvents:"none",userSelect:"none",WebkitUserSelect:"none",MozUserSelect:"none",msUserSelect:"none"},children:I??"<unknown>"}):null]})},xXA={version:"0.0.518"};function xDe(e){e.querySelectorAll("canvas").forEach(A=>A.remove())}var _De=e=>{e.outputColorSpace=pm,e.toneMapping=v_A,e.toneMappingExposure=1},_XA="cadViewerCameraStateSession",kXA=(e,A)=>{try{const t={position:e.position.toArray(),quaternion:e.quaternion.toArray(),up:e.up.toArray(),fov:e.fov??50,target:A.target.toArray()};sessionStorage.setItem(_XA,JSON.stringify(t))}catch(t){console.warn("Failed to save camera:",t)}},kEA=(e,A)=>{try{const t=sessionStorage.getItem(_XA);if(!t)return!1;const i=JSON.parse(t);if(e.position.fromArray(i.position),e.quaternion.fromArray(i.quaternion),e.up.fromArray(i.up),"fov"in e){const n=e;n.fov=i.fov,n.updateProjectionMatrix?.()}return A.target.fromArray(i.target),A.update(),e.updateMatrixWorld(),!0}catch(t){return console.warn("Failed to restore camera:",t),!1}},FXA=AA.createContext(void 0),kDe=({children:e,defaultTarget:A,initialCameraPosition:t})=>{const i=AA.useRef(null),n=AA.useRef(null),[o,s]=AA.useState(null),[r,a]=AA.useState("perspective"),[g,c]=AA.useState(t??null),[I,l]=AA.useState(new Wp(0,0,0)),B=AA.useMemo(()=>{const[h,u,d]=t??[5,-5,5],f=Math.hypot(h-A.x,u-A.y,d-A.z);return f>0?f:5},[t,A]),C=AA.useCallback(h=>{const u=[A.x,A.y,A.z],d=n.current,f=i.current;let m=B;switch(d&&f&&(m=d.position.distanceTo(f.target)),h){case"Top Center Angled":{const w=m/Math.sqrt(2);return{position:[A.x,A.y-w,A.z+w],target:u,up:[0,0,1]}}case"Top Down":return{position:[A.x,A.y,A.z+m],target:u,up:[0,0,1]};case"Top Left Corner":return{position:[A.x-m*.6,A.y-m*.6,A.z+m*.6],target:u,up:[0,0,1]};case"Top Right Corner":return{position:[A.x+m*.6,A.y-m*.6,A.z+m*.6],target:u,up:[0,0,1]};case"Left Sideview":return{position:[A.x-m,A.y,A.z],target:u,up:[0,0,1]};case"Right Sideview":return{position:[A.x+m,A.y,A.z],target:u,up:[0,0,1]};case"Front":return{position:[A.x,A.y-m,A.z],target:u,up:[0,0,1]};default:return null}},[B,A,n,i]),Q=AA.useCallback(h=>{i.current=h},[]),E=AA.useMemo(()=>({controlsRef:i,mainCameraRef:n,defaultTarget:A,baseDistance:B,controller:o,setController:s,getPresetConfig:C,handleControlsChange:Q,cameraType:r,setCameraType:a,cameraPosition:g,setCameraPosition:c,cameraRotation:I,setCameraRotation:l,saveCameraToSession:kXA,loadCameraFromSession:kEA}),[A,B,o,C,Q,r,g,I]);return Z.jsx(FXA.Provider,{value:E,children:e})},y_=()=>{const e=AA.useContext(FXA);if(!e)throw new Error("useCameraController must be used within a CameraControllerProvider");return e},FDe=AA.forwardRef(({children:e,scene:A,camera:t,style:i,onCreated:n},o)=>{const{cameraType:s}=y_(),r=AA.useRef(null),[a,g]=AA.useState(null),c=AA.useRef([]),I=AA.useRef(void 0);I.current=n;const l=AA.useRef(null),B=AA.useCallback(h=>{c.current.push(h)},[]),C=AA.useCallback(h=>{c.current=c.current.filter(u=>u!==h)},[]),Q=AA.useMemo(()=>new oF,[]);A?.up&&Q.up.set(A.up.x,A.up.y,A.up.z);const E=AA.useRef(new pg);return AA.useImperativeHandle(o,()=>E.current),AA.useEffect(()=>{if(!r.current)return;xDe(r.current);const h=new fP({antialias:!0,alpha:!0});_De(h),h.setSize(r.current.clientWidth,r.current.clientHeight),h.setPixelRatio(window.devicePixelRatio),r.current.appendChild(h.domElement);const u=r.current.clientWidth/r.current.clientHeight,d=s==="perspective"?new uE(75,u,.1,1e3):new $2(-10*u,10*u,10,-10,-1e3,1e3);l.current?(d.position.copy(l.current.position),d.quaternion.copy(l.current.quaternion),d.up.copy(l.current.up)):(t?.up&&d.up.set(t.up[0],t.up[1],t.up[2]),t?.position&&d.position.set(t.position[0],t.position[1],t.position[2]),d.lookAt(0,0,0)),Q.add(E.current),window.__TSCIRCUIT_THREE_OBJECT=E.current,g({scene:Q,camera:d,renderer:h,rootObject:E.current,addFrameListener:B,removeFrameListener:C}),I.current?.({camera:d,renderer:h});let f;const m=new mMt,w=()=>{const b=m.getElapsedTime(),k=m.getDelta();c.current.forEach(x=>x(b,k)),h.render(Q,d),f=requestAnimationFrame(w)};w();const D=()=>{if(r.current){const b=r.current.clientWidth/r.current.clientHeight;d instanceof uE?d.aspect=b:d instanceof $2&&(d.left=-10*b,d.right=10*b,d.top=10,d.bottom=-10),d.updateProjectionMatrix(),h.setSize(r.current.clientWidth,r.current.clientHeight)}};return window.addEventListener("resize",D),()=>{l.current={position:d.position.clone(),quaternion:d.quaternion.clone(),up:d.up.clone()},window.removeEventListener("resize",D),cancelAnimationFrame(f),r.current&&h.domElement&&r.current.removeChild(h.domElement),h.dispose(),Q.remove(E.current),window.__TSCIRCUIT_THREE_OBJECT===E.current&&(window.__TSCIRCUIT_THREE_OBJECT=void 0)}},[Q,B,C,s]),Z.jsx("div",{ref:r,style:{width:"100%",height:"100%",...i},children:a&&Z.jsx(GzA.Provider,{value:a,children:Z.jsx(oDe,{children:e})})})}),GDe=({autoRotate:e,autoRotateSpeed:A,onStart:t,panSpeed:i,rotateSpeed:n,zoomSpeed:o,enableDamping:s,dampingFactor:r,target:a,onControlsChange:g})=>{const{camera:c,renderer:I}=Lu(),l=AA.useMemo(()=>!c||!I?null:new vvt(c,I.domElement),[c,I]);return AA.useEffect(()=>(g?.(l??null),()=>g?.(null)),[l,g]),AA.useEffect(()=>{if(!l)return;const B=()=>{g?.(l)};return l.addEventListener("change",B),()=>{l.removeEventListener("change",B)}},[l,g]),AA.useEffect(()=>{l&&(l.autoRotate=e||!1,l.autoRotateSpeed=A||1,i!==void 0&&(l.panSpeed=i),n!==void 0&&(l.rotateSpeed=n),o!==void 0&&(l.zoomSpeed=o),s!==void 0&&(l.enableDamping=s),r!==void 0&&(l.dampingFactor=r),l.zoomToCursor=!0,l.mouseButtons={LEFT:hx.ROTATE,MIDDLE:hx.PAN,RIGHT:null},a&&(l.target.set(a[0],a[1],a[2]),l.update()))},[l,e,A,i,n,o,s,r,a]),AA.useEffect(()=>{if(!(!l||!t))return l.addEventListener("start",t),()=>{l.removeEventListener("start",t)}},[l,t]),AA.useEffect(()=>{if(l)return()=>{l.dispose()}},[l]),oH(()=>{l?.update()},[l]),null},MDe=`
|
|
5136
|
+
`).replace(/d 0\./g,"d 1."),B=g.replace(/newmtl[\s\S]*?endmtl/g,"").replace(/^mtllib.*/gm,""),C=new yvt;C.setMaterialOptions({invertTrProperty:!0});const Q=C.parse(l.replace(/Kd\s+([\d.]+)\s+([\d.]+)\s+([\d.]+)/g,"Kd $2 $2 $2"),"embedded.mtl");return I.setMaterials(Q),I.parse(B)}return I.parse(g.replace(/^mtllib.*/gm,""))}catch(a){return a}}function r(){if(n.has(i)){const g=n.get(i);return g.result?Promise.resolve(g.result.clone()):g.promise.then(c=>c instanceof Error?c:c.clone())}const a=s().then(g=>(g instanceof Error||n.set(i,{...n.get(i),result:g}),g));return n.set(i,{promise:a,result:null}),a}return r().then(a=>{o||t(a)}).catch(a=>{console.error(a)}),()=>{o=!0}},[e]),A}function EDe({url:e,position:A,rotation:t,onHover:i,onUnhover:n,isHovered:o,scale:s,isTranslucent:r=!1}){const a=QDe(e),{rootObject:g}=Lu(),c=AA.useMemo(()=>a&&!(a instanceof Error)?(a.traverse(I=>{if(I instanceof Ao&&I.material){const l=B=>{B.transparent=r,B.opacity=r?.5:1,B.depthWrite=!r,B.needsUpdate=!0};Array.isArray(I.material)?I.material.forEach(l):l(I.material)}}),a):new Ao(new _m(.5,.5,.5),new dh({transparent:!0,color:"red",opacity:.25})),[a,r]);if(AA.useEffect(()=>{if(!(!g||!c))return g.add(c),()=>{g.remove(c)}},[g,c]),AA.useEffect(()=>{c&&(A&&(Array.isArray(A)?c.position.fromArray(A):c.position.copy(A)),t&&(Array.isArray(t)?c.rotation.fromArray(t):c.rotation.copy(t)),s!==void 0&&c.scale.setScalar(s))},[c,Array.isArray(A)?A[0]:A?.x,Array.isArray(A)?A[1]:A?.y,Array.isArray(A)?A[2]:A?.z,Array.isArray(t)?t[0]:t?.x,Array.isArray(t)?t[1]:t?.y,Array.isArray(t)?t[2]:t?.z,s]),a instanceof Error)throw a;return Z.jsx(dH,{isHovered:o,onHover:i,onUnhover:n,object:c})}var _EA,hDe="https://cdn.jsdelivr.net/npm/occt-import-js@0.0.23/dist";function uDe(e){if(typeof e=="function")return e;if(e&&typeof e=="object"&&"default"in e&&typeof e.default=="function")return e.default;throw new Error("Unable to resolve occt-import-js factory export")}async function dDe(){if(!_EA){const e=await import("https://cdn.jsdelivr.net/npm/occt-import-js@0.0.23/+esm");_EA=uDe(e)({locateFile:t=>`${hDe}/${t}`})}return _EA}function pDe(e){const A=new Vp;for(const t of e){const i=t.attributes.position?.array??[],n=t.index?.array??[];if(!i.length||!n.length)continue;const o=new fg;o.setAttribute("position",new Jo(i,3));const s=t.attributes.normal?.array??[];s.length?o.setAttribute("normal",new Jo(s,3)):o.computeVertexNormals(),o.setIndex(n);const r=new dh({color:t.color?new Oi(t.color[0],t.color[1],t.color[2]):new Oi(.82,.82,.82)}),a=new Ao(o,r);a.name=t.name,A.add(a)}return A}async function fDe(e){const A=await fetch(e);if(!A.ok)throw new Error(`Failed to fetch STEP file: ${A.statusText}`);const t=await A.arrayBuffer(),n=(await dDe()).ReadStepFile(new Uint8Array(t),null);if(!n.success||!n.meshes.length)throw new Error("occt-import-js failed to convert STEP file");const o=pDe(n.meshes),s=new b$;return await new Promise((a,g)=>{s.parse(o,c=>{c instanceof ArrayBuffer?a(c):g(new Error("GLTFExporter did not return binary output"))},c=>{g(c)},{binary:!0})})}var wXA="step-glb-cache:";function yDe(e){const A=new Uint8Array(e),t=32768;let i="";for(let n=0;n<A.length;n+=t){const o=A.subarray(n,n+t);i+=String.fromCharCode(...o)}return btoa(i)}function mDe(e){const A=atob(e),t=new Uint8Array(A.length);for(let i=0;i<A.length;i+=1)t[i]=A.charCodeAt(i);return t.buffer}function wDe(e){try{const A=localStorage.getItem(`${wXA}${e}`);return A?mDe(A):null}catch(A){return console.warn("Failed to read STEP GLB cache",A),null}}function DXA(e,A){try{const t=yDe(A);localStorage.setItem(`${wXA}${e}`,t)}catch(t){console.warn("Failed to write STEP GLB cache",t)}}function DDe(){const e=globalThis;return e.stepUrlToGltfModelConversions||(e.stepUrlToGltfModelConversions={inProgress:new Map,completed:new Map}),e.stepUrlToGltfModelConversions}var SDe=({stepUrl:e,position:A,rotation:t,scale:i,onHover:n,onUnhover:o,isHovered:s,isTranslucent:r})=>{const[a,g]=AA.useState(null);return AA.useEffect(()=>{let c=!0,I=null,l=!0;const B=DDe(),C=wDe(e);if(C){const h={arrayBuffer:C,blobUrl:URL.createObjectURL(new Blob([C],{type:"model/gltf-binary"}))};return B.completed.set(e,h),I=h.blobUrl,l=!1,g(h.blobUrl),()=>{c=!1,I&&l&&URL.revokeObjectURL(I)}}const Q=B.completed.get(e);if(Q)return I=Q.blobUrl,l=!1,g(Q.blobUrl),DXA(e,Q.arrayBuffer),()=>{c=!1,I&&l&&URL.revokeObjectURL(I)};let E=B.inProgress.get(e);return E||(E=fDe(e).then(h=>{const u={arrayBuffer:h,blobUrl:URL.createObjectURL(new Blob([h],{type:"model/gltf-binary"}))};return B.completed.set(e,u),B.inProgress.delete(e),u}).catch(h=>{throw B.inProgress.delete(e),h}),B.inProgress.set(e,E)),E.then(h=>{c&&(I=h.blobUrl,l=!1,g(h.blobUrl),DXA(e,h.arrayBuffer))}).catch(h=>{console.error("Failed to convert STEP file to GLB",h),c&&g(null)}),()=>{c=!1,I&&l&&URL.revokeObjectURL(I)}},[e]),a?Z.jsx(mXA,{gltfUrl:a,position:A,rotation:t,scale:i,onHover:n,onUnhover:o,isHovered:s,isTranslucent:r}):null},bDe=(e,A)=>{if(e)return A?A(e):e},SXA=(...e)=>e,bXA=({cad_component:e,circuitJson:A,resolveStaticAsset:t})=>{const i=FzA(A),[n,o]=AA.useState(!1),{visibility:s}=jF(),[r,a]=AA.useState(null),g=AA.useCallback(w=>{w?.mousePosition?(o(!0),a(w.mousePosition)):(o(!1),a(null))},[]),c=AA.useCallback(()=>{o(!1),a(null)},[]),I=AA.useMemo(()=>Ji(A).source_component.getUsing({source_component_id:e.source_component_id})?.name,[A,e.source_component_id]),l=AA.useMemo(()=>A.filter(D=>D.type==="pcb_plated_hole"&&D.pcb_component_id===e.pcb_component_id).length>0,[A,e.pcb_component_id]),B=AA.useCallback(w=>bDe(w,t),[t]),C=B(e.model_obj_url??e.model_wrl_url??e.model_stl_url),Q=B(e.model_glb_url??e.model_gltf_url),E=B(e.model_step_url),u=A.find(w=>w.type==="pcb_component"&&w.source_component_id===e.source_component_id)?.layer??"top",d=AA.useMemo(()=>e.rotation?SXA(e.rotation.x*Math.PI/180,e.rotation.y*Math.PI/180,e.rotation.z*Math.PI/180):SXA(0,0,0),[e.rotation,u]),f=AA.useMemo(()=>{if(!e.position)return;let w;return u==="top"?w=e.position.z:u==="bottom"?w=-(e.position.z+i):w=e.position.z,[e.position.x,e.position.y,w]},[e.position,u,i]);let m=null;if(C?m=Z.jsx(EDe,{url:C,position:f,rotation:d,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model},e.cad_component_id):Q?m=Z.jsx(mXA,{gltfUrl:Q,position:f,rotation:d,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model},e.cad_component_id):E&&!e.model_jscad&&!e.footprinter_string?m=Z.jsx(SDe,{stepUrl:E,position:f,rotation:d,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model}):e.model_jscad?m=Z.jsx(lDe,{jscadPlan:e.model_jscad,positionOffset:f,rotationOffset:d,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model},e.cad_component_id):e.footprinter_string&&(m=Z.jsx(rDe,{positionOffset:f,rotationOffset:d,footprint:e.footprinter_string,scale:e.model_unit_to_mm_scale_factor,onHover:g,onUnhover:c,isHovered:n,isTranslucent:e.show_as_translucent_model})),e.show_as_translucent_model){if(!s.translucentModels)return null}else if(l&&!s.throughHoleModels||!l&&!s.smtModels)return null;return Z.jsxs(Z.Fragment,{children:[m,n&&r?Z.jsx(MzA,{position:r,style:{fontFamily:"sans-serif",transform:"translate3d(1rem, 1rem, 0)",backgroundColor:"white",padding:"5px",borderRadius:"3px",pointerEvents:"none",userSelect:"none",WebkitUserSelect:"none",MozUserSelect:"none",msUserSelect:"none"},children:I??"<unknown>"}):null]})},xXA={version:"0.0.519"};function xDe(e){e.querySelectorAll("canvas").forEach(A=>A.remove())}var _De=e=>{e.outputColorSpace=pm,e.toneMapping=v_A,e.toneMappingExposure=1},_XA="cadViewerCameraStateSession",kXA=(e,A)=>{try{const t={position:e.position.toArray(),quaternion:e.quaternion.toArray(),up:e.up.toArray(),fov:e.fov??50,target:A.target.toArray()};sessionStorage.setItem(_XA,JSON.stringify(t))}catch(t){console.warn("Failed to save camera:",t)}},kEA=(e,A)=>{try{const t=sessionStorage.getItem(_XA);if(!t)return!1;const i=JSON.parse(t);if(e.position.fromArray(i.position),e.quaternion.fromArray(i.quaternion),e.up.fromArray(i.up),"fov"in e){const n=e;n.fov=i.fov,n.updateProjectionMatrix?.()}return A.target.fromArray(i.target),A.update(),e.updateMatrixWorld(),!0}catch(t){return console.warn("Failed to restore camera:",t),!1}},FXA=AA.createContext(void 0),kDe=({children:e,defaultTarget:A,initialCameraPosition:t})=>{const i=AA.useRef(null),n=AA.useRef(null),[o,s]=AA.useState(null),[r,a]=AA.useState("perspective"),[g,c]=AA.useState(t??null),[I,l]=AA.useState(new Wp(0,0,0)),B=AA.useMemo(()=>{const[h,u,d]=t??[5,-5,5],f=Math.hypot(h-A.x,u-A.y,d-A.z);return f>0?f:5},[t,A]),C=AA.useCallback(h=>{const u=[A.x,A.y,A.z],d=n.current,f=i.current;let m=B;switch(d&&f&&(m=d.position.distanceTo(f.target)),h){case"Top Center Angled":{const w=m/Math.sqrt(2);return{position:[A.x,A.y-w,A.z+w],target:u,up:[0,0,1]}}case"Top Down":return{position:[A.x,A.y,A.z+m],target:u,up:[0,0,1]};case"Top Left Corner":return{position:[A.x-m*.6,A.y-m*.6,A.z+m*.6],target:u,up:[0,0,1]};case"Top Right Corner":return{position:[A.x+m*.6,A.y-m*.6,A.z+m*.6],target:u,up:[0,0,1]};case"Left Sideview":return{position:[A.x-m,A.y,A.z],target:u,up:[0,0,1]};case"Right Sideview":return{position:[A.x+m,A.y,A.z],target:u,up:[0,0,1]};case"Front":return{position:[A.x,A.y-m,A.z],target:u,up:[0,0,1]};default:return null}},[B,A,n,i]),Q=AA.useCallback(h=>{i.current=h},[]),E=AA.useMemo(()=>({controlsRef:i,mainCameraRef:n,defaultTarget:A,baseDistance:B,controller:o,setController:s,getPresetConfig:C,handleControlsChange:Q,cameraType:r,setCameraType:a,cameraPosition:g,setCameraPosition:c,cameraRotation:I,setCameraRotation:l,saveCameraToSession:kXA,loadCameraFromSession:kEA}),[A,B,o,C,Q,r,g,I]);return Z.jsx(FXA.Provider,{value:E,children:e})},y_=()=>{const e=AA.useContext(FXA);if(!e)throw new Error("useCameraController must be used within a CameraControllerProvider");return e},FDe=AA.forwardRef(({children:e,scene:A,camera:t,style:i,onCreated:n},o)=>{const{cameraType:s}=y_(),r=AA.useRef(null),[a,g]=AA.useState(null),c=AA.useRef([]),I=AA.useRef(void 0);I.current=n;const l=AA.useRef(null),B=AA.useCallback(h=>{c.current.push(h)},[]),C=AA.useCallback(h=>{c.current=c.current.filter(u=>u!==h)},[]),Q=AA.useMemo(()=>new oF,[]);A?.up&&Q.up.set(A.up.x,A.up.y,A.up.z);const E=AA.useRef(new pg);return AA.useImperativeHandle(o,()=>E.current),AA.useEffect(()=>{if(!r.current)return;xDe(r.current);const h=new fP({antialias:!0,alpha:!0});_De(h),h.setSize(r.current.clientWidth,r.current.clientHeight),h.setPixelRatio(window.devicePixelRatio),r.current.appendChild(h.domElement);const u=r.current.clientWidth/r.current.clientHeight,d=s==="perspective"?new uE(75,u,.1,1e3):new $2(-10*u,10*u,10,-10,-1e3,1e3);l.current?(d.position.copy(l.current.position),d.quaternion.copy(l.current.quaternion),d.up.copy(l.current.up)):(t?.up&&d.up.set(t.up[0],t.up[1],t.up[2]),t?.position&&d.position.set(t.position[0],t.position[1],t.position[2]),d.lookAt(0,0,0)),Q.add(E.current),window.__TSCIRCUIT_THREE_OBJECT=E.current,g({scene:Q,camera:d,renderer:h,rootObject:E.current,addFrameListener:B,removeFrameListener:C}),I.current?.({camera:d,renderer:h});let f;const m=new mMt,w=()=>{const b=m.getElapsedTime(),k=m.getDelta();c.current.forEach(x=>x(b,k)),h.render(Q,d),f=requestAnimationFrame(w)};w();const D=()=>{if(r.current){const b=r.current.clientWidth/r.current.clientHeight;d instanceof uE?d.aspect=b:d instanceof $2&&(d.left=-10*b,d.right=10*b,d.top=10,d.bottom=-10),d.updateProjectionMatrix(),h.setSize(r.current.clientWidth,r.current.clientHeight)}};return window.addEventListener("resize",D),()=>{l.current={position:d.position.clone(),quaternion:d.quaternion.clone(),up:d.up.clone()},window.removeEventListener("resize",D),cancelAnimationFrame(f),r.current&&h.domElement&&r.current.removeChild(h.domElement),h.dispose(),Q.remove(E.current),window.__TSCIRCUIT_THREE_OBJECT===E.current&&(window.__TSCIRCUIT_THREE_OBJECT=void 0)}},[Q,B,C,s]),Z.jsx("div",{ref:r,style:{width:"100%",height:"100%",...i},children:a&&Z.jsx(GzA.Provider,{value:a,children:Z.jsx(oDe,{children:e})})})}),GDe=({autoRotate:e,autoRotateSpeed:A,onStart:t,panSpeed:i,rotateSpeed:n,zoomSpeed:o,enableDamping:s,dampingFactor:r,target:a,onControlsChange:g})=>{const{camera:c,renderer:I}=Lu(),l=AA.useMemo(()=>!c||!I?null:new vvt(c,I.domElement),[c,I]);return AA.useEffect(()=>(g?.(l??null),()=>g?.(null)),[l,g]),AA.useEffect(()=>{if(!l)return;const B=()=>{g?.(l)};return l.addEventListener("change",B),()=>{l.removeEventListener("change",B)}},[l,g]),AA.useEffect(()=>{l&&(l.autoRotate=e||!1,l.autoRotateSpeed=A||1,i!==void 0&&(l.panSpeed=i),n!==void 0&&(l.rotateSpeed=n),o!==void 0&&(l.zoomSpeed=o),s!==void 0&&(l.enableDamping=s),r!==void 0&&(l.dampingFactor=r),l.zoomToCursor=!0,l.mouseButtons={LEFT:hx.ROTATE,MIDDLE:hx.PAN,RIGHT:null},a&&(l.target.set(a[0],a[1],a[2]),l.update()))},[l,e,A,i,n,o,s,r,a]),AA.useEffect(()=>{if(!(!l||!t))return l.addEventListener("start",t),()=>{l.removeEventListener("start",t)}},[l,t]),AA.useEffect(()=>{if(l)return()=>{l.dispose()}},[l]),oH(()=>{l?.update()},[l]),null},MDe=`
|
|
5137
5137
|
varying vec3 worldPosition;
|
|
5138
5138
|
void main() {
|
|
5139
5139
|
worldPosition = (modelMatrix * vec4(position, 1.0)).xyz;
|
|
@@ -5172,7 +5172,7 @@ ${a.join(`
|
|
|
5172
5172
|
`+a+` |
|
|
5173
5173
|
`+o.line+" | "+g+`
|
|
5174
5174
|
`+a+" | "+NEA("",n.column-1," ")+NEA("",I,"^")}else A+=`
|
|
5175
|
-
at `+s}return A},dW.buildMessage=function(e,A){var t={literal:function(g){return'"'+n(g.text)+'"'},class:function(g){var c=g.parts.map(function(I){return Array.isArray(I)?o(I[0])+"-"+o(I[1]):o(I)});return"["+(g.inverted?"^":"")+c.join("")+"]"},any:function(){return"any character"},end:function(){return"end of input"},other:function(g){return g.description}};function i(g){return g.charCodeAt(0).toString(16).toUpperCase()}function n(g){return g.replace(/\\/g,"\\\\").replace(/"/g,'\\"').replace(/\0/g,"\\0").replace(/\t/g,"\\t").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/[\x00-\x0F]/g,function(c){return"\\x0"+i(c)}).replace(/[\x10-\x1F\x7F-\x9F]/g,function(c){return"\\x"+i(c)})}function o(g){return g.replace(/\\/g,"\\\\").replace(/\]/g,"\\]").replace(/\^/g,"\\^").replace(/-/g,"\\-").replace(/\0/g,"\\0").replace(/\t/g,"\\t").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/[\x00-\x0F]/g,function(c){return"\\x0"+i(c)}).replace(/[\x10-\x1F\x7F-\x9F]/g,function(c){return"\\x"+i(c)})}function s(g){return t[g.type](g)}function r(g){var c=g.map(s),I,l;if(c.sort(),c.length>0){for(I=1,l=1;I<c.length;I++)c[I-1]!==c[I]&&(c[l]=c[I],l++);c.length=l}switch(c.length){case 1:return c[0];case 2:return c[0]+" or "+c[1];default:return c.slice(0,-1).join(", ")+", or "+c[c.length-1]}}function a(g){return g?'"'+n(g)+'"':"end of input"}return"Expected "+r(e)+" but "+a(A)+" found."};var pSe=e=>{if(e.length===0)return null;let A=e[0].x,t=e[0].y,i=e[0].x,n=e[0].y;for(let o=1;o<e.length;o++){const s=e[o];s.x<A&&(A=s.x),s.y<t&&(t=s.y),s.x>i&&(i=s.x),s.y>n&&(n=s.y)}return{minX:A,minY:t,maxX:i,maxY:n}};function cD(e){if(e.outline&&e.outline.length>=3){const s=pSe(e.outline);return{...s,width:s.maxX-s.minX,height:s.maxY-s.minY,centerX:(s.minX+s.maxX)/2,centerY:(s.minY+s.maxY)/2}}const A=e.width??0,t=e.height??0,i=e.center?.x??0,n=e.center?.y??0;return{...{minX:i-A/2,maxX:i+A/2,minY:n-t/2,maxY:n+t/2},width:A,height:t,centerX:i,centerY:n}}function pW(e,A){if(e===void 0)return A;if(typeof e=="number")return e;const t=parseFloat(e.replace(/mm$/,""));return isNaN(t)?A:t}function fSe(e){return e.layer==="bottom"?e.is_mirrored!==!1:e.is_mirrored===!0}function ySe(e){const A=e.flat();if(A.length===0)return{minX:0,maxX:0,minY:0,maxY:0,width:0,height:0,centerX:0,centerY:0};const t=Math.min(...A.map(s=>s[0])),i=Math.max(...A.map(s=>s[0])),n=Math.min(...A.map(s=>s[1])),o=Math.max(...A.map(s=>s[1]));return{minX:t,maxX:i,minY:n,maxY:o,width:i-t,height:o-n,centerX:(t+i)/2,centerY:(n+o)/2}}function mSe(e){const A=[];return e.forEach(t=>{t.length===29?(A.push(t.slice(0,15)),A.push(t.slice(14,29))):t.length===17?(A.push(t.slice(0,10)),A.push(t.slice(9,17))):A.push(t)}),A}function wSe(e,A){let t=-e.centerX,i=-e.centerY;return A.includes("left")?t=-e.minX:A.includes("right")&&(t=-e.maxX),A.includes("top")?i=-e.maxY:A.includes("bottom")&&(i=-e.minY),{x:t,y:i}}function DSe(e,A){const t=[];let i=e.ccw_rotation??0;if(fSe(e)&&(t.push(w_(A.centerX,A.centerY),{a:-1,b:0,c:0,d:1,e:0,f:0},w_(-A.centerX,-A.centerY)),i=-i),i){const s=i*Math.PI/180;t.push(w_(A.centerX,A.centerY),KXA(s),w_(-A.centerX,-A.centerY))}return{matrix:t.length>0?TXA(...t):void 0,rotationDeg:i}}function PXA(e,A,t,i,n,o,s){A.forEach(r=>{e.beginPath(),r.forEach((a,g)=>{let c={x:a[0],y:a[1]};t&&(c=YXA(t,c));const I=c.x+i.x+n.x,l=c.y+i.y+n.y,B=o(I),C=s(l);g===0?e.moveTo(B,C):e.lineTo(B,C)}),e.stroke()})}function SSe(e,A,t,i,n,o){e.save(),e.translate(A,t),e.rotate(-o),e.fillRect(-i/2,-n/2,i,n),e.restore()}function bSe(e,A,t,i,n,o,s,r,a,g){const c=typeof A.font_size=="number"?A.font_size:.2,I={left:pW(A.knockout_padding?.left,c*.5),right:pW(A.knockout_padding?.right,c*.5),top:pW(A.knockout_padding?.top,c*.3),bottom:pW(A.knockout_padding?.bottom,c*.3)},l=i.width+I.left+I.right,B=i.height+I.top+I.bottom,C=s(A.anchor_position.x),Q=r(A.anchor_position.y),E=l*a,h=B*a;e.fillStyle=g;const u=o*Math.PI/180;SSe(e,C,Q,E,h,u);const d={x:-i.centerX,y:-i.centerY};e.globalCompositeOperation="destination-out",PXA(e,t,n,d,A.anchor_position,s,r),e.globalCompositeOperation="source-over"}function xSe({layer:e,circuitJson:A,boardData:t,copperColor:i="rgb(230, 153, 51)",traceTextureResolution:n}){const s=A.filter(Q=>Q.type==="pcb_copper_text").filter(Q=>Q.layer===e);if(s.length===0)return null;const r=cD(t),a=document.createElement("canvas"),g=Math.floor(r.width*n),c=Math.floor(r.height*n);a.width=g,a.height=c;const I=a.getContext("2d");if(!I)return null;e==="bottom"&&(I.translate(0,c),I.scale(1,-1)),I.strokeStyle=i,I.fillStyle=i;const l=Q=>(Q-r.minX)*n,B=Q=>(r.maxY-Q)*n;s.forEach(Q=>{const E=typeof Q.font_size=="number"?Q.font_size:.2,h=Math.max(.02,E*.08)*n;I.lineWidth=h,I.lineCap="round",I.lineJoin="round";const u=(0,ESe.vectorText)({height:E*.45,input:Q.text}),d=mSe(u),f=ySe(d),{matrix:m,rotationDeg:w}=DSe(Q,f);if(Q.is_knockout)bSe(I,Q,d,f,m,w,l,B,n,i);else{const D=Q.anchor_alignment||"center",b=wSe(f,D);PXA(I,d,m,b,Q.anchor_position,l,B)}});const C=new kx(a);return C.generateMipmaps=!0,C.minFilter=hh,C.magFilter=uI,C.anisotropy=16,C.needsUpdate=!0,C}function _Se({layer:e,circuitJson:A,boardData:t,copperColor:i,traceTextureResolution:n}){const s=Ji(A).pcb_smtpad.list().filter(Q=>Q.layer===e);if(s.length===0)return null;const r=cD(t),a=document.createElement("canvas"),g=Math.floor(r.width*n),c=Math.floor(r.height*n);a.width=g,a.height=c;const I=a.getContext("2d");if(!I)return null;e==="bottom"&&(I.translate(0,c),I.scale(1,-1));const l=Q=>(Q-r.minX)*n,B=Q=>(r.maxY-Q)*n;I.fillStyle=i,s.forEach(Q=>{if(Q.shape==="polygon"&&Q.points){I.beginPath(),Q.points.forEach((f,m)=>{const w=l(f.x),D=B(f.y);m===0?I.moveTo(w,D):I.lineTo(w,D)}),I.closePath(),I.fill();return}if(Q.x===void 0||Q.y===void 0)return;const E=Q.x,h=Q.y,u=l(E),d=B(h);if(Q.shape==="rect"){const f=Q.width*n,m=Q.height*n,w=Gy(Q),D=zF(Q.width,Q.height,w)*n;D>0?(I.beginPath(),I.roundRect(u-f/2,d-m/2,f,m,D),I.fill()):I.fillRect(u-f/2,d-m/2,f,m)}else if(Q.shape==="circle"){const f=(Q.radius??Q.width/2)*n;I.beginPath(),I.arc(u,d,f,0,2*Math.PI),I.fill()}else if(Q.shape==="pill"||Q.shape==="rotated_pill"){const f=Q.width*n,m=Q.height*n,w=Math.min(f,m)/2,b=-(Q.ccw_rotation||0)*(Math.PI/180);b?(I.save(),I.translate(u,d),I.rotate(b),I.beginPath(),I.roundRect(-f/2,-m/2,f,m,w),I.fill(),I.restore()):(I.beginPath(),I.roundRect(u-f/2,d-m/2,f,m,w),I.fill())}else if(Q.shape==="rotated_rect"){const f=Q.width*n,m=Q.height*n,w=Gy(Q),D=zF(Q.width,Q.height,w)*n,k=-(Q.ccw_rotation||0)*(Math.PI/180);I.save(),I.translate(u,d),I.rotate(k),I.beginPath(),I.roundRect(-f/2,-m/2,f,m,D),I.fill(),I.restore()}});const C=new kx(a);return C.generateMipmaps=!0,C.minFilter=hh,C.magFilter=uI,C.anisotropy=16,C.needsUpdate=!0,C}function kSe({layer:e,circuitJson:A,panelData:t,outlineColor:i="black",traceTextureResolution:n}){const o=Ji(A).pcb_board.list().filter(B=>B.pcb_panel_id===t.pcb_board_id);if(o.length===0)return null;const s=document.createElement("canvas"),r=Math.floor(t.width*n),a=Math.floor(t.height*n);s.width=r,s.height=a;const g=s.getContext("2d");if(!g)return null;e==="bottom"&&(g.translate(0,a),g.scale(1,-1)),g.strokeStyle=i,g.lineWidth=.05*n;const c=B=>(B-t.center.x+t.width/2)*n,I=B=>(-(B-t.center.y)+t.height/2)*n;o.forEach(B=>{if(B.outline&&B.outline.length>=2)g.beginPath(),B.outline.forEach((C,Q)=>{const E=c(C.x),h=I(C.y);Q===0?g.moveTo(E,h):g.lineTo(E,h)}),g.closePath(),g.stroke();else{const C=B.width,Q=B.height,{x:E,y:h}=B.center,u=c(E-C/2),d=I(h+Q/2);g.strokeRect(u,d,C*n,Q*n)}});const l=new kx(s);return l.generateMipmaps=!0,l.minFilter=hh,l.magFilter=uI,l.anisotropy=16,l.needsUpdate=!0,l}var FSe=Kr(VQA()),qXA=25.4,GSe=qXA/1e3,MSe=/^\s*(-?\d*(?:\.\d+)?)(?:\s*(mm|mil|inch|in|"))?\s*$/i;function RSe(e){if(!e)return;const A=e.trim().toLowerCase();return A==='"'||A==="inch"?"in":A}function FQ(e){if(e==null)return;if(typeof e=="number")return Number.isFinite(e)?e:void 0;if(typeof e!="string")return;const A=e.trim();if(A.length===0)return;const t=A.match(MSe);if(!t){const r=Number.parseFloat(A);return Number.isFinite(r)?r:void 0}const[,i,n]=t,o=Number.parseFloat(i||"0");if(!Number.isFinite(o))return;switch(RSe(n)){case"mil":return o*GSe;case"in":return o*qXA;case"mm":case void 0:return o;default:return o}}function Vm(e,A){const t=FQ(e);return t===void 0?A:t}function OXA(e){let A=e;if(A.startsWith("#")&&(A=A.slice(1)),A.length===6){const t=parseInt(A.slice(0,2),16),i=parseInt(A.slice(2,4),16),n=parseInt(A.slice(4,6),16);return`rgb(${t}, ${i}, ${n})`}return e.startsWith("rgb")?e:"rgb(255, 243, 204)"}function NSe({layer:e,circuitJson:A,boardData:t,silkscreenColor:i="rgb(255,255,255)",traceTextureResolution:n}){const o=Ji(A).pcb_silkscreen_text.list(),s=Ji(A).pcb_silkscreen_path.list(),r=Ji(A).pcb_silkscreen_line.list(),a=Ji(A).pcb_silkscreen_rect.list(),g=Ji(A).pcb_silkscreen_circle.list(),c=Ji(A).pcb_fabrication_note_rect.list(),I=Ji(A).pcb_note_line.list(),l=o.filter(N=>N.layer===e),B=s.filter(N=>N.layer===e),C=r.filter(N=>N.layer===e),Q=a.filter(N=>N.layer===e),E=g.filter(N=>N.layer===e),h=c.filter(N=>N.layer===e),u=I.filter(N=>N.layer===e);if(l.length===0&&B.length===0&&C.length===0&&Q.length===0&&E.length===0&&h.length===0&&u.length===0)return null;const d=cD(t),f=document.createElement("canvas"),m=Math.floor(d.width*n),w=Math.floor(d.height*n);f.width=m,f.height=w;const D=f.getContext("2d");if(!D)return null;e==="bottom"&&(D.translate(0,w),D.scale(1,-1)),D.strokeStyle=i,D.fillStyle=i;const b=N=>(N-d.minX)*n,k=N=>(d.maxY-N)*n;C.forEach(N=>{const R=FQ(N.x1)??0,U=FQ(N.y1)??0,T=FQ(N.x2)??0,Y=FQ(N.y2)??0;R===T&&U===Y||(D.beginPath(),D.lineWidth=Vm(N.stroke_width,.1)*n,D.lineCap="round",D.moveTo(b(R),k(U)),D.lineTo(b(T),k(Y)),D.stroke())}),u.forEach(N=>{const R=FQ(N.x1)??0,U=FQ(N.y1)??0,T=FQ(N.x2)??0,Y=FQ(N.y2)??0;if(R===T&&U===Y)return;D.save();let O=i;N.color?O=OXA(N.color):O="rgb(255, 243, 204)",D.strokeStyle=O,D.beginPath(),D.lineWidth=Vm(N.stroke_width,.1)*n,D.lineCap="round";const W=N.is_dashed??!1;if(W){const X=Math.max(D.lineWidth*2,1);D.setLineDash([X,X])}D.moveTo(b(R),k(U)),D.lineTo(b(T),k(Y)),D.stroke(),W&&D.setLineDash([]),D.restore()}),B.forEach(N=>{N.route.length<2||(D.beginPath(),D.lineWidth=Vm(N.stroke_width,.1)*n,D.lineCap="round",D.lineJoin="round",N.route.forEach((R,U)=>{const T=b(FQ(R.x)??0),Y=k(FQ(R.y)??0);U===0?D.moveTo(T,Y):D.lineTo(T,Y)}),D.stroke())}),E.forEach(N=>{const R=Vm(N.radius,0);if(R<=0)return;const U=Vm(N.stroke_width,.12),T=U>0,Y=FQ(N.center?.x)??0,O=FQ(N.center?.y)??0,W=b(Y),X=k(O),iA=R*n;if(D.save(),D.translate(W,X),T){const aA=iA+U/2*n,tA=Math.max(0,iA-U/2*n);tA>0?(D.beginPath(),D.arc(0,0,aA,0,2*Math.PI),D.arc(0,0,tA,0,2*Math.PI,!0),D.fill("evenodd")):(D.beginPath(),D.arc(0,0,aA,0,2*Math.PI),D.fill())}else D.beginPath(),D.arc(0,0,iA,0,2*Math.PI),D.fill();D.restore()}),Q.forEach(N=>{const R=Vm(N.width,0),U=Vm(N.height,0);if(R<=0||U<=0)return;const T=FQ(N.center?.x)??0,Y=FQ(N.center?.y)??0,O=b(T),W=k(Y),X=Gy(N),iA=typeof X=="string"?FQ(X):X,aA=zF(R,U,iA);D.save(),D.translate(O,W);const tA=R/2*n,oA=U/2*n,rA=Math.min(aA*n,tA,oA),CA=N.stroke_width??!1,SA=N.is_filled??!0,MA=N.is_stroke_dashed??!1,GA=CA?Vm(N.stroke_width,.1)*n:0;if(((hA,kA,dA,qA,ZA)=>{if(D.beginPath(),ZA<=0)D.rect(hA,kA,dA,qA);else{const rt=ZA,yA=hA+dA,$A=kA+qA;D.moveTo(hA+rt,kA),D.lineTo(yA-rt,kA),D.quadraticCurveTo(yA,kA,yA,kA+rt),D.lineTo(yA,$A-rt),D.quadraticCurveTo(yA,$A,yA-rt,$A),D.lineTo(hA+rt,$A),D.quadraticCurveTo(hA,$A,hA,$A-rt),D.lineTo(hA,kA+rt),D.quadraticCurveTo(hA,kA,hA+rt,kA),D.closePath()}})(-tA,-oA,tA*2,oA*2,rA),SA&&D.fill(),CA&&GA>0){if(D.lineWidth=GA,MA){const hA=Math.max(GA*2,1);D.setLineDash([hA,hA])}D.stroke(),MA&&D.setLineDash([])}D.restore()}),h.forEach(N=>{const R=Vm(N.width,0),U=Vm(N.height,0);if(R<=0||U<=0)return;const T=FQ(N.center?.x)??0,Y=FQ(N.center?.y)??0,O=b(T),W=k(Y),X=Gy(N),iA=typeof X=="string"?FQ(X):X,aA=zF(R,U,iA);D.save(),D.translate(O,W);const tA=R/2*n,oA=U/2*n,rA=Math.min(aA*n,tA,oA),CA=N.has_stroke??!1,SA=N.is_filled??!0,MA=N.is_stroke_dashed??!1,GA=CA?Vm(N.stroke_width,.1)*n:0;let TA=i,hA=i;if(N.color){const dA=OXA(N.color);TA=dA,hA=dA}else TA="rgb(255, 243, 204)",hA="rgb(255, 243, 204)";if(((dA,qA,ZA,rt,yA)=>{if(D.beginPath(),yA<=0)D.rect(dA,qA,ZA,rt);else{const $A=yA,KA=dA+ZA,HA=qA+rt;D.moveTo(dA+$A,qA),D.lineTo(KA-$A,qA),D.quadraticCurveTo(KA,qA,KA,qA+$A),D.lineTo(KA,HA-$A),D.quadraticCurveTo(KA,HA,KA-$A,HA),D.lineTo(dA+$A,HA),D.quadraticCurveTo(dA,HA,dA,HA-$A),D.lineTo(dA,qA+$A),D.quadraticCurveTo(dA,qA,dA+$A,qA),D.closePath()}})(-tA,-oA,tA*2,oA*2,rA),SA&&(D.fillStyle=TA,D.fill()),CA&&GA>0){if(D.strokeStyle=hA,D.lineWidth=GA,MA){const dA=Math.max(GA*2,1);D.setLineDash([dA,dA])}D.stroke(),MA&&D.setLineDash([])}D.restore()}),l.forEach(N=>{const R=N.font_size||.25,U=Math.min(Math.max(.01,R*.1),R*.05)*n;D.lineWidth=U,D.lineCap="butt",D.lineJoin="miter";const T=(0,FSe.vectorText)({height:R*.45,input:N.text}),Y=[];T.forEach(MA=>{MA.length===29?(Y.push(MA.slice(0,15)),Y.push(MA.slice(14,29))):MA.length===17?(Y.push(MA.slice(0,10)),Y.push(MA.slice(9,17))):Y.push(MA)});const O=Y.flat(),W={minX:O.length>0?Math.min(...O.map(MA=>MA[0])):0,maxX:O.length>0?Math.max(...O.map(MA=>MA[0])):0,minY:O.length>0?Math.min(...O.map(MA=>MA[1])):0,maxY:O.length>0?Math.max(...O.map(MA=>MA[1])):0},X=(W.minX+W.maxX)/2,iA=(W.minY+W.maxY)/2;let aA=-X,tA=-iA;const oA=N.anchor_alignment||"center";oA.includes("left")?aA=-W.minX:oA.includes("right")&&(aA=-W.maxX),oA.includes("top")?tA=-W.maxY:oA.includes("bottom")&&(tA=-W.minY);const rA=[];let CA=N.ccw_rotation??0;if(N.layer==="bottom"&&(rA.push(w_(X,iA),{a:-1,b:0,c:0,d:1,e:0,f:0},w_(-X,-iA)),CA=-CA),CA){const MA=CA*Math.PI/180;rA.push(w_(X,iA),KXA(MA),w_(-X,-iA))}const SA=rA.length>0?TXA(...rA):void 0;Y.forEach(MA=>{D.beginPath(),MA.forEach((GA,TA)=>{let hA={x:GA[0],y:GA[1]};SA&&(hA=YXA(SA,hA));const kA=hA.x+aA+N.anchor_position.x,dA=hA.y+tA+N.anchor_position.y,qA=b(kA),ZA=k(dA);TA===0?D.moveTo(qA,ZA):D.lineTo(qA,ZA)}),D.stroke()})});const x=new kx(f);return x.generateMipmaps=!0,x.minFilter=hh,x.magFilter=uI,x.anisotropy=16,x.needsUpdate=!0,x}function WXA(e){return e&&e.route_type==="wire"&&typeof e.layer=="string"&&typeof e.width=="number"}function vSe({layer:e,circuitJson:A,boardData:t,traceColor:i,traceTextureResolution:n}){const o=Ji(A).pcb_trace.list(),s=Ji(A).pcb_via.list(),r=Ji(A).pcb_plated_hole.list(),a=o.filter(Q=>Q.route.some(E=>WXA(E)&&E.layer===e));if(a.length===0)return null;const g=cD(t),c=document.createElement("canvas"),I=Math.floor(g.width*n),l=Math.floor(g.height*n);c.width=I,c.height=l;const B=c.getContext("2d");if(!B)return null;e==="bottom"&&(B.translate(0,l),B.scale(1,-1)),a.forEach(Q=>{let E=!0;B.beginPath(),B.strokeStyle=i,B.lineCap="round",B.lineJoin="round";let h=0;for(const u of Q.route){if(!WXA(u)||u.layer!==e){E||B.stroke(),E=!0;continue}const d=u.x,f=u.y;h=u.width*n,B.lineWidth=h;const m=(d-g.minX)*n,w=(g.maxY-f)*n;E?(B.moveTo(m,w),E=!1):B.lineTo(m,w)}E||B.stroke()}),B.globalCompositeOperation="destination-out",B.fillStyle="black",s.forEach(Q=>{const E=(Q.x-g.minX)*n,h=(g.maxY-Q.y)*n,u=Q.outer_diameter/2*n;B.beginPath(),B.arc(E,h,u,0,2*Math.PI,!1),B.fill()}),r.forEach(Q=>{if(Q.layers.includes(e)&&Q.shape==="circle"){const E=(Q.x-g.minX)*n,h=(g.maxY-Q.y)*n,u=Q.outer_diameter/2*n;B.beginPath(),B.arc(E,h,u,0,2*Math.PI,!1),B.fill()}else if(Q.layers.includes(e)&&Q.shape==="rotated_pill_hole_with_rect_pad"){const E=(Q.x-g.minX)*n,h=(g.maxY-Q.y)*n,u=(Q.rect_pad_width??Q.hole_width??0)*n,d=(Q.rect_pad_height??Q.hole_height??0)*n,m=-(Q.rect_ccw_rotation||0);m?(B.save(),B.translate(E,h),B.rotate(m*Math.PI/180),B.beginPath(),B.rect(-u/2,-d/2,u,d),B.fill(),B.restore()):(B.beginPath(),B.rect(E-u/2,h-d/2,u,d),B.fill())}}),B.globalCompositeOperation="source-over";const C=new kx(c);return C.generateMipmaps=!0,C.minFilter=hh,C.magFilter=uI,C.anisotropy=16,C.needsUpdate=!0,C}Kr(d_()),Kr(VN());function LSe(e,A,t,i){if(!t||Math.abs(t)<1e-9)return[];const n=4*Math.atan(t),o=A[0]-e[0],s=A[1]-e[1],r=Math.sqrt(o*o+s*s);if(r<1e-9)return[];const a=Math.abs(r/(2*Math.sin(n/2))),g=Math.sqrt(Math.max(0,a*a-r/2*(r/2))),c=[(e[0]+A[0])/2,(e[1]+A[1])/2],I=o/r,B=-(s/r),C=I,Q=c[0]+B*g*Math.sign(t),E=c[1]+C*g*Math.sign(t),h=Math.atan2(e[1]-E,e[0]-Q),u=[],d=Math.max(2,Math.ceil(i*Math.abs(n)/(Math.PI*2)*4)),f=n/d;for(let m=1;m<d;m++){const w=h+f*m;u.push([Q+a*Math.cos(w),E+a*Math.sin(w)])}return u}function ZXA(e,A){const t=[],i=e.vertices;for(let n=0;n<i.length;n++){const o=i[n],s=i[(n+1)%i.length];if(t.push([o.x,o.y]),o.bulge){const r=LSe([o.x,o.y],[s.x,s.y],o.bulge,A);t.push(...r)}}return t}function VXA({ctx:e,points:A,canvasXFromPcb:t,canvasYFromPcb:i}){A.length<3||(e.beginPath(),A.forEach((n,o)=>{const s=t(n[0]),r=i(n[1]);o===0?e.moveTo(s,r):e.lineTo(s,r)}),e.closePath(),e.fill())}function USe({ctx:e,pour:A,canvasXFromPcb:t,canvasYFromPcb:i}){const n=A.brep_shape;if(!n||!n.outer_ring)return;const o=ZXA(n.outer_ring,32);if(o.length>=3&&VXA({ctx:e,points:o,canvasXFromPcb:t,canvasYFromPcb:i}),n.inner_rings&&n.inner_rings.length>0){e.globalCompositeOperation="destination-out";for(const s of n.inner_rings){const r=ZXA(s,32);r.length>=3&&VXA({ctx:e,points:r,canvasXFromPcb:t,canvasYFromPcb:i})}e.globalCompositeOperation="source-over"}}function HSe({layer:e,circuitJson:A,boardData:t,traceTextureResolution:i=av}){const n=A.filter(h=>h.type==="pcb_copper_pour"),o=e==="top"?"top_copper":"bottom_copper",s=n.filter(h=>h.layer===e);if(s.length===0)return null;const r=cD(t),a=document.createElement("canvas"),g=Math.floor(r.width*i),c=Math.floor(r.height*i);a.width=g,a.height=c;const I=a.getContext("2d");if(!I)return null;e==="bottom"&&(I.translate(0,c),I.scale(1,-1));const l=h=>(h-r.minX)*i,B=h=>(r.maxY-h)*i,C=s.filter(h=>h.shape==="rect"||h.shape==="polygon"),Q=s.filter(h=>h.shape==="brep");if(C.length>0){const h=new bQA(I);h.setCameraBounds({minX:r.minX,maxX:r.maxX,minY:r.minY,maxY:r.maxY});const u=C.filter(w=>w.covered_with_solder_mask!==!1),d=C.filter(w=>w.covered_with_solder_mask===!1),f=`rgb(${pr.fr4TracesWithMaskGreen.map(w=>w*255).join(",")})`,m=`rgb(${pr.copper.map(w=>w*255).join(",")})`;u.length>0&&(h.configure({colorOverrides:{copper:{top:f,bottom:f,inner1:f,inner2:f,inner3:f,inner4:f,inner5:f,inner6:f}}}),h.drawElements(u,{layers:[o]})),d.length>0&&(h.configure({colorOverrides:{copper:{top:m,bottom:m,inner1:m,inner2:m,inner3:m,inner4:m,inner5:m,inner6:m}}}),h.drawElements(d,{layers:[o]}))}for(const h of Q){const d=h.covered_with_solder_mask!==!1?pr.fr4TracesWithMaskGreen:pr.copper,f=`rgb(${d[0]*255}, ${d[1]*255}, ${d[2]*255})`;I.fillStyle=f,USe({ctx:I,pour:h,canvasXFromPcb:l,canvasYFromPcb:B})}const E=new kx(a);return E.generateMipmaps=!0,E.minFilter=hh,E.magFilter=uI,E.anisotropy=16,E.needsUpdate=!0,E}var fW=e=>{const[A=0,t=0,i=0]=e;return`rgb(${Math.round(A*255)}, ${Math.round(t*255)}, ${Math.round(i*255)})`},YSe=e=>{const A=fW(ODe[e]??pr.fr4SolderMaskGreen),t=fW(e==="fr1"?pr.fr1TracesWithMaskCopper:pr.fr4TracesWithMaskGreen);return{soldermask:A,soldermaskOverCopper:t,copper:fW(pr.copper),transparent:"rgba(0,0,0,0)"}},jXA=(e,A)=>{e.setCameraBounds({minX:A.minX,maxX:A.maxX,minY:A.minY,maxY:A.maxY})},JSe=({ctx:e,layer:A,bounds:t,elements:i,boardMaterial:n})=>{const o=YSe(n),s=A==="top"?"top_copper":"bottom_copper",r=new bQA(e);r.configure({colorOverrides:{copper:{top:o.transparent,bottom:o.transparent,inner1:o.transparent,inner2:o.transparent,inner3:o.transparent,inner4:o.transparent,inner5:o.transparent,inner6:o.transparent},drill:o.transparent,boardOutline:o.transparent,substrate:o.transparent,keepout:o.transparent,fabricationNote:o.transparent,silkscreen:{top:o.transparent,bottom:o.transparent},courtyard:{top:o.transparent,bottom:o.transparent},soldermask:{top:o.soldermask,bottom:o.soldermask},soldermaskWithCopperUnderneath:{top:o.soldermaskOverCopper,bottom:o.soldermaskOverCopper},soldermaskOverCopper:{top:o.soldermaskOverCopper,bottom:o.soldermaskOverCopper}}}),jXA(r,t),r.drawElements(i,{layers:[s],drawSoldermask:!0,drawSoldermaskTop:A==="top",drawSoldermaskBottom:A==="bottom"});const a=i.filter(g=>g.type==="pcb_copper_pour"&&g.layer===A&&g.covered_with_solder_mask===!1);if(a.length>0){e.save(),e.globalCompositeOperation="destination-out";const g=new bQA(e);g.configure({colorOverrides:{copper:{top:o.copper,bottom:o.copper,inner1:o.copper,inner2:o.copper,inner3:o.copper,inner4:o.copper,inner5:o.copper,inner6:o.copper}}}),jXA(g,t),g.drawElements(a,{layers:[s]}),e.restore()}},TSe=e=>({minX:e.center.x-e.width/2,maxX:e.center.x+e.width/2,minY:e.center.y-e.height/2,maxY:e.center.y+e.height/2,width:e.width,height:e.height,centerX:e.center.x,centerY:e.center.y}),KSe=(e,A)=>{const t=Math.min(e.minX,A.minX),i=Math.max(e.maxX,A.maxX),n=Math.min(e.minY,A.minY),o=Math.max(e.maxY,A.maxY);return{minX:t,maxX:i,minY:n,maxY:o,width:i-t,height:o-n,centerX:(t+i)/2,centerY:(n+o)/2}},PSe=(e,A)=>{const t=e.filter(s=>s.type==="pcb_panel"),i=e.filter(s=>s.type==="pcb_board"),n=t.find(s=>s.pcb_panel_id===A.pcb_board_id)??t[0];return n&&n.width>0&&n.height>0?TSe(n):(i.length>1?i:[A]).map(s=>cD(s)).reduce((s,r)=>KSe(s,r))};function qSe({layer:e,circuitJson:A,boardData:t,traceTextureResolution:i=av}){const n=PSe(A,t),o=Math.floor(n.width*i),s=Math.floor(n.height*i);if(o<=0||s<=0)return null;const r=document.createElement("canvas");r.width=o,r.height=s;const a=r.getContext("2d");if(!a)return null;e==="bottom"&&(a.translate(0,s),a.scale(1,-1));const g=A.some(I=>I.type==="pcb_board")?A:[t,...A];JSe({ctx:a,layer:e,bounds:n,elements:g,boardMaterial:t.material});const c=new kx(r);return c.generateMipmaps=!0,c.minFilter=hh,c.magFilter=uI,c.anisotropy=16,c.needsUpdate=!0,c}var vEA=e=>{const[A=0,t=0,i=0]=e;return`rgb(${Math.round(A*255)}, ${Math.round(t*255)}, ${Math.round(i*255)})`},OSe=({textures:e,boardData:A,traceTextureResolution:t})=>{if(!e.some(c=>c?.image))return null;const n=cD(A),o=Math.floor(n.width*t),s=Math.floor(n.height*t);if(o<=0||s<=0)return null;const r=document.createElement("canvas");r.width=o,r.height=s+1;const a=r.getContext("2d");if(!a)return null;e.forEach(c=>{if(!c?.image)return;const I=c.image;a.drawImage(I,0,0,o,s)});const g=new kx(r);return g.generateMipmaps=!1,g.minFilter=uI,g.magFilter=uI,g.premultiplyAlpha=!0,g.anisotropy=16,g.needsUpdate=!0,g};function zXA({circuitJson:e,boardData:A,traceTextureResolution:t,visibility:i}){const n=vEA(pr.fr4TracesWithMaskGreen),o=vEA(pr.fr4TracesWithoutMaskTan),s="rgb(255,255,255)",r=vEA(pr.copper),a=i?.boardBody??!0,g=I=>{const l=(I==="top"?i?.topMask:i?.bottomMask)??!0,B=(I==="top"?i?.topCopper:i?.bottomCopper)??!0,C=(I==="top"?i?.topSilkscreen:i?.bottomSilkscreen)??!0,Q=l?qSe({layer:I,circuitJson:e,boardData:A,traceTextureResolution:t}):null,E=B?vSe({layer:I,circuitJson:e,boardData:A,traceColor:l?n:o,traceTextureResolution:t}):null,h=B?xSe({layer:I,circuitJson:e,boardData:A,copperColor:r,traceTextureResolution:t}):null,u=B?HSe({layer:I,circuitJson:e,boardData:A,traceTextureResolution:t}):null,d=B?_Se({layer:I,circuitJson:e,boardData:A,copperColor:r,traceTextureResolution:t}):null,f=C?NSe({layer:I,circuitJson:e,boardData:A,silkscreenColor:s,traceTextureResolution:t}):null,m=a?kSe({layer:I,circuitJson:e,panelData:A,traceTextureResolution:t}):null;return OSe({textures:[u,E,h,d,Q,f,m],boardData:A,traceTextureResolution:t})},c=A.num_layers??2;return{topBoard:g("top"),bottomBoard:c<2?null:g("bottom")}}function XXA(e,A){const{texture:t,yOffset:i,isBottomLayer:n,usePolygonOffset:o=!1,renderOrder:s=0,isFaux:r=!1}=e;if(!t)return null;const a=cD(A),g=new km(a.width,a.height),c=new xd({map:t,transparent:!0,alphaTest:.08,side:WB,depthWrite:!0,polygonOffset:o,polygonOffsetFactor:o?-4:0,polygonOffsetUnits:o?-4:0,opacity:r?QW:1}),I=new Ao(g,c);return I.position.set(a.centerX,a.centerY,i),n&&I.rotation.set(Math.PI,0,0),I.name=`${n?"bottom":"top"}-board-texture-plane`,I.renderOrder=s,I}function WSe(e,A,t,i=!1){const n=[];if(!e||!A||t===null)return n;const o=.005,s=XXA({texture:e.topBoard,yOffset:t/2+o,isBottomLayer:!1,usePolygonOffset:!0,renderOrder:1,isFaux:i},A);s&&n.push(s);const r=XXA({texture:e.bottomBoard,yOffset:-t/2-o,isBottomLayer:!0,usePolygonOffset:!0,renderOrder:1,isFaux:i},A);return r&&n.push(r),n}var ZSe=4e6,VSe=4096,jSe=1;function $XA(e,A,t={}){const{maxTexturePixels:i=ZSe,maxTextureDimension:n=VSe,minTextureResolution:o=jSe}=t,s=cD(e);if(!Number.isFinite(s.width)||!Number.isFinite(s.height)||s.width<=0||s.height<=0)return A;const r=Math.max(s.width,s.height),a=n/r,g=Math.sqrt(i/(s.width*s.height)),c=Math.min(A,a,g);return Math.max(o,c)}function zSe({circuitJson:e,pcbThickness:A,isFaux:t=!1}){const{rootObject:i}=Lu(),{visibility:n}=jF(),o=AA.useMemo(()=>{const a=e.filter(I=>I.type==="pcb_panel"),g=Ji(e).pcb_board.list();if(a.length>0){const I=a[0],l=g.find(B=>B.pcb_panel_id===I.pcb_panel_id);return{type:"pcb_board",pcb_board_id:I.pcb_panel_id,center:I.center,width:I.width,height:I.height,thickness:l?.thickness??1.4,material:l?.material??"fr4",num_layers:l?.num_layers??2}}const c=g.filter(I=>!I.pcb_panel_id);return c.length>0?c[0]:null},[e]),s=AA.useMemo(()=>o?$XA(o,av):av,[o]),r=AA.useMemo(()=>!o||!o.width||!o.height?null:zXA({circuitJson:e,boardData:o,traceTextureResolution:s,visibility:n}),[e,o,s,n]);return AA.useEffect(()=>{if(!i||!o||!r)return;const a=[],g=C=>{const Q=["map","alphaMap","aoMap","bumpMap","displacementMap","emissiveMap","lightMap","metalnessMap","normalMap","roughnessMap","specularMap"],E=C;for(const h of Q){const u=E[h];u&&u instanceof Hc&&(u.dispose(),E[h]=null)}C.dispose()},c=(C,Q,E,h,u=!1,d=!0,f=1)=>{if(!C)return null;const m=cD(o),w=new km(m.width,m.height),D=new xd({map:C,transparent:!0,alphaTest:.08,side:WB,depthWrite:d,polygonOffset:u,polygonOffsetFactor:u?-4:0,polygonOffsetUnits:u?-4:0,opacity:t?QW:1}),b=new Ao(w,D);return b.position.set(m.centerX,m.centerY,Q),E&&b.rotation.set(Math.PI,0,0),b.name=h,b.renderOrder=f,b.frustumCulled=!1,b},I=.005,l=c(r.topBoard,A/2+I,!1,"jscad-top-board-texture",!0);l&&(a.push(l),i.add(l));const B=c(r.bottomBoard,-A/2-I,!0,"jscad-bottom-board-texture",!0);return B&&(a.push(B),i.add(B)),()=>{a.forEach(C=>{C.parent===i&&i.remove(C),C.geometry.dispose(),Array.isArray(C.material)?C.material.forEach(Q=>g(Q)):C.material instanceof Zp&&g(C.material)}),r.topBoard?.dispose(),r.bottomBoard?.dispose()}},[i,o,r,A]),null}function XSe(e){const A=Ji(e).cad_component.list(),t=Ji(e).pcb_smtpad.list(),i=Ji(e).pcb_hole.list(),n=Ji(e).pcb_plated_hole.list(),o=Ji(e).pcb_via.list();if(A.length===0&&t.length===0&&i.length===0&&n.length===0&&o.length===0)return null;const s=[...i,...n,...o,...t],r=wL(s);let a=r.minX,g=r.maxX,c=r.minY,I=r.maxY;for(const u of A)if(u.position){const d=u.position.x,f=u.position.y;a=Math.min(a,d),g=Math.max(g,d),c=Math.min(c,f),I=Math.max(I,f)}a===1/0&&(a=-10,g=10,c=-10,I=10);const l=2,B=Math.max(Math.abs(a),Math.abs(g))+l,C=Math.max(Math.abs(c),Math.abs(I))+l,Q=Math.max(2*B,10),E=Math.max(2*C,10);return{type:"pcb_board",pcb_board_id:"faux-board",center:{x:0,y:0},width:Q,height:E,thickness:1.4,material:"fr4",num_layers:2}}function A6A(e){if(Ji(e).pcb_board.list().length>0)return e;const t=XSe(e);if(!t)return e;const n=t.thickness/2;return[...e.map(s=>{if(s.type==="cad_component"){const r=s;if(r.position){const a=r.position.z??0;return{...r,position:{...r.position,z:a+n}}}}return s}),t]}var $Se=AA.forwardRef(({circuitJson:e,children:A,autoRotateDisabled:t,clickToInteractEnabled:i,onUserInteraction:n,onCameraControllerReady:o,resolveStaticAsset:s},r)=>{const a=MXA(A),g=AA.useMemo(()=>A6A(e??a),[e,a]),c=ISe(g),I=AA.useMemo(()=>{if(!g)return[5,-5,5];try{const u=Ji(g).pcb_board.list()[0];if(!u)return[5,-5,5];const{width:d,height:f}=u;if(!d&&!f)return[5,-5,5];const m=5,w=Math.max(d,m),D=Math.max(f,m),b=Math.max(w,D);return[b*.4,-b*.7,b*.9]}catch(u){return console.error(u),[5,-5,5]}},[g]),l=AA.useMemo(()=>{if(!g)return!1;try{const u=Ji(g).pcb_board.list()[0];return!!u&&u.pcb_board_id==="faux-board"}catch{return!1}},[g]),B=AA.useMemo(()=>{if(g)try{const u=Ji(g).pcb_board.list()[0];return u?{width:u.width??0,height:u.height??0}:void 0}catch(u){console.error(u);return}},[g]),C=AA.useMemo(()=>{if(g)try{const u=Ji(g).pcb_board.list()[0];return!u||!u.center?void 0:{x:u.center.x,y:u.center.y}}catch(u){console.error(u);return}},[g]),Q=FzA(g),{stls:E}=KDe(c),h=Ji(g).cad_component.list();return Z.jsxs(GXA,{ref:r,autoRotateDisabled:t,initialCameraPosition:I,clickToInteractEnabled:i,boardDimensions:B,boardCenter:C,onUserInteraction:n,onCameraControllerReady:o,children:[E.map(({stlData:u,color:d,layerType:f},m)=>Z.jsx(QSe,{stlData:u,color:d,opacity:m===0?l?.8:.95:1,layerType:f},`board-${m}`)),Z.jsx(zSe,{circuitJson:g,pcbThickness:Q,isFaux:l}),h.map(u=>Z.jsx(HXA,{fallback:({error:d})=>Z.jsx(UXA,{cad_component:u,error:d}),children:Z.jsx(bXA,{cad_component:u,circuitJson:g,resolveStaticAsset:s},u.cad_component_id)},u.cad_component_id))]})}),Abe=e=>{let A=0;for(let i=0;i<e.length;i++){const n=(i+1)%e.length;e[i]&&e[n]&&(A+=e[i][0]*e[n][1],A-=e[n][0]*e[i][1])}return A/2<=0};function tbe(e,A,t,i,n){let o,s=null;if(t.outline&&t.outline.length>=3){let r=t.outline.map(g=>[g.x,g.y]);Abe(r)&&(r=r.reverse());const a=A.ofPolygons([r]);n.push(a),s=a,o=e.extrude(a,i,void 0,void 0,void 0,!0),n.push(o)}else t.outline&&t.outline.length>0&&console.warn("Board outline has fewer than 3 points, falling back to rectangular board."),o=e.cube([t.width,t.height,i],!0),n.push(o),o=o.translate([t.center.x,t.center.y,0]),n.push(o);return{boardOp:o,outlineCrossSection:s}}var ebe=64;function d0({Manifold:e,width:A,height:t,thickness:i,borderRadius:n}){const o=zF(A,t,n);if(o<=0)return e.cube([A,t,i],!0);const s=[],r=A-2*o,a=t-2*o;return r>0&&s.push(e.cube([r,t,i],!0)),a>0&&s.push(e.cube([A,a,i],!0)),[[A/2-o,t/2-o],[-A/2+o,t/2-o],[-A/2+o,-t/2+o],[A/2-o,-t/2+o]].forEach(([c,I])=>{s.push(e.cylinder(i,o,o,ebe,!0).translate([c,I,0]))}),e.union(s)}var ibe=e=>{let A=0;for(let i=0;i<e.length;i++){const n=(i+1)%e.length;e[i]&&e[n]&&(A+=e[i][0]*e[n][1],A-=e[n][0]*e[i][1])}return A/2<=0};function nbe(e,A,t,i,n){const o=[],s=Ji(t).pcb_cutout.list();for(const r of s){let a;const g=i*1.5;switch(r.shape){case"rect":{const l=Gy(r);if(typeof l=="number"&&l>0?a=d0({Manifold:e,width:r.width,height:r.height,thickness:g,borderRadius:l}):a=e.cube([r.width,r.height,g],!0),n.push(a),r.rotation){const B=a.rotate([0,0,r.rotation]);n.push(B),a=B}a=a.translate([r.center.x,r.center.y,0]),n.push(a);break}case"circle":a=e.cylinder(g,r.radius,-1,VB,!0),n.push(a),a=a.translate([r.center.x,r.center.y,0]),n.push(a);break;case"polygon":if(r.points.length<3){console.warn(`PCB Cutout [${r.pcb_cutout_id}] polygon has fewer than 3 points, skipping.`);continue}let c=r.points.map(l=>[l.x,l.y]);ibe(c)&&(c=c.reverse());const I=A.ofPolygons([c]);n.push(I),a=e.extrude(I,g,0,0,[1,1],!0),n.push(a);break;default:console.warn(`Unsupported cutout shape: ${r.shape} for cutout ${r.pcb_cutout_id}`);continue}a&&o.push(a)}return{cutoutOps:o}}function t6A({Manifold:e,x:A,y:t,diameter:i,thickness:n,segments:o=32}){return e.cylinder(n*1.2,i/2,i/2,o,!0).translate([A,t,0])}function e6A({Manifold:e,x:A,y:t,holeDiameter:i,thickness:n,zOffset:o=.001,segments:s=32}){const r=i/2+o;return e.cylinder(n*1.2,r,r,s,!0).translate([A,t,0])}function obe(e,A,t,i,n){const o=[],s=Ji(t).pcb_hole.list(),r=(g,c,I)=>{const l=d0({Manifold:e,width:g,height:c,thickness:I,borderRadius:Math.min(g,c)/2});return n.push(l),l},a=(g,c,I)=>{const l=[];for(let B=0;B<I;B++){const C=2*Math.PI*B/I;l.push([g/2*Math.cos(C),c/2*Math.sin(C)])}return l};return s.forEach(g=>{const c=g.hole_shape,I=g.x,l=g.y,B=i*1.2,C=g.ccw_rotation??g.rotation??0,Q=g.hole_width??g.hole_diameter,E=g.hole_height??g.hole_diameter;let h=null;if(c==="circle"){h=t6A({Manifold:e,x:I,y:l,diameter:g.hole_diameter,thickness:i,segments:VB}),o.push(h),n.push(h);return}if(c==="pill"||c==="rotated_pill")h=r(Q,E,B);else if(c==="oval"){let u=a(Q,E,VB),d=0;for(let m=0;m<u.length;m++){const w=(m+1)%u.length;d+=u[m][0]*u[w][1],d-=u[w][0]*u[m][1]}d<=0&&(u=u.reverse());const f=A.ofPolygons([u]);n.push(f),h=e.extrude(f,B,0,0,[1,1],!0),n.push(h)}if(h){if(C!==0){const d=h.rotate([0,0,C]);n.push(d),h=d}const u=h.translate([I,l,0]);n.push(u),o.push(u)}}),{nonPlatedHoleBoardDrills:o}}function ID(e){const A=new fg;if(A.setAttribute("position",new Jo(e.vertProperties,3)),A.setIndex(new W6(e.triVerts,1)),e.runIndex&&e.runIndex.length>1&&e.runOriginalID)for(let t=0;t<e.runIndex.length-1;t++){const i=e.runIndex[t],n=e.runIndex[t+1]-i;A.addGroup(i,n,0)}else A.addGroup(0,e.triVerts.length,0);return A}var wH=e=>{let A=0;for(let i=0;i<e.length;i++){const n=(i+1)%e.length;e[i]&&e[n]&&(A+=e[i][0]*e[n][1],A-=e[n][0]*e[i][1])}return A/2<=0},yW=(e,A,t)=>{const i=[];for(let n=0;n<t;n++){const o=2*Math.PI*n/t;i.push([e/2*Math.cos(o),A/2*Math.sin(o)])}return i},$F=new Oi(...pr.copper),mW=.05,wW=.003,My=5e-4,DW=.004;function sbe(e,A,t,i,n,o){const s=[],r=Ji(t).pcb_plated_hole.list(),a=[],g=[],c=(C,Q,E)=>{const h=d0({Manifold:e,width:C,height:Q,thickness:E,borderRadius:Math.min(C,Q)/2});return n.push(h),h},I=({padOutline:C,thickness:Q})=>{if(!Array.isArray(C)||C.length<3)return null;let E=C.map(d=>[d.x,d.y]);wH(E)&&(E=E.reverse());const h=A.ofPolygons([E]);n.push(h);const u=e.extrude(h,Q,0,0,[1,1],!0);return n.push(u),u},l=({ph:C,depth:Q,sizeDelta:E=0})=>{if(C.shape!=="hole_with_polygon_pad")return null;const u=C.pad_outline;if(!Array.isArray(u)||u.length<3)return null;const d=C.hole_shape||"circle",f=C.hole_offset_x||0,m=C.hole_offset_y||0;let w=null;if(d==="circle"){const D=Math.max((C.hole_diameter??0)+E,Ln),b=Math.max(D/2,Ln/2);w=e.cylinder(Q,b,b,VB,!0),n.push(w)}else{const D=C.hole_width??C.hole_diameter,b=C.hole_height??C.hole_diameter;if(!D||!b)return null;const k=Math.max(D+E,Ln),x=Math.max(b+E,Ln);if(d==="oval"){let N=yW(k,x,VB);wH(N)&&(N=N.reverse());const R=A.ofPolygons([N]);n.push(R),w=e.extrude(R,Q,0,0,[1,1],!0),n.push(w)}else(d==="pill"||d==="rotated_pill")&&(w=d0({Manifold:e,width:k,height:x,thickness:Q,borderRadius:Math.min(k,x)/2}),n.push(w))}if(!w)return null;if(f||m){const D=w.translate([f,m,0]);n.push(D),w=D}return w};r.forEach((C,Q)=>{if(C.shape==="circle"){const E=e6A({Manifold:e,x:C.x,y:C.y,holeDiameter:C.hole_diameter*1.02,thickness:i,zOffset:rf,segments:VB});n.push(E),s.push(E);const h=i+2*rf,u=e.cylinder(h,C.outer_diameter/2,C.outer_diameter/2,VB,!0);n.push(u);const d=e.cylinder(h*1.05,C.hole_diameter/2,C.hole_diameter/2,VB,!0);n.push(d);const f=u.subtract(d);n.push(f);const m=f.translate([C.x,C.y,0]);n.push(m);let w=m;if(o){const b=e.intersection([m,o]);n.push(b),w=b}g.push(w);const D=ID(w.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:D,color:$F})}else if(C.shape==="pill"){const E=C.hole_width,h=C.hole_height,u=.4,d=C.outer_width??E+u,f=C.outer_height??h+u,m=E+2*rf,w=h+2*rf,D=i*1.2;let b=c(m,w,D);if(C.ccw_rotation){const W=b.rotate([0,0,C.ccw_rotation]);n.push(W),b=W}const k=b.translate([C.x,C.y,0]);n.push(k),s.push(k);const x=i+2*rf,N=c(d,f,x),R=c(E,h,x*1.05);let U=N.subtract(R);if(n.push(U),C.ccw_rotation){const W=U.rotate([0,0,C.ccw_rotation]);n.push(W),U=W}const T=U.translate([C.x,C.y,0]);n.push(T);let Y=T;if(o){const W=e.intersection([T,o]);n.push(W),Y=W}g.push(Y);const O=ID(Y.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:O,color:$F})}else if(C.shape==="pill_hole_with_rect_pad"){if(C.hole_shape&&C.hole_shape!=="pill"||C.pad_shape&&C.pad_shape!=="rect")return;const E=C.hole_width,h=C.hole_height,u=C.hole_offset_x||0,d=C.hole_offset_y||0,f=C.rect_pad_width,m=C.rect_pad_height,w=Gy(C),D=wW,b=E+2*rf,k=h+2*rf,x=i*1.2,R=c(b,k,x).translate([u,d,0]).translate([C.x,C.y,0]);n.push(R),s.push(R);const U=d0({Manifold:e,width:f,height:m,thickness:Math.max(i-2*(D+My+DW),Ln),borderRadius:w});n.push(U);const T=d0({Manifold:e,width:f,height:m,thickness:D,borderRadius:w}).translate([0,0,i/2+My+D/2]),Y=d0({Manifold:e,width:f,height:m,thickness:D,borderRadius:w}).translate([0,0,-i/2-My-D/2]);n.push(T,Y);const O=c(E,h,i*.8).translate([u,d,0]);n.push(O);const W=e.union([U,T,Y,O]);n.push(W);const X=c(Math.max(E-2*mW,.01),Math.max(h-2*mW,.01),i*1.2).translate([u,d,0]);n.push(X);const iA=W.subtract(X);n.push(iA);const aA=iA.translate([C.x,C.y,0]);n.push(aA);let tA=aA;if(o){const rA=e.intersection([aA,o]);n.push(rA),tA=rA}g.push(tA);const oA=ID(tA.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:oA,color:$F})}else if(C.shape==="rotated_pill_hole_with_rect_pad"){if(C.hole_shape&&C.hole_shape!=="rotated_pill"||C.pad_shape&&C.pad_shape!=="rect")return;const E=C.hole_width,h=C.hole_height,u=C.hole_offset_x||0,d=C.hole_offset_y||0,f=C.rect_pad_width,m=C.rect_pad_height,w=Gy(C),D=wW,b=E+2*rf,k=h+2*rf,x=i*1.2;let N=c(b,k,x).translate([u,d,0]);if(C.hole_ccw_rotation){const rA=N.rotate([0,0,C.hole_ccw_rotation]);n.push(rA),N=rA}const R=N.translate([C.x,C.y,0]);n.push(R),s.push(R);let U=d0({Manifold:e,width:f,height:m,thickness:Math.max(i-2*(D+My+DW),Ln),borderRadius:w});if(n.push(U),C.rect_ccw_rotation){const rA=U.rotate([0,0,C.rect_ccw_rotation]);n.push(rA),U=rA}let T=d0({Manifold:e,width:f,height:m,thickness:D,borderRadius:w}).translate([0,0,i/2+My+D/2]);if(C.rect_ccw_rotation){const rA=T.rotate([0,0,C.rect_ccw_rotation]);n.push(rA),T=rA}let Y=d0({Manifold:e,width:f,height:m,thickness:D,borderRadius:w}).translate([0,0,-i/2-My-D/2]);if(C.rect_ccw_rotation){const rA=Y.rotate([0,0,C.rect_ccw_rotation]);n.push(rA),Y=rA}n.push(T,Y);let O=c(E,h,i*.8).translate([u,d,0]);if(C.hole_ccw_rotation){const rA=O.rotate([0,0,C.hole_ccw_rotation]);n.push(rA),O=rA}n.push(O);const W=e.union([U,T,Y,O]);n.push(W);let X=c(Math.max(E-2*mW,.01),Math.max(h-2*mW,.01),i*1.2).translate([u,d,0]);if(C.hole_ccw_rotation){const rA=X.rotate([0,0,C.hole_ccw_rotation]);n.push(rA),X=rA}n.push(X);const iA=W.subtract(X);n.push(iA);const aA=iA.translate([C.x,C.y,0]);n.push(aA);let tA=aA;if(o){const rA=e.intersection([aA,o]);n.push(rA),tA=rA}g.push(tA);const oA=ID(tA.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:oA,color:$F})}else if(C.shape==="hole_with_polygon_pad"){const E=C.pad_outline;if(!Array.isArray(E)||E.length<3)return;const h=l({ph:C,depth:i*1.2,sizeDelta:2*Ln});if(!h)return;const u=h.translate([C.x,C.y,0]);n.push(u),s.push(u);const d=wW,f=Math.max(i-2*(d+My+DW),Ln),m=I({padOutline:E,thickness:f}),w=I({padOutline:E,thickness:d}),D=I({padOutline:E,thickness:d});if(!m||!w||!D)return;const b=w.translate([0,0,i/2+My+d/2]),k=D.translate([0,0,-i/2-My-d/2]);n.push(b,k);const x=l({ph:C,depth:i*1.02});if(!x)return;const N=l({ph:C,depth:i*.8,sizeDelta:-2*Ln})||x,R=e.union([m,b,k,x]);n.push(R);const U=R.subtract(N);n.push(U);const T=U.translate([C.x,C.y,0]);n.push(T);let Y=T;if(o){const W=e.intersection([T,o]);n.push(W),Y=W}g.push(Y);const O=ID(Y.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:O,color:$F})}else if(C.shape==="oval"){const E=C.hole_width,h=C.hole_height,u=C.outer_width??E+.4,d=C.outer_height??h+.4,f=E+2*rf,m=h+2*rf,w=i*1.2;let D=yW(f,m,VB);wH(D)&&(D=D.reverse());const b=A.ofPolygons([D]);n.push(b);let k=e.extrude(b,w,0,0,[1,1],!0);if(n.push(k),C.ccw_rotation){const oA=k.rotate([0,0,C.ccw_rotation]);n.push(oA),k=oA}const x=k.translate([C.x,C.y,0]);n.push(x),s.push(x);const N=i+2*rf;let R=yW(u,d,VB);wH(R)&&(R=R.reverse());const U=A.ofPolygons([R]);n.push(U);const T=e.extrude(U,N,0,0,[1,1],!0);n.push(T);let Y=yW(E,h,VB);wH(Y)&&(Y=Y.reverse());const O=A.ofPolygons([Y]);n.push(O);const W=e.extrude(O,N*1.05,0,0,[1,1],!0);n.push(W);let X=T.subtract(W);if(n.push(X),C.ccw_rotation){const oA=X.rotate([0,0,C.ccw_rotation]);n.push(oA),X=oA}const iA=X.translate([C.x,C.y,0]);n.push(iA);let aA=iA;if(o){const oA=e.intersection([iA,o]);n.push(oA),aA=oA}g.push(aA);const tA=ID(aA.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:tA,color:$F})}else if(C.shape==="circular_hole_with_rect_pad"){if(C.hole_shape&&C.hole_shape!=="circle"||C.pad_shape&&C.pad_shape!=="rect")return;const E=C.hole_offset_x||0,h=C.hole_offset_y||0,u=t6A({Manifold:e,x:C.x+E,y:C.y+h,diameter:C.hole_diameter,thickness:i,segments:VB});n.push(u),s.push(u);const d=C.rect_pad_width??C.hole_diameter,f=C.rect_pad_height??C.hole_diameter,m=Gy(C),w=wW,D=C.hole_diameter/2,b=d0({Manifold:e,width:d,height:f,thickness:Math.max(i-2*(w+My+DW),Ln),borderRadius:m});n.push(b);const k=d0({Manifold:e,width:d,height:f,thickness:w,borderRadius:m}).translate([0,0,i/2+My+w/2]),x=d0({Manifold:e,width:d,height:f,thickness:w,borderRadius:m}).translate([0,0,-i/2-My-w/2]);n.push(k,x);const N=e.cylinder(i*.8,D,D,VB,!0).translate([E,h,0]);n.push(N);const R=e.union([b,k,x,N]);n.push(R);const U=e.cylinder(i*1.2,Math.max(D-Ln,.01),Math.max(D-Ln,.01),VB,!0).translate([E,h,0]);n.push(U);const T=R.subtract(U);n.push(T);const Y=T.translate([C.x,C.y,0]);n.push(Y);let O=Y;if(o){const X=e.intersection([Y,o]);n.push(X),O=X}g.push(O);const W=ID(O.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:W,color:$F})}});let B;return g.length>0&&(B=e.union(g),n.push(B)),{platedHoleBoardDrills:s,platedHoleCopperGeoms:a,platedHoleSubtractOp:B}}function rbe({Manifold:e,x:A,y:t,outerDiameter:i,holeDiameter:n,thickness:o,zOffset:s=.001,segments:r=32}){const a=s,g=s;if(i<n)throw new Error(`Invalid via geometry: outerDiameter (${i}) must be >= holeDiameter (${n})`);const c=Math.min(i/2,n/2+g),I=e.cylinder(o,c,-1,r,!0),l=e.cylinder(a,i/2,-1,r,!0).translate([0,0,o/2]),B=e.cylinder(a,i/2,-1,r,!0).translate([0,0,-o/2]),C=e.union([I,l,B]),Q=o+a*2,E=e.cylinder(Q,n/2,-1,r,!0);return C.subtract(E).translate([A,t,0])}var abe=new Oi(...pr.copper);function gbe(e,A,t,i,n){const o=[],s=Ji(A).pcb_via.list(),r=[];return s.forEach((a,g)=>{if(typeof a.hole_diameter=="number"){const c=e6A({Manifold:e,x:a.x,y:a.y,holeDiameter:a.hole_diameter,thickness:t,zOffset:rf,segments:VB});i.push(c),o.push(c)}if(typeof a.outer_diameter=="number"&&typeof a.hole_diameter=="number"){const c=rbe({Manifold:e,x:a.x,y:a.y,outerDiameter:a.outer_diameter,holeDiameter:a.hole_diameter,thickness:t,zOffset:rf,segments:VB});i.push(c);let I=c;if(n){const B=e.intersection([c,n]);i.push(B),I=B}const l=ID(I.getMesh());r.push({key:`via-${a.pcb_via_id||g}`,geometry:l,color:abe})}}),{viaBoardDrills:o,viaCopperGeoms:r}}var cbe=(e,A,t)=>{const[i,n]=AA.useState(null),[o,s]=AA.useState(null),[r,a]=AA.useState(null),[g,c]=AA.useState(!0),I=AA.useRef([]),l=AA.useMemo(()=>{const E=A.filter(d=>d.type==="pcb_panel"),h=Ji(A).pcb_board.list();if(E.length>0){const d=E[0],f=h.find(m=>m.pcb_panel_id===d.pcb_panel_id);return{type:"pcb_board",pcb_board_id:d.pcb_panel_id,center:d.center,width:d.width,height:d.height,thickness:f?.thickness??1.4,material:f?.material??"fr4",num_layers:f?.num_layers??2}}const u=h.filter(d=>!d.pcb_panel_id);return u.length>0?u[0]:null},[A]),B=AA.useMemo(()=>{const E=Ji(A).pcb_board.list();return E.length>0&&E[0].pcb_board_id==="faux-board"},[A]),C=AA.useMemo(()=>l?$XA(l,av):av,[l]);AA.useEffect(()=>{if(!e||!l){n(null),s(null),c(!1);return}if((l.width===0||!l.width)&&(l.height===0||!l.height)&&(!l.outline||l.outline.length<3)){n({platedHoles:[],vias:[]}),s(l.thickness??0),c(!1);return}c(!0),a(null);const E=e.Manifold,h=e.CrossSection,u=m=>{if(!(!m||typeof m.delete!="function"))try{m.delete()}catch(w){(!(w instanceof Error)||!w.message?.includes("Manifold instance already deleted"))&&console.warn("Failed to delete Manifold instance",w)}};I.current.forEach(u),I.current=[];let d=null;const f={};try{const m=l.thickness||1.4;s(m);const{boardOp:w,outlineCrossSection:D}=tbe(E,h,l,m,I.current);let b=w;const x=m+2*1;let N=null;const R=.01;if(D){let oA=D;if(R>0){const CA=D.offset(R);I.current.push(CA),oA=CA}const rA=E.extrude(oA,x,void 0,void 0,void 0,!0);I.current.push(rA),N=rA}else{const oA=(l.width||0)+2*R,rA=(l.height||0)+2*R,CA=E.cube([oA,rA,x],!0);I.current.push(CA);const SA=CA.translate([l.center.x,l.center.y,0]);I.current.push(SA),N=SA}const U=[];let T=null;const{nonPlatedHoleBoardDrills:Y}=obe(E,h,A,m,I.current);U.push(...Y);const{platedHoleBoardDrills:O,platedHoleCopperGeoms:W,platedHoleSubtractOp:X}=sbe(E,h,A,m,I.current,N);U.push(...O),f.platedHoles=W;const{viaBoardDrills:iA,viaCopperGeoms:aA}=gbe(E,A,m,I.current,N);if(U.push(...iA),f.vias=aA,U.length>0){T=E.union(U),I.current.push(T);const oA=X?E.union([T,X]):T;I.current.push(oA);const rA=b.subtract(oA);if(I.current.push(rA),b=rA,X){const CA=X.subtract(T);I.current.push(CA);const SA=CA.getMesh(),MA=ID(SA);f.platedHoles=[{key:"plated-holes-union",geometry:MA,color:new Oi(pr.copper[0],pr.copper[1],pr.copper[2])}]}}const{cutoutOps:tA}=nbe(E,h,A,m,I.current);if(tA.length>0){const oA=E.union(tA);I.current.push(oA);const rA=b.subtract(oA);I.current.push(rA),b=rA}if(d=b,d){const oA=d.getMesh(),rA=ID(oA),CA=FEA[l.material]??pr.fr4Tan;f.board={geometry:rA,color:new Oi(CA[0],CA[1],CA[2]),material:l.material,isFaux:B}}n(f)}catch(m){console.error("Error processing geometry with Manifold in hook:",m),a(m.message||"An unknown error occurred while processing geometry in hook."),n(null)}finally{c(!1)}return()=>{I.current.forEach(u),I.current=[]}},[e,A,l]);const Q=AA.useMemo(()=>!l||!C?null:zXA({circuitJson:A,boardData:l,traceTextureResolution:C,visibility:t}),[A,l,C,t]);return{geoms:i,textures:Q,pcbThickness:o,error:r,isLoading:g,boardData:l,isFauxBoard:B}},Ibe=WB,lbe=({material:e,color:A,side:t=Ibe,isFaux:i=!1})=>e==="fr4"?new Fm({color:A,side:t,metalness:0,roughness:.8,specularIntensity:.2,ior:1.45,sheen:0,clearcoat:0,transparent:i,opacity:i?QW:1,flatShading:!0,polygonOffset:!0,polygonOffsetFactor:1,polygonOffsetUnits:1}):new dh({color:A,side:t,flatShading:!0,metalness:.1,roughness:.8,transparent:!0,opacity:i?QW:.9,polygonOffset:!0,polygonOffsetFactor:1,polygonOffsetUnits:1});function Bbe(e){const A=[];if(!e)return A;if(e.board&&e.board.geometry){const i=new Ao(e.board.geometry,lbe({material:e.board.material,color:e.board.color,side:WB,isFaux:e.board.isFaux}));i.name="board-geom",A.push(i)}const t=i=>{i&&i.forEach(n=>{const o=new Ao(n.geometry,new dh({color:n.color,side:WB,flatShading:!0}));o.name=n.key,A.push(o)})};return t(e.platedHoles),t(e.vias),A}var Cbe=({geometryMeshes:e,textureMeshes:A})=>{const{rootObject:t}=Lu(),{visibility:i}=jF(),n=o=>{o.geometry.dispose();const s=Array.isArray(o.material)?o.material:[o.material];for(const r of s){if(!r)continue;const a=["map","alphaMap","aoMap","bumpMap","displacementMap","emissiveMap","lightMap","metalnessMap","normalMap","roughnessMap","specularMap"],g=r;for(const c of a){const I=g[c];I&&I instanceof Hc&&(I.dispose(),g[c]=null)}r.dispose()}};return AA.useEffect(()=>{if(t)return e.forEach(o=>{let s=!0;o.name==="board-geom"?s=i.boardBody:(o.name.includes("plated_hole")||o.name.includes("via"))&&(s=i.topCopper||i.bottomCopper),s&&t.add(o)}),A.forEach(o=>{t.add(o)}),()=>{e.forEach(o=>{o.parent===t&&t.remove(o)}),A.forEach(o=>{o.parent===t&&t.remove(o),n(o)})}},[t,e,A,i]),null},Qbe="https://cdn.jsdelivr.net/npm/manifold-3d@3.2.1",Ebe=({circuitJson:e,autoRotateDisabled:A,clickToInteractEnabled:t,onUserInteraction:i,children:n,onCameraControllerReady:o,resolveStaticAsset:s})=>{const r=MXA(n),a=AA.useMemo(()=>A6A(e??r),[e,r]),[g,c]=AA.useState(null),[I,l]=AA.useState(null),{visibility:B}=jF();AA.useEffect(()=>{if(window.ManifoldModule&&typeof window.ManifoldModule=="object"&&window.ManifoldModule.setup){c(window.ManifoldModule);return}const N=async W=>{try{const X=await W();X.setup(),window.ManifoldModule=X,c(X)}catch(X){console.error("Failed to initialize Manifold:",X),l(`Failed to initialize Manifold: ${X instanceof Error?X.message:"Unknown error"}`)}},R=window.ManifoldModule??window.MANIFOLD??window.MANIFOLD_MODULE;if(R){window.ManifoldModule=R,N(window.ManifoldModule);return}const U="manifoldLoaded",T=()=>{const W=window.ManifoldModule??window.MANIFOLD??window.MANIFOLD_MODULE;if(W)window.ManifoldModule=W,N(window.ManifoldModule);else{const X="ManifoldModule not found on window after script load.";console.error(X),l(X)}};window.addEventListener(U,T,{once:!0});const Y=document.createElement("script");Y.type="module",Y.innerHTML=`
|
|
5175
|
+
at `+s}return A},dW.buildMessage=function(e,A){var t={literal:function(g){return'"'+n(g.text)+'"'},class:function(g){var c=g.parts.map(function(I){return Array.isArray(I)?o(I[0])+"-"+o(I[1]):o(I)});return"["+(g.inverted?"^":"")+c.join("")+"]"},any:function(){return"any character"},end:function(){return"end of input"},other:function(g){return g.description}};function i(g){return g.charCodeAt(0).toString(16).toUpperCase()}function n(g){return g.replace(/\\/g,"\\\\").replace(/"/g,'\\"').replace(/\0/g,"\\0").replace(/\t/g,"\\t").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/[\x00-\x0F]/g,function(c){return"\\x0"+i(c)}).replace(/[\x10-\x1F\x7F-\x9F]/g,function(c){return"\\x"+i(c)})}function o(g){return g.replace(/\\/g,"\\\\").replace(/\]/g,"\\]").replace(/\^/g,"\\^").replace(/-/g,"\\-").replace(/\0/g,"\\0").replace(/\t/g,"\\t").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/[\x00-\x0F]/g,function(c){return"\\x0"+i(c)}).replace(/[\x10-\x1F\x7F-\x9F]/g,function(c){return"\\x"+i(c)})}function s(g){return t[g.type](g)}function r(g){var c=g.map(s),I,l;if(c.sort(),c.length>0){for(I=1,l=1;I<c.length;I++)c[I-1]!==c[I]&&(c[l]=c[I],l++);c.length=l}switch(c.length){case 1:return c[0];case 2:return c[0]+" or "+c[1];default:return c.slice(0,-1).join(", ")+", or "+c[c.length-1]}}function a(g){return g?'"'+n(g)+'"':"end of input"}return"Expected "+r(e)+" but "+a(A)+" found."};var pSe=e=>{if(e.length===0)return null;let A=e[0].x,t=e[0].y,i=e[0].x,n=e[0].y;for(let o=1;o<e.length;o++){const s=e[o];s.x<A&&(A=s.x),s.y<t&&(t=s.y),s.x>i&&(i=s.x),s.y>n&&(n=s.y)}return{minX:A,minY:t,maxX:i,maxY:n}};function cD(e){if(e.outline&&e.outline.length>=3){const s=pSe(e.outline);return{...s,width:s.maxX-s.minX,height:s.maxY-s.minY,centerX:(s.minX+s.maxX)/2,centerY:(s.minY+s.maxY)/2}}const A=e.width??0,t=e.height??0,i=e.center?.x??0,n=e.center?.y??0;return{...{minX:i-A/2,maxX:i+A/2,minY:n-t/2,maxY:n+t/2},width:A,height:t,centerX:i,centerY:n}}function pW(e,A){if(e===void 0)return A;if(typeof e=="number")return e;const t=parseFloat(e.replace(/mm$/,""));return isNaN(t)?A:t}function fSe(e){return e.layer==="bottom"?e.is_mirrored!==!1:e.is_mirrored===!0}function ySe(e){const A=e.flat();if(A.length===0)return{minX:0,maxX:0,minY:0,maxY:0,width:0,height:0,centerX:0,centerY:0};const t=Math.min(...A.map(s=>s[0])),i=Math.max(...A.map(s=>s[0])),n=Math.min(...A.map(s=>s[1])),o=Math.max(...A.map(s=>s[1]));return{minX:t,maxX:i,minY:n,maxY:o,width:i-t,height:o-n,centerX:(t+i)/2,centerY:(n+o)/2}}function mSe(e){const A=[];return e.forEach(t=>{t.length===29?(A.push(t.slice(0,15)),A.push(t.slice(14,29))):t.length===17?(A.push(t.slice(0,10)),A.push(t.slice(9,17))):A.push(t)}),A}function wSe(e,A){let t=-e.centerX,i=-e.centerY;return A.includes("left")?t=-e.minX:A.includes("right")&&(t=-e.maxX),A.includes("top")?i=-e.maxY:A.includes("bottom")&&(i=-e.minY),{x:t,y:i}}function DSe(e,A){const t=[];let i=e.ccw_rotation??0;if(fSe(e)&&(t.push(w_(A.centerX,A.centerY),{a:-1,b:0,c:0,d:1,e:0,f:0},w_(-A.centerX,-A.centerY)),i=-i),i){const s=i*Math.PI/180;t.push(w_(A.centerX,A.centerY),KXA(s),w_(-A.centerX,-A.centerY))}return{matrix:t.length>0?TXA(...t):void 0,rotationDeg:i}}function PXA(e,A,t,i,n,o,s){A.forEach(r=>{e.beginPath(),r.forEach((a,g)=>{let c={x:a[0],y:a[1]};t&&(c=YXA(t,c));const I=c.x+i.x+n.x,l=c.y+i.y+n.y,B=o(I),C=s(l);g===0?e.moveTo(B,C):e.lineTo(B,C)}),e.stroke()})}function SSe(e,A,t,i,n,o){e.save(),e.translate(A,t),e.rotate(-o),e.fillRect(-i/2,-n/2,i,n),e.restore()}function bSe(e,A,t,i,n,o,s,r,a,g){const c=typeof A.font_size=="number"?A.font_size:.2,I={left:pW(A.knockout_padding?.left,c*.5),right:pW(A.knockout_padding?.right,c*.5),top:pW(A.knockout_padding?.top,c*.3),bottom:pW(A.knockout_padding?.bottom,c*.3)},l=i.width+I.left+I.right,B=i.height+I.top+I.bottom,C=s(A.anchor_position.x),Q=r(A.anchor_position.y),E=l*a,h=B*a;e.fillStyle=g;const u=o*Math.PI/180;SSe(e,C,Q,E,h,u);const d={x:-i.centerX,y:-i.centerY};e.globalCompositeOperation="destination-out",PXA(e,t,n,d,A.anchor_position,s,r),e.globalCompositeOperation="source-over"}function xSe({layer:e,circuitJson:A,boardData:t,copperColor:i="rgb(230, 153, 51)",traceTextureResolution:n}){const s=A.filter(Q=>Q.type==="pcb_copper_text").filter(Q=>Q.layer===e);if(s.length===0)return null;const r=cD(t),a=document.createElement("canvas"),g=Math.floor(r.width*n),c=Math.floor(r.height*n);a.width=g,a.height=c;const I=a.getContext("2d");if(!I)return null;e==="bottom"&&(I.translate(0,c),I.scale(1,-1)),I.strokeStyle=i,I.fillStyle=i;const l=Q=>(Q-r.minX)*n,B=Q=>(r.maxY-Q)*n;s.forEach(Q=>{const E=typeof Q.font_size=="number"?Q.font_size:.2,h=Math.max(.02,E*.08)*n;I.lineWidth=h,I.lineCap="round",I.lineJoin="round";const u=(0,ESe.vectorText)({height:E*.45,input:Q.text}),d=mSe(u),f=ySe(d),{matrix:m,rotationDeg:w}=DSe(Q,f);if(Q.is_knockout)bSe(I,Q,d,f,m,w,l,B,n,i);else{const D=Q.anchor_alignment||"center",b=wSe(f,D);PXA(I,d,m,b,Q.anchor_position,l,B)}});const C=new kx(a);return C.generateMipmaps=!0,C.minFilter=hh,C.magFilter=uI,C.anisotropy=16,C.needsUpdate=!0,C}function _Se({layer:e,circuitJson:A,boardData:t,copperColor:i,traceTextureResolution:n}){const s=Ji(A).pcb_smtpad.list().filter(Q=>Q.layer===e);if(s.length===0)return null;const r=cD(t),a=document.createElement("canvas"),g=Math.floor(r.width*n),c=Math.floor(r.height*n);a.width=g,a.height=c;const I=a.getContext("2d");if(!I)return null;e==="bottom"&&(I.translate(0,c),I.scale(1,-1));const l=Q=>(Q-r.minX)*n,B=Q=>(r.maxY-Q)*n;I.fillStyle=i,s.forEach(Q=>{if(Q.shape==="polygon"&&Q.points){I.beginPath(),Q.points.forEach((f,m)=>{const w=l(f.x),D=B(f.y);m===0?I.moveTo(w,D):I.lineTo(w,D)}),I.closePath(),I.fill();return}if(Q.x===void 0||Q.y===void 0)return;const E=Q.x,h=Q.y,u=l(E),d=B(h);if(Q.shape==="rect"){const f=Q.width*n,m=Q.height*n,w=Gy(Q),D=zF(Q.width,Q.height,w)*n;D>0?(I.beginPath(),I.roundRect(u-f/2,d-m/2,f,m,D),I.fill()):I.fillRect(u-f/2,d-m/2,f,m)}else if(Q.shape==="circle"){const f=(Q.radius??Q.width/2)*n;I.beginPath(),I.arc(u,d,f,0,2*Math.PI),I.fill()}else if(Q.shape==="pill"||Q.shape==="rotated_pill"){const f=Q.width*n,m=Q.height*n,w=Math.min(f,m)/2,b=-(Q.ccw_rotation||0)*(Math.PI/180);b?(I.save(),I.translate(u,d),I.rotate(b),I.beginPath(),I.roundRect(-f/2,-m/2,f,m,w),I.fill(),I.restore()):(I.beginPath(),I.roundRect(u-f/2,d-m/2,f,m,w),I.fill())}else if(Q.shape==="rotated_rect"){const f=Q.width*n,m=Q.height*n,w=Gy(Q),D=zF(Q.width,Q.height,w)*n,k=-(Q.ccw_rotation||0)*(Math.PI/180);I.save(),I.translate(u,d),I.rotate(k),I.beginPath(),I.roundRect(-f/2,-m/2,f,m,D),I.fill(),I.restore()}});const C=new kx(a);return C.generateMipmaps=!0,C.minFilter=hh,C.magFilter=uI,C.anisotropy=16,C.needsUpdate=!0,C}function kSe({layer:e,circuitJson:A,panelData:t,outlineColor:i="black",traceTextureResolution:n}){const o=Ji(A).pcb_board.list().filter(B=>B.pcb_panel_id===t.pcb_board_id);if(o.length===0)return null;const s=document.createElement("canvas"),r=Math.floor(t.width*n),a=Math.floor(t.height*n);s.width=r,s.height=a;const g=s.getContext("2d");if(!g)return null;e==="bottom"&&(g.translate(0,a),g.scale(1,-1)),g.strokeStyle=i,g.lineWidth=.05*n;const c=B=>(B-t.center.x+t.width/2)*n,I=B=>(-(B-t.center.y)+t.height/2)*n;o.forEach(B=>{if(B.outline&&B.outline.length>=2)g.beginPath(),B.outline.forEach((C,Q)=>{const E=c(C.x),h=I(C.y);Q===0?g.moveTo(E,h):g.lineTo(E,h)}),g.closePath(),g.stroke();else{const C=B.width,Q=B.height,{x:E,y:h}=B.center,u=c(E-C/2),d=I(h+Q/2);g.strokeRect(u,d,C*n,Q*n)}});const l=new kx(s);return l.generateMipmaps=!0,l.minFilter=hh,l.magFilter=uI,l.anisotropy=16,l.needsUpdate=!0,l}var FSe=Kr(VQA()),qXA=25.4,GSe=qXA/1e3,MSe=/^\s*(-?\d*(?:\.\d+)?)(?:\s*(mm|mil|inch|in|"))?\s*$/i;function RSe(e){if(!e)return;const A=e.trim().toLowerCase();return A==='"'||A==="inch"?"in":A}function FQ(e){if(e==null)return;if(typeof e=="number")return Number.isFinite(e)?e:void 0;if(typeof e!="string")return;const A=e.trim();if(A.length===0)return;const t=A.match(MSe);if(!t){const r=Number.parseFloat(A);return Number.isFinite(r)?r:void 0}const[,i,n]=t,o=Number.parseFloat(i||"0");if(!Number.isFinite(o))return;switch(RSe(n)){case"mil":return o*GSe;case"in":return o*qXA;case"mm":case void 0:return o;default:return o}}function Vm(e,A){const t=FQ(e);return t===void 0?A:t}function OXA(e){let A=e;if(A.startsWith("#")&&(A=A.slice(1)),A.length===6){const t=parseInt(A.slice(0,2),16),i=parseInt(A.slice(2,4),16),n=parseInt(A.slice(4,6),16);return`rgb(${t}, ${i}, ${n})`}return e.startsWith("rgb")?e:"rgb(255, 243, 204)"}function NSe({layer:e,circuitJson:A,boardData:t,silkscreenColor:i="rgb(255,255,255)",traceTextureResolution:n}){const o=Ji(A).pcb_silkscreen_text.list(),s=Ji(A).pcb_silkscreen_path.list(),r=Ji(A).pcb_silkscreen_line.list(),a=Ji(A).pcb_silkscreen_rect.list(),g=Ji(A).pcb_silkscreen_circle.list(),c=Ji(A).pcb_fabrication_note_rect.list(),I=Ji(A).pcb_note_line.list(),l=o.filter(N=>N.layer===e),B=s.filter(N=>N.layer===e),C=r.filter(N=>N.layer===e),Q=a.filter(N=>N.layer===e),E=g.filter(N=>N.layer===e),h=c.filter(N=>N.layer===e),u=I.filter(N=>N.layer===e);if(l.length===0&&B.length===0&&C.length===0&&Q.length===0&&E.length===0&&h.length===0&&u.length===0)return null;const d=cD(t),f=document.createElement("canvas"),m=Math.floor(d.width*n),w=Math.floor(d.height*n);f.width=m,f.height=w;const D=f.getContext("2d");if(!D)return null;e==="bottom"&&(D.translate(0,w),D.scale(1,-1)),D.strokeStyle=i,D.fillStyle=i;const b=N=>(N-d.minX)*n,k=N=>(d.maxY-N)*n;C.forEach(N=>{const R=FQ(N.x1)??0,U=FQ(N.y1)??0,T=FQ(N.x2)??0,Y=FQ(N.y2)??0;R===T&&U===Y||(D.beginPath(),D.lineWidth=Vm(N.stroke_width,.1)*n,D.lineCap="round",D.moveTo(b(R),k(U)),D.lineTo(b(T),k(Y)),D.stroke())}),u.forEach(N=>{const R=FQ(N.x1)??0,U=FQ(N.y1)??0,T=FQ(N.x2)??0,Y=FQ(N.y2)??0;if(R===T&&U===Y)return;D.save();let O=i;N.color?O=OXA(N.color):O="rgb(255, 243, 204)",D.strokeStyle=O,D.beginPath(),D.lineWidth=Vm(N.stroke_width,.1)*n,D.lineCap="round";const W=N.is_dashed??!1;if(W){const X=Math.max(D.lineWidth*2,1);D.setLineDash([X,X])}D.moveTo(b(R),k(U)),D.lineTo(b(T),k(Y)),D.stroke(),W&&D.setLineDash([]),D.restore()}),B.forEach(N=>{N.route.length<2||(D.beginPath(),D.lineWidth=Vm(N.stroke_width,.1)*n,D.lineCap="round",D.lineJoin="round",N.route.forEach((R,U)=>{const T=b(FQ(R.x)??0),Y=k(FQ(R.y)??0);U===0?D.moveTo(T,Y):D.lineTo(T,Y)}),D.stroke())}),E.forEach(N=>{const R=Vm(N.radius,0);if(R<=0)return;const U=Vm(N.stroke_width,.12),T=U>0,Y=FQ(N.center?.x)??0,O=FQ(N.center?.y)??0,W=b(Y),X=k(O),iA=R*n;if(D.save(),D.translate(W,X),T){const aA=iA+U/2*n,tA=Math.max(0,iA-U/2*n);tA>0?(D.beginPath(),D.arc(0,0,aA,0,2*Math.PI),D.arc(0,0,tA,0,2*Math.PI,!0),D.fill("evenodd")):(D.beginPath(),D.arc(0,0,aA,0,2*Math.PI),D.fill())}else D.beginPath(),D.arc(0,0,iA,0,2*Math.PI),D.fill();D.restore()}),Q.forEach(N=>{const R=Vm(N.width,0),U=Vm(N.height,0);if(R<=0||U<=0)return;const T=FQ(N.center?.x)??0,Y=FQ(N.center?.y)??0,O=b(T),W=k(Y),X=Gy(N),iA=typeof X=="string"?FQ(X):X,aA=zF(R,U,iA);D.save(),D.translate(O,W);const tA=R/2*n,oA=U/2*n,rA=Math.min(aA*n,tA,oA),CA=N.stroke_width??!1,SA=N.is_filled??!0,MA=N.is_stroke_dashed??!1,GA=CA?Vm(N.stroke_width,.1)*n:0;if(((hA,kA,dA,qA,ZA)=>{if(D.beginPath(),ZA<=0)D.rect(hA,kA,dA,qA);else{const rt=ZA,yA=hA+dA,$A=kA+qA;D.moveTo(hA+rt,kA),D.lineTo(yA-rt,kA),D.quadraticCurveTo(yA,kA,yA,kA+rt),D.lineTo(yA,$A-rt),D.quadraticCurveTo(yA,$A,yA-rt,$A),D.lineTo(hA+rt,$A),D.quadraticCurveTo(hA,$A,hA,$A-rt),D.lineTo(hA,kA+rt),D.quadraticCurveTo(hA,kA,hA+rt,kA),D.closePath()}})(-tA,-oA,tA*2,oA*2,rA),SA&&D.fill(),CA&&GA>0){if(D.lineWidth=GA,MA){const hA=Math.max(GA*2,1);D.setLineDash([hA,hA])}D.stroke(),MA&&D.setLineDash([])}D.restore()}),h.forEach(N=>{const R=Vm(N.width,0),U=Vm(N.height,0);if(R<=0||U<=0)return;const T=FQ(N.center?.x)??0,Y=FQ(N.center?.y)??0,O=b(T),W=k(Y),X=Gy(N),iA=typeof X=="string"?FQ(X):X,aA=zF(R,U,iA);D.save(),D.translate(O,W);const tA=R/2*n,oA=U/2*n,rA=Math.min(aA*n,tA,oA),CA=N.has_stroke??!1,SA=N.is_filled??!0,MA=N.is_stroke_dashed??!1,GA=CA?Vm(N.stroke_width,.1)*n:0;let TA=i,hA=i;if(N.color){const dA=OXA(N.color);TA=dA,hA=dA}else TA="rgb(255, 243, 204)",hA="rgb(255, 243, 204)";if(((dA,qA,ZA,rt,yA)=>{if(D.beginPath(),yA<=0)D.rect(dA,qA,ZA,rt);else{const $A=yA,KA=dA+ZA,HA=qA+rt;D.moveTo(dA+$A,qA),D.lineTo(KA-$A,qA),D.quadraticCurveTo(KA,qA,KA,qA+$A),D.lineTo(KA,HA-$A),D.quadraticCurveTo(KA,HA,KA-$A,HA),D.lineTo(dA+$A,HA),D.quadraticCurveTo(dA,HA,dA,HA-$A),D.lineTo(dA,qA+$A),D.quadraticCurveTo(dA,qA,dA+$A,qA),D.closePath()}})(-tA,-oA,tA*2,oA*2,rA),SA&&(D.fillStyle=TA,D.fill()),CA&&GA>0){if(D.strokeStyle=hA,D.lineWidth=GA,MA){const dA=Math.max(GA*2,1);D.setLineDash([dA,dA])}D.stroke(),MA&&D.setLineDash([])}D.restore()}),l.forEach(N=>{const R=N.font_size||.25,U=Math.min(Math.max(.01,R*.1),R*.05)*n;D.lineWidth=U,D.lineCap="butt",D.lineJoin="miter";const T=(0,FSe.vectorText)({height:R*.45,input:N.text}),Y=[];T.forEach(MA=>{MA.length===29?(Y.push(MA.slice(0,15)),Y.push(MA.slice(14,29))):MA.length===17?(Y.push(MA.slice(0,10)),Y.push(MA.slice(9,17))):Y.push(MA)});const O=Y.flat(),W={minX:O.length>0?Math.min(...O.map(MA=>MA[0])):0,maxX:O.length>0?Math.max(...O.map(MA=>MA[0])):0,minY:O.length>0?Math.min(...O.map(MA=>MA[1])):0,maxY:O.length>0?Math.max(...O.map(MA=>MA[1])):0},X=(W.minX+W.maxX)/2,iA=(W.minY+W.maxY)/2;let aA=-X,tA=-iA;const oA=N.anchor_alignment||"center";oA.includes("left")?aA=-W.minX:oA.includes("right")&&(aA=-W.maxX),oA.includes("top")?tA=-W.maxY:oA.includes("bottom")&&(tA=-W.minY);const rA=[];let CA=N.ccw_rotation??0;if(N.layer==="bottom"&&(rA.push(w_(X,iA),{a:-1,b:0,c:0,d:1,e:0,f:0},w_(-X,-iA)),CA=-CA),CA){const MA=CA*Math.PI/180;rA.push(w_(X,iA),KXA(MA),w_(-X,-iA))}const SA=rA.length>0?TXA(...rA):void 0;Y.forEach(MA=>{D.beginPath(),MA.forEach((GA,TA)=>{let hA={x:GA[0],y:GA[1]};SA&&(hA=YXA(SA,hA));const kA=hA.x+aA+N.anchor_position.x,dA=hA.y+tA+N.anchor_position.y,qA=b(kA),ZA=k(dA);TA===0?D.moveTo(qA,ZA):D.lineTo(qA,ZA)}),D.stroke()})});const x=new kx(f);return x.generateMipmaps=!0,x.minFilter=hh,x.magFilter=uI,x.anisotropy=16,x.needsUpdate=!0,x}function WXA(e){return e&&e.route_type==="wire"&&typeof e.layer=="string"&&typeof e.width=="number"}function vSe({layer:e,circuitJson:A,boardData:t,traceColor:i,traceTextureResolution:n}){const o=Ji(A).pcb_trace.list(),s=Ji(A).pcb_via.list(),r=Ji(A).pcb_plated_hole.list(),a=o.filter(Q=>Q.route.some(E=>WXA(E)&&E.layer===e));if(a.length===0)return null;const g=cD(t),c=document.createElement("canvas"),I=Math.floor(g.width*n),l=Math.floor(g.height*n);c.width=I,c.height=l;const B=c.getContext("2d");if(!B)return null;e==="bottom"&&(B.translate(0,l),B.scale(1,-1)),a.forEach(Q=>{let E=!0;B.beginPath(),B.strokeStyle=i,B.lineCap="round",B.lineJoin="round";let h=0;for(const u of Q.route){if(!WXA(u)||u.layer!==e){E||B.stroke(),E=!0;continue}const d=u.x,f=u.y;h=u.width*n,B.lineWidth=h;const m=(d-g.minX)*n,w=(g.maxY-f)*n;E?(B.moveTo(m,w),E=!1):B.lineTo(m,w)}E||B.stroke()}),B.globalCompositeOperation="destination-out",B.fillStyle="black",s.forEach(Q=>{const E=(Q.x-g.minX)*n,h=(g.maxY-Q.y)*n,u=Q.outer_diameter/2*n;B.beginPath(),B.arc(E,h,u,0,2*Math.PI,!1),B.fill()}),r.forEach(Q=>{if(Q.layers.includes(e)&&Q.shape==="circle"){const E=(Q.x-g.minX)*n,h=(g.maxY-Q.y)*n,u=Q.outer_diameter/2*n;B.beginPath(),B.arc(E,h,u,0,2*Math.PI,!1),B.fill()}else if(Q.layers.includes(e)&&Q.shape==="rotated_pill_hole_with_rect_pad"){const E=(Q.x-g.minX)*n,h=(g.maxY-Q.y)*n,u=(Q.rect_pad_width??Q.hole_width??0)*n,d=(Q.rect_pad_height??Q.hole_height??0)*n,m=-(Q.rect_ccw_rotation||0);m?(B.save(),B.translate(E,h),B.rotate(m*Math.PI/180),B.beginPath(),B.rect(-u/2,-d/2,u,d),B.fill(),B.restore()):(B.beginPath(),B.rect(E-u/2,h-d/2,u,d),B.fill())}}),B.globalCompositeOperation="source-over";const C=new kx(c);return C.generateMipmaps=!0,C.minFilter=hh,C.magFilter=uI,C.anisotropy=16,C.needsUpdate=!0,C}Kr(d_()),Kr(VN());function LSe(e,A,t,i){if(!t||Math.abs(t)<1e-9)return[];const n=4*Math.atan(t),o=A[0]-e[0],s=A[1]-e[1],r=Math.sqrt(o*o+s*s);if(r<1e-9)return[];const a=Math.abs(r/(2*Math.sin(n/2))),g=Math.sqrt(Math.max(0,a*a-r/2*(r/2))),c=[(e[0]+A[0])/2,(e[1]+A[1])/2],I=o/r,B=-(s/r),C=I,Q=c[0]+B*g*Math.sign(t),E=c[1]+C*g*Math.sign(t),h=Math.atan2(e[1]-E,e[0]-Q),u=[],d=Math.max(2,Math.ceil(i*Math.abs(n)/(Math.PI*2)*4)),f=n/d;for(let m=1;m<d;m++){const w=h+f*m;u.push([Q+a*Math.cos(w),E+a*Math.sin(w)])}return u}function ZXA(e,A){const t=[],i=e.vertices;for(let n=0;n<i.length;n++){const o=i[n],s=i[(n+1)%i.length];if(t.push([o.x,o.y]),o.bulge){const r=LSe([o.x,o.y],[s.x,s.y],o.bulge,A);t.push(...r)}}return t}function VXA({ctx:e,points:A,canvasXFromPcb:t,canvasYFromPcb:i}){A.length<3||(e.beginPath(),A.forEach((n,o)=>{const s=t(n[0]),r=i(n[1]);o===0?e.moveTo(s,r):e.lineTo(s,r)}),e.closePath(),e.fill())}function USe({ctx:e,pour:A,canvasXFromPcb:t,canvasYFromPcb:i}){const n=A.brep_shape;if(!n||!n.outer_ring)return;const o=ZXA(n.outer_ring,32);if(o.length>=3&&VXA({ctx:e,points:o,canvasXFromPcb:t,canvasYFromPcb:i}),n.inner_rings&&n.inner_rings.length>0){e.globalCompositeOperation="destination-out";for(const s of n.inner_rings){const r=ZXA(s,32);r.length>=3&&VXA({ctx:e,points:r,canvasXFromPcb:t,canvasYFromPcb:i})}e.globalCompositeOperation="source-over"}}function HSe({layer:e,circuitJson:A,boardData:t,traceTextureResolution:i=av}){const n=A.filter(h=>h.type==="pcb_copper_pour"),o=e==="top"?"top_copper":"bottom_copper",s=n.filter(h=>h.layer===e);if(s.length===0)return null;const r=cD(t),a=document.createElement("canvas"),g=Math.floor(r.width*i),c=Math.floor(r.height*i);a.width=g,a.height=c;const I=a.getContext("2d");if(!I)return null;e==="bottom"&&(I.translate(0,c),I.scale(1,-1));const l=h=>(h-r.minX)*i,B=h=>(r.maxY-h)*i,C=s.filter(h=>h.shape==="rect"||h.shape==="polygon"),Q=s.filter(h=>h.shape==="brep");if(C.length>0){const h=new bQA(I);h.setCameraBounds({minX:r.minX,maxX:r.maxX,minY:r.minY,maxY:r.maxY});const u=C.filter(w=>w.covered_with_solder_mask!==!1),d=C.filter(w=>w.covered_with_solder_mask===!1),f=`rgb(${pr.fr4TracesWithMaskGreen.map(w=>w*255).join(",")})`,m=`rgb(${pr.copper.map(w=>w*255).join(",")})`;u.length>0&&(h.configure({colorOverrides:{copper:{top:f,bottom:f,inner1:f,inner2:f,inner3:f,inner4:f,inner5:f,inner6:f}}}),h.drawElements(u,{layers:[o]})),d.length>0&&(h.configure({colorOverrides:{copper:{top:m,bottom:m,inner1:m,inner2:m,inner3:m,inner4:m,inner5:m,inner6:m}}}),h.drawElements(d,{layers:[o]}))}for(const h of Q){const d=h.covered_with_solder_mask!==!1?pr.fr4TracesWithMaskGreen:pr.copper,f=`rgb(${d[0]*255}, ${d[1]*255}, ${d[2]*255})`;I.fillStyle=f,USe({ctx:I,pour:h,canvasXFromPcb:l,canvasYFromPcb:B})}const E=new kx(a);return E.generateMipmaps=!0,E.minFilter=hh,E.magFilter=uI,E.anisotropy=16,E.needsUpdate=!0,E}var fW=e=>{const[A=0,t=0,i=0]=e;return`rgb(${Math.round(A*255)}, ${Math.round(t*255)}, ${Math.round(i*255)})`},YSe=e=>{const A=fW(ODe[e]??pr.fr4SolderMaskGreen),t=fW(e==="fr1"?pr.fr1TracesWithMaskCopper:pr.fr4TracesWithMaskGreen);return{soldermask:A,soldermaskOverCopper:t,copper:fW(pr.copper),transparent:"rgba(0,0,0,0)"}},jXA=(e,A)=>{e.setCameraBounds({minX:A.minX,maxX:A.maxX,minY:A.minY,maxY:A.maxY})},JSe=({ctx:e,layer:A,bounds:t,elements:i,boardMaterial:n})=>{const o=YSe(n),s=A==="top"?"top_copper":"bottom_copper",r=new bQA(e);r.configure({colorOverrides:{copper:{top:o.transparent,bottom:o.transparent,inner1:o.transparent,inner2:o.transparent,inner3:o.transparent,inner4:o.transparent,inner5:o.transparent,inner6:o.transparent},drill:o.transparent,boardOutline:o.transparent,substrate:o.transparent,keepout:o.transparent,fabricationNote:o.transparent,silkscreen:{top:o.transparent,bottom:o.transparent},courtyard:{top:o.transparent,bottom:o.transparent},soldermask:{top:o.soldermask,bottom:o.soldermask},soldermaskWithCopperUnderneath:{top:o.soldermaskOverCopper,bottom:o.soldermaskOverCopper},soldermaskOverCopper:{top:o.soldermaskOverCopper,bottom:o.soldermaskOverCopper}}}),jXA(r,t),r.drawElements(i,{layers:[s],drawSoldermask:!0,drawSoldermaskTop:A==="top",drawSoldermaskBottom:A==="bottom"});const a=i.filter(g=>g.type==="pcb_copper_pour"&&g.layer===A&&g.covered_with_solder_mask===!1);if(a.length>0){e.save(),e.globalCompositeOperation="destination-out";const g=new bQA(e);g.configure({colorOverrides:{copper:{top:o.copper,bottom:o.copper,inner1:o.copper,inner2:o.copper,inner3:o.copper,inner4:o.copper,inner5:o.copper,inner6:o.copper}}}),jXA(g,t),g.drawElements(a,{layers:[s]}),e.restore()}},TSe=e=>({minX:e.center.x-e.width/2,maxX:e.center.x+e.width/2,minY:e.center.y-e.height/2,maxY:e.center.y+e.height/2,width:e.width,height:e.height,centerX:e.center.x,centerY:e.center.y}),KSe=(e,A)=>{const t=Math.min(e.minX,A.minX),i=Math.max(e.maxX,A.maxX),n=Math.min(e.minY,A.minY),o=Math.max(e.maxY,A.maxY);return{minX:t,maxX:i,minY:n,maxY:o,width:i-t,height:o-n,centerX:(t+i)/2,centerY:(n+o)/2}},PSe=(e,A)=>{const t=e.filter(s=>s.type==="pcb_panel"),i=e.filter(s=>s.type==="pcb_board"),n=t.find(s=>s.pcb_panel_id===A.pcb_board_id)??t[0];return n&&n.width>0&&n.height>0?TSe(n):(i.length>1?i:[A]).map(s=>cD(s)).reduce((s,r)=>KSe(s,r))};function qSe({layer:e,circuitJson:A,boardData:t,traceTextureResolution:i=av}){const n=PSe(A,t),o=Math.floor(n.width*i),s=Math.floor(n.height*i);if(o<=0||s<=0)return null;const r=document.createElement("canvas");r.width=o,r.height=s;const a=r.getContext("2d");if(!a)return null;e==="bottom"&&(a.translate(0,s),a.scale(1,-1));const g=A.some(I=>I.type==="pcb_board")?A:[t,...A];JSe({ctx:a,layer:e,bounds:n,elements:g,boardMaterial:t.material});const c=new kx(r);return c.generateMipmaps=!0,c.minFilter=hh,c.magFilter=uI,c.anisotropy=16,c.needsUpdate=!0,c}var vEA=e=>{const[A=0,t=0,i=0]=e;return`rgb(${Math.round(A*255)}, ${Math.round(t*255)}, ${Math.round(i*255)})`},OSe=({textures:e,boardData:A,traceTextureResolution:t})=>{if(!e.some(c=>c?.image))return null;const n=cD(A),o=Math.floor(n.width*t),s=Math.floor(n.height*t);if(o<=0||s<=0)return null;const r=document.createElement("canvas");r.width=o,r.height=s+1;const a=r.getContext("2d");if(!a)return null;e.forEach(c=>{if(!c?.image)return;const I=c.image;a.drawImage(I,0,0,o,s)});const g=new kx(r);return g.generateMipmaps=!1,g.minFilter=uI,g.magFilter=uI,g.premultiplyAlpha=!0,g.anisotropy=16,g.needsUpdate=!0,g};function zXA({circuitJson:e,boardData:A,traceTextureResolution:t,visibility:i}){const n=vEA(pr.fr4TracesWithMaskGreen),o=vEA(pr.fr4TracesWithoutMaskTan),s="rgb(255,255,255)",r=vEA(pr.copper),a=i?.boardBody??!0,g=I=>{const l=(I==="top"?i?.topMask:i?.bottomMask)??!0,B=(I==="top"?i?.topCopper:i?.bottomCopper)??!0,C=(I==="top"?i?.topSilkscreen:i?.bottomSilkscreen)??!0,Q=l?qSe({layer:I,circuitJson:e,boardData:A,traceTextureResolution:t}):null,E=B?vSe({layer:I,circuitJson:e,boardData:A,traceColor:l?n:o,traceTextureResolution:t}):null,h=B?xSe({layer:I,circuitJson:e,boardData:A,copperColor:r,traceTextureResolution:t}):null,u=B?HSe({layer:I,circuitJson:e,boardData:A,traceTextureResolution:t}):null,d=B?_Se({layer:I,circuitJson:e,boardData:A,copperColor:r,traceTextureResolution:t}):null,f=C?NSe({layer:I,circuitJson:e,boardData:A,silkscreenColor:s,traceTextureResolution:t}):null,m=a?kSe({layer:I,circuitJson:e,panelData:A,traceTextureResolution:t}):null;return OSe({textures:[u,E,h,d,Q,f,m],boardData:A,traceTextureResolution:t})},c=A.num_layers??2;return{topBoard:g("top"),bottomBoard:c<2?null:g("bottom")}}function XXA(e,A){const{texture:t,yOffset:i,isBottomLayer:n,usePolygonOffset:o=!1,renderOrder:s=0,isFaux:r=!1}=e;if(!t)return null;const a=cD(A),g=new km(a.width,a.height),c=new xd({map:t,transparent:!0,alphaTest:.08,side:WB,depthWrite:!0,polygonOffset:o,polygonOffsetFactor:o?-4:0,polygonOffsetUnits:o?-4:0,opacity:r?QW:1}),I=new Ao(g,c);return I.position.set(a.centerX,a.centerY,i),n&&I.rotation.set(Math.PI,0,0),I.name=`${n?"bottom":"top"}-board-texture-plane`,I.renderOrder=s,I}function WSe(e,A,t,i=!1){const n=[];if(!e||!A||t===null)return n;const o=.005,s=XXA({texture:e.topBoard,yOffset:t/2+o,isBottomLayer:!1,usePolygonOffset:!0,renderOrder:1,isFaux:i},A);s&&n.push(s);const r=XXA({texture:e.bottomBoard,yOffset:-t/2-o,isBottomLayer:!0,usePolygonOffset:!0,renderOrder:1,isFaux:i},A);return r&&n.push(r),n}var ZSe=4e6,VSe=4096,jSe=1;function $XA(e,A,t={}){const{maxTexturePixels:i=ZSe,maxTextureDimension:n=VSe,minTextureResolution:o=jSe}=t,s=cD(e);if(!Number.isFinite(s.width)||!Number.isFinite(s.height)||s.width<=0||s.height<=0)return A;const r=Math.max(s.width,s.height),a=n/r,g=Math.sqrt(i/(s.width*s.height)),c=Math.min(A,a,g);return Math.max(o,c)}function zSe({circuitJson:e,pcbThickness:A,isFaux:t=!1}){const{rootObject:i}=Lu(),{visibility:n}=jF(),o=AA.useMemo(()=>{const a=e.filter(I=>I.type==="pcb_panel"),g=Ji(e).pcb_board.list();if(a.length>0){const I=a[0],l=g.find(B=>B.pcb_panel_id===I.pcb_panel_id);return{type:"pcb_board",pcb_board_id:I.pcb_panel_id,center:I.center,width:I.width,height:I.height,thickness:l?.thickness??1.4,material:l?.material??"fr4",num_layers:l?.num_layers??2}}const c=g.filter(I=>!I.pcb_panel_id);return c.length>0?c[0]:null},[e]),s=AA.useMemo(()=>o?$XA(o,av):av,[o]),r=AA.useMemo(()=>!o||!o.width||!o.height?null:zXA({circuitJson:e,boardData:o,traceTextureResolution:s,visibility:n}),[e,o,s,n]);return AA.useEffect(()=>{if(!i||!o||!r)return;const a=[],g=C=>{const Q=["map","alphaMap","aoMap","bumpMap","displacementMap","emissiveMap","lightMap","metalnessMap","normalMap","roughnessMap","specularMap"],E=C;for(const h of Q){const u=E[h];u&&u instanceof Hc&&(u.dispose(),E[h]=null)}C.dispose()},c=(C,Q,E,h,u=!1,d=!0,f=1)=>{if(!C)return null;const m=cD(o),w=new km(m.width,m.height),D=new xd({map:C,transparent:!0,alphaTest:.08,side:WB,depthWrite:d,polygonOffset:u,polygonOffsetFactor:u?-4:0,polygonOffsetUnits:u?-4:0,opacity:t?QW:1}),b=new Ao(w,D);return b.position.set(m.centerX,m.centerY,Q),E&&b.rotation.set(Math.PI,0,0),b.name=h,b.renderOrder=f,b.frustumCulled=!1,b},I=.005,l=c(r.topBoard,A/2+I,!1,"jscad-top-board-texture",!0);l&&(a.push(l),i.add(l));const B=c(r.bottomBoard,-A/2-I,!0,"jscad-bottom-board-texture",!0);return B&&(a.push(B),i.add(B)),()=>{a.forEach(C=>{C.parent===i&&i.remove(C),C.geometry.dispose(),Array.isArray(C.material)?C.material.forEach(Q=>g(Q)):C.material instanceof Zp&&g(C.material)}),r.topBoard?.dispose(),r.bottomBoard?.dispose()}},[i,o,r,A]),null}function XSe(e){const A=Ji(e).cad_component.list(),t=Ji(e).pcb_smtpad.list(),i=Ji(e).pcb_hole.list(),n=Ji(e).pcb_plated_hole.list(),o=Ji(e).pcb_via.list();if(A.length===0&&t.length===0&&i.length===0&&n.length===0&&o.length===0)return null;const s=[...i,...n,...o,...t],r=wL(s);let a=r.minX,g=r.maxX,c=r.minY,I=r.maxY;for(const u of A)if(u.position){const d=u.position.x,f=u.position.y;a=Math.min(a,d),g=Math.max(g,d),c=Math.min(c,f),I=Math.max(I,f)}a===1/0&&(a=-10,g=10,c=-10,I=10);const l=2,B=Math.max(Math.abs(a),Math.abs(g))+l,C=Math.max(Math.abs(c),Math.abs(I))+l,Q=Math.max(2*B,10),E=Math.max(2*C,10);return{type:"pcb_board",pcb_board_id:"faux-board",center:{x:0,y:0},width:Q,height:E,thickness:1.4,material:"fr4",num_layers:2}}function A6A(e){if(Ji(e).pcb_board.list().length>0)return e;const t=XSe(e);if(!t)return e;const n=t.thickness/2;return[...e.map(s=>{if(s.type==="cad_component"){const r=s;if(r.position){const a=r.position.z??0;return{...r,position:{...r.position,z:a+n}}}}return s}),t]}var $Se=AA.forwardRef(({circuitJson:e,children:A,autoRotateDisabled:t,clickToInteractEnabled:i,onUserInteraction:n,onCameraControllerReady:o,resolveStaticAsset:s},r)=>{const a=MXA(A),g=AA.useMemo(()=>A6A(e??a),[e,a]),c=ISe(g),I=AA.useMemo(()=>{if(!g)return[5,-5,5];try{const u=Ji(g).pcb_board.list()[0];if(!u)return[5,-5,5];const{width:d,height:f}=u;if(!d&&!f)return[5,-5,5];const m=5,w=Math.max(d,m),D=Math.max(f,m),b=Math.max(w,D);return[b*.4,-b*.7,b*.9]}catch(u){return console.error(u),[5,-5,5]}},[g]),l=AA.useMemo(()=>{if(!g)return!1;try{const u=Ji(g).pcb_board.list()[0];return!!u&&u.pcb_board_id==="faux-board"}catch{return!1}},[g]),B=AA.useMemo(()=>{if(g)try{const u=Ji(g).pcb_board.list()[0];return u?{width:u.width??0,height:u.height??0}:void 0}catch(u){console.error(u);return}},[g]),C=AA.useMemo(()=>{if(g)try{const u=Ji(g).pcb_board.list()[0];return!u||!u.center?void 0:{x:u.center.x,y:u.center.y}}catch(u){console.error(u);return}},[g]),Q=FzA(g),{stls:E}=KDe(c),h=Ji(g).cad_component.list();return Z.jsxs(GXA,{ref:r,autoRotateDisabled:t,initialCameraPosition:I,clickToInteractEnabled:i,boardDimensions:B,boardCenter:C,onUserInteraction:n,onCameraControllerReady:o,children:[E.map(({stlData:u,color:d,layerType:f},m)=>Z.jsx(QSe,{stlData:u,color:d,opacity:m===0?l?.8:.95:1,layerType:f},`board-${m}`)),Z.jsx(zSe,{circuitJson:g,pcbThickness:Q,isFaux:l}),h.map(u=>Z.jsx(HXA,{fallback:({error:d})=>Z.jsx(UXA,{cad_component:u,error:d}),children:Z.jsx(bXA,{cad_component:u,circuitJson:g,resolveStaticAsset:s},u.cad_component_id)},u.cad_component_id))]})}),Abe=e=>{let A=0;for(let i=0;i<e.length;i++){const n=(i+1)%e.length;e[i]&&e[n]&&(A+=e[i][0]*e[n][1],A-=e[n][0]*e[i][1])}return A/2<=0};function tbe(e,A,t,i,n){let o,s=null;if(t.outline&&t.outline.length>=3){let r=t.outline.map(g=>[g.x,g.y]);Abe(r)&&(r=r.reverse());const a=A.ofPolygons([r]);n.push(a),s=a,o=e.extrude(a,i,void 0,void 0,void 0,!0),n.push(o)}else t.outline&&t.outline.length>0&&console.warn("Board outline has fewer than 3 points, falling back to rectangular board."),o=e.cube([t.width,t.height,i],!0),n.push(o),o=o.translate([t.center.x,t.center.y,0]),n.push(o);return{boardOp:o,outlineCrossSection:s}}var ebe=64;function d0({Manifold:e,width:A,height:t,thickness:i,borderRadius:n}){const o=zF(A,t,n);if(o<=0)return e.cube([A,t,i],!0);const s=[],r=A-2*o,a=t-2*o;return r>0&&s.push(e.cube([r,t,i],!0)),a>0&&s.push(e.cube([A,a,i],!0)),[[A/2-o,t/2-o],[-A/2+o,t/2-o],[-A/2+o,-t/2+o],[A/2-o,-t/2+o]].forEach(([c,I])=>{s.push(e.cylinder(i,o,o,ebe,!0).translate([c,I,0]))}),e.union(s)}var ibe=e=>{let A=0;for(let i=0;i<e.length;i++){const n=(i+1)%e.length;e[i]&&e[n]&&(A+=e[i][0]*e[n][1],A-=e[n][0]*e[i][1])}return A/2<=0};function nbe(e,A,t,i,n){const o=[],s=Ji(t).pcb_cutout.list();for(const r of s){let a;const g=i*1.5;switch(r.shape){case"rect":{const l=Gy(r);if(typeof l=="number"&&l>0?a=d0({Manifold:e,width:r.width,height:r.height,thickness:g,borderRadius:l}):a=e.cube([r.width,r.height,g],!0),n.push(a),r.rotation){const B=a.rotate([0,0,r.rotation]);n.push(B),a=B}a=a.translate([r.center.x,r.center.y,0]),n.push(a);break}case"circle":a=e.cylinder(g,r.radius,-1,VB,!0),n.push(a),a=a.translate([r.center.x,r.center.y,0]),n.push(a);break;case"polygon":if(r.points.length<3){console.warn(`PCB Cutout [${r.pcb_cutout_id}] polygon has fewer than 3 points, skipping.`);continue}let c=r.points.map(l=>[l.x,l.y]);ibe(c)&&(c=c.reverse());const I=A.ofPolygons([c]);n.push(I),a=e.extrude(I,g,0,0,[1,1],!0),n.push(a);break;default:console.warn(`Unsupported cutout shape: ${r.shape} for cutout ${r.pcb_cutout_id}`);continue}a&&o.push(a)}return{cutoutOps:o}}function t6A({Manifold:e,x:A,y:t,diameter:i,thickness:n,segments:o=32}){return e.cylinder(n*1.2,i/2,i/2,o,!0).translate([A,t,0])}function e6A({Manifold:e,x:A,y:t,holeDiameter:i,thickness:n,zOffset:o=.001,segments:s=32}){const r=i/2+o;return e.cylinder(n*1.2,r,r,s,!0).translate([A,t,0])}function obe(e,A,t,i,n){const o=[],s=Ji(t).pcb_hole.list(),r=(g,c,I)=>{const l=d0({Manifold:e,width:g,height:c,thickness:I,borderRadius:Math.min(g,c)/2});return n.push(l),l},a=(g,c,I)=>{const l=[];for(let B=0;B<I;B++){const C=2*Math.PI*B/I;l.push([g/2*Math.cos(C),c/2*Math.sin(C)])}return l};return s.forEach(g=>{const c=g.hole_shape,I=g.x,l=g.y,B=i*1.2,C=g.ccw_rotation??g.rotation??0,Q=g.hole_width??g.hole_diameter,E=g.hole_height??g.hole_diameter;let h=null;if(c==="circle"){h=t6A({Manifold:e,x:I,y:l,diameter:g.hole_diameter,thickness:i,segments:VB}),o.push(h),n.push(h);return}if(c==="pill"||c==="rotated_pill")h=r(Q,E,B);else if(c==="oval"){let u=a(Q,E,VB),d=0;for(let m=0;m<u.length;m++){const w=(m+1)%u.length;d+=u[m][0]*u[w][1],d-=u[w][0]*u[m][1]}d<=0&&(u=u.reverse());const f=A.ofPolygons([u]);n.push(f),h=e.extrude(f,B,0,0,[1,1],!0),n.push(h)}if(h){if(C!==0){const d=h.rotate([0,0,C]);n.push(d),h=d}const u=h.translate([I,l,0]);n.push(u),o.push(u)}}),{nonPlatedHoleBoardDrills:o}}function ID(e){const A=new fg;if(A.setAttribute("position",new Jo(e.vertProperties,3)),A.setIndex(new W6(e.triVerts,1)),e.runIndex&&e.runIndex.length>1&&e.runOriginalID)for(let t=0;t<e.runIndex.length-1;t++){const i=e.runIndex[t],n=e.runIndex[t+1]-i;A.addGroup(i,n,0)}else A.addGroup(0,e.triVerts.length,0);return A}var wH=e=>{let A=0;for(let i=0;i<e.length;i++){const n=(i+1)%e.length;e[i]&&e[n]&&(A+=e[i][0]*e[n][1],A-=e[n][0]*e[i][1])}return A/2<=0},yW=(e,A,t)=>{const i=[];for(let n=0;n<t;n++){const o=2*Math.PI*n/t;i.push([e/2*Math.cos(o),A/2*Math.sin(o)])}return i},$F=new Oi(...pr.copper),mW=.05,wW=.003,My=5e-4,DW=.004;function sbe(e,A,t,i,n,o){const s=[],r=Ji(t).pcb_plated_hole.list(),a=[],g=[],c=(C,Q,E)=>{const h=d0({Manifold:e,width:C,height:Q,thickness:E,borderRadius:Math.min(C,Q)/2});return n.push(h),h},I=({padOutline:C,thickness:Q})=>{if(!Array.isArray(C)||C.length<3)return null;let E=C.map(d=>[d.x,d.y]);wH(E)&&(E=E.reverse());const h=A.ofPolygons([E]);n.push(h);const u=e.extrude(h,Q,0,0,[1,1],!0);return n.push(u),u},l=({ph:C,depth:Q,sizeDelta:E=0})=>{if(C.shape!=="hole_with_polygon_pad")return null;const u=C.pad_outline;if(!Array.isArray(u)||u.length<3)return null;const d=C.hole_shape||"circle",f=C.hole_offset_x||0,m=C.hole_offset_y||0;let w=null;if(d==="circle"){const D=Math.max((C.hole_diameter??0)+E,Ln),b=Math.max(D/2,Ln/2);w=e.cylinder(Q,b,b,VB,!0),n.push(w)}else{const D=C.hole_width??C.hole_diameter,b=C.hole_height??C.hole_diameter;if(!D||!b)return null;const k=Math.max(D+E,Ln),x=Math.max(b+E,Ln);if(d==="oval"){let N=yW(k,x,VB);wH(N)&&(N=N.reverse());const R=A.ofPolygons([N]);n.push(R),w=e.extrude(R,Q,0,0,[1,1],!0),n.push(w)}else(d==="pill"||d==="rotated_pill")&&(w=d0({Manifold:e,width:k,height:x,thickness:Q,borderRadius:Math.min(k,x)/2}),n.push(w))}if(!w)return null;if(f||m){const D=w.translate([f,m,0]);n.push(D),w=D}return w};r.forEach((C,Q)=>{if(C.shape==="circle"){const E=e6A({Manifold:e,x:C.x,y:C.y,holeDiameter:C.hole_diameter*1.02,thickness:i,zOffset:rf,segments:VB});n.push(E),s.push(E);const h=i+2*rf,u=e.cylinder(h,C.outer_diameter/2,C.outer_diameter/2,VB,!0);n.push(u);const d=e.cylinder(h*1.05,C.hole_diameter/2,C.hole_diameter/2,VB,!0);n.push(d);const f=u.subtract(d);n.push(f);const m=f.translate([C.x,C.y,0]);n.push(m);let w=m;if(o){const b=e.intersection([m,o]);n.push(b),w=b}g.push(w);const D=ID(w.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:D,color:$F})}else if(C.shape==="pill"){const E=C.hole_width,h=C.hole_height,u=.4,d=C.outer_width??E+u,f=C.outer_height??h+u,m=E+2*rf,w=h+2*rf,D=i*1.2;let b=c(m,w,D);if(C.ccw_rotation){const W=b.rotate([0,0,C.ccw_rotation]);n.push(W),b=W}const k=b.translate([C.x,C.y,0]);n.push(k),s.push(k);const x=i+2*rf,N=c(d,f,x),R=c(E,h,x*1.05);let U=N.subtract(R);if(n.push(U),C.ccw_rotation){const W=U.rotate([0,0,C.ccw_rotation]);n.push(W),U=W}const T=U.translate([C.x,C.y,0]);n.push(T);let Y=T;if(o){const W=e.intersection([T,o]);n.push(W),Y=W}g.push(Y);const O=ID(Y.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:O,color:$F})}else if(C.shape==="pill_hole_with_rect_pad"){if(C.hole_shape&&C.hole_shape!=="pill"||C.pad_shape&&C.pad_shape!=="rect")return;const E=C.hole_width,h=C.hole_height,u=C.hole_offset_x||0,d=C.hole_offset_y||0,f=C.rect_pad_width,m=C.rect_pad_height,w=Gy(C),D=wW,b=E+2*rf,k=h+2*rf,x=i*1.2,R=c(b,k,x).translate([u,d,0]).translate([C.x,C.y,0]);n.push(R),s.push(R);const U=d0({Manifold:e,width:f,height:m,thickness:Math.max(i-2*(D+My+DW),Ln),borderRadius:w});n.push(U);const T=d0({Manifold:e,width:f,height:m,thickness:D,borderRadius:w}).translate([0,0,i/2+My+D/2]),Y=d0({Manifold:e,width:f,height:m,thickness:D,borderRadius:w}).translate([0,0,-i/2-My-D/2]);n.push(T,Y);const O=c(E,h,i*.8).translate([u,d,0]);n.push(O);const W=e.union([U,T,Y,O]);n.push(W);const X=c(Math.max(E-2*mW,.01),Math.max(h-2*mW,.01),i*1.2).translate([u,d,0]);n.push(X);const iA=W.subtract(X);n.push(iA);const aA=iA.translate([C.x,C.y,0]);n.push(aA);let tA=aA;if(o){const rA=e.intersection([aA,o]);n.push(rA),tA=rA}g.push(tA);const oA=ID(tA.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:oA,color:$F})}else if(C.shape==="rotated_pill_hole_with_rect_pad"){if(C.hole_shape&&C.hole_shape!=="rotated_pill"||C.pad_shape&&C.pad_shape!=="rect")return;const E=C.hole_width,h=C.hole_height,u=C.hole_offset_x||0,d=C.hole_offset_y||0,f=C.rect_pad_width,m=C.rect_pad_height,w=Gy(C),D=wW,b=E+2*rf,k=h+2*rf,x=i*1.2;let N=c(b,k,x).translate([u,d,0]);if(C.hole_ccw_rotation){const rA=N.rotate([0,0,C.hole_ccw_rotation]);n.push(rA),N=rA}const R=N.translate([C.x,C.y,0]);n.push(R),s.push(R);let U=d0({Manifold:e,width:f,height:m,thickness:Math.max(i-2*(D+My+DW),Ln),borderRadius:w});if(n.push(U),C.rect_ccw_rotation){const rA=U.rotate([0,0,C.rect_ccw_rotation]);n.push(rA),U=rA}let T=d0({Manifold:e,width:f,height:m,thickness:D,borderRadius:w}).translate([0,0,i/2+My+D/2]);if(C.rect_ccw_rotation){const rA=T.rotate([0,0,C.rect_ccw_rotation]);n.push(rA),T=rA}let Y=d0({Manifold:e,width:f,height:m,thickness:D,borderRadius:w}).translate([0,0,-i/2-My-D/2]);if(C.rect_ccw_rotation){const rA=Y.rotate([0,0,C.rect_ccw_rotation]);n.push(rA),Y=rA}n.push(T,Y);let O=c(E,h,i*.8).translate([u,d,0]);if(C.hole_ccw_rotation){const rA=O.rotate([0,0,C.hole_ccw_rotation]);n.push(rA),O=rA}n.push(O);const W=e.union([U,T,Y,O]);n.push(W);let X=c(Math.max(E-2*mW,.01),Math.max(h-2*mW,.01),i*1.2).translate([u,d,0]);if(C.hole_ccw_rotation){const rA=X.rotate([0,0,C.hole_ccw_rotation]);n.push(rA),X=rA}n.push(X);const iA=W.subtract(X);n.push(iA);const aA=iA.translate([C.x,C.y,0]);n.push(aA);let tA=aA;if(o){const rA=e.intersection([aA,o]);n.push(rA),tA=rA}g.push(tA);const oA=ID(tA.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:oA,color:$F})}else if(C.shape==="hole_with_polygon_pad"){const E=C.pad_outline;if(!Array.isArray(E)||E.length<3)return;const h=l({ph:C,depth:i*1.2,sizeDelta:2*Ln});if(!h)return;const u=h.translate([C.x,C.y,0]);n.push(u),s.push(u);const d=wW,f=Math.max(i-2*(d+My+DW),Ln),m=I({padOutline:E,thickness:f}),w=I({padOutline:E,thickness:d}),D=I({padOutline:E,thickness:d});if(!m||!w||!D)return;const b=w.translate([0,0,i/2+My+d/2]),k=D.translate([0,0,-i/2-My-d/2]);n.push(b,k);const x=l({ph:C,depth:i*1.02});if(!x)return;const N=l({ph:C,depth:i*.8,sizeDelta:-2*Ln})||x,R=e.union([m,b,k,x]);n.push(R);const U=R.subtract(N);n.push(U);const T=U.translate([C.x,C.y,0]);n.push(T);let Y=T;if(o){const W=e.intersection([T,o]);n.push(W),Y=W}g.push(Y);const O=ID(Y.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:O,color:$F})}else if(C.shape==="oval"){const E=C.hole_width,h=C.hole_height,u=C.outer_width??E+.4,d=C.outer_height??h+.4,f=E+2*rf,m=h+2*rf,w=i*1.2;let D=yW(f,m,VB);wH(D)&&(D=D.reverse());const b=A.ofPolygons([D]);n.push(b);let k=e.extrude(b,w,0,0,[1,1],!0);if(n.push(k),C.ccw_rotation){const oA=k.rotate([0,0,C.ccw_rotation]);n.push(oA),k=oA}const x=k.translate([C.x,C.y,0]);n.push(x),s.push(x);const N=i+2*rf;let R=yW(u,d,VB);wH(R)&&(R=R.reverse());const U=A.ofPolygons([R]);n.push(U);const T=e.extrude(U,N,0,0,[1,1],!0);n.push(T);let Y=yW(E,h,VB);wH(Y)&&(Y=Y.reverse());const O=A.ofPolygons([Y]);n.push(O);const W=e.extrude(O,N*1.05,0,0,[1,1],!0);n.push(W);let X=T.subtract(W);if(n.push(X),C.ccw_rotation){const oA=X.rotate([0,0,C.ccw_rotation]);n.push(oA),X=oA}const iA=X.translate([C.x,C.y,0]);n.push(iA);let aA=iA;if(o){const oA=e.intersection([iA,o]);n.push(oA),aA=oA}g.push(aA);const tA=ID(aA.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:tA,color:$F})}else if(C.shape==="circular_hole_with_rect_pad"){if(C.hole_shape&&C.hole_shape!=="circle"||C.pad_shape&&C.pad_shape!=="rect")return;const E=C.hole_offset_x||0,h=C.hole_offset_y||0,u=t6A({Manifold:e,x:C.x+E,y:C.y+h,diameter:C.hole_diameter,thickness:i,segments:VB});n.push(u),s.push(u);const d=C.rect_pad_width??C.hole_diameter,f=C.rect_pad_height??C.hole_diameter,m=Gy(C),w=wW,D=C.hole_diameter/2,b=d0({Manifold:e,width:d,height:f,thickness:Math.max(i-2*(w+My+DW),Ln),borderRadius:m});n.push(b);const k=d0({Manifold:e,width:d,height:f,thickness:w,borderRadius:m}).translate([0,0,i/2+My+w/2]),x=d0({Manifold:e,width:d,height:f,thickness:w,borderRadius:m}).translate([0,0,-i/2-My-w/2]);n.push(k,x);const N=e.cylinder(i*.8,D,D,VB,!0).translate([E,h,0]);n.push(N);const R=e.union([b,k,x,N]);n.push(R);const U=e.cylinder(i*1.2,Math.max(D-Ln,.01),Math.max(D-Ln,.01),VB,!0).translate([E,h,0]);n.push(U);const T=R.subtract(U);n.push(T);const Y=T.translate([C.x,C.y,0]);n.push(Y);let O=Y;if(o){const X=e.intersection([Y,o]);n.push(X),O=X}g.push(O);const W=ID(O.getMesh());a.push({key:`ph-${C.pcb_plated_hole_id||Q}`,geometry:W,color:$F})}});let B;return g.length>0&&(B=e.union(g),n.push(B)),{platedHoleBoardDrills:s,platedHoleCopperGeoms:a,platedHoleSubtractOp:B}}function rbe({Manifold:e,x:A,y:t,outerDiameter:i,holeDiameter:n,thickness:o,zOffset:s=.001,segments:r=32}){const a=s,g=s;if(i<n)throw new Error(`Invalid via geometry: outerDiameter (${i}) must be >= holeDiameter (${n})`);const c=Math.min(i/2,n/2+g),I=e.cylinder(o,c,-1,r,!0),l=e.cylinder(a,i/2,-1,r,!0).translate([0,0,o/2]),B=e.cylinder(a,i/2,-1,r,!0).translate([0,0,-o/2]),C=e.union([I,l,B]),Q=o+a*2,E=e.cylinder(Q,n/2,-1,r,!0);return C.subtract(E).translate([A,t,0])}var abe=new Oi(...pr.copper);function gbe(e,A,t,i,n){const o=[],s=Ji(A).pcb_via.list(),r=[];return s.forEach((a,g)=>{if(typeof a.hole_diameter=="number"){const c=e6A({Manifold:e,x:a.x,y:a.y,holeDiameter:a.hole_diameter,thickness:t,zOffset:rf,segments:VB});i.push(c),o.push(c)}if(typeof a.outer_diameter=="number"&&typeof a.hole_diameter=="number"){const c=rbe({Manifold:e,x:a.x,y:a.y,outerDiameter:a.outer_diameter,holeDiameter:a.hole_diameter,thickness:t,zOffset:rf,segments:VB});i.push(c);let I=c;if(n){const B=e.intersection([c,n]);i.push(B),I=B}const l=ID(I.getMesh());r.push({key:`via-${a.pcb_via_id||g}`,geometry:l,color:abe})}}),{viaBoardDrills:o,viaCopperGeoms:r}}var cbe=(e,A,t)=>{const[i,n]=AA.useState(null),[o,s]=AA.useState(null),[r,a]=AA.useState(null),[g,c]=AA.useState(!0),I=AA.useRef([]),l=AA.useMemo(()=>{const E=A.filter(d=>d.type==="pcb_panel"),h=Ji(A).pcb_board.list();if(E.length>0){const d=E[0],f=h.find(m=>m.pcb_panel_id===d.pcb_panel_id);return{type:"pcb_board",pcb_board_id:d.pcb_panel_id,center:d.center,width:d.width,height:d.height,thickness:f?.thickness??1.4,material:f?.material??"fr4",num_layers:f?.num_layers??2}}const u=h.filter(d=>!d.pcb_panel_id);return u.length>0?u[0]:null},[A]),B=AA.useMemo(()=>{const E=Ji(A).pcb_board.list();return E.length>0&&E[0].pcb_board_id==="faux-board"},[A]),C=AA.useMemo(()=>l?$XA(l,av):av,[l]);AA.useEffect(()=>{if(!e||!l){n(null),s(null),c(!1);return}if((l.width===0||!l.width)&&(l.height===0||!l.height)&&(!l.outline||l.outline.length<3)){n({platedHoles:[],vias:[]}),s(l.thickness??0),c(!1);return}c(!0),a(null);const E=e.Manifold,h=e.CrossSection,u=m=>{if(!(!m||typeof m.delete!="function"))try{m.delete()}catch(w){(!(w instanceof Error)||!w.message?.includes("Manifold instance already deleted"))&&console.warn("Failed to delete Manifold instance",w)}};I.current.forEach(u),I.current=[];let d=null;const f={};try{const m=l.thickness||1.4;s(m);const{boardOp:w,outlineCrossSection:D}=tbe(E,h,l,m,I.current);let b=w;const x=m+2*1;let N=null;const R=.01;if(D){let oA=D;if(R>0){const CA=D.offset(R);I.current.push(CA),oA=CA}const rA=E.extrude(oA,x,void 0,void 0,void 0,!0);I.current.push(rA),N=rA}else{const oA=(l.width||0)+2*R,rA=(l.height||0)+2*R,CA=E.cube([oA,rA,x],!0);I.current.push(CA);const SA=CA.translate([l.center.x,l.center.y,0]);I.current.push(SA),N=SA}const U=[];let T=null;const{nonPlatedHoleBoardDrills:Y}=obe(E,h,A,m,I.current);U.push(...Y);const{platedHoleBoardDrills:O,platedHoleCopperGeoms:W,platedHoleSubtractOp:X}=sbe(E,h,A,m,I.current,N);U.push(...O),f.platedHoles=W;const{viaBoardDrills:iA,viaCopperGeoms:aA}=gbe(E,A,m,I.current,N);if(U.push(...iA),f.vias=aA,U.length>0){T=E.union(U),I.current.push(T);const oA=X?E.union([T,X]):T;I.current.push(oA);const rA=b.subtract(oA);if(I.current.push(rA),b=rA,X){const CA=X.subtract(T);I.current.push(CA);const SA=CA.getMesh(),MA=ID(SA);f.platedHoles=[{key:"plated-holes-union",geometry:MA,color:new Oi(pr.copper[0],pr.copper[1],pr.copper[2])}]}}const{cutoutOps:tA}=nbe(E,h,A,m,I.current);if(tA.length>0){const oA=E.union(tA);I.current.push(oA);const rA=b.subtract(oA);I.current.push(rA),b=rA}if(d=b,d){const oA=d.getMesh(),rA=ID(oA),CA=FEA[l.material]??pr.fr4Tan;f.board={geometry:rA,color:new Oi(CA[0],CA[1],CA[2]),material:l.material,isFaux:B}}n(f)}catch(m){console.error("Error processing geometry with Manifold in hook:",m),a(m.message||"An unknown error occurred while processing geometry in hook."),n(null)}finally{c(!1)}return()=>{I.current.forEach(u),I.current=[]}},[e,A,l]);const Q=AA.useMemo(()=>!l||!C?null:zXA({circuitJson:A,boardData:l,traceTextureResolution:C,visibility:t}),[A,l,C,t]);return{geoms:i,textures:Q,pcbThickness:o,error:r,isLoading:g,boardData:l,isFauxBoard:B}},Ibe=WB,lbe=({material:e,color:A,side:t=Ibe,isFaux:i=!1})=>e==="fr4"?new Fm({color:A,side:t,metalness:0,roughness:.8,specularIntensity:.2,ior:1.45,sheen:0,clearcoat:0,transparent:i,opacity:i?QW:1,flatShading:!0,polygonOffset:!0,polygonOffsetFactor:1,polygonOffsetUnits:1}):new dh({color:A,side:t,flatShading:!0,metalness:.1,roughness:.8,transparent:!0,opacity:i?QW:.9,polygonOffset:!0,polygonOffsetFactor:1,polygonOffsetUnits:1});function Bbe(e){const A=[];if(!e)return A;if(e.board&&e.board.geometry){const i=new Ao(e.board.geometry,lbe({material:e.board.material,color:e.board.color,side:WB,isFaux:e.board.isFaux}));i.name="board-geom",A.push(i)}const t=i=>{i&&i.forEach(n=>{const o=new Ao(n.geometry,new dh({color:n.color,side:WB,flatShading:!0}));o.name=n.key,A.push(o)})};return t(e.platedHoles),t(e.vias),A}var Cbe=({geometryMeshes:e,textureMeshes:A})=>{const{rootObject:t}=Lu(),{visibility:i}=jF(),n=o=>{o.geometry.dispose();const s=Array.isArray(o.material)?o.material:[o.material];for(const r of s){if(!r)continue;const a=["map","alphaMap","aoMap","bumpMap","displacementMap","emissiveMap","lightMap","metalnessMap","normalMap","roughnessMap","specularMap"],g=r;for(const c of a){const I=g[c];I&&I instanceof Hc&&(I.dispose(),g[c]=null)}r.dispose()}};return AA.useEffect(()=>{if(t)return e.forEach(o=>{let s=!0;o.name==="board-geom"?s=i.boardBody:(o.name.includes("plated_hole")||o.name.includes("via"))&&(s=i.topCopper||i.bottomCopper),s&&t.add(o)}),()=>{e.forEach(o=>{o.parent===t&&t.remove(o),n(o)})}},[t,e,i]),AA.useEffect(()=>{if(t)return A.forEach(o=>{t.add(o)}),()=>{A.forEach(o=>{o.parent===t&&t.remove(o),n(o)})}},[t,A]),null},Qbe="https://cdn.jsdelivr.net/npm/manifold-3d@3.2.1",Ebe=({circuitJson:e,autoRotateDisabled:A,clickToInteractEnabled:t,onUserInteraction:i,children:n,onCameraControllerReady:o,resolveStaticAsset:s})=>{const r=MXA(n),a=AA.useMemo(()=>A6A(e??r),[e,r]),[g,c]=AA.useState(null),[I,l]=AA.useState(null),{visibility:B}=jF();AA.useEffect(()=>{if(window.ManifoldModule&&typeof window.ManifoldModule=="object"&&window.ManifoldModule.setup){c(window.ManifoldModule);return}const N=async W=>{try{const X=await W();X.setup(),window.ManifoldModule=X,c(X)}catch(X){console.error("Failed to initialize Manifold:",X),l(`Failed to initialize Manifold: ${X instanceof Error?X.message:"Unknown error"}`)}},R=window.ManifoldModule??window.MANIFOLD??window.MANIFOLD_MODULE;if(R){window.ManifoldModule=R,N(window.ManifoldModule);return}const U="manifoldLoaded",T=()=>{const W=window.ManifoldModule??window.MANIFOLD??window.MANIFOLD_MODULE;if(W)window.ManifoldModule=W,N(window.ManifoldModule);else{const X="ManifoldModule not found on window after script load.";console.error(X),l(X)}};window.addEventListener(U,T,{once:!0});const Y=document.createElement("script");Y.type="module",Y.innerHTML=`
|
|
5176
5176
|
try {
|
|
5177
5177
|
const { default: ManifoldModule } = await import('${Qbe}/manifold.js');
|
|
5178
5178
|
window.ManifoldModule = ManifoldModule;
|
|
@@ -5684,7 +5684,7 @@ test("${g} should solve problem correctly", () => {
|
|
|
5684
5684
|
// Add more specific assertions based on expected output
|
|
5685
5685
|
// expect(solver.netLabelPlacementSolver!.netLabelPlacements).toMatchInlineSnapshot()
|
|
5686
5686
|
})
|
|
5687
|
-
`,I=new Blob([c],{type:"text/plain"}),l=URL.createObjectURL(I),B=document.createElement("a");B.href=l,B.download=`${g}.test.ts`,B.click(),URL.revokeObjectURL(l)}catch(a){alert(`Error generating test.ts for ${e.constructor.name}: ${a instanceof Error?a.message:String(a)}`)}i(!1)};return Z.jsxs("div",{className:`relative ${A}`,ref:n,children:[Z.jsx("button",{className:"px-2 py-1 rounded text-xs cursor-pointer",onClick:()=>i(!t),title:`Download options for ${e.constructor.name}`,children:e.constructor.name}),t&&Z.jsxs("div",{className:"absolute top-full left-0 mt-1 bg-white border border-gray-300 rounded shadow-lg z-10 min-w-[150px]",children:[Z.jsx("button",{className:"w-full text-left px-3 py-2 hover:bg-gray-100 text-xs",onClick:o,children:"Download JSON"}),Z.jsx("button",{className:"w-full text-left px-3 py-2 hover:bg-gray-100 text-xs",onClick:s,children:"Download page.tsx"}),Z.jsx("button",{className:"w-full text-left px-3 py-2 hover:bg-gray-100 text-xs",onClick:r,children:"Download test.ts"})]})]})},dct=e=>e.activeSubSolver?[e,...dct(e.activeSubSolver)]:[e],vZe=({solver:e})=>{const A=dct(e);return Z.jsx("div",{className:"flex gap-1 items-center text-sm pt-1",children:A.map((t,i)=>Z.jsxs("div",{className:"flex items-center",children:[i>0&&Z.jsx("span",{className:"text-gray-400 mx-1",children:"→"}),Z.jsx(NZe,{solver:t})]},t.constructor.name))})},LZe=({solver:e,triggerRender:A,animationSpeed:t=25,onSolverStarted:i,onSolverCompleted:n})=>{const[o,s]=AA.useReducer(Q=>!Q,!1),r=AA.useRef(void 0),a=()=>{!e.solved&&!e.failed&&(e.step(),A())},g=()=>{!e.solved&&!e.failed&&(i&&i(e),e.solve(),A(),n&&n(e))},c=()=>{o?(r.current&&(clearInterval(r.current),r.current=void 0),s()):(s(),r.current=setInterval(()=>{if(e.solved||e.failed){r.current&&(clearInterval(r.current),r.current=void 0),s(),A(),n&&e.solved&&n(e);return}e.step(),A()},t))},I=()=>{const Q=e;if(Q.getCurrentPhase&&!e.solved&&!e.failed){const E=Q.getCurrentPhase();for(;Q.getCurrentPhase()===E&&!e.solved&&!e.failed;)e.step();A()}},l=()=>{if(e.solved||e.failed||o)return;const Q=window.prompt("Step until which iteration?",`${e.iterations}`);if(Q===null)return;const E=Number(Q);if(!Number.isFinite(E)){window.alert("Please enter a valid number for the iteration");return}for(;e.iterations<E&&!e.solved&&!e.failed;)e.step();A(),e.solved&&n&&n(e)};AA.useEffect(()=>()=>{r.current&&clearInterval(r.current)},[]),AA.useEffect(()=>{(e.solved||e.failed)&&o&&(r.current&&(clearInterval(r.current),r.current=void 0),s())},[e.solved,e.failed,o]);const B=e.getCurrentPhase!==void 0,C=B?e.getCurrentPhase():null;return Z.jsxs("div",{className:"space-y-2 p-2 border-b",children:[Z.jsx("div",{className:"flex items-center",children:Z.jsx(vZe,{solver:e})}),Z.jsxs("div",{className:"flex gap-2 items-center flex-wrap",children:[Z.jsx("button",{onClick:a,disabled:e.solved||e.failed||o,className:"bg-blue-500 hover:bg-blue-600 disabled:bg-gray-300 text-white px-3 py-1 rounded text-sm",children:"Step"}),Z.jsx("button",{onClick:g,disabled:e.solved||e.failed||o,className:"bg-green-500 hover:bg-green-600 disabled:bg-gray-300 text-white px-3 py-1 rounded text-sm",children:"Solve"}),Z.jsx("button",{onClick:c,disabled:e.solved||e.failed,className:`px-3 py-1 rounded text-white text-sm ${o?"bg-red-500 hover:bg-red-600":"bg-yellow-500 hover:bg-yellow-600"} disabled:bg-gray-300`,children:o?"Stop":"Animate"}),Z.jsx("button",{onClick:l,disabled:e.solved||e.failed||o,className:"bg-orange-500 hover:bg-orange-600 disabled:bg-gray-300 text-white px-3 py-1 rounded text-sm",children:"Step Until Iteration"}),B&&Z.jsx("button",{onClick:I,disabled:e.solved||e.failed||o,className:"bg-purple-500 hover:bg-purple-600 disabled:bg-gray-300 text-white px-3 py-1 rounded text-sm",children:"Next Stage"}),Z.jsxs("div",{className:"text-sm text-gray-600",children:["Iterations: ",e.iterations]}),e.timeToSolve!==void 0&&Z.jsxs("div",{className:"text-sm text-gray-600",children:["Time: ",(e.timeToSolve/1e3).toFixed(3),"s"]}),C&&Z.jsxs("div",{className:"text-sm text-gray-600",children:["Phase: ",Z.jsx("span",{className:"font-medium",children:C})]}),e.solved&&Z.jsx("div",{className:"px-2 py-1 bg-green-100 text-green-800 rounded text-sm",children:"Solved"}),e.failed&&Z.jsx("div",{className:"px-2 py-1 bg-red-100 text-red-800 rounded text-sm",children:"Failed"})]}),e.error&&Z.jsxs("div",{className:"text-red-600 text-sm",children:["Error: ",e.error]})]})},UZe=(e,A,t)=>{const i=e.currentPipelineStepIndex;return A<i?"Completed":A===i&&e.activeSubSolver?e.activeSubSolver.failed?"Failed":"In Progress":"Not Started"},HZe=(e,A)=>{const i=e.pipelineDef[A].solverName,n=UZe(e,A),o=e[i],s=e.firstIterationOfPhase?.[i]??null,r=e.iterations;let a=0;if(n==="Completed"){const l=e.pipelineDef[A+1],B=l?e.firstIterationOfPhase?.[l.solverName]:void 0;B!==void 0&&s!==null?a=B-s:s!==null&&(a=r-s)}else n==="In Progress"&&s!==null&&(a=r-s);const g=e.timeSpentOnPhase?.[i]??0;let c=0;n==="Completed"?c=1:n==="In Progress"&&o&&(c=o.progress??0);const I=o?.stats??null;return{index:A,name:i,status:n,firstIteration:s,iterations:a,progress:c,timeSpent:g,stats:I&&Object.keys(I).length>0?I:null,solverInstance:o??null}},YZe=({status:e})=>{const A={"Not Started":"text-blue-600","In Progress":"text-yellow-600",Completed:"text-green-600",Failed:"text-red-600"};return Z.jsx("span",{className:`font-medium ${A[e]}`,children:e})},JZe=({progress:e})=>{if(e===0)return null;const A=Math.round(e*100);return Z.jsxs("div",{className:"flex items-center gap-2",children:[Z.jsx("div",{className:"w-20 h-2 bg-gray-200 rounded overflow-hidden",children:Z.jsx("div",{className:"h-full bg-blue-500 transition-all duration-200",style:{width:`${A}%`}})}),Z.jsxs("span",{className:"text-xs text-gray-500",children:[A,"%"]})]})},TZe=e=>Object.entries(e).map(([A,t])=>`${A}: ${t}`).join(", "),KZe=({stats:e})=>{if(!e||Object.keys(e).length===0)return Z.jsx("span",{children:"-"});const A=Object.entries(e),t=TZe(e);return Z.jsxs("details",{className:"cursor-pointer",children:[Z.jsx("summary",{className:"whitespace-nowrap overflow-hidden text-ellipsis max-w-[200px]",children:t}),Z.jsx("div",{className:"mt-1 text-xs",children:A.map(([i,n])=>Z.jsxs("div",{children:[i,": ",String(n)]},i))})]})},ZpA=e=>{if(e===null||typeof e!="object")return e;if(Array.isArray(e))return e.map(ZpA);const A={};for(const[t,i]of Object.entries(e))t.startsWith("_")||(A[t]=ZpA(i));return A},PZe=(e,A)=>{try{if(typeof e.getConstructorParams!="function"){alert(`getConstructorParams() is not implemented for ${A}`);return}const t=ZpA(e.getConstructorParams()),i=new Blob([JSON.stringify(t,null,2)],{type:"application/json"}),n=URL.createObjectURL(i),o=document.createElement("a");o.href=n,o.download=`${A}_input.json`,o.click(),URL.revokeObjectURL(n)}catch(t){alert(`Error downloading input for ${A}: ${t instanceof Error?t.message:String(t)}`)}},qZe=({solver:e,onStepUntilPhase:A,onDownloadInput:t})=>{const i=e.pipelineDef.map((r,a)=>HZe(e,a)),n=r=>{A?.(r)},o=r=>{r.solverInstance&&(t?t(r.solverInstance,r.name):PZe(r.solverInstance,r.name))},s=r=>`${(r/1e3).toFixed(2)}s`;return Z.jsxs("div",{className:"border-t border-gray-200",children:[Z.jsx("div",{className:"px-4 py-2 bg-gray-50 border-b border-gray-200",children:Z.jsx("h3",{className:"text-sm font-semibold text-gray-700",children:"Pipeline Steps"})}),Z.jsx("div",{className:"overflow-x-auto",children:Z.jsxs("table",{className:"w-full text-sm",children:[Z.jsx("thead",{children:Z.jsxs("tr",{className:"bg-gray-50 border-b border-gray-200",children:[Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Step"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Status"}),Z.jsxs("th",{className:"px-4 py-2 text-center font-semibold text-gray-700",children:["i",Z.jsx("sub",{children:"0"})]}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Iterations"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Progress"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Time"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Stats"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Input"})]})}),Z.jsx("tbody",{children:i.map(r=>Z.jsxs("tr",{className:`border-b border-gray-100 ${r.status==="In Progress"?"bg-yellow-50":""}`,children:[Z.jsx("td",{className:"px-4 py-2",children:Z.jsxs("div",{className:"flex items-center gap-2",children:[Z.jsx("span",{className:"text-gray-400 w-6",children:String(r.index+1).padStart(2,"0")}),Z.jsx("button",{onClick:()=>n(r.name),disabled:r.status==="Completed"||e.solved||e.failed,className:"text-blue-500 hover:text-blue-700 disabled:text-gray-300 disabled:cursor-not-allowed",title:`Step until ${r.name} completes`,children:Z.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",className:"w-4 h-4",children:Z.jsx("path",{fillRule:"evenodd",d:"M4.5 5.653c0-1.426 1.529-2.33 2.779-1.643l11.54 6.348c1.295.712 1.295 2.573 0 3.285L7.28 19.991c-1.25.687-2.779-.217-2.779-1.643V5.653z",clipRule:"evenodd"})})}),Z.jsx("span",{className:"font-medium text-gray-900",children:r.name})]})}),Z.jsx("td",{className:"px-4 py-2",children:Z.jsx(YZe,{status:r.status})}),Z.jsx("td",{className:"px-4 py-2 text-center text-gray-600",children:r.firstIteration!==null?r.firstIteration:""}),Z.jsx("td",{className:"px-4 py-2 text-gray-600",children:r.iterations}),Z.jsx("td",{className:"px-4 py-2",children:Z.jsx(JZe,{progress:r.progress})}),Z.jsx("td",{className:"px-4 py-2 text-gray-600",children:s(r.timeSpent)}),Z.jsx("td",{className:"px-4 py-2 text-gray-500",children:Z.jsx(KZe,{stats:r.stats})}),Z.jsx("td",{className:"px-4 py-2",children:r.solverInstance?Z.jsxs("button",{onClick:()=>o(r),className:"flex items-center gap-1 text-blue-500 hover:text-blue-700",title:`Download input for ${r.name}`,children:[Z.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",className:"w-4 h-4",children:Z.jsx("path",{fillRule:"evenodd",d:"M12 2.25a.75.75 0 01.75.75v11.69l3.22-3.22a.75.75 0 111.06 1.06l-4.5 4.5a.75.75 0 01-1.06 0l-4.5-4.5a.75.75 0 111.06-1.06l3.22 3.22V3a.75.75 0 01.75-.75zm-9 13.5a.75.75 0 01.75.75v2.25a1.5 1.5 0 001.5 1.5h13.5a1.5 1.5 0 001.5-1.5V16.5a.75.75 0 011.5 0v2.25a3 3 0 01-3 3H5.25a3 3 0 01-3-3V16.5a.75.75 0 01.75-.75z",clipRule:"evenodd"})}),Z.jsx("span",{children:"Input"})]}):null})]},r.name))})]})})]})},OZe=class extends nn.Component{constructor(e){super(e),this.state={hasError:!1}}static getDerivedStateFromError(){return{hasError:!0}}componentDidCatch(e){console.error("InteractiveGraphics render error:",e)}render(){return this.state.hasError?this.props.fallback:this.props.children}};function WZe({graphics:e}){const A=e.points??[],t=e.lines??[],i=e.rects??[],n=e.circles??[],o=e.texts??[];let s=Number.POSITIVE_INFINITY,r=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY,g=Number.NEGATIVE_INFINITY;const c=(E,h)=>{typeof E=="number"&&(E<s&&(s=E),E>a&&(a=E)),typeof h=="number"&&(h<r&&(r=h),h>g&&(g=h))};for(const E of A)c(E.x,E.y);for(const E of t){const h=E.points??[];for(const u of h)c(u.x,u.y)}for(const E of i){const h=E.x??0,u=E.y??0,d=E.width??0,f=E.height??0;c(h,u),c(h+d,u+f)}for(const E of n){const h=E.x??0,u=E.y??0,d=E.radius??1;c(h-d,u-d),c(h+d,u+d)}for(const E of o)c(E.x,E.y);(!isFinite(s)||!isFinite(r)||!isFinite(a)||!isFinite(g))&&(s=-20,r=-20,a=20,g=20);const I=10,l=s-I,B=r-I,C=Math.max(1,a-s+2*I),Q=Math.max(1,g-r+2*I);return Z.jsxs("svg",{className:"w-full h-[400px] bg-white",viewBox:`${l} ${B} ${C} ${Q}`,role:"img","aria-label":"Graphics fallback",children:[i.map((E,h)=>Z.jsx("rect",{x:E.x??0,y:E.y??0,width:E.width??0,height:E.height??0,fill:"none",stroke:E.strokeColor??"black",strokeWidth:E.strokeWidth??1},`rect-${h}`)),t.map((E,h)=>Z.jsx("polyline",{fill:"none",stroke:E.strokeColor??"black",strokeWidth:E.strokeWidth??1,points:(E.points??[]).map(u=>`${u.x??0},${u.y??0}`).join(" ")},`line-${h}`)),n.map((E,h)=>Z.jsx("circle",{cx:E.x??0,cy:E.y??0,r:E.radius??1.5,fill:E.fillColor??"none",stroke:E.strokeColor??"black",strokeWidth:E.strokeWidth??1},`circle-${h}`)),A.map((E,h)=>Z.jsx("circle",{cx:E.x??0,cy:E.y??0,r:E.radius??1.5,fill:E.color??"black"},`point-${h}`)),o.map((E,h)=>Z.jsx("text",{x:E.x??0,y:E.y??0,fontSize:E.fontSize??10,fill:E.color??"black",children:E.text??""},`text-${h}`))]})}var ZZe=({solver:e,animationSpeed:A=25,onSolverStarted:t,onSolverCompleted:i})=>{const[n,o]=AA.useReducer(c=>c+1,0),s=AA.useMemo(()=>{try{return e.visualize()||{points:[],lines:[],rects:[],circles:[]}}catch(c){return console.error("Visualization error:",c),{points:[],lines:[],rects:[],circles:[]}}},[e,n]),r=AA.useMemo(()=>(s.rects?.length||0)===0&&(s.lines?.length||0)===0&&(s.points?.length||0)===0&&(s.circles?.length||0)===0,[s]);AA.useEffect(()=>{if(!(typeof document>"u")&&!document.querySelector('script[src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"]')){const c=document.createElement("script");c.src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4",document.head.appendChild(c)}},[]);const a=e.pipelineDef!==void 0,g=c=>{const I=e;if(!e.solved&&!e.failed){for(;!e.solved&&!e.failed&&I.currentPipelineStepIndex<=I.pipelineDef.findIndex(l=>l.solverName===c);)e.step();o()}};return Z.jsxs("div",{children:[Z.jsx(LZe,{solver:e,triggerRender:o,animationSpeed:A,onSolverStarted:t,onSolverCompleted:i}),r?Z.jsx("div",{className:"p-4 text-gray-500",children:"No Graphics Yet"}):Z.jsx(OZe,{fallback:Z.jsx(WZe,{graphics:s}),children:Z.jsx(RZe,{graphics:s})}),a&&Z.jsx(qZe,{solver:e,onStepUntilPhase:g})]})};const VZe=()=>{AA.useEffect(()=>{const e="tailwind-cdn-script";if(document.getElementById(e)||window.tailwind)return;const A=document.createElement("div");A.className="hidden",document.body.appendChild(A);const t=window.getComputedStyle(A).display==="none";if(document.body.removeChild(A),t)return;const i=document.createElement("script");i.id=e,i.src="https://cdn.tailwindcss.com",document.head.appendChild(i)},[])},jZe=e=>e.toLowerCase().includes("pack")?UGe:e.toLowerCase().includes("rout")?PGe:_Ge,zZe=({solverEvents:e=[]})=>{const[A,t]=AA.useState(null);VZe();const i=AA.useMemo(()=>{const r=new Map;for(const a of e){const g=`${a.componentName}-${a.solverName}`;r.set(g,a)}return r},[e]),n=AA.useMemo(()=>Array.from(i.keys()),[i]),o=A?i.get(A):null,s=AA.useMemo(()=>{if(!o)return{instance:null,error:null,classFound:!1};const r=rrA[o.solverName];if(!r)return{instance:null,error:`Solver class "${o.solverName}" not found in SOLVERS registry. Available: ${Object.keys(rrA).join(", ")}`,classFound:!1};try{const a=o.solverParams,g=a?.input!==void 0?a.input:a;return{instance:new r(g),error:null,classFound:!0}}catch(a){const g=a instanceof Error?a.message:String(a);return console.error("Failed to reconstruct solver:",a),{instance:null,error:`Failed to instantiate solver: ${g}`,classFound:!0}}},[o]);return e.length===0?Z.jsx("div",{className:"rf-p-4",children:Z.jsx("div",{className:"rf-bg-gray-50 rf-rounded-md rf-border rf-border-gray-200",children:Z.jsxs("div",{className:"rf-p-4",children:[Z.jsx("h3",{className:"rf-text-lg rf-font-semibold rf-text-gray-800 rf-mb-3",children:"No Solvers Detected"}),Z.jsx("p",{className:"rf-text-sm rf-text-gray-600",children:"Solvers will appear here when the circuit runs. Solvers are used for tasks like component packing and autorouting."})]})})}):Z.jsxs("div",{className:"rf-flex rf-h-full rf-overflow-hidden",children:[Z.jsxs("div",{className:"rf-w-64 rf-border-r rf-border-gray-200 rf-overflow-y-auto rf-flex-shrink-0",children:[Z.jsxs("div",{className:"rf-text-xs rf-font-semibold rf-text-gray-500 rf-px-3 rf-py-2 rf-bg-gray-50 rf-border-b rf-border-gray-200",children:[n.length," ",n.length===1?"Solver":"Solvers"]}),n.map(r=>{const a=i.get(r),g=A===r;return Z.jsx("div",{className:`rf-px-3 rf-py-2 rf-cursor-pointer rf-border-b rf-border-gray-100 ${g?"rf-bg-blue-50 rf-border-l-2 rf-border-l-blue-500":"hover:rf-bg-gray-50"}`,onClick:()=>t(r),children:(()=>{const c=jZe(a.solverName);return Z.jsxs("div",{className:"rf-flex rf-items-center rf-gap-2",children:[Z.jsx(c,{className:"rf-w-4 rf-h-4 rf-text-blue-500 rf-flex-shrink-0"}),Z.jsxs("div",{className:"rf-flex-1 rf-min-w-0",children:[Z.jsx("div",{className:"rf-text-sm rf-font-medium rf-text-gray-800 rf-truncate",children:a.componentName}),Z.jsx("div",{className:"rf-text-xs rf-text-gray-500 rf-truncate",children:a.solverName})]})]})})()},r)})]}),Z.jsx("div",{className:"rf-flex-1 rf-overflow-hidden",children:o?s.instance?Z.jsx(dD,{fallback:Z.jsx("div",{className:"rf-p-4",children:Z.jsxs("div",{className:"rf-bg-red-50 rf-rounded-md rf-border rf-border-red-200 rf-p-4",children:[Z.jsx("h3",{className:"rf-text-lg rf-font-semibold rf-text-red-800 rf-mb-2",children:"Error Loading Solver Debugger"}),Z.jsxs("p",{className:"rf-text-sm rf-text-red-600",children:["Failed to render the solver debugger for"," ",o.solverName]})]})}),children:Z.jsx(ZZe,{solver:s.instance})}):Z.jsxs("div",{className:"rf-p-4",children:[Z.jsxs("div",{className:"rf-mb-4",children:[Z.jsx("h3",{className:"rf-text-lg rf-font-semibold rf-text-gray-800",children:o.solverName}),Z.jsxs("p",{className:"rf-text-sm rf-text-gray-500",children:["Component: ",o.componentName]})]}),s.error&&Z.jsx("div",{className:`rf-rounded-md rf-border rf-p-4 rf-mb-4 ${s.classFound?"rf-bg-red-50 rf-border-red-200":"rf-bg-yellow-50 rf-border-yellow-200"}`,children:Z.jsx("p",{className:`rf-text-sm ${s.classFound?"rf-text-red-700":"rf-text-yellow-700"}`,children:s.error})}),Z.jsxs("div",{className:"rf-border rf-border-gray-200 rf-rounded-md rf-overflow-hidden",children:[Z.jsx("div",{className:"rf-px-3 rf-py-2 rf-bg-gray-50",children:Z.jsx("span",{className:"rf-text-sm rf-font-medium rf-text-gray-700",children:"Solver Parameters"})}),Z.jsx("div",{className:"rf-p-3 rf-bg-white rf-border-t rf-border-gray-200",children:Z.jsx("pre",{className:"rf-text-xs rf-font-mono rf-text-gray-600 rf-whitespace-pre-wrap rf-overflow-x-auto",children:JSON.stringify(o.solverParams,null,2)})})]})]}):Z.jsx("div",{className:"rf-flex rf-items-center rf-justify-center rf-h-full",children:Z.jsx("p",{className:"rf-text-sm rf-text-gray-500",children:"Select a solver from the list to view details"})})})]})},pct=({errorMessage:e,errorStack:A,circuitJsonErrors:t})=>{AA.useEffect(()=>{if(e){const i=new Error(e);A&&(i.stack=A);try{UK.captureException(i)}catch{}}},[e,A]),AA.useEffect(()=>{if(t&&t.length>0)for(const i of t){const n=new Error(i.message||"Circuit JSON Error");i.stack&&(n.stack=i.stack);try{UK.captureException(n,{error_type:i.type})}catch{}}},[t])},fct="0.0.1636",XZe={version:fct},VpA={BASE_URL:"/",DEV:!1,MODE:"production",PROD:!0,SSR:!1},jpA=new Map,BV=e=>{const A=jpA.get(e);return A?Object.fromEntries(Object.entries(A.stores).map(([t,i])=>[t,i.getState()])):{}},$Ze=(e,A,t)=>{if(e===void 0)return{type:"untracked",connection:A.connect(t)};const i=jpA.get(t.name);if(i)return{type:"tracked",store:e,...i};const n={connection:A.connect(t),stores:{}};return jpA.set(t.name,n),{type:"tracked",store:e,...n}},yct=(e,A={})=>(t,i,n)=>{const{enabled:o,anonymousActionType:s,store:r,...a}=A;let g;try{g=(o??(VpA?"production":void 0)!=="production")&&window.__REDUX_DEVTOOLS_EXTENSION__}catch{}if(!g)return(VpA?"production":void 0)!=="production"&&o&&console.warn("[zustand devtools middleware] Please install/enable Redux devtools extension"),e(t,i,n);const{connection:c,...I}=$Ze(r,g,a);let l=!0;n.setState=(Q,E,h)=>{const u=t(Q,E);if(!l)return u;const d=h===void 0?{type:s||"anonymous"}:typeof h=="string"?{type:h}:h;return r===void 0?(c?.send(d,i()),u):(c?.send({...d,type:`${r}/${d.type}`},{...BV(a.name),[r]:n.getState()}),u)};const B=(...Q)=>{const E=l;l=!1,t(...Q),l=E},C=e(n.setState,i,n);if(I.type==="untracked"?c?.init(C):(I.stores[I.store]=n,c?.init(Object.fromEntries(Object.entries(I.stores).map(([Q,E])=>[Q,Q===I.store?C:E.getState()])))),n.dispatchFromDevtools&&typeof n.dispatch=="function"){let Q=!1;const E=n.dispatch;n.dispatch=(...h)=>{(VpA?"production":void 0)!=="production"&&h[0].type==="__setState"&&!Q&&(console.warn('[zustand devtools middleware] "__setState" action type is reserved to set state from the devtools. Avoid using it.'),Q=!0),E(...h)}}return c.subscribe(Q=>{var E;switch(Q.type){case"ACTION":if(typeof Q.payload!="string"){console.error("[zustand devtools middleware] Unsupported action format");return}return zpA(Q.payload,h=>{if(h.type==="__setState"){if(r===void 0){B(h.state);return}Object.keys(h.state).length!==1&&console.error(`
|
|
5687
|
+
`,I=new Blob([c],{type:"text/plain"}),l=URL.createObjectURL(I),B=document.createElement("a");B.href=l,B.download=`${g}.test.ts`,B.click(),URL.revokeObjectURL(l)}catch(a){alert(`Error generating test.ts for ${e.constructor.name}: ${a instanceof Error?a.message:String(a)}`)}i(!1)};return Z.jsxs("div",{className:`relative ${A}`,ref:n,children:[Z.jsx("button",{className:"px-2 py-1 rounded text-xs cursor-pointer",onClick:()=>i(!t),title:`Download options for ${e.constructor.name}`,children:e.constructor.name}),t&&Z.jsxs("div",{className:"absolute top-full left-0 mt-1 bg-white border border-gray-300 rounded shadow-lg z-10 min-w-[150px]",children:[Z.jsx("button",{className:"w-full text-left px-3 py-2 hover:bg-gray-100 text-xs",onClick:o,children:"Download JSON"}),Z.jsx("button",{className:"w-full text-left px-3 py-2 hover:bg-gray-100 text-xs",onClick:s,children:"Download page.tsx"}),Z.jsx("button",{className:"w-full text-left px-3 py-2 hover:bg-gray-100 text-xs",onClick:r,children:"Download test.ts"})]})]})},dct=e=>e.activeSubSolver?[e,...dct(e.activeSubSolver)]:[e],vZe=({solver:e})=>{const A=dct(e);return Z.jsx("div",{className:"flex gap-1 items-center text-sm pt-1",children:A.map((t,i)=>Z.jsxs("div",{className:"flex items-center",children:[i>0&&Z.jsx("span",{className:"text-gray-400 mx-1",children:"→"}),Z.jsx(NZe,{solver:t})]},t.constructor.name))})},LZe=({solver:e,triggerRender:A,animationSpeed:t=25,onSolverStarted:i,onSolverCompleted:n})=>{const[o,s]=AA.useReducer(Q=>!Q,!1),r=AA.useRef(void 0),a=()=>{!e.solved&&!e.failed&&(e.step(),A())},g=()=>{!e.solved&&!e.failed&&(i&&i(e),e.solve(),A(),n&&n(e))},c=()=>{o?(r.current&&(clearInterval(r.current),r.current=void 0),s()):(s(),r.current=setInterval(()=>{if(e.solved||e.failed){r.current&&(clearInterval(r.current),r.current=void 0),s(),A(),n&&e.solved&&n(e);return}e.step(),A()},t))},I=()=>{const Q=e;if(Q.getCurrentPhase&&!e.solved&&!e.failed){const E=Q.getCurrentPhase();for(;Q.getCurrentPhase()===E&&!e.solved&&!e.failed;)e.step();A()}},l=()=>{if(e.solved||e.failed||o)return;const Q=window.prompt("Step until which iteration?",`${e.iterations}`);if(Q===null)return;const E=Number(Q);if(!Number.isFinite(E)){window.alert("Please enter a valid number for the iteration");return}for(;e.iterations<E&&!e.solved&&!e.failed;)e.step();A(),e.solved&&n&&n(e)};AA.useEffect(()=>()=>{r.current&&clearInterval(r.current)},[]),AA.useEffect(()=>{(e.solved||e.failed)&&o&&(r.current&&(clearInterval(r.current),r.current=void 0),s())},[e.solved,e.failed,o]);const B=e.getCurrentPhase!==void 0,C=B?e.getCurrentPhase():null;return Z.jsxs("div",{className:"space-y-2 p-2 border-b",children:[Z.jsx("div",{className:"flex items-center",children:Z.jsx(vZe,{solver:e})}),Z.jsxs("div",{className:"flex gap-2 items-center flex-wrap",children:[Z.jsx("button",{onClick:a,disabled:e.solved||e.failed||o,className:"bg-blue-500 hover:bg-blue-600 disabled:bg-gray-300 text-white px-3 py-1 rounded text-sm",children:"Step"}),Z.jsx("button",{onClick:g,disabled:e.solved||e.failed||o,className:"bg-green-500 hover:bg-green-600 disabled:bg-gray-300 text-white px-3 py-1 rounded text-sm",children:"Solve"}),Z.jsx("button",{onClick:c,disabled:e.solved||e.failed,className:`px-3 py-1 rounded text-white text-sm ${o?"bg-red-500 hover:bg-red-600":"bg-yellow-500 hover:bg-yellow-600"} disabled:bg-gray-300`,children:o?"Stop":"Animate"}),Z.jsx("button",{onClick:l,disabled:e.solved||e.failed||o,className:"bg-orange-500 hover:bg-orange-600 disabled:bg-gray-300 text-white px-3 py-1 rounded text-sm",children:"Step Until Iteration"}),B&&Z.jsx("button",{onClick:I,disabled:e.solved||e.failed||o,className:"bg-purple-500 hover:bg-purple-600 disabled:bg-gray-300 text-white px-3 py-1 rounded text-sm",children:"Next Stage"}),Z.jsxs("div",{className:"text-sm text-gray-600",children:["Iterations: ",e.iterations]}),e.timeToSolve!==void 0&&Z.jsxs("div",{className:"text-sm text-gray-600",children:["Time: ",(e.timeToSolve/1e3).toFixed(3),"s"]}),C&&Z.jsxs("div",{className:"text-sm text-gray-600",children:["Phase: ",Z.jsx("span",{className:"font-medium",children:C})]}),e.solved&&Z.jsx("div",{className:"px-2 py-1 bg-green-100 text-green-800 rounded text-sm",children:"Solved"}),e.failed&&Z.jsx("div",{className:"px-2 py-1 bg-red-100 text-red-800 rounded text-sm",children:"Failed"})]}),e.error&&Z.jsxs("div",{className:"text-red-600 text-sm",children:["Error: ",e.error]})]})},UZe=(e,A,t)=>{const i=e.currentPipelineStepIndex;return A<i?"Completed":A===i&&e.activeSubSolver?e.activeSubSolver.failed?"Failed":"In Progress":"Not Started"},HZe=(e,A)=>{const i=e.pipelineDef[A].solverName,n=UZe(e,A),o=e[i],s=e.firstIterationOfPhase?.[i]??null,r=e.iterations;let a=0;if(n==="Completed"){const l=e.pipelineDef[A+1],B=l?e.firstIterationOfPhase?.[l.solverName]:void 0;B!==void 0&&s!==null?a=B-s:s!==null&&(a=r-s)}else n==="In Progress"&&s!==null&&(a=r-s);const g=e.timeSpentOnPhase?.[i]??0;let c=0;n==="Completed"?c=1:n==="In Progress"&&o&&(c=o.progress??0);const I=o?.stats??null;return{index:A,name:i,status:n,firstIteration:s,iterations:a,progress:c,timeSpent:g,stats:I&&Object.keys(I).length>0?I:null,solverInstance:o??null}},YZe=({status:e})=>{const A={"Not Started":"text-blue-600","In Progress":"text-yellow-600",Completed:"text-green-600",Failed:"text-red-600"};return Z.jsx("span",{className:`font-medium ${A[e]}`,children:e})},JZe=({progress:e})=>{if(e===0)return null;const A=Math.round(e*100);return Z.jsxs("div",{className:"flex items-center gap-2",children:[Z.jsx("div",{className:"w-20 h-2 bg-gray-200 rounded overflow-hidden",children:Z.jsx("div",{className:"h-full bg-blue-500 transition-all duration-200",style:{width:`${A}%`}})}),Z.jsxs("span",{className:"text-xs text-gray-500",children:[A,"%"]})]})},TZe=e=>Object.entries(e).map(([A,t])=>`${A}: ${t}`).join(", "),KZe=({stats:e})=>{if(!e||Object.keys(e).length===0)return Z.jsx("span",{children:"-"});const A=Object.entries(e),t=TZe(e);return Z.jsxs("details",{className:"cursor-pointer",children:[Z.jsx("summary",{className:"whitespace-nowrap overflow-hidden text-ellipsis max-w-[200px]",children:t}),Z.jsx("div",{className:"mt-1 text-xs",children:A.map(([i,n])=>Z.jsxs("div",{children:[i,": ",String(n)]},i))})]})},ZpA=e=>{if(e===null||typeof e!="object")return e;if(Array.isArray(e))return e.map(ZpA);const A={};for(const[t,i]of Object.entries(e))t.startsWith("_")||(A[t]=ZpA(i));return A},PZe=(e,A)=>{try{if(typeof e.getConstructorParams!="function"){alert(`getConstructorParams() is not implemented for ${A}`);return}const t=ZpA(e.getConstructorParams()),i=new Blob([JSON.stringify(t,null,2)],{type:"application/json"}),n=URL.createObjectURL(i),o=document.createElement("a");o.href=n,o.download=`${A}_input.json`,o.click(),URL.revokeObjectURL(n)}catch(t){alert(`Error downloading input for ${A}: ${t instanceof Error?t.message:String(t)}`)}},qZe=({solver:e,onStepUntilPhase:A,onDownloadInput:t})=>{const i=e.pipelineDef.map((r,a)=>HZe(e,a)),n=r=>{A?.(r)},o=r=>{r.solverInstance&&(t?t(r.solverInstance,r.name):PZe(r.solverInstance,r.name))},s=r=>`${(r/1e3).toFixed(2)}s`;return Z.jsxs("div",{className:"border-t border-gray-200",children:[Z.jsx("div",{className:"px-4 py-2 bg-gray-50 border-b border-gray-200",children:Z.jsx("h3",{className:"text-sm font-semibold text-gray-700",children:"Pipeline Steps"})}),Z.jsx("div",{className:"overflow-x-auto",children:Z.jsxs("table",{className:"w-full text-sm",children:[Z.jsx("thead",{children:Z.jsxs("tr",{className:"bg-gray-50 border-b border-gray-200",children:[Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Step"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Status"}),Z.jsxs("th",{className:"px-4 py-2 text-center font-semibold text-gray-700",children:["i",Z.jsx("sub",{children:"0"})]}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Iterations"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Progress"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Time"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Stats"}),Z.jsx("th",{className:"px-4 py-2 text-left font-semibold text-gray-700",children:"Input"})]})}),Z.jsx("tbody",{children:i.map(r=>Z.jsxs("tr",{className:`border-b border-gray-100 ${r.status==="In Progress"?"bg-yellow-50":""}`,children:[Z.jsx("td",{className:"px-4 py-2",children:Z.jsxs("div",{className:"flex items-center gap-2",children:[Z.jsx("span",{className:"text-gray-400 w-6",children:String(r.index+1).padStart(2,"0")}),Z.jsx("button",{onClick:()=>n(r.name),disabled:r.status==="Completed"||e.solved||e.failed,className:"text-blue-500 hover:text-blue-700 disabled:text-gray-300 disabled:cursor-not-allowed",title:`Step until ${r.name} completes`,children:Z.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",className:"w-4 h-4",children:Z.jsx("path",{fillRule:"evenodd",d:"M4.5 5.653c0-1.426 1.529-2.33 2.779-1.643l11.54 6.348c1.295.712 1.295 2.573 0 3.285L7.28 19.991c-1.25.687-2.779-.217-2.779-1.643V5.653z",clipRule:"evenodd"})})}),Z.jsx("span",{className:"font-medium text-gray-900",children:r.name})]})}),Z.jsx("td",{className:"px-4 py-2",children:Z.jsx(YZe,{status:r.status})}),Z.jsx("td",{className:"px-4 py-2 text-center text-gray-600",children:r.firstIteration!==null?r.firstIteration:""}),Z.jsx("td",{className:"px-4 py-2 text-gray-600",children:r.iterations}),Z.jsx("td",{className:"px-4 py-2",children:Z.jsx(JZe,{progress:r.progress})}),Z.jsx("td",{className:"px-4 py-2 text-gray-600",children:s(r.timeSpent)}),Z.jsx("td",{className:"px-4 py-2 text-gray-500",children:Z.jsx(KZe,{stats:r.stats})}),Z.jsx("td",{className:"px-4 py-2",children:r.solverInstance?Z.jsxs("button",{onClick:()=>o(r),className:"flex items-center gap-1 text-blue-500 hover:text-blue-700",title:`Download input for ${r.name}`,children:[Z.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",className:"w-4 h-4",children:Z.jsx("path",{fillRule:"evenodd",d:"M12 2.25a.75.75 0 01.75.75v11.69l3.22-3.22a.75.75 0 111.06 1.06l-4.5 4.5a.75.75 0 01-1.06 0l-4.5-4.5a.75.75 0 111.06-1.06l3.22 3.22V3a.75.75 0 01.75-.75zm-9 13.5a.75.75 0 01.75.75v2.25a1.5 1.5 0 001.5 1.5h13.5a1.5 1.5 0 001.5-1.5V16.5a.75.75 0 011.5 0v2.25a3 3 0 01-3 3H5.25a3 3 0 01-3-3V16.5a.75.75 0 01.75-.75z",clipRule:"evenodd"})}),Z.jsx("span",{children:"Input"})]}):null})]},r.name))})]})})]})},OZe=class extends nn.Component{constructor(e){super(e),this.state={hasError:!1}}static getDerivedStateFromError(){return{hasError:!0}}componentDidCatch(e){console.error("InteractiveGraphics render error:",e)}render(){return this.state.hasError?this.props.fallback:this.props.children}};function WZe({graphics:e}){const A=e.points??[],t=e.lines??[],i=e.rects??[],n=e.circles??[],o=e.texts??[];let s=Number.POSITIVE_INFINITY,r=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY,g=Number.NEGATIVE_INFINITY;const c=(E,h)=>{typeof E=="number"&&(E<s&&(s=E),E>a&&(a=E)),typeof h=="number"&&(h<r&&(r=h),h>g&&(g=h))};for(const E of A)c(E.x,E.y);for(const E of t){const h=E.points??[];for(const u of h)c(u.x,u.y)}for(const E of i){const h=E.x??0,u=E.y??0,d=E.width??0,f=E.height??0;c(h,u),c(h+d,u+f)}for(const E of n){const h=E.x??0,u=E.y??0,d=E.radius??1;c(h-d,u-d),c(h+d,u+d)}for(const E of o)c(E.x,E.y);(!isFinite(s)||!isFinite(r)||!isFinite(a)||!isFinite(g))&&(s=-20,r=-20,a=20,g=20);const I=10,l=s-I,B=r-I,C=Math.max(1,a-s+2*I),Q=Math.max(1,g-r+2*I);return Z.jsxs("svg",{className:"w-full h-[400px] bg-white",viewBox:`${l} ${B} ${C} ${Q}`,role:"img","aria-label":"Graphics fallback",children:[i.map((E,h)=>Z.jsx("rect",{x:E.x??0,y:E.y??0,width:E.width??0,height:E.height??0,fill:"none",stroke:E.strokeColor??"black",strokeWidth:E.strokeWidth??1},`rect-${h}`)),t.map((E,h)=>Z.jsx("polyline",{fill:"none",stroke:E.strokeColor??"black",strokeWidth:E.strokeWidth??1,points:(E.points??[]).map(u=>`${u.x??0},${u.y??0}`).join(" ")},`line-${h}`)),n.map((E,h)=>Z.jsx("circle",{cx:E.x??0,cy:E.y??0,r:E.radius??1.5,fill:E.fillColor??"none",stroke:E.strokeColor??"black",strokeWidth:E.strokeWidth??1},`circle-${h}`)),A.map((E,h)=>Z.jsx("circle",{cx:E.x??0,cy:E.y??0,r:E.radius??1.5,fill:E.color??"black"},`point-${h}`)),o.map((E,h)=>Z.jsx("text",{x:E.x??0,y:E.y??0,fontSize:E.fontSize??10,fill:E.color??"black",children:E.text??""},`text-${h}`))]})}var ZZe=({solver:e,animationSpeed:A=25,onSolverStarted:t,onSolverCompleted:i})=>{const[n,o]=AA.useReducer(c=>c+1,0),s=AA.useMemo(()=>{try{return e.visualize()||{points:[],lines:[],rects:[],circles:[]}}catch(c){return console.error("Visualization error:",c),{points:[],lines:[],rects:[],circles:[]}}},[e,n]),r=AA.useMemo(()=>(s.rects?.length||0)===0&&(s.lines?.length||0)===0&&(s.points?.length||0)===0&&(s.circles?.length||0)===0,[s]);AA.useEffect(()=>{if(!(typeof document>"u")&&!document.querySelector('script[src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"]')){const c=document.createElement("script");c.src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4",document.head.appendChild(c)}},[]);const a=e.pipelineDef!==void 0,g=c=>{const I=e;if(!e.solved&&!e.failed){for(;!e.solved&&!e.failed&&I.currentPipelineStepIndex<=I.pipelineDef.findIndex(l=>l.solverName===c);)e.step();o()}};return Z.jsxs("div",{children:[Z.jsx(LZe,{solver:e,triggerRender:o,animationSpeed:A,onSolverStarted:t,onSolverCompleted:i}),r?Z.jsx("div",{className:"p-4 text-gray-500",children:"No Graphics Yet"}):Z.jsx(OZe,{fallback:Z.jsx(WZe,{graphics:s}),children:Z.jsx(RZe,{graphics:s})}),a&&Z.jsx(qZe,{solver:e,onStepUntilPhase:g})]})};const VZe=()=>{AA.useEffect(()=>{const e="tailwind-cdn-script";if(document.getElementById(e)||window.tailwind)return;const A=document.createElement("div");A.className="hidden",document.body.appendChild(A);const t=window.getComputedStyle(A).display==="none";if(document.body.removeChild(A),t)return;const i=document.createElement("script");i.id=e,i.src="https://cdn.tailwindcss.com",document.head.appendChild(i)},[])},jZe=e=>e.toLowerCase().includes("pack")?UGe:e.toLowerCase().includes("rout")?PGe:_Ge,zZe=({solverEvents:e=[]})=>{const[A,t]=AA.useState(null);VZe();const i=AA.useMemo(()=>{const r=new Map;for(const a of e){const g=`${a.componentName}-${a.solverName}`;r.set(g,a)}return r},[e]),n=AA.useMemo(()=>Array.from(i.keys()),[i]),o=A?i.get(A):null,s=AA.useMemo(()=>{if(!o)return{instance:null,error:null,classFound:!1};const r=rrA[o.solverName];if(!r)return{instance:null,error:`Solver class "${o.solverName}" not found in SOLVERS registry. Available: ${Object.keys(rrA).join(", ")}`,classFound:!1};try{const a=o.solverParams,g=a?.input!==void 0?a.input:a;return{instance:new r(g),error:null,classFound:!0}}catch(a){const g=a instanceof Error?a.message:String(a);return console.error("Failed to reconstruct solver:",a),{instance:null,error:`Failed to instantiate solver: ${g}`,classFound:!0}}},[o]);return e.length===0?Z.jsx("div",{className:"rf-p-4",children:Z.jsx("div",{className:"rf-bg-gray-50 rf-rounded-md rf-border rf-border-gray-200",children:Z.jsxs("div",{className:"rf-p-4",children:[Z.jsx("h3",{className:"rf-text-lg rf-font-semibold rf-text-gray-800 rf-mb-3",children:"No Solvers Detected"}),Z.jsx("p",{className:"rf-text-sm rf-text-gray-600",children:"Solvers will appear here when the circuit runs. Solvers are used for tasks like component packing and autorouting."})]})})}):Z.jsxs("div",{className:"rf-flex rf-h-full rf-overflow-hidden",children:[Z.jsxs("div",{className:"rf-w-64 rf-border-r rf-border-gray-200 rf-overflow-y-auto rf-flex-shrink-0",children:[Z.jsxs("div",{className:"rf-text-xs rf-font-semibold rf-text-gray-500 rf-px-3 rf-py-2 rf-bg-gray-50 rf-border-b rf-border-gray-200",children:[n.length," ",n.length===1?"Solver":"Solvers"]}),n.map(r=>{const a=i.get(r),g=A===r;return Z.jsx("div",{className:`rf-px-3 rf-py-2 rf-cursor-pointer rf-border-b rf-border-gray-100 ${g?"rf-bg-blue-50 rf-border-l-2 rf-border-l-blue-500":"hover:rf-bg-gray-50"}`,onClick:()=>t(r),children:(()=>{const c=jZe(a.solverName);return Z.jsxs("div",{className:"rf-flex rf-items-center rf-gap-2",children:[Z.jsx(c,{className:"rf-w-4 rf-h-4 rf-text-blue-500 rf-flex-shrink-0"}),Z.jsxs("div",{className:"rf-flex-1 rf-min-w-0",children:[Z.jsx("div",{className:"rf-text-sm rf-font-medium rf-text-gray-800 rf-truncate",children:a.componentName}),Z.jsx("div",{className:"rf-text-xs rf-text-gray-500 rf-truncate",children:a.solverName})]})]})})()},r)})]}),Z.jsx("div",{className:"rf-flex-1 rf-overflow-hidden",children:o?s.instance?Z.jsx(dD,{fallback:Z.jsx("div",{className:"rf-p-4",children:Z.jsxs("div",{className:"rf-bg-red-50 rf-rounded-md rf-border rf-border-red-200 rf-p-4",children:[Z.jsx("h3",{className:"rf-text-lg rf-font-semibold rf-text-red-800 rf-mb-2",children:"Error Loading Solver Debugger"}),Z.jsxs("p",{className:"rf-text-sm rf-text-red-600",children:["Failed to render the solver debugger for"," ",o.solverName]})]})}),children:Z.jsx(ZZe,{solver:s.instance})}):Z.jsxs("div",{className:"rf-p-4",children:[Z.jsxs("div",{className:"rf-mb-4",children:[Z.jsx("h3",{className:"rf-text-lg rf-font-semibold rf-text-gray-800",children:o.solverName}),Z.jsxs("p",{className:"rf-text-sm rf-text-gray-500",children:["Component: ",o.componentName]})]}),s.error&&Z.jsx("div",{className:`rf-rounded-md rf-border rf-p-4 rf-mb-4 ${s.classFound?"rf-bg-red-50 rf-border-red-200":"rf-bg-yellow-50 rf-border-yellow-200"}`,children:Z.jsx("p",{className:`rf-text-sm ${s.classFound?"rf-text-red-700":"rf-text-yellow-700"}`,children:s.error})}),Z.jsxs("div",{className:"rf-border rf-border-gray-200 rf-rounded-md rf-overflow-hidden",children:[Z.jsx("div",{className:"rf-px-3 rf-py-2 rf-bg-gray-50",children:Z.jsx("span",{className:"rf-text-sm rf-font-medium rf-text-gray-700",children:"Solver Parameters"})}),Z.jsx("div",{className:"rf-p-3 rf-bg-white rf-border-t rf-border-gray-200",children:Z.jsx("pre",{className:"rf-text-xs rf-font-mono rf-text-gray-600 rf-whitespace-pre-wrap rf-overflow-x-auto",children:JSON.stringify(o.solverParams,null,2)})})]})]}):Z.jsx("div",{className:"rf-flex rf-items-center rf-justify-center rf-h-full",children:Z.jsx("p",{className:"rf-text-sm rf-text-gray-500",children:"Select a solver from the list to view details"})})})]})},pct=({errorMessage:e,errorStack:A,circuitJsonErrors:t})=>{AA.useEffect(()=>{if(e){const i=new Error(e);A&&(i.stack=A);try{UK.captureException(i)}catch{}}},[e,A]),AA.useEffect(()=>{if(t&&t.length>0)for(const i of t){const n=new Error(i.message||"Circuit JSON Error");i.stack&&(n.stack=i.stack);try{UK.captureException(n,{error_type:i.type})}catch{}}},[t])},fct="0.0.1637",XZe={version:fct},VpA={BASE_URL:"/",DEV:!1,MODE:"production",PROD:!0,SSR:!1},jpA=new Map,BV=e=>{const A=jpA.get(e);return A?Object.fromEntries(Object.entries(A.stores).map(([t,i])=>[t,i.getState()])):{}},$Ze=(e,A,t)=>{if(e===void 0)return{type:"untracked",connection:A.connect(t)};const i=jpA.get(t.name);if(i)return{type:"tracked",store:e,...i};const n={connection:A.connect(t),stores:{}};return jpA.set(t.name,n),{type:"tracked",store:e,...n}},yct=(e,A={})=>(t,i,n)=>{const{enabled:o,anonymousActionType:s,store:r,...a}=A;let g;try{g=(o??(VpA?"production":void 0)!=="production")&&window.__REDUX_DEVTOOLS_EXTENSION__}catch{}if(!g)return(VpA?"production":void 0)!=="production"&&o&&console.warn("[zustand devtools middleware] Please install/enable Redux devtools extension"),e(t,i,n);const{connection:c,...I}=$Ze(r,g,a);let l=!0;n.setState=(Q,E,h)=>{const u=t(Q,E);if(!l)return u;const d=h===void 0?{type:s||"anonymous"}:typeof h=="string"?{type:h}:h;return r===void 0?(c?.send(d,i()),u):(c?.send({...d,type:`${r}/${d.type}`},{...BV(a.name),[r]:n.getState()}),u)};const B=(...Q)=>{const E=l;l=!1,t(...Q),l=E},C=e(n.setState,i,n);if(I.type==="untracked"?c?.init(C):(I.stores[I.store]=n,c?.init(Object.fromEntries(Object.entries(I.stores).map(([Q,E])=>[Q,Q===I.store?C:E.getState()])))),n.dispatchFromDevtools&&typeof n.dispatch=="function"){let Q=!1;const E=n.dispatch;n.dispatch=(...h)=>{(VpA?"production":void 0)!=="production"&&h[0].type==="__setState"&&!Q&&(console.warn('[zustand devtools middleware] "__setState" action type is reserved to set state from the devtools. Avoid using it.'),Q=!0),E(...h)}}return c.subscribe(Q=>{var E;switch(Q.type){case"ACTION":if(typeof Q.payload!="string"){console.error("[zustand devtools middleware] Unsupported action format");return}return zpA(Q.payload,h=>{if(h.type==="__setState"){if(r===void 0){B(h.state);return}Object.keys(h.state).length!==1&&console.error(`
|
|
5688
5688
|
[zustand devtools middleware] Unsupported __setState action format.
|
|
5689
5689
|
When using 'store' option in devtools(), the 'state' should have only one key, which is a value of 'store' that was passed in devtools(),
|
|
5690
5690
|
and value of this only key should be a state object. Example: { "type": "__setState", "state": { "abc123Store": { "foo": "bar" } } }
|
|
@@ -5825,8 +5825,8 @@ ${a.join(`
|
|
|
5825
5825
|
`)}};NA.register(Fii);var aEt=class cSA extends NA{static token="locked";static parentToken="group";token="locked";value;constructor(A){super(),this.value=A}static fromSexprPrimitives(A){if(A.length===0)return new cSA(!0);const t=pi(A[0]);return new cSA(t==="yes")}getString(){return this.value?"(locked yes)":"(locked no)"}};NA.register(aEt);var gEt=class ayt extends NA{static token="members";static parentToken="group";token="members";members;constructor(A){super(),this.members=A}static fromSexprPrimitives(A){const t=[];for(const i of A){const n=pi(i);n&&t.push(n)}return new ayt(t)}getString(){return this.members.length===0?"(members)":`(members ${this.members.map(t=>`"${t}"`).join(" ")})`}};NA.register(gEt);var HmA=class gyt extends NA{static token="end";static parentToken="segment";token="end";_x;_y;constructor(A,t){super(),this._x=A,this._y=t}static fromSexprPrimitives(A){const[t,i]=A,n=ai(t),o=ai(i);if(n===void 0||o===void 0)throw new Error("end expects two numeric arguments");return new gyt(n,o)}get x(){return this._x}set x(A){this._x=A}get y(){return this._y}set y(A){this._y=A}toObject(){return{x:this._x,y:this._y}}getChildren(){return[]}getString(){return`(end ${this._x} ${this._y})`}};NA.register(HmA);var Gii=new Set(["true","yes","1"]),cEt=class Zz extends Ml{static token="locked";static parentToken="segment";token="locked";constructor(A){super(A)}static fromSexprPrimitives(A){const[t]=A;return typeof t=="boolean"?new Zz(t):typeof t=="string"?new Zz(Gii.has(t.toLowerCase())):new Zz(!1)}getString(){return`(locked ${this.value?"yes":"no"})`}};NA.register(cEt);var uj=class cyt extends NA{static token="net";static parentToken="segment";token="net";_id;_name;constructor(A,t){super(),this._id=A,this._name=t}static fromSexprPrimitives(A){const[t,i]=A,n=ai(t);if(n===void 0)throw new Error("net expects a numeric identifier");const o=i===void 0?void 0:pi(i);return new cyt(n,o??void 0)}get id(){return this._id}set id(A){this._id=A}get name(){return this._name}set name(A){this._name=A===""?void 0:A}toObject(){return this._name===void 0?{id:this._id}:{id:this._id,name:this._name}}getChildren(){return[]}getString(){const A=this._name?` ${Bn(this._name)}`:"";return`(net ${this._id}${A})`}};NA.register(uj);var YmA=class Iyt extends NA{static token="start";static parentToken="segment";token="start";_x;_y;constructor(A,t){super(),this._x=A,this._y=t}static fromSexprPrimitives(A){const[t,i]=A,n=ai(t),o=ai(i);if(n===void 0||o===void 0)throw new Error("start expects two numeric arguments");return new Iyt(n,o)}get x(){return this._x}set x(A){this._x=A}get y(){return this._y}set y(A){this._y=A}toObject(){return{x:this._x,y:this._y}}getChildren(){return[]}getString(){return`(start ${this._x} ${this._y})`}};NA.register(YmA);var IEt=new Set(["start","end","width","layer","net","tstamp","uuid","locked"]),JmA=class lyt extends NA{static token="segment";token="segment";_sxStart;_sxEnd;_sxWidth;_sxLayer;_sxNet;_sxTstamp;_sxUuid;_sxLocked;constructor(A={}){super(),A.start!==void 0&&(this.start=A.start),A.end!==void 0&&(this.end=A.end),A.width!==void 0&&(this.width=A.width),A.layer!==void 0&&(this.layer=A.layer),A.net!==void 0&&(this.net=A.net),A.tstamp!==void 0&&(this.tstamp=A.tstamp),A.uuid!==void 0&&(this.uuid=A.uuid),A.locked!==void 0&&(this.locked=A.locked)}static fromSexprPrimitives(A){const t=new lyt,{propertyMap:i,arrayPropertyMap:n}=NA.parsePrimitivesToClassProperties(A,this.token),o=Object.keys(i).filter(r=>!IEt.has(r));if(o.length>0)throw new Error(`Unsupported child tokens inside segment expression: ${o.join(", ")}`);for(const[r,a]of Object.entries(n)){if(!IEt.has(r))throw new Error(`Unsupported child tokens inside segment expression: ${r}`);if(a.length>1)throw new Error(`Segment does not support repeated child tokens: ${r}`)}t._sxStart=n.start?.[0]??i.start,t._sxEnd=n.end?.[0]??i.end,t._sxWidth=n.width?.[0]??i.width,t._sxLayer=n.layer?.[0]??i.layer,t._sxNet=n.net?.[0]??i.net;const s=n.locked?.[0]??i.locked;return t._sxLocked=s&&s.value?s:void 0,t._sxTstamp=n.tstamp?.[0]??i.tstamp,t._sxUuid=n.uuid?.[0]??i.uuid,t}get start(){return this._sxStart}set start(A){this._sxStart=this.normalizeStart(A)}get end(){return this._sxEnd}set end(A){this._sxEnd=this.normalizeEnd(A)}get startPoint(){return this._sxStart?.toObject()}get endPoint(){return this._sxEnd?.toObject()}get width(){return this._sxWidth?.value}set width(A){if(A===void 0){this._sxWidth=void 0;return}this._sxWidth=A instanceof Mr?A:new Mr(A)}get widthClass(){return this._sxWidth}set widthClass(A){this._sxWidth=A}get layer(){return this._sxLayer}set layer(A){if(A===void 0){this._sxLayer=void 0;return}if(A instanceof mr){this._sxLayer=A;return}const t=Array.isArray(A)?A:[A];this._sxLayer=new mr(t)}get net(){return this._sxNet}set net(A){if(A===void 0){this._sxNet=void 0;return}if(A instanceof uj){this._sxNet=A;return}this._sxNet=new uj(A.id,A.name)}get tstamp(){return this._sxTstamp}set tstamp(A){if(A===void 0){this._sxTstamp=void 0;return}this._sxTstamp=A instanceof Zg?A:new Zg(A)}get uuid(){return this._sxUuid}set uuid(A){if(A===void 0){this._sxUuid=void 0;return}this._sxUuid=A instanceof Li?A:new Li(A)}get locked(){return this._sxLocked?.value??!1}set locked(A){this._sxLocked=A?new cEt(!0):void 0}getChildren(){const A=[];return this._sxStart&&A.push(this._sxStart),this._sxEnd&&A.push(this._sxEnd),this._sxWidth&&A.push(this._sxWidth),this._sxLayer&&A.push(this._sxLayer),this._sxNet&&A.push(this._sxNet),this._sxLocked&&A.push(this._sxLocked),this._sxTstamp&&A.push(this._sxTstamp),this._sxUuid&&A.push(this._sxUuid),A}normalizeStart(A){if(A!==void 0)return A instanceof YmA?A:new YmA(A.x,A.y)}normalizeEnd(A){if(A!==void 0)return A instanceof HmA?A:new HmA(A.x,A.y)}};NA.register(JmA);var lEt=class Byt extends NA{static token="zone";token="zone";_rawChildren=[];static fromSexprPrimitives(A){const t=new Byt;return t._rawChildren=[...A],t}get rawChildren(){return[...this._rawChildren]}set rawChildren(A){this._rawChildren=[...A]}getChildren(){return[]}getString(){const A=["(zone"];for(const t of this._rawChildren)A.push(` ${_E(t)}`);return A.push(")"),A.join(`
|
|
5826
5826
|
`)}};NA.register(lEt);var dj=class Cyt extends NA{static token="layers";token="layers";_names=[];constructor(A=[]){super(),this.names=A}static fromSexprPrimitives(A){const t=A.map(i=>typeof i=="string"||typeof i=="number"?String(i):_E(i));return new Cyt(t)}get names(){return[...this._names]}set names(A){this._names=A.map(t=>String(t))}getString(){return`(layers ${this._names.map(t=>/^[^\s()"]+$/u.test(t)&&!["nil","#t","#f"].includes(t)?t:Bn(t)).join(" ")})`}};NA.register(dj);var UJ=class extends NA{_value;quoteStringValue=!1;constructor(e){super(),this._value=e}static fromSexprPrimitives(e){const[A]=e,t=this.parsePrimitiveValue(A),i=this;return new i(t)}static parsePrimitiveValue(e){const A=pi(e);if(A===void 0)throw new Error(`${this.name} expects a primitive value`);return A}get value(){return this._value}set value(e){this._value=e}getChildren(){return[]}formatValue(){return typeof this._value=="string"?this.quoteStringValue?Bn(this._value):this._value:`${this._value}`}getString(){return`(${this.token} ${this.formatValue()})`}},Mii=class extends NA{_values;constructor(e){super(),this._values=e}static fromSexprPrimitives(e){const A=e.map(i=>{const n=ai(i);if(n===void 0)throw new Error(`${this.name} expects numeric primitives but received ${i}`);return n}),t=this;return new t(A)}get values(){return[...this._values]}set values(e){this._values=[...e]}getChildren(){return[]}getString(){return`(${this.token} ${this._values.join(" ")})`}},Rii=class extends NA{_x;_y;constructor(e,A){super(),this._x=e,this._y=A}static fromSexprPrimitives(e){const[A,t]=e,i=ai(A),n=ai(t);if(i===void 0||n===void 0)throw new Error(`${this.name} expects two numeric values`);const o=this;return new o(i,n)}get x(){return this._x}set x(e){this._x=e}get y(){return this._y}set y(e){this._y=e}getChildren(){return[]}getString(){return`(${this.token} ${this._x} ${this._y})`}},wr=class extends UJ{static parentToken="pcbplotparams"},jy=class extends wr{static parsePrimitiveValue(e){const A=ai(e);if(A===void 0)throw new Error(`pcbplotparams ${this.token} expects a numeric value`);return A}},BEt=class extends wr{static token="layerselection";token="layerselection"};NA.register(BEt);var CEt=class extends wr{static token="plot_on_all_layers_selection";token="plot_on_all_layers_selection"};NA.register(CEt);var QEt=class extends jy{static token="dashed_line_dash_ratio";token="dashed_line_dash_ratio"};NA.register(QEt);var EEt=class extends jy{static token="dashed_line_gap_ratio";token="dashed_line_gap_ratio"};NA.register(EEt);var hEt=class extends jy{static token="svgprecision";token="svgprecision"};NA.register(hEt);var uEt=class extends jy{static token="linewidth";token="linewidth"};NA.register(uEt);var dEt=class extends jy{static token="mode";token="mode"};NA.register(dEt);var pEt=class extends jy{static token="hpglpennumber";token="hpglpennumber"};NA.register(pEt);var fEt=class extends jy{static token="hpglpenspeed";token="hpglpenspeed"};NA.register(fEt);var yEt=class extends jy{static token="hpglpendiameter";token="hpglpendiameter"};NA.register(yEt);var mEt=class extends jy{static token="hpglpenoverlay";token="hpglpenoverlay"};NA.register(mEt);var wEt=class extends jy{static token="outputformat";token="outputformat"};NA.register(wEt);var DEt=class extends jy{static token="drillshape";token="drillshape"};NA.register(DEt);var SEt=class extends jy{static token="scaleselection";token="scaleselection"};NA.register(SEt);var bEt=class extends wr{static token="disableapertmacros";token="disableapertmacros"};NA.register(bEt);var xEt=class extends wr{static token="usegerberextensions";token="usegerberextensions"};NA.register(xEt);var _Et=class extends wr{static token="usegerberattributes";token="usegerberattributes"};NA.register(_Et);var kEt=class extends wr{static token="usegerberadvancedattributes";token="usegerberadvancedattributes"};NA.register(kEt);var FEt=class extends wr{static token="creategerberjobfile";token="creategerberjobfile"};NA.register(FEt);var GEt=class extends wr{static token="excludeedgelayer";token="excludeedgelayer"};NA.register(GEt);var MEt=class extends wr{static token="plotframeref";token="plotframeref"};NA.register(MEt);var REt=class extends wr{static token="viasonmask";token="viasonmask"};NA.register(REt);var NEt=class extends wr{static token="useauxorigin";token="useauxorigin"};NA.register(NEt);var vEt=class extends wr{static token="pdf_front_fp_property_popups";token="pdf_front_fp_property_popups"};NA.register(vEt);var LEt=class extends wr{static token="pdf_back_fp_property_popups";token="pdf_back_fp_property_popups"};NA.register(LEt);var UEt=class extends wr{static token="pdf_metadata";token="pdf_metadata"};NA.register(UEt);var HEt=class extends wr{static token="pdf_single_document";token="pdf_single_document"};NA.register(HEt);var YEt=class extends wr{static token="dxfpolygonmode";token="dxfpolygonmode"};NA.register(YEt);var JEt=class extends wr{static token="dxfimperialunits";token="dxfimperialunits"};NA.register(JEt);var TEt=class extends wr{static token="dxfusepcbnewfont";token="dxfusepcbnewfont"};NA.register(TEt);var KEt=class extends wr{static token="psnegative";token="psnegative"};NA.register(KEt);var PEt=class extends wr{static token="psa4output";token="psa4output"};NA.register(PEt);var qEt=class extends wr{static token="plotreference";token="plotreference"};NA.register(qEt);var OEt=class extends wr{static token="plotvalue";token="plotvalue"};NA.register(OEt);var WEt=class extends wr{static token="plotothertext";token="plotothertext"};NA.register(WEt);var ZEt=class extends wr{static token="plotinvisibletext";token="plotinvisibletext"};NA.register(ZEt);var VEt=class extends wr{static token="padsonsilk";token="padsonsilk"};NA.register(VEt);var jEt=class extends wr{static token="sketchpadsonfab";token="sketchpadsonfab"};NA.register(jEt);var zEt=class extends wr{static token="plotpadnumbers";token="plotpadnumbers"};NA.register(zEt);var XEt=class extends wr{static token="hidednponfab";token="hidednponfab"};NA.register(XEt);var $Et=class extends wr{static token="sketchdnponfab";token="sketchdnponfab"};NA.register($Et);var Aht=class extends wr{static token="crossoutdnponfab";token="crossoutdnponfab"};NA.register(Aht);var tht=class extends wr{static token="subtractmaskfromsilk";token="subtractmaskfromsilk"};NA.register(tht);var eht=class extends wr{static token="plot_black_and_white";token="plot_black_and_white"};NA.register(eht);var iht=class extends wr{static token="mirror";token="mirror"};NA.register(iht);var nht=class extends wr{static token="outputdirectory";token="outputdirectory";quoteStringValue=!0};NA.register(nht);var oht=class extends wr{static token="plot_on_all_layers";token="plot_on_all_layers"};NA.register(oht);var sht=class extends wr{static token="plotinvisible";token="plotinvisible"};NA.register(sht);var Nii={layerselection:"layerselection",plot_on_all_layers_selection:"plot_on_all_layers_selection",disableapertmacros:"disableapertmacros",usegerberextensions:"usegerberextensions",usegerberattributes:"usegerberattributes",usegerberadvancedattributes:"usegerberadvancedattributes",creategerberjobfile:"creategerberjobfile",excludeedgelayer:"excludeedgelayer",dashed_line_dash_ratio:"dashed_line_dash_ratio",dashed_line_gap_ratio:"dashed_line_gap_ratio",svgprecision:"svgprecision",linewidth:"linewidth",plotframeref:"plotframeref",plotreference:"plotreference",plotvalue:"plotvalue",plotothertext:"plotothertext",plotinvisibletext:"plotinvisibletext",padsonsilk:"padsonsilk",sketchpadsonfab:"sketchpadsonfab",plotpadnumbers:"plotpadnumbers",hidednponfab:"hidednponfab",sketchdnponfab:"sketchdnponfab",crossoutdnponfab:"crossoutdnponfab",subtractmaskfromsilk:"subtractmaskfromsilk",plot_black_and_white:"plot_black_and_white",plot_on_all_layers:"plot_on_all_layers",plotinvisible:"plotinvisible",mode:"mode",useauxorigin:"useauxorigin",viasonmask:"viasonmask",hpglpennumber:"hpglpennumber",hpglpenspeed:"hpglpenspeed",hpglpendiameter:"hpglpendiameter",hpglpenoverlay:"hpglpenoverlay",pdf_front_fp_property_popups:"pdf_front_fp_property_popups",pdf_back_fp_property_popups:"pdf_back_fp_property_popups",pdf_metadata:"pdf_metadata",pdf_single_document:"pdf_single_document",dxfpolygonmode:"dxfpolygonmode",dxfimperialunits:"dxfimperialunits",dxfusepcbnewfont:"dxfusepcbnewfont",psnegative:"psnegative",psa4output:"psa4output",mirror:"mirror",outputformat:"outputformat",drillshape:"drillshape",scaleselection:"scaleselection",outputdirectory:"outputdirectory"},vii=["layerselection","plot_on_all_layers_selection","disableapertmacros","usegerberextensions","usegerberattributes","usegerberadvancedattributes","creategerberjobfile","excludeedgelayer","dashed_line_dash_ratio","dashed_line_gap_ratio","svgprecision","linewidth","plotframeref","plotreference","plotvalue","plotothertext","mode","useauxorigin","viasonmask","hpglpennumber","hpglpenspeed","hpglpendiameter","hpglpenoverlay","pdf_front_fp_property_popups","pdf_back_fp_property_popups","pdf_metadata","pdf_single_document","dxfpolygonmode","dxfimperialunits","dxfusepcbnewfont","psnegative","psa4output","plot_black_and_white","plot_on_all_layers","plotinvisible","plotinvisibletext","padsonsilk","sketchpadsonfab","plotpadnumbers","hidednponfab","sketchdnponfab","crossoutdnponfab","subtractmaskfromsilk","outputformat","mirror","drillshape","scaleselection","outputdirectory"],TmA=class Qyt extends NA{static token="pcbplotparams";static parentToken="setup";token="pcbplotparams";_properties={};static fromSexprPrimitives(A){const t=new Qyt,{propertyMap:i}=NA.parsePrimitivesToClassProperties(A,this.token);for(const[n,o]of Object.entries(i)){const s=Nii[n];if(!s)throw new Error(`Unsupported pcbplotparams token: ${n}`);t._properties[s]=o}return t}getChildren(){const A=[];for(const t of vii){const i=this._properties[t];i&&A.push(i)}return A}clearProperty(A){delete this._properties[A]}setStringProperty(A,t,i){if(t===void 0){this.clearProperty(A);return}this._properties[A]=new i(t)}setNumberProperty(A,t,i){if(t===void 0){this.clearProperty(A);return}this._properties[A]=new i(t)}setStringOrNumberProperty(A,t,i){if(t===void 0){this.clearProperty(A);return}this._properties[A]=new i(t)}get layerselection(){return this._properties.layerselection?.value}set layerselection(A){this.setStringOrNumberProperty("layerselection",A,BEt)}get plot_on_all_layers_selection(){return this._properties.plot_on_all_layers_selection?.value}set plot_on_all_layers_selection(A){this.setStringOrNumberProperty("plot_on_all_layers_selection",A,CEt)}get disableapertmacros(){return this._properties.disableapertmacros?.value}set disableapertmacros(A){this.setStringProperty("disableapertmacros",A,bEt)}get usegerberextensions(){return this._properties.usegerberextensions?.value}set usegerberextensions(A){this.setStringProperty("usegerberextensions",A,xEt)}get usegerberattributes(){return this._properties.usegerberattributes?.value}set usegerberattributes(A){this.setStringProperty("usegerberattributes",A,_Et)}get usegerberadvancedattributes(){return this._properties.usegerberadvancedattributes?.value}set usegerberadvancedattributes(A){this.setStringProperty("usegerberadvancedattributes",A,kEt)}get creategerberjobfile(){return this._properties.creategerberjobfile?.value}set creategerberjobfile(A){this.setStringProperty("creategerberjobfile",A,FEt)}get excludeedgelayer(){return this._properties.excludeedgelayer?.value}set excludeedgelayer(A){this.setStringProperty("excludeedgelayer",A,GEt)}get dashed_line_dash_ratio(){return this._properties.dashed_line_dash_ratio?.value}set dashed_line_dash_ratio(A){this.setNumberProperty("dashed_line_dash_ratio",A,QEt)}get dashed_line_gap_ratio(){return this._properties.dashed_line_gap_ratio?.value}set dashed_line_gap_ratio(A){this.setNumberProperty("dashed_line_gap_ratio",A,EEt)}get svgprecision(){return this._properties.svgprecision?.value}set svgprecision(A){this.setNumberProperty("svgprecision",A,hEt)}get linewidth(){return this._properties.linewidth?.value}set linewidth(A){this.setNumberProperty("linewidth",A,uEt)}get plotframeref(){return this._properties.plotframeref?.value}set plotframeref(A){this.setStringProperty("plotframeref",A,MEt)}get plotreference(){return this._properties.plotreference?.value}set plotreference(A){this.setStringProperty("plotreference",A,qEt)}get plotvalue(){return this._properties.plotvalue?.value}set plotvalue(A){this.setStringProperty("plotvalue",A,OEt)}get plotothertext(){return this._properties.plotothertext?.value}set plotothertext(A){this.setStringProperty("plotothertext",A,WEt)}get plotinvisibletext(){return this._properties.plotinvisibletext?.value}set plotinvisibletext(A){this.setStringProperty("plotinvisibletext",A,ZEt)}get padsonsilk(){return this._properties.padsonsilk?.value}set padsonsilk(A){this.setStringProperty("padsonsilk",A,VEt)}get plotpadnumbers(){return this._properties.plotpadnumbers?.value}set plotpadnumbers(A){this.setStringProperty("plotpadnumbers",A,zEt)}get sketchpadsonfab(){return this._properties.sketchpadsonfab?.value}set sketchpadsonfab(A){this.setStringProperty("sketchpadsonfab",A,jEt)}get hidednponfab(){return this._properties.hidednponfab?.value}set hidednponfab(A){this.setStringProperty("hidednponfab",A,XEt)}get sketchdnponfab(){return this._properties.sketchdnponfab?.value}set sketchdnponfab(A){this.setStringProperty("sketchdnponfab",A,$Et)}get crossoutdnponfab(){return this._properties.crossoutdnponfab?.value}set crossoutdnponfab(A){this.setStringProperty("crossoutdnponfab",A,Aht)}get subtractmaskfromsilk(){return this._properties.subtractmaskfromsilk?.value}set subtractmaskfromsilk(A){this.setStringProperty("subtractmaskfromsilk",A,tht)}get plot_black_and_white(){return this._properties.plot_black_and_white?.value}set plot_black_and_white(A){this.setStringProperty("plot_black_and_white",A,eht)}get plot_on_all_layers(){return this._properties.plot_on_all_layers?.value}set plot_on_all_layers(A){this.setStringProperty("plot_on_all_layers",A,oht)}get plotinvisible(){return this._properties.plotinvisible?.value}set plotinvisible(A){this.setStringProperty("plotinvisible",A,sht)}get mode(){return this._properties.mode?.value}set mode(A){this.setNumberProperty("mode",A,dEt)}get useauxorigin(){return this._properties.useauxorigin?.value}set useauxorigin(A){this.setStringProperty("useauxorigin",A,NEt)}get viasonmask(){return this._properties.viasonmask?.value}set viasonmask(A){this.setStringProperty("viasonmask",A,REt)}get hpglpennumber(){return this._properties.hpglpennumber?.value}set hpglpennumber(A){this.setNumberProperty("hpglpennumber",A,pEt)}get hpglpenspeed(){return this._properties.hpglpenspeed?.value}set hpglpenspeed(A){this.setNumberProperty("hpglpenspeed",A,fEt)}get hpglpendiameter(){return this._properties.hpglpendiameter?.value}set hpglpendiameter(A){this.setNumberProperty("hpglpendiameter",A,yEt)}get hpglpenoverlay(){return this._properties.hpglpenoverlay?.value}set hpglpenoverlay(A){this.setNumberProperty("hpglpenoverlay",A,mEt)}get pdf_front_fp_property_popups(){return this._properties.pdf_front_fp_property_popups?.value}set pdf_front_fp_property_popups(A){this.setStringProperty("pdf_front_fp_property_popups",A,vEt)}get pdf_back_fp_property_popups(){return this._properties.pdf_back_fp_property_popups?.value}set pdf_back_fp_property_popups(A){this.setStringProperty("pdf_back_fp_property_popups",A,LEt)}get pdf_metadata(){return this._properties.pdf_metadata?.value}set pdf_metadata(A){this.setStringProperty("pdf_metadata",A,UEt)}get pdf_single_document(){return this._properties.pdf_single_document?.value}set pdf_single_document(A){this.setStringProperty("pdf_single_document",A,HEt)}get dxfpolygonmode(){return this._properties.dxfpolygonmode?.value}set dxfpolygonmode(A){this.setStringProperty("dxfpolygonmode",A,YEt)}get dxfimperialunits(){return this._properties.dxfimperialunits?.value}set dxfimperialunits(A){this.setStringProperty("dxfimperialunits",A,JEt)}get dxfusepcbnewfont(){return this._properties.dxfusepcbnewfont?.value}set dxfusepcbnewfont(A){this.setStringProperty("dxfusepcbnewfont",A,TEt)}get psnegative(){return this._properties.psnegative?.value}set psnegative(A){this.setStringProperty("psnegative",A,KEt)}get psa4output(){return this._properties.psa4output?.value}set psa4output(A){this.setStringProperty("psa4output",A,PEt)}get mirror(){return this._properties.mirror?.value}set mirror(A){this.setStringProperty("mirror",A,iht)}get outputformat(){return this._properties.outputformat?.value}set outputformat(A){this.setNumberProperty("outputformat",A,wEt)}get drillshape(){return this._properties.drillshape?.value}set drillshape(A){this.setNumberProperty("drillshape",A,DEt)}get scaleselection(){return this._properties.scaleselection?.value}set scaleselection(A){this.setNumberProperty("scaleselection",A,SEt)}get outputdirectory(){return this._properties.outputdirectory?.value}set outputdirectory(A){this.setStringProperty("outputdirectory",A,nht)}};NA.register(TmA);var pj=class extends UJ{static parentToken="setup"},KmA=class extends pj{static token="zone_45_only";token="zone_45_only"};NA.register(KmA);var PmA=class extends pj{static token="allow_soldermask_bridges_in_footprints";token="allow_soldermask_bridges_in_footprints"};NA.register(PmA);var qmA=class extends pj{static token="visible_elements";token="visible_elements"};NA.register(qmA);var OmA=class extends pj{static token="uvias_allowed";token="uvias_allowed"};NA.register(OmA);var WmA=class Eyt extends NA{static token="tenting";static parentToken="setup";token="tenting";_sides=[];constructor(A=[]){super(),this.sides=A}static fromSexprPrimitives(A){const t=A.map(i=>pi(i)).filter(i=>i!==void 0);return new Eyt(t)}get sides(){return[...this._sides]}set sides(A){this._sides=A.map(t=>String(t))}getChildren(){return[]}getString(){return this._sides.length===0?"(tenting)":`(tenting ${this._sides.join(" ")})`}};NA.register(WmA);var HJ=class extends Mii{static parentToken="setup"},rht=class extends Rii{static parentToken="setup"},ZmA=class extends HJ{static token="pcb_text_size";token="pcb_text_size"};NA.register(ZmA);var VmA=class extends HJ{static token="mod_text_size";token="mod_text_size"};NA.register(VmA);var jmA=class extends HJ{static token="pad_size";token="pad_size"};NA.register(jmA);var zmA=class extends HJ{static token="pad_to_paste_clearance_values";token="pad_to_paste_clearance_values"};NA.register(zmA);var XmA=class extends HJ{static token="trace_width";token="trace_width"};NA.register(XmA);var $mA=class extends rht{static token="aux_axis_origin";token="aux_axis_origin"};NA.register($mA);var AwA=class extends rht{static token="grid_origin";token="grid_origin"};NA.register(AwA);var gB=class extends UJ{static parentToken="setup";static parsePrimitiveValue(e){const A=ai(e);if(A===void 0)throw new Error(`${this.name} expects a numeric value`);return A}},twA=class extends gB{static token="pad_to_mask_clearance";token="pad_to_mask_clearance"};NA.register(twA);var ewA=class extends gB{static token="solder_mask_min_width";token="solder_mask_min_width"};NA.register(ewA);var iwA=class extends gB{static token="pad_to_paste_clearance";token="pad_to_paste_clearance"};NA.register(iwA);var nwA=class extends gB{static token="pad_to_paste_clearance_ratio";token="pad_to_paste_clearance_ratio"};NA.register(nwA);var owA=class extends gB{static token="last_trace_width";token="last_trace_width"};NA.register(owA);var swA=class extends gB{static token="trace_clearance";token="trace_clearance"};NA.register(swA);var rwA=class extends gB{static token="zone_clearance";token="zone_clearance"};NA.register(rwA);var awA=class extends gB{static token="trace_min";token="trace_min"};NA.register(awA);var gwA=class extends gB{static token="segment_width";token="segment_width"};NA.register(gwA);var cwA=class extends gB{static token="edge_width";token="edge_width"};NA.register(cwA);var IwA=class extends gB{static token="via_size";token="via_size"};NA.register(IwA);var lwA=class extends gB{static token="via_drill";token="via_drill"};NA.register(lwA);var BwA=class extends gB{static token="via_min_size";token="via_min_size"};NA.register(BwA);var CwA=class extends gB{static token="via_min_drill";token="via_min_drill"};NA.register(CwA);var QwA=class extends gB{static token="uvia_size";token="uvia_size"};NA.register(QwA);var EwA=class extends gB{static token="uvia_drill";token="uvia_drill"};NA.register(EwA);var hwA=class extends gB{static token="uvia_min_size";token="uvia_min_size"};NA.register(hwA);var uwA=class extends gB{static token="uvia_min_drill";token="uvia_min_drill"};NA.register(uwA);var dwA=class extends gB{static token="pcb_text_width";token="pcb_text_width"};NA.register(dwA);var pwA=class extends gB{static token="mod_edge_width";token="mod_edge_width"};NA.register(pwA);var fwA=class extends gB{static token="mod_text_width";token="mod_text_width"};NA.register(fwA);var ywA=class extends gB{static token="pad_drill";token="pad_drill"};NA.register(ywA);var YJ=class extends UJ{static parentToken="stackup"},aht=class extends YJ{static token="copper_finish";token="copper_finish";quoteStringValue=!0};NA.register(aht);var ght=class extends YJ{static token="dielectric_constraints";token="dielectric_constraints"};NA.register(ght);var cht=class extends YJ{static token="edge_connector";token="edge_connector"};NA.register(cht);var Iht=class extends YJ{static token="castellated_pads";token="castellated_pads"};NA.register(Iht);var lht=class extends YJ{static token="edge_plating";token="edge_plating"};NA.register(lht);var b1=class extends UJ{static parentToken="layer"},mwA=class extends b1{static token="type";token="type";quoteStringValue=!0};NA.register(mwA);var wwA=class extends b1{static token="color";token="color";quoteStringValue=!0};NA.register(wwA);var DwA=class extends b1{static token="thickness";token="thickness";static parsePrimitiveValue(e){const A=ai(e);if(A===void 0)throw new Error("Stackup layer thickness expects a numeric value");return A}};NA.register(DwA);var SwA=class extends b1{static token="material";token="material";quoteStringValue=!0};NA.register(SwA);var bwA=class extends b1{static token="epsilon_r";token="epsilon_r";static parsePrimitiveValue(e){const A=ai(e);if(A===void 0)throw new Error("Stackup layer epsilon_r expects a numeric value");return A}};NA.register(bwA);var xwA=class extends b1{static token="loss_tangent";token="loss_tangent";static parsePrimitiveValue(e){const A=ai(e);if(A===void 0)throw new Error("Stackup layer loss_tangent expects a numeric value");return A}};NA.register(xwA);var Bht=class hyt extends NA{static token="layer";static parentToken="stackup";token="layer";_name;_number;_sxType;_sxColor;_sxThickness;_sxMaterial;_sxEpsilonR;_sxLossTangent;constructor(A,t={}){super(),this._name=A,this._number=t.number,this._sxType=t.type,this._sxColor=t.color,this._sxThickness=t.thickness,this._sxMaterial=t.material,this._sxEpsilonR=t.epsilonR,this._sxLossTangent=t.lossTangent}static fromSexprPrimitives(A){if(A.length===0)throw new Error("Stackup layer requires at least a name");const t=pi(A[0]);if(t===void 0)throw new Error("Stackup layer name must be a string");let i=1,n;const o=A[i],s=ai(o);s!==void 0&&(n=s,i+=1);const r=A.slice(i),{propertyMap:a}=NA.parsePrimitivesToClassProperties(r,this.token);return new hyt(t,{number:n,type:a.type,color:a.color,thickness:a.thickness,material:a.material,epsilonR:a.epsilon_r,lossTangent:a.loss_tangent})}get name(){return this._name}set name(A){const t=pi(A);if(t===void 0)throw new Error("Stackup layer name must be a string");this._name=t}get number(){return this._number}set number(A){if(A===void 0){this._number=void 0;return}const t=ai(A);if(t===void 0)throw new Error("Stackup layer number must be numeric");this._number=t}get type(){return this._sxType?.value}set type(A){if(A===void 0){this._sxType=void 0;return}this._sxType=A instanceof mwA?A:new mwA(A)}get color(){return this._sxColor?.value}set color(A){if(A===void 0){this._sxColor=void 0;return}this._sxColor=A instanceof wwA?A:new wwA(A)}get thickness(){return this._sxThickness?.value}set thickness(A){if(A===void 0){this._sxThickness=void 0;return}this._sxThickness=A instanceof DwA?A:new DwA(A)}get material(){return this._sxMaterial?.value}set material(A){if(A===void 0){this._sxMaterial=void 0;return}this._sxMaterial=A instanceof SwA?A:new SwA(A)}get epsilonR(){return this._sxEpsilonR?.value}set epsilonR(A){if(A===void 0){this._sxEpsilonR=void 0;return}this._sxEpsilonR=A instanceof bwA?A:new bwA(A)}get lossTangent(){return this._sxLossTangent?.value}set lossTangent(A){if(A===void 0){this._sxLossTangent=void 0;return}this._sxLossTangent=A instanceof xwA?A:new xwA(A)}getChildren(){const A=[];return this._sxType&&A.push(this._sxType),this._sxColor&&A.push(this._sxColor),this._sxThickness&&A.push(this._sxThickness),this._sxMaterial&&A.push(this._sxMaterial),this._sxEpsilonR&&A.push(this._sxEpsilonR),this._sxLossTangent&&A.push(this._sxLossTangent),A}getString(){const A=`(layer ${Bn(this._name)}${this._number!==void 0?` ${this._number}`:""}`,t=this.getChildren();if(t.length===0)return`${A})`;const i=[A];for(const n of t)i.push(n.getStringIndented());return i.push(")"),i.join(`
|
|
5827
5827
|
`)}};NA.register(Bht);var _wA=class uyt extends NA{static token="stackup";static parentToken="setup";token="stackup";_layers=[];_sxCopperFinish;_sxDielectricConstraints;_sxEdgeConnector;_sxCastellatedPads;_sxEdgePlating;constructor(A={}){super(),this.layers=A.layers??[],this._sxCopperFinish=A.copperFinish,this._sxDielectricConstraints=A.dielectricConstraints,this._sxEdgeConnector=A.edgeConnector,this._sxCastellatedPads=A.castellatedPads,this._sxEdgePlating=A.edgePlating}static fromSexprPrimitives(A){const{propertyMap:t,arrayPropertyMap:i}=NA.parsePrimitivesToClassProperties(A,this.token);return new uyt({layers:i.layer??[],copperFinish:t.copper_finish,dielectricConstraints:t.dielectric_constraints,edgeConnector:t.edge_connector,castellatedPads:t.castellated_pads,edgePlating:t.edge_plating})}get layers(){return[...this._layers]}set layers(A){this._layers=A.map(t=>{if(!(t instanceof Bht))throw new Error("Stackup layers must be StackupLayer instances");return t})}get copperFinish(){return this._sxCopperFinish?.value}set copperFinish(A){this._sxCopperFinish=A?new aht(A):void 0}get dielectricConstraints(){return this._sxDielectricConstraints?.value}set dielectricConstraints(A){this._sxDielectricConstraints=A?new ght(A):void 0}get edgeConnector(){return this._sxEdgeConnector?.value}set edgeConnector(A){this._sxEdgeConnector=A?new cht(A):void 0}get castellatedPads(){return this._sxCastellatedPads?.value}set castellatedPads(A){this._sxCastellatedPads=A?new Iht(A):void 0}get edgePlating(){return this._sxEdgePlating?.value}set edgePlating(A){this._sxEdgePlating=A?new lht(A):void 0}getChildren(){const A=[...this._layers],t=[this._sxCopperFinish,this._sxDielectricConstraints,this._sxEdgeConnector,this._sxCastellatedPads,this._sxEdgePlating];for(const i of t)i&&A.push(i);return A}};NA.register(_wA);var Lii={stackup:"stackup",pcbplotparams:"pcbPlotParams",pad_to_mask_clearance:"padToMaskClearance",solder_mask_min_width:"solderMaskMinWidth",pad_to_paste_clearance:"padToPasteClearance",pad_to_paste_clearance_ratio:"padToPasteClearanceRatio",last_trace_width:"lastTraceWidth",trace_clearance:"traceClearance",zone_clearance:"zoneClearance",zone_45_only:"zone45Only",trace_min:"traceMin",segment_width:"segmentWidth",edge_width:"edgeWidth",via_size:"viaSize",via_drill:"viaDrill",via_min_size:"viaMinSize",via_min_drill:"viaMinDrill",uvias_allowed:"uviasAllowed",uvia_size:"uviaSize",uvia_drill:"uviaDrill",uvia_min_size:"uviaMinSize",uvia_min_drill:"uviaMinDrill",pcb_text_width:"pcbTextWidth",pcb_text_size:"pcbTextSize",mod_edge_width:"modEdgeWidth",mod_text_size:"modTextSize",mod_text_width:"modTextWidth",pad_size:"padSize",pad_drill:"padDrill",allow_soldermask_bridges_in_footprints:"allowSoldermaskBridgesInFootprints",tenting:"tenting",aux_axis_origin:"auxAxisOrigin",grid_origin:"gridOrigin",visible_elements:"visibleElements",pad_to_paste_clearance_values:"padToPasteClearanceValues",trace_width:"traceWidth"},Uii=["stackup","padToMaskClearance","solderMaskMinWidth","padToPasteClearance","padToPasteClearanceRatio","lastTraceWidth","traceClearance","zoneClearance","zone45Only","traceMin","segmentWidth","edgeWidth","viaSize","viaDrill","viaMinSize","viaMinDrill","uviaSize","uviaDrill","uviasAllowed","uviaMinSize","uviaMinDrill","pcbTextWidth","pcbTextSize","modEdgeWidth","modTextSize","modTextWidth","padSize","padDrill","allowSoldermaskBridgesInFootprints","tenting","auxAxisOrigin","gridOrigin","visibleElements","padToPasteClearanceValues","traceWidth","pcbPlotParams"],kwA=class dyt extends NA{static token="setup";token="setup";_properties={};static fromSexprPrimitives(A){const t=new dyt,{propertyMap:i}=NA.parsePrimitivesToClassProperties(A,this.token);for(const[n,o]of Object.entries(i)){const s=Lii[n];if(!s)throw new Error(`Unsupported setup property token: ${n}`);t._properties[s]=o}return t}getChildren(){const A=[];for(const t of Uii){const i=this._properties[t];i&&A.push(i)}return A}setProperty(A,t){if(t){this._properties[A]=t;return}delete this._properties[A]}setNumberProperty(A,t,i){if(t===void 0){delete this._properties[A];return}this._properties[A]=new i(t)}getPropertyInstance(A,t){const i=this._properties[A];return i instanceof t?i:void 0}get stackup(){return this.getPropertyInstance("stackup",_wA)}set stackup(A){if(A!==void 0&&!(A instanceof _wA))throw new Error("stackup must be a Stackup instance");this.setProperty("stackup",A)}get pcbPlotParams(){return this.getPropertyInstance("pcbPlotParams",TmA)}set pcbPlotParams(A){if(A!==void 0&&!(A instanceof TmA))throw new Error("pcbPlotParams must be a PcbPlotParams instance");this.setProperty("pcbPlotParams",A)}get padToMaskClearance(){return this.getPropertyInstance("padToMaskClearance",twA)?.value}set padToMaskClearance(A){this.setNumberProperty("padToMaskClearance",A,twA)}get solderMaskMinWidth(){return this.getPropertyInstance("solderMaskMinWidth",ewA)?.value}set solderMaskMinWidth(A){this.setNumberProperty("solderMaskMinWidth",A,ewA)}get padToPasteClearance(){return this.getPropertyInstance("padToPasteClearance",iwA)?.value}set padToPasteClearance(A){this.setNumberProperty("padToPasteClearance",A,iwA)}get padToPasteClearanceRatio(){return this.getPropertyInstance("padToPasteClearanceRatio",nwA)?.value}set padToPasteClearanceRatio(A){this.setNumberProperty("padToPasteClearanceRatio",A,nwA)}get lastTraceWidth(){return this.getPropertyInstance("lastTraceWidth",owA)?.value}set lastTraceWidth(A){this.setNumberProperty("lastTraceWidth",A,owA)}get traceClearance(){return this.getPropertyInstance("traceClearance",swA)?.value}set traceClearance(A){this.setNumberProperty("traceClearance",A,swA)}get zoneClearance(){return this.getPropertyInstance("zoneClearance",rwA)?.value}set zoneClearance(A){this.setNumberProperty("zoneClearance",A,rwA)}get zone45Only(){return this.getPropertyInstance("zone45Only",KmA)?.value}set zone45Only(A){this.setProperty("zone45Only",A===void 0?void 0:new KmA(A))}get traceMin(){return this.getPropertyInstance("traceMin",awA)?.value}set traceMin(A){this.setNumberProperty("traceMin",A,awA)}get segmentWidth(){return this.getPropertyInstance("segmentWidth",gwA)?.value}set segmentWidth(A){this.setNumberProperty("segmentWidth",A,gwA)}get edgeWidth(){return this.getPropertyInstance("edgeWidth",cwA)?.value}set edgeWidth(A){this.setNumberProperty("edgeWidth",A,cwA)}get viaSize(){return this.getPropertyInstance("viaSize",IwA)?.value}set viaSize(A){this.setNumberProperty("viaSize",A,IwA)}get viaDrill(){return this.getPropertyInstance("viaDrill",lwA)?.value}set viaDrill(A){this.setNumberProperty("viaDrill",A,lwA)}get viaMinSize(){return this.getPropertyInstance("viaMinSize",BwA)?.value}set viaMinSize(A){this.setNumberProperty("viaMinSize",A,BwA)}get viaMinDrill(){return this.getPropertyInstance("viaMinDrill",CwA)?.value}set viaMinDrill(A){this.setNumberProperty("viaMinDrill",A,CwA)}get uviasAllowed(){return this.getPropertyInstance("uviasAllowed",OmA)?.value}set uviasAllowed(A){this.setProperty("uviasAllowed",A===void 0?void 0:new OmA(A))}get uviaSize(){return this.getPropertyInstance("uviaSize",QwA)?.value}set uviaSize(A){this.setNumberProperty("uviaSize",A,QwA)}get uviaDrill(){return this.getPropertyInstance("uviaDrill",EwA)?.value}set uviaDrill(A){this.setNumberProperty("uviaDrill",A,EwA)}get uviaMinSize(){return this.getPropertyInstance("uviaMinSize",hwA)?.value}set uviaMinSize(A){this.setNumberProperty("uviaMinSize",A,hwA)}get uviaMinDrill(){return this.getPropertyInstance("uviaMinDrill",uwA)?.value}set uviaMinDrill(A){this.setNumberProperty("uviaMinDrill",A,uwA)}get pcbTextWidth(){return this.getPropertyInstance("pcbTextWidth",dwA)?.value}set pcbTextWidth(A){this.setNumberProperty("pcbTextWidth",A,dwA)}get pcbTextSize(){return this.getPropertyInstance("pcbTextSize",ZmA)?.values}set pcbTextSize(A){if(A===void 0){delete this._properties.pcbTextSize;return}this.setProperty("pcbTextSize",new ZmA(A))}get modEdgeWidth(){return this.getPropertyInstance("modEdgeWidth",pwA)?.value}set modEdgeWidth(A){this.setNumberProperty("modEdgeWidth",A,pwA)}get modTextSize(){return this.getPropertyInstance("modTextSize",VmA)?.values}set modTextSize(A){if(A===void 0){delete this._properties.modTextSize;return}this.setProperty("modTextSize",new VmA(A))}get modTextWidth(){return this.getPropertyInstance("modTextWidth",fwA)?.value}set modTextWidth(A){this.setNumberProperty("modTextWidth",A,fwA)}get padSize(){return this.getPropertyInstance("padSize",jmA)?.values}set padSize(A){if(A===void 0){delete this._properties.padSize;return}this.setProperty("padSize",new jmA(A))}get padDrill(){return this.getPropertyInstance("padDrill",ywA)?.value}set padDrill(A){this.setNumberProperty("padDrill",A,ywA)}get allowSoldermaskBridgesInFootprints(){return this.getPropertyInstance("allowSoldermaskBridgesInFootprints",PmA)?.value}set allowSoldermaskBridgesInFootprints(A){this.setProperty("allowSoldermaskBridgesInFootprints",A===void 0?void 0:new PmA(A))}get tenting(){return this.getPropertyInstance("tenting",WmA)?.sides}set tenting(A){if(A===void 0){delete this._properties.tenting;return}this.setProperty("tenting",new WmA(A))}get auxAxisOrigin(){const A=this.getPropertyInstance("auxAxisOrigin",$mA);if(A)return{x:A.x,y:A.y}}set auxAxisOrigin(A){if(!A){delete this._properties.auxAxisOrigin;return}this.setProperty("auxAxisOrigin",new $mA(A.x,A.y))}get gridOrigin(){const A=this.getPropertyInstance("gridOrigin",AwA);if(A)return{x:A.x,y:A.y}}set gridOrigin(A){if(!A){delete this._properties.gridOrigin;return}this.setProperty("gridOrigin",new AwA(A.x,A.y))}get visibleElements(){return this.getPropertyInstance("visibleElements",qmA)?.value}set visibleElements(A){this.setProperty("visibleElements",A===void 0?void 0:new qmA(A))}get padToPasteClearanceValues(){return this.getPropertyInstance("padToPasteClearanceValues",zmA)?.values}set padToPasteClearanceValues(A){if(A===void 0){delete this._properties.padToPasteClearanceValues;return}this.setProperty("padToPasteClearanceValues",new zmA(A))}get traceWidth(){return this.getPropertyInstance("traceWidth",XmA)?.values}set traceWidth(A){if(A===void 0){delete this._properties.traceWidth;return}this.setProperty("traceWidth",new XmA(A))}};NA.register(kwA);var Cht=class extends aa{static token="thickness";static parentToken="general";token="thickness"};NA.register(Cht);var Qht=class pyt extends NA{static token="legacy_teardrops";static parentToken="general";token="legacy_teardrops";_enabled;constructor(A){super(),this._enabled=A}static fromSexprPrimitives(A){const t=pi(A[0]);if(t===void 0)throw new Error("legacy_teardrops expects a string value");const i=/^(yes|true)$/iu.test(t);return new pyt(i)}get enabled(){return this._enabled}set enabled(A){this._enabled=A}getChildren(){return[]}getString(){return`(legacy_teardrops ${this._enabled?"yes":"no"})`}};NA.register(Qht);var Eht=new Set(["thickness","legacy_teardrops"]),FwA=class fyt extends NA{static token="general";static parentToken="kicad_pcb";token="general";_sxThickness;_sxLegacyTeardrops;static fromSexprPrimitives(A){const t=new fyt,{propertyMap:i,arrayPropertyMap:n}=NA.parsePrimitivesToClassProperties(A,this.token);for(const o of Object.keys(i))if(!Eht.has(o))throw new Error(`general encountered unsupported child token "${o}"`);for(const[o,s]of Object.entries(n)){if(!Eht.has(o))throw new Error(`general encountered unsupported child token "${o}"`);if(s.length>1)throw new Error(`general encountered repeated child token "${o}"`)}return t._sxThickness=n.thickness?.[0]??i.thickness,t._sxLegacyTeardrops=n.legacy_teardrops?.[0]??i.legacy_teardrops,t}get thickness(){return this._sxThickness?.value}set thickness(A){this._sxThickness=A===void 0?void 0:new Cht(A)}get legacyTeardrops(){return this._sxLegacyTeardrops?.enabled}set legacyTeardrops(A){if(A===void 0){this._sxLegacyTeardrops=void 0;return}this._sxLegacyTeardrops=new Qht(A)}getChildren(){const A=[];return this._sxThickness&&A.push(this._sxThickness),this._sxLegacyTeardrops&&A.push(this._sxLegacyTeardrops),A}};NA.register(FwA);var Rl=class yyt extends NA{static token="__pcb_layer_definition__";static parentToken="layers";token="__pcb_layer_definition__";_index;_name;_type;_userName;constructor(A){super(),this._index=A.index,this._name=A.name,this._type=A.type,this._userName=A.userName}static fromPrimitive(A){if(!Array.isArray(A)||A.length<3)throw new Error(`layers entry must be an array with at least index, name, and type: ${JSON.stringify(A)}`);const[t,i,n,o]=A,s=ai(t),r=pi(i),a=pi(n),g=o===void 0?void 0:pi(o);if(s===void 0||r===void 0||a===void 0)throw new Error(`layers entry is missing required values: ${JSON.stringify(A)}`);return new yyt({index:s,name:r,type:a,userName:g})}get index(){return this._index}set index(A){this._index=A}get name(){return this._name}set name(A){this._name=A}get type(){return this._type}set type(A){this._type=A}get userName(){return this._userName}set userName(A){this._userName=A}getChildren(){return[]}getString(){if(this._index===void 0||this._name===void 0||this._type===void 0)return"()";const A=[String(this._index),Bn(this._name),this._type];return this._userName!==void 0&&A.push(Bn(this._userName)),`(${A.join(" ")})`}};NA.register(Rl);var GwA=class myt extends NA{static token="layers";static parentToken="kicad_pcb";token="layers";_definitions=[];static fromSexprPrimitives(A){const t=new myt;return t._definitions=A.map(i=>Rl.fromPrimitive(i)),t}get definitions(){return[...this._definitions]}set definitions(A){this._definitions=[...A]}getChildren(){return[...this._definitions]}};NA.register(GwA);var fj=class wyt extends NA{static token="net";static parentToken="kicad_pcb";token="net";_id;_name;constructor(A,t){super(),this._id=A,this._name=t}static fromSexprPrimitives(A){const t=ai(A[0]),i=pi(A[1]);if(t===void 0||i===void 0)throw new Error("net requires numeric id and string name");return new wyt(t,i)}get id(){return this._id}set id(A){this._id=A}get name(){return this._name}set name(A){this._name=A}getChildren(){return[]}getString(){return`(net ${this._id} ${Bn(this._name)})`}};NA.register(fj);var MwA=class extends aa{static token="version";static parentToken="kicad_pcb";token="version"};NA.register(MwA);var Hii=e=>/^[A-Za-z0-9._-]+$/.test(e),RwA=class extends Vy{static token="generator";static parentToken="kicad_pcb";token="generator";getString(){return`(generator ${Hii(this.value)?this.value:Bn(this.value)})`}};NA.register(RwA);var Yii=e=>/^[A-Za-z0-9._-]+$/.test(e),NwA=class extends Vy{static token="generator_version";static parentToken="kicad_pcb";token="generator_version";getString(){return`(generator_version ${Yii(this.value)?this.value:Bn(this.value)})`}};NA.register(NwA);var vwA=class Dyt extends NA{static token="net";static parentToken="via";token="net";_id;_name;constructor(A,t){super(),this._id=A,this._name=t}static fromSexprPrimitives(A){const t=ai(A[0]);if(t===void 0)throw new Error("via net requires a numeric id");const i=A.length>1?pi(A[1]):void 0;return new Dyt(t,i)}get id(){return this._id}set id(A){this._id=A}get name(){return this._name}set name(A){this._name=A}getChildren(){return[]}getString(){return this._name!==void 0?`(net ${this._id} ${Bn(this._name)})`:`(net ${this._id})`}};NA.register(vwA);var Jii=new Set(["locked","free","remove_unused_layers","keep_end_layers"]),LwA=class Syt extends NA{static token="via";token="via";_type;_locked=!1;_free=!1;_removeUnusedLayers=!1;_keepEndLayers=!1;_sxAt;_size;_drill;_sxLayers;_sxNet;_sxUuid;_sxTstamp;_sxTeardrops;constructor(A={}){super(),A.type!==void 0&&(this.type=A.type),A.locked!==void 0&&(this.locked=A.locked),A.free!==void 0&&(this.free=A.free),A.removeUnusedLayers!==void 0&&(this.removeUnusedLayers=A.removeUnusedLayers),A.keepEndLayers!==void 0&&(this.keepEndLayers=A.keepEndLayers),A.at!==void 0&&(this.at=A.at),A.size!==void 0&&(this.size=A.size),A.drill!==void 0&&(this.drill=A.drill),A.layers!==void 0&&(this.layers=A.layers),A.net!==void 0&&(this.net=A.net),A.uuid!==void 0&&(this.uuid=A.uuid),A.tstamp!==void 0&&(this.tstamp=A.tstamp),A.teardrops!==void 0&&(this.teardrops=A.teardrops)}static fromSexprPrimitives(A){const t=new Syt;for(const i of A){if(typeof i=="string"){t.consumeBareToken(i);continue}if(!Array.isArray(i)||i.length===0)throw new Error(`via encountered unsupported primitive child: ${JSON.stringify(i)}`);const[n,...o]=i;if(typeof n!="string")throw new Error(`via encountered child with non-string token: ${JSON.stringify(i)}`);t.consumeNode(n,o)}return t}consumeBareToken(A){if(A==="blind"||A==="micro"){this._type=A;return}if(!Jii.has(A))throw new Error(`via encountered unsupported flag "${A}"`);switch(A){case"locked":this._locked=!0;break;case"free":this._free=!0;break;case"remove_unused_layers":this._removeUnusedLayers=!0;break;case"keep_end_layers":this._keepEndLayers=!0;break}}consumeNode(A,t){switch(A){case"type":{const i=pi(t[0]);if(i===void 0)throw new Error("via type expects a string value");this._type=i;return}case"locked":this._locked=this.parseYesNo(t);return;case"free":this._free=this.parseYesNo(t);return;case"remove_unused_layers":this._removeUnusedLayers=this.parseYesNo(t);return;case"keep_end_layers":this._keepEndLayers=this.parseYesNo(t);return;case"at":{const i=NA.parsePrimitiveSexpr(["at",...t],{parentToken:this.token});if(!(i instanceof Wg))throw new Error("via failed to parse at child");this._sxAt=i;return}case"size":{const i=ai(t[0]);if(i===void 0)throw new Error("via size expects a numeric value");this._size=i;return}case"drill":{const i=ai(t[0]);if(i===void 0)throw new Error("via drill expects a numeric value");this._drill=i;return}case"layers":{this._sxLayers=dj.fromSexprPrimitives(t);return}case"net":{this._sxNet=vwA.fromSexprPrimitives(t);return}case"teardrops":{this._sxTeardrops=HQt.fromSexprPrimitives(t);return}case"uuid":{const i=pi(t[0]);if(i===void 0)throw new Error("via uuid expects a string value");this._sxUuid=new Li(i);return}case"tstamp":{const i=pi(t[0]);if(i===void 0)throw new Error("via tstamp expects a string value");this._sxTstamp=new Zg(i);return}default:throw new Error(`via encountered unsupported child token "${A}"`)}}parseYesNo(A){if(A.length===0)return!0;const t=pi(A[0]);if(t===void 0)throw new Error("Expected string when parsing via boolean child");return/^(yes|true)$/iu.test(t)}get type(){return this._type}set type(A){this._type=A}get locked(){return this._locked}set locked(A){this._locked=A}get free(){return this._free}set free(A){this._free=A}get removeUnusedLayers(){return this._removeUnusedLayers}set removeUnusedLayers(A){this._removeUnusedLayers=A}get keepEndLayers(){return this._keepEndLayers}set keepEndLayers(A){this._keepEndLayers=A}get at(){return this._sxAt}set at(A){this._sxAt=A!==void 0?Wg.from(A):void 0}get size(){return this._size}set size(A){this._size=A}get drill(){return this._drill}set drill(A){this._drill=A}get layers(){return this._sxLayers}set layers(A){if(A===void 0){this._sxLayers=void 0;return}this._sxLayers=A instanceof dj?A:new dj(A)}get net(){return this._sxNet}set net(A){this._sxNet=A}get uuid(){return this._sxUuid}set uuid(A){if(A===void 0){this._sxUuid=void 0;return}this._sxUuid=A instanceof Li?A:new Li(A)}get teardrops(){return this._sxTeardrops}set teardrops(A){this._sxTeardrops=A}get tstamp(){return this._sxTstamp}set tstamp(A){if(A===void 0){this._sxTstamp=void 0;return}this._sxTstamp=A instanceof Zg?A:new Zg(A)}getChildren(){const A=[];return this._sxAt&&A.push(this._sxAt),this._sxLayers&&A.push(this._sxLayers),this._sxNet&&A.push(this._sxNet),this._sxUuid&&A.push(this._sxUuid),this._sxTstamp&&A.push(this._sxTstamp),this._sxTeardrops&&A.push(this._sxTeardrops),A}getString(){const A=["(via"];return this._type!==void 0&&A.push(` (type ${this._type})`),this._locked&&A.push(" (locked)"),this._free&&A.push(" (free)"),this._removeUnusedLayers&&A.push(" (remove_unused_layers)"),this._keepEndLayers&&A.push(" (keep_end_layers)"),this._sxAt&&A.push(this._sxAt.getStringIndented()),this._size!==void 0&&A.push(` (size ${this._size})`),this._drill!==void 0&&A.push(` (drill ${this._drill})`),this._sxLayers&&A.push(this._sxLayers.getStringIndented()),this._sxNet&&A.push(this._sxNet.getStringIndented()),this._sxUuid&&A.push(this._sxUuid.getStringIndented()),this._sxTstamp&&A.push(this._sxTstamp.getStringIndented()),this._sxTeardrops&&A.push(this._sxTeardrops.getStringIndented()),A.push(")"),A.join(`
|
|
5828
|
-
`)}};NA.register(LwA);var UwA=class byt extends NA{static token="kicad_pcb";token="kicad_pcb";_sxVersion;_sxGenerator;_sxGeneratorVersion;_sxGeneral;_sxPaper;_sxTitleBlock;_sxLayers;_sxSetup;_properties=[];_nets=[];_footprints=[];_images=[];_segments=[];_grLines=[];_grTexts=[];_grPolys=[];_grRects=[];_vias=[];_zones=[];_otherChildren=[];constructor(A={}){super(),A.version!==void 0&&(this.version=A.version),A.generator!==void 0&&(this.generator=A.generator),A.generatorVersion!==void 0&&(this.generatorVersion=A.generatorVersion),A.general!==void 0&&(this.general=A.general),A.paper!==void 0&&(this.paper=A.paper),A.titleBlock!==void 0&&(this.titleBlock=A.titleBlock),A.layers!==void 0&&(this.layers=A.layers),A.setup!==void 0&&(this.setup=A.setup),A.properties!==void 0&&(this.properties=A.properties),A.nets!==void 0&&(this.nets=A.nets),A.footprints!==void 0&&(this.footprints=A.footprints),A.images!==void 0&&(this.images=A.images),A.segments!==void 0&&(this.segments=A.segments),A.graphicLines!==void 0&&(this.graphicLines=A.graphicLines),A.graphicTexts!==void 0&&(this.graphicTexts=A.graphicTexts),A.graphicPolys!==void 0&&(this.graphicPolys=A.graphicPolys),A.graphicRects!==void 0&&(this.graphicRects=A.graphicRects),A.vias!==void 0&&(this.vias=A.vias),A.zones!==void 0&&(this.zones=A.zones),A.otherChildren!==void 0&&(this.otherChildren=A.otherChildren)}static fromSexprPrimitives(A){const t=new byt;for(const i of A){if(!Array.isArray(i)||i.length===0)throw new Error(`kicad_pcb encountered unsupported primitive child: ${JSON.stringify(i)}`);const n=NA.parsePrimitiveSexpr(i,{parentToken:this.token});if(!(n instanceof NA))throw new Error(`kicad_pcb expected SxClass child, received ${JSON.stringify(i)}`);t.consumeChild(n)}return t}consumeChild(A){if(A instanceof MwA){this._sxVersion=A;return}if(A instanceof RwA){this._sxGenerator=A;return}if(A instanceof NwA){this._sxGeneratorVersion=A;return}if(A instanceof FwA){this._sxGeneral=A;return}if(A instanceof ij){this._sxPaper=A;return}if(A instanceof QCt){this._sxTitleBlock=A;return}if(A instanceof GwA){this._sxLayers=A;return}if(A instanceof kwA){this._sxSetup=A;return}if(A instanceof OD){this._properties.push(A);return}if(A instanceof fj){this._nets.push(A);return}if(A instanceof xmA){this._footprints.push(A);return}if(A instanceof hCt){this._images.push(A);return}if(A instanceof JmA){this._segments.push(A);return}if(A instanceof Ej){this._grLines.push(A);return}if(A instanceof hj){this._grTexts.push(A);return}if(A instanceof sEt){this._grPolys.push(A);return}if(A instanceof iEt){this._grRects.push(A);return}if(A instanceof LwA){this._vias.push(A);return}if(A instanceof lEt){this._zones.push(A);return}this._otherChildren.push(A)}get version(){return this._sxVersion?.value}set version(A){this._sxVersion=A===void 0?void 0:new MwA(A)}get generator(){return this._sxGenerator?.value}set generator(A){this._sxGenerator=A===void 0?void 0:new RwA(A)}get generatorVersion(){return this._sxGeneratorVersion?.value}set generatorVersion(A){this._sxGeneratorVersion=A===void 0?void 0:new NwA(A)}get general(){return this._sxGeneral}set general(A){this._sxGeneral=A}get paper(){return this._sxPaper}set paper(A){this._sxPaper=A}get titleBlock(){return this._sxTitleBlock}set titleBlock(A){this._sxTitleBlock=A}get layers(){return this._sxLayers}set layers(A){this._sxLayers=A}get setup(){return this._sxSetup}set setup(A){this._sxSetup=A}get properties(){return[...this._properties]}set properties(A){this._properties=[...A]}get nets(){return[...this._nets]}set nets(A){this._nets=[...A]}get footprints(){return[...this._footprints]}set footprints(A){this._footprints=[...A]}get images(){return[...this._images]}set images(A){this._images=[...A]}get segments(){return[...this._segments]}set segments(A){this._segments=[...A]}get graphicLines(){return[...this._grLines]}set graphicLines(A){this._grLines=[...A]}get graphicTexts(){return[...this._grTexts]}set graphicTexts(A){this._grTexts=[...A]}get graphicPolys(){return[...this._grPolys]}set graphicPolys(A){this._grPolys=[...A]}get graphicRects(){return[...this._grRects]}set graphicRects(A){this._grRects=[...A]}get vias(){return[...this._vias]}set vias(A){this._vias=[...A]}get zones(){return[...this._zones]}set zones(A){this._zones=[...A]}get otherChildren(){return[...this._otherChildren]}set otherChildren(A){this._otherChildren=[...A]}getChildren(){const A=[];return this._sxVersion&&A.push(this._sxVersion),this._sxGenerator&&A.push(this._sxGenerator),this._sxGeneratorVersion&&A.push(this._sxGeneratorVersion),this._sxGeneral&&A.push(this._sxGeneral),this._sxPaper&&A.push(this._sxPaper),this._sxTitleBlock&&A.push(this._sxTitleBlock),this._sxLayers&&A.push(this._sxLayers),this._sxSetup&&A.push(this._sxSetup),A.push(...this._properties),A.push(...this._nets),A.push(...this._footprints),A.push(...this._images),A.push(...this._segments),A.push(...this._grLines),A.push(...this._grTexts),A.push(...this._grPolys),A.push(...this._grRects),A.push(...this._vias),A.push(...this._zones),A.push(...this._otherChildren),A}};NA.register(UwA);var hht=e=>NA.parse(e),Nh=class{MAX_ITERATIONS=1e3;iteration=0;finished=!1;input;ctx;constructor(e,A){this.input=e,this.ctx=A}step(){if(this.iteration++,this.iteration>this.MAX_ITERATIONS)throw new Error("Max iterations reached");this._step()}_step(){throw new Error("Not implemented")}runUntilFinished(){for(;!this.finished;)this.step()}getOutput(){throw new Error("Not implemented")}},Tii=class extends Nh{_step(){const{kicadSch:e,schematicPaperSize:A}=this.ctx;if(!e)throw new Error("KicadSch instance not initialized in context");e.version=20250114;const t=new ij;t.size=A?.name??"A4",e.paper=t,e.uuid=new Li(crypto.randomUUID()),this.finished=!0}getOutput(){return this.ctx.kicadSch}};function RG(e,A){if(e.manufacturer_part_number)return HwA(e.manufacturer_part_number);const t=Kii(e.ftype),i=A?.footprinter_string;return HwA(i?`${t}_${i}`:t)}function Kii(e){if(!e)return"component";let A=e.replace(/^simple_/,"");return A||"component"}function HwA(e){return e.replace(/[\\\/:\s]+/g,"_").replace(/_+/g,"_").replace(/^_|_$/g,"").trim()||"component"}function uht(e){return e?e.match(/^([A-Za-z]+)/)?.[1]?.toUpperCase()??"U":"U"}var dht={simple_resistor:"R",simple_capacitor:"C",simple_inductor:"L",simple_diode:"D",simple_led:"D",simple_chip:"U",simple_transistor:"Q",simple_mosfet:"Q",simple_fuse:"F",simple_switch:"SW",simple_push_button:"SW",simple_potentiometer:"RV",simple_crystal:"Y",simple_resonator:"Y",simple_pin_header:"J",simple_pinout:"J",simple_test_point:"TP",simple_battery:"BT"},Pii=/^[A-Za-z]+\d+$/;function pht(e){return e?Pii.test(e.trim()):!1}function yj(e){const A=e?.ftype;if(A&&dht[A])return dht[A];const t=e?.name;return pht(t),uht(t)}function qii(e){const A=e?.name;return pht(A)?A.trim():`${yj(e)}?`}function fht(e){return e in wQ}function yht(e,A,t,i){if(i)return`Custom:${i}`;if(e.type!=="source_component")return A.symbol_name?fht(A.symbol_name)?`Device:${A.symbol_name}`:`Custom:${A.symbol_name}`:"Device:Component";if(A.symbol_name)return fht(A.symbol_name)?`Device:${A.symbol_name}`:`Custom:${A.symbol_name}`;const n=RG(e,t);return`Device:${yj(e)}_${n}`}function Oii(e){const{circuitJson:A,schematicSymbolId:t,schematicSymbol:i,schematicComponentId:n}=e,o=A.filter(Q=>Q.type==="schematic_circle"&&Q.schematic_symbol_id===t),s=A.filter(Q=>Q.type==="schematic_line"&&Q.schematic_symbol_id===t),r=n?A.filter(Q=>Q.type==="schematic_line"&&Q.schematic_component_id===n&&!Q.schematic_symbol_id):[],a=[...s,...r],g=A.filter(Q=>Q.type==="schematic_path"&&Q.schematic_symbol_id===t),c=A.filter(Q=>Q.type==="schematic_text"&&Q.schematic_symbol_id===t);let I=A.filter(Q=>Q.type==="schematic_port"&&"schematic_symbol_id"in Q&&Q.schematic_symbol_id===t);if(I.length===0&&n&&(I=A.filter(Q=>Q.type==="schematic_port"&&Q.schematic_component_id===n&&Q.display_pin_label!==void 0),I.length===0)){const Q=A.filter(h=>h.type==="schematic_port"&&h.schematic_component_id===n),E=new Set;I=Q.filter(h=>{const u=h.pin_number;if(u!==void 0){if(E.has(u))return!1;E.add(u)}return!0})}const l=[];for(const Q of o)l.push({type:"circle",x:Q.center?.x??0,y:Q.center?.y??0,radius:Q.radius??.5,fill:Q.is_filled??!1,fillColor:Q.fill_color});for(const Q of a)l.push({type:"path",points:[{x:Q.x1??0,y:Q.y1??0},{x:Q.x2??0,y:Q.y2??0}]});for(const Q of g)Q.points&&Q.points.length>0&&l.push({type:"path",points:Q.points,fill:Q.is_filled??!1,fillColor:Q.fill_color});const B=c.map(Q=>({text:Q.text??"",x:Q.position?.x??0,y:Q.position?.y??0,fontSize:Q.font_size??.2,anchor:Q.anchor??"center"})),C=I.map((Q,E)=>({x:Q.center?.x??0,y:Q.center?.y??0,labels:[Q.display_pin_label||`${Q.pin_number||E+1}`],pinNumber:Q.pin_number||E+1,facingDirection:Q.facing_direction}));return C.sort((Q,E)=>Q.pinNumber-E.pinNumber),{center:i.center||{x:0,y:0},size:i.size||{width:1,height:1},primitives:l,texts:B,ports:C}}function Wii({points:e,transform:A,fillType:t}){const i=new dCt,n=e.map(a=>{const g=Ee(A,a);return new LQ(g.x,g.y)}),o=new YC(n);i.points=o;const s=new qD;s.width=.254,s.type="default",i.stroke=s;const r=new SCt;return r.type=t,i.fill=r,i}function Zii({primitive:e,transform:A,scale:t}){const i=new _Ct,n=Ee(A,{x:e.x,y:e.y}),o=i;o._sxCenter=new wCt(n.x,n.y),o._sxRadius=new DCt(e.radius*t);const s=new qD;s.width=.254,s.type="default",o._sxStroke=s;const r=new bCt;return r.type=e.fill?"background":"none",o._sxFill=r,i}function Vii({schText:e,transform:A,scale:t}){const i=new kCt,n=Ee(A,{x:e.x,y:e.y});i.value=e.text,i.at=[n.x,n.y,0];const o=e.fontSize*t,s=new uf;return s.size={height:o,width:o},i.effects=new hf({font:s}),i}function jii({libId:e,symbolData:A,isChip:t,c2kMatSchScale:i}){const n=new w1({libraryId:`${e.split(":")[1]}_0_1`}),s=t?i:15.24,r=A.center?.x??0,a=A.center?.y??0,g=bl(fh(s,s),ir(-r,-a));for(const I of A.primitives||[])if(I.type==="path"&&I.points){const l=t||I.fill?"background":"none",B=Wii({points:I.points,transform:g,fillType:l});n.polylines.push(B)}else if(I.type==="circle"){const l=Zii({primitive:I,transform:g,scale:s});n.circles.push(l)}const c=Array.isArray(A.texts)?A.texts:[];for(const I of c){const l=Vii({schText:I,transform:g,scale:s});n.texts.push(l)}return n}function zii(e,A){const t=A.schematic_port.list().filter(r=>r.schematic_component_id===e.schematic_component_id).sort((r,a)=>(r.pin_number||0)-(a.pin_number||0)),i=e.size?.width||1.5,n=e.size?.height||1,o={type:"path",points:[{x:-i/2,y:-n/2},{x:i/2,y:-n/2},{x:i/2,y:n/2},{x:-i/2,y:n/2},{x:-i/2,y:-n/2}]},s=t.map(r=>{const a=r.center.x-e.center.x,g=r.center.y-e.center.y;return{x:a,y:g,labels:[r.display_pin_label||`${r.pin_number||1}`],pinNumber:r.pin_number||1}});return{center:{x:0,y:0},primitives:[o],ports:s,size:{width:i,height:n}}}function Xii(e,A){const t=new uf;return t.size={height:e,width:e},new hf({font:t,hiddenText:A})}function $ii({symbol:e,libId:A,description:t,keywords:i,fpFilters:n,footprintRef:o="",referencePrefix:s}){const r=s||A.split(":")[1]?.[0]||"U",a=[{key:"Reference",value:r,id:0,at:[2.032,0,90],hide:!1},{key:"Value",value:r,id:1,at:[0,0,90],hide:!1},{key:"Footprint",value:o,id:2,at:[-1.778,0,90],hide:!0},{key:"Datasheet",value:"~",id:3,at:[0,0,0],hide:!0},{key:"Description",value:t,id:4,at:[0,0,0],hide:!0},{key:"ki_keywords",value:i,id:5,at:[0,0,0],hide:!0},{key:"ki_fp_filters",value:n,id:6,at:[0,0,0],hide:!0}];for(const g of a)e.properties.push(new df({key:g.key,value:g.value,id:g.id,at:g.at,effects:Xii(1.27,g.hide)}))}function Ani({port:e,center:A,size:t,isChip:i,portIndex:n,schematicComponent:o,schematicPorts:s,c2kMatSchScale:r}){const g=i?r:15.24;let c=e.x??0,I=e.y??0,l=!1;if(i&&n!==void 0&&o){const w=s.filter(D=>D.schematic_component_id===o.schematic_component_id).sort((D,b)=>(D.pin_number||0)-(b.pin_number||0));if(w[n]){const D=w[n];c=D.center.x-o.center.x,I=D.center.y-o.center.y,l=!0}}let B,C;if(l)B=c,C=I;else{const w=A?.x??0,D=A?.y??0;B=c-w,C=I-D}const Q=fh(g,g),E=Ee(Q,{x:B,y:C});let h;if(i&&t){const w=t.width/2,D=t.height/2,b=Math.abs(B)/w,k=Math.abs(C)/D;h=b>k}else h=Math.abs(B)>Math.abs(C);let u=E.x,d=E.y;const f=6;if(i&&t){const w=t.width/2*g,D=t.height/2*g;h?(u=B>0?w:-w,d=C*g):(u=B*g,d=C>0?D:-D)}let m=0;return h?B>0?(m=180,i&&(u=u+f)):(m=0,i&&(u=u-f)):C>0?(m=270,i&&(d=d+f)):(m=90,i&&(d=d-f)),{x:u,y:d,angle:m}}function tni({libId:e,symbolData:A,isChip:t,schematicComponent:i,schematicPorts:n,c2kMatSchScale:o}){const s=new w1({libraryId:`${e.split(":")[1]}_1_1`}),r=6,a=2.54;for(let g=0;g<(A.ports?.length||0);g++){const c=A.ports[g],I=new rj;I.pinElectricalType="passive",I.pinGraphicStyle="line";const{x:l,y:B,angle:C}=Ani({port:c,center:A.center,size:A.size,isChip:t,portIndex:g,schematicComponent:i,schematicPorts:n,c2kMatSchScale:o});I.at=[l,B,C],I.length=t?r:a;const Q=new uf;Q.size={height:1.27,width:1.27};const E=new hf({font:Q}),h=c.labels?.[0]||"~";I._sxName=new uyA({value:h,effects:E});const u=new uf;u.size={height:1.27,width:1.27};const d=new hf({font:u}),f=c.pinNumber?.toString()||`${g+1}`;I._sxNumber=new GCt({value:f,effects:d}),s.pins.push(I)}return s}var eni=class extends Nh{processedSymbolNames=new Set;_step(){const{kicadSch:e,db:A}=this.ctx,t=new HCt,i=[];this.processedSymbolNames=new Set;const n=A.schematic_component.list();for(const s of n){const r=this.createLibrarySymbolForComponent(s);r&&i.push(r)}const o=A.schematic_net_label?.list?.()||[];for(const s of o)if(s.symbol_name){const r=s.source_net_id?A.source_net.get(s.source_net_id)?.is_power:!1,a=s.source_net_id?A.source_net.get(s.source_net_id)?.is_ground:!1;if(r||a){const c=this.createLibrarySymbolForNetLabel({netLabel:s,isPower:r??!1,isGround:a??!1});c&&i.push(c)}}t.symbols=i,e&&(e.libSymbols=t),this.finished=!0}createLibrarySymbolForComponent(e){const{db:A}=this.ctx,t=e.source_component_id?A.source_component.get(e.source_component_id):null;if(!t)return null;const i=A.cad_component?.list()?.find(c=>c.source_component_id===t.source_component_id);let n=e.schematic_symbol_id;if(!n){const c=this.ctx.circuitJson.find(I=>(I.type==="schematic_line"||I.type==="schematic_circle"||I.type==="schematic_path")&&I.schematic_component_id===e.schematic_component_id&&I.schematic_symbol_id);c&&(n=c.schematic_symbol_id)}if(n)return this.createLibrarySymbolFromSchematicSymbol(e,t,i,n);const o=e.symbol_name||(t.ftype==="simple_chip"?`generic_chip_${e.source_component_id}`:null);if(!o)return null;const s=this.getSymbolData(o,e);if(!s)return null;const r=yht(t,e,i),a=t.ftype==="simple_chip",g=RG(t,i);return this.createLibrarySymbol({libId:r,symbolData:s,isChip:a,schematicComponent:e,description:this.getDescription(t),keywords:this.getKeywords(t),fpFilters:this.getFpFilters(t),footprintRef:g?`tscircuit:${g}`:"",referencePrefix:yj(t)})}createLibrarySymbolFromSchematicSymbol(e,A,t,i){const{db:n}=this.ctx,o=this.ctx.circuitJson.find(c=>c.type==="schematic_symbol"&&c.schematic_symbol_id===i);if(!o)return null;let s;if(o.name)s=o.name;else{const c=RG(A,t);c?s=c:s=`custom_${A.ftype||"component"}_${i}`}const r=`Custom:${s}`;if(this.processedSymbolNames.has(r))return null;this.processedSymbolNames.add(r);const a=Oii({circuitJson:this.ctx.circuitJson,schematicSymbolId:i,schematicSymbol:o,schematicComponentId:e.schematic_component_id}),g=RG(A,t);return this.createLibrarySymbol({libId:r,symbolData:a,isChip:!1,schematicComponent:e,description:this.getDescription(A),keywords:this.getKeywords(A),fpFilters:this.getFpFilters(A,o.name),footprintRef:g?`tscircuit:${g}`:"",referencePrefix:yj(A)})}createLibrarySymbolForNetLabel({netLabel:e,isPower:A,isGround:t}){const i=e.symbol_name;if(!i)return null;const n=wQ[i];if(!n)return null;const o=`Custom:${i}`;return this.createLibrarySymbol({libId:o,symbolData:n,isChip:!1,schematicComponent:void 0,description:A?"Power net label":t?"Ground net label":"Net symbol",keywords:A?"power net":t?"ground net":"net",fpFilters:"",referencePrefix:o.split(":")[1]?.[0]||"U"})}getSymbolData(e,A){return e.startsWith("generic_chip_")?zii(A,this.ctx.db):wQ[e]||null}createLibrarySymbol({libId:e,symbolData:A,isChip:t,schematicComponent:i,description:n,keywords:o,fpFilters:s,footprintRef:r="",referencePrefix:a}){const g=new w1({libraryId:e,excludeFromSim:!1,inBom:!0,onBoard:!0}),c=new QyA;c.hide=!t,g._sxPinNumbers=c;const I=new hyA;I.offset=t?1.27:0,g._sxPinNames=I,$ii({symbol:g,libId:e,description:n,keywords:o,fpFilters:s,footprintRef:r,referencePrefix:a});const l=jii({libId:e,symbolData:A,isChip:t,c2kMatSchScale:this.ctx.c2kMatSch?.a??15});g.subSymbols.push(l);const B=tni({libId:e,symbolData:A,isChip:t,schematicComponent:i,schematicPorts:this.ctx.db.schematic_port.list(),c2kMatSchScale:this.ctx.c2kMatSch?.a??15});return g.subSymbols.push(B),g._sxEmbeddedFonts=new y1(!1),g}getDescription(e){return e?.ftype==="simple_resistor"?"Resistor":e?.ftype==="simple_capacitor"?"Capacitor":e?.ftype==="simple_chip"?"Integrated Circuit":"Component"}getKeywords(e){return e?.ftype==="simple_resistor"?"R res resistor":e?.ftype==="simple_capacitor"?"C cap capacitor":e?.ftype==="simple_chip"?"U IC chip":""}getFpFilters(e,A){return A?`${A}*`:e?.ftype==="simple_resistor"?"R_*":e?.ftype==="simple_capacitor"?"C_*":(e?.ftype==="simple_chip","*")}getOutput(){if(!this.ctx.kicadSch)throw new Error("kicadSch is not initialized");return this.ctx.kicadSch}},ini=class extends Nh{_step(){const{kicadSch:e,db:A}=this.ctx,t=A.schematic_component.list();if(t.length===0){this.finished=!0;return}const i=[];for(const n of t){const o=n.source_component_id?A.source_component.get(n.source_component_id):null;if(!o||!this.ctx.c2kMatSch)continue;const{x:s,y:r}=Ee(this.ctx.c2kMatSch,{x:n.center.x,y:n.center.y}),a=crypto.randomUUID(),g=new w1({at:[s,r,0],unit:1,excludeFromSim:!1,inBom:!0,onBoard:!0,dnp:!1,uuid:a,fieldsAutoplaced:!0}),c=A.cad_component?.list()?.find(oA=>oA.source_component_id===o.source_component_id);let I,l=n.schematic_symbol_id;if(!l){const oA=this.ctx.circuitJson.find(rA=>(rA.type==="schematic_line"||rA.type==="schematic_circle"||rA.type==="schematic_path")&&rA.schematic_component_id===n.schematic_component_id&&rA.schematic_symbol_id);oA&&(l=oA.schematic_symbol_id)}if(l){const oA=this.ctx.circuitJson.find(rA=>rA.type==="schematic_symbol"&&rA.schematic_symbol_id===l);if(oA?.name)I=oA.name;else{const rA=RG(o,c);rA?I=rA:I=`custom_${o.ftype||"component"}_${l}`}}const B=yht(o,n,c,I),C=new ByA(B);g._sxLibId=C;const{reference:Q,value:E,description:h}=this.getComponentMetadata(o),{refTextPos:u,valTextPos:d}=this.getTextPositions(n,{x:s,y:r});let f;if(l){const oA=this.ctx.circuitJson.find(rA=>rA.type==="schematic_symbol"&&rA.schematic_symbol_id===l);oA&&oA.type==="schematic_symbol"&&(f=oA.metadata?.kicad_symbol)}const m=f?.properties?.Reference,w=new df({key:"Reference",value:m?.value??Q,id:0,at:[u.x,u.y,0],effects:this.createTextEffects(Number(m?.effects?.font?.size?.x??1.27),m?.effects?.hide??!1)}),D=o.ftype==="simple_chip",b=f?.properties?.Value,k=new df({key:"Value",value:b?.value??E,id:1,at:[d.x,d.y,0],effects:this.createTextEffects(Number(b?.effects?.font?.size?.x??1.27),b?.effects?.hide??D)}),x=f?.properties?.Footprint,N=new df({key:"Footprint",value:x?.value??"",id:2,at:[s-1.778,r,90],effects:this.createTextEffects(1.27,x?.effects?.hide??!0)}),R=f?.properties?.Datasheet,U=new df({key:"Datasheet",value:R?.value??"~",id:3,at:[s,r,0],effects:this.createTextEffects(1.27,R?.effects?.hide??!0)}),T=f?.properties?.Description,Y=new df({key:"Description",value:T?.value??h,id:4,at:[s,r,0],effects:this.createTextEffects(1.27,T?.effects?.hide??!0)});g.properties.push(w,k,N,U,Y);const O=f?.properties?.ki_keywords;if(O?.value){const oA=new df({key:"ki_keywords",value:O.value,id:5,at:[s,r,0],effects:this.createTextEffects(1.27,O.effects?.hide??!0)});g.properties.push(oA)}const W=f?.properties?.ki_fp_filters;if(W?.value){const oA=new df({key:"ki_fp_filters",value:W.value,id:6,at:[s,r,0],effects:this.createTextEffects(1.27,W.effects?.hide??!0)});g.properties.push(oA)}if(f){if(f.inBom!==void 0&&(g.inBom=f.inBom),f.onBoard!==void 0&&(g.onBoard=f.onBoard),f.excludeFromSim!==void 0&&(g.excludeFromSim=f.excludeFromSim),f.pinNames){const oA=new hyA;f.pinNames.offset!==void 0&&(oA.offset=Number(f.pinNames.offset)),f.pinNames.hide!==void 0&&(oA.hide=f.pinNames.hide),g.pinNames=oA}if(f.pinNumbers){const oA=new QyA;f.pinNumbers.hide!==void 0&&(oA.hide=f.pinNumbers.hide),g.pinNumbers=oA}f.embeddedFonts!==void 0&&(g._sxEmbeddedFonts=new y1(f.embeddedFonts))}let X=A.schematic_port.list().filter(oA=>oA.schematic_component_id===n.schematic_component_id);if(l){const oA=X.filter(rA=>rA.display_pin_label);oA.length>0&&(X=oA)}X.sort((oA,rA)=>(oA.pin_number||0)-(rA.pin_number||0));for(let oA=0;oA<X.length;oA++){const rA=X[oA];if(!rA)continue;const CA=new rj;CA.numberString=`${rA.pin_number||oA+1}`,CA.uuid=crypto.randomUUID(),g.pins.push(CA)}const iA=new dyA,aA=new fyA(""),tA=new yyA(`/${e?.uuid?.value||""}`);tA.reference=Q,tA.unit=1,aA.paths.push(tA),iA.projects.push(aA),g._sxInstances=iA,i.push(g)}e&&(e.symbols=i),this.finished=!0}getTextPositions(e,A){const i=(this.ctx.db.schematic_text?.list?.()?.filter(B=>B.schematic_component_id===e.schematic_component_id)||[]).find(B=>B.text&&B.text.length>0);if(i&&this.ctx.c2kMatSch){const B=Ee(this.ctx.c2kMatSch,{x:i.position.x,y:i.position.y}),C={x:A.x,y:A.y+6};return{refTextPos:B,valTextPos:C}}const n=e.symbol_name,o=wQ[n];if(!o)return{refTextPos:{x:A.x,y:A.y-6},valTextPos:{x:A.x,y:A.y+6}};let s=null,r=null;for(const B of o.primitives)B.type==="text"&&(B.text==="{REF}"?s=B:B.text==="{VAL}"&&(r=B));const a=o.center||{x:0,y:0},c=n.includes("_down")||n.includes("_up")?.15:0,I=s&&this.ctx.c2kMatSch?Ee(this.ctx.c2kMatSch,{x:e.center.x+(s.x-a.x)+c,y:e.center.y+(s.y-a.y)}):{x:A.x,y:A.y-6},l=r&&this.ctx.c2kMatSch?Ee(this.ctx.c2kMatSch,{x:e.center.x+(r.x-a.x)+c,y:e.center.y+(r.y-a.y)}):{x:A.x,y:A.y+6};return{refTextPos:I,valTextPos:l}}getComponentMetadata(e){const A=e.name||"?",t=qii(e);return e.ftype==="simple_resistor"?{reference:t,value:e.display_resistance||"R",description:"Resistor"}:e.ftype==="simple_capacitor"?{reference:t,value:e.display_capacitance||"C",description:"Capacitor"}:e.ftype==="simple_inductor"?{reference:t,value:e.display_inductance||"L",description:"Inductor"}:e.ftype==="simple_diode"?{reference:t,value:"D",description:"Diode"}:e.ftype==="simple_chip"?{reference:t,value:A,description:"Integrated Circuit"}:e.ftype==="simple_led"?{reference:t,value:e.manufacturer_part_number||"",description:"LED"}:e.ftype==="simple_switch"?{reference:t,value:e.manufacturer_part_number||"",description:"Switch"}:e.ftype==="simple_potentiometer"?{reference:t,value:e.display_max_resistance||"",description:"Potentiometer"}:{reference:t,value:A,description:"Component"}}createTextEffects(e,A=!1,t){const i=new uf;i.size={height:e,width:e};const n=t?new MJ({horizontal:t}):void 0;return new hf({font:i,hiddenText:A,justify:n})}getOutput(){if(!this.ctx.kicadSch)throw new Error("kicadSch is not initialized");return this.ctx.kicadSch}},nni=class extends Nh{_step(){const{kicadSch:e,db:A}=this.ctx,t=A.schematic_net_label?.list?.()||[];if(t.length===0){this.finished=!0;return}if(!this.ctx.c2kMatSch){this.finished=!0;return}const i=[],n=[];for(const o of t){const s=o.text||"",r=o.symbol_name;if(r){const a=this.createSymbolFromNetLabel(o,s,r);a&&i.push(a)}else{const a=this.createGlobalLabel(o,s);a&&n.push(a)}}if(e&&i.length>0){const o=e.symbols||[];e.symbols=[...o,...i]}e&&n.length>0&&(e.globalLabels=[...e.globalLabels||[],...n]),this.finished=!0}createSymbolFromNetLabel(e,A,t){if(!this.ctx.c2kMatSch)return null;const{x:i,y:n}=Ee(this.ctx.c2kMatSch,{x:e.anchor_position?.x??e.center?.x??0,y:e.anchor_position?.y??e.center?.y??0}),o=crypto.randomUUID(),s=new w1({at:[i,n,0],unit:1,excludeFromSim:!1,inBom:!0,onBoard:!0,dnp:!1,uuid:o,fieldsAutoplaced:!0}),r=`Custom:${t}`,a=new ByA(r);s._sxLibId=a;const g=t.includes("_up")||t.toLowerCase().includes("vcc"),c=g?-4:4,I=g?-6:6,l=new df({key:"Reference",value:A,id:0,at:[i,n+c,0],effects:this.createTextEffects(1.27,!1)}),B=new df({key:"Value",value:A,id:1,at:[i,n+I,0],effects:this.createTextEffects(1.27,!0)}),C=new df({key:"Footprint",value:"",id:2,at:[i-1.778,n,90],effects:this.createTextEffects(1.27,!0)}),Q=new df({key:"Datasheet",value:"~",id:3,at:[i,n,0],effects:this.createTextEffects(1.27,!0)}),E=new df({key:"Description",value:`Power/Net symbol: ${A}`,id:4,at:[i,n,0],effects:this.createTextEffects(1.27,!0)});s.properties.push(l,B,C,Q,E);const h=new rj;h.numberString="1",h.uuid=crypto.randomUUID(),s.pins.push(h);const{kicadSch:u}=this.ctx,d=new dyA,f=new fyA(""),m=new yyA(`/${u?.uuid?.value||""}`);return m.reference=A,m.unit=1,f.paths.push(m),d.projects.push(f),s._sxInstances=d,s}createGlobalLabel(e,A){if(!this.ctx.c2kMatSch||!this.ctx.kicadSch)return null;const{x:t,y:i}=Ee(this.ctx.c2kMatSch,{x:e.anchor_position?.x??e.center?.x??0,y:e.anchor_position?.y??e.center?.y??0}),n=e.anchor_side||"left",s={left:0,right:180,top:270,bottom:90}[n]||0,a={left:{horizontal:"left"},right:{horizontal:"right"},top:{vertical:"top"},bottom:{vertical:"bottom"}}[n]||{},g=this.createTextEffects(1.27,!1);return Object.keys(a).length>0&&(g.justify=new MJ(a)),new ZCt({value:A,at:[t,i,s],effects:g,uuid:crypto.randomUUID(),fieldsAutoplaced:!0})}createTextEffects(e,A=!1){const t=new uf;return t.size={height:e,width:e},new hf({font:t,hiddenText:A})}getOutput(){if(!this.ctx.kicadSch)throw new Error("kicadSch is not initialized");return this.ctx.kicadSch}},oni=class extends Nh{_step(){const{kicadSch:e,db:A}=this.ctx;if(!e)throw new Error("KicadSch instance not initialized in context");const t=A.schematic_trace.list();if(t.length===0){this.finished=!0;return}const i=[],n=[];for(const o of t){for(const s of o.edges){const r=this.createWireFromEdge(s);i.push(r)}for(const s of o.junctions){const r=this.createJunction(s);n.push(r)}}e.wires=i,e.junctions=n,this.finished=!0}createWireFromEdge(e){const A=new JCt;if(!this.ctx.c2kMatSch)throw new Error("Schematic transformation matrix not initialized in context");const t=Ee(this.ctx.c2kMatSch,{x:e.from.x,y:e.from.y}),i=Ee(this.ctx.c2kMatSch,{x:e.to.x,y:e.to.y}),n=t.x,o=t.y,s=i.x,r=i.y,a=new YC([new LQ(n,o),new LQ(s,r)]);A.points=a;const g=new qD;return g.width=0,g.type="default",A.stroke=g,A.uuid=crypto.randomUUID(),A}createJunction(e){if(!this.ctx.c2kMatSch)throw new Error("Schematic transformation matrix not initialized in context");const{x:A,y:t}=Ee(this.ctx.c2kMatSch,{x:e.x,y:e.y}),i=new TCt({at:[A,t],diameter:0});return i.uuid=crypto.randomUUID(),i}getOutput(){return this.ctx.kicadSch}},sni=class extends Nh{_step(){const{kicadSch:e}=this.ctx;if(!e)throw new Error("KicadSch instance not initialized in context");const A=new SyA,t=new zCt;t.value="/";const i=new XCt("1");t.pages=[i],A.paths=[t],e.sheetInstances=A,e.embeddedFonts=new y1(!1),this.finished=!0}getOutput(){return this.ctx.kicadSch}};function rni(e){const A=e.schematic_component.list(),t=e.schematic_trace.list();let i=1/0,n=1/0,o=-1/0,s=-1/0;for(const g of A){const c=g.size?.width??0,I=g.size?.height??0;i=Math.min(i,g.center.x-c/2),n=Math.min(n,g.center.y-I/2),o=Math.max(o,g.center.x+c/2),s=Math.max(s,g.center.y+I/2)}for(const g of t)for(const c of g.edges)i=Math.min(i,c.from.x,c.to.x),n=Math.min(n,c.from.y,c.to.y),o=Math.max(o,c.from.x,c.to.x),s=Math.max(s,c.from.y,c.to.y);i===1/0&&(i=0,n=0,o=0,s=0);const r=(i+o)/2,a=(n+s)/2;return{center:{x:r,y:a},bounds:{minX:i,minY:n,maxX:o,maxY:s}}}var mj=[{name:"A4",width:297,height:210},{name:"A3",width:420,height:297},{name:"A2",width:594,height:420},{name:"A1",width:841,height:594},{name:"A0",width:1189,height:841}];function ani(e,A,t=20){const i=e+2*t,n=A+2*t;for(let o=0;o<mj.length;o++){const s=mj[o];if(i<=s.width&&n<=s.height)return s}return mj[mj.length-1]}var mht=class{ctx;pipeline;currentStageIndex=0;finished=!1;get currentStage(){return this.pipeline[this.currentStageIndex]}constructor(e){const t=xa(e),{center:i,bounds:n}=rni(t),o=(n.maxX-n.minX)*15,s=(n.maxY-n.minY)*15,r=ani(o,s),a=r.width/2,g=r.height/2;this.ctx={db:t,circuitJson:e,kicadSch:new xyA({generator:"circuit-json-to-kicad",generatorVersion:"0.0.1"}),schematicPaperSize:r,c2kMatSch:bl(ir(a,g),fh(15,-15),ir(-i.x,-i.y))},this.pipeline=[new Tii(e,this.ctx),new eni(e,this.ctx),new ini(e,this.ctx),new nni(e,this.ctx),new oni(e,this.ctx),new sni(e,this.ctx)]}step(){if(!this.currentStage){this.finished=!0;return}this.currentStage.step(),this.currentStage.finished&&this.currentStageIndex++}runUntilFinished(){for(;!this.finished;)this.step()}getOutput(){return this.ctx.kicadSch}getOutputString(){return this.ctx.kicadSch.getString()}},gni=class extends Nh{_step(){const{kicadPcb:e,db:A}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");const i=A.pcb_board?.list()?.[0]?.num_layers??2;this.ctx.numLayers=i,e.version=20241229;const n=new ij;n.size="A4",e.paper=n;const o=new FwA;o.thickness=1.6,e.general=o;const s=new kwA;s.padToMaskClearance=0,e.setup=s;const r=new GwA,a=[new Rl({index:0,name:"F.Cu",type:"signal"})];for(let g=1;g<i-1;g++)a.push(new Rl({index:g,name:`In${g}.Cu`,type:"signal"}));a.push(new Rl({index:31,name:"B.Cu",type:"signal"})),a.push(new Rl({index:32,name:"B.Adhes",type:"user"}),new Rl({index:33,name:"F.Adhes",type:"user"}),new Rl({index:34,name:"B.Paste",type:"user"}),new Rl({index:35,name:"F.Paste",type:"user"}),new Rl({index:36,name:"B.SilkS",type:"user"}),new Rl({index:37,name:"F.SilkS",type:"user"}),new Rl({index:38,name:"B.Mask",type:"user"}),new Rl({index:39,name:"F.Mask",type:"user"}),new Rl({index:40,name:"Dwgs.User",type:"user"}),new Rl({index:41,name:"Cmts.User",type:"user"}),new Rl({index:42,name:"Eco1.User",type:"user"}),new Rl({index:43,name:"Eco2.User",type:"user"}),new Rl({index:44,name:"Edge.Cuts",type:"user"}),new Rl({index:45,name:"Margin",type:"user"}),new Rl({index:46,name:"B.CrtYd",type:"user"}),new Rl({index:47,name:"F.CrtYd",type:"user"}),new Rl({index:48,name:"B.Fab",type:"user"}),new Rl({index:49,name:"F.Fab",type:"user"})),r.definitions=a,e.layers=r,this.finished=!0}getOutput(){return this.ctx.kicadPcb}},cni=class extends Nh{_step(){const{kicadPcb:e}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");this.ctx.pcbNetMap=new Map;const A=new Map,t=this.ctx.db.source_net?.list()??[];for(const r of t){const a=r.subcircuit_connectivity_map_key||r.source_net_id;if(!a)continue;const g=r.name||r.source_net_id||"",c=g&&g.trim().length>0?g:a;A.set(a,c)}const i=this.ctx.db.source_trace?.list()??[];for(const r of i){let a=r.subcircuit_connectivity_map_key;if(!a&&r.connected_source_net_ids?.length)for(const g of r.connected_source_net_ids){const c=this.ctx.db.source_net?.get(g);if(c?.subcircuit_connectivity_map_key&&c.subcircuit_connectivity_map_key.length>0){a=c.subcircuit_connectivity_map_key;break}}if(a&&!A.has(a)){const g=r.display_name||r.source_trace_id||"",c=g&&g.trim().length>0?g:a;A.set(a,c)}}const n=Array.from(A.entries()).sort((r,a)=>r[0].localeCompare(a[0])),o=[];o.push(new fj(0,""));let s=1;for(const[r,a]of n){const g=new fj(s,a);o.push(g);const c={id:s,name:a};this.ctx.pcbNetMap.set(r,c),s++}e.nets=o,this.finished=!0}getOutput(){return this.ctx.kicadPcb}};function Ini(e){let A=0;for(let i=0;i<e.length;i++){const n=e.charCodeAt(i);A=(A<<5)-A+n,A=A&A}let t="";for(let i=0;i<4;i++){let n=A;for(let o=0;o<e.length;o++)n=(n<<5)-n+e.charCodeAt(o)+i*31,n=n&n;t+=Math.abs(n).toString(16).padStart(8,"0")}return t}function pf(e){const A=Ini(e);return`${A.slice(0,8)}-${A.slice(8,12)}-${A.slice(12,16)}-${A.slice(16,20)}-${A.slice(20,32)}`}function wj(e){const A=new uf;return e?.font?.size?A.size={width:Number(e.font.size.x),height:Number(e.font.size.y)}:A.size={width:1.27,height:1.27},e?.font?.thickness!==void 0?A.thickness=Number(e.font.thickness):A.thickness=.15,new hf({font:A})}function lni(e,A,t){if(A.properties){const i=[],n=A.properties.Reference;i.push(new OD({key:"Reference",value:t,position:n?.at?[Number(n.at.x),Number(n.at.y),Number(n.at.rotation??0)]:[0,-3,0],layer:n?.layer??"F.SilkS",uuid:pf(`${t}-property-Reference`),effects:wj(n?.effects),hidden:n?.hide}));const o=A.properties.Value,s=o?.value??A.footprintName??"";i.push(new OD({key:"Value",value:s,position:o?.at?[Number(o.at.x),Number(o.at.y),Number(o.at.rotation??0)]:[0,3,0],layer:o?.layer??"F.Fab",uuid:pf(`${t}-property-Value`),effects:wj(o?.effects),hidden:o?.hide}));const r=A.properties.Datasheet;i.push(new OD({key:"Datasheet",value:r?.value??"",position:r?.at?[Number(r.at.x),Number(r.at.y),Number(r.at.rotation??0)]:[0,0,0],layer:r?.layer??"F.Fab",uuid:pf(`${t}-property-Datasheet`),effects:wj(r?.effects),hidden:r?.hide??!0}));const a=A.properties.Description;i.push(new OD({key:"Description",value:a?.value??"",position:a?.at?[Number(a.at.x),Number(a.at.y),Number(a.at.rotation??0)]:[0,0,0],layer:a?.layer??"F.Fab",uuid:pf(`${t}-property-Description`),effects:wj(a?.effects),hidden:a?.hide??!0})),e.properties=i}if(A.attributes&&(e.attr||(e.attr=new _yA),A.attributes.through_hole?e.attr.type="through_hole":A.attributes.smd&&(e.attr.type="smd"),A.attributes.exclude_from_pos_files!==void 0&&(e.attr.excludeFromPosFiles=A.attributes.exclude_from_pos_files),A.attributes.exclude_from_bom!==void 0&&(e.attr.excludeFromBom=A.attributes.exclude_from_bom)),A.footprintName&&(e.libraryLink=A.footprintName),A.layer&&(e.layer=A.layer),A.embeddedFonts!==void 0&&(e.embeddedFonts=new y1(A.embeddedFonts)),A.model){const i=new Bj(A.model.path);A.model.offset&&(i.offset={x:Number(A.model.offset.x),y:Number(A.model.offset.y),z:Number(A.model.offset.z)}),A.model.scale&&(i.scale={x:Number(A.model.scale.x),y:Number(A.model.scale.y),z:Number(A.model.scale.z)}),A.model.rotate&&(i.rotate={x:Number(A.model.rotate.x),y:Number(A.model.rotate.y),z:Number(A.model.rotate.z)});const n=e.models||[];e.models=[i,...n]}}function Bni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),r={top:"F.SilkS",bottom:"B.SilkS"}[i.layer]||i.layer||"F.SilkS",a=new lmA({center:{x:n,y:o},end:{x:n+i.radius,y:o},layer:r,stroke:new qD,fill:!1});a.stroke&&(a.stroke.width=i.stroke_width||.05,a.stroke.type="default"),t.push(a)}return t}function Cni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),r={top:"F.CrtYd",bottom:"B.CrtYd"}[i.layer]||"F.CrtYd",a=new lmA({center:{x:n,y:o},end:{x:n+i.radius,y:o},layer:r,stroke:new qD,fill:!1});a.stroke&&(a.stroke.width=.05,a.stroke.type="default"),t.push(a)}return t}function Qni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),s=i.width/2,r=i.height/2,g={top:"F.Fab",bottom:"B.Fab"}[i.layer]||i.layer||"F.Fab",c=new Ij({start:{x:n-s,y:o-r},end:{x:n+s,y:o+r},layer:g,stroke:new qD,fill:!1});c.stroke&&(c.stroke.width=i.stroke_width||.1,c.stroke.type="default"),t.push(c)}return t}function Eni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),s=i.width/2,r=i.height/2,a="F.Fab",g=new Ij({start:{x:n-s,y:o-r},end:{x:n+s,y:o+r},layer:a,stroke:new qD,fill:!1});g.stroke&&(g.stroke.width=i.stroke_width||.1,g.stroke.type="default"),t.push(g)}return t}function hni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),s=i.width/2,r=i.height/2,g={top:"F.CrtYd",bottom:"B.CrtYd"}[i.layer]||"F.CrtYd",c=new Ij({start:{x:n-s,y:o-r},end:{x:n+s,y:o+r},layer:g,stroke:new qD,fill:!1});c.stroke&&(c.stroke.width=.05,c.stroke.type="default"),t.push(c)}return t}function uni(e,A){const t=[];for(const i of e){if(!i.outline||i.outline.length<2)continue;const o={top:"F.CrtYd",bottom:"B.CrtYd"}[i.layer]||"F.CrtYd",s=i.outline.map(g=>{const c=g.x-A.x,I=-(g.y-A.y);return new LQ(c,I)}),r=new PQt;r.points=new YC(s),r.layer=o,r.fill=!1;const a=new qD;a.width=.05,a.type="default",r.stroke=a,t.push(r)}return t}function dni({textElement:e,componentCenter:A,componentRotation:t=0}){if(!e.text||!e.anchor_position)return null;const i=e.anchor_position.x-A.x,n=-(e.anchor_position.y-A.y),o=t!==0?Rm(t*Math.PI/180):Ru(),s=Ee(o,{x:i,y:n}),r={x:s.x,y:s.y},g={top:"F.SilkS",bottom:"B.SilkS"}[e.layer]||e.layer||"F.SilkS",c=(e.font_size||1)/1.5,I=new uf;I.size={width:c,height:c};const l=new hf({font:I}),B=e.ccw_rotation||0;return new emA({type:"user",text:e.text,position:{x:r.x,y:r.y,angle:B},layer:g,effects:l})}function pni(e,A,t,i){const n=[];for(const o of e){const s=dni({textElement:o,componentCenter:A,componentRotation:t});s&&(i&&o.text===i&&(s.type="reference"),n.push(s))}return n}function fni(e,A,t){const i=[];for(const n of e){const o=n.anchor_position.x-A.x,s=-(n.anchor_position.y-A.y),r=t!==0?Rm(t*Math.PI/180):Ru(),a=Ee(r,{x:o,y:s}),g=n.font_size||1,c=new uf;c.size={width:g,height:g};const I=new hf({font:c}),l=new emA({type:"user",text:n.text,position:{x:a.x,y:a.y,angle:0},layer:"F.Fab",effects:I});i.push(l)}return i}function yni(e,A){const t=[],i=e.model_step_url||e.model_wrl_url;if(!i)return t;const n=new Bj(i);if(e.position&&(n.offset={x:(e.position.x||0)-A.x,y:-((e.position.y||0)-A.y),z:e.position.z||0}),e.rotation&&(n.rotate={x:e.rotation.x||0,y:e.rotation.y||0,z:e.rotation.z||0}),e.model_unit_to_mm_scale_factor){const o=e.model_unit_to_mm_scale_factor;n.scale={x:o,y:o,z:o}}return t.push(n),t}function mni({pcbPad:e,componentCenter:A,padNumber:t,componentRotation:i=0,netInfo:n,componentId:o}){let s,r;if("x"in e&&"y"in e)s=e.x,r=e.y;else if("points"in e&&Array.isArray(e.points)){const u=e.points;s=u.reduce((d,f)=>d+f.x,0)/u.length,r=u.reduce((d,f)=>d+f.y,0)/u.length}else throw new Error("Pad must have either x/y coordinates or points array");const a=bl(i!==0?Rm(i*Math.PI/180):{a:1,b:0,c:0,d:1,e:0,f:0},fh(1,-1),ir(-A.x,-A.y)),g=Ee(a,{x:s,y:r}),I={top:"F.Cu",bottom:"B.Cu"}[e.layer]||"F.Cu";let l,B,C,Q;if(e.shape==="circle")l="circle",B=["radius"in e?e.radius*2:.5,"radius"in e?e.radius*2:.5];else if(e.shape==="polygon"&&"points"in e){const u=e.points,d=bl(fh(1,-1),ir(-s,-r)),f=u.map(w=>{const D=Ee(d,{x:w.x,y:w.y});return new LQ(D.x,D.y)}),m=new zyA;m.contours=[new YC(f)],m.width=0,m.filled=!0,Q=new bQt,Q.addGraphic(m),l="custom",C=new cQt,C.anchor="circle",B=[.2,.2]}else l="rect",B=["width"in e?e.width:.5,"height"in e?e.height:.5];const E=`pad:${o}:${t}:${g.x},${g.y}`,h=new cj({number:String(t),padType:"smd",shape:l,at:[g.x,g.y,0],size:B,layers:[`${I}`,`${I==="F.Cu"?"F":"B"}.Paste`,`${I==="F.Cu"?"F":"B"}.Mask`],uuid:pf(E)});return C&&(h.options=C),Q&&(h.primitives=Q),n&&(h.net=new qyA(n.id,n.name)),h}function wni(e,A,t,i,n,o){const s=[];let r=n;for(const a of e){const g=o(a.pcb_port_id),c=mni({pcbPad:a,componentCenter:A,padNumber:r,componentRotation:t,netInfo:g,componentId:i});s.push(c),r++}return{pads:s,nextPadNumber:r}}function Dni({platedHole:e,componentCenter:A,padNumber:t,componentRotation:i=0,netInfo:n,componentId:o}){if(!("x"in e&&"y"in e))return null;const s=e.x-A.x,r=-(e.y-A.y),a=i!==0?Rm(i*Math.PI/180):Ru(),g=Ee(a,{x:s,y:r});let c="circle",I,l,B=0;const C="hole_offset_x"in e||"hole_offset_y"in e;let Q;if(C){const u={x:e.hole_offset_x??0,y:e.hole_offset_y??0};(u.x!==0||u.y!==0)&&(Q=Ee(a,{x:-u.x,y:u.y}))}e.shape==="circle"?(c="circle",I=[e.outer_diameter,e.outer_diameter],l=new WD({diameter:e.hole_diameter,offset:Q})):e.shape==="pill"||e.shape==="oval"?(c="oval",I=[e.outer_width,e.outer_height],l=new WD({oval:!0,diameter:e.hole_width,width:e.hole_height,offset:Q})):e.shape==="pill_hole_with_rect_pad"?(c="rect",I=[e.rect_pad_width,e.rect_pad_height],l=new WD({oval:!0,diameter:e.hole_width,width:e.hole_height,offset:Q})):e.shape==="circular_hole_with_rect_pad"?(c="rect",I=[e.rect_pad_width,e.rect_pad_height],l=new WD({diameter:e.hole_diameter,offset:Q})):e.shape==="rotated_pill_hole_with_rect_pad"?(c="rect",I=[e.rect_pad_width,e.rect_pad_height],l=new WD({oval:!0,diameter:e.hole_width,width:e.hole_height,offset:Q}),B=e.rect_ccw_rotation||0):(c="circle",I=[1.6,1.6],l=new WD({diameter:.8,offset:Q}));const E=`thruhole:${o}:${t}:${g.x},${g.y}`,h=new cj({number:String(t),padType:"thru_hole",shape:c,at:[g.x,g.y,B],size:I,drill:l,layers:["*.Cu","*.Mask"],removeUnusedLayers:!1,uuid:pf(E)});return n&&(h.net=new qyA(n.id,n.name)),h}function Sni(e,A,t,i,n,o){const s=[];let r=n;for(const a of e){const g=o(a.pcb_port_id),c=Dni({platedHole:a,componentCenter:A,padNumber:r,componentRotation:t,netInfo:g,componentId:i});c&&(s.push(c),r++)}return{pads:s,nextPadNumber:r}}function bni({pcbHole:e,componentCenter:A,componentRotation:t=0}){if(!("x"in e&&"y"in e))return null;const i=e.x-A.x,n=-(e.y-A.y),o=t!==0?Rm(t*Math.PI/180):Ru(),s=Ee(o,{x:i,y:n});let r="circle",a,g;if(e.hole_shape==="circle"){r="circle";const c=e.hole_diameter;a=[c,c],g=new WD({diameter:c})}else if(e.hole_shape==="oval"){r="oval";const c=e.hole_width,I=e.hole_height;a=[c,I],g=new WD({oval:!0,diameter:c,width:I})}else{r="circle";const c="hole_diameter"in e?e.hole_diameter:1;a=[c,c],g=new WD({diameter:c})}return new cj({number:"",padType:"np_thru_hole",shape:r,at:[s.x,s.y,0],size:a,drill:g,layers:["*.Cu","*.Mask"],removeUnusedLayers:!1,uuid:crypto.randomUUID()})}function xni(e,A,t){const i=[];for(const n of e){const o=bni({pcbHole:n,componentCenter:A,componentRotation:t});o&&i.push(o)}return i}var _ni=class extends Nh{componentsProcessed=0;pcbComponents=[];getNetInfoForPcbPort(e){if(!e)return;const A=this.ctx.db.pcb_port?.get(e);if(!A)return;const t=A.source_port_id;if(!t)return;const i=this.ctx.db.source_port?.get(t);if(!i)return;const n=i.subcircuit_connectivity_map_key;if(n)return this.ctx.pcbNetMap?.get(n)}getCadComponentForPcbComponent(e){return(this.ctx.db.cad_component?.list()||[]).find(t=>t.pcb_component_id===e)}constructor(e,A){super(e,A),this.pcbComponents=this.ctx.db.pcb_component.list()}_step(){const{kicadPcb:e,c2kMatPcb:A}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");if(!A)throw new Error("PCB transformation matrix not initialized in context");if(this.componentsProcessed>=this.pcbComponents.length){this.finished=!0;return}const t=this.pcbComponents[this.componentsProcessed],i=t.source_component_id?this.ctx.db.source_component.get(t.source_component_id):null,n=this.getCadComponentForPcbComponent(t.pcb_component_id),o=i?RG(i,n):"Unknown",s=Ee(A,{x:t.center.x,y:t.center.y}),r=`footprint:${t.pcb_component_id}:${s.x},${s.y}`,a=new xmA({libraryLink:`tscircuit:${o}`,layer:"F.Cu",at:[s.x,s.y,t.rotation||0],uuid:pf(r)}),g=a.fpTexts,c=this.ctx.db.pcb_silkscreen_text?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];g.push(...pni(c,t.center,t.rotation||0,i?.name));const I=this.ctx.db.pcb_note_text?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];g.push(...fni(I,t.center,t.rotation||0)),a.fpTexts=g;const l=a.fpPads,B=O=>this.getNetInfoForPcbPort(O),C=this.ctx.db.pcb_smtpad?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],{pads:Q,nextPadNumber:E}=wni(C,t.center,t.rotation||0,t.pcb_component_id,1,B);l.push(...Q);const h=this.ctx.db.pcb_plated_hole?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],{pads:u}=Sni(h,t.center,t.rotation||0,t.pcb_component_id,E,B);l.push(...u);const d=this.ctx.db.pcb_hole?.list().filter(O=>O.subcircuit_id===t.subcircuit_id)||[],f=xni(d,t.center,t.rotation||0);l.push(...f),a.fpPads=l;const m=this.ctx.db.pcb_silkscreen_circle?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],w=a.fpCircles??[];w.push(...Bni(m,t.center));const D=this.ctx.db.pcb_courtyard_circle?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];w.push(...Cni(D,t.center)),a.fpCircles=w;const b=this.ctx.db.pcb_fabrication_note_rect?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],k=a.fpRects??[];k.push(...Qni(b,t.center));const x=this.ctx.db.pcb_note_rect?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];k.push(...Eni(x,t.center));const N=this.ctx.db.pcb_courtyard_rect?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];k.push(...hni(N,t.center)),a.fpRects=k;const R=this.ctx.db.pcb_courtyard_outline?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],U=uni(R,t.center);if(U.length>0&&(a.fpPolys=U),n){const O=yni(n,t.center);O.length>0&&(a.models=O)}const T=t.metadata?.kicad_footprint;T&&i?.name&&lni(a,T,i.name);const Y=e.footprints;Y.push(a),e.footprints=Y,this.componentsProcessed++}getOutput(){return this.ctx.kicadPcb}},kni={top:"F.Cu",bottom:"B.Cu",inner1:"In1.Cu",inner2:"In2.Cu",inner3:"In3.Cu",inner4:"In4.Cu",inner5:"In5.Cu",inner6:"In6.Cu"};function Fni(e){return e&&(kni[e]||e)||"F.Cu"}function Gni(e){const A=["F.Cu"];for(let t=1;t<e-1;t++)A.push(`In${t}.Cu`);return A.push("B.Cu"),A}var Mni=class extends Nh{tracesProcessed=0;pcbTraces=[];constructor(e,A){super(e,A),this.pcbTraces=this.ctx.db.pcb_trace.list()}_step(){const{kicadPcb:e,c2kMatPcb:A,pcbNetMap:t}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");if(!A)throw new Error("PCB transformation matrix not initialized in context");if(this.tracesProcessed>=this.pcbTraces.length){this.finished=!0;return}const i=this.pcbTraces[this.tracesProcessed];if(!i.route||i.route.length<2){this.tracesProcessed++;return}let n=i.route[0]?.layer;for(let o=0;o<i.route.length-1;o++){const s=i.route[o],r=i.route[o+1],a=Ee(A,{x:s.x,y:s.y}),g=Ee(A,{x:r.x,y:r.y});let c;if(t){let E=i.subcircuit_connectivity_map_key;if(!E&&i.source_trace_id){const h=this.ctx.db.source_trace?.get(i.source_trace_id);if(h&&(E=h.subcircuit_connectivity_map_key,!E&&h.connected_source_net_ids?.length))for(const u of h.connected_source_net_ids){const d=this.ctx.db.source_net?.get(u);if(d?.subcircuit_connectivity_map_key){E=d.subcircuit_connectivity_map_key;break}}}if(!E&&typeof i.connection_name=="string"){const h=this.ctx.db.source_net?.get(i.connection_name);h?.subcircuit_connectivity_map_key&&(E=h.subcircuit_connectivity_map_key)}E&&(c=t.get(E))}const I=s.layer??r.layer??n,l=Fni(I),B=`segment:${a.x},${a.y}:${g.x},${g.y}:${l}:${c?.id??0}`,C=new JmA({start:{x:a.x,y:a.y},end:{x:g.x,y:g.y},layer:l,width:i.width||.25,net:new uj(c?.id??0),uuid:pf(B)}),Q=e.segments;Q.push(C),e.segments=Q,s.layer&&(n=s.layer),r.layer&&(n=r.layer)}this.tracesProcessed++}getOutput(){return this.ctx.kicadPcb}},Rni=class extends Nh{viasProcessed=0;pcbVias=[];constructor(e,A){super(e,A),this.pcbVias=this.ctx.db.pcb_via?.list()||[]}_step(){const{kicadPcb:e,c2kMatPcb:A,pcbNetMap:t}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");if(!A)throw new Error("PCB transformation matrix not initialized in context");if(this.viasProcessed>=this.pcbVias.length){this.finished=!0;return}const i=this.pcbVias[this.viasProcessed],n=Ee(A,{x:i.x,y:i.y});let o;if(t){let I=i.subcircuit_connectivity_map_key;if(!I&&i.pcb_trace_id){const l=this.ctx.db.pcb_trace?.get(i.pcb_trace_id);if(l&&("subcircuit_connectivity_map_key"in l&&(I=l.subcircuit_connectivity_map_key),!I&&l.source_trace_id)){const B=this.ctx.db.source_trace?.get(l.source_trace_id);if(B&&("subcircuit_connectivity_map_key"in B&&(I=B.subcircuit_connectivity_map_key),!I&&B.connected_source_net_ids?.length))for(const C of B.connected_source_net_ids){const Q=this.ctx.db.source_net?.get(C);if(Q?.subcircuit_connectivity_map_key){I=Q.subcircuit_connectivity_map_key;break}}}}if(!I&&i.connection_name){const l=this.ctx.db.source_net?.get(i.connection_name);l?.subcircuit_connectivity_map_key&&(I=l.subcircuit_connectivity_map_key)}I&&(o=t.get(I))}const s=this.ctx.numLayers??2,r=i.layers?i.layers.map(I=>I==="top"?"F.Cu":I==="bottom"?"B.Cu":`In${I.replace("inner","")}.Cu`):Gni(s),a=`via:${n.x},${n.y}:${i.outer_diameter||.8}:${i.hole_diameter||.4}:${o?.id??0}`,g=new LwA({at:[n.x,n.y],size:i.outer_diameter||.8,drill:i.hole_diameter||.4,layers:r,net:new vwA(o?.id??0),uuid:pf(a)}),c=e.vias;c.push(g),e.vias=c,this.viasProcessed++}getOutput(){return this.ctx.kicadPcb}};function Nni({textElement:e,c2kMatPcb:A}){if(!e.text||!e.anchor_position)return null;const t=Ee(A,{x:e.anchor_position.x,y:e.anchor_position.y}),n={top:"F.Fab",bottom:"B.Fab"}[e.layer]||e.layer||"F.Fab",o=(e.font_size||1)/1.5,s=new uf;s.size={width:o,height:o};const r=new MJ,a=e.anchor_alignment||"center";switch(a){case"top_left":r.horizontal="left",r.vertical="top";break;case"top_right":r.horizontal="right",r.vertical="top";break;case"bottom_left":r.horizontal="left",r.vertical="bottom";break;case"bottom_right":r.horizontal="right",r.vertical="bottom";break}const g=new hf({font:s});a!=="center"&&(g.justify=r);const c=new Wg([t.x,t.y,0]),I=new hj({text:e.text,layer:n,effects:g});return I.position=c,I}function vni({textElement:e,c2kMatPcb:A}){if(!e.text||!e.anchor_position)return null;const t=Ee(A,{x:e.anchor_position.x,y:e.anchor_position.y}),n={top:"F.SilkS",bottom:"B.SilkS"}[e.layer]||e.layer||"F.SilkS",o=(e.font_size||1)/1.5,s=new uf;s.size={width:o,height:o};const r=new MJ,a=e.anchor_alignment||"center";switch(a){case"top_left":r.horizontal="left",r.vertical="top";break;case"top_right":r.horizontal="right",r.vertical="top";break;case"bottom_left":r.horizontal="left",r.vertical="bottom";break;case"bottom_right":r.horizontal="right",r.vertical="bottom";break}const g=new hf({font:s});a!=="center"&&(g.justify=r);const c=e.ccw_rotation||0,I=new Wg([t.x,t.y,c]),l=new hj({text:e.text,layer:n,effects:g});return l.position=I,l}var Lni=class extends Nh{_step(){const{kicadPcb:e,c2kMatPcb:A}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");if(!A)throw new Error("PCB transformation matrix not initialized in context");const t=this.ctx.db.pcb_silkscreen_path?.list()||[];for(const s of t)if(!(!s.route||s.route.length<2))for(let r=0;r<s.route.length-1;r++){const a=s.route[r],g=s.route[r+1];if(!a||!g)continue;const c=Ee(A,{x:a.x,y:a.y}),I=Ee(A,{x:g.x,y:g.y}),B={top:"F.SilkS",bottom:"B.SilkS"}[s.layer]||s.layer||"F.SilkS",C=new Ej({start:{x:c.x,y:c.y},end:{x:I.x,y:I.y},layer:B,width:s.stroke_width||.15}),Q=e.graphicLines;Q.push(C),e.graphicLines=Q}const i=this.ctx.db.pcb_silkscreen_text?.list().filter(s=>!s.pcb_component_id)||[];for(const s of i){const r=vni({textElement:s,c2kMatPcb:A});if(r){const a=e.graphicTexts;a.push(r),e.graphicTexts=a}}const n=this.ctx.db.pcb_fabrication_note_text?.list()||[];for(const s of n){const r=Nni({textElement:s,c2kMatPcb:A});if(r){const a=e.graphicTexts;a.push(r),e.graphicTexts=a}}const o=this.ctx.db.pcb_board?.list()||[];if(o.length>0){const s=o[0];if(!s){this.finished=!0;return}let r;if(s.outline&&s.outline.length>0)r=s.outline;else{const g=s.width?s.width/2:0,c=s.height?s.height/2:0;r=[{x:s.center.x-g,y:s.center.y-c},{x:s.center.x+g,y:s.center.y-c},{x:s.center.x+g,y:s.center.y+c},{x:s.center.x-g,y:s.center.y+c}]}const a=r.map(g=>Ee(A,g));for(let g=0;g<a.length;g++){const c=a[g],I=a[(g+1)%a.length];if(!c||!I)continue;const l=new Ej({start:{x:c.x,y:c.y},end:{x:I.x,y:I.y},layer:"Edge.Cuts",width:.1}),B=e.graphicLines;B.push(l),e.graphicLines=B}}this.finished=!0}getOutput(){return this.ctx.kicadPcb}},wht=class{ctx;pipeline;currentStageIndex=0;finished=!1;get currentStage(){return this.pipeline[this.currentStageIndex]}constructor(e){this.ctx={db:xa(e),circuitJson:e,kicadPcb:new UwA({generator:"circuit-json-to-kicad",generatorVersion:"0.0.1"}),c2kMatPcb:bl(ir(100,100),fh(1,-1))},this.pipeline=[new gni(e,this.ctx),new cni(e,this.ctx),new _ni(e,this.ctx),new Mni(e,this.ctx),new Rni(e,this.ctx),new Lni(e,this.ctx)]}step(){if(!this.currentStage){this.finished=!0;return}this.currentStage.step(),this.currentStage.finished&&this.currentStageIndex++}runUntilFinished(){for(;!this.finished;)this.step()}getOutput(){return this.ctx.kicadPcb}getOutputString(){return this.ctx.kicadPcb.getString()}},Uni=class{ctx;project;constructor(e,A={}){const t=A.projectName??e?.project?.name??"circuit-json-project",i=A.schematicFilename??`${t}.kicad_sch`,n=A.pcbFilename??`${t}.kicad_pcb`,o=new Date().toISOString();this.ctx={db:xa(e),circuitJson:e},this.project={version:1,head:{generator:"circuit-json-to-kicad",generator_version:"0.0.1",project_name:t,created:o,modified:o},meta:{version:1},text_variables:{},libraries:{pinned_symbol_libs:[],pinned_footprint_libs:[]},boards:[],cvpcb:{meta:{version:0}},erc:{meta:{version:0},erc_exclusions:[]},net_settings:{meta:{version:1},last_net_id:0,classes:[]},pcbnew:{page_layout_descr_file:"",last_paths:{}},schematic:{meta:{version:1},page_layout_descr_file:"",last_opened_files:[i]},board:{meta:{version:1},last_opened_board:n},sheets:[[Math.random().toString(36).substring(2,15),"Root"]]}}runUntilFinished(){}getOutput(){return this.project}getOutputString(){return`${JSON.stringify(this.project,null,2)}
|
|
5829
|
-
`}},Hni=class extends Nh{_step(){const e=new mht(this.ctx.circuitJson);e.runUntilFinished(),this.ctx.kicadSchString=e.getOutputString();const A=new wht(this.ctx.circuitJson);A.runUntilFinished(),this.ctx.kicadPcbString=A.getOutputString(),this.finished=!0}getOutput(){return this.ctx.libraryOutput}},Yni=class extends Nh{isCustomSymbol(e){return e?.startsWith("Custom:")??!1}_step(){const e=this.ctx.kicadSchString,A=this.ctx.fpLibraryName??"tscircuit";if(!e)throw new Error("Schematic content not available. Run GenerateKicadSchAndPcbStage first.");const t=new Map;try{const n=hht(e).find(r=>r instanceof xyA);if(!n){this.ctx.symbolEntries=[],this.finished=!0;return}const o=n.libSymbols;if(!o){this.ctx.symbolEntries=[],this.finished=!0;return}const s=o.symbols??[];for(const r of s){const a=this.isCustomSymbol(r.libraryId),g=this.sanitizeSymbolName(r.libraryId);t.has(g)||(r.libraryId=g,this.updateFootprintProperty(r,A),a||this.snapPinPositionsToGrid(r),t.set(g,{symbolName:g,symbol:r,isBuiltin:!a}))}}catch(i){console.warn("Failed to parse schematic for symbol extraction:",i)}this.ctx.symbolEntries=Array.from(t.values()),this.finished=!0}updateFootprintProperty(e,A){const t=e.properties??[];for(const i of t)if(i.key==="Footprint"&&i.value){const n=i.value.split(":");n.length>1?i.value=`${A}:${n[1]}`:i.value.trim()&&(i.value=`${A}:${i.value}`)}}sanitizeSymbolName(e){if(!e)return"symbol";const A=e.split(":");return(A.length>1?A[1]:A[0])?.replace(/[\\\/]/g,"-").trim()||"symbol"}snapPinPositionsToGrid(e){for(const t of e.subSymbols??[]){for(const i of t.pins??[])i.at&&(i.at.x=Math.round(i.at.x/1.27)*1.27,i.at.y=Math.round(i.at.y/1.27)*1.27);for(const i of t.polylines??[])if(i.points?.points)for(const n of i.points.points)"x"in n&&"y"in n&&(n.x=Math.round(n.x/1.27)*1.27,n.y=Math.round(n.y/1.27)*1.27)}}getOutput(){return this.ctx.libraryOutput}},Jni=20240108,Tni="pcbnew",Kni="8.0";function Pni(e){const A=e.split(/[/\\]/);return A[A.length-1]||e}var qni=class extends Nh{findCustomFootprintNames(){const e=new Set,A=this.ctx.db.cad_component?.list()??[],t=this.ctx.db.source_component;for(const i of A)if(!i.footprinter_string){const n=i.source_component_id?t?.get(i.source_component_id):null;if(n){const o=RG(n,i);e.add(o)}}return e}_step(){const e=this.ctx.kicadPcbString,A=this.ctx.fpLibraryName??"tscircuit";if(!e)throw new Error("PCB content not available. Run GenerateKicadSchAndPcbStage first.");const t=this.findCustomFootprintNames(),i=new Map;try{const o=hht(e).find(r=>r instanceof UwA);if(!o){this.ctx.footprintEntries=[],this.finished=!0;return}const s=o.footprints??[];for(const r of s){const a=this.sanitizeFootprint({footprint:r,fpLibraryName:A,customFootprintNames:t});i.has(a.footprintName)||i.set(a.footprintName,a)}}catch(n){console.warn("Failed to parse PCB for footprint extraction:",n)}this.ctx.footprintEntries=Array.from(i.values()),this.finished=!0}sanitizeFootprint({footprint:e,fpLibraryName:A,customFootprintNames:t}){const n=(e.libraryLink??"footprint").split(":"),o=(n.length>1?n[1]:n[0])?.replace(/[\\\/]/g,"-").trim()||"footprint",s=!t.has(o);if(e.libraryLink=o,e.position=Wg.from([0,0,0]),e.locked=!1,e.placed=!1,e.version=Jni,e.generator=Tni,e.generatorVersion=Kni,e.descr||(e.descr=""),e.tags||(e.tags=""),e.embeddedFonts||(e.embeddedFonts=new y1(!1)),!e.attr){const d=new _yA,f=(e.fpPads??[]).map(m=>m.padType);f.some(m=>m.includes("thru_hole"))?d.type="through_hole":f.some(m=>m.includes("smd"))&&(d.type="smd"),e.attr=d}e.uuid=void 0,e.path=void 0,e.sheetfile=void 0,e.sheetname=void 0;const r=new uf;r.size={width:1.27,height:1.27},r.thickness=.15;const a=new hf({font:r}),g=e.fpPads??[];let c=0,I=0;for(const d of g){const f=d.at,m=d.size;if(f&&m){const w=f.y??0,D=m.height??0,b=w-D/2,k=w+D/2;c=Math.min(c,b),I=Math.max(I,k)}}const l=c-.5,B=I+.5;e.properties=[new OD({key:"Reference",value:"REF**",position:[0,l,0],layer:"F.SilkS",uuid:pf(`${o}-property-Reference`),effects:a}),new OD({key:"Value",value:"Val**",position:[0,B,0],layer:"F.Fab",uuid:pf(`${o}-property-Value`),effects:a}),new OD({key:"Datasheet",value:"",position:[0,0,0],layer:"F.Fab",hidden:!0,uuid:pf(`${o}-property-Datasheet`),effects:a}),new OD({key:"Description",value:"",position:[0,0,0],layer:"F.Fab",hidden:!0,uuid:pf(`${o}-property-Description`),effects:a})];const C=e.fpTexts??[];for(const d of C)d.uuid=void 0,d.type==="reference"?d.text="REF**":d.type==="value"&&d.text.trim().length===0&&(d.text=o);e.fpTexts=C;const Q=e.fpPads??[];for(let d=0;d<Q.length;d++){const f=Q[d];f&&(f.uuid=pf(`${o}-pad-${f.number??d}`),f.net=void 0)}e.fpPads=Q;const E=e.models??[],h=[],u=[];for(const d of E)if(d.path){const f=Pni(d.path),m=`../../3dmodels/${A}.3dshapes/${f}`,w=new Bj(m);d.offset&&(w.offset=d.offset),d.scale&&(w.scale=d.scale),d.rotate&&(w.rotate=d.rotate),h.push(w),u.push(d.path)}return e.models=h,{footprintName:o,kicadModString:e.getString(),model3dSourcePaths:u,isBuiltin:s}}getOutput(){return this.ctx.libraryOutput}},Oni=20211014,Wni="circuit-json-to-kicad",Zni=class extends Nh{_step(){const e=this.ctx.symbolEntries??[],A=this.generateSymbolLibrary(e);this.ctx.libraryOutput||(this.ctx.libraryOutput={kicadSymString:"",symbols:[],footprints:[],fpLibTableString:"",symLibTableString:"",model3dSourcePaths:[]}),this.ctx.libraryOutput.kicadSymString=A,this.finished=!0}generateSymbolLibrary(e){return new LCt({version:Oni,generator:Wni,symbols:e.map(t=>t.symbol)}).getString()}getOutput(){return this.ctx.libraryOutput}},Vni=class extends Nh{_step(){const e=this.ctx.libraryName??"tscircuit",A=this.ctx.fpLibraryName??"tscircuit",t=this.ctx.footprintEntries??[],i=this.ctx.symbolEntries??[],n=new Set;for(const r of t)for(const a of r.model3dSourcePaths)n.add(a);const o=this.generateFpLibTable(A),s=this.generateSymLibTable(e);this.ctx.libraryOutput||(this.ctx.libraryOutput={kicadSymString:"",symbols:[],footprints:[],fpLibTableString:"",symLibTableString:"",model3dSourcePaths:[]}),this.ctx.libraryOutput.symbols=i,this.ctx.libraryOutput.footprints=t,this.ctx.libraryOutput.fpLibTableString=o,this.ctx.libraryOutput.symLibTableString=s,this.ctx.libraryOutput.model3dSourcePaths=Array.from(n),this.finished=!0}generateFpLibTable(e){return`(fp_lib_table
|
|
5828
|
+
`)}};NA.register(LwA);var UwA=class byt extends NA{static token="kicad_pcb";token="kicad_pcb";_sxVersion;_sxGenerator;_sxGeneratorVersion;_sxGeneral;_sxPaper;_sxTitleBlock;_sxLayers;_sxSetup;_properties=[];_nets=[];_footprints=[];_images=[];_segments=[];_grLines=[];_grTexts=[];_grPolys=[];_grRects=[];_vias=[];_zones=[];_otherChildren=[];constructor(A={}){super(),A.version!==void 0&&(this.version=A.version),A.generator!==void 0&&(this.generator=A.generator),A.generatorVersion!==void 0&&(this.generatorVersion=A.generatorVersion),A.general!==void 0&&(this.general=A.general),A.paper!==void 0&&(this.paper=A.paper),A.titleBlock!==void 0&&(this.titleBlock=A.titleBlock),A.layers!==void 0&&(this.layers=A.layers),A.setup!==void 0&&(this.setup=A.setup),A.properties!==void 0&&(this.properties=A.properties),A.nets!==void 0&&(this.nets=A.nets),A.footprints!==void 0&&(this.footprints=A.footprints),A.images!==void 0&&(this.images=A.images),A.segments!==void 0&&(this.segments=A.segments),A.graphicLines!==void 0&&(this.graphicLines=A.graphicLines),A.graphicTexts!==void 0&&(this.graphicTexts=A.graphicTexts),A.graphicPolys!==void 0&&(this.graphicPolys=A.graphicPolys),A.graphicRects!==void 0&&(this.graphicRects=A.graphicRects),A.vias!==void 0&&(this.vias=A.vias),A.zones!==void 0&&(this.zones=A.zones),A.otherChildren!==void 0&&(this.otherChildren=A.otherChildren)}static fromSexprPrimitives(A){const t=new byt;for(const i of A){if(!Array.isArray(i)||i.length===0)throw new Error(`kicad_pcb encountered unsupported primitive child: ${JSON.stringify(i)}`);const n=NA.parsePrimitiveSexpr(i,{parentToken:this.token});if(!(n instanceof NA))throw new Error(`kicad_pcb expected SxClass child, received ${JSON.stringify(i)}`);t.consumeChild(n)}return t}consumeChild(A){if(A instanceof MwA){this._sxVersion=A;return}if(A instanceof RwA){this._sxGenerator=A;return}if(A instanceof NwA){this._sxGeneratorVersion=A;return}if(A instanceof FwA){this._sxGeneral=A;return}if(A instanceof ij){this._sxPaper=A;return}if(A instanceof QCt){this._sxTitleBlock=A;return}if(A instanceof GwA){this._sxLayers=A;return}if(A instanceof kwA){this._sxSetup=A;return}if(A instanceof OD){this._properties.push(A);return}if(A instanceof fj){this._nets.push(A);return}if(A instanceof xmA){this._footprints.push(A);return}if(A instanceof hCt){this._images.push(A);return}if(A instanceof JmA){this._segments.push(A);return}if(A instanceof Ej){this._grLines.push(A);return}if(A instanceof hj){this._grTexts.push(A);return}if(A instanceof sEt){this._grPolys.push(A);return}if(A instanceof iEt){this._grRects.push(A);return}if(A instanceof LwA){this._vias.push(A);return}if(A instanceof lEt){this._zones.push(A);return}this._otherChildren.push(A)}get version(){return this._sxVersion?.value}set version(A){this._sxVersion=A===void 0?void 0:new MwA(A)}get generator(){return this._sxGenerator?.value}set generator(A){this._sxGenerator=A===void 0?void 0:new RwA(A)}get generatorVersion(){return this._sxGeneratorVersion?.value}set generatorVersion(A){this._sxGeneratorVersion=A===void 0?void 0:new NwA(A)}get general(){return this._sxGeneral}set general(A){this._sxGeneral=A}get paper(){return this._sxPaper}set paper(A){this._sxPaper=A}get titleBlock(){return this._sxTitleBlock}set titleBlock(A){this._sxTitleBlock=A}get layers(){return this._sxLayers}set layers(A){this._sxLayers=A}get setup(){return this._sxSetup}set setup(A){this._sxSetup=A}get properties(){return[...this._properties]}set properties(A){this._properties=[...A]}get nets(){return[...this._nets]}set nets(A){this._nets=[...A]}get footprints(){return[...this._footprints]}set footprints(A){this._footprints=[...A]}get images(){return[...this._images]}set images(A){this._images=[...A]}get segments(){return[...this._segments]}set segments(A){this._segments=[...A]}get graphicLines(){return[...this._grLines]}set graphicLines(A){this._grLines=[...A]}get graphicTexts(){return[...this._grTexts]}set graphicTexts(A){this._grTexts=[...A]}get graphicPolys(){return[...this._grPolys]}set graphicPolys(A){this._grPolys=[...A]}get graphicRects(){return[...this._grRects]}set graphicRects(A){this._grRects=[...A]}get vias(){return[...this._vias]}set vias(A){this._vias=[...A]}get zones(){return[...this._zones]}set zones(A){this._zones=[...A]}get otherChildren(){return[...this._otherChildren]}set otherChildren(A){this._otherChildren=[...A]}getChildren(){const A=[];return this._sxVersion&&A.push(this._sxVersion),this._sxGenerator&&A.push(this._sxGenerator),this._sxGeneratorVersion&&A.push(this._sxGeneratorVersion),this._sxGeneral&&A.push(this._sxGeneral),this._sxPaper&&A.push(this._sxPaper),this._sxTitleBlock&&A.push(this._sxTitleBlock),this._sxLayers&&A.push(this._sxLayers),this._sxSetup&&A.push(this._sxSetup),A.push(...this._properties),A.push(...this._nets),A.push(...this._footprints),A.push(...this._images),A.push(...this._segments),A.push(...this._grLines),A.push(...this._grTexts),A.push(...this._grPolys),A.push(...this._grRects),A.push(...this._vias),A.push(...this._zones),A.push(...this._otherChildren),A}};NA.register(UwA);var hht=e=>NA.parse(e),Nh=class{MAX_ITERATIONS=1e3;iteration=0;finished=!1;input;ctx;constructor(e,A){this.input=e,this.ctx=A}step(){if(this.iteration++,this.iteration>this.MAX_ITERATIONS)throw new Error("Max iterations reached");this._step()}_step(){throw new Error("Not implemented")}runUntilFinished(){for(;!this.finished;)this.step()}getOutput(){throw new Error("Not implemented")}},Tii=class extends Nh{_step(){const{kicadSch:e,schematicPaperSize:A}=this.ctx;if(!e)throw new Error("KicadSch instance not initialized in context");e.version=20250114;const t=new ij;t.size=A?.name??"A4",e.paper=t,e.uuid=new Li(crypto.randomUUID()),this.finished=!0}getOutput(){return this.ctx.kicadSch}};function RG(e,A){if(e.manufacturer_part_number)return HwA(e.manufacturer_part_number);const t=Kii(e.ftype),i=A?.footprinter_string;return HwA(i?`${t}_${i}`:t)}function Kii(e){if(!e)return"component";let A=e.replace(/^simple_/,"");return A||"component"}function HwA(e){return e.replace(/[\\\/:\s]+/g,"_").replace(/_+/g,"_").replace(/^_|_$/g,"").trim()||"component"}function uht(e){return e?e.match(/^([A-Za-z]+)/)?.[1]?.toUpperCase()??"U":"U"}var dht={simple_resistor:"R",simple_capacitor:"C",simple_inductor:"L",simple_diode:"D",simple_led:"D",simple_chip:"U",simple_transistor:"Q",simple_mosfet:"Q",simple_fuse:"F",simple_switch:"SW",simple_push_button:"SW",simple_potentiometer:"RV",simple_crystal:"Y",simple_resonator:"Y",simple_pin_header:"J",simple_pinout:"J",simple_test_point:"TP",simple_battery:"BT"},Pii=/^[A-Za-z]+\d+$/;function pht(e){return e?Pii.test(e.trim()):!1}function yj(e){const A=e?.ftype;if(A&&dht[A])return dht[A];const t=e?.name;return pht(t),uht(t)}function qii(e){const A=e?.name;return pht(A)?A.trim():`${yj(e)}?`}function fht(e){return e in wQ}function yht(e,A,t,i){if(i)return`Custom:${i}`;if(e.type!=="source_component")return A.symbol_name?fht(A.symbol_name)?`Device:${A.symbol_name}`:`Custom:${A.symbol_name}`:"Device:Component";if(A.symbol_name)return fht(A.symbol_name)?`Device:${A.symbol_name}`:`Custom:${A.symbol_name}`;const n=RG(e,t);return`Device:${yj(e)}_${n}`}function Oii(e){const{circuitJson:A,schematicSymbolId:t,schematicSymbol:i,schematicComponentId:n}=e,o=A.filter(Q=>Q.type==="schematic_circle"&&Q.schematic_symbol_id===t),s=A.filter(Q=>Q.type==="schematic_line"&&Q.schematic_symbol_id===t),r=n?A.filter(Q=>Q.type==="schematic_line"&&Q.schematic_component_id===n&&!Q.schematic_symbol_id):[],a=[...s,...r],g=A.filter(Q=>Q.type==="schematic_path"&&Q.schematic_symbol_id===t),c=A.filter(Q=>Q.type==="schematic_text"&&Q.schematic_symbol_id===t);let I=A.filter(Q=>Q.type==="schematic_port"&&"schematic_symbol_id"in Q&&Q.schematic_symbol_id===t);if(I.length===0&&n&&(I=A.filter(Q=>Q.type==="schematic_port"&&Q.schematic_component_id===n&&Q.display_pin_label!==void 0),I.length===0)){const Q=A.filter(h=>h.type==="schematic_port"&&h.schematic_component_id===n),E=new Set;I=Q.filter(h=>{const u=h.pin_number;if(u!==void 0){if(E.has(u))return!1;E.add(u)}return!0})}const l=[];for(const Q of o)l.push({type:"circle",x:Q.center?.x??0,y:Q.center?.y??0,radius:Q.radius??.5,fill:Q.is_filled??!1,fillColor:Q.fill_color});for(const Q of a)l.push({type:"path",points:[{x:Q.x1??0,y:Q.y1??0},{x:Q.x2??0,y:Q.y2??0}]});for(const Q of g)Q.points&&Q.points.length>0&&l.push({type:"path",points:Q.points,fill:Q.is_filled??!1,fillColor:Q.fill_color});const B=c.map(Q=>({text:Q.text??"",x:Q.position?.x??0,y:Q.position?.y??0,fontSize:Q.font_size??.2,anchor:Q.anchor??"center"})),C=I.map((Q,E)=>({x:Q.center?.x??0,y:Q.center?.y??0,labels:[Q.display_pin_label||`${Q.pin_number||E+1}`],pinNumber:Q.pin_number||E+1,facingDirection:Q.facing_direction}));return C.sort((Q,E)=>Q.pinNumber-E.pinNumber),{center:i.center||{x:0,y:0},size:i.size||{width:1,height:1},primitives:l,texts:B,ports:C}}function Wii({points:e,transform:A,fillType:t}){const i=new dCt,n=e.map(a=>{const g=Ee(A,a);return new LQ(g.x,g.y)}),o=new YC(n);i.points=o;const s=new qD;s.width=.254,s.type="default",i.stroke=s;const r=new SCt;return r.type=t,i.fill=r,i}function Zii({primitive:e,transform:A,scale:t}){const i=new _Ct,n=Ee(A,{x:e.x,y:e.y}),o=i;o._sxCenter=new wCt(n.x,n.y),o._sxRadius=new DCt(e.radius*t);const s=new qD;s.width=.254,s.type="default",o._sxStroke=s;const r=new bCt;return r.type=e.fill?"background":"none",o._sxFill=r,i}function Vii({schText:e,transform:A,scale:t}){const i=new kCt,n=Ee(A,{x:e.x,y:e.y});i.value=e.text,i.at=[n.x,n.y,0];const o=e.fontSize*t,s=new uf;return s.size={height:o,width:o},i.effects=new hf({font:s}),i}function jii({libId:e,symbolData:A,isChip:t,c2kMatSchScale:i}){const n=new w1({libraryId:`${e.split(":")[1]}_0_1`}),s=t?i:15.24,r=A.center?.x??0,a=A.center?.y??0,g=bl(fh(s,s),ir(-r,-a));for(const I of A.primitives||[])if(I.type==="path"&&I.points){const l=t||I.fill?"background":"none",B=Wii({points:I.points,transform:g,fillType:l});n.polylines.push(B)}else if(I.type==="circle"){const l=Zii({primitive:I,transform:g,scale:s});n.circles.push(l)}const c=Array.isArray(A.texts)?A.texts:[];for(const I of c){const l=Vii({schText:I,transform:g,scale:s});n.texts.push(l)}return n}function zii(e,A){const t=A.schematic_port.list().filter(r=>r.schematic_component_id===e.schematic_component_id).sort((r,a)=>(r.pin_number||0)-(a.pin_number||0)),i=e.size?.width||1.5,n=e.size?.height||1,o={type:"path",points:[{x:-i/2,y:-n/2},{x:i/2,y:-n/2},{x:i/2,y:n/2},{x:-i/2,y:n/2},{x:-i/2,y:-n/2}]},s=t.map(r=>{const a=r.center.x-e.center.x,g=r.center.y-e.center.y;return{x:a,y:g,labels:[r.display_pin_label||`${r.pin_number||1}`],pinNumber:r.pin_number||1}});return{center:{x:0,y:0},primitives:[o],ports:s,size:{width:i,height:n}}}function Xii(e,A){const t=new uf;return t.size={height:e,width:e},new hf({font:t,hiddenText:A})}function $ii({symbol:e,libId:A,description:t,keywords:i,fpFilters:n,footprintRef:o="",referencePrefix:s}){const r=s||A.split(":")[1]?.[0]||"U",a=[{key:"Reference",value:r,id:0,at:[2.032,0,90],hide:!1},{key:"Value",value:r,id:1,at:[0,0,90],hide:!1},{key:"Footprint",value:o,id:2,at:[-1.778,0,90],hide:!0},{key:"Datasheet",value:"~",id:3,at:[0,0,0],hide:!0},{key:"Description",value:t,id:4,at:[0,0,0],hide:!0},{key:"ki_keywords",value:i,id:5,at:[0,0,0],hide:!0},{key:"ki_fp_filters",value:n,id:6,at:[0,0,0],hide:!0}];for(const g of a)e.properties.push(new df({key:g.key,value:g.value,id:g.id,at:g.at,effects:Xii(1.27,g.hide)}))}function Ani({port:e,center:A,size:t,isChip:i,portIndex:n,schematicComponent:o,schematicPorts:s,c2kMatSchScale:r}){const g=i?r:15.24;let c=e.x??0,I=e.y??0,l=!1;if(i&&n!==void 0&&o){const w=s.filter(D=>D.schematic_component_id===o.schematic_component_id).sort((D,b)=>(D.pin_number||0)-(b.pin_number||0));if(w[n]){const D=w[n];c=D.center.x-o.center.x,I=D.center.y-o.center.y,l=!0}}let B,C;if(l)B=c,C=I;else{const w=A?.x??0,D=A?.y??0;B=c-w,C=I-D}const Q=fh(g,g),E=Ee(Q,{x:B,y:C});let h;if(i&&t){const w=t.width/2,D=t.height/2,b=Math.abs(B)/w,k=Math.abs(C)/D;h=b>k}else h=Math.abs(B)>Math.abs(C);let u=E.x,d=E.y;const f=6;if(i&&t){const w=t.width/2*g,D=t.height/2*g;h?(u=B>0?w:-w,d=C*g):(u=B*g,d=C>0?D:-D)}let m=0;return h?B>0?(m=180,i&&(u=u+f)):(m=0,i&&(u=u-f)):C>0?(m=270,i&&(d=d+f)):(m=90,i&&(d=d-f)),{x:u,y:d,angle:m}}function tni({libId:e,symbolData:A,isChip:t,schematicComponent:i,schematicPorts:n,c2kMatSchScale:o}){const s=new w1({libraryId:`${e.split(":")[1]}_1_1`}),r=6,a=2.54;for(let g=0;g<(A.ports?.length||0);g++){const c=A.ports[g],I=new rj;I.pinElectricalType="passive",I.pinGraphicStyle="line";const{x:l,y:B,angle:C}=Ani({port:c,center:A.center,size:A.size,isChip:t,portIndex:g,schematicComponent:i,schematicPorts:n,c2kMatSchScale:o});I.at=[l,B,C],I.length=t?r:a;const Q=new uf;Q.size={height:1.27,width:1.27};const E=new hf({font:Q}),h=c.labels?.[0]||"~";I._sxName=new uyA({value:h,effects:E});const u=new uf;u.size={height:1.27,width:1.27};const d=new hf({font:u}),f=c.pinNumber?.toString()||`${g+1}`;I._sxNumber=new GCt({value:f,effects:d}),s.pins.push(I)}return s}var eni=class extends Nh{processedSymbolNames=new Set;_step(){const{kicadSch:e,db:A}=this.ctx,t=new HCt,i=[];this.processedSymbolNames=new Set;const n=A.schematic_component.list();for(const s of n){const r=this.createLibrarySymbolForComponent(s);r&&i.push(r)}const o=A.schematic_net_label?.list?.()||[];for(const s of o)if(s.symbol_name){const r=s.source_net_id?A.source_net.get(s.source_net_id)?.is_power:!1,a=s.source_net_id?A.source_net.get(s.source_net_id)?.is_ground:!1;if(r||a){const c=this.createLibrarySymbolForNetLabel({netLabel:s,isPower:r??!1,isGround:a??!1});c&&i.push(c)}}t.symbols=i,e&&(e.libSymbols=t),this.finished=!0}createLibrarySymbolForComponent(e){const{db:A}=this.ctx,t=e.source_component_id?A.source_component.get(e.source_component_id):null;if(!t)return null;const i=A.cad_component?.list()?.find(c=>c.source_component_id===t.source_component_id);let n=e.schematic_symbol_id;if(!n){const c=this.ctx.circuitJson.find(I=>(I.type==="schematic_line"||I.type==="schematic_circle"||I.type==="schematic_path")&&I.schematic_component_id===e.schematic_component_id&&I.schematic_symbol_id);c&&(n=c.schematic_symbol_id)}if(n)return this.createLibrarySymbolFromSchematicSymbol(e,t,i,n);const o=e.symbol_name||(t.ftype==="simple_chip"?`generic_chip_${e.source_component_id}`:null);if(!o)return null;const s=this.getSymbolData(o,e);if(!s)return null;const r=yht(t,e,i),a=t.ftype==="simple_chip",g=RG(t,i);return this.createLibrarySymbol({libId:r,symbolData:s,isChip:a,schematicComponent:e,description:this.getDescription(t),keywords:this.getKeywords(t),fpFilters:this.getFpFilters(t),footprintRef:g?`tscircuit:${g}`:"",referencePrefix:yj(t)})}createLibrarySymbolFromSchematicSymbol(e,A,t,i){const{db:n}=this.ctx,o=this.ctx.circuitJson.find(c=>c.type==="schematic_symbol"&&c.schematic_symbol_id===i);if(!o)return null;let s;if(o.name)s=o.name;else{const c=RG(A,t);c?s=c:s=`custom_${A.ftype||"component"}_${i}`}const r=`Custom:${s}`;if(this.processedSymbolNames.has(r))return null;this.processedSymbolNames.add(r);const a=Oii({circuitJson:this.ctx.circuitJson,schematicSymbolId:i,schematicSymbol:o,schematicComponentId:e.schematic_component_id}),g=RG(A,t);return this.createLibrarySymbol({libId:r,symbolData:a,isChip:!1,schematicComponent:e,description:this.getDescription(A),keywords:this.getKeywords(A),fpFilters:this.getFpFilters(A,o.name),footprintRef:g?`tscircuit:${g}`:"",referencePrefix:yj(A)})}createLibrarySymbolForNetLabel({netLabel:e,isPower:A,isGround:t}){const i=e.symbol_name;if(!i)return null;const n=wQ[i];if(!n)return null;const o=`Custom:${i}`;return this.createLibrarySymbol({libId:o,symbolData:n,isChip:!1,schematicComponent:void 0,description:A?"Power net label":t?"Ground net label":"Net symbol",keywords:A?"power net":t?"ground net":"net",fpFilters:"",referencePrefix:o.split(":")[1]?.[0]||"U"})}getSymbolData(e,A){return e.startsWith("generic_chip_")?zii(A,this.ctx.db):wQ[e]||null}createLibrarySymbol({libId:e,symbolData:A,isChip:t,schematicComponent:i,description:n,keywords:o,fpFilters:s,footprintRef:r="",referencePrefix:a}){const g=new w1({libraryId:e,excludeFromSim:!1,inBom:!0,onBoard:!0}),c=new QyA;c.hide=!t,g._sxPinNumbers=c;const I=new hyA;I.offset=t?1.27:0,g._sxPinNames=I,$ii({symbol:g,libId:e,description:n,keywords:o,fpFilters:s,footprintRef:r,referencePrefix:a});const l=jii({libId:e,symbolData:A,isChip:t,c2kMatSchScale:this.ctx.c2kMatSch?.a??15});g.subSymbols.push(l);const B=tni({libId:e,symbolData:A,isChip:t,schematicComponent:i,schematicPorts:this.ctx.db.schematic_port.list(),c2kMatSchScale:this.ctx.c2kMatSch?.a??15});return g.subSymbols.push(B),g._sxEmbeddedFonts=new y1(!1),g}getDescription(e){return e?.ftype==="simple_resistor"?"Resistor":e?.ftype==="simple_capacitor"?"Capacitor":e?.ftype==="simple_chip"?"Integrated Circuit":"Component"}getKeywords(e){return e?.ftype==="simple_resistor"?"R res resistor":e?.ftype==="simple_capacitor"?"C cap capacitor":e?.ftype==="simple_chip"?"U IC chip":""}getFpFilters(e,A){return A?`${A}*`:e?.ftype==="simple_resistor"?"R_*":e?.ftype==="simple_capacitor"?"C_*":(e?.ftype==="simple_chip","*")}getOutput(){if(!this.ctx.kicadSch)throw new Error("kicadSch is not initialized");return this.ctx.kicadSch}},ini=class extends Nh{_step(){const{kicadSch:e,db:A}=this.ctx,t=A.schematic_component.list();if(t.length===0){this.finished=!0;return}const i=[];for(const n of t){const o=n.source_component_id?A.source_component.get(n.source_component_id):null;if(!o||!this.ctx.c2kMatSch)continue;const{x:s,y:r}=Ee(this.ctx.c2kMatSch,{x:n.center.x,y:n.center.y}),a=crypto.randomUUID(),g=new w1({at:[s,r,0],unit:1,excludeFromSim:!1,inBom:!0,onBoard:!0,dnp:!1,uuid:a,fieldsAutoplaced:!0}),c=A.cad_component?.list()?.find(oA=>oA.source_component_id===o.source_component_id);let I,l=n.schematic_symbol_id;if(!l){const oA=this.ctx.circuitJson.find(rA=>(rA.type==="schematic_line"||rA.type==="schematic_circle"||rA.type==="schematic_path")&&rA.schematic_component_id===n.schematic_component_id&&rA.schematic_symbol_id);oA&&(l=oA.schematic_symbol_id)}if(l){const oA=this.ctx.circuitJson.find(rA=>rA.type==="schematic_symbol"&&rA.schematic_symbol_id===l);if(oA?.name)I=oA.name;else{const rA=RG(o,c);rA?I=rA:I=`custom_${o.ftype||"component"}_${l}`}}const B=yht(o,n,c,I),C=new ByA(B);g._sxLibId=C;const{reference:Q,value:E,description:h}=this.getComponentMetadata(o),{refTextPos:u,valTextPos:d}=this.getTextPositions(n,{x:s,y:r});let f;if(l){const oA=this.ctx.circuitJson.find(rA=>rA.type==="schematic_symbol"&&rA.schematic_symbol_id===l);oA&&oA.type==="schematic_symbol"&&(f=oA.metadata?.kicad_symbol)}const m=f?.properties?.Reference,w=new df({key:"Reference",value:m?.value??Q,id:0,at:[u.x,u.y,0],effects:this.createTextEffects(Number(m?.effects?.font?.size?.x??1.27),m?.effects?.hide??!1)}),D=o.ftype==="simple_chip",b=f?.properties?.Value,k=new df({key:"Value",value:b?.value??E,id:1,at:[d.x,d.y,0],effects:this.createTextEffects(Number(b?.effects?.font?.size?.x??1.27),b?.effects?.hide??D)}),x=f?.properties?.Footprint,N=new df({key:"Footprint",value:x?.value??"",id:2,at:[s-1.778,r,90],effects:this.createTextEffects(1.27,x?.effects?.hide??!0)}),R=f?.properties?.Datasheet,U=new df({key:"Datasheet",value:R?.value??"~",id:3,at:[s,r,0],effects:this.createTextEffects(1.27,R?.effects?.hide??!0)}),T=f?.properties?.Description,Y=new df({key:"Description",value:T?.value??h,id:4,at:[s,r,0],effects:this.createTextEffects(1.27,T?.effects?.hide??!0)});g.properties.push(w,k,N,U,Y);const O=f?.properties?.ki_keywords;if(O?.value){const oA=new df({key:"ki_keywords",value:O.value,id:5,at:[s,r,0],effects:this.createTextEffects(1.27,O.effects?.hide??!0)});g.properties.push(oA)}const W=f?.properties?.ki_fp_filters;if(W?.value){const oA=new df({key:"ki_fp_filters",value:W.value,id:6,at:[s,r,0],effects:this.createTextEffects(1.27,W.effects?.hide??!0)});g.properties.push(oA)}if(f){if(f.inBom!==void 0&&(g.inBom=f.inBom),f.onBoard!==void 0&&(g.onBoard=f.onBoard),f.excludeFromSim!==void 0&&(g.excludeFromSim=f.excludeFromSim),f.pinNames){const oA=new hyA;f.pinNames.offset!==void 0&&(oA.offset=Number(f.pinNames.offset)),f.pinNames.hide!==void 0&&(oA.hide=f.pinNames.hide),g.pinNames=oA}if(f.pinNumbers){const oA=new QyA;f.pinNumbers.hide!==void 0&&(oA.hide=f.pinNumbers.hide),g.pinNumbers=oA}f.embeddedFonts!==void 0&&(g._sxEmbeddedFonts=new y1(f.embeddedFonts))}let X=A.schematic_port.list().filter(oA=>oA.schematic_component_id===n.schematic_component_id);if(l){const oA=X.filter(rA=>rA.display_pin_label);oA.length>0&&(X=oA)}X.sort((oA,rA)=>(oA.pin_number||0)-(rA.pin_number||0));for(let oA=0;oA<X.length;oA++){const rA=X[oA];if(!rA)continue;const CA=new rj;CA.numberString=`${rA.pin_number||oA+1}`,CA.uuid=crypto.randomUUID(),g.pins.push(CA)}const iA=new dyA,aA=new fyA(""),tA=new yyA(`/${e?.uuid?.value||""}`);tA.reference=Q,tA.unit=1,aA.paths.push(tA),iA.projects.push(aA),g._sxInstances=iA,i.push(g)}e&&(e.symbols=i),this.finished=!0}getTextPositions(e,A){const i=(this.ctx.db.schematic_text?.list?.()?.filter(B=>B.schematic_component_id===e.schematic_component_id)||[]).find(B=>B.text&&B.text.length>0);if(i&&this.ctx.c2kMatSch){const B=Ee(this.ctx.c2kMatSch,{x:i.position.x,y:i.position.y}),C={x:A.x,y:A.y+6};return{refTextPos:B,valTextPos:C}}const n=e.symbol_name,o=wQ[n];if(!o)return{refTextPos:{x:A.x,y:A.y-6},valTextPos:{x:A.x,y:A.y+6}};let s=null,r=null;for(const B of o.primitives)B.type==="text"&&(B.text==="{REF}"?s=B:B.text==="{VAL}"&&(r=B));const a=o.center||{x:0,y:0},c=n.includes("_down")||n.includes("_up")?.15:0,I=s&&this.ctx.c2kMatSch?Ee(this.ctx.c2kMatSch,{x:e.center.x+(s.x-a.x)+c,y:e.center.y+(s.y-a.y)}):{x:A.x,y:A.y-6},l=r&&this.ctx.c2kMatSch?Ee(this.ctx.c2kMatSch,{x:e.center.x+(r.x-a.x)+c,y:e.center.y+(r.y-a.y)}):{x:A.x,y:A.y+6};return{refTextPos:I,valTextPos:l}}getComponentMetadata(e){const A=e.name||"?",t=qii(e);return e.ftype==="simple_resistor"?{reference:t,value:e.display_resistance||"R",description:"Resistor"}:e.ftype==="simple_capacitor"?{reference:t,value:e.display_capacitance||"C",description:"Capacitor"}:e.ftype==="simple_inductor"?{reference:t,value:e.display_inductance||"L",description:"Inductor"}:e.ftype==="simple_diode"?{reference:t,value:"D",description:"Diode"}:e.ftype==="simple_chip"?{reference:t,value:A,description:"Integrated Circuit"}:e.ftype==="simple_led"?{reference:t,value:e.manufacturer_part_number||"",description:"LED"}:e.ftype==="simple_switch"?{reference:t,value:e.manufacturer_part_number||"",description:"Switch"}:e.ftype==="simple_potentiometer"?{reference:t,value:e.display_max_resistance||"",description:"Potentiometer"}:{reference:t,value:A,description:"Component"}}createTextEffects(e,A=!1,t){const i=new uf;i.size={height:e,width:e};const n=t?new MJ({horizontal:t}):void 0;return new hf({font:i,hiddenText:A,justify:n})}getOutput(){if(!this.ctx.kicadSch)throw new Error("kicadSch is not initialized");return this.ctx.kicadSch}},nni=class extends Nh{_step(){const{kicadSch:e,db:A}=this.ctx,t=A.schematic_net_label?.list?.()||[];if(t.length===0){this.finished=!0;return}if(!this.ctx.c2kMatSch){this.finished=!0;return}const i=[],n=[];for(const o of t){const s=o.text||"",r=o.symbol_name;if(r){const a=this.createSymbolFromNetLabel(o,s,r);a&&i.push(a)}else{const a=this.createGlobalLabel(o,s);a&&n.push(a)}}if(e&&i.length>0){const o=e.symbols||[];e.symbols=[...o,...i]}e&&n.length>0&&(e.globalLabels=[...e.globalLabels||[],...n]),this.finished=!0}createSymbolFromNetLabel(e,A,t){if(!this.ctx.c2kMatSch)return null;const{x:i,y:n}=Ee(this.ctx.c2kMatSch,{x:e.anchor_position?.x??e.center?.x??0,y:e.anchor_position?.y??e.center?.y??0}),o=crypto.randomUUID(),s=new w1({at:[i,n,0],unit:1,excludeFromSim:!1,inBom:!0,onBoard:!0,dnp:!1,uuid:o,fieldsAutoplaced:!0}),r=`Custom:${t}`,a=new ByA(r);s._sxLibId=a;const g=t.includes("_up")||t.toLowerCase().includes("vcc"),c=g?-4:4,I=g?-6:6,l=new df({key:"Reference",value:A,id:0,at:[i,n+c,0],effects:this.createTextEffects(1.27,!1)}),B=new df({key:"Value",value:A,id:1,at:[i,n+I,0],effects:this.createTextEffects(1.27,!0)}),C=new df({key:"Footprint",value:"",id:2,at:[i-1.778,n,90],effects:this.createTextEffects(1.27,!0)}),Q=new df({key:"Datasheet",value:"~",id:3,at:[i,n,0],effects:this.createTextEffects(1.27,!0)}),E=new df({key:"Description",value:`Power/Net symbol: ${A}`,id:4,at:[i,n,0],effects:this.createTextEffects(1.27,!0)});s.properties.push(l,B,C,Q,E);const h=new rj;h.numberString="1",h.uuid=crypto.randomUUID(),s.pins.push(h);const{kicadSch:u}=this.ctx,d=new dyA,f=new fyA(""),m=new yyA(`/${u?.uuid?.value||""}`);return m.reference=A,m.unit=1,f.paths.push(m),d.projects.push(f),s._sxInstances=d,s}createGlobalLabel(e,A){if(!this.ctx.c2kMatSch||!this.ctx.kicadSch)return null;const{x:t,y:i}=Ee(this.ctx.c2kMatSch,{x:e.anchor_position?.x??e.center?.x??0,y:e.anchor_position?.y??e.center?.y??0}),n=e.anchor_side||"left",s={left:0,right:180,top:270,bottom:90}[n]||0,a={left:{horizontal:"left"},right:{horizontal:"right"},top:{vertical:"top"},bottom:{vertical:"bottom"}}[n]||{},g=this.createTextEffects(1.27,!1);return Object.keys(a).length>0&&(g.justify=new MJ(a)),new ZCt({value:A,at:[t,i,s],effects:g,uuid:crypto.randomUUID(),fieldsAutoplaced:!0})}createTextEffects(e,A=!1){const t=new uf;return t.size={height:e,width:e},new hf({font:t,hiddenText:A})}getOutput(){if(!this.ctx.kicadSch)throw new Error("kicadSch is not initialized");return this.ctx.kicadSch}},oni=class extends Nh{_step(){const{kicadSch:e,db:A}=this.ctx;if(!e)throw new Error("KicadSch instance not initialized in context");const t=A.schematic_trace.list();if(t.length===0){this.finished=!0;return}const i=[],n=[];for(const o of t){for(const s of o.edges){const r=this.createWireFromEdge(s);i.push(r)}for(const s of o.junctions){const r=this.createJunction(s);n.push(r)}}e.wires=i,e.junctions=n,this.finished=!0}createWireFromEdge(e){const A=new JCt;if(!this.ctx.c2kMatSch)throw new Error("Schematic transformation matrix not initialized in context");const t=Ee(this.ctx.c2kMatSch,{x:e.from.x,y:e.from.y}),i=Ee(this.ctx.c2kMatSch,{x:e.to.x,y:e.to.y}),n=t.x,o=t.y,s=i.x,r=i.y,a=new YC([new LQ(n,o),new LQ(s,r)]);A.points=a;const g=new qD;return g.width=0,g.type="default",A.stroke=g,A.uuid=crypto.randomUUID(),A}createJunction(e){if(!this.ctx.c2kMatSch)throw new Error("Schematic transformation matrix not initialized in context");const{x:A,y:t}=Ee(this.ctx.c2kMatSch,{x:e.x,y:e.y}),i=new TCt({at:[A,t],diameter:0});return i.uuid=crypto.randomUUID(),i}getOutput(){return this.ctx.kicadSch}},sni=class extends Nh{_step(){const{kicadSch:e}=this.ctx;if(!e)throw new Error("KicadSch instance not initialized in context");const A=new SyA,t=new zCt;t.value="/";const i=new XCt("1");t.pages=[i],A.paths=[t],e.sheetInstances=A,e.embeddedFonts=new y1(!1),this.finished=!0}getOutput(){return this.ctx.kicadSch}};function rni(e){const A=e.schematic_component.list(),t=e.schematic_trace.list();let i=1/0,n=1/0,o=-1/0,s=-1/0;for(const g of A){const c=g.size?.width??0,I=g.size?.height??0;i=Math.min(i,g.center.x-c/2),n=Math.min(n,g.center.y-I/2),o=Math.max(o,g.center.x+c/2),s=Math.max(s,g.center.y+I/2)}for(const g of t)for(const c of g.edges)i=Math.min(i,c.from.x,c.to.x),n=Math.min(n,c.from.y,c.to.y),o=Math.max(o,c.from.x,c.to.x),s=Math.max(s,c.from.y,c.to.y);i===1/0&&(i=0,n=0,o=0,s=0);const r=(i+o)/2,a=(n+s)/2;return{center:{x:r,y:a},bounds:{minX:i,minY:n,maxX:o,maxY:s}}}var mj=[{name:"A4",width:297,height:210},{name:"A3",width:420,height:297},{name:"A2",width:594,height:420},{name:"A1",width:841,height:594},{name:"A0",width:1189,height:841}];function ani(e,A,t=20){const i=e+2*t,n=A+2*t;for(let o=0;o<mj.length;o++){const s=mj[o];if(i<=s.width&&n<=s.height)return s}return mj[mj.length-1]}var mht=class{ctx;pipeline;currentStageIndex=0;finished=!1;get currentStage(){return this.pipeline[this.currentStageIndex]}constructor(e){const t=xa(e),{center:i,bounds:n}=rni(t),o=(n.maxX-n.minX)*15,s=(n.maxY-n.minY)*15,r=ani(o,s),a=r.width/2,g=r.height/2;this.ctx={db:t,circuitJson:e,kicadSch:new xyA({generator:"circuit-json-to-kicad",generatorVersion:"0.0.1"}),schematicPaperSize:r,c2kMatSch:bl(ir(a,g),fh(15,-15),ir(-i.x,-i.y))},this.pipeline=[new Tii(e,this.ctx),new eni(e,this.ctx),new ini(e,this.ctx),new nni(e,this.ctx),new oni(e,this.ctx),new sni(e,this.ctx)]}step(){if(!this.currentStage){this.finished=!0;return}this.currentStage.step(),this.currentStage.finished&&this.currentStageIndex++}runUntilFinished(){for(;!this.finished;)this.step()}getOutput(){return this.ctx.kicadSch}getOutputString(){return this.ctx.kicadSch.getString()}},gni=class extends Nh{_step(){const{kicadPcb:e,db:A}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");const i=A.pcb_board?.list()?.[0]?.num_layers??2;this.ctx.numLayers=i,e.version=20241229;const n=new ij;n.size="A4",e.paper=n;const o=new FwA;o.thickness=1.6,e.general=o;const s=new kwA;s.padToMaskClearance=0,e.setup=s;const r=new GwA,a=[new Rl({index:0,name:"F.Cu",type:"signal"})];for(let g=1;g<i-1;g++)a.push(new Rl({index:g,name:`In${g}.Cu`,type:"signal"}));a.push(new Rl({index:31,name:"B.Cu",type:"signal"})),a.push(new Rl({index:32,name:"B.Adhes",type:"user"}),new Rl({index:33,name:"F.Adhes",type:"user"}),new Rl({index:34,name:"B.Paste",type:"user"}),new Rl({index:35,name:"F.Paste",type:"user"}),new Rl({index:36,name:"B.SilkS",type:"user"}),new Rl({index:37,name:"F.SilkS",type:"user"}),new Rl({index:38,name:"B.Mask",type:"user"}),new Rl({index:39,name:"F.Mask",type:"user"}),new Rl({index:40,name:"Dwgs.User",type:"user"}),new Rl({index:41,name:"Cmts.User",type:"user"}),new Rl({index:42,name:"Eco1.User",type:"user"}),new Rl({index:43,name:"Eco2.User",type:"user"}),new Rl({index:44,name:"Edge.Cuts",type:"user"}),new Rl({index:45,name:"Margin",type:"user"}),new Rl({index:46,name:"B.CrtYd",type:"user"}),new Rl({index:47,name:"F.CrtYd",type:"user"}),new Rl({index:48,name:"B.Fab",type:"user"}),new Rl({index:49,name:"F.Fab",type:"user"})),r.definitions=a,e.layers=r,this.finished=!0}getOutput(){return this.ctx.kicadPcb}},cni=class extends Nh{_step(){const{kicadPcb:e}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");this.ctx.pcbNetMap=new Map;const A=new Map,t=this.ctx.db.source_net?.list()??[];for(const r of t){const a=r.subcircuit_connectivity_map_key||r.source_net_id;if(!a)continue;const g=r.name||r.source_net_id||"",c=g&&g.trim().length>0?g:a;A.set(a,c)}const i=this.ctx.db.source_trace?.list()??[];for(const r of i){let a=r.subcircuit_connectivity_map_key;if(!a&&r.connected_source_net_ids?.length)for(const g of r.connected_source_net_ids){const c=this.ctx.db.source_net?.get(g);if(c?.subcircuit_connectivity_map_key&&c.subcircuit_connectivity_map_key.length>0){a=c.subcircuit_connectivity_map_key;break}}if(a&&!A.has(a)){const g=r.display_name||r.source_trace_id||"",c=g&&g.trim().length>0?g:a;A.set(a,c)}}const n=Array.from(A.entries()).sort((r,a)=>r[0].localeCompare(a[0])),o=[];o.push(new fj(0,""));let s=1;for(const[r,a]of n){const g=new fj(s,a);o.push(g);const c={id:s,name:a};this.ctx.pcbNetMap.set(r,c),s++}e.nets=o,this.finished=!0}getOutput(){return this.ctx.kicadPcb}};function Ini(e){let A=0;for(let i=0;i<e.length;i++){const n=e.charCodeAt(i);A=(A<<5)-A+n,A=A&A}let t="";for(let i=0;i<4;i++){let n=A;for(let o=0;o<e.length;o++)n=(n<<5)-n+e.charCodeAt(o)+i*31,n=n&n;t+=Math.abs(n).toString(16).padStart(8,"0")}return t}function pf(e){const A=Ini(e);return`${A.slice(0,8)}-${A.slice(8,12)}-${A.slice(12,16)}-${A.slice(16,20)}-${A.slice(20,32)}`}function wj(e){const A=new uf;return e?.font?.size?A.size={width:Number(e.font.size.x),height:Number(e.font.size.y)}:A.size={width:1.27,height:1.27},e?.font?.thickness!==void 0?A.thickness=Number(e.font.thickness):A.thickness=.15,new hf({font:A})}function lni(e,A,t){if(A.properties){const i=[],n=A.properties.Reference;i.push(new OD({key:"Reference",value:n?.value??t,position:n?.at?[Number(n.at.x),Number(n.at.y),Number(n.at.rotation??0)]:[0,-3,0],layer:n?.layer??"F.SilkS",uuid:pf(`${t}-property-Reference`),effects:wj(n?.effects),hidden:n?.hide}));const o=A.properties.Value,s=o?.value??A.footprintName??"";i.push(new OD({key:"Value",value:s,position:o?.at?[Number(o.at.x),Number(o.at.y),Number(o.at.rotation??0)]:[0,3,0],layer:o?.layer??"F.Fab",uuid:pf(`${t}-property-Value`),effects:wj(o?.effects),hidden:o?.hide}));const r=A.properties.Datasheet;i.push(new OD({key:"Datasheet",value:r?.value??"",position:r?.at?[Number(r.at.x),Number(r.at.y),Number(r.at.rotation??0)]:[0,0,0],layer:r?.layer??"F.Fab",uuid:pf(`${t}-property-Datasheet`),effects:wj(r?.effects),hidden:r?.hide??!0}));const a=A.properties.Description;i.push(new OD({key:"Description",value:a?.value??"",position:a?.at?[Number(a.at.x),Number(a.at.y),Number(a.at.rotation??0)]:[0,0,0],layer:a?.layer??"F.Fab",uuid:pf(`${t}-property-Description`),effects:wj(a?.effects),hidden:a?.hide??!0})),e.properties=i}if(A.attributes&&(e.attr||(e.attr=new _yA),A.attributes.through_hole?e.attr.type="through_hole":A.attributes.smd&&(e.attr.type="smd"),A.attributes.exclude_from_pos_files!==void 0&&(e.attr.excludeFromPosFiles=A.attributes.exclude_from_pos_files),A.attributes.exclude_from_bom!==void 0&&(e.attr.excludeFromBom=A.attributes.exclude_from_bom)),A.footprintName&&(e.libraryLink=A.footprintName),A.layer&&(e.layer=A.layer),A.embeddedFonts!==void 0&&(e.embeddedFonts=new y1(A.embeddedFonts)),A.model){const i=new Bj(A.model.path);A.model.offset&&(i.offset={x:Number(A.model.offset.x),y:Number(A.model.offset.y),z:Number(A.model.offset.z)}),A.model.scale&&(i.scale={x:Number(A.model.scale.x),y:Number(A.model.scale.y),z:Number(A.model.scale.z)}),A.model.rotate&&(i.rotate={x:Number(A.model.rotate.x),y:Number(A.model.rotate.y),z:Number(A.model.rotate.z)});const n=e.models||[];e.models=[i,...n]}}function Bni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),r={top:"F.SilkS",bottom:"B.SilkS"}[i.layer]||i.layer||"F.SilkS",a=new lmA({center:{x:n,y:o},end:{x:n+i.radius,y:o},layer:r,stroke:new qD,fill:!1});a.stroke&&(a.stroke.width=i.stroke_width||.05,a.stroke.type="default"),t.push(a)}return t}function Cni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),r={top:"F.CrtYd",bottom:"B.CrtYd"}[i.layer]||"F.CrtYd",a=new lmA({center:{x:n,y:o},end:{x:n+i.radius,y:o},layer:r,stroke:new qD,fill:!1});a.stroke&&(a.stroke.width=.05,a.stroke.type="default"),t.push(a)}return t}function Qni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),s=i.width/2,r=i.height/2,g={top:"F.Fab",bottom:"B.Fab"}[i.layer]||i.layer||"F.Fab",c=new Ij({start:{x:n-s,y:o-r},end:{x:n+s,y:o+r},layer:g,stroke:new qD,fill:!1});c.stroke&&(c.stroke.width=i.stroke_width||.1,c.stroke.type="default"),t.push(c)}return t}function Eni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),s=i.width/2,r=i.height/2,a="F.Fab",g=new Ij({start:{x:n-s,y:o-r},end:{x:n+s,y:o+r},layer:a,stroke:new qD,fill:!1});g.stroke&&(g.stroke.width=i.stroke_width||.1,g.stroke.type="default"),t.push(g)}return t}function hni(e,A){const t=[];for(const i of e){const n=i.center.x-A.x,o=-(i.center.y-A.y),s=i.width/2,r=i.height/2,g={top:"F.CrtYd",bottom:"B.CrtYd"}[i.layer]||"F.CrtYd",c=new Ij({start:{x:n-s,y:o-r},end:{x:n+s,y:o+r},layer:g,stroke:new qD,fill:!1});c.stroke&&(c.stroke.width=.05,c.stroke.type="default"),t.push(c)}return t}function uni(e,A){const t=[];for(const i of e){if(!i.outline||i.outline.length<2)continue;const o={top:"F.CrtYd",bottom:"B.CrtYd"}[i.layer]||"F.CrtYd",s=i.outline.map(g=>{const c=g.x-A.x,I=-(g.y-A.y);return new LQ(c,I)}),r=new PQt;r.points=new YC(s),r.layer=o,r.fill=!1;const a=new qD;a.width=.05,a.type="default",r.stroke=a,t.push(r)}return t}function dni({textElement:e,componentCenter:A,componentRotation:t=0}){if(!e.text||!e.anchor_position)return null;const i=e.anchor_position.x-A.x,n=-(e.anchor_position.y-A.y),o=t!==0?Rm(t*Math.PI/180):Ru(),s=Ee(o,{x:i,y:n}),r={x:s.x,y:s.y},g={top:"F.SilkS",bottom:"B.SilkS"}[e.layer]||e.layer||"F.SilkS",c=(e.font_size||1)/1.5,I=new uf;I.size={width:c,height:c};const l=new hf({font:I}),B=e.ccw_rotation||0;return new emA({type:"user",text:e.text,position:{x:r.x,y:r.y,angle:B},layer:g,effects:l})}function pni(e,A,t,i){const n=[];for(const o of e){const s=dni({textElement:o,componentCenter:A,componentRotation:t});s&&(i&&o.text===i&&(s.type="reference"),n.push(s))}return n}function fni(e,A,t){const i=[];for(const n of e){const o=n.anchor_position.x-A.x,s=-(n.anchor_position.y-A.y),r=t!==0?Rm(t*Math.PI/180):Ru(),a=Ee(r,{x:o,y:s}),g=n.font_size||1,c=new uf;c.size={width:g,height:g};const I=new hf({font:c}),l=new emA({type:"user",text:n.text,position:{x:a.x,y:a.y,angle:0},layer:"F.Fab",effects:I});i.push(l)}return i}function yni(e,A){const t=[],i=e.model_step_url||e.model_wrl_url;if(!i)return t;const n=new Bj(i);if(e.position&&(n.offset={x:(e.position.x||0)-A.x,y:-((e.position.y||0)-A.y),z:e.position.z||0}),e.rotation&&(n.rotate={x:e.rotation.x||0,y:e.rotation.y||0,z:e.rotation.z||0}),e.model_unit_to_mm_scale_factor){const o=e.model_unit_to_mm_scale_factor;n.scale={x:o,y:o,z:o}}return t.push(n),t}function mni({pcbPad:e,componentCenter:A,padNumber:t,componentRotation:i=0,netInfo:n,componentId:o}){let s,r;if("x"in e&&"y"in e)s=e.x,r=e.y;else if("points"in e&&Array.isArray(e.points)){const u=e.points;s=u.reduce((d,f)=>d+f.x,0)/u.length,r=u.reduce((d,f)=>d+f.y,0)/u.length}else throw new Error("Pad must have either x/y coordinates or points array");const a=bl(i!==0?Rm(i*Math.PI/180):{a:1,b:0,c:0,d:1,e:0,f:0},fh(1,-1),ir(-A.x,-A.y)),g=Ee(a,{x:s,y:r}),I={top:"F.Cu",bottom:"B.Cu"}[e.layer]||"F.Cu";let l,B,C,Q;if(e.shape==="circle")l="circle",B=["radius"in e?e.radius*2:.5,"radius"in e?e.radius*2:.5];else if(e.shape==="polygon"&&"points"in e){const u=e.points,d=bl(fh(1,-1),ir(-s,-r)),f=u.map(w=>{const D=Ee(d,{x:w.x,y:w.y});return new LQ(D.x,D.y)}),m=new zyA;m.contours=[new YC(f)],m.width=0,m.filled=!0,Q=new bQt,Q.addGraphic(m),l="custom",C=new cQt,C.anchor="circle",B=[.2,.2]}else l="rect",B=["width"in e?e.width:.5,"height"in e?e.height:.5];const E=`pad:${o}:${t}:${g.x},${g.y}`,h=new cj({number:String(t),padType:"smd",shape:l,at:[g.x,g.y,0],size:B,layers:[`${I}`,`${I==="F.Cu"?"F":"B"}.Paste`,`${I==="F.Cu"?"F":"B"}.Mask`],uuid:pf(E)});return C&&(h.options=C),Q&&(h.primitives=Q),n&&(h.net=new qyA(n.id,n.name)),h}function wni(e,A,t,i,n,o){const s=[];let r=n;for(const a of e){const g=o(a.pcb_port_id),c=mni({pcbPad:a,componentCenter:A,padNumber:r,componentRotation:t,netInfo:g,componentId:i});s.push(c),r++}return{pads:s,nextPadNumber:r}}function Dni({platedHole:e,componentCenter:A,padNumber:t,componentRotation:i=0,netInfo:n,componentId:o}){if(!("x"in e&&"y"in e))return null;const s=e.x-A.x,r=-(e.y-A.y),a=i!==0?Rm(i*Math.PI/180):Ru(),g=Ee(a,{x:s,y:r});let c="circle",I,l,B=0;const C="hole_offset_x"in e||"hole_offset_y"in e;let Q;if(C){const u={x:e.hole_offset_x??0,y:e.hole_offset_y??0};(u.x!==0||u.y!==0)&&(Q=Ee(a,{x:-u.x,y:u.y}))}e.shape==="circle"?(c="circle",I=[e.outer_diameter,e.outer_diameter],l=new WD({diameter:e.hole_diameter,offset:Q})):e.shape==="pill"||e.shape==="oval"?(c="oval",I=[e.outer_width,e.outer_height],l=new WD({oval:!0,diameter:e.hole_width,width:e.hole_height,offset:Q})):e.shape==="pill_hole_with_rect_pad"?(c="rect",I=[e.rect_pad_width,e.rect_pad_height],l=new WD({oval:!0,diameter:e.hole_width,width:e.hole_height,offset:Q})):e.shape==="circular_hole_with_rect_pad"?(c="rect",I=[e.rect_pad_width,e.rect_pad_height],l=new WD({diameter:e.hole_diameter,offset:Q})):e.shape==="rotated_pill_hole_with_rect_pad"?(c="rect",I=[e.rect_pad_width,e.rect_pad_height],l=new WD({oval:!0,diameter:e.hole_width,width:e.hole_height,offset:Q}),B=e.rect_ccw_rotation||0):(c="circle",I=[1.6,1.6],l=new WD({diameter:.8,offset:Q}));const E=`thruhole:${o}:${t}:${g.x},${g.y}`,h=new cj({number:String(t),padType:"thru_hole",shape:c,at:[g.x,g.y,B],size:I,drill:l,layers:["*.Cu","*.Mask"],removeUnusedLayers:!1,uuid:pf(E)});return n&&(h.net=new qyA(n.id,n.name)),h}function Sni(e,A,t,i,n,o){const s=[];let r=n;for(const a of e){const g=o(a.pcb_port_id),c=Dni({platedHole:a,componentCenter:A,padNumber:r,componentRotation:t,netInfo:g,componentId:i});c&&(s.push(c),r++)}return{pads:s,nextPadNumber:r}}function bni({pcbHole:e,componentCenter:A,componentRotation:t=0}){if(!("x"in e&&"y"in e))return null;const i=e.x-A.x,n=-(e.y-A.y),o=t!==0?Rm(t*Math.PI/180):Ru(),s=Ee(o,{x:i,y:n});let r="circle",a,g;if(e.hole_shape==="circle"){r="circle";const c=e.hole_diameter;a=[c,c],g=new WD({diameter:c})}else if(e.hole_shape==="oval"){r="oval";const c=e.hole_width,I=e.hole_height;a=[c,I],g=new WD({oval:!0,diameter:c,width:I})}else{r="circle";const c="hole_diameter"in e?e.hole_diameter:1;a=[c,c],g=new WD({diameter:c})}return new cj({number:"",padType:"np_thru_hole",shape:r,at:[s.x,s.y,0],size:a,drill:g,layers:["*.Cu","*.Mask"],removeUnusedLayers:!1,uuid:crypto.randomUUID()})}function xni(e,A,t){const i=[];for(const n of e){const o=bni({pcbHole:n,componentCenter:A,componentRotation:t});o&&i.push(o)}return i}var _ni=class extends Nh{componentsProcessed=0;pcbComponents=[];getNetInfoForPcbPort(e){if(!e)return;const A=this.ctx.db.pcb_port?.get(e);if(!A)return;const t=A.source_port_id;if(!t)return;const i=this.ctx.db.source_port?.get(t);if(!i)return;const n=i.subcircuit_connectivity_map_key;if(n)return this.ctx.pcbNetMap?.get(n)}getCadComponentForPcbComponent(e){return(this.ctx.db.cad_component?.list()||[]).find(t=>t.pcb_component_id===e)}constructor(e,A){super(e,A),this.pcbComponents=this.ctx.db.pcb_component.list()}_step(){const{kicadPcb:e,c2kMatPcb:A}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");if(!A)throw new Error("PCB transformation matrix not initialized in context");if(this.componentsProcessed>=this.pcbComponents.length){this.finished=!0;return}const t=this.pcbComponents[this.componentsProcessed],i=t.source_component_id?this.ctx.db.source_component.get(t.source_component_id):null,n=this.getCadComponentForPcbComponent(t.pcb_component_id),o=i?RG(i,n):"Unknown",s=Ee(A,{x:t.center.x,y:t.center.y}),r=`footprint:${t.pcb_component_id}:${s.x},${s.y}`,a=new xmA({libraryLink:`tscircuit:${o}`,layer:"F.Cu",at:[s.x,s.y,t.rotation||0],uuid:pf(r)}),g=a.fpTexts,c=this.ctx.db.pcb_silkscreen_text?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];g.push(...pni(c,t.center,t.rotation||0,i?.name));const I=this.ctx.db.pcb_note_text?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];g.push(...fni(I,t.center,t.rotation||0)),a.fpTexts=g;const l=a.fpPads,B=O=>this.getNetInfoForPcbPort(O),C=this.ctx.db.pcb_smtpad?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],{pads:Q,nextPadNumber:E}=wni(C,t.center,t.rotation||0,t.pcb_component_id,1,B);l.push(...Q);const h=this.ctx.db.pcb_plated_hole?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],{pads:u}=Sni(h,t.center,t.rotation||0,t.pcb_component_id,E,B);l.push(...u);const d=this.ctx.db.pcb_hole?.list().filter(O=>O.subcircuit_id===t.subcircuit_id)||[],f=xni(d,t.center,t.rotation||0);l.push(...f),a.fpPads=l;const m=this.ctx.db.pcb_silkscreen_circle?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],w=a.fpCircles??[];w.push(...Bni(m,t.center));const D=this.ctx.db.pcb_courtyard_circle?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];w.push(...Cni(D,t.center)),a.fpCircles=w;const b=this.ctx.db.pcb_fabrication_note_rect?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],k=a.fpRects??[];k.push(...Qni(b,t.center));const x=this.ctx.db.pcb_note_rect?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];k.push(...Eni(x,t.center));const N=this.ctx.db.pcb_courtyard_rect?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[];k.push(...hni(N,t.center)),a.fpRects=k;const R=this.ctx.db.pcb_courtyard_outline?.list().filter(O=>O.pcb_component_id===t.pcb_component_id)||[],U=uni(R,t.center);if(U.length>0&&(a.fpPolys=U),n){const O=yni(n,t.center);O.length>0&&(a.models=O)}const T=t.metadata?.kicad_footprint;T&&i?.name&&lni(a,T,i.name);const Y=e.footprints;Y.push(a),e.footprints=Y,this.componentsProcessed++}getOutput(){return this.ctx.kicadPcb}},kni={top:"F.Cu",bottom:"B.Cu",inner1:"In1.Cu",inner2:"In2.Cu",inner3:"In3.Cu",inner4:"In4.Cu",inner5:"In5.Cu",inner6:"In6.Cu"};function Fni(e){return e&&(kni[e]||e)||"F.Cu"}function Gni(e){const A=["F.Cu"];for(let t=1;t<e-1;t++)A.push(`In${t}.Cu`);return A.push("B.Cu"),A}var Mni=class extends Nh{tracesProcessed=0;pcbTraces=[];constructor(e,A){super(e,A),this.pcbTraces=this.ctx.db.pcb_trace.list()}_step(){const{kicadPcb:e,c2kMatPcb:A,pcbNetMap:t}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");if(!A)throw new Error("PCB transformation matrix not initialized in context");if(this.tracesProcessed>=this.pcbTraces.length){this.finished=!0;return}const i=this.pcbTraces[this.tracesProcessed];if(!i.route||i.route.length<2){this.tracesProcessed++;return}let n=i.route[0]?.layer;for(let o=0;o<i.route.length-1;o++){const s=i.route[o],r=i.route[o+1],a=Ee(A,{x:s.x,y:s.y}),g=Ee(A,{x:r.x,y:r.y});let c;if(t){let E=i.subcircuit_connectivity_map_key;if(!E&&i.source_trace_id){const h=this.ctx.db.source_trace?.get(i.source_trace_id);if(h&&(E=h.subcircuit_connectivity_map_key,!E&&h.connected_source_net_ids?.length))for(const u of h.connected_source_net_ids){const d=this.ctx.db.source_net?.get(u);if(d?.subcircuit_connectivity_map_key){E=d.subcircuit_connectivity_map_key;break}}}if(!E&&typeof i.connection_name=="string"){const h=this.ctx.db.source_net?.get(i.connection_name);h?.subcircuit_connectivity_map_key&&(E=h.subcircuit_connectivity_map_key)}E&&(c=t.get(E))}const I=s.layer??r.layer??n,l=Fni(I),B=`segment:${a.x},${a.y}:${g.x},${g.y}:${l}:${c?.id??0}`,C=new JmA({start:{x:a.x,y:a.y},end:{x:g.x,y:g.y},layer:l,width:i.width||.25,net:new uj(c?.id??0),uuid:pf(B)}),Q=e.segments;Q.push(C),e.segments=Q,s.layer&&(n=s.layer),r.layer&&(n=r.layer)}this.tracesProcessed++}getOutput(){return this.ctx.kicadPcb}},Rni=class extends Nh{viasProcessed=0;pcbVias=[];constructor(e,A){super(e,A),this.pcbVias=this.ctx.db.pcb_via?.list()||[]}_step(){const{kicadPcb:e,c2kMatPcb:A,pcbNetMap:t}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");if(!A)throw new Error("PCB transformation matrix not initialized in context");if(this.viasProcessed>=this.pcbVias.length){this.finished=!0;return}const i=this.pcbVias[this.viasProcessed],n=Ee(A,{x:i.x,y:i.y});let o;if(t){let I=i.subcircuit_connectivity_map_key;if(!I&&i.pcb_trace_id){const l=this.ctx.db.pcb_trace?.get(i.pcb_trace_id);if(l&&("subcircuit_connectivity_map_key"in l&&(I=l.subcircuit_connectivity_map_key),!I&&l.source_trace_id)){const B=this.ctx.db.source_trace?.get(l.source_trace_id);if(B&&("subcircuit_connectivity_map_key"in B&&(I=B.subcircuit_connectivity_map_key),!I&&B.connected_source_net_ids?.length))for(const C of B.connected_source_net_ids){const Q=this.ctx.db.source_net?.get(C);if(Q?.subcircuit_connectivity_map_key){I=Q.subcircuit_connectivity_map_key;break}}}}if(!I&&i.connection_name){const l=this.ctx.db.source_net?.get(i.connection_name);l?.subcircuit_connectivity_map_key&&(I=l.subcircuit_connectivity_map_key)}I&&(o=t.get(I))}const s=this.ctx.numLayers??2,r=i.layers?i.layers.map(I=>I==="top"?"F.Cu":I==="bottom"?"B.Cu":`In${I.replace("inner","")}.Cu`):Gni(s),a=`via:${n.x},${n.y}:${i.outer_diameter||.8}:${i.hole_diameter||.4}:${o?.id??0}`,g=new LwA({at:[n.x,n.y],size:i.outer_diameter||.8,drill:i.hole_diameter||.4,layers:r,net:new vwA(o?.id??0),uuid:pf(a)}),c=e.vias;c.push(g),e.vias=c,this.viasProcessed++}getOutput(){return this.ctx.kicadPcb}};function Nni({textElement:e,c2kMatPcb:A}){if(!e.text||!e.anchor_position)return null;const t=Ee(A,{x:e.anchor_position.x,y:e.anchor_position.y}),n={top:"F.Fab",bottom:"B.Fab"}[e.layer]||e.layer||"F.Fab",o=(e.font_size||1)/1.5,s=new uf;s.size={width:o,height:o};const r=new MJ,a=e.anchor_alignment||"center";switch(a){case"top_left":r.horizontal="left",r.vertical="top";break;case"top_right":r.horizontal="right",r.vertical="top";break;case"bottom_left":r.horizontal="left",r.vertical="bottom";break;case"bottom_right":r.horizontal="right",r.vertical="bottom";break}const g=new hf({font:s});a!=="center"&&(g.justify=r);const c=new Wg([t.x,t.y,0]),I=new hj({text:e.text,layer:n,effects:g});return I.position=c,I}function vni({textElement:e,c2kMatPcb:A}){if(!e.text||!e.anchor_position)return null;const t=Ee(A,{x:e.anchor_position.x,y:e.anchor_position.y}),n={top:"F.SilkS",bottom:"B.SilkS"}[e.layer]||e.layer||"F.SilkS",o=(e.font_size||1)/1.5,s=new uf;s.size={width:o,height:o};const r=new MJ,a=e.anchor_alignment||"center";switch(a){case"top_left":r.horizontal="left",r.vertical="top";break;case"top_right":r.horizontal="right",r.vertical="top";break;case"bottom_left":r.horizontal="left",r.vertical="bottom";break;case"bottom_right":r.horizontal="right",r.vertical="bottom";break}const g=new hf({font:s});a!=="center"&&(g.justify=r);const c=e.ccw_rotation||0,I=new Wg([t.x,t.y,c]),l=new hj({text:e.text,layer:n,effects:g});return l.position=I,l}var Lni=class extends Nh{_step(){const{kicadPcb:e,c2kMatPcb:A}=this.ctx;if(!e)throw new Error("KicadPcb instance not initialized in context");if(!A)throw new Error("PCB transformation matrix not initialized in context");const t=this.ctx.db.pcb_silkscreen_path?.list()||[];for(const s of t)if(!(!s.route||s.route.length<2))for(let r=0;r<s.route.length-1;r++){const a=s.route[r],g=s.route[r+1];if(!a||!g)continue;const c=Ee(A,{x:a.x,y:a.y}),I=Ee(A,{x:g.x,y:g.y}),B={top:"F.SilkS",bottom:"B.SilkS"}[s.layer]||s.layer||"F.SilkS",C=new Ej({start:{x:c.x,y:c.y},end:{x:I.x,y:I.y},layer:B,width:s.stroke_width||.15}),Q=e.graphicLines;Q.push(C),e.graphicLines=Q}const i=this.ctx.db.pcb_silkscreen_text?.list().filter(s=>!s.pcb_component_id)||[];for(const s of i){const r=vni({textElement:s,c2kMatPcb:A});if(r){const a=e.graphicTexts;a.push(r),e.graphicTexts=a}}const n=this.ctx.db.pcb_fabrication_note_text?.list()||[];for(const s of n){const r=Nni({textElement:s,c2kMatPcb:A});if(r){const a=e.graphicTexts;a.push(r),e.graphicTexts=a}}const o=this.ctx.db.pcb_board?.list()||[];if(o.length>0){const s=o[0];if(!s){this.finished=!0;return}let r;if(s.outline&&s.outline.length>0)r=s.outline;else{const g=s.width?s.width/2:0,c=s.height?s.height/2:0;r=[{x:s.center.x-g,y:s.center.y-c},{x:s.center.x+g,y:s.center.y-c},{x:s.center.x+g,y:s.center.y+c},{x:s.center.x-g,y:s.center.y+c}]}const a=r.map(g=>Ee(A,g));for(let g=0;g<a.length;g++){const c=a[g],I=a[(g+1)%a.length];if(!c||!I)continue;const l=new Ej({start:{x:c.x,y:c.y},end:{x:I.x,y:I.y},layer:"Edge.Cuts",width:.1}),B=e.graphicLines;B.push(l),e.graphicLines=B}}this.finished=!0}getOutput(){return this.ctx.kicadPcb}},wht=class{ctx;pipeline;currentStageIndex=0;finished=!1;get currentStage(){return this.pipeline[this.currentStageIndex]}constructor(e){this.ctx={db:xa(e),circuitJson:e,kicadPcb:new UwA({generator:"circuit-json-to-kicad",generatorVersion:"0.0.1"}),c2kMatPcb:bl(ir(100,100),fh(1,-1))},this.pipeline=[new gni(e,this.ctx),new cni(e,this.ctx),new _ni(e,this.ctx),new Mni(e,this.ctx),new Rni(e,this.ctx),new Lni(e,this.ctx)]}step(){if(!this.currentStage){this.finished=!0;return}this.currentStage.step(),this.currentStage.finished&&this.currentStageIndex++}runUntilFinished(){for(;!this.finished;)this.step()}getOutput(){return this.ctx.kicadPcb}getOutputString(){return this.ctx.kicadPcb.getString()}},Uni=class{ctx;project;constructor(e,A={}){const t=A.projectName??e?.project?.name??"circuit-json-project",i=A.schematicFilename??`${t}.kicad_sch`,n=A.pcbFilename??`${t}.kicad_pcb`,o=new Date().toISOString();this.ctx={db:xa(e),circuitJson:e},this.project={version:1,head:{generator:"circuit-json-to-kicad",generator_version:"0.0.1",project_name:t,created:o,modified:o},meta:{version:1},text_variables:{},libraries:{pinned_symbol_libs:[],pinned_footprint_libs:[]},boards:[],cvpcb:{meta:{version:0}},erc:{meta:{version:0},erc_exclusions:[]},net_settings:{meta:{version:1},last_net_id:0,classes:[]},pcbnew:{page_layout_descr_file:"",last_paths:{}},schematic:{meta:{version:1},page_layout_descr_file:"",last_opened_files:[i]},board:{meta:{version:1},last_opened_board:n},sheets:[[Math.random().toString(36).substring(2,15),"Root"]]}}runUntilFinished(){}getOutput(){return this.project}getOutputString(){return`${JSON.stringify(this.project,null,2)}
|
|
5829
|
+
`}},Hni=class extends Nh{_step(){const e=new mht(this.ctx.circuitJson);e.runUntilFinished(),this.ctx.kicadSchString=e.getOutputString();const A=new wht(this.ctx.circuitJson);A.runUntilFinished(),this.ctx.kicadPcbString=A.getOutputString(),this.finished=!0}getOutput(){return this.ctx.libraryOutput}},Yni=class extends Nh{isCustomSymbol(e){return e?.startsWith("Custom:")??!1}_step(){const e=this.ctx.kicadSchString,A=this.ctx.fpLibraryName??"tscircuit";if(!e)throw new Error("Schematic content not available. Run GenerateKicadSchAndPcbStage first.");const t=new Map;try{const n=hht(e).find(r=>r instanceof xyA);if(!n){this.ctx.symbolEntries=[],this.finished=!0;return}const o=n.libSymbols;if(!o){this.ctx.symbolEntries=[],this.finished=!0;return}const s=o.symbols??[];for(const r of s){const a=this.isCustomSymbol(r.libraryId),g=this.sanitizeSymbolName(r.libraryId);t.has(g)||(r.libraryId=g,this.updateFootprintProperty(r,A),a||this.snapPinPositionsToGrid(r),t.set(g,{symbolName:g,symbol:r,isBuiltin:!a}))}}catch(i){console.warn("Failed to parse schematic for symbol extraction:",i)}this.ctx.symbolEntries=Array.from(t.values()),this.finished=!0}updateFootprintProperty(e,A){const t=e.properties??[];for(const i of t)if(i.key==="Footprint"&&i.value){const n=i.value.split(":");n.length>1?i.value=`${A}:${n[1]}`:i.value.trim()&&(i.value=`${A}:${i.value}`)}}sanitizeSymbolName(e){if(!e)return"symbol";const A=e.split(":");return(A.length>1?A[1]:A[0])?.replace(/[\\\/]/g,"-").trim()||"symbol"}snapPinPositionsToGrid(e){for(const t of e.subSymbols??[]){for(const i of t.pins??[])i.at&&(i.at.x=Math.round(i.at.x/1.27)*1.27,i.at.y=Math.round(i.at.y/1.27)*1.27);for(const i of t.polylines??[])if(i.points?.points)for(const n of i.points.points)"x"in n&&"y"in n&&(n.x=Math.round(n.x/1.27)*1.27,n.y=Math.round(n.y/1.27)*1.27)}}getOutput(){return this.ctx.libraryOutput}},Jni=20240108,Tni="pcbnew",Kni="8.0";function Pni(e){const A=e.split(/[/\\]/);return A[A.length-1]||e}var qni=class extends Nh{findCustomFootprintNames(){const e=new Set,A=this.ctx.db.cad_component?.list()??[],t=this.ctx.db.source_component;for(const i of A)if(!i.footprinter_string){const n=i.source_component_id?t?.get(i.source_component_id):null;if(n){const o=RG(n,i);e.add(o);const s=this.ctx.circuitJson.find(r=>r.type==="pcb_component"&&r.source_component_id===i.source_component_id);s&&s.type==="pcb_component"&&s.metadata?.kicad_footprint?.footprintName&&e.add(s.metadata.kicad_footprint.footprintName)}}return e}_step(){const e=this.ctx.kicadPcbString,A=this.ctx.fpLibraryName??"tscircuit";if(!e)throw new Error("PCB content not available. Run GenerateKicadSchAndPcbStage first.");const t=this.findCustomFootprintNames(),i=new Map;try{const o=hht(e).find(r=>r instanceof UwA);if(!o){this.ctx.footprintEntries=[],this.finished=!0;return}const s=o.footprints??[];for(const r of s){const a=this.sanitizeFootprint({footprint:r,fpLibraryName:A,customFootprintNames:t});i.has(a.footprintName)||i.set(a.footprintName,a)}}catch(n){console.warn("Failed to parse PCB for footprint extraction:",n)}this.ctx.footprintEntries=Array.from(i.values()),this.finished=!0}sanitizeFootprint({footprint:e,fpLibraryName:A,customFootprintNames:t}){const n=(e.libraryLink??"footprint").split(":"),o=(n.length>1?n[1]:n[0])?.replace(/[\\\/]/g,"-").trim()||"footprint",s=!t.has(o);if(e.libraryLink=o,e.position=Wg.from([0,0,0]),e.locked=!1,e.placed=!1,e.version=Jni,e.generator=Tni,e.generatorVersion=Kni,e.descr||(e.descr=""),e.tags||(e.tags=""),e.embeddedFonts||(e.embeddedFonts=new y1(!1)),!e.attr){const d=new _yA,f=(e.fpPads??[]).map(m=>m.padType);f.some(m=>m.includes("thru_hole"))?d.type="through_hole":f.some(m=>m.includes("smd"))&&(d.type="smd"),e.attr=d}e.uuid=void 0,e.path=void 0,e.sheetfile=void 0,e.sheetname=void 0;const r=new uf;r.size={width:1.27,height:1.27},r.thickness=.15;const a=new hf({font:r}),g=e.fpPads??[];let c=0,I=0;for(const d of g){const f=d.at,m=d.size;if(f&&m){const w=f.y??0,D=m.height??0,b=w-D/2,k=w+D/2;c=Math.min(c,b),I=Math.max(I,k)}}const l=c-.5,B=I+.5;e.properties=[new OD({key:"Reference",value:"REF**",position:[0,l,0],layer:"F.SilkS",uuid:pf(`${o}-property-Reference`),effects:a}),new OD({key:"Value",value:"Val**",position:[0,B,0],layer:"F.Fab",uuid:pf(`${o}-property-Value`),effects:a}),new OD({key:"Datasheet",value:"",position:[0,0,0],layer:"F.Fab",hidden:!0,uuid:pf(`${o}-property-Datasheet`),effects:a}),new OD({key:"Description",value:"",position:[0,0,0],layer:"F.Fab",hidden:!0,uuid:pf(`${o}-property-Description`),effects:a})];const C=e.fpTexts??[];for(const d of C)d.uuid=void 0,d.type==="reference"?d.text="REF**":d.type==="value"&&d.text.trim().length===0&&(d.text=o);e.fpTexts=C;const Q=e.fpPads??[];for(let d=0;d<Q.length;d++){const f=Q[d];f&&(f.uuid=pf(`${o}-pad-${f.number??d}`),f.net=void 0)}e.fpPads=Q;const E=e.models??[],h=[],u=[];for(const d of E)if(d.path){const f=Pni(d.path),m=`../../3dmodels/${A}.3dshapes/${f}`,w=new Bj(m);d.offset&&(w.offset=d.offset),d.scale&&(w.scale=d.scale),d.rotate&&(w.rotate=d.rotate),h.push(w),u.push(d.path)}return e.models=h,{footprintName:o,kicadModString:e.getString(),model3dSourcePaths:u,isBuiltin:s}}getOutput(){return this.ctx.libraryOutput}},Oni=20211014,Wni="circuit-json-to-kicad",Zni=class extends Nh{_step(){const e=this.ctx.symbolEntries??[],A=this.generateSymbolLibrary(e);this.ctx.libraryOutput||(this.ctx.libraryOutput={kicadSymString:"",symbols:[],footprints:[],fpLibTableString:"",symLibTableString:"",model3dSourcePaths:[]}),this.ctx.libraryOutput.kicadSymString=A,this.finished=!0}generateSymbolLibrary(e){return new LCt({version:Oni,generator:Wni,symbols:e.map(t=>t.symbol)}).getString()}getOutput(){return this.ctx.libraryOutput}},Vni=class extends Nh{_step(){const e=this.ctx.libraryName??"tscircuit",A=this.ctx.fpLibraryName??"tscircuit",t=this.ctx.footprintEntries??[],i=this.ctx.symbolEntries??[],n=new Set;for(const r of t)for(const a of r.model3dSourcePaths)n.add(a);const o=this.generateFpLibTable(A),s=this.generateSymLibTable(e);this.ctx.libraryOutput||(this.ctx.libraryOutput={kicadSymString:"",symbols:[],footprints:[],fpLibTableString:"",symLibTableString:"",model3dSourcePaths:[]}),this.ctx.libraryOutput.symbols=i,this.ctx.libraryOutput.footprints=t,this.ctx.libraryOutput.fpLibTableString=o,this.ctx.libraryOutput.symLibTableString=s,this.ctx.libraryOutput.model3dSourcePaths=Array.from(n),this.finished=!0}generateFpLibTable(e){return`(fp_lib_table
|
|
5830
5830
|
(version 7)
|
|
5831
5831
|
(lib (name "${e}") (type "KiCad") (uri "\${KIPRJMOD}/${e}.pretty") (options "") (descr "Generated by circuit-json-to-kicad"))
|
|
5832
5832
|
)
|